<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>S32 SDKのトピックRe: FlexCAN asserts due to FreeRTOS nesting violation</title>
    <link>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908733#M3897</link>
    <description>Hello Petr,&lt;BR /&gt;&lt;BR /&gt;thanks for the information!&lt;BR /&gt;&lt;BR /&gt;Best regards, M_SCH</description>
    <pubDate>Mon, 15 Jul 2024 11:30:13 GMT</pubDate>
    <dc:creator>M_SCH</dc:creator>
    <dc:date>2024-07-15T11:30:13Z</dc:date>
    <item>
      <title>FlexCAN asserts due to FreeRTOS nesting violation</title>
      <link>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1906170#M3893</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;I have the following setup:&lt;/P&gt;&lt;UL&gt;&lt;LI&gt;&lt;SPAN&gt;S32DS v3.5.12&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;RTD (P03, AR v4.7.0, SW v2.0.0)&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;FreeRTOS 10.5.1 v2.0.0&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;S32K148 MCU&lt;/SPAN&gt;&lt;/LI&gt;&lt;/UL&gt;&lt;P&gt;I use a project that depends on the following drivers&lt;/P&gt;&lt;UL&gt;&lt;LI&gt;&lt;SPAN&gt;FlexCAN&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;FreeRTOS&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;BaseNXP (selects OsifFreeRtosType)&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;others (may not be relevant to the potential bug)&lt;/SPAN&gt;&lt;/LI&gt;&lt;/UL&gt;&lt;P&gt;When I debug the application I observe that it ends up in an assert statement through the following sequence of function calls:&lt;/P&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;ISR(CAN0_ORED_0_15_MB_IRQHandler)&lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/FlexCAN_Ip_Irq.c at line 214&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;FlexCAN_IRQHandler( ... ) &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/FlexCAN_Ip.c at line 2926&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;FlexCAN_IRQHandlerRxMB &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/FlexCAN_Ip.c at line 1342&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;can_RX_TX_callback &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;custom callback for to handle CAN RX/TX events, located inside the project folder&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;calls&amp;nbsp;FlexCAN_Ip_Receive&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;FlexCAN_Ip_Receive &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/FlexCAN_Ip.c at line 2046&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;FlexCAN_SetMsgBuffIntCmd &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/FlexCAN_Ip_HwAccess.c at line 1053&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;SchM_Enter_Can_43_FLEXCAN_CAN_EXCLUSIVE_AREA_18 &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/src/SchM_Can_43_FLEXCAN.c at line 1125&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;OsIf_SuspendAllInterrupts &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/include/OsIf_Internal.h at line 274&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;SuspendAllInterrupts &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;RTD/include/OsIf_Internal.h at line 247&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;taskENTER_CRITICAL &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;FreeRTOS/Source/Include/task.h at line 210&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;portENTER_CRITICAL &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;FreeRTOS/Source/portable/GCC/ARM_CM4F/portmacro.h at line 105&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;LI&gt;&lt;SPAN&gt;vPortEnterCritical &lt;/SPAN&gt;&lt;/LI&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;FreeRTOS/Source/portable/GCC/ARM_CM4F/port.c at line 425&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;configASSERT&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;/OL&gt;&lt;P&gt;See also the debug session call sequence&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="M_SCH_0-1720689662553.png" style="width: 400px;"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/288099iED2A0578A85AEA6D/image-size/medium?v=v2&amp;amp;px=400" role="button" title="M_SCH_0-1720689662553.png" alt="M_SCH_0-1720689662553.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;Now I found a&amp;nbsp;&lt;/SPAN&gt;&lt;A href="https://community.nxp.com/t5/S32-SDK/S32K344-LLD-FreeRTOS-FlexCAN-interrupt-issue/td-p/1870576" target="_blank" rel="noopener"&gt;&lt;SPAN&gt;similar ticket&lt;/SPAN&gt;&lt;/A&gt;&lt;SPAN&gt;&amp;nbsp;where one NXP tech-support employee labels this issue as a bug, which may be resolved in a future RTD package release.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;To be sure, can you&lt;/P&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;confirm that this is a bug in the RTD driver&lt;/SPAN&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;present a workaround&lt;/SPAN&gt;&lt;OL&gt;&lt;LI&gt;&lt;SPAN&gt;I have tried to replace the&amp;nbsp;portENTER_CRITICAL call by&amp;nbsp;portENTER_CRITICAL_FROM_ISR (same for the EXIT version) in the local RTD folder in the header file Osif_Internal.h and in the RTD installation folder (S32DS.3.5\S32DS\software\PlatformSDK_S32K1_S32M24\RTD\BaseNXP_TS_T40D2M20I0R0\include\Osif_Internal.h)&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN&gt;But then I get another build error (Description Resource Path Location Type&lt;BR /&gt;too few arguments to function 'vPortSetBASEPRI' portmacro.h /__FreeRTOS_Toggle_Led_Example_S32K148__/FreeRTOS/Source/portable/GCC/ARM_CM4F line 102 C/C++ Problem)&lt;BR /&gt;&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;/LI&gt;&lt;LI&gt;&lt;SPAN&gt;point out if this is resolved by the RTD P04 package or when you plan to release package which fixes this isse&lt;/SPAN&gt;&lt;/LI&gt;&lt;/OL&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;M_SCH&lt;/P&gt;</description>
      <pubDate>Thu, 11 Jul 2024 09:31:16 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1906170#M3893</guid>
      <dc:creator>M_SCH</dc:creator>
      <dc:date>2024-07-11T09:31:16Z</dc:date>
    </item>
    <item>
      <title>Re: FlexCAN asserts due to FreeRTOS nesting violation</title>
      <link>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908728#M3896</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;
&lt;P&gt;yes, this is RTD issue and will be fixed with next RTD release. It should be version 3.0.0, not sure of the release plan.&lt;BR /&gt;Not able to comment more.&lt;/P&gt;
&lt;P&gt;BR, Petr&lt;/P&gt;</description>
      <pubDate>Mon, 15 Jul 2024 11:34:25 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908728#M3896</guid>
      <dc:creator>PetrS</dc:creator>
      <dc:date>2024-07-15T11:34:25Z</dc:date>
    </item>
    <item>
      <title>Re: FlexCAN asserts due to FreeRTOS nesting violation</title>
      <link>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908733#M3897</link>
      <description>Hello Petr,&lt;BR /&gt;&lt;BR /&gt;thanks for the information!&lt;BR /&gt;&lt;BR /&gt;Best regards, M_SCH</description>
      <pubDate>Mon, 15 Jul 2024 11:30:13 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908733#M3897</guid>
      <dc:creator>M_SCH</dc:creator>
      <dc:date>2024-07-15T11:30:13Z</dc:date>
    </item>
    <item>
      <title>Re: FlexCAN asserts due to FreeRTOS nesting violation</title>
      <link>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908816#M3899</link>
      <description>&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;one more thing.&lt;/P&gt;&lt;P&gt;My current implementation relies on the FlexCAN_Ip_Receive function using interrupts. Which of the following options would you recommend for a temporary fix:&lt;/P&gt;&lt;P&gt;1. Modify the Osif_Internal.h file (so that it matches the implementation of the RTD AR 4.4.0, SW 1.0.0):&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;LI-CODE lang="c"&gt;#define ResumeAllInterrupts()   ASM_KEYWORD(" cpsie i")
#define SuspendAllInterrupts()  ASM_KEYWORD(" cpsid i")​&lt;/LI-CODE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;2.&amp;nbsp;Use FlexCAN_Ip_ReceiveBlocking - keep in mind that I have multiple message buffers to query.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;M_SCH&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 15 Jul 2024 12:58:17 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-SDK/FlexCAN-asserts-due-to-FreeRTOS-nesting-violation/m-p/1908816#M3899</guid>
      <dc:creator>M_SCH</dc:creator>
      <dc:date>2024-07-15T12:58:17Z</dc:date>
    </item>
  </channel>
</rss>

