<?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 How to use the Acceptance Filter MSCAN of MC9S12ZVC? in S12 / MagniV Microcontrollers</title>
    <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512772#M12490</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello. My name is Ryu.&lt;/P&gt;&lt;P&gt;I'd like to know how to use the acceptance filter of MSCAN.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I use standard id&lt;SPAN style="color: #606060;"&gt;&lt;STRONG&gt; 0x1F0 ~ 0x1F4, 0x5FA ~ 0x5FC&lt;/STRONG&gt;.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;And Below Functions are generated by PE.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;SetAcceptanceMode(byte Mode);&lt;/P&gt;&lt;P&gt;SetAcceptanceCode(dword AccCode1, dword AccCode2);&lt;/P&gt;&lt;P&gt;SetAcceptanceCode(dword AccCode1, dword AccCode2);&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Please let me know how to set the Acceptance Filter using these functions.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 19 Apr 2016 07:56:52 GMT</pubDate>
    <dc:creator>seung-taeryu</dc:creator>
    <dc:date>2016-04-19T07:56:52Z</dc:date>
    <item>
      <title>How to use the Acceptance Filter MSCAN of MC9S12ZVC?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512772#M12490</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello. My name is Ryu.&lt;/P&gt;&lt;P&gt;I'd like to know how to use the acceptance filter of MSCAN.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I use standard id&lt;SPAN style="color: #606060;"&gt;&lt;STRONG&gt; 0x1F0 ~ 0x1F4, 0x5FA ~ 0x5FC&lt;/STRONG&gt;.&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;And Below Functions are generated by PE.&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;SetAcceptanceMode(byte Mode);&lt;/P&gt;&lt;P&gt;SetAcceptanceCode(dword AccCode1, dword AccCode2);&lt;/P&gt;&lt;P&gt;SetAcceptanceCode(dword AccCode1, dword AccCode2);&lt;/P&gt;&lt;P style="min-height: 8pt; padding: 0px;"&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Please let me know how to set the Acceptance Filter using these functions.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 19 Apr 2016 07:56:52 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512772#M12490</guid>
      <dc:creator>seung-taeryu</dc:creator>
      <dc:date>2016-04-19T07:56:52Z</dc:date>
    </item>
    <item>
      <title>Re: How to use the Acceptance Filter MSCAN of MC9S12ZVC?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512773#M12491</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Seung-Tang,&lt;/P&gt;&lt;P&gt;I suppose that you mean functions:&lt;/P&gt;&lt;P&gt;SetAcceptanceMode(byte Mode);&lt;/P&gt;&lt;P&gt;SetAcceptanceCode(dword AccCode1, dword AccCode2);&lt;/P&gt;&lt;P&gt;SetAcceptanceMask(dword AccMask1, dword AccMask2);&lt;/P&gt;&lt;P&gt;In fact, these functions just write Mode, AccCode1, AccCode2, AccMask1 and AccMask2 values into appropriate CANIDAC_IDAM, CANIDARx and CANIDMRx registers.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Since you use standard ID (11bit ID), you could define up to 4 16bit filters (or up to 8 8bit filters).&lt;/P&gt;&lt;P&gt;Note: The bit IDE=0 in the case of standard IDs.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I will focus now only on 16bit filter mode – Mode=0x01&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;When we will write your IDs as binary, we could see that four 16bit filters will be enough and simultaneously you will also filter-out all other IDs.&lt;/P&gt;&lt;P&gt;0x1F0&amp;nbsp; -&amp;gt; 001 1111 0000&lt;/P&gt;&lt;P&gt;0x1F1&amp;nbsp; -&amp;gt; 001 1111 0001&lt;/P&gt;&lt;P&gt;0x1F2&amp;nbsp; -&amp;gt; 001 1111 0010&lt;/P&gt;&lt;P&gt;0x1F3&amp;nbsp; -&amp;gt; 001 1111 0011&lt;/P&gt;&lt;P&gt;The first filter will be 001 1111 00XX = 0011 1110 0XX0 0000 after left alignment -&amp;gt; 0x3E00 (0x3E10 in the case of Remote frame) as ID and 0x0067 (0x0077 if we do not care whether it is Data or Remote frame) as mask.&lt;/P&gt;&lt;P&gt;Note: We do not care about the last three bits in 16bit filter&lt;/P&gt;&lt;P&gt;CANIDAR1 =0x3E, CANIDAR0 =0x00, CANIDMR1 =0x00, CANIDMR0 =0x67&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;0x1F4&amp;nbsp; -&amp;gt; 001 1111 0100&lt;/P&gt;&lt;P&gt;The second filter will be 001 1111 0100 = 0011 1110 1000 0000 after left alignment -&amp;gt; 0x3E80 (0x3E90 in the case of Remote frame) as ID and 0x0007 (0x0017 if we do not care whether it is Data or Remote frame) mask.&lt;/P&gt;&lt;P&gt;CANIDAR3 =0x3E, CANIDAR2 =0x00, CANIDMR3 =0x00, CANIDMR2 =0x07&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;0x5FA&amp;nbsp; -&amp;gt; 101 1111 1010&lt;/P&gt;&lt;P&gt;0x5FB&amp;nbsp; -&amp;gt; 101 1111 1011&lt;/P&gt;&lt;P&gt;The third filter will be 101 1111 101X = 1011 1111 01X0 0000 after left alignment -&amp;gt; 0xBF40 (0xBF50 in the case of Remote frame) as ID and 0x0027 (0x0037 if we do not care whether it is Data or Remote frame) mask.&lt;/P&gt;&lt;P&gt;CANIDAR5 =0xBF, CANIDAR4 =0x40, CANIDMR5 =0x00, CANIDMR4 =0x27&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;0x5FC&amp;nbsp; -&amp;gt; 101 1111 1100&lt;/P&gt;&lt;P&gt;The fourth filter will be 101 1111 1100 = 1011 1111 1000 0000 after left alignment -&amp;gt; 0xBF80 (0xBF90 in the case of Remote frame) as ID and 0x0007 (0x0017 if we do not care whether it is Data or Remote frame) mask.&lt;/P&gt;&lt;P&gt;CANIDAR7 =0xBF, CANIDAR6 =0x80, CANIDMR7 =0x00, CANIDMR6 =0x07&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The AccCode1,2 and AccMask1,2 types are defined as:&lt;/P&gt;&lt;P&gt;typedef union {&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dword dw;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; struct {&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; byte b0;&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; byte b1;&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; byte b2;&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; byte b3;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }b;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; }DwordSwap;&lt;/P&gt;&lt;P&gt;Therefore the AccCode1 should be 0x003E003E, AccCode2 should be 0x40BF80BF, AccMask1 should be 0x67000700 and AccMask2 should be 0x27000700.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I hope that I didn’t make any mistake in my calculations.&lt;/P&gt;&lt;P&gt;Please check it.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;I hope it helps you.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;RadekS&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>Wed, 20 Apr 2016 12:46:42 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512773#M12491</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2016-04-20T12:46:42Z</dc:date>
    </item>
    <item>
      <title>Re: How to use the Acceptance Filter MSCAN of MC9S12ZVC?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512774#M12492</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Radek&lt;/P&gt;&lt;P&gt;I seem to have a problem understanding how to implement acceptance masks for extended IDs. I have a project that needs to respond only to message ID 0x0FF0001 and 0x0FF0002. I would be grateful if you could show me how to achieve this.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Regards&lt;/P&gt;&lt;P&gt;Gordon&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 31 Oct 2018 14:06:40 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512774#M12492</guid>
      <dc:creator>gordonp</dc:creator>
      <dc:date>2018-10-31T14:06:40Z</dc:date>
    </item>
    <item>
      <title>Re: How to use the Acceptance Filter MSCAN of MC9S12ZVC?</title>
      <link>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512775#M12493</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Gordon,&lt;/P&gt;&lt;P&gt;please look at document&amp;nbsp;&lt;A href="https://community.nxp.com/docs/DOC-335457"&gt;CAN Standard ID and CAN Extended ID for S12(X) and MagniV devices, memories refreshment&lt;/A&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Since you need filtering extended ID, please look at EXTENDED ID sheet.&lt;/P&gt;&lt;P&gt;Some more details regarding MSCAN module you may get from &lt;A href="https://community.nxp.com/external-link.jspa?url=http%3A%2F%2Fwww.nxp.com%2Ffiles%2Fmicrocontrollers%2Fdoc%2Fapp_note%2FAN3034.pdf"&gt;AN3034 Using MSCAN on the HCS12 Family&lt;/A&gt;, &lt;A href="https://community.nxp.com/external-link.jspa?url=http%3A%2F%2Fwww.nxp.com%2Fwebapp%2Fsps%2Fdownload%2Flicense.jsp%3FcolCode%3DAN3034SW"&gt;SW&lt;/A&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;I hope it helps you&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Have a great day,&lt;BR /&gt;Radek&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 31 Oct 2018 16:58:05 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S12-MagniV-Microcontrollers/How-to-use-the-Acceptance-Filter-MSCAN-of-MC9S12ZVC/m-p/512775#M12493</guid>
      <dc:creator>RadekS</dc:creator>
      <dc:date>2018-10-31T16:58:05Z</dc:date>
    </item>
  </channel>
</rss>

