blob: e7bf22fe36ffbe78b63ba037bf25eac040ca77c7 (
plain)
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
*/
|