CTI on LPC55S06 for Modbus

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

CTI on LPC55S06 for Modbus

512件の閲覧回数
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 返信

413件の閲覧回数
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%3EModbus%E7%94%A8LPC55S06%E4%B8%8A%E3%81%AECTI%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2321916%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3ENXP%E3%82%B3%E3%83%9F%E3%83%A5%E3%83%8B%E3%83%86%E3%82%A3%E3%81%AE%E7%9A%86%E6%A7%98%E3%80%81%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%82%3C%2FP%3E%3CP%3ELPC55S06%20%E3%81%AB%20Modbus%20RTU%20%E3%82%B9%E3%83%AC%E3%83%BC%E3%83%96%E3%82%92%E5%AE%9F%E8%A3%85%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82Modbus%20%E4%BB%95%E6%A7%98%E3%81%AB%E3%82%88%E3%82%8C%E3%81%B0%E3%80%81%E3%83%95%E3%83%AC%E3%83%BC%E3%83%A0%E3%81%AE%E7%B5%82%E4%BA%86%20(EOF)%20%E3%82%92%E9%80%9A%E7%9F%A5%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%203.5%20%E6%96%87%E5%AD%97%E3%81%AE%E7%84%A1%E9%9F%B3%E9%96%93%E9%9A%94%E3%82%92%E6%A4%9C%E5%87%BA%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E9%AB%98%E3%81%84%E3%83%9C%E3%83%BC%E3%83%AC%E3%83%BC%E3%83%88%E3%81%A7%E3%81%AF%20CPU%20%E3%81%AB%E8%B2%A0%E8%8D%B7%E3%81%8C%E3%81%8B%E3%81%8B%E3%82%8A%E3%81%99%E3%81%8E%E3%82%8B%E3%81%9F%E3%82%81%E3%80%81%E3%82%BD%E3%83%95%E3%83%88%E3%82%A6%E3%82%A7%E3%82%A2%20%E3%82%BF%E3%82%A4%E3%83%9E%E3%83%BC%E3%82%92%E3%83%AA%E3%82%BB%E3%83%83%E3%83%88%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E5%8F%97%E4%BF%A1%E3%83%90%E3%82%A4%E3%83%88%E3%81%94%E3%81%A8%E3%81%AB%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%82%92%E7%94%9F%E6%88%90%E3%81%99%E3%82%8B%E3%81%93%E3%81%A8%E3%81%AF%E9%81%BF%E3%81%91%E3%81%9F%E3%81%84%E3%81%A8%E8%80%83%E3%81%88%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E3%81%93%E3%81%AE%E3%83%87%E3%83%90%E3%82%A4%E3%82%B9%E3%81%AE%20Flexcomm%20USART%20%E3%81%AB%E3%81%AF%E3%80%81%E7%89%B9%E5%AE%9A%E3%81%AE%E6%96%87%E5%AD%97%E5%B9%85%E3%81%97%E3%81%8D%E3%81%84%E5%80%A4%20(3.5%20%E3%81%AA%E3%81%A9)%20%E3%81%AB%E8%A8%AD%E5%AE%9A%E3%81%A7%E3%81%8D%E3%82%8B%E5%B0%82%E7%94%A8%E3%81%AE%E3%80%8C%E6%96%87%E5%AD%97%E3%82%BF%E3%82%A4%E3%83%A0%E3%82%A2%E3%82%A6%E3%83%88%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%80%8D(CTI)%20%E3%81%8C%E3%81%AA%E3%81%84%E3%81%93%E3%81%A8%E3%81%AB%E6%B0%97%E4%BB%98%E3%81%8D%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FP%3E%3COL%3E%3CLI%3E%3CP%3EFlexcomm%20USART%20%E3%81%BE%E3%81%9F%E3%81%AF%20FIFO%20%E3%81%AB%E3%81%AF%E3%80%81RX%20%E3%81%8C%E4%B8%80%E5%AE%9A%E6%9C%9F%E9%96%93%E9%9D%9E%E3%82%A2%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%E3%81%AB%E3%81%AA%E3%81%A3%E3%81%9F%E5%BE%8C%E3%81%AB%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%82%92%E3%83%88%E3%83%AA%E3%82%AC%E3%83%BC%E3%81%99%E3%82%8B%E9%9A%A0%E3%81%97%E3%83%8F%E3%83%BC%E3%83%89%E3%82%A6%E3%82%A7%E3%82%A2%E6%A9%9F%E8%83%BD%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8B%3F%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E3%81%9D%E3%81%86%E3%81%A7%E3%81%AA%E3%81%84%E5%A0%B4%E5%90%88%E3%80%81DMA%20%2B%20CTIMER%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%203.5%20%E6%96%87%E5%AD%97%E3%81%AE%E3%82%AE%E3%83%A3%E3%83%83%E3%83%97%E3%82%92%E6%A4%9C%E5%87%BA%E3%81%99%E3%82%8B%E6%8E%A8%E5%A5%A8%E3%81%95%E3%82%8C%E3%82%8B%E3%80%8C%E4%BD%8E%E3%82%AA%E3%83%BC%E3%83%90%E3%83%BC%E3%83%98%E3%83%83%E3%83%89%E3%80%8D%E3%81%AE%E6%96%B9%E6%B3%95%E3%81%AF%E4%BD%95%E3%81%A7%E3%81%99%E3%81%8B%3F%3C%2FP%3E%3C%2FLI%3E%3C%2FOL%3E%3CP%3E%E3%81%93%E3%82%8C%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8B%20LPC55xx%20%E3%83%95%E3%82%A1%E3%83%9F%E3%83%AA%E3%81%AE%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%20%E3%82%B3%E3%83%BC%E3%83%89%E3%81%BE%E3%81%9F%E3%81%AF%E3%82%A2%E3%83%97%E3%83%AA%E3%82%B1%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%20%E3%83%8E%E3%83%BC%E3%83%88%E3%81%8C%E3%81%82%E3%82%8C%E3%81%B0%E3%80%81%E5%A4%A7%E5%A4%89%E5%8A%A9%E3%81%8B%E3%82%8A%E3%81%BE%E3%81%99%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%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%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%E3%81%84%E3%81%84%E3%81%88%E3%80%81LPC55S06%20%E4%B8%8A%E3%81%AE%20Flexcomm%20USART%20%E3%81%AB%E3%81%AF%E3%80%81%E3%83%8F%E3%83%BC%E3%83%89%E3%82%A6%E3%82%A7%E3%82%A2%E3%81%AE%E3%80%8C%E6%96%87%E5%AD%97%E3%82%BF%E3%82%A4%E3%83%A0%E3%82%A2%E3%82%A6%E3%83%88%E3%80%8D%E3%82%84%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E5%8F%AF%E8%83%BD%E3%81%AA%20RX%20%E3%82%A2%E3%82%A4%E3%83%89%E3%83%AB%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%81%AF%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FP%3E%0A%3CP%3ERX%20%E3%82%A2%E3%82%A4%E3%83%89%E3%83%AB%E6%A4%9C%E5%87%BA%E3%81%AB%E3%81%AF%20USART%20%2B%20DMA%20%2B%20CTIMER%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%A7%E3%81%8D%E3%82%8B%E3%81%A8%E6%80%9D%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3EUSART%20RX%20DMA%20%E3%81%AF%E3%80%81%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%20FIFO%20%E3%81%8B%E3%82%89%E5%BE%AA%E7%92%B0%E3%83%90%E3%83%83%E3%83%95%E3%82%A1%E3%81%AB%E7%B6%99%E7%B6%9A%E7%9A%84%E3%81%AB%E7%A7%BB%E5%8B%95%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3ECTIMER%20%E3%81%AF%E3%83%87%E3%83%BC%E3%82%BF%E3%81%8C%E5%88%B0%E7%9D%80%E3%81%97%E3%81%AA%E3%81%84%E5%A0%B4%E5%90%88%E3%81%AB%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E3%82%92%E7%94%9F%E6%88%90%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CDIV%3E3.5%20%E6%96%87%E5%AD%97%E6%99%82%E9%96%93%E3%81%AE%E3%82%BF%E3%82%A4%E3%83%9E%E3%83%BC%E3%82%92%E8%A8%AD%E5%AE%9A%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%0A%3CDIV%3ERX%20DMA%E3%82%A4%E3%83%99%E3%83%B3%E3%83%88%E3%81%94%E3%81%A8%E3%81%ABCTIMER%E3%82%92%E5%86%8D%E8%B5%B7%E5%8B%95%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3CBR%20%2F%3E%E3%82%BF%E3%82%A4%E3%83%9E%E3%83%BC%E3%81%8C%E6%9C%9F%E9%99%90%E5%88%87%E3%82%8C%E3%81%AB%E3%81%AA%E3%81%A3%E3%81%9F%E5%A0%B4%E5%90%88%E3%80%81%E6%AC%A1%E3%81%AE%E3%81%93%E3%81%A8%E3%82%92%E6%84%8F%E5%91%B3%E3%81%97%E3%81%BE%E3%81%99%3A%3CBR%20%2F%3E%203.5%20%E6%96%87%E5%AD%97%E3%81%AE%E3%83%90%E3%82%A4%E3%83%88%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82Modbus%20%E3%83%95%E3%83%AC%E3%83%BC%E3%83%A0%E3%81%AE%E7%B5%82%E4%BA%86%20(EOF)%20%E3%81%8C%E6%A4%9C%E5%87%BA%E3%81%95%E3%82%8C%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%0A%3CDIV%3EBR%3C%2FDIV%3E%0A%3CDIV%3E%E3%83%8F%E3%83%AA%E3%83%BC%3C%2FDIV%3E%0A%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3C%2FLINGO-BODY%3E