diff options
| author | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2018-08-03 18:46:10 +0200 |
|---|---|---|
| committer | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2018-08-06 08:50:52 +0200 |
| commit | 5fccf5f5a85d01ca21d06675216345a182555cce (patch) | |
| tree | 2ff8f6a5e810588c4797f204a2fb04d65b0ce7a2 /validation/linear | |
| parent | c47f18c7699d0a9fbb8b8adbd2c3bf177214beb4 (diff) | |
| download | sparse-dev-5fccf5f5a85d01ca21d06675216345a182555cce.tar.gz | |
simplify linearize_logical()
The linearized code for logical expressions looks like:
.Lc
... condition 1 ...
cbr %c, .L1, .L2
.L1
%phisrc %phi1 <- $1
br .Lm
.L2
... condition 2 ...
%phisrc %phi2 <- %r
br .Lm
.Lm
%phi %r <- %phi1, %phi2
But .L1 can easily be merged with .Lc:
.Lc
... condition 1 ...
%phisrc %phi1 <- $1
cbr %c, .Lm, .L2
.L2
... condition 2 ...
%phisrc %phi2 <- %r
br .Lm
.Lm
%phi %r <- %phi1, %phi2
Do this simplification which:
* creates less basic blocks & branches
* do at linearization time a simplification not done later.
Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@gmail.com>
Diffstat (limited to 'validation/linear')
| -rw-r--r-- | validation/linear/logical.c | 160 |
1 files changed, 68 insertions, 92 deletions
diff --git a/validation/linear/logical.c b/validation/linear/logical.c index ed0dd70e..148ad427 100644 --- a/validation/linear/logical.c +++ b/validation/linear/logical.c @@ -26,15 +26,12 @@ os: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi1 <- $1 load.32 %r1 <- 0[i] setne.1 %r2 <- %r1, $0 - cbr %r2, .L2, .L3 + cbr %r2, .L3, .L2 .L2: - phisrc.32 %phi1 <- $1 - br .L4 - -.L3: load.64 %r3 <- 0[b] load.32 %r4 <- 0[%r3] lsr.32 %r5 <- %r4, $1 @@ -42,9 +39,9 @@ os: setne.1 %r7 <- %r6, $0 zext.32 %r8 <- (1) %r7 phisrc.32 %phi2 <- %r8 - br .L4 + br .L3 -.L4: +.L3: phi.32 %r9 <- %phi1, %phi2 phisrc.32 %phi3(return) <- %r9 br .L1 @@ -55,19 +52,16 @@ os: ou: -.L5: +.L4: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi5 <- $1 load.32 %r11 <- 0[i] setne.1 %r12 <- %r11, $0 - cbr %r12, .L7, .L8 + cbr %r12, .L7, .L6 -.L7: - phisrc.32 %phi5 <- $1 - br .L9 - -.L8: +.L6: load.64 %r13 <- 0[b] load.32 %r14 <- 0[%r13] lsr.32 %r15 <- %r14, $3 @@ -75,206 +69,188 @@ ou: setne.1 %r17 <- %r16, $0 zext.32 %r18 <- (1) %r17 phisrc.32 %phi6 <- %r18 - br .L9 + br .L7 -.L9: +.L7: phi.32 %r19 <- %phi5, %phi6 phisrc.32 %phi7(return) <- %r19 - br .L6 + br .L5 -.L6: +.L5: phi.32 %r20 <- %phi7(return) ret.32 %r20 ol: -.L10: +.L8: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi9 <- $1 load.32 %r21 <- 0[i] setne.1 %r22 <- %r21, $0 - cbr %r22, .L12, .L13 + cbr %r22, .L11, .L10 -.L12: - phisrc.32 %phi9 <- $1 - br .L14 - -.L13: +.L10: load.64 %r23 <- 0[b] load.64 %r24 <- 8[%r23] setne.1 %r25 <- %r24, $0 zext.32 %r26 <- (1) %r25 phisrc.32 %phi10 <- %r26 - br .L14 + br .L11 -.L14: +.L11: phi.32 %r27 <- %phi9, %phi10 phisrc.32 %phi11(return) <- %r27 - br .L11 + br .L9 -.L11: +.L9: phi.32 %r28 <- %phi11(return) ret.32 %r28 od: -.L15: +.L12: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi13 <- $1 load.32 %r29 <- 0[i] setne.1 %r30 <- %r29, $0 - cbr %r30, .L17, .L18 + cbr %r30, .L15, .L14 -.L17: - phisrc.32 %phi13 <- $1 - br .L19 - -.L18: +.L14: load.64 %r31 <- 0[b] load.64 %r32 <- 16[%r31] setfval.64 %r33 <- 0.000000e+00 fcmpune.1 %r34 <- %r32, %r33 zext.32 %r35 <- (1) %r34 phisrc.32 %phi14 <- %r35 - br .L19 + br .L15 -.L19: +.L15: phi.32 %r36 <- %phi13, %phi14 phisrc.32 %phi15(return) <- %r36 - br .L16 + br .L13 -.L16: +.L13: phi.32 %r37 <- %phi15(return) ret.32 %r37 as: -.L20: +.L16: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi17 <- $0 load.32 %r38 <- 0[i] setne.1 %r39 <- %r38, $0 - cbr %r39, .L22, .L23 + cbr %r39, .L18, .L19 -.L22: +.L18: load.64 %r40 <- 0[b] load.32 %r41 <- 0[%r40] lsr.32 %r42 <- %r41, $1 trunc.2 %r43 <- (32) %r42 setne.1 %r44 <- %r43, $0 zext.32 %r45 <- (1) %r44 - phisrc.32 %phi17 <- %r45 - br .L24 - -.L23: - phisrc.32 %phi18 <- $0 - br .L24 + phisrc.32 %phi18 <- %r45 + br .L19 -.L24: - phi.32 %r46 <- %phi17, %phi18 +.L19: + phi.32 %r46 <- %phi18, %phi17 phisrc.32 %phi19(return) <- %r46 - br .L21 + br .L17 -.L21: +.L17: phi.32 %r47 <- %phi19(return) ret.32 %r47 au: -.L25: +.L20: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi21 <- $0 load.32 %r48 <- 0[i] setne.1 %r49 <- %r48, $0 - cbr %r49, .L27, .L28 + cbr %r49, .L22, .L23 -.L27: +.L22: load.64 %r50 <- 0[b] load.32 %r51 <- 0[%r50] lsr.32 %r52 <- %r51, $3 trunc.3 %r53 <- (32) %r52 setne.1 %r54 <- %r53, $0 zext.32 %r55 <- (1) %r54 - phisrc.32 %phi21 <- %r55 - br .L29 - -.L28: - phisrc.32 %phi22 <- $0 - br .L29 + phisrc.32 %phi22 <- %r55 + br .L23 -.L29: - phi.32 %r56 <- %phi21, %phi22 +.L23: + phi.32 %r56 <- %phi22, %phi21 phisrc.32 %phi23(return) <- %r56 - br .L26 + br .L21 -.L26: +.L21: phi.32 %r57 <- %phi23(return) ret.32 %r57 al: -.L30: +.L24: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi25 <- $0 load.32 %r58 <- 0[i] setne.1 %r59 <- %r58, $0 - cbr %r59, .L32, .L33 + cbr %r59, .L26, .L27 -.L32: +.L26: load.64 %r60 <- 0[b] load.64 %r61 <- 8[%r60] setne.1 %r62 <- %r61, $0 zext.32 %r63 <- (1) %r62 - phisrc.32 %phi25 <- %r63 - br .L34 - -.L33: - phisrc.32 %phi26 <- $0 - br .L34 + phisrc.32 %phi26 <- %r63 + br .L27 -.L34: - phi.32 %r64 <- %phi25, %phi26 +.L27: + phi.32 %r64 <- %phi26, %phi25 phisrc.32 %phi27(return) <- %r64 - br .L31 + br .L25 -.L31: +.L25: phi.32 %r65 <- %phi27(return) ret.32 %r65 ad: -.L35: +.L28: <entry-point> store.32 %arg1 -> 0[i] store.64 %arg2 -> 0[b] + phisrc.32 %phi29 <- $0 load.32 %r66 <- 0[i] setne.1 %r67 <- %r66, $0 - cbr %r67, .L37, .L38 + cbr %r67, .L30, .L31 -.L37: +.L30: load.64 %r68 <- 0[b] load.64 %r69 <- 16[%r68] setfval.64 %r70 <- 0.000000e+00 fcmpune.1 %r71 <- %r69, %r70 zext.32 %r72 <- (1) %r71 - phisrc.32 %phi29 <- %r72 - br .L39 - -.L38: - phisrc.32 %phi30 <- $0 - br .L39 + phisrc.32 %phi30 <- %r72 + br .L31 -.L39: - phi.32 %r73 <- %phi29, %phi30 +.L31: + phi.32 %r73 <- %phi30, %phi29 phisrc.32 %phi31(return) <- %r73 - br .L36 + br .L29 -.L36: +.L29: phi.32 %r74 <- %phi31(return) ret.32 %r74 |
