<?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 MKW30Z hardware init in Kinetis Software Development Kit</title>
    <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649056#M6997</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;IAR 7.50;&amp;nbsp; KW40Z_Connectivity_Software_1.0.1 (KSDK_1.3.0)&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;as program start point is&lt;/P&gt;&lt;P&gt;\platform\devices\MKW30Z4\startup\iar\&lt;STRONG&gt;startup_MKW30Z4.s&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;Reset_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;STRONG&gt; CPSID&amp;nbsp;&amp;nbsp; I&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ; Mask interrupts&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =&lt;STRONG&gt;SystemInit&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =&lt;STRONG&gt;init_data_bss&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CPSIE&amp;nbsp;&amp;nbsp; I&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ; Unmask interrupts&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =__iar_program_start&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK NMI_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;BR /&gt;NMI_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; B .&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK HardFault_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;BR /&gt;HardFault_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; B .&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK SVC_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="177619_177619.png"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/122891iE9B7305FD01545D6/image-size/large?v=v2&amp;amp;px=999" role="button" title="177619_177619.png" alt="177619_177619.png" /&gt;&lt;/span&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/13695iAAF153D179728163/image-size/large?v=v2&amp;amp;px=999" role="button" title="pastedImage_1.png" alt="pastedImage_1.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;calling:&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;void &lt;STRONG&gt;SystemInit&lt;/STRONG&gt; (void) {&lt;/P&gt;&lt;P&gt;#if (DISABLE_WDOG)&lt;BR /&gt;&amp;nbsp; /* SIM_COPC: COPT=0,COPCLKS=0,COPW=0 */&lt;BR /&gt;&amp;nbsp; SIM-&amp;gt;COPC = (uint32_t)0x00u;&lt;BR /&gt;#endif /* (DISABLE_WDOG) */&lt;BR /&gt;&lt;BR /&gt;#ifdef CLOCK_SETUP&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;why is there another hardware init needed in KSDK group: board.c board.h ?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sun, 19 Feb 2017 09:10:55 GMT</pubDate>
    <dc:creator>lucianfiran</dc:creator>
    <dc:date>2017-02-19T09:10:55Z</dc:date>
    <item>
      <title>MKW30Z hardware init</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649056#M6997</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;IAR 7.50;&amp;nbsp; KW40Z_Connectivity_Software_1.0.1 (KSDK_1.3.0)&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;as program start point is&lt;/P&gt;&lt;P&gt;\platform\devices\MKW30Z4\startup\iar\&lt;STRONG&gt;startup_MKW30Z4.s&lt;/STRONG&gt;&lt;/P&gt;&lt;P&gt;Reset_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;STRONG&gt; CPSID&amp;nbsp;&amp;nbsp; I&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ; Mask interrupts&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =&lt;STRONG&gt;SystemInit&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =&lt;STRONG&gt;init_data_bss&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BLX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; CPSIE&amp;nbsp;&amp;nbsp; I&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; ; Unmask interrupts&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; LDR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0, =__iar_program_start&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; BX&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; R0&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK NMI_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;BR /&gt;NMI_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; B .&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK HardFault_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;BR /&gt;HardFault_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; B .&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; PUBWEAK SVC_Handler&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; SECTION .text:CODE:REORDER:NOROOT(1)&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper" image-alt="177619_177619.png"&gt;&lt;img src="https://community.nxp.com/t5/image/serverpage/image-id/122891iE9B7305FD01545D6/image-size/large?v=v2&amp;amp;px=999" role="button" title="177619_177619.png" alt="177619_177619.png" /&gt;&lt;/span&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/13695iAAF153D179728163/image-size/large?v=v2&amp;amp;px=999" role="button" title="pastedImage_1.png" alt="pastedImage_1.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;calling:&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;void &lt;STRONG&gt;SystemInit&lt;/STRONG&gt; (void) {&lt;/P&gt;&lt;P&gt;#if (DISABLE_WDOG)&lt;BR /&gt;&amp;nbsp; /* SIM_COPC: COPT=0,COPCLKS=0,COPW=0 */&lt;BR /&gt;&amp;nbsp; SIM-&amp;gt;COPC = (uint32_t)0x00u;&lt;BR /&gt;#endif /* (DISABLE_WDOG) */&lt;BR /&gt;&lt;BR /&gt;#ifdef CLOCK_SETUP&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;why is there another hardware init needed in KSDK group: board.c board.h ?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 19 Feb 2017 09:10:55 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649056#M6997</guid>
      <dc:creator>lucianfiran</dc:creator>
      <dc:date>2017-02-19T09:10:55Z</dc:date>
    </item>
    <item>
      <title>Re: MKW30Z hardware init</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649057#M6998</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi, Lucian,&lt;/P&gt;&lt;P&gt;If you check the code, you will see that code in board.c file is to configure the clock for core, flash and bus. But the &lt;STRONG&gt;SystemInit&lt;/STRONG&gt;() is used to disable watchdog,&lt;/P&gt;&lt;P&gt;Hope it can help you&lt;/P&gt;&lt;P&gt;BR&lt;/P&gt;&lt;P&gt;Xiangjun Rong&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 28 Feb 2017 08:13:19 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649057#M6998</guid>
      <dc:creator>xiangjun_rong</dc:creator>
      <dc:date>2017-02-28T08:13:19Z</dc:date>
    </item>
    <item>
      <title>Re: MKW30Z hardware init</title>
      <link>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649058#M6999</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I see this issue was addressed in SDK 2.0&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;A href="http://www.nxp.com/assets/documents/data/en/user-guides/KSDK20TUG.pdf"&gt;http://www.nxp.com/assets/documents/data/en/user-guides/KSDK20TUG.pdf&lt;/A&gt;&lt;/P&gt;&lt;P&gt;Kinetis SDK 2.0 Transition Guide&lt;/P&gt;&lt;P&gt;3.6 Startup&lt;BR /&gt;Kinetis SDK 2.0 has a somewhat different startup and initialization sequence. Code initially begins executing in the Reset_Handler found in \devices\&amp;lt;device&amp;gt;\&amp;lt;compiler&amp;gt;\startup_&amp;lt;device&amp;gt;.s. &lt;BR /&gt;The SystemInit() function is now found at \devices\&amp;lt;device&amp;gt; and is slightly different since it no longer provides an option to configure the clock at this point. &lt;BR /&gt;Its purpose is to enable cache (if available) and disable the watchdog timer. &lt;BR /&gt;The majority of the board initialization still occurs after reaching the main() function. &lt;BR /&gt;However the biggest change in how Kinetis SDK starts up is that there is no longer a hardware_init() function. Instead similar functions are called directly from main(). The following functions are typically called:&lt;BR /&gt;BOARD_InitPins();&lt;BR /&gt;BOARD_BootClockRUN();&lt;BR /&gt;BOARD_InitDebugConsole();&lt;BR /&gt;Inside of these initialization functions, the method and API for initializing pins and clocks has also been changed from 1.x.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 28 Feb 2017 09:46:18 GMT</pubDate>
      <guid>https://community.nxp.com/t5/Kinetis-Software-Development-Kit/MKW30Z-hardware-init/m-p/649058#M6999</guid>
      <dc:creator>lucianfiran</dc:creator>
      <dc:date>2017-02-28T09:46:18Z</dc:date>
    </item>
  </channel>
</rss>

