CC2650如何实现串口的不定长字节接收
时间:10-02
整理:3721RD
点击:
各位大侠,如何实现串口不定长字节的接收,接收完成后自动调用回调函数
协议栈为Zstack Home 1.2.2a Sampleswitch,TI-RTOS系统
在你发送的 字节中加入协议头和协议尾,接收的时候进行判断就好了,不然的话,是不可能实现的。你没告诉接收多少,他怎么可能识别呢?
协议栈本身就支持不定长发送的,建议使用网蜂的方法重写原先的MT层函数,替换下MT_UartProcessZToolData
void MT_UartProcessZToolData ( uint8 port, uint8 event ) { uint8 flag=0,i,j=0; //flag是判断有没有收到数据,j记录数据长度 uint8 buf[128]; //串口buffer最大缓冲默认是128,我们这里用128. (void)event; // Intentionally unreferenced parameter while ((Hal_UART_RxBufLen(port))&&(j<128)) //检测串口数据是否接收完成 { HalUARTRead (port,&buf[j], 1); //把数据接收放到buf中 j++; //记录字符数 flag=1; //已经从串口接收到信息 } if(flag==1) //已经从串口接收到信息 { /* Allocate memory for the data */ //分配内存空间,为机构体内容+数据内容+1个记录长度的数据 pMsg = (mtOSALSerialData_t *)osal_msg_allocate( sizeof ( mtOSALSerialData_t )+j+1); //事件号用原来的CMD_SERIAL_MSG pMsg->hdr.event = CMD_SERIAL_MSG; pMsg->msg = (uint8*)(pMsg+1); // 把数据定位到结构体数据部分 pMsg->msg [0]= j; //给上层的数据第一个是长度 for(i=0;i<j;i++) //从第二个开始记录数据 pMsg->msg [i+1]= buf[i]; osal_msg_send( App_TaskID, (byte *)pMsg ); //登记任务,发往上层 /* deallocate the msg */ osal_msg_deallocate ( (uint8 *)pMsg ); //释放内存 } }