<?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>MQX Software SolutionsのトピックWrong clock configuration in FLEXCAN_Initialize</title>
    <link>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278377#M8662</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello community!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I've noticed strange behavior in FLEXCAN_Initialize. No matter what you pass as the last argument (clock source), this option is never applied. I performed a small investigation and found the reason for this. Prior to actually setting the clock source, softreset is issued to flexcan (kflexcan.c:325):&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if((can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_MDIS_MASK) == 0x00000000)&lt;BR /&gt;&amp;nbsp;&amp;nbsp; {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* clock disable (module) */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; can_reg_ptr-&amp;gt;MCR = CAN_MCR_MDIS_MASK;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* wait until disable mode acknowledged */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (!can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_LPMACK_MASK) {}&lt;BR /&gt;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; /* Reset FLEXCAN, Halt, freeze mode */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(FLEXCAN_Softreset(dev_num))&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return (FLEXCAN_INIT_FAILED);&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; /*&amp;nbsp; Wait for entering the freeze mode */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; while((can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_FRZACK_MASK) == 0) {}&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; /* &lt;BR /&gt;&amp;nbsp;&amp;nbsp; ** Select the clock source &lt;BR /&gt;&amp;nbsp;&amp;nbsp; ** Default: internal bus clock (fsys/2).&lt;BR /&gt;&amp;nbsp;&amp;nbsp; */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; FLEXCAN_Select_clk (dev_num, clk);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In the FLEXCAN_Softreset, flexcan leaves "module disable" state. But according to K20 Sub-Family Reference Manual, clock source bit (CLKSRC of CANx_CTRL1) can be modified only in "module disable" state (p. 1112).&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;Mikhail Burakov&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Thu, 14 Nov 2013 16:29:51 GMT</pubDate>
    <dc:creator>mikhailburakov</dc:creator>
    <dc:date>2013-11-14T16:29:51Z</dc:date>
    <item>
      <title>Wrong clock configuration in FLEXCAN_Initialize</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278377#M8662</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello community!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I've noticed strange behavior in FLEXCAN_Initialize. No matter what you pass as the last argument (clock source), this option is never applied. I performed a small investigation and found the reason for this. Prior to actually setting the clock source, softreset is issued to flexcan (kflexcan.c:325):&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; if((can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_MDIS_MASK) == 0x00000000)&lt;BR /&gt;&amp;nbsp;&amp;nbsp; {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* clock disable (module) */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; can_reg_ptr-&amp;gt;MCR = CAN_MCR_MDIS_MASK;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* wait until disable mode acknowledged */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (!can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_LPMACK_MASK) {}&lt;BR /&gt;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; /* Reset FLEXCAN, Halt, freeze mode */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; if(FLEXCAN_Softreset(dev_num))&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; return (FLEXCAN_INIT_FAILED);&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; /*&amp;nbsp; Wait for entering the freeze mode */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; while((can_reg_ptr-&amp;gt;MCR &amp;amp; CAN_MCR_FRZACK_MASK) == 0) {}&lt;BR /&gt;&amp;nbsp;&amp;nbsp; &lt;BR /&gt;&amp;nbsp;&amp;nbsp; /* &lt;BR /&gt;&amp;nbsp;&amp;nbsp; ** Select the clock source &lt;BR /&gt;&amp;nbsp;&amp;nbsp; ** Default: internal bus clock (fsys/2).&lt;BR /&gt;&amp;nbsp;&amp;nbsp; */&lt;BR /&gt;&amp;nbsp;&amp;nbsp; FLEXCAN_Select_clk (dev_num, clk);&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In the FLEXCAN_Softreset, flexcan leaves "module disable" state. But according to K20 Sub-Family Reference Manual, clock source bit (CLKSRC of CANx_CTRL1) can be modified only in "module disable" state (p. 1112).&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;Mikhail Burakov&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 14 Nov 2013 16:29:51 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278377#M8662</guid>
      <dc:creator>mikhailburakov</dc:creator>
      <dc:date>2013-11-14T16:29:51Z</dc:date>
    </item>
    <item>
      <title>Re: Wrong clock configuration in FLEXCAN_Initialize</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278378#M8663</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, Mikhail&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I think the FlexCAN initialize steps just as follow code refer as the manual reference.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;canx-&amp;gt;MCR&amp;nbsp;&amp;nbsp; |= CAN_MCR_MDIS_MASK; //disable CAN&lt;/P&gt;&lt;P&gt;canx-&amp;gt;CTRL1 |= CAN_CTRL1_CLKSRC_MASK; // select the peripheral clock as clock source&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;//and the enable CAN and software reset&lt;/P&gt;&lt;P&gt;canx-&amp;gt;MCR |= CAN_MCR_HALT_MASK; &lt;/P&gt;&lt;P&gt;canx-&amp;gt;MCR |= CAN_MCR_FRZ_MASK;&lt;/P&gt;&lt;P&gt;canx-&amp;gt;MCR &amp;amp;= ~CAN_MCR_MDIS_MASK; &lt;/P&gt;&lt;P&gt;while(!(canx-&amp;gt;MCR &amp;amp; CAN_MCR_LPMACK_MASK));&amp;nbsp;&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;canx-&amp;gt;MCR ^= CAN_MCR_SOFTRST_MASK;&lt;/P&gt;&lt;P&gt;while(canx-&amp;gt;MCR &amp;amp; CAN_MCR_SOFTRST_MASK);&lt;/P&gt;&lt;P&gt;while(!(canx-&amp;gt;MCR &amp;amp; CAN_MCR_FRZACK_MASK));&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best Regards&lt;/P&gt;&lt;P&gt;Laplenden&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 27 Nov 2013 12:51:49 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278378#M8663</guid>
      <dc:creator>AaronsCook</dc:creator>
      <dc:date>2013-11-27T12:51:49Z</dc:date>
    </item>
    <item>
      <title>Re: Wrong clock configuration in FLEXCAN_Initialize</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278379#M8664</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Actually I don't have any problems with FlexCAN initialization. Just pointing out a quirk in MQX code, because someone can lose some time investigating this issue. The described behavior can be worked around with ease.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best regards,&lt;/P&gt;&lt;P&gt;Mikhail Burakov&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 27 Nov 2013 13:04:23 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Wrong-clock-configuration-in-FLEXCAN-Initialize/m-p/278379#M8664</guid>
      <dc:creator>mikhailburakov</dc:creator>
      <dc:date>2013-11-27T13:04:23Z</dc:date>
    </item>
  </channel>
</rss>

