R/ARMeilleure/CodeGen/Optimizations
FICTURE7 f2a7b300c4
Fix type mismatch in BitwiseAnd simplification (#2571)
* Fix type mismatch in `BitwiseAnd` simplification

`TryEliminateBitwiseAnd` would turn the `BitwiseAnd` operation into a
copy of the wrong type. E.g:

Before `Simplification`:
```llvm
i64 %0 = BitwiseAnd i64 0x0, %1
```

After `Simplication`:
```llvm
i64 %0 = Copy i32 0x0
```

Since the with the changes in #2515, we iterate in reverse order and
`Simplication`, `ConstantFolding` does not indicate if it modified
the CFG, the second pass to "retype" the copy into the proper
destination type does not happen.

This also blocked copy propagation since its destination type did not
match with its source type. But in the cases I've seen, the
`PreAllocator` would insert a copy for the propagated constant, which
results in no diffs.

Since the copy remained as is, asserts are fired when generating it.

* Set PPTC version
2021-08-20 14:42:00 -03:00
..
BlockPlacement.cs Reduce JIT GC allocations (#2515) 2021-08-17 15:08:34 -03:00
ConstantFolding.cs Reduce JIT GC allocations (#2515) 2021-08-17 15:08:34 -03:00
Optimizer.cs Reduce JIT GC allocations (#2515) 2021-08-17 15:08:34 -03:00
Simplification.cs Fix type mismatch in BitwiseAnd simplification (#2571) 2021-08-20 14:42:00 -03:00