<?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>MCUXpresso SDKのトピックRe: KE18 clock driver doesn't work</title>
    <link>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713039#M331</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, David&lt;/P&gt;&lt;P&gt;Thanks for your sharing. I was surprise when I see your report. Because bit-field structure is not only used here, you can see it in many place. So I checked it&amp;nbsp;in internet, like &lt;A href="http://en.cppreference.com/w/cpp/language/bit_field"&gt;http://en.cppreference.com/w/cpp/language/bit_field&lt;/A&gt;. It&amp;nbsp;seems that unnamed bit_field are kept. Then&amp;nbsp;I&amp;nbsp;made a test on MCUXpresso.&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;struct S {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b1 : 2;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int :3;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b2 : 2;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b3 : 2;&lt;BR /&gt;};&lt;/P&gt;&lt;P&gt;union teststruct&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;unsigned int data;&lt;BR /&gt;&amp;nbsp;struct S bitfield;&lt;BR /&gt;}ts;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;/*******************************************************************************&lt;BR /&gt;&amp;nbsp;* Code&lt;BR /&gt;&amp;nbsp;******************************************************************************/&lt;BR /&gt;/*!&lt;BR /&gt;&amp;nbsp;* @brief Main function&lt;BR /&gt;&amp;nbsp;*/&lt;BR /&gt;int main(void)&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; char ch;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Init board hardware. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_InitPins();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_BootClockRUN();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_InitDebugConsole();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; PRINTF("hello world.\r\n");&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b1=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b2=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b3=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; PRINTF("%x",ts.data);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (1)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ch = GETCHAR();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUTCHAR(ch);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;BR /&gt;}&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;The out put is "a1", not "15". As you know, MCNXpresso use GCC.&lt;/P&gt;&lt;P&gt;I'm not sure what happened to your code. Can you give more detail?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Joph&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Wed, 06 Sep 2017 06:56:04 GMT</pubDate>
    <dc:creator>jingpan</dc:creator>
    <dc:date>2017-09-06T06:56:04Z</dc:date>
    <item>
      <title>KE18 clock driver doesn't work</title>
      <link>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713038#M330</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;After using the clock driver to get the KE18F512 working in MCUXpresso, I thought I would share that there's a bug that prevents it from working.&amp;nbsp; In fsl_clock.h, there is a structure for the SCG system clock divider:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;typedef struct _scg_sys_clk_config&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divSlow : 4; /*!&amp;lt; Slow clock divider, see @ref scg_sys_clk_div_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divBus : 4;&amp;nbsp; /*!&amp;lt; Bus clock divider, see @ref scg_sys_clk_div_t.&amp;nbsp; */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divCore : 4; /*!&amp;lt; Core clock divider, see @ref scg_sys_clk_div_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t src : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; System clock source, see @ref scg_sys_clk_src_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; reserved. */&lt;BR /&gt;} scg_sys_clk_config_t;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Unfortunately, GCC does not include the unnamed "reserved" fields, so the structure is not 32 bits wide as is needed to write the SCG_RCCR register, so it does not get changed.&amp;nbsp; It is necessary to name the reserved fields to make it work:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;typedef struct _scg_sys_clk_config&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divSlow : 4; /*!&amp;lt; Slow clock divider, see @ref scg_sys_clk_div_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divBus : 4;&amp;nbsp; /*!&amp;lt; Bus clock divider, see @ref scg_sys_clk_div_t.&amp;nbsp; */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t &lt;STRONG&gt;reserved1&lt;/STRONG&gt;: 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t &lt;STRONG&gt;reserved2&lt;/STRONG&gt;: 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t divCore : 4; /*!&amp;lt; Core clock divider, see @ref scg_sys_clk_div_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t &lt;STRONG&gt;reserved3&lt;/STRONG&gt;: 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; Reserved. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t src : 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; System clock source, see @ref scg_sys_clk_src_t. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; uint32_t &lt;STRONG&gt;reserved4&lt;/STRONG&gt;: 4;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /*!&amp;lt; reserved. */&lt;BR /&gt;} scg_sys_clk_config_t;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 31 Aug 2017 14:52:30 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713038#M330</guid>
      <dc:creator>davidsherman</dc:creator>
      <dc:date>2017-08-31T14:52:30Z</dc:date>
    </item>
    <item>
      <title>Re: KE18 clock driver doesn't work</title>
      <link>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713039#M331</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, David&lt;/P&gt;&lt;P&gt;Thanks for your sharing. I was surprise when I see your report. Because bit-field structure is not only used here, you can see it in many place. So I checked it&amp;nbsp;in internet, like &lt;A href="http://en.cppreference.com/w/cpp/language/bit_field"&gt;http://en.cppreference.com/w/cpp/language/bit_field&lt;/A&gt;. It&amp;nbsp;seems that unnamed bit_field are kept. Then&amp;nbsp;I&amp;nbsp;made a test on MCUXpresso.&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;struct S {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b1 : 2;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int :3;&amp;nbsp;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b2 : 2;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; unsigned int b3 : 2;&lt;BR /&gt;};&lt;/P&gt;&lt;P&gt;union teststruct&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;unsigned int data;&lt;BR /&gt;&amp;nbsp;struct S bitfield;&lt;BR /&gt;}ts;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;/*******************************************************************************&lt;BR /&gt;&amp;nbsp;* Code&lt;BR /&gt;&amp;nbsp;******************************************************************************/&lt;BR /&gt;/*!&lt;BR /&gt;&amp;nbsp;* @brief Main function&lt;BR /&gt;&amp;nbsp;*/&lt;BR /&gt;int main(void)&lt;BR /&gt;{&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; char ch;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Init board hardware. */&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_InitPins();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_BootClockRUN();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; BOARD_InitDebugConsole();&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; PRINTF("hello world.\r\n");&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b1=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b2=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; ts.bitfield.b3=1;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; PRINTF("%x",ts.data);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; while (1)&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ch = GETCHAR();&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUTCHAR(ch);&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;BR /&gt;}&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;The out put is "a1", not "15". As you know, MCNXpresso use GCC.&lt;/P&gt;&lt;P&gt;I'm not sure what happened to your code. Can you give more detail?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Joph&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 06 Sep 2017 06:56:04 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713039#M331</guid>
      <dc:creator>jingpan</dc:creator>
      <dc:date>2017-09-06T06:56:04Z</dc:date>
    </item>
    <item>
      <title>Re: KE18 clock driver doesn't work</title>
      <link>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713040#M332</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I believe I see what the problem was.&amp;nbsp; I had been using a previous version of KSDK for this part, and the bit fields in the scg_sys_clk_config_t structure WERE named, so the initializer I created had those fields accounted for.&amp;nbsp; I reused the same startup code and the fields were not populated correctly as a result of the now-unnamed bitfields.&amp;nbsp; If I take out the unneeded parameters for the unused bitfields it works properly.&amp;nbsp; Thank you.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 06 Sep 2017 12:52:41 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MCUXpresso-SDK/KE18-clock-driver-doesn-t-work/m-p/713040#M332</guid>
      <dc:creator>davidsherman</dc:creator>
      <dc:date>2017-09-06T12:52:41Z</dc:date>
    </item>
  </channel>
</rss>

