韦根的接收对时间的实时性要求比较高,如果用查询的方法接收会出现丢帧的现象:假设查询到DATA0
为0时主程序正在指向其他任务,等主程序执行完该任务时DATA0已经变为1了,那么这样就导致了一
个0 bit丢了,这样读出的卡号肯定奇偶校验通不过,所以表现出CPU接收不到ID模块发送的卡号了。
唯一的办法是在外部中断里接收每个bit。 Wiegand接口界面由三条导线组成:
DATA0:暂定,兰色,P2.5 (通常为绿色)。
DATA1:暂定,白色,P2.6 (通常为白色)。
GND:(通常为黑色),暂定信号地。
当安装商拿到读卡器时,他们希望在读卡器和门禁控制面板的连接点(终端)上都能够看到这三个名称。
当前所有的标准型读卡器都提供可选择的Wiegand接口。这三条线负责传送Wiegand数据,也被称为
Wiegand信号。 //功能:把数组封包成韦根26的格式,并发送出去// 原理是把每个字节的低4位取出,来计算这个字节的值//入口:str=要封包的数组,//出口:DATA0P3.0DATA1=P3.1//设计:大鹏,大鹏艾迪,2006/4/11void delay_100us(void){//-------------------------延时100usTR0 = 0 TH0 = (65536 - 78)/256 //定时100usTL0 = (65536 - 78)%256 TF0 = 0 ET0 = 0 TR0 = 1 while (!TF0) { }}void delay_1500us(void){TR0 = 0 TH0 = (65536 - 1382)/256 //定时1500usTL0 = (65536 - 1382)%256 TF0 = 0 ET0 = 0 TR0 = 1 while (!TF0) { }}void WG_send_bit_1(void){WG_DATA1 = 0 //----------------------延时100usdelay_100us() WG_DATA1 = 1 //-------------------------------延时一个发送周期delay_1500us() }void WG_send_bit_0(void){WG_DATA0 = 0 //----------------------延时100usdelay_100us() WG_DATA1 = 1 //-------------------------------延时一个发送周期delay_1500us() }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 uchar data check_temp //韦根包奇偶效验中间暂存bit data even //韦根包前12位偶效验bit data odd //韦根包后12位齐效验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) wiegand[1] = wiegand[1]|(*(str+2)<<4) wiegand[1] = wiegand[1]|(*(str+3)&0x0f)wiegand[2] = wiegand[2]|(*(str+4)<<4) wiegand[2] = wiegand[2]|(*(str+5)&0x0f) //--------------------------------计算前12位1的个数是否为偶数,为偶效验用check_temp = wiegand[1]&0xf0 check_temp ^= wiegand[0] check_temp ^= check_temp>>4 check_temp ^= check_temp>>2 check_temp ^= check_temp>>1 even=!(check_temp&1) //--------------------------------计算后12位1的个数是否为偶数,为奇效验用check_temp = wiegand[1]&0x0f check_temp ^= wiegand[2] check_temp ^= check_temp>>4 check_temp ^= check_temp>>2 check_temp ^= check_temp>>1 odd=check_temp&1 //================================启动发送,用定时器做时间延时//--------------------------------韦根 输出端初始化WG_DATA0 = 1 WG_DATA1 = 1 //--------------------------------发送偶效验if(even){WG_send_bit_1() }else{WG_send_bit_0() }//-------------------------------发送24位数据for(i = 0i<24i++){//---------------------------韦根 输出端初始化if((wiegand[0])&0x80){WG_send_bit_1() }else{WG_send_bit_0() }(*(long*)&wiegand[0]) <<= 1 }//==============================发送奇效验位if(odd){WG_send_bit_1() }else{WG_send_bit_0() }}
Wiegand协议是国际上统一的标准,有很多格式,标准的26-bit 应该是最常用的格式。此外,还有34-bit 、37-bit 等格式。格式的含义如下:当给出这一串数字,用户并不知道这串数字的含义,但如果说这是一个电话号码的时候,那么你可能就会说:哦,028是成都的区号,而88888888是电话号码。呵呵,不错,这正是四川航空的服务热线。但是安防行业并不愿意把这些格式公开,而安防公司也常常变化这些格式来保证产品的保密性。
而标准26-bit 格式是一个开放式的格式,这就意味着任何人都可以购买某一特定格式的HID卡,并且这些特定格式的种类是公开可选的。26-Bit格式就是一个广泛使用的工业标准,并且对所有HID的用户开放。几乎所有的门禁控制系统都接受标准的26-Bit格式。
Wiegand(韦根)协议是由摩托罗拉公司制定的一种通讯协议,它适用于涉及门禁控制系统的读卡器和卡片的许多特性;其协议并没有定义通讯的波特率、也没有定义数据长度韦根格式主要定义是数据传输方式:Data0和Data1两根数据线分别传输0和1.现在应用最多的是26bit,34bit,36bit,44bit等等。
韦根26位输出格式:
E XXXX XXXX XXXX XXXX XXXX XXXX O
前12BIT偶校验前12位 后12位 后12BIT奇校验
以上数据从左至右顺序发送。高位在前。
如果电卡的地区码位2个字符,即8位则可用那设置255个地区码((15x16)+15=255);电子卡的卡
号位4个字符,即16位则可设置65535个卡号
((15x16x16x16)+(15x16x16)+(15x16)+15= 65,535)。
以电子卡为标准26位韦根格式为例,假设电子卡号码为:
地区码 :01 卡号:0001
韦根输出为:
前12BIT偶校验 前12位 后12位 后12BIT奇校验
地区码 卡号
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)