<?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 PRINTF problem in SDK 2.0 in Kinetis Software Development Kit</title>
    <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547862#M5614</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have FRDM-K64F, KDS 3.2 and SDK 2.0 for K64F CPU family.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;When I startet to use SDK 2.0 I found two problem with PRINTF. One less serious is definition of its first parameters "char *", which should be nowadays "const char *". It generates enormous number of warnings.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The second more serious problem is bug of float numbers output. Below is my main():&lt;/P&gt;&lt;P&gt;int main(void) {&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Init board hardware. */&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_InitPins();&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_BootClockRUN();&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_InitDebugConsole();&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; float x = 0.9;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &lt;STRONG&gt;printf( "%f %f %f\n", x, x - 1.0, -3.14 );&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;&amp;nbsp; PRINTF( "%f %f %f\n", x, x - 1.0, -3.14 );&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Add your code here */&lt;/P&gt;&lt;P&gt;&amp;nbsp; for(;;) { /* Infinite loop to avoid leaving the main function */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; __asm("NOP"); /* something to use as a breakpoint stop while looping */&lt;/P&gt;&lt;P&gt;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The output is:&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;0.900000 -0.100000 -3.140000&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;0.900000 -1.100000 -4.140000&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The problem is in function DbgConsole_ConvertFloatRadixNumToString where some programmer badly implements condition: &lt;/P&gt;&lt;P&gt; if (fa &amp;lt;= pow(-10, precision_width))&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; intpart--;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;The sign minus must be in front of pow. &lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;reg.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sun, 19 Jun 2016 11:22:47 GMT</pubDate>
    <dc:creator>regexp</dc:creator>
    <dc:date>2016-06-19T11:22:47Z</dc:date>
    <item>
      <title>PRINTF problem in SDK 2.0</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547862#M5614</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have FRDM-K64F, KDS 3.2 and SDK 2.0 for K64F CPU family.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;When I startet to use SDK 2.0 I found two problem with PRINTF. One less serious is definition of its first parameters "char *", which should be nowadays "const char *". It generates enormous number of warnings.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The second more serious problem is bug of float numbers output. Below is my main():&lt;/P&gt;&lt;P&gt;int main(void) {&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Init board hardware. */&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_InitPins();&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_BootClockRUN();&lt;/P&gt;&lt;P&gt;&amp;nbsp; BOARD_InitDebugConsole();&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; float x = 0.9;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &lt;STRONG&gt;printf( "%f %f %f\n", x, x - 1.0, -3.14 );&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;&amp;nbsp; PRINTF( "%f %f %f\n", x, x - 1.0, -3.14 );&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp; /* Add your code here */&lt;/P&gt;&lt;P&gt;&amp;nbsp; for(;;) { /* Infinite loop to avoid leaving the main function */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; __asm("NOP"); /* something to use as a breakpoint stop while looping */&lt;/P&gt;&lt;P&gt;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;}&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The output is:&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;0.900000 -0.100000 -3.140000&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;&lt;STRONG&gt;0.900000 -1.100000 -4.140000&lt;/STRONG&gt;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;The problem is in function DbgConsole_ConvertFloatRadixNumToString where some programmer badly implements condition: &lt;/P&gt;&lt;P&gt; if (fa &amp;lt;= pow(-10, precision_width))&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; intpart--;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }&lt;/P&gt;&lt;P&gt;The sign minus must be in front of pow. &lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;reg.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 19 Jun 2016 11:22:47 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547862#M5614</guid>
      <dc:creator>regexp</dc:creator>
      <dc:date>2016-06-19T11:22:47Z</dc:date>
    </item>
    <item>
      <title>Re: PRINTF problem in SDK 2.0</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547863#M5615</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi reg,&lt;/P&gt;&lt;P&gt;printf() is calling compiler tool chain printf.&lt;/P&gt;&lt;P&gt;PRINTF is calling embedded code in KSDK_v2.&lt;/P&gt;&lt;P&gt;PRINTF in KSDK_v2 has errata that the development team is validating currently.&lt;/P&gt;&lt;P&gt;A workaround for it is posted here:&lt;/P&gt;&lt;P&gt;&lt;A _jive_internal="true" href="https://community.nxp.com/message/754763?et=watches.email.thread#comment-754763" title="https://community.nxp.com/message/754763?et=watches.email.thread#comment-754763"&gt;https://community.nxp.com/message/754763?et=watches.email.thread#comment-754763&lt;/A&gt; &lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;David &lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 20 Jun 2016 14:10:54 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547863#M5615</guid>
      <dc:creator>DavidS</dc:creator>
      <dc:date>2016-06-20T14:10:54Z</dc:date>
    </item>
    <item>
      <title>Re: PRINTF problem in SDK 2.0</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547864#M5616</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I recommend what David said. There was a discussion on this topic a few days ago.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Please test it on your side and let us know, if this works you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a nice day.&lt;/P&gt;&lt;P&gt;Iva&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 21 Jun 2016 13:42:26 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/PRINTF-problem-in-SDK-2-0/m-p/547864#M5616</guid>
      <dc:creator>ivadorazinova</dc:creator>
      <dc:date>2016-06-21T13:42:26Z</dc:date>
    </item>
  </channel>
</rss>

