当前位置:文档之家› 韦根协议介绍与韦根码

韦根协议介绍与韦根码

韦根协议介绍
韦根协议读卡器系列
Wiegand协议是国际上统一的标准,是由摩托罗拉公司制定的一种通讯协议。它适用于涉及门禁控制系统的读卡器和卡片的许多特性。它有很多格式,标准的26-bit应该是最常用的格式。此外,还有34-bit、37-bit等格式。而标准26-bit格式是一个开放式的格式,这就意味着任何人都可以购买某一特定格式的HID卡,并且这些特定格式的种类是公开可选的。26-Bit格式就是一个广泛使用的工业标准,并且对所有HID的用户开放。几乎所有的门禁控制系统都接受标准的26-Bit格式。
韦根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的格式,并发送出去//原理是把每个字节的低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){one_num++;}check_temp>>=1;}wiegand[2] = wiegand[2]|(*(str+4)<<4);wiegand[2] = wiegand[2]|(*(str+5)&0x0f);//--------------------------------计算接下来的8位1的个数,为奇效验用check_temp = wiegand[2];for(i = 0;i<8;i++){if(check_temp&0x01){one_num++;}check_temp >>= 1;}//--------------------------------判断1的个数one_num%2 == 0 (odd = 1):(odd = 0);one_num = 0;//================================启动发送,用定时器做时间延时//--------------------------------韦根输出端初始化WG_DATA0 = 1;WG_DATA1 = 1;//--------------------------------发送偶效验if(even){WG_DATA1 = 0;//-------------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA1 = 1;}else{WG_DATA0 = 0;//------------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA0 = 1;}//----------------------------延时一个发送周期TR0 = 0;TH0 =(65536 - 1382)/256; //定时1500usTL0 =(65536 - 1382)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;//-------------------------------发送24位数据for(i = 0;i<24;i++){//---------------------------韦根输出端初始化WG_DATA0 = 1;WG_DATA1 = 1;if((wiegand[0])&0x80){WG_DATA1 = 0;//----------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA1 = 1;}else{WG_DATA0 = 0;//---------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA0 = 1;}(*(long*)&wiegand[0]) <<= 1;//-------------------------------延时一个发送周期TR0 = 0;TH0 =(65536 - 1382)/256; //定时1500usTL0 =(65536 - 1382)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;}//==============================发送奇效验位//------------------------------韦根输出端初始化WG_DATA0 = 1;WG_DATA1 = 1;if(odd){WG_DATA1 = 0;//-------------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA1 = 1;}else{WG_DATA0 = 0;//-------------------------延时100usTR0 = 0;TH0 =(65536 - 78)/256; //定时100usTL0 =(65536 - 78)%256;TF0 = 0;ET0 = 0;TR0 = 1;while (!TF0) { ;}TF0 = 0;WG_DATA0 = 1;}}
相关主题