1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
typedef unsigned int u32;
typedef int s32;
s32 asr31(s32 a) { return a >> 31; }
s32 asr32(s32 a) { return a >> 32; }
s32 asr33(s32 a) { return a >> 33; }
u32 lsr31(u32 a) { return a >> 31; }
u32 lsr32(u32 a) { return a >> 32; }
u32 lsr33(u32 a) { return a >> 33; }
u32 shl31(u32 a) { return a << 31; }
u32 shl32(u32 a) { return a << 32; }
u32 shl33(u32 a) { return a << 33; }
/*
* check-name: optim/shift-big.c
* check-command: test-linearize -Wno-decl -m64 $file
*
* check-error-ignore
* check-output-start
asr31:
.L0:
<entry-point>
asr.32 %r2 <- %arg1, $31
ret.32 %r2
asr32:
.L2:
<entry-point>
asr.32 %r5 <- %arg1, $32
ret.32 %r5
asr33:
.L4:
<entry-point>
asr.32 %r8 <- %arg1, $33
ret.32 %r8
lsr31:
.L6:
<entry-point>
lsr.32 %r11 <- %arg1, $31
ret.32 %r11
lsr32:
.L8:
<entry-point>
lsr.32 %r14 <- %arg1, $32
ret.32 %r14
lsr33:
.L10:
<entry-point>
lsr.32 %r17 <- %arg1, $33
ret.32 %r17
shl31:
.L12:
<entry-point>
shl.32 %r20 <- %arg1, $31
ret.32 %r20
shl32:
.L14:
<entry-point>
shl.32 %r23 <- %arg1, $32
ret.32 %r23
shl33:
.L16:
<entry-point>
shl.32 %r26 <- %arg1, $33
ret.32 %r26
* check-output-end
*/
|