URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [gcc.target/] [xstormy16/] [sfr/] [27_if0_sfrw_bitfield_f.c] - Rev 691
Compare with Previous | Blame | View Log
/* { dg-options { -nostartfiles below100.o -Tbelow100.ld -O2 } } */ /* { dg-final { scan-assembler "mov.b r., *32533" } } */ 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.b15) { if (!SFRB.b15) return "Fail"; else return "Success"; } else return "Fail"; } int main (void) { *pA = 0x1234; *pB = 0xedcb; return Do ()[0] == 'F'; }