- Mar 08, 2004
-
-
Chris Lattner authored
llvm-svn: 12211
-
Chris Lattner authored
llvm-svn: 12210
-
Chris Lattner authored
llvm-svn: 12209
-
Chris Lattner authored
llvm-svn: 12208
-
Chris Lattner authored
llvm-svn: 12207
-
Chris Lattner authored
llvm-svn: 12205
-
Chris Lattner authored
testcase like this: int %test(int* %P, int %A) { %Pv = load int* %P %B = add int %A, %Pv ret int %B } We now generate: test: mov %ECX, DWORD PTR [%ESP + 4] mov %EAX, DWORD PTR [%ESP + 8] add %EAX, DWORD PTR [%ECX] ret Instead of: test: mov %EAX, DWORD PTR [%ESP + 4] mov %ECX, DWORD PTR [%ESP + 8] mov %EAX, DWORD PTR [%EAX] add %EAX, %ECX ret ... saving one instruction, and often a register. Note that there are a lot of other instructions that could use this, but they aren't handled. I'm not really interested in adding them, but mul/div and all of the FP instructions could be supported as well if someone wanted to add them. llvm-svn: 12204
-
Chris Lattner authored
llvm-svn: 12203
-
Chris Lattner authored
This allows pointers to aggregate objects, whose elements are only read, to be promoted and passed in by element instead of by reference. This can enable a LOT of subsequent optimizations in the caller function. It's worth pointing out that this stuff happens a LOT of C++ programs, because objects in templates are generally passed around by reference. When these templates are instantiated on small aggregate or scalar types, however, it is more efficient to pass them in by value than by reference. This transformation triggers most on C++ codes (e.g. 334 times on eon), but does happen on C codes as well. For example, on mesa it triggers 72 times, and on gcc it triggers 35 times. this is amazingly good considering that we are using 'basicaa' so far. llvm-svn: 12202
-
Chris Lattner authored
llvm-svn: 12201
-
- Mar 07, 2004
-
-
Chris Lattner authored
llvm-svn: 12200
-
Chris Lattner authored
llvm-svn: 12199
-
Chris Lattner authored
llvm-svn: 12198
-
Chris Lattner authored
a zero value is the most likely way to cause further simplification, so we do it. llvm-svn: 12197
-
Chris Lattner authored
llvm-svn: 12196
-
Chris Lattner authored
llvm-svn: 12195
-
Chris Lattner authored
llvm-svn: 12194
-
Chris Lattner authored
variables. llvm-svn: 12193
-
Chris Lattner authored
llvm-svn: 12192
-
Alkis Evlogimenos authored
llvm-svn: 12190
-
Alkis Evlogimenos authored
llvm-svn: 12189
-
- Mar 06, 2004
-
-
Alkis Evlogimenos authored
llvm-svn: 12188
-
Alkis Evlogimenos authored
llvm-svn: 12187
-
Brian Gaeke authored
Emit RETL instruction to return instead of funny JMPL. Fix indentation. llvm-svn: 12186
-
Brian Gaeke authored
Add RET, RETL. Rename SAVE, RESTORE & JMPL for consistency. llvm-svn: 12185
-
Brian Gaeke authored
llvm-svn: 12184
-
Brian Gaeke authored
llvm-svn: 12183
-
Brian Gaeke authored
llvm-svn: 12182
-
Brian Gaeke authored
llvm-svn: 12180
-
- Mar 05, 2004
-
-
Chris Lattner authored
llvm-svn: 12169
-
Misha Brukman authored
llvm-svn: 12161
-
Brian Gaeke authored
llvm-svn: 12143
-
- Mar 04, 2004
-
-
Chris Lattner authored
llvm-svn: 12128
-
Chris Lattner authored
llvm-svn: 12127
-
Chris Lattner authored
llvm-svn: 12126
-
Chris Lattner authored
This reduces CBU time from 145s -> 122s (debug build), reduces # allocated nodes from 129420 to 116477. llvm-svn: 12125
-
Brian Gaeke authored
llvm-svn: 12124
-
Chris Lattner authored
llvm-svn: 12123
-
Brian Gaeke authored
llvm-svn: 12122
-
Alkis Evlogimenos authored
llvm-svn: 12120
-