Enable FDCAN_IT_ARB_PROTOCOL_ERROR
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
2025-03-28 4:09 AM - last edited on 2025-03-28 4:13 AM by mƎALLEm
Hello
I use CAN FD and have a functioning communication with 3 participants. Now I want to activate the interrupt that notifies me when the device has lost the arbitration contest.
I forward each of the four NVIC interrupts in stm32h7xx_hal_fdcan:
void FDCAN2_IT0_IRQHandler(void)
{
HAL_FDCAN_IRQHandler(&hfdcan2);
}
When initializing CAN, I activate the interrupt:
retVal = HAL_FDCAN_ActivateNotification(m_Fdcan2Handle, FDCAN_IT_ARB_PROTOCOL_ERROR, 0);
and set the CallbackHandle beforehand:
retVal = HAL_FDCAN_RegisterTxEventFifoCallback(m_Fdcan2Handle, MyCallback);
SYSM_ASSERT_STOP(retVal == HAL_OK, retVal);
retVal = HAL_FDCAN_RegisterErrorStatusCallback(m_Fdcan2Handle, MyCallback);
SYSM_ASSERT_STOP(retVal == HAL_OK, retVal);
retVal = HAL_FDCAN_RegisterTxBufferAbortCallback(m_Fdcan2Handle, MyCallback);
SYSM_ASSERT_STOP(retVal == HAL_OK, retVal);
retVal = HAL_FDCAN_RegisterTxEventFifoCallback(m_Fdcan2Handle, MyCallback);
SYSM_ASSERT_STOP(retVal == HAL_OK, retVal);
Despite arbitration collisions, I do not end up in my callback “MyCallback”.
What have I overlooked?
Best regards
- Labels:
-
FDCAN
-
STM32H7 Series
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
2025-03-28 4:26 AM - edited 2025-03-28 8:48 AM
Hello,
First, please use </> button to share your code. See this link. (I've edited your post).
Second, according to the description of the PEA bit it might be not intended to signal a lost of arbitration but to signal a protocol error that occurred during the arbitration phase:
I may ask internally and get back to you as soon as I have an answer. Internal ticket 206406 has been submitted (not accessible by the community users).
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
2025-03-28 4:26 AM
Hello @MFrie.7
For better debugging, please ensure that the return value retVal is equal to HAL_OK when calling the HAL functions.
retVal = HAL_FDCAN_ActivateNotification(m_Fdcan2Handle, FDCAN_IT_ARB_PROTOCOL_ERROR, 0);
if (retVal != HAL_OK)
{
// Error handler
}
Thanks
Omar
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
2025-03-31 4:34 AM - edited 2025-03-31 4:35 AM
Hello,
Thank you for your reply and opening an internal ticket.
In the reference manual I see an other possible solution for this problem, but I can't get it to work:
I check TXBTO and TXBFC for a lost of the arbitration contest like this:
if (TXBFC & ~TXBTO)
{
...
The problem with this is, that I now count to much lost of arbitration contest. Perhaps I need to trigger TXBRP from 1 to 0? I have not found a way (Interrupt) for that.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
2025-04-02 1:48 AM
I don't think this is an efficient way as it's not exclusively to signal the loss of the arbitration but also an issue in transmission.
