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 87 88 89 90 91 92 93
|
#define bool _Bool
bool bfimp(float a) { return a; }
bool bfexp(float a) { return (bool)a; }
bool bfnot(float a) { return !a; }
int ifnot(float a) { return !a; }
bool bfior(float a, float b) { return a || b; }
int ifior(float a, float b) { return a || b; }
bool bfand(float a, float b) { return a && b; }
int ifand(float a, float b) { return a && b; }
/*
* check-name: bool context fp
* check-command: test-linearize -Wno-decl $file
*
* check-output-start
bfimp:
.L0:
<entry-point>
setfval.32 %r2 <- 0.000000e+00
fcmpune.1 %r3 <- %arg1, %r2
ret.1 %r3
bfexp:
.L2:
<entry-point>
setfval.32 %r6 <- 0.000000e+00
fcmpune.1 %r7 <- %arg1, %r6
ret.1 %r7
bfnot:
.L4:
<entry-point>
setfval.32 %r10 <- 0.000000e+00
fcmpoeq.1 %r12 <- %arg1, %r10
ret.1 %r12
ifnot:
.L6:
<entry-point>
setfval.32 %r15 <- 0.000000e+00
fcmpoeq.32 %r16 <- %arg1, %r15
ret.32 %r16
bfior:
.L8:
<entry-point>
setfval.32 %r19 <- 0.000000e+00
fcmpune.1 %r20 <- %arg1, %r19
fcmpune.1 %r23 <- %arg2, %r19
or.1 %r24 <- %r20, %r23
ret.1 %r24
ifior:
.L10:
<entry-point>
setfval.32 %r29 <- 0.000000e+00
fcmpune.1 %r30 <- %arg1, %r29
fcmpune.1 %r33 <- %arg2, %r29
or.1 %r34 <- %r30, %r33
zext.32 %r35 <- (1) %r34
ret.32 %r35
bfand:
.L12:
<entry-point>
setfval.32 %r38 <- 0.000000e+00
fcmpune.1 %r39 <- %arg1, %r38
fcmpune.1 %r42 <- %arg2, %r38
and.1 %r43 <- %r39, %r42
ret.1 %r43
ifand:
.L14:
<entry-point>
setfval.32 %r48 <- 0.000000e+00
fcmpune.1 %r49 <- %arg1, %r48
fcmpune.1 %r52 <- %arg2, %r48
and.1 %r53 <- %r49, %r52
zext.32 %r54 <- (1) %r53
ret.32 %r54
* check-output-end
*/
|