| | |
| | | #define MSG_WTAG 6 |
| | | #define MSG_PWTAG 8 |
| | | #define MSG_REGTAGRESPONSE 0x0b |
| | | #define MSG_TAGPOS 0x0D |
| | | |
| | | #define CMD_READ 1 |
| | | #define CMD_WRITE 2 |
| | |
| | | } |
| | | u8 remotetag_para[30],remotetag_paralen; |
| | | u8 remotesend_state=0; |
| | | extern u16 taglist_pos; |
| | | uint16_t configremotetagID; |
| | | struct regtag_structure regtag_map; |
| | | struct tagpos_structure tagpos[50]; |
| | | void UsartParseDataHandler(uint8_t data) |
| | | { |
| | | static UsartRecvPackState usart_receive_state = UsartReceiveWaitHead0; |
| | |
| | | if(((data + checksum)&0xff) == 0xFF) //鏍¢獙閫氳繃 |
| | | { |
| | | switch(pack_msgtype) |
| | | { |
| | | {uint16_t serial_tag_id_recv; |
| | | case MSG_RW: |
| | | pack_cmd = mUsartReceivePack[0]; |
| | | pack_index = mUsartReceivePack[1]; |
| | |
| | | regtag_map.index++; |
| | | if(regtag_map.index==MAX_REGTAGNUM) |
| | | {regtag_map.index = 0;} |
| | | regtag_map.remain_time[regtag_map.index]=5; |
| | | memcpy(®tag_map.tagid[regtag_map.index],&mUsartReceivePack[0],2); |
| | | memcpy(®tag_map.tag_frequency[regtag_map.index],&mUsartReceivePack[2],2); |
| | | memcpy(®tag_map.tag_slotpos[regtag_map.index],&mUsartReceivePack[4],2); |
| | | break; |
| | | case MSG_TAGPOS: |
| | | memcpy(&serial_tag_id_recv,&mUsartReceivePack[0],2); |
| | | taglist_pos=CmpTagInList(serial_tag_id_recv); |
| | | tagpos[taglist_pos].tagid = serial_tag_id_recv; |
| | | memcpy(&tagpos[taglist_pos].baoxu,&mUsartReceivePack[2],2); |
| | | memcpy(&tagpos[taglist_pos].pos,&mUsartReceivePack[4],12); |
| | | break; |
| | | } |
| | | SendConfigConfirm(pack_msgtype,pack_length); |
| | | } |