Evan Cheng
|
498f19548c
|
Added isReMaterializable.
llvm-svn: 35160
|
2007-03-19 06:22:07 +00:00 |
|
Chris Lattner
|
59fe2be1c4
|
fix a warning
llvm-svn: 35152
|
2007-03-19 00:39:32 +00:00 |
|
Chris Lattner
|
a1df6908d2
|
minor updates
llvm-svn: 35143
|
2007-03-18 22:41:33 +00:00 |
|
Nick Lewycky
|
04ecc07c25
|
This is implemented. We now generate:
entry:
icmp ugt i32 %x, 4 ; <i1>:0 [#uses=1]
br i1 %0, label %cond_true, label %cond_false
cond_true: ; preds = %entry
%tmp1 = tail call i32 (...)* @bar( i32 12 ) ; <i32> [#uses=0]
ret void
cond_false: ; preds = %entry
switch i32 %x, label %cond_true15 [
i32 4, label %cond_true3
i32 3, label %cond_true7
i32 2, label %cond_true11
i32 0, label %cond_false17
]
...
llvm-svn: 35142
|
2007-03-18 14:37:20 +00:00 |
|
Devang Patel
|
2dabb16eac
|
Support 'I' inline asm constraint.
llvm-svn: 35129
|
2007-03-17 00:13:28 +00:00 |
|
Lauro Ramos Venancio
|
f756184c5e
|
Only ARMv6 has BSWAP.
Fix MultiSource/Applications/aha test.
llvm-svn: 35128
|
2007-03-16 22:54:16 +00:00 |
|
Bill Wendling
|
8ced23ee5a
|
And now support for MMX logical operations.
llvm-svn: 35125
|
2007-03-16 09:44:46 +00:00 |
|
Evan Cheng
|
4858c6f781
|
Added isLegalAddressExpression(). Only allows X +/- C for now.
llvm-svn: 35122
|
2007-03-16 08:43:56 +00:00 |
|
Bill Wendling
|
feaff80149
|
Multiplication support for MMX.
llvm-svn: 35118
|
2007-03-15 21:24:36 +00:00 |
|
Evan Cheng
|
00edaa08b5
|
Under X86-64 large code model, do not emit 32-bit pc relative calls.
llvm-svn: 35108
|
2007-03-14 22:11:11 +00:00 |
|
Evan Cheng
|
fc80b5b712
|
Notes about codegen issues.
llvm-svn: 35107
|
2007-03-14 21:03:53 +00:00 |
|
Evan Cheng
|
50a0af3b57
|
Clean up.
llvm-svn: 35105
|
2007-03-14 20:20:19 +00:00 |
|
Evan Cheng
|
2617c8dd3a
|
Oops.
llvm-svn: 35104
|
2007-03-14 19:44:58 +00:00 |
|
Evan Cheng
|
371b8e8fa9
|
X86-64 JIT is in large code model. Need stubs for direct calls.
llvm-svn: 35097
|
2007-03-14 10:51:55 +00:00 |
|
Evan Cheng
|
1092e481ce
|
x86-64 JIT stub codegen.
llvm-svn: 35096
|
2007-03-14 10:48:08 +00:00 |
|
Evan Cheng
|
15de6714a4
|
Preliminary support for X86-64 JIT stub codegen.
llvm-svn: 35095
|
2007-03-14 10:44:30 +00:00 |
|
Evan Cheng
|
7cbde8351a
|
AM2 can match 2^n +/- 1. e.g. ldr r3, [r2, r2, lsl #2]
llvm-svn: 35088
|
2007-03-13 21:05:54 +00:00 |
|
Evan Cheng
|
7b24b3e474
|
Zero is always a legal AM immediate.
llvm-svn: 35087
|
2007-03-13 20:37:59 +00:00 |
|
Nicolas Geoffray
|
9c77df75ea
|
Stack and register alignment of call arguments in the ELF ABI
llvm-svn: 35083
|
2007-03-13 15:02:46 +00:00 |
|
Evan Cheng
|
92712d4884
|
Implement getTargetLowering() or else LSR won't be using ARM specific hooks.
llvm-svn: 35077
|
2007-03-13 01:20:42 +00:00 |
|
Evan Cheng
|
7767159f08
|
Updated TargetLowering LSR addressing mode hooks for ARM and Thumb.
llvm-svn: 35075
|
2007-03-12 23:30:29 +00:00 |
|
Evan Cheng
|
06d83c8fce
|
More flexible TargetLowering LSR hooks for testing whether an immediate is a legal target address immediate or scale.
llvm-svn: 35074
|
2007-03-12 23:29:01 +00:00 |
|
Evan Cheng
|
0eeb8b59eb
|
More flexible TargetLowering LSR hooks for testing whether an immediate is
a legal target address immediate or scale.
llvm-svn: 35073
|
2007-03-12 23:28:50 +00:00 |
|
Evan Cheng
|
4224fa3617
|
Stupid bug: SSE2 supports v2i64 add / sub.
llvm-svn: 35070
|
2007-03-12 22:58:52 +00:00 |
|
Bill Wendling
|
236cfc4344
|
Adding more arithmetic operators to MMX. This is an almost exact copy of
the addition. Please let me know if you have suggestions.
llvm-svn: 35055
|
2007-03-10 09:57:05 +00:00 |
|
Evan Cheng
|
a4e410aa9c
|
Minor stuff.
llvm-svn: 35049
|
2007-03-09 19:46:06 +00:00 |
|
Evan Cheng
|
d7201d12af
|
Add comments about LSR / ARM.
llvm-svn: 35048
|
2007-03-09 19:35:33 +00:00 |
|
Evan Cheng
|
2e6f19d8c8
|
Unfinished work and ideas related to register scavenger.
llvm-svn: 35047
|
2007-03-09 19:34:51 +00:00 |
|
Dale Johannesen
|
10a05b538d
|
apply comments from review of last patch
llvm-svn: 35045
|
2007-03-09 19:18:59 +00:00 |
|
Dale Johannesen
|
23c2498e23
|
Add some observations from CoreGraphics benchmark. Remove register
scavenging todo item, since it is now implemented.
llvm-svn: 35044
|
2007-03-09 17:58:17 +00:00 |
|
Evan Cheng
|
7ef8db2fb5
|
Implement inline asm modifier c.
llvm-svn: 35035
|
2007-03-08 22:42:46 +00:00 |
|
Bill Wendling
|
5fef3fd7e7
|
Added "padd*" support for MMX. Added MMX move stuff to X86InstrInfo so that
moves, loads, etc. are recognized.
llvm-svn: 35031
|
2007-03-08 22:09:11 +00:00 |
|
Evan Cheng
|
6445ce2423
|
Fix a typo.
llvm-svn: 35030
|
2007-03-08 21:59:30 +00:00 |
|
Evan Cheng
|
7d528d089c
|
Putting more constants which do not contain relocations into .literal{4|8|16}
llvm-svn: 35026
|
2007-03-08 08:31:54 +00:00 |
|
Evan Cheng
|
393fd04eb4
|
Change register allocation order to Dale's suggestion.
llvm-svn: 35021
|
2007-03-08 02:56:40 +00:00 |
|
Evan Cheng
|
2c3e4ab3a6
|
Bug fix. Not advancing the register scavenger iterator correctly.
llvm-svn: 35020
|
2007-03-08 02:55:08 +00:00 |
|
Evan Cheng
|
c79408b032
|
For Darwin, put constant data into .const, .const_data, .literal{4|8|16}
sections.
llvm-svn: 35017
|
2007-03-08 01:25:25 +00:00 |
|
Evan Cheng
|
14b63d89c1
|
Put constant data to .const, .const_data, .literal{4|8|16} sections.
llvm-svn: 35016
|
2007-03-08 01:07:07 +00:00 |
|
Evan Cheng
|
6bf2f3665e
|
Add ReadOnlySection directive.
llvm-svn: 35015
|
2007-03-08 01:00:38 +00:00 |
|
Evan Cheng
|
51c3e53eb7
|
Only safe to use a call-clobbered or spilled callee-saved register as scratch register.
llvm-svn: 35010
|
2007-03-07 20:30:36 +00:00 |
|
Bill Wendling
|
8f49ba1000
|
Remove useless pattern fragments.
llvm-svn: 35009
|
2007-03-07 18:23:09 +00:00 |
|
Anton Korobeynikov
|
85d6c1ebad
|
Refactoring of formal parameter flags. Enable properly use of
zext/sext/aext stuff.
llvm-svn: 35008
|
2007-03-07 16:25:09 +00:00 |
|
Bill Wendling
|
3c201ddd02
|
Properly support v8i8 and v4i16 types. It now converts them to v2i32 for
load and stores.
llvm-svn: 35002
|
2007-03-07 05:43:18 +00:00 |
|
Anton Korobeynikov
|
090c2d50ea
|
Fix DWARF debugging information on x86/Linux and (hopefully)
Mingw32/Cygwin targets. This fixes PR978
llvm-svn: 35000
|
2007-03-07 02:47:57 +00:00 |
|
Evan Cheng
|
493960579f
|
ARM always use register scavenger. No longer reserves R12.
llvm-svn: 34999
|
2007-03-07 02:46:23 +00:00 |
|
Evan Cheng
|
4e01b11512
|
Fix some brittle code. Watch out for cases where register scavenger is pointing to deleted instructions.
llvm-svn: 34998
|
2007-03-07 02:38:05 +00:00 |
|
Evan Cheng
|
9839628fd1
|
Fix one more Thumb eliminateFrameIndex bug.
llvm-svn: 34990
|
2007-03-07 00:12:18 +00:00 |
|
Evan Cheng
|
63ffd3e17f
|
Register scavenging is now on by default for ARM.
llvm-svn: 34987
|
2007-03-06 22:02:53 +00:00 |
|
Evan Cheng
|
6453ad00d2
|
Make load / store optimizer use register scavenger.
llvm-svn: 34986
|
2007-03-06 21:59:20 +00:00 |
|
Bill Wendling
|
a02d43fbbd
|
Add LOAD/STORE support for MMX.
llvm-svn: 34978
|
2007-03-06 18:53:42 +00:00 |
|