Fixing divd constant.
This commit is contained in:
parent
4327724f77
commit
4248268b4f
|
@ -350,7 +350,7 @@ bool ConstantPropagationPass::Run(HIRBuilder* builder) {
|
|||
case OPCODE_DIV:
|
||||
if (i->src1.value->IsConstant() && i->src2.value->IsConstant()) {
|
||||
v->set_from(i->src1.value);
|
||||
v->Div(i->src2.value);
|
||||
v->Div(i->src2.value, (i->flags & ARITHMETIC_UNSIGNED) != 0);
|
||||
i->Remove();
|
||||
}
|
||||
break;
|
||||
|
|
Binary file not shown.
|
@ -4,38 +4,101 @@ Disassembly of section .text:
|
|||
100000: 7c 64 2b d6 divw r3,r4,r5
|
||||
100004: 4e 80 00 20 blr
|
||||
|
||||
0000000000100008 <test_divw_3>:
|
||||
100008: 7c 64 2b d6 divw r3,r4,r5
|
||||
10000c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100010 <test_divw_4>:
|
||||
0000000000100008 <test_divw_1_constant>:
|
||||
100008: 38 80 00 01 li r4,1
|
||||
10000c: 38 a0 00 02 li r5,2
|
||||
100010: 7c 64 2b d6 divw r3,r4,r5
|
||||
100014: 4e 80 00 20 blr
|
||||
|
||||
0000000000100018 <test_divw_5>:
|
||||
0000000000100018 <test_divw_3>:
|
||||
100018: 7c 64 2b d6 divw r3,r4,r5
|
||||
10001c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100020 <test_divw_6>:
|
||||
100020: 7c 64 2b d6 divw r3,r4,r5
|
||||
100024: 4e 80 00 20 blr
|
||||
|
||||
0000000000100028 <test_divw_7>:
|
||||
0000000000100020 <test_divw_3_constant>:
|
||||
100020: 38 80 00 02 li r4,2
|
||||
100024: 38 a0 00 01 li r5,1
|
||||
100028: 7c 64 2b d6 divw r3,r4,r5
|
||||
10002c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100030 <test_divw_8>:
|
||||
0000000000100030 <test_divw_4>:
|
||||
100030: 7c 64 2b d6 divw r3,r4,r5
|
||||
100034: 4e 80 00 20 blr
|
||||
|
||||
0000000000100038 <test_divw_9>:
|
||||
100038: 7c 64 2b d6 divw r3,r4,r5
|
||||
10003c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100040 <test_divw_10>:
|
||||
0000000000100038 <test_divw_4_constant>:
|
||||
100038: 38 80 00 23 li r4,35
|
||||
10003c: 38 a0 00 07 li r5,7
|
||||
100040: 7c 64 2b d6 divw r3,r4,r5
|
||||
100044: 4e 80 00 20 blr
|
||||
|
||||
0000000000100048 <test_divw_11>:
|
||||
0000000000100048 <test_divw_5>:
|
||||
100048: 7c 64 2b d6 divw r3,r4,r5
|
||||
10004c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100050 <test_divw_5_constant>:
|
||||
100050: 38 80 00 00 li r4,0
|
||||
100054: 38 a0 00 01 li r5,1
|
||||
100058: 7c 64 2b d6 divw r3,r4,r5
|
||||
10005c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100060 <test_divw_6>:
|
||||
100060: 7c 64 2b d6 divw r3,r4,r5
|
||||
100064: 4e 80 00 20 blr
|
||||
|
||||
0000000000100068 <test_divw_6_constant>:
|
||||
100068: 38 80 ff ff li r4,-1
|
||||
10006c: 38 a0 00 01 li r5,1
|
||||
100070: 7c 64 2b d6 divw r3,r4,r5
|
||||
100074: 4e 80 00 20 blr
|
||||
|
||||
0000000000100078 <test_divw_7>:
|
||||
100078: 7c 64 2b d6 divw r3,r4,r5
|
||||
10007c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100080 <test_divw_7_constant>:
|
||||
100080: 38 80 ff ff li r4,-1
|
||||
100084: 38 a0 ff ff li r5,-1
|
||||
100088: 7c 64 2b d6 divw r3,r4,r5
|
||||
10008c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100090 <test_divw_8>:
|
||||
100090: 7c 64 2b d6 divw r3,r4,r5
|
||||
100094: 4e 80 00 20 blr
|
||||
|
||||
0000000000100098 <test_divw_8_constant>:
|
||||
100098: 38 80 00 01 li r4,1
|
||||
10009c: 38 a0 ff ff li r5,-1
|
||||
1000a0: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000a4: 4e 80 00 20 blr
|
||||
|
||||
00000000001000a8 <test_divw_9>:
|
||||
1000a8: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000ac: 4e 80 00 20 blr
|
||||
|
||||
00000000001000b0 <test_divw_9_constant>:
|
||||
1000b0: 38 80 ff ff li r4,-1
|
||||
1000b4: 78 84 00 60 clrldi r4,r4,33
|
||||
1000b8: 38 a0 00 01 li r5,1
|
||||
1000bc: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000c0: 4e 80 00 20 blr
|
||||
|
||||
00000000001000c4 <test_divw_10>:
|
||||
1000c4: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000c8: 4e 80 00 20 blr
|
||||
|
||||
00000000001000cc <test_divw_10_constant>:
|
||||
1000cc: 38 80 ff ff li r4,-1
|
||||
1000d0: 78 84 00 60 clrldi r4,r4,33
|
||||
1000d4: 7c 85 23 78 mr r5,r4
|
||||
1000d8: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000dc: 4e 80 00 20 blr
|
||||
|
||||
00000000001000e0 <test_divw_11>:
|
||||
1000e0: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000e4: 4e 80 00 20 blr
|
||||
|
||||
00000000001000e8 <test_divw_11_constant>:
|
||||
1000e8: 38 80 00 01 li r4,1
|
||||
1000ec: 38 a0 ff ff li r5,-1
|
||||
1000f0: 78 a5 00 60 clrldi r5,r5,33
|
||||
1000f4: 7c 64 2b d6 divw r3,r4,r5
|
||||
1000f8: 4e 80 00 20 blr
|
||||
|
|
|
@ -1,10 +1,20 @@
|
|||
0000000000000000 t test_divw_1
|
||||
0000000000000008 t test_divw_3
|
||||
0000000000000010 t test_divw_4
|
||||
0000000000000018 t test_divw_5
|
||||
0000000000000020 t test_divw_6
|
||||
0000000000000028 t test_divw_7
|
||||
0000000000000030 t test_divw_8
|
||||
0000000000000038 t test_divw_9
|
||||
0000000000000040 t test_divw_10
|
||||
0000000000000048 t test_divw_11
|
||||
0000000000000008 t test_divw_1_constant
|
||||
0000000000000018 t test_divw_3
|
||||
0000000000000020 t test_divw_3_constant
|
||||
0000000000000030 t test_divw_4
|
||||
0000000000000038 t test_divw_4_constant
|
||||
0000000000000048 t test_divw_5
|
||||
0000000000000050 t test_divw_5_constant
|
||||
0000000000000060 t test_divw_6
|
||||
0000000000000068 t test_divw_6_constant
|
||||
0000000000000078 t test_divw_7
|
||||
0000000000000080 t test_divw_7_constant
|
||||
0000000000000090 t test_divw_8
|
||||
0000000000000098 t test_divw_8_constant
|
||||
00000000000000a8 t test_divw_9
|
||||
00000000000000b0 t test_divw_9_constant
|
||||
00000000000000c4 t test_divw_10
|
||||
00000000000000cc t test_divw_10_constant
|
||||
00000000000000e0 t test_divw_11
|
||||
00000000000000e8 t test_divw_11_constant
|
||||
|
|
Binary file not shown.
|
@ -4,42 +4,112 @@ Disassembly of section .text:
|
|||
100000: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100004: 4e 80 00 20 blr
|
||||
|
||||
0000000000100008 <test_divwu_3>:
|
||||
100008: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10000c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100010 <test_divwu_4>:
|
||||
0000000000100008 <test_divwu_1_constant>:
|
||||
100008: 38 80 00 01 li r4,1
|
||||
10000c: 38 a0 00 02 li r5,2
|
||||
100010: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100014: 4e 80 00 20 blr
|
||||
|
||||
0000000000100018 <test_divwu_5>:
|
||||
0000000000100018 <test_divwu_3>:
|
||||
100018: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10001c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100020 <test_divwu_6>:
|
||||
100020: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100024: 4e 80 00 20 blr
|
||||
|
||||
0000000000100028 <test_divwu_7>:
|
||||
0000000000100020 <test_divwu_3_constant>:
|
||||
100020: 38 80 00 02 li r4,2
|
||||
100024: 38 a0 00 01 li r5,1
|
||||
100028: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10002c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100030 <test_divwu_8>:
|
||||
0000000000100030 <test_divwu_4>:
|
||||
100030: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100034: 4e 80 00 20 blr
|
||||
|
||||
0000000000100038 <test_divwu_9>:
|
||||
100038: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10003c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100040 <test_divwu_10>:
|
||||
0000000000100038 <test_divwu_4_constant>:
|
||||
100038: 38 80 00 23 li r4,35
|
||||
10003c: 38 a0 00 07 li r5,7
|
||||
100040: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100044: 4e 80 00 20 blr
|
||||
|
||||
0000000000100048 <test_divwu_11>:
|
||||
0000000000100048 <test_divwu_5>:
|
||||
100048: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10004c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100050 <test_divwu_12>:
|
||||
100050: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100054: 4e 80 00 20 blr
|
||||
0000000000100050 <test_divwu_5_constant>:
|
||||
100050: 38 80 00 00 li r4,0
|
||||
100054: 38 a0 00 01 li r5,1
|
||||
100058: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10005c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100060 <test_divwu_6>:
|
||||
100060: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100064: 4e 80 00 20 blr
|
||||
|
||||
0000000000100068 <test_divwu_6_constant>:
|
||||
100068: 38 80 ff ff li r4,-1
|
||||
10006c: 38 a0 00 01 li r5,1
|
||||
100070: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100074: 4e 80 00 20 blr
|
||||
|
||||
0000000000100078 <test_divwu_7>:
|
||||
100078: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10007c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100080 <test_divwu_7_constant>:
|
||||
100080: 38 80 ff ff li r4,-1
|
||||
100084: 38 a0 ff ff li r5,-1
|
||||
100088: 7c 64 2b 96 divwu r3,r4,r5
|
||||
10008c: 4e 80 00 20 blr
|
||||
|
||||
0000000000100090 <test_divwu_8>:
|
||||
100090: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100094: 4e 80 00 20 blr
|
||||
|
||||
0000000000100098 <test_divwu_8_constant>:
|
||||
100098: 38 80 00 01 li r4,1
|
||||
10009c: 38 a0 ff ff li r5,-1
|
||||
1000a0: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000a4: 4e 80 00 20 blr
|
||||
|
||||
00000000001000a8 <test_divwu_9>:
|
||||
1000a8: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000ac: 4e 80 00 20 blr
|
||||
|
||||
00000000001000b0 <test_divwu_9_constant>:
|
||||
1000b0: 38 80 ff ff li r4,-1
|
||||
1000b4: 78 84 00 60 clrldi r4,r4,33
|
||||
1000b8: 38 a0 00 01 li r5,1
|
||||
1000bc: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000c0: 4e 80 00 20 blr
|
||||
|
||||
00000000001000c4 <test_divwu_10>:
|
||||
1000c4: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000c8: 4e 80 00 20 blr
|
||||
|
||||
00000000001000cc <test_divwu_10_constant>:
|
||||
1000cc: 38 80 ff ff li r4,-1
|
||||
1000d0: 78 84 00 60 clrldi r4,r4,33
|
||||
1000d4: 7c 85 23 78 mr r5,r4
|
||||
1000d8: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000dc: 4e 80 00 20 blr
|
||||
|
||||
00000000001000e0 <test_divwu_11>:
|
||||
1000e0: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000e4: 4e 80 00 20 blr
|
||||
|
||||
00000000001000e8 <test_divwu_11_constant>:
|
||||
1000e8: 38 80 00 01 li r4,1
|
||||
1000ec: 38 a0 ff ff li r5,-1
|
||||
1000f0: 78 a5 00 60 clrldi r5,r5,33
|
||||
1000f4: 7c 64 2b 96 divwu r3,r4,r5
|
||||
1000f8: 4e 80 00 20 blr
|
||||
|
||||
00000000001000fc <test_divwu_12>:
|
||||
1000fc: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100100: 4e 80 00 20 blr
|
||||
|
||||
0000000000100104 <test_divwu_12_constant>:
|
||||
100104: 38 80 00 01 li r4,1
|
||||
100108: 78 84 f8 24 rldicr r4,r4,31,32
|
||||
10010c: 38 a0 ff ff li r5,-1
|
||||
100110: 7c 64 2b 96 divwu r3,r4,r5
|
||||
100114: 4e 80 00 20 blr
|
||||
|
|
|
@ -1,11 +1,22 @@
|
|||
0000000000000000 t test_divwu_1
|
||||
0000000000000008 t test_divwu_3
|
||||
0000000000000010 t test_divwu_4
|
||||
0000000000000018 t test_divwu_5
|
||||
0000000000000020 t test_divwu_6
|
||||
0000000000000028 t test_divwu_7
|
||||
0000000000000030 t test_divwu_8
|
||||
0000000000000038 t test_divwu_9
|
||||
0000000000000040 t test_divwu_10
|
||||
0000000000000048 t test_divwu_11
|
||||
0000000000000050 t test_divwu_12
|
||||
0000000000000008 t test_divwu_1_constant
|
||||
0000000000000018 t test_divwu_3
|
||||
0000000000000020 t test_divwu_3_constant
|
||||
0000000000000030 t test_divwu_4
|
||||
0000000000000038 t test_divwu_4_constant
|
||||
0000000000000048 t test_divwu_5
|
||||
0000000000000050 t test_divwu_5_constant
|
||||
0000000000000060 t test_divwu_6
|
||||
0000000000000068 t test_divwu_6_constant
|
||||
0000000000000078 t test_divwu_7
|
||||
0000000000000080 t test_divwu_7_constant
|
||||
0000000000000090 t test_divwu_8
|
||||
0000000000000098 t test_divwu_8_constant
|
||||
00000000000000a8 t test_divwu_9
|
||||
00000000000000b0 t test_divwu_9_constant
|
||||
00000000000000c4 t test_divwu_10
|
||||
00000000000000cc t test_divwu_10_constant
|
||||
00000000000000e0 t test_divwu_11
|
||||
00000000000000e8 t test_divwu_11_constant
|
||||
00000000000000fc t test_divwu_12
|
||||
0000000000000104 t test_divwu_12_constant
|
||||
|
|
|
@ -304,20 +304,36 @@ void Value::Mul(Value* other) {
|
|||
}
|
||||
}
|
||||
|
||||
void Value::Div(Value* other) {
|
||||
void Value::Div(Value* other, bool is_unsigned) {
|
||||
assert_true(type == other->type);
|
||||
switch (type) {
|
||||
case INT8_TYPE:
|
||||
constant.i8 /= uint8_t(other->constant.i8);
|
||||
if (is_unsigned) {
|
||||
constant.i8 /= uint8_t(other->constant.i8);
|
||||
} else {
|
||||
constant.i8 /= other->constant.i8;
|
||||
}
|
||||
break;
|
||||
case INT16_TYPE:
|
||||
constant.i16 /= uint16_t(other->constant.i16);
|
||||
if (is_unsigned) {
|
||||
constant.i16 /= uint16_t(other->constant.i16);
|
||||
} else {
|
||||
constant.i16 /= other->constant.i16;
|
||||
}
|
||||
break;
|
||||
case INT32_TYPE:
|
||||
constant.i32 /= uint32_t(other->constant.i32);
|
||||
if (is_unsigned) {
|
||||
constant.i32 /= uint32_t(other->constant.i32);
|
||||
} else {
|
||||
constant.i32 /= other->constant.i32;
|
||||
}
|
||||
break;
|
||||
case INT64_TYPE:
|
||||
constant.i64 /= uint64_t(other->constant.i64);
|
||||
if (is_unsigned) {
|
||||
constant.i64 /= uint64_t(other->constant.i64);
|
||||
} else {
|
||||
constant.i64 /= other->constant.i64;
|
||||
}
|
||||
break;
|
||||
case FLOAT32_TYPE:
|
||||
constant.f32 /= other->constant.f32;
|
||||
|
|
|
@ -385,7 +385,7 @@ class Value {
|
|||
bool Add(Value* other);
|
||||
bool Sub(Value* other);
|
||||
void Mul(Value* other);
|
||||
void Div(Value* other);
|
||||
void Div(Value* other, bool is_unsigned);
|
||||
static void MulAdd(Value* dest, Value* value1, Value* value2, Value* value3);
|
||||
static void MulSub(Value* dest, Value* value1, Value* value2, Value* value3);
|
||||
void Neg();
|
||||
|
|
Loading…
Reference in New Issue