当前位置:文档之家› 韦根协议简介

韦根协议简介

韦根协议简介

韦根门禁通讯协议

一、前言:

Wiegand(韦根)协议是由摩托罗拉公司制定的一种通讯协议,它适用于涉及门禁控制系统的读卡器和卡

片的许多特性;其协议并没有定义通讯的波特率、也没有定义数据长度韦根格式主要定义是数据传输方

式:Data0和Data1两根数据线分别传输0和1.现在应用最多的是26bit,34 bit,36bit,44bit等等。

二、韦根数据输出的基本概念:

二、韦根数据输出由二根线组成,分别是DATA0 和 DATA1 ;二根线分别将‘0’

或‘1’输出。

输出‘0’时:DATA0线上出现负脉冲;

输出‘1’时:DATA1线上出现负脉冲;

负脉冲宽度TP=100微妙;周期TW=1600微妙

具体时序如下:

例如:数据‘01000’的时序如下:

三、韦根26位输出格式:韦根26位输出格式:

E XXXX XXXX XXXX XXXX XXXX XXXX O

前12BIT偶校验前12位后12位后12BIT奇校验

以上数据从左至右顺序发送。高位在前。

如果电卡的地区码位2个字符,即8位则可用那设置255个地区码((15x1

6)+15=255);电子卡的卡

号位4个字符,即16位则可设置65536个卡号

((15x16x16x16)+(15x16x16)+(15x16)+15= 65,535)。

以电子卡为标准26位韦根格式为例,假设电子卡号码为:

地区码:01 卡号:0001

韦根输出为:

1 0000 0001 0000 0000 0000 0001 0

前12BIT偶校验前12位后12位后12BIT奇校验

地区码卡号

四、韦根26接收:

韦根的接收对时间的实时性要求比较高,如果用查询的方法接收会出现丢帧的现象:假设查询到DATA0

为0时主程序正在指向其他任务,等主程序执行完该任务时DATA0已经变为1了,那么这样就导致了一

个0 bit丢了,这样读出的卡号肯定奇偶校验通不过,所以表现出CPU接收不到ID模块发送的卡号了。

唯一的办法是在外部中断里接收每个bit。

(仅仅在中断里获得开始接收wiegand数据还不行,因为这是尽管给开始接

收wiegand数据标志位置位

了,但是主程序还在执行其他代码而没有到达查询开始接收wiegand数据标志位这条指令)。

五、韦根接口定义:

Wiegand接口界面由三条导线组成:

DATA0:暂定,兰色,P2.5 (通常为绿色)。

DATA1:暂定,白色,P2.6 (通常为白色)。

GND:(通常为黑色), 暂定信号地。

当安装商拿到读卡器时,他们希望在读卡器和门禁控制面板的连接点(终端)上都能够看到这三个名称。

目前所有的标准型读卡器都提供可选择的Wiegand接口。这三条线负责传送Wiegand数据,也被称为

Wiegand信号。

六、特别说明:

在上述标准26位韦根格式中,只包含了电子卡HID码的低8位,即对应于韦根输出的第2位到第9位,实际上电子卡的HID码为16位。

除非特别说明,所售Census产品的韦根通讯协议均为上述标准协议。

奇/偶校验(ECC)是数据传送时采用的一种校正数据错误的一种方式,分为奇校验和偶校验两种,其原理如下:如果是采用奇校验,在传送每一个字节的时候另外附加一位作为校验位,当实际数据中“1”的个数为偶数的时候,这个校验位就是“1”,否则,这个校验位就是“0”,这样就可以保证传送的数据满足奇校验的要求。在接收方收到数据时,将按照奇校验的要求检测数据中“1”的个数,如果为奇数,表示传送正确,反之,表示传送错误。

偶校验的过程和奇校验一样,只不过是检测数据中的“1”的个数为偶数。

七、发送程序:

//------------------------------------------------------

//功能:把数组封包成韦根26的格式,并发送出去

// 原理是把每个字节的低4位取出,来计算这个字节的值

//入口:str=要封包的数组,

//出口:DATA0P3.0;DATA1=P3.1

//设计:大鹏,大鹏艾迪,2006/4/11

//------------------------------------------------------

void send_wiegand26(uchar *str)

{

//| wiegand[0] | wiegand[1] | wiegand[2] |

//| *str *(str + 1) | *(str + 2) *(str + 3)| *(str + 4) *(str + 5) |

uchar data i;

static uchar data one_num; //计算1的个数

uchar data check_temp; //韦根包奇偶效验中间暂存

bit data even; //韦根包前12位偶效验

bit data odd; //韦根包后12位齐效验

static uchar data wiegand[3]; //韦根包数据24位

//--------------------------------端口方向定义

P3M0 = 0x00; //普通I/O口

P3M1 = 0x00;

//================================数组到韦根包的转化

wiegand[0] = wiegand[0]|((*str)<<4);//原理是把每个字节的低4位取出,来计算这个字节的值

wiegand[0] = wiegand[0]|(*(str+1)&0x0f);

//--------------------------------计算前8位1的个数,为偶效验用check_temp = wiegand[0];

for(i = 0;i<8;i++)

{

if(check_temp&0x01) //(check_temp&0x01)

{

one_num++;

}

check_temp >>= 1;

}

wiegand[1] = wiegand[1]|(*(str+2)<<4);

//--------------------------------计算接下来的4位1的个数,为偶效验用

check_temp = wiegand[1];

for(i = 0;i<4;i++)

{

if(check_temp&0x80)

{

one_num++;

}

check_temp<<=1;

}

//--------------------------------判断1的个数

one_num%2 == 0 ? (even = 0):( even = 1);

one_num = 0;

wiegand[1] = wiegand[1]|(*(str+3)&0x0f);

//--------------------------------计算接下来的4位1的个数,为奇效验用

check_temp = wiegand[1];

for(i = 0;i<4;i++)

{

if(check_temp&0x01)

相关主题