diff options
author | Mike Pall <mike> | 2016-07-22 16:35:46 +0200 |
---|---|---|
committer | Mike Pall <mike> | 2016-07-22 16:35:46 +0200 |
commit | c98660c8c3921e43029625e51166c9d273ad09df (patch) | |
tree | 2304faeffbdf815d4579c693adc44462fe1d152b | |
parent | 22e8e0796940e0583c59642dad069873c1077f75 (diff) | |
download | luajit-c98660c8c3921e43029625e51166c9d273ad09df.tar.gz luajit-c98660c8c3921e43029625e51166c9d273ad09df.tar.bz2 luajit-c98660c8c3921e43029625e51166c9d273ad09df.zip |
Must preserve J->fold.ins (fins) around call to lj_ir_ksimd().
-rw-r--r-- | src/lj_opt_fold.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/lj_opt_fold.c b/src/lj_opt_fold.c index 73a368ed..5f4b8810 100644 --- a/src/lj_opt_fold.c +++ b/src/lj_opt_fold.c | |||
@@ -998,8 +998,10 @@ LJFOLDF(simplify_nummuldiv_k) | |||
998 | if (n == 1.0) { /* x o 1 ==> x */ | 998 | if (n == 1.0) { /* x o 1 ==> x */ |
999 | return LEFTFOLD; | 999 | return LEFTFOLD; |
1000 | } else if (n == -1.0) { /* x o -1 ==> -x */ | 1000 | } else if (n == -1.0) { /* x o -1 ==> -x */ |
1001 | IRRef op1 = fins->op1; | ||
1002 | fins->op2 = (IRRef1)lj_ir_ksimd(J, LJ_KSIMD_NEG); /* Modifies fins. */ | ||
1003 | fins->op1 = op1; | ||
1001 | fins->o = IR_NEG; | 1004 | fins->o = IR_NEG; |
1002 | fins->op2 = (IRRef1)lj_ir_ksimd(J, LJ_KSIMD_NEG); | ||
1003 | return RETRYFOLD; | 1005 | return RETRYFOLD; |
1004 | } else if (fins->o == IR_MUL && n == 2.0) { /* x * 2 ==> x + x */ | 1006 | } else if (fins->o == IR_MUL && n == 2.0) { /* x * 2 ==> x + x */ |
1005 | fins->o = IR_ADD; | 1007 | fins->o = IR_ADD; |