These are done / no longer care.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@85798 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Evan Cheng 2009-11-02 07:58:25 +00:00
parent e3b88fc01e
commit d3e18fad7e

View File

@ -8,12 +8,8 @@ Reimplement 'select' in terms of 'SEL'.
add doesn't need to overflow between the two 16-bit chunks. add doesn't need to overflow between the two 16-bit chunks.
* Implement pre/post increment support. (e.g. PR935) * Implement pre/post increment support. (e.g. PR935)
* Coalesce stack slots!
* Implement smarter constant generation for binops with large immediates. * Implement smarter constant generation for binops with large immediates.
* Consider materializing FP constants like 0.0f and 1.0f using integer
immediate instructions then copy to FPU. Slower than load into FPU?
//===---------------------------------------------------------------------===// //===---------------------------------------------------------------------===//
Crazy idea: Consider code that uses lots of 8-bit or 16-bit values. By the Crazy idea: Consider code that uses lots of 8-bit or 16-bit values. By the
@ -422,14 +418,6 @@ are not remembered when the same two values are compared twice.
//===---------------------------------------------------------------------===// //===---------------------------------------------------------------------===//
More register scavenging work:
1. Use the register scavenger to track frame index materialized into registers
(those that do not fit in addressing modes) to allow reuse in the same BB.
2. Finish scavenging for Thumb.
//===---------------------------------------------------------------------===//
More LSR enhancements possible: More LSR enhancements possible:
1. Teach LSR about pre- and post- indexed ops to allow iv increment be merged 1. Teach LSR about pre- and post- indexed ops to allow iv increment be merged
@ -540,10 +528,6 @@ while ARMConstantIslandPass only need to worry about LDR (literal).
//===---------------------------------------------------------------------===// //===---------------------------------------------------------------------===//
We need to fix constant isel for ARMv6t2 to use MOVT.
//===---------------------------------------------------------------------===//
Constant island pass should make use of full range SoImm values for LEApcrel. Constant island pass should make use of full range SoImm values for LEApcrel.
Be careful though as the last attempt caused infinite looping on lencod. Be careful though as the last attempt caused infinite looping on lencod.
@ -593,11 +577,6 @@ it saves an instruction and a register.
//===---------------------------------------------------------------------===// //===---------------------------------------------------------------------===//
add/sub/and/or + i32 imm can be simplified by folding part of the immediate
into the operation.
//===---------------------------------------------------------------------===//
It might be profitable to cse MOVi16 if there are lots of 32-bit immediates It might be profitable to cse MOVi16 if there are lots of 32-bit immediates
with the same bottom half. with the same bottom half.