// Test signbits40
# mach: bfin
.include "testutils.inc"
start
// positive value in accum, smaller than 1.0
A1 = A0 = 0;
R0.L = 0xffff;
R0.H = 0x0000;
A0.w = R0;
R0.L = 0x0000;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x7fff ); DBGA ( R4.L , 0x8000 );
DBGA ( R5.H , 0x0000 ); DBGA ( R5.L , 0x0000 );
// neg value in accum, larger than -1.0
A1 = A0 = 0;
R0.L = 0x0000;
R0.H = 0xffff;
A0.w = R0;
R0.L = 0x00ff;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x8000 ); DBGA ( R4.L , 0x0000 );
DBGA ( R5.H , 0xffff ); DBGA ( R5.L , 0xffff );
// positive value in accum, larger than 1.0
A1 = A0 = 0;
R0.L = 0xffff;
R0.H = 0xffff;
A0.w = R0;
R0.L = 0x000f;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x7fff ); DBGA ( R4.L , 0xffff );
DBGA ( R5.H , 0x0000 ); DBGA ( R5.L , 0x0000 );
// negative value in accum, smaller than -1.0
A1 = A0 = 0;
R0.L = 0x0000;
R0.H = 0x0000;
A0.w = R0;
R0.L = 0x0080;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x8000 ); DBGA ( R4.L , 0x0000 );
DBGA ( R5.H , 0xffff ); DBGA ( R5.L , 0xffff );
// no normalization
A1 = A0 = 0;
R0.L = 0xfffa;
R0.H = 0x7fff;
A0.w = R0;
R0.L = 0x0000;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x7fff ); DBGA ( R4.L , 0xfffa );
DBGA ( R5.H , 0x0000 ); DBGA ( R5.L , 0x0000 );
// no normalization (-1.0)
A1 = A0 = 0;
R0.L = 0x0000;
R0.H = 0x8000;
A0.w = R0;
R0.L = 0x00ff;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x8000 ); DBGA ( R4.L , 0x0000 );
DBGA ( R5.H , 0xffff ); DBGA ( R5.L , 0xffff );
// norm by 1
A1 = A0 = 0;
R0.L = 0x0000;
R0.H = 0x8000;
A0.w = R0;
R0.L = 0x0000;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x4000 ); DBGA ( R4.L , 0x0000 );
DBGA ( R5.H , 0x0000 ); DBGA ( R5.L , 0x0000 );
// norm by 1
A1 = A0 = 0;
R0.L = 0x0000;
R0.H = 0x0000;
A0.w = R0;
R0.L = 0x00ff;
A0.x = R0;
R5.L = SIGNBITS A0;
_DBG R5;
A0 = ASHIFT A0 BY R5.L;
_DBG A0;
R4 = A0.w;
R5 = A0.x;
DBGA ( R4.H , 0x8000 ); DBGA ( R4.L , 0x0000 );
DBGA ( R5.H , 0xffff ); DBGA ( R5.L , 0xffff );
pass