How to reverse bitfield arrangement?

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

How to reverse bitfield arrangement?

2,768 次查看
fangfq
Contributor III

Hi,

I have a structure that contains bitfields in code. The question is on how to change the arrangement order of the bitfields within the byte.

Instead of having it arranged from MSB  to LSB, (What S32 DS doing by default)

typedef struct

{

   uint8_t    a:4;

   uint8_t    b:3;

} test;

LSB    0    1    2    3    4    5    6    7    MSB

       none b0  b1  b2  a0  a1  a2  a3

I would like to make it arranged from LSB to MSB,

typedef struct

{

   uint8_t    a:4;

   uint8_t    b:3;

} test;

LSB    0    1    2    3    4    5    6    7    MSB

          a0  a1  a2  a3  b0  b1  b2 none

This issue caused very serious problems on CAN communication legacy code as all the signals are defined as bitfields. 

In CodeWarrior, there was an option to config the compiler:

#pragma reverse_bitfields on

http://www.nxp.com/docs/en/reference-manual/CCOMPILERRM.pdf  Page 192

I would like how to do the same settings in S32 DS. Thanks in advance!

0 项奖励
回复
2 回复数

2,127 次查看
alexanderfedoto
NXP Employee
NXP Employee

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.

The simpliest way to support bi-endian is to use follwoing wrapper:

#ifdef LITTLE_ENDIAN /* Little endian order */
#define BITFIELDS_02(a01, a02) \
    a01; a02;
#elif defined BIG_ENDIAN
#define BITFIELDS_02(a01, a02) \
    a02; a01;

#else

#error "Endianess not defined"
#endif


typedef struct
{
BITFIELDS_02(
   uint8_t    a:4,
   uint8_t    b:3,
)
} test;

0 项奖励
回复

2,127 次查看
jiri_kral
NXP Employee
NXP Employee

Hello, 

I'm afraid that #pragma revese_bitfields on is no more supported by gcc version 4. There is similar question on stackoverflow site. 

Best way how to solve your issue is rewrite your structure definitions or do bit swap when you receive message from CAN bus. 

Jiri

0 项奖励
回复