Chris Lattner
|
59f1a92c77
|
mark some unsupported ops as unsupported
llvm-svn: 24852
|
2005-12-19 01:39:40 +00:00 |
|
Chris Lattner
|
bd8b911c46
|
Keep stack frames 8-byte aligned. This fixes olden/voronoi
llvm-svn: 24849
|
2005-12-19 01:15:13 +00:00 |
|
Chris Lattner
|
be3df4a199
|
Elimiante SP and FP, which weren't members of the IntRegs register class
llvm-svn: 24844
|
2005-12-19 00:06:52 +00:00 |
|
Chris Lattner
|
e8dad0dcb9
|
Add support for calls to external symbols
llvm-svn: 24838
|
2005-12-18 23:07:11 +00:00 |
|
Chris Lattner
|
745c88ba10
|
we have no memcpy
llvm-svn: 24837
|
2005-12-18 23:00:27 +00:00 |
|
Chris Lattner
|
d8c98dcfe0
|
Fix a crash on a call with no arguments
llvm-svn: 24836
|
2005-12-18 22:57:47 +00:00 |
|
Chris Lattner
|
27357a915a
|
Change return lowering so that we can autogen the matching code.
llvm-svn: 24832
|
2005-12-18 21:03:04 +00:00 |
|
Chris Lattner
|
41ec63f309
|
Implement Calls for V8. This would be completely autogenerated except for
a small bug in tblgen. When that is fixed, we can remove the ISD::Call case
in Select.
llvm-svn: 24830
|
2005-12-18 15:55:15 +00:00 |
|
Chris Lattner
|
b82f4641c4
|
Implement the full V8 ABI for incoming arguments.
llvm-svn: 24825
|
2005-12-18 13:33:06 +00:00 |
|
Chris Lattner
|
11fa3cc8ee
|
Give V8 select_cc, in the spirit of the PPC backend
llvm-svn: 24823
|
2005-12-18 08:13:54 +00:00 |
|
Chris Lattner
|
e0ebaa24f9
|
V8 doesn't have FP extload
llvm-svn: 24821
|
2005-12-18 07:13:32 +00:00 |
|
Chris Lattner
|
0d0850d22e
|
simplifications, fix typo
llvm-svn: 24820
|
2005-12-18 07:09:06 +00:00 |
|
Chris Lattner
|
941ba22d08
|
Add frameindex support
Add support for copying (e.g. returning) doubles
Add support for F<->I instructions
llvm-svn: 24818
|
2005-12-18 06:59:57 +00:00 |
|
Chris Lattner
|
2aab8f4471
|
Add constant pool support, including folding into addresses.
Pretty print addresses a bit, to not print [%r1+%g0]: just print [%r1]
llvm-svn: 24813
|
2005-12-18 02:37:35 +00:00 |
|
Chris Lattner
|
cba8a96bd0
|
Teach the addressing mode stuff to fold "%lo" into 'ri' addressing modes,
allowing us to compile this:
to this:
%G1 = external global int
%G2 = external global int
void %test() {
%X = load int* %G1
store int %X, int* %G2
ret void
}
test:
save -96, %sp, %sp
sethi %hi(G1), %l0
ld [%l0+%lo(G1)], %l0
sethi %hi(G2), %l1
st %l0, [%l1+%lo(G2)]
restore %g0, %g0, %g0
retl
nop
instead of this:
test:
save -96, %sp, %sp
sethi %hi(G1), %l0
or %g0, %lo(G1), %l1
ld [%l1+%l0], %l0
sethi %hi(G2), %l1
or %g0, %lo(G2), %l2
st %l0, [%l2+%l1]
restore %g0, %g0, %g0
retl
nop
llvm-svn: 24812
|
2005-12-18 02:27:00 +00:00 |
|
Chris Lattner
|
5303e59b7a
|
Add initial support for global variables, and fix a bug in addr mode selection
where we didn't select the operands.
llvm-svn: 24811
|
2005-12-18 02:10:39 +00:00 |
|
Chris Lattner
|
47785d8fc3
|
Add initial conditional branch support. This doesn't actually work yet due
to a bug in the scheduler.
llvm-svn: 24807
|
2005-12-18 01:20:35 +00:00 |
|
Chris Lattner
|
057fbaea0d
|
Implement 64-bit add/sub, make sure to receive and return 64-bit args with
the right halves in the right regs
llvm-svn: 24799
|
2005-12-17 22:55:57 +00:00 |
|
Chris Lattner
|
a4865938dc
|
implement div and rem
llvm-svn: 24798
|
2005-12-17 22:39:19 +00:00 |
|
Chris Lattner
|
88a3754b46
|
implement MULHU/MULHS for 64-bit multiplies
llvm-svn: 24797
|
2005-12-17 22:30:00 +00:00 |
|
Chris Lattner
|
a4dbacd0d6
|
Make the addressing modes smarter
llvm-svn: 24795
|
2005-12-17 21:25:27 +00:00 |
|
Chris Lattner
|
3afda7194f
|
Add support for 64-bit arguments
llvm-svn: 24792
|
2005-12-17 20:59:06 +00:00 |
|
Chris Lattner
|
c1ab8a5e42
|
Sparc doesn't have sext_inreg
llvm-svn: 24791
|
2005-12-17 20:50:42 +00:00 |
|
Chris Lattner
|
3e51b620ec
|
Add basic addressing mode support and one load.
llvm-svn: 24782
|
2005-12-17 20:04:49 +00:00 |
|
Chris Lattner
|
4de7491c52
|
Implement ret with operand, giving us this:
int %test(int %A) {
ret int %A
}
llvm-svn: 24773
|
2005-12-17 08:15:09 +00:00 |
|
Chris Lattner
|
3fca9488d2
|
Implement LowerArguments, at least for the first 6 integer args
llvm-svn: 24770
|
2005-12-17 08:03:24 +00:00 |
|
Chris Lattner
|
62aadddb9d
|
Add the framework for a dag-dag isel
llvm-svn: 24769
|
2005-12-17 07:47:01 +00:00 |
|