<?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 Re: test CCR register/ assembler macros in S12 / MagniV Microcontrollers</title>
    <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179714#M6478</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Because it's&amp;nbsp;1) a waste of 1&amp;nbsp;byte of flash memory to store BIT_I constant, and 2) code is slower. Instead of using immediate addressing (BIT_I constant embedded in CPU instruction and&amp;nbsp;effectively queued in instruction queue), you are forcing CPU to read BIT_I from memory. This is much slower and thus doesn't make sense.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Mon, 07 Nov 2011 16:48:30 GMT</pubDate>
    <dc:creator>kef</dc:creator>
    <dc:date>2011-11-07T16:48:30Z</dc:date>
    <item>
      <title>test CCR register/ assembler macros</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179711#M6475</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have problem: I would like to find out if function is called from ISR or from main task context. I am not sure if it possible at all, but if I do not use nested interrupts than is enough for me to test if global maskable interrupts are masked or not, it is flag &lt;STRONG&gt;I&lt;/STRONG&gt; in &lt;STRONG&gt;CCR&lt;/STRONG&gt; register.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I wrote code but I am not sure if is correct, because I do not know how to use assembler with C code, may some one check:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;&lt;EM&gt;uint8_t CC;&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;static uint8_t const BIT_I = 0x10;&lt;/EM&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;EM&gt;__asm(pshc);&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;__asm(movb 1, SP+,CC);&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;__asm(DES);&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;__asm(pulc);&lt;/EM&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;EM&gt;if (CC &amp;amp; BIT_I)&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;{&lt;/EM&gt;&lt;BR /&gt;&lt;EM&gt;/* I flag is set */&lt;/EM&gt;&lt;BR /&gt; &lt;EM&gt;}&lt;/EM&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;issue for me are assembler macros, may someone looke at this macros if are they correct or there is easier soultion to read CCR register (maped to global memory?)?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Regards&lt;/P&gt;&lt;P&gt;/Greg&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 04 Nov 2011 19:12:18 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179711#M6475</guid>
      <dc:creator>grzegorzK</dc:creator>
      <dc:date>2011-11-04T19:12:18Z</dc:date>
    </item>
    <item>
      <title>Re: test CCR register/ assembler macros</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179712#M6476</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;These two lines should suffice&lt;/P&gt;&lt;P&gt;&lt;EM&gt;__asm(pshc);&lt;/EM&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp; &lt;EM&gt;__asm(movb 1, SP+,CC);&lt;/EM&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Or without stack manipulations, just&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; TFR&amp;nbsp; CCR, A&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; STAA&amp;nbsp; CC&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;It doesn't make sense to allocate BIT_I constant in flash. Better define it either as&lt;/P&gt;&lt;P&gt;#define BIT_I 0x40&lt;/P&gt;&lt;P&gt;or&lt;/P&gt;&lt;P&gt;enum {BIT_I=0x40};&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 04 Nov 2011 21:39:22 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179712#M6476</guid>
      <dc:creator>kef</dc:creator>
      <dc:date>2011-11-04T21:39:22Z</dc:date>
    </item>
    <item>
      <title>Re: test CCR register/ assembler macros</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179713#M6477</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;BLOCKQUOTE&gt;Thank you&lt;/BLOCKQUOTE&gt;&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;&lt;BLOCKQUOTE&gt;kef wrote:&lt;/BLOCKQUOTE&gt;&lt;BLOCKQUOTE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;It doesn't make sense to allocate BIT_I constant in flash. Better define it either as&lt;/P&gt;&lt;P&gt;#define BIT_I 0x40&lt;/P&gt;&lt;P&gt;or&lt;/P&gt;&lt;P&gt;enum {BIT_I=0x40};&lt;/P&gt;&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;why it does not make sense? I do not understand.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 07 Nov 2011 16:06:11 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179713#M6477</guid>
      <dc:creator>grzegorzK</dc:creator>
      <dc:date>2011-11-07T16:06:11Z</dc:date>
    </item>
    <item>
      <title>Re: test CCR register/ assembler macros</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179714#M6478</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Because it's&amp;nbsp;1) a waste of 1&amp;nbsp;byte of flash memory to store BIT_I constant, and 2) code is slower. Instead of using immediate addressing (BIT_I constant embedded in CPU instruction and&amp;nbsp;effectively queued in instruction queue), you are forcing CPU to read BIT_I from memory. This is much slower and thus doesn't make sense.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 07 Nov 2011 16:48:30 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/test-CCR-register-assembler-macros/m-p/179714#M6478</guid>
      <dc:creator>kef</dc:creator>
      <dc:date>2011-11-07T16:48:30Z</dc:date>
    </item>
  </channel>
</rss>

