aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/validation/optim/shift-big.c
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
 */