i.MX8QM Cortex-M FLEXCAN FreeRTOS

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

i.MX8QM Cortex-M FLEXCAN FreeRTOS

跳至解决方案
1,206 次查看
io
Contributor II

Hello,
I’m working with i.MX8QM Cortex-M4 running FreeRTOS.
I use the NXP FlexCAN driver with interrupt callback. Inside the callback I try to call xSemaphoreGiveFromISR(), but the program always hangs/stuck at that point.

I already tried changing interrupt priority and checked FreeRTOS config, but still same result.
Does anyone have a simple example how to use FlexCAN with FreeRTOS task (semaphore or task notify) on i.MX8QM?

Here is my main program.
https://pastebin.com/BrhXQC1w 

Thanks.

标记 (3)
0 项奖励
回复
1 解答
1,128 次查看
io
Contributor II

Just wanna share for anyone who may need it.

The problem was just the interrupt setup. I wrongly set the NVIC Priority
NVIC_SetPriority(DMA_FLEXCAN0_INT_IRQn, 3); which should be NVIC_SetPriority(IRQSTEER_4_IRQn, 3);

The FLEXCAN0 interrupt was connected to IRQSTEER_4_IRQn. Because the interrupt priority was wrongly set, it defaulted to a high priority (maybe 0). Then when calling xSemaphoreGiveFromISR() inside isr flexcan_callback, it causing the portASSERT_IF_INTERRUPT_PRIORITY_INVALID() failure and the program to stuck there.

Ref:
https://community.nxp.com/t5/i-MX-Processors/imx8qm-IRQSTEER-interrupt-mapping/m-p/1067519/highlight...

https://www.freertos.org/Documentation/02-Kernel/03-Supported-devices/04-Demos/ARM-Cortex/RTOS-Corte...

 

Regards,

io

在原帖中查看解决方案

0 项奖励
回复
2 回复数
1,129 次查看
io
Contributor II

Just wanna share for anyone who may need it.

The problem was just the interrupt setup. I wrongly set the NVIC Priority
NVIC_SetPriority(DMA_FLEXCAN0_INT_IRQn, 3); which should be NVIC_SetPriority(IRQSTEER_4_IRQn, 3);

The FLEXCAN0 interrupt was connected to IRQSTEER_4_IRQn. Because the interrupt priority was wrongly set, it defaulted to a high priority (maybe 0). Then when calling xSemaphoreGiveFromISR() inside isr flexcan_callback, it causing the portASSERT_IF_INTERRUPT_PRIORITY_INVALID() failure and the program to stuck there.

Ref:
https://community.nxp.com/t5/i-MX-Processors/imx8qm-IRQSTEER-interrupt-mapping/m-p/1067519/highlight...

https://www.freertos.org/Documentation/02-Kernel/03-Supported-devices/04-Demos/ARM-Cortex/RTOS-Corte...

 

Regards,

io

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2175915%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3Ei.MX8QM%20Cortex-M%20FLEXCAN%20FreeRTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2175915%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%EF%BC%8C%3CBR%20%2F%3E%EF%BC%8C%E6%88%91%E6%AD%A3%E5%9C%A8%E4%BD%BF%E7%94%A8%E8%BF%90%E8%A1%8C%20FreeRTOS%20%E7%9A%84%20i.MX8QM%20Cortex-M4%E3%80%82%3CBR%20%2F%3E%E6%88%91%E4%BD%BF%E7%94%A8%E7%9A%84%E6%98%AF%E5%B8%A6%E6%9C%89%E4%B8%AD%E6%96%AD%E5%9B%9E%E8%B0%83%E5%8A%9F%E8%83%BD%E7%9A%84%E6%81%A9%E6%99%BA%E6%B5%A6%20FlexCAN%20%E9%A9%B1%E5%8A%A8%E7%A8%8B%E5%BA%8F%E3%80%82%E6%88%91%E8%AF%95%E5%9B%BE%E5%9C%A8%E5%9B%9E%E8%B0%83%E4%B8%AD%E8%B0%83%E7%94%A8%20xSemaphoreGiveFromISR()%EF%BC%8C%E4%BD%86%E7%A8%8B%E5%BA%8F%E6%80%BB%E6%98%AF%E5%9C%A8%E6%AD%A4%E6%97%B6%E6%8C%82%E8%B5%B7%2F%E5%8D%A1%E4%BD%8F%E3%80%82%3C%2FP%3E%3CP%3E%E6%88%91%E5%B7%B2%E5%B0%9D%E8%AF%95%E6%9B%B4%E6%94%B9%E4%B8%AD%E6%96%AD%E4%BC%98%E5%85%88%E7%BA%A7%EF%BC%8C%E5%B9%B6%E6%A3%80%E6%9F%A5%E4%BA%86%20FreeRTOS%20%E9%85%8D%E7%BD%AE%EF%BC%8C%E4%BD%86%E7%BB%93%E6%9E%9C%E8%BF%98%E6%98%AF%E4%B8%80%E6%A0%B7%E3%80%82%3CBR%20%2F%3E%E6%98%AF%E5%90%A6%E6%9C%89%E4%BA%BA%E6%9C%89%E5%9C%A8%20i.MX8QM%20%E4%B8%8A%E5%B0%86%20FlexCAN%20%E4%B8%8E%20FreeRTOS%20%E4%BB%BB%E5%8A%A1%EF%BC%88%E4%BF%A1%E5%8F%B7%E6%88%96%E4%BB%BB%E5%8A%A1%E9%80%9A%E7%9F%A5%EF%BC%89%E7%BB%93%E5%90%88%E4%BD%BF%E7%94%A8%E7%9A%84%E7%AE%80%E5%8D%95%E7%A4%BA%E4%BE%8B%EF%BC%9F%3C%2FP%3E%3CP%3E%E8%BF%99%E6%98%AF%E6%88%91%E7%9A%84%E4%B8%BB%E7%A8%8B%E5%BA%8F%E3%80%82%3CBR%20%2F%3E%3CA%20title%3D%22flexcan_rtos%22%20href%3D%22https%3A%2F%2Fpastebin.com%2FBrhXQC1w%22%20target%3D%22_self%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fpastebin.com%2FBrhXQC1w%3C%2FA%3E%20%3CBR%20%2F%3E%3CBR%20%2F%3E%E8%B0%A2%E8%B0%A2%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-LABS%20id%3D%22lingo-labs-2175915%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CLINGO-LABEL%3Ei.MX%208%20%E7%B3%BB%E5%88%97%20%7C%20i.MX%208QuadMax%20(8QM)%20%7C%208QuadPlus%3C%2FLINGO-LABEL%3E%3C%2FLINGO-LABS%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2178167%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20i.MX8QM%20Cortex-M%20FLEXCAN%20FreeRTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2178167%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E5%8F%AA%E6%98%AF%E6%83%B3%E5%92%8C%E5%A4%A7%E5%AE%B6%E5%88%86%E4%BA%AB%E4%B8%80%E4%B8%8B%EF%BC%8C%E4%B9%9F%E8%AE%B8%E6%9C%89%E9%9C%80%E8%A6%81%E7%9A%84%E4%BA%BA%E5%8F%AF%E4%BB%A5%E5%8F%82%E8%80%83%E3%80%82%3C%2FP%3E%3CP%3E%E9%97%AE%E9%A2%98%E5%87%BA%E5%9C%A8%E4%B8%AD%E6%96%AD%E8%AE%BE%E7%BD%AE%E4%B8%8A%E3%80%82%E6%88%91%E9%94%99%E8%AF%AF%E5%9C%B0%E8%AE%BE%E7%BD%AE%E4%BA%86%20NVIC%20%E4%BC%98%E5%85%88%E7%BA%A7%3CBR%20%2F%3ENVIC_SetPriority(DMA_FLEXCAN0_INT_IRQn%2C3)%EF%BC%9B%E5%BA%94%E8%AF%A5%E6%98%AF%20NVIC_SetPriority(IRQSTEER_4_IRQn%2C3)%EF%BC%9B%3C%2FP%3E%3CP%3E%E7%BC%86%E7%BA%BF%20%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3EFLEXCAN0%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%E4%B8%AD%E6%96%AD%E8%BF%9E%E6%8E%A5%E5%88%B0%20%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3EIRQSTEER_4_IRQn%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E.%E7%94%B1%E4%BA%8E%E4%B8%AD%E6%96%AD%E4%BC%98%E5%85%88%E7%BA%A7%E8%AE%BE%E7%BD%AE%E9%94%99%E8%AF%AF%EF%BC%8C%E5%AE%83%E9%BB%98%E8%AE%A4%E4%B8%BA%E9%AB%98%E4%BC%98%E5%85%88%E7%BA%A7%EF%BC%88%E5%8F%AF%E8%83%BD%E6%98%AF%20%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E0)%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E.%E7%84%B6%E5%90%8E%E5%9C%A8%E8%B0%83%E7%94%A8%20%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3ExSemaphoreGiveFromISR()%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%E6%97%B6%EF%BC%8C%E4%BC%9A%E5%AF%BC%E8%87%B4%20%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3E%3CSPAN%20class%3D%22%22%3EportASSERT_IF_INTERRUPT_PRIORITY_INVALID()%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%3C%2FSPAN%3E%E5%A4%B1%E8%B4%A5%EF%BC%8C%E5%AF%BC%E8%87%B4%E7%A8%8B%E5%BA%8F%E5%8D%A1%E5%9C%A8%E9%82%A3%E9%87%8C%E3%80%82%3C%2FP%3E%3CP%3ERef%3A%3CBR%20%2F%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2Fimx8qm-IRQSTEER-interrupt-mapping%2Fm-p%2F1067519%2Fhighlight%2Ftrue%23M156853%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2Fimx8qm-IRQSTEER-interrupt-mapping%2Fm-p%2F1067519%2Fhighlight%2Ftrue%23M156853%3C%2FA%3E%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fwww.freertos.org%2FDocumentation%2F02-Kernel%2F03-Supported-devices%2F04-Demos%2FARM-Cortex%2FRTOS-Cortex-M3-M4%22%20target%3D%22_blank%22%20rel%3D%22noopener%20nofollow%20noreferrer%22%3Ehttps%3A%2F%2Fwww.freertos.org%2FDocumentation%2F02-Kernel%2F03-Supported-devices%2F04-Demos%2FARM-Cortex%2FRTOS-Cortex-M3-M4%3C%2FA%3E%3C%2FP%3E%3CBR%20%2F%3E%3CP%3E%E6%AD%A4%E8%87%B4%EF%BC%8C%3C%2FP%3E%3CP%3EIO%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2177512%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20i.MX8QM%20Cortex-M%20FLEXCAN%20FreeRTOS%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2177512%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3C%2FP%3E%0A%3CP%3E%E8%AF%B7%E6%A3%80%E6%9F%A5%EF%BC%9A%3C%2FP%3E%0A%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors-Knowledge-Base%2FiMX8QM-FLEXCAN-enable-and-test-case-on-A-core%2Fta-p%2F1349003%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors-Knowledge-Base%2FiMX8QM-FLEXCAN-enable-and-test-case-on-A-core%2Fta-p%2F1349003%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FHow-to-read-from-CAN-through-M4%2Fm-p%2F1695836%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FHow-to-read-from-CAN-through-M4%2Fm-p%2F1695836%3C%2FA%3E%3C%2FP%3E%0A%3CBR%20%2F%3E%0A%3CP%3E%E6%AD%A4%E8%87%B4%3C%2FP%3E%3C%2FLINGO-BODY%3E