CTI on LPC55S06 for Modbus

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

CTI on LPC55S06 for Modbus

560 次查看
smitz96
Junior Contributor III

Hi NXP Community,

I am implementing a Modbus RTU Slave on the LPC55S06. According to the Modbus specification, I need to detect a 3.5 character silent interval to signal the End of Frame (EOF).

I want to avoid generating an interrupt for every received byte to reset a software timer, as this is too CPU-intensive at high baud rates. I noticed the Flexcomm USART on this device does not have a dedicated "Character Timeout Interrupt" (CTI) that can be set to a specific character-width threshold (like 3.5).

  1. Is there a hidden hardware feature in the Flexcomm USART or FIFO to trigger an interrupt after a programmable period of RX inactivity?

  2. If not, what is the recommended "low-overhead" way to use DMA + CTIMER to detect the 3.5 char gap?

Any example code or application notes for the LPC55xx family regarding this would be greatly appreciated.

标签 (1)
标记 (4)
0 项奖励
回复
1 回复

461 次查看
Harry_Zhang
NXP Employee
NXP Employee

Hi @smitz96 

No — the Flexcomm USART on LPC55S06 does not contain any hardware "character timeout" or programmable RX‑idle interrupt.

I think you can use USART + DMA + CTIMER  for RX‑idle detection.

USART RX DMA continuously moves data from FIFO into a circular buffer.

CTIMER  generates interrupt when no data arrives.

You configure a timer for 3.5 character times.
On every RX DMA event, you restart the CTIMER
If timer expires, it means:
No bytes for 3.5 chars   Modbus frame end detected (EOF).
 
BR
Harry
 
0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2321916%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ELPC55S06%20%E4%B8%8A%E7%94%A8%E4%BA%8E%20Modbus%20%E7%9A%84%20CTI%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2321916%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%97%A8%EF%BC%8C%E6%81%A9%E6%99%BA%E6%B5%A6%E7%A4%BE%E5%8C%BA%E3%80%81%3C%2FP%3E%3CP%3E%E6%88%91%E6%AD%A3%E5%9C%A8%20LPC55S06%20%E4%B8%8A%E5%AE%9E%E7%8E%B0%E4%B8%80%E4%B8%AA%20Modbus%20RTU%20%E4%BB%8E%E7%AB%99%E3%80%82%E6%A0%B9%E6%8D%AE%20Modbus%20%E8%A7%84%E8%8C%83%EF%BC%8C%E6%88%91%E9%9C%80%E8%A6%81%E6%A3%80%E6%B5%8B%203.5%20%E4%B8%AA%E5%AD%97%E7%AC%A6%E7%9A%84%E6%97%A0%E5%A3%B0%E9%97%B4%E9%9A%94%EF%BC%8C%E4%BB%A5%E5%8F%91%E5%87%BA%E5%B8%A7%E7%BB%93%E6%9D%9F%20(EOF)%20%E4%BF%A1%E5%8F%B7%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E6%83%B3%E9%81%BF%E5%85%8D%E4%B8%BA%E6%AF%8F%E4%B8%AA%E6%8E%A5%E6%94%B6%E5%88%B0%E7%9A%84%E5%AD%97%E8%8A%82%E7%94%9F%E6%88%90%E4%B8%AD%E6%96%AD%E6%9D%A5RESET%E8%BD%AF%E4%BB%B6%E8%AE%A1%E6%97%B6%E5%99%A8%EF%BC%8C%E5%9B%A0%E4%B8%BA%E8%BF%99%E5%9C%A8%E9%AB%98%E6%B3%A2%E7%89%B9%E7%8E%87%E4%B8%8B%E4%BC%9A%E5%8D%A0%E7%94%A8%E5%A4%AA%E5%A4%9A%E7%9A%84CPU%E3%80%82%E6%88%91%E6%B3%A8%E6%84%8F%E5%88%B0%E8%BF%99%E6%AC%BE%E8%AE%BE%E5%A4%87%E4%B8%8A%E7%9A%84%20Flexcomm%20USART%20%E6%B2%A1%E6%9C%89%E4%B8%93%E7%94%A8%20%22%20%E5%AD%97%E7%AC%A6%E8%B6%85%E6%97%B6%E4%B8%AD%E6%96%AD%20%22%20(CTI)%EF%BC%8C%E5%8F%AF%E4%BB%A5%E8%AE%BE%E7%BD%AE%E4%B8%BA%E7%89%B9%E5%AE%9A%E7%9A%84%E5%AD%97%E7%AC%A6%E5%AE%BD%E5%BA%A6%E9%98%88%E5%80%BC%EF%BC%88%E6%AF%94%E5%A6%82%203.5%EF%BC%89%E3%80%82%3C%2FP%3E%3COL%3E%3CLI%3E%3CP%3EFlexcomm%20USART%20%E6%88%96%20FIFO%20%E4%B8%AD%E6%98%AF%E5%90%A6%E6%9C%89%E9%9A%90%E8%97%8F%E7%9A%84%E7%A1%AC%E4%BB%B6%E5%8A%9F%E8%83%BD%EF%BC%8C%E5%8F%AF%E4%BB%A5%E5%9C%A8%E5%8F%AF%E7%BC%96%E7%A8%8B%E7%9A%84%20RX%20%E4%B8%8D%E6%B4%BB%E5%8A%A8%E6%97%B6%E9%97%B4%E6%AE%B5%E5%90%8E%E8%A7%A6%E5%8F%91%E4%B8%AD%E6%96%AD%EF%BC%9F%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E5%A6%82%E6%9E%9C%E6%B2%A1%E6%9C%89%EF%BC%8C%E5%BB%BA%E8%AE%AE%E4%BD%BF%E7%94%A8%E4%BB%80%E4%B9%88%22%E4%BD%8E%E5%BC%80%E9%94%80%22%20%E6%96%B9%E6%B3%95%E6%9D%A5%E4%BD%BF%E7%94%A8%20DMA%20%2B%20CTIMER%20%E6%A3%80%E6%B5%8B%203.5%20%E5%AD%97%E7%AC%A6%E9%97%B4%E9%9A%99%EF%BC%9F%3C%2FP%3E%3C%2FLI%3E%3C%2FOL%3E%3CP%3E%E5%A6%82%E6%9E%9C%E6%9C%89%20LPC55xx%20%E7%B3%BB%E5%88%97%E4%B8%AD%E4%B8%8E%E6%AD%A4%E7%9B%B8%E5%85%B3%E7%9A%84%E4%BB%BB%E4%BD%95%E7%A4%BA%E4%BE%8B%E4%BB%A3%E7%A0%81%E6%88%96%E5%BA%94%E7%94%A8%E7%AC%94%E8%AE%B0%EF%BC%8C%E6%88%91%E4%BB%AC%E5%B0%86%E4%B8%8D%E8%83%9C%E6%84%9F%E6%BF%80%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-2321916%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CLINGO-LABEL%3ELPC55xx%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2326081%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20CTI%20on%20LPC55S06%20for%20Modbus%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2326081%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F260168%22%20target%3D%22_blank%22%3E%40smitz96%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%E4%B8%8D%E6%98%AF%20%E2%80%94%20LPC55S06%20%E4%B8%8A%E7%9A%84%20Flexcomm%20USART%20%E4%B8%8D%E5%8C%85%E5%90%AB%E4%BB%BB%E4%BD%95%E7%A1%AC%E4%BB%B6%20%22%20%E5%AD%97%E7%AC%A6%E8%B6%85%E6%97%B6%20%22%20%E6%88%96%E5%8F%AF%E7%BC%96%E7%A8%8B%E7%9A%84%20Rx%E2%80%91Idle%20%E4%B8%AD%E6%96%AD%E3%80%82%3C%2FP%3E%0A%3CP%3E%E6%88%91%E8%AE%A4%E4%B8%BA%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%20USART%20%2B%20DMA%20%2B%20CTIMER%20%E8%BF%9B%E8%A1%8C%20RX%20%E7%A9%BA%E9%97%B2%E6%A3%80%E6%B5%8B%E3%80%82%3C%2FP%3E%0A%3CP%3EUSART%20RX%20DMA%20%E4%B8%8D%E6%96%AD%E5%B0%86%E6%95%B0%E6%8D%AE%E4%BB%8E%20FIFO%20%E7%A7%BB%E5%85%A5%E5%BE%AA%E7%8E%AF%E7%BC%93%E5%86%B2%E5%8C%BA%E3%80%82%3C%2FP%3E%0A%3CP%3ECTIMER%20%E5%9C%A8%E6%97%A0%E6%95%B0%E6%8D%AE%E5%88%B0%E8%BE%BE%E6%97%B6%E4%BA%A7%E7%94%9F%E4%B8%AD%E6%96%AD%E3%80%82%3C%2FP%3E%0A%3CDIV%3E%E6%82%A8%E9%85%8D%E7%BD%AE%E4%BA%86%E4%B8%80%E4%B8%AA%203.5%20%E4%B8%AA%E5%AD%97%E7%AC%A6%E6%97%B6%E9%97%B4%E7%9A%84%E8%AE%A1%E6%97%B6%E5%99%A8%E3%80%82%3C%2FDIV%3E%0A%3CDIV%3E%E5%9C%A8%E6%AF%8F%E4%B8%AA%20RX%20DMA%20%E4%BA%8B%E4%BB%B6%E4%B8%AD%EF%BC%8C%3CBR%20%2F%3E%E5%A6%82%E6%9E%9C%E8%AE%A1%E6%97%B6%E5%99%A8%E5%88%B0%E6%9C%9F%EF%BC%8C%E5%88%99%E9%87%8D%E5%90%AF%20CTIMER%EF%BC%8C%E8%BF%99%E6%84%8F%E5%91%B3%E7%9D%80%EF%BC%9A%3CBR%20%2F%3E%E6%9C%AA%E6%A3%80%E6%B5%8B%E5%88%B0%203.5%20%E4%B8%AA%E5%AD%97%E7%AC%A6%E7%9A%84%E5%AD%97%E8%8A%82%20Modbus%20%E5%B8%A7%E6%9C%AB%E7%AB%AF%20(EOF)%E3%80%82%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%0A%3CDIV%3EBR%3C%2FDIV%3E%0A%3CDIV%3E%E5%93%88%E5%88%A9%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3C%2FLINGO-BODY%3E