<?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のトピックRe: Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
    <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224335#M6035</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm using the KEIL tool chain.&amp;nbsp; I suppose there are implications across linkers, but they should be fairly generic.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;An example of the vector table can be found as part of the Freescale CMSIS distribution which is produced by Freescale, so I think this would be a natural shoe-in for MQX (file header example below).&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;;/*****************************************************************************&lt;/P&gt;&lt;P&gt;; * @file:&amp;nbsp;&amp;nbsp;&amp;nbsp; startup_MK60F12.s&lt;/P&gt;&lt;P&gt;; * @purpose: CMSIS Cortex-M4 Core Device Startup File for the&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; MK60F12&lt;/P&gt;&lt;P&gt;; * @version: 1.1&lt;/P&gt;&lt;P&gt;; * @date:&amp;nbsp;&amp;nbsp;&amp;nbsp; 2011-11-3&lt;/P&gt;&lt;P&gt;; *&lt;/P&gt;&lt;P&gt;; * Copyright: 1997 - 2012 Freescale Semiconductor, Inc. All Rights Reserved.&lt;/P&gt;&lt;P&gt;;*&lt;/P&gt;&lt;P&gt;; *------- &amp;lt;&amp;lt;&amp;lt; Use Configuration Wizard in Context Menu &amp;gt;&amp;gt;&amp;gt; ------------------&lt;/P&gt;&lt;P&gt;; *&lt;/P&gt;&lt;P&gt;; *****************************************************************************/&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Mon, 06 May 2013 21:26:33 GMT</pubDate>
    <dc:creator>pmt</dc:creator>
    <dc:date>2013-05-06T21:26:33Z</dc:date>
    <item>
      <title>Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224333#M6033</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Greetings,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In the MQX vectors.c file the majority of the vectors are set to a single define, DEFAULT_VECTOR:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* Cortex external interrupt vectors&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;&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; */&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; DEFAULT_VECTOR,&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* 0x10&amp;nbsp; 0x00000040&amp;nbsp;&amp;nbsp; -&amp;nbsp;&amp;nbsp; ivINT_DMA0&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;&amp;nbsp;&amp;nbsp;&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; DEFAULT_VECTOR,&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; /* 0x11&amp;nbsp; 0x00000044&amp;nbsp;&amp;nbsp; -&amp;nbsp;&amp;nbsp; ivINT_DMA1&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;&amp;nbsp;&amp;nbsp;&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; ...&lt;/P&gt;&lt;P&gt;However, more useful would be if they are set to unique names:&lt;/P&gt;&lt;P&gt;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; ; External Interrupts&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; DCD&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DMA0_DMA16_IRQHandler&amp;nbsp; ; DMA channel 0/16 transfer complete interrupt&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; DCD&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DMA1_DMA17_IRQHandler&amp;nbsp; ; DMA channel 1/17 transfer complete interrupt&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; ...&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;That are set to the default handler with a WEAK export:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Default_Handler PROC&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; EXPORT&amp;nbsp; DMA0_DMA16_IRQHandler&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; [WEAK]&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;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; EXPORT&amp;nbsp; DMA1_DMA17_IRQHandler&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; [WEAK]&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;&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;&amp;nbsp;&amp;nbsp;&amp;nbsp; // default ISR handler&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;then the user is able to create an override function in the user code like without the need to call run-time kernel interrupt install code.&amp;nbsp; This is true even if the vector table is left in ROM:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;// User kernel ISR C code example&lt;/P&gt;&lt;P&gt;void DMA0_DMA16_IRQHandler(void)&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; // ISR handler here ...&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 10pt; line-height: 1.5em;"&gt;}&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Can you consider this as a modification to the MQX vector BSPs?&amp;nbsp; It would allow compile time kernel ISR installation that woudl work in ROM or RAM.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;PMT&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 04 May 2013 02:42:34 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224333#M6033</guid>
      <dc:creator>pmt</dc:creator>
      <dc:date>2013-05-04T02:42:34Z</dc:date>
    </item>
    <item>
      <title>Re: Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224334#M6034</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;What toolchain are you using?&amp;nbsp; Any implication across different linkers?&amp;nbsp;&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks for posting.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;MacL&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 06 May 2013 20:54:39 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224334#M6034</guid>
      <dc:creator>macl</dc:creator>
      <dc:date>2013-05-06T20:54:39Z</dc:date>
    </item>
    <item>
      <title>Re: Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224335#M6035</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm using the KEIL tool chain.&amp;nbsp; I suppose there are implications across linkers, but they should be fairly generic.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;An example of the vector table can be found as part of the Freescale CMSIS distribution which is produced by Freescale, so I think this would be a natural shoe-in for MQX (file header example below).&amp;nbsp; &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;;/*****************************************************************************&lt;/P&gt;&lt;P&gt;; * @file:&amp;nbsp;&amp;nbsp;&amp;nbsp; startup_MK60F12.s&lt;/P&gt;&lt;P&gt;; * @purpose: CMSIS Cortex-M4 Core Device Startup File for the&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; MK60F12&lt;/P&gt;&lt;P&gt;; * @version: 1.1&lt;/P&gt;&lt;P&gt;; * @date:&amp;nbsp;&amp;nbsp;&amp;nbsp; 2011-11-3&lt;/P&gt;&lt;P&gt;; *&lt;/P&gt;&lt;P&gt;; * Copyright: 1997 - 2012 Freescale Semiconductor, Inc. All Rights Reserved.&lt;/P&gt;&lt;P&gt;;*&lt;/P&gt;&lt;P&gt;; *------- &amp;lt;&amp;lt;&amp;lt; Use Configuration Wizard in Context Menu &amp;gt;&amp;gt;&amp;gt; ------------------&lt;/P&gt;&lt;P&gt;; *&lt;/P&gt;&lt;P&gt;; *****************************************************************************/&lt;/P&gt;&lt;P&gt;&lt;SPAN class="mce_paste_marker"&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 06 May 2013 21:26:33 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224335#M6035</guid>
      <dc:creator>pmt</dc:creator>
      <dc:date>2013-05-06T21:26:33Z</dc:date>
    </item>
    <item>
      <title>Re: Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224336#M6036</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello pmt,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I noticed you are using KEIL, samples you posted are from assembly file for freescale board, something similar is in CMSIS as well. I have not tested weak linkage with all compilers we support (GCC, GCC, IAR, ARMCC, Kinetis CW compiler). &lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;What would you loose if you don't call run-time function, chaining ISR interrupts, because _int_install_kernel_isr returns pointer to the previous ISR and temporarily assig ISR to a vector.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards,&lt;/P&gt;&lt;P&gt;c0170&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 07 May 2013 05:50:24 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224336#M6036</guid>
      <dc:creator>c0170</dc:creator>
      <dc:date>2013-05-07T05:50:24Z</dc:date>
    </item>
    <item>
      <title>Re: Overriding MQX ROM Vector table at compile time, kernel_isr Feature Request</title>
      <link>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224337#M6037</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;That's true, you would loose the chaining of the MQX default interrupt, but only if the user manually chose to override the out of-the-box MQX default vector table value.&amp;nbsp; In most cases this is simply the _default_interrupt handler anyway.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The advantages are:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; - That you gain the ability to install user interrupt in a ROM build vector table (this is a definable option under MQX).&amp;nbsp; &lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; - No need to run-time install the interrupt vector, though the user still has the option to call _int_install with RAM vector tables.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; - Better aligns with CMSIS which has a lot of value in providing greater portability.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In the end I think this gives the user more flexibility and will maintain default backward compatibility.&amp;nbsp; Something to consider!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;PMT&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 07 May 2013 13:28:52 GMT</pubDate>
      <guid>https://community.nxp.com/t5/MQX-Software-Solutions/Overriding-MQX-ROM-Vector-table-at-compile-time-kernel-isr/m-p/224337#M6037</guid>
      <dc:creator>pmt</dc:creator>
      <dc:date>2013-05-07T13:28:52Z</dc:date>
    </item>
  </channel>
</rss>

