本帖最后由 香水城 于 2017-8-11 14:38 编辑
CEC 输出数据始终和输出长度不匹配
前言
客户反应使用我们的STM32F446 的CEC 库的时候,输出的数据和数据长度始终不匹配,跟电视通信不正常,如果输出的数据始终比长度多一个字节.客户试着按字节数减一去做输出,但是又不能输出一个字节的情况.
调研
首先,我们来看看CEC 发送数据的过程:
1,数据格式,包含一个起始位,header OPCODE 以及0 到14 个字节的OPERAND 数据.以及一个EOM 和ACK.
2 发送过程: 从下面两个寄存器的描述来看,当我们发送最后一个字节之前,要将EOM 置位.而每一次发送数据的第四位时候,它会发出TXBR 的请求(请求发送下一个数据)
3 发送函数: 当客户在调用下面发送函数的时候,数据跟长度不匹配.
HAL_CEC_Transmit_IT(&hcec,InitiatorAddress ,DestinationAddress, (uint8_t *)&Tab_Tx, TxSize);
例如 :发送2 个字节(TxSize=2) 0x44 和0x43,但是我在后面发觉多出来一个字节(如下图),而如果我们将TxSize 设为1,反而数据发送正确. 从上面的函数来看,并没有什么错误.它仅仅开始发送了HEADER 和开始发送.
4 中断处理函数:
从上面的函数来看当我们发送字节数大于0 的时候,他每次发送一个字节,而当等于0 的时候它置位EOM,并且再次放了一个字节进入TXDR,看到这里就明白了,错误出现在这里了,既然是发送字节为0 了,为什么还要放一个字节呢?这里应该是最后一个字节的时候,置位EOM 和发送一个字节数据,而当再次中断来这里SIZE 变为0 的时候什么都不做.
解决方法:
按照下面的方法修改中断处理函数,送给客户验证,能够正常发送数据并且跟电视通信正常
对应的PDF: CEC 输出的数据和数据长度始终不匹配
更多实战经验请看:【ST MCU实战经验汇总贴】
|