mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-19 23:29:20 +00:00
add some notes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36965 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7de291aa8c
commit
0f1621bb4c
@ -1094,5 +1094,33 @@ it should compile to a move from the stack slot directly into eax. DAGCombine
|
||||
has this xform, but it is currently disabled until the alignment fields of
|
||||
the load/store nodes are trustworthy.
|
||||
|
||||
//===---------------------------------------------------------------------===//
|
||||
|
||||
Sometimes it is better to codegen subtractions from a constant (e.g. 7-x) with
|
||||
a neg instead of a sub instruction. Consider:
|
||||
|
||||
int test(char X) { return 7-X; }
|
||||
|
||||
we currently produce:
|
||||
_test:
|
||||
movl $7, %eax
|
||||
movsbl 4(%esp), %ecx
|
||||
subl %ecx, %eax
|
||||
ret
|
||||
|
||||
We would use one fewer register if codegen'd as:
|
||||
|
||||
movsbl 4(%esp), %eax
|
||||
neg %eax
|
||||
add $7, %eax
|
||||
ret
|
||||
|
||||
Note that this isn't beneficial if the load can be folded into the sub. In
|
||||
this case, we want a sub:
|
||||
|
||||
int test(int X) { return 7-X; }
|
||||
_test:
|
||||
movl $7, %eax
|
||||
subl 4(%esp), %eax
|
||||
ret
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user