<?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>topic Possible LPCOpen Clock powerdown bug? in LPC Microcontrollers</title>
    <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617682#M24150</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I've been getting familiar with LPCOpen for the LPC18xx series. &amp;nbsp;It seems&amp;nbsp;Chip_Clock_SetBaseClock() might have a bug. &amp;nbsp;The function documentation says:&lt;/P&gt;&lt;P&gt;BaseClock : CHIP_CGU_BASE_CLK_T value indicating which base clock to set&lt;BR /&gt;Input : CHIP_CGU_CLKIN_T value indicating which clock source to use or CLOCKINPUT_PD to power down base clock&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;However, in the function itself, it seems it only ever *tries* to power down a base clock when BaseClock &amp;gt;= CLK_BASE_NONE (which obviously wouldn't power down anything). &amp;nbsp;I'm not sure if this is by-design, or if the bracketing on the if() statement is just awry. &amp;nbsp;It seems to me that the base clock powerdown should happen when the if(Input != CLKINPUT_PD) is false.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Might I also suggest updating the forum to allow pasting of formatted code snippets?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;/* Sets a CGU Base Clock clock source */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;void Chip_Clock_SetBaseClock(CHIP_CGU_BASE_CLK_T BaseClock, CHIP_CGU_CLKIN_T Input, bool autoblocken, bool powerdn)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;uint32_t reg = LPC_CGU-&amp;gt;BASE_CLK[BaseClock];&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (BaseClock &amp;lt; CLK_BASE_NONE) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (Input != CLKINPUT_PD) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;/* Mask off fields we plan to update */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg &amp;amp;= ~((0x1F &amp;lt;&amp;lt; 24) | 1 | (1 &amp;lt;&amp;lt; 11));&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (autoblocken) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (1 &amp;lt;&amp;lt; 11);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (powerdn) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (1 &amp;lt;&amp;lt; 0);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;/* Set clock source */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (Input &amp;lt;&amp;lt; 24);&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;else {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg | 1; /* Power down this base clock */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;}&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 07 Oct 2016 19:20:51 GMT</pubDate>
    <dc:creator>otsl</dc:creator>
    <dc:date>2016-10-07T19:20:51Z</dc:date>
    <item>
      <title>Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617682#M24150</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I've been getting familiar with LPCOpen for the LPC18xx series. &amp;nbsp;It seems&amp;nbsp;Chip_Clock_SetBaseClock() might have a bug. &amp;nbsp;The function documentation says:&lt;/P&gt;&lt;P&gt;BaseClock : CHIP_CGU_BASE_CLK_T value indicating which base clock to set&lt;BR /&gt;Input : CHIP_CGU_CLKIN_T value indicating which clock source to use or CLOCKINPUT_PD to power down base clock&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;However, in the function itself, it seems it only ever *tries* to power down a base clock when BaseClock &amp;gt;= CLK_BASE_NONE (which obviously wouldn't power down anything). &amp;nbsp;I'm not sure if this is by-design, or if the bracketing on the if() statement is just awry. &amp;nbsp;It seems to me that the base clock powerdown should happen when the if(Input != CLKINPUT_PD) is false.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Might I also suggest updating the forum to allow pasting of formatted code snippets?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;/* Sets a CGU Base Clock clock source */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;void Chip_Clock_SetBaseClock(CHIP_CGU_BASE_CLK_T BaseClock, CHIP_CGU_CLKIN_T Input, bool autoblocken, bool powerdn)&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;{&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;uint32_t reg = LPC_CGU-&amp;gt;BASE_CLK[BaseClock];&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (BaseClock &amp;lt; CLK_BASE_NONE) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (Input != CLKINPUT_PD) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;/* Mask off fields we plan to update */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg &amp;amp;= ~((0x1F &amp;lt;&amp;lt; 24) | 1 | (1 &amp;lt;&amp;lt; 11));&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (autoblocken) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (1 &amp;lt;&amp;lt; 11);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (powerdn) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (1 &amp;lt;&amp;lt; 0);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;/* Set clock source */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (Input &amp;lt;&amp;lt; 24);&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg;&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;else {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg | 1; /* Power down this base clock */&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;}&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 07 Oct 2016 19:20:51 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617682#M24150</guid>
      <dc:creator>otsl</dc:creator>
      <dc:date>2016-10-07T19:20:51Z</dc:date>
    </item>
    <item>
      <title>Re: Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617683#M24151</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi &lt;A _jive_internal="true" data-content-finding="Community" data-userid="286357" data-username="otsl" href="https://community.nxp.com/people/otsl"&gt;otsl&lt;/A&gt; ,&lt;/P&gt;&lt;P&gt;Thanks for your sharing.&lt;/P&gt;&lt;P&gt;Obviously, the power down setting has been executed in the following code snippet, and the following comment is awry.&lt;/P&gt;&lt;P&gt;I'd like to report the Chip_Clock_SetBaseClock() for checking, I'll also inform you if I get some replies.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;if (powerdn) {&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;reg |= (1 &amp;lt;&amp;lt; 0);&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN style="font-family: 'courier new', courier, monospace;"&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;}&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-family: 'courier new',courier,monospace;"&gt;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg | 1;&lt;STRONG style="color: #ff0000;"&gt; /* Power down this base clock */&lt;/STRONG&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Have a great day,&lt;BR /&gt;Ping&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 08 Oct 2016 03:00:13 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617683#M24151</guid>
      <dc:creator>jeremyzhou</dc:creator>
      <dc:date>2016-10-08T03:00:13Z</dc:date>
    </item>
    <item>
      <title>Re: Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617684#M24152</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I don't think that's the whole story.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;For example, if (as per the documentation) I call:&lt;/P&gt;&lt;P&gt;Chip_Clock_SetBaseClock(CLK_BASE_SPIFI,&amp;nbsp;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;CLOCKINPUT_PD, 1, 1);&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;I would expect the BASE_SPIFI clock to be powered down. &amp;nbsp;However, based on the code:&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;&lt;SPAN&gt;if (BaseClock &amp;lt; CLK_BASE_NONE) &amp;nbsp; &amp;nbsp;&amp;lt;----- would evaluate to true&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;&lt;SPAN style="background-color: #ffffff;"&gt;Followed by:&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;&lt;SPAN style="background-color: #ffffff;"&gt;if (Input != CLKINPUT_PD) &amp;nbsp; &amp;lt;------- evaluate as FALSE&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;&lt;SPAN style="background-color: #ffffff;"&gt;And therefore would not execute anything at all in the function (just simply exiting).&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 10 Nov 2016 17:21:28 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617684#M24152</guid>
      <dc:creator>otsl</dc:creator>
      <dc:date>2016-11-10T17:21:28Z</dc:date>
    </item>
    <item>
      <title>Re: Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617685#M24153</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi &lt;SPAN class=""&gt;&lt;A _jive_internal="true" data-userid="286357" data-username="otsl" href="https://community.nxp.com/people/otsl"&gt;otsl&lt;/A&gt;&lt;/SPAN&gt;,&lt;/P&gt;&lt;P&gt;You can use the Chip_Clock_SetBaseClock(CLK_BASE_SPIFI, &lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;CLKIN_32K, 1, 1); instead of the previous code.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;In my opinion, the CLKINPUT_PD seems like a sign which is used to get your attention to select a correct CGU Clock input.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="color: #51626f; background-color: #ffffff;"&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="pastedImage_1.png"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/8117iC701BFB95F54F2E2/image-size/large?v=v2&amp;amp;px=999" role="button" title="pastedImage_1.png" alt="pastedImage_1.png" /&gt;&lt;/span&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;Ping&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 11 Nov 2016 09:38:27 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617685#M24153</guid>
      <dc:creator>jeremyzhou</dc:creator>
      <dc:date>2016-11-11T09:38:27Z</dc:date>
    </item>
    <item>
      <title>Re: Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617686#M24154</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Ok, I hate to keep harping on this, but I do thing you're missing the point. &amp;nbsp;The function (or documentation of the function) has a bug.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;According to the documentation, this particular function serves two purposes:&lt;/P&gt;&lt;P&gt;1. Attach a base clock to an input source.&lt;/P&gt;&lt;P&gt;2. Power down a base clock.&lt;/P&gt;&lt;P&gt;It should be possible to do #2 WITHOUT doing #1. &amp;nbsp;In your example, not only do I powerdown the SPIFI clock, I also attach it to the 32kHz oscillator. &amp;nbsp;Sure, I can do this, but then, depending on which clock I'm powering down, I have to select a proper input clock. &amp;nbsp;I *could* use the 32kHz clock for most (unless it's USB0), however, this is contrary to the documented use of the function.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;ALSO, if the function was intended to be used how you describe, why&amp;nbsp;would the fall through of the first 'if' statement be to shut down a non-existent BaseClock:&lt;/P&gt;&lt;P&gt;if (BaseClock &amp;lt; CLK_BASE_NONE) {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;....&lt;BR /&gt; }&lt;BR /&gt; else {&lt;BR /&gt; &amp;nbsp;&amp;nbsp;&amp;nbsp;LPC_CGU-&amp;gt;BASE_CLK[BaseClock] = reg | 1; /* Power down this base clock */&lt;BR /&gt; }&lt;/P&gt;&lt;P&gt;This would try to set the power-down bit of a non-existent (BaseClock &amp;gt;= CLK_BASE_NONE) clock by writing to a portion of register space that is not defined.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I think it's far more reasonable to assume that this function is buggy, and the 'else' parameter specified above should be related to the 'if(Input != CLKINPUT_PD)' block.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;If you had a public bugtracker for LPCOpen, I would submit this, but since you don't (that I can find), the forums seem to be my only way.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 17 Nov 2016 19:06:43 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617686#M24154</guid>
      <dc:creator>otsl</dc:creator>
      <dc:date>2016-11-17T19:06:43Z</dc:date>
    </item>
    <item>
      <title>Re: Possible LPCOpen Clock powerdown bug?</title>
      <link>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617687#M24155</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi &lt;SPAN class=""&gt;&lt;A _jive_internal="true" class="" data-containerid="-1" data-containertype="-1" data-objectid="286357" data-objecttype="3" href="https://community.nxp.com/people/otsl"&gt;otsl&lt;/A&gt;&lt;/SPAN&gt;,&lt;/P&gt;&lt;P&gt;Thanks for your clarification.&lt;/P&gt;&lt;P&gt;I've already reported the bug and thanks again.&lt;BR /&gt;Have a great day,&lt;BR /&gt;Ping&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 18 Nov 2016 03:09:25 GMT</pubDate>
      <guid>https://community.nxp.com/t5/LPC-Microcontrollers/Possible-LPCOpen-Clock-powerdown-bug/m-p/617687#M24155</guid>
      <dc:creator>jeremyzhou</dc:creator>
      <dc:date>2016-11-18T03:09:25Z</dc:date>
    </item>
  </channel>
</rss>

