你好,
我们的设置有一个外部MCU,它通过UART连接到DA14580。DA14580和MCU使用我们设计的协议相互通信。
DA14580正在等待UART读取5个字节标题。MCU发送具有data_length的标题(5字节)。然后,DA14580将UART_RED与要接收的data_length字节进行。
观察:
假设,MCU必须发送5个字节标题和32字节数据。
UART HW使用的内部缓冲区似乎是16个字节。因为我们所看到的是DA14580正确地接收标题,然后尝试在DA14580的UART HW缓冲区中存在的某些部分数据,然后从未调用读取回调。32个字节永远不会完全读取。
如果在从MCU接收到实际数据之前调用的UART读取32个字节的UART,则整个读取成功,则读取回调已正确执行。
在读取标题后,我们还尝试从DA14580读取一个字节。在这种情况下,会发生什么,(16 - 5)IE逐个读取11个字节。虽然,DA14580从未收到其他字节,尽管它们已被MCU发送。
似乎是DA14580 UART的问题。你能否检查和恢复。
注意:我们还启用了HW级别流量控制,并仍然看到了这个问题。可以请确认HW流控制是否正常工作,并使用API UART_FLOW_ON()打开
- hrishikesh.
设备:
Hello Hrishikesh,
我目前正在调查这个问题,并将提供更新来解决这个问题。
最好的,
LC.
Hello Hrishikesh,
硬件FIFO具有16个字节,并且根据标准提供1,4,8和14字节的中断。您使用的是当前的中断水平是多少?如果您在当前的中断级别遇到问题,那么您可以执行以下选项
禁用FIFO并正常从接收器缓冲区读取数据。这可以通过监视RX数据可移中断和RX超时中断来实现。这样你就可以控制你拍摄多少数据。基于标题中的长度字段,您可以读取多个字节的递增。
另一个选项是配置RTL中断以触发FIFO中收到的每个字节,包括接收标题(以较低的速度工作最佳(最佳)。这样,您将根据您的需求读取数据。
请提供一些更有洞察力,如当前的波特率,即RTL中断等,以及如何阅读第一个标题,然后是下一个数据,这将在找出实际问题时得到很多帮助。如果您有任何疑虑,请告诉我
最好的,
LC.
解决了UART相关问题。问题是UART流控制未启用。
我们使用UART_FLOW_ON()API调用UART_INIT()后
这应该在SDK标题文件中记录在UART_FLOW_ON()中:在UART_INIT()之前需要调用此API以生效。
你好Dhrishi,
的顺序UART_FLOW_ON()和UART_INIT()无论要启用硬件流控件是否有关。应该有一些可能发生的原因。
请确认您面临的问题是否完全解决。
最好的,
LC.
是的。我们面临的问题完全解决。虽然,当我互换UART_FLOW_ON()和UART_INIT()时,我可以看到流量控制没有生效。
无论如何,我会再次在一次新的观察/调查结果中再次尝试并更新。
谢谢,
hrishikesh.
Hello Hrishikesh,
很高兴听到它被解决了。如果未指定并确保在相关地点更新,我将审核它。
最好的,
LC.
嗨LC,
我也是从外部MCU读取的UART的类似问题。
阅读此帖子后,我通过调用UART_INIT()之后调用UART_FLOW_ON()来尝试。这没有帮助我。
我拥有的是一个UART2设置,可以在57.6kbps的外部MCU通信。将数据从DA发送到外部MCU很好。它能够接收DA发送的所有内容。但是,当从外部MCU接收到DA的UART数据有每个事务的帧错误。我附上了Saleae捕获让你看看。
在捕获中,DataToQPI是从DA到外部MCU发送的数据,而DataFromQPI是从外部MCU发送到DA的数据。
谢谢,
- khai
嗨LC,
我想出了我的问题。我必须将RX引脚配置为Pull_up以下:
gpio_configurepin(gpio_uart2_rx_port,gpio_uart2_rx_pin,input_pullup,pid_uart2_rx,false);
谢谢,
- khai
嗨LC,
既然RX Pull_up线路脱离了路,我就会在问题上读取RX行上的数据进入DA缓冲区。下面是我在UART2中读取RX数据的代码:
BOOL READFROMCIIF(字节*数据,int data_len){
bool r = true;
短IDX = 0;
int nbytes = 0,bytes_left = data_len;
而(idx//等待1ms for FPGA以在CI UART数据寄存器中加载字节
qpispincounter(tick_1msec);
//了解要发送到ASIC的CI输出缓冲区的字节数
// khai:尝试使用ci_output_buffer_sz而不是rx_callback_size
if(bytes_left> ci_output_buffer_sz)
nbytes = ci_output_buffer_sz;
别的
nbytes = bytes_left;
//删除将从剩余总量检索的字节
bytes_left - = nbytes;
//读取ASIC的字节
UART2_READ(数据+ IDX,NBYTES,NBULL);
Idx + = nbytes;
}
返回r;
}
在rx_callback_size = 8字节时,我已经使用了CI_OUTPUT_BUFFER_SZ = 256字节。调用者对此功能请求读取140字节。我看过rx线的leaee,所有140字节都在附加的logicdata文件中的电线上。但是,当上述功能遍历循环读取时,读入缓冲区的字节与电线上的内容不同。
当我使用rx_callback_size时,前16个字节看起来很好。之后,内存中的字节丢失并跳到接下来的几个字节。然后,其余的是在时间点的所有0。使用CI_OUTPUT_BUFFER_SZ时,我只会获得前16个字节,其余的是0s。
以某种方式指定每个读取的读取缓冲区大小似乎很重要。这必须正确阅读数据吗?
谢谢,
- khai
凯瑟你好,
我无法在我最后重现这个问题。所以我并不完全确定在这种情况下出错了。但是,我会提出几个建议。
1.请检查您是否相应地分配GPIO并且连接是正确的。我认为它们是正确的,因为您可以看到逻辑分析仪上的数据。
2.我附加一个来自实际驱动程序修改的示例驱动程序,以解决RX FIFO调整。尝试使用此驱动程序代替当前的驱动程序并检查是否解决了问题。请注意,这不是官方发布驱动程序,仅用于测试目的。
最好的,
LC.
嗨LC,
在函数UART2_INIT中的新修改_uart2.c文件中(uint16_t baudr,uint8_t dlf_value,uint8_t模式),第二个参数dlf_value的设置是什么?我的UART2.c文件中不需要此参数。
你不应该还要发给我UART2.H文件吗?
谢谢,
- khai
凯瑟你好,
请在此处使用附加的头文件。最新版本中的UART驱动程序中几乎没有更新。
最好的,
LC.