<?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 reverse bitfield arrangement? in S32 Design Studio</title>
    <link>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689526#M1535</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 have a structure that&amp;nbsp;contains bitfields in code.&amp;nbsp;The question is on how to change the arrangement order of the bitfields within the byte.&lt;/P&gt;&lt;P&gt;Instead of having it arranged from MSB &amp;nbsp;to LSB, (What S32 DS doing&amp;nbsp;by default)&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;typedef struct&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN style="background-color: #f6f6f6;"&gt;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;a:4;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;b:3;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;} test;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;LSB&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;0 &amp;nbsp;&amp;nbsp;&amp;nbsp;1 &amp;nbsp;&amp;nbsp;&amp;nbsp;2 &amp;nbsp;&amp;nbsp;&amp;nbsp;3 &amp;nbsp;&amp;nbsp;&amp;nbsp;4 &amp;nbsp;&amp;nbsp;&amp;nbsp;5 &amp;nbsp;&amp;nbsp;&amp;nbsp;6 &amp;nbsp;&amp;nbsp;&amp;nbsp;7 &amp;nbsp;&amp;nbsp;&amp;nbsp;MSB&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; none b0&amp;nbsp; b1 &amp;nbsp;b2 &amp;nbsp;a0 &amp;nbsp;a1 &amp;nbsp;a2&amp;nbsp; a3&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;I would like to make it&amp;nbsp;&lt;SPAN&gt;arranged from LSB to MSB,&lt;/SPAN&gt;&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;typedef struct&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN style="background-color: #f6f6f6;"&gt;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;a:4;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;b:3;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;}&amp;nbsp;test;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;LSB&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;0 &amp;nbsp;&amp;nbsp;&amp;nbsp;1 &amp;nbsp;&amp;nbsp;&amp;nbsp;2 &amp;nbsp;&amp;nbsp;&amp;nbsp;3 &amp;nbsp;&amp;nbsp;&amp;nbsp;4 &amp;nbsp;&amp;nbsp;&amp;nbsp;5 &amp;nbsp;&amp;nbsp;&amp;nbsp;6 &amp;nbsp;&amp;nbsp;&amp;nbsp;7 &amp;nbsp;&amp;nbsp;&amp;nbsp;MSB&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; a0 &amp;nbsp;a1 &amp;nbsp;a2 &amp;nbsp;a3&amp;nbsp; b0&amp;nbsp; b1&amp;nbsp;&amp;nbsp;b2 none&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This issue caused very serious problems on CAN communication legacy code as all the signals are defined as bitfields.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In CodeWarrior, there was an option to config the&amp;nbsp;compiler:&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;#pragma reverse_bitfields on&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;A class="link-titled" href="http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf" title="http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf"&gt;http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf&lt;/A&gt;&amp;nbsp; Page 192&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I would like how to do the same settings&amp;nbsp;in S32 DS. Thanks in advance!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 01 Aug 2017 00:18:55 GMT</pubDate>
    <dc:creator>fangfq</dc:creator>
    <dc:date>2017-08-01T00:18:55Z</dc:date>
    <item>
      <title>How to reverse bitfield arrangement?</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689526#M1535</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 have a structure that&amp;nbsp;contains bitfields in code.&amp;nbsp;The question is on how to change the arrangement order of the bitfields within the byte.&lt;/P&gt;&lt;P&gt;Instead of having it arranged from MSB &amp;nbsp;to LSB, (What S32 DS doing&amp;nbsp;by default)&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;typedef struct&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN style="background-color: #f6f6f6;"&gt;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;a:4;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;b:3;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;} test;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;LSB&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;0 &amp;nbsp;&amp;nbsp;&amp;nbsp;1 &amp;nbsp;&amp;nbsp;&amp;nbsp;2 &amp;nbsp;&amp;nbsp;&amp;nbsp;3 &amp;nbsp;&amp;nbsp;&amp;nbsp;4 &amp;nbsp;&amp;nbsp;&amp;nbsp;5 &amp;nbsp;&amp;nbsp;&amp;nbsp;6 &amp;nbsp;&amp;nbsp;&amp;nbsp;7 &amp;nbsp;&amp;nbsp;&amp;nbsp;MSB&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; none b0&amp;nbsp; b1 &amp;nbsp;b2 &amp;nbsp;a0 &amp;nbsp;a1 &amp;nbsp;a2&amp;nbsp; a3&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;I would like to make it&amp;nbsp;&lt;SPAN&gt;arranged from LSB to MSB,&lt;/SPAN&gt;&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;typedef struct&lt;/P&gt;&lt;P&gt;{&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;SPAN style="background-color: #f6f6f6;"&gt;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;a:4;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;uint8_t &amp;nbsp;&amp;nbsp;&amp;nbsp;b:3;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;}&amp;nbsp;test;&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;LSB&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;0 &amp;nbsp;&amp;nbsp;&amp;nbsp;1 &amp;nbsp;&amp;nbsp;&amp;nbsp;2 &amp;nbsp;&amp;nbsp;&amp;nbsp;3 &amp;nbsp;&amp;nbsp;&amp;nbsp;4 &amp;nbsp;&amp;nbsp;&amp;nbsp;5 &amp;nbsp;&amp;nbsp;&amp;nbsp;6 &amp;nbsp;&amp;nbsp;&amp;nbsp;7 &amp;nbsp;&amp;nbsp;&amp;nbsp;MSB&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;SPAN style="background-color: #f6f6f6;"&gt;&lt;SPAN&gt;&amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; &amp;nbsp; a0 &amp;nbsp;a1 &amp;nbsp;a2 &amp;nbsp;a3&amp;nbsp; b0&amp;nbsp; b1&amp;nbsp;&amp;nbsp;b2 none&lt;/SPAN&gt;&lt;/SPAN&gt;&lt;/P&gt;&lt;P style="margin: 0px; padding: 0px;"&gt;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This issue caused very serious problems on CAN communication legacy code as all the signals are defined as bitfields.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;In CodeWarrior, there was an option to config the&amp;nbsp;compiler:&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;#pragma reverse_bitfields on&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;P&gt;&lt;A class="link-titled" href="http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf" title="http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf"&gt;http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf&lt;/A&gt;&amp;nbsp; Page 192&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I would like how to do the same settings&amp;nbsp;in S32 DS. Thanks in advance!&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 01 Aug 2017 00:18:55 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689526#M1535</guid>
      <dc:creator>fangfq</dc:creator>
      <dc:date>2017-08-01T00:18:55Z</dc:date>
    </item>
    <item>
      <title>Re: How to reverse bitfield arrangement?</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689527#M1536</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'm afraid that #pragma revese_bitfields on is no more supported by gcc version 4. There is similar question on&amp;nbsp;&lt;A href="https://stackoverflow.com/questions/6728218/how-to-enforce-the-struct-bit-order-with-the-gcc-compiler"&gt;stackoverflow&lt;/A&gt;&amp;nbsp;site.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Best way how to solve your issue is rewrite your structure definitions or do bit swap when you receive message from CAN bus.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Jiri&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 01 Aug 2017 07:58:51 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689527#M1536</guid>
      <dc:creator>jiri_kral</dc:creator>
      <dc:date>2017-08-01T07:58:51Z</dc:date>
    </item>
    <item>
      <title>Re: How to reverse bitfield arrangement?</title>
      <link>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689528#M1537</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Bitfiled allocation is not detined by standard and compiler do whatever he wants with this. Although most of compilers doesn't change fields order inside of.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;The simpliest way to support bi-endian is to use follwoing wrapper:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;BLOCKQUOTE class="jive_macro_quote jive-quote jive_text_macro"&gt;&lt;P&gt;#ifdef LITTLE_ENDIAN /* Little endian order */&lt;BR /&gt;#define BITFIELDS_02(a01, a02) \&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; a01; a02;&lt;BR /&gt;#elif defined BIG_ENDIAN&lt;BR /&gt;#define BITFIELDS_02(a01, a02) \&lt;BR /&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; a02; a01;&lt;/P&gt;&lt;P&gt;#else&lt;/P&gt;&lt;P&gt;#error "Endianess not defined"&lt;BR /&gt;#endif&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;typedef struct&lt;BR /&gt;{&lt;BR /&gt;&lt;STRONG&gt;BITFIELDS_02(&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; uint8_t&amp;nbsp;&amp;nbsp;&amp;nbsp; a:4&lt;STRONG&gt;,&lt;/STRONG&gt;&lt;BR /&gt;&amp;nbsp;&amp;nbsp; uint8_t&amp;nbsp;&amp;nbsp;&amp;nbsp; b:3&lt;STRONG&gt;,&lt;/STRONG&gt;&lt;BR /&gt;&lt;STRONG&gt;)&lt;/STRONG&gt;&lt;BR /&gt;} test;&lt;/P&gt;&lt;/BLOCKQUOTE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Wed, 02 Aug 2017 11:33:09 GMT</pubDate>
      <guid>https://community.nxp.com/t5/S32-Design-Studio/How-to-reverse-bitfield-arrangement/m-p/689528#M1537</guid>
      <dc:creator>alexanderfedoto</dc:creator>
      <dc:date>2017-08-02T11:33:09Z</dc:date>
    </item>
  </channel>
</rss>

