URL
https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk
Subversion Repositories openrisc_me
[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [gcc.target/] [xstormy16/] [sfr/] [26_if1_sfrw_bitfield_3.c] - Rev 329
Compare with Previous | Blame | View Log
/* { dg-options { -nostartfiles below100.o -Tbelow100.ld -O2 } } */ /* { dg-final { scan-assembler "bn 32532,#3" } } */ typedef struct { unsigned short b0:1; unsigned short b1:1; unsigned short b2:1; unsigned short b3:1; unsigned short b4:1; unsigned short b5:1; unsigned short b6:1; unsigned short b7:1; unsigned short b8:1; unsigned short b9:1; unsigned short b10:1; unsigned short b11:1; unsigned short b12:1; unsigned short b13:1; unsigned short b14:1; unsigned short b15:1; } BitField; #define SFRA (*((volatile BitField*)0x7f14)) unsigned short *pA = (unsigned short *) 0x7f14; #define SFRB (*((volatile BitField*)0x7f10)) unsigned short *pB = (unsigned short *) 0x7f10; char * Do (void) { if (SFRA.b3) { if (SFRB.b3) return "Fail"; else return "Success"; } else return "Fail"; } int main (void) { *pA = 0xedcb; *pB = 0x1234; return Do ()[0] == 'F'; }