summaryrefslogtreecommitdiffstats
path: root/llvm/lib
Commit message (Collapse)AuthorAgeFilesLines
* Let MRegisterInfo now owns RegScavenger; eliminateFrameIndex must preserve ↵Evan Cheng2007-02-272-30/+51
| | | | | | register kill info. llvm-svn: 34692
* Let MRegisterInfo now owns RegScavenger.Evan Cheng2007-02-271-3/+3
| | | | llvm-svn: 34691
* RegScavenger interface change to make it more flexible.Evan Cheng2007-02-271-16/+18
| | | | llvm-svn: 34690
* implement CCMatchIfCC in terms of CCMatchIfChris Lattner2007-02-271-4/+4
| | | | llvm-svn: 34685
* build cc infoChris Lattner2007-02-271-1/+1
| | | | llvm-svn: 34684
* Adjust to changes in the APInt interface.Reid Spencer2007-02-272-5/+5
| | | | llvm-svn: 34681
* Improve APInt interface:Reid Spencer2007-02-271-34/+1
| | | | | | | | | | 1. Add unsigned and signed versions of methods so a "bool" argument doesn't need to be passed in. 2. Make the various getMin/getMax functions all be inline since they are so simple. 3. Simplify sdiv and srem code. llvm-svn: 34680
* Conform to single person attribution in file comment.Reid Spencer2007-02-271-3/+2
| | | | llvm-svn: 34678
* For PR1205:Reid Spencer2007-02-271-14/+5
| | | | | | | | | | | Implement review feedback: 1. Use new APInt::RoundDoubleToAPInt interface to specify the bit width so that we don't have to truncate or extend in constant folding. 2. Fix a pasteo in SDiv that prevented a check for overflow. 3. Fix the shift operators: undef happens when the shift amount is equal to the bitwidth. llvm-svn: 34677
* 1. Fix three serious bugs in the comparison code.Reid Spencer2007-02-271-18/+22
| | | | | | | 2. Change RoundDoubleToAPInt to take a bit width parameter. Use that parameter to limit the bit width of the result. llvm-svn: 34673
* a noteChris Lattner2007-02-271-0/+42
| | | | llvm-svn: 34670
* Make getPassManagerType() const.Devang Patel2007-02-272-3/+5
| | | | llvm-svn: 34669
* Fix parenthesis for BCTRL_{ELF|Macho} test.Nicolas Geoffray2007-02-271-1/+1
| | | | llvm-svn: 34668
* Differentiate between the MachO and the ELF ABI the CALL instruction.Nicolas Geoffray2007-02-274-12/+12
| | | | llvm-svn: 34667
* Duplicate use of LR, take 2.Jim Laskey2007-02-273-26/+42
| | | | llvm-svn: 34666
* Allow the AsmWriter to print out arbitrary precision integers.Reid Spencer2007-02-271-1/+1
| | | | llvm-svn: 34664
* Correct the implelmentation of ConstantInt::getAllOnesValue() for bitReid Spencer2007-02-271-1/+1
| | | | | | widths > 64 bits. llvm-svn: 34663
* Get rid of extraneous // in file comment.Reid Spencer2007-02-271-1/+1
| | | | llvm-svn: 34662
* Add calling convention infoChris Lattner2007-02-272-2/+11
| | | | llvm-svn: 34661
* For PR1205:Reid Spencer2007-02-271-102/+135
| | | | | | Implement constant folding via APInt instead of uint64_t. llvm-svn: 34660
* move target independent calling convention stuff to TargetCallingConv.tdChris Lattner2007-02-272-56/+71
| | | | llvm-svn: 34659
* fill in some holesChris Lattner2007-02-271-7/+33
| | | | llvm-svn: 34658
* switch x86-64 return value lowering over to using same mechanism as argumentChris Lattner2007-02-271-68/+88
| | | | | | lowering uses. llvm-svn: 34657
* Minor refactoring of CC Lowering interfacesChris Lattner2007-02-272-23/+28
| | | | llvm-svn: 34656
* move CC Lowering stuff to its own public interfaceChris Lattner2007-02-272-146/+51
| | | | llvm-svn: 34655
* refactor x86-64 argument lowering yet again, this time eliminating templates,Chris Lattner2007-02-271-166/+179
| | | | | | 'clients', etc, and adding CCValAssign instead. llvm-svn: 34654
* ConstantFolding.cpp/h -> ConstantFold.cpp/h to avoid confusion withChris Lattner2007-02-273-2/+2
| | | | | | lib/Analysis/ConstantFolding. llvm-svn: 34653
* Backing out Jim's LR spill changes. This was causing llvm-gcc bootstrappingEvan Cheng2007-02-273-19/+2
| | | | | | | | | to infinite loop: PPCMachineFunctionInfo.h updated: 1.2 -> 1.3 PPCRegisterInfo.cpp updated: 1.110 -> 1.111 PPCRegisterInfo.h updated: 1.28 -> 1.29 llvm-svn: 34652
* forward() should not increment internal iterator. Its client may insert ↵Evan Cheng2007-02-272-5/+26
| | | | | | instruction between now and next forward() call. llvm-svn: 34649
* Simplify and document RoundDoubleToAPInt.Reid Spencer2007-02-271-3/+15
| | | | llvm-svn: 34648
* For PR1205:Reid Spencer2007-02-261-16/+49
| | | | | | | | | | Implement the first step towards arbitrary precision integer support in LLVM. The APInt class provides arbitrary precision arithmetic and value representation. This patch changes ConstantInt to use APInt as its value representation without supporting bit widths > 64 yet. That change will come after ConstantFolding handles bit widths > 64 bits. llvm-svn: 34647
* 1. Make sure all delete operators of arrays use the array form of delete.Reid Spencer2007-02-261-19/+45
| | | | | | | | | | | | | | 2. Rewrite operator=(const APInt& RHS) to allow the RHS to be a different bit width than the LHS. This makes it possible to use APInt as the key of a DenseMap, as needed for the IntConstants map in Constants.cpp 3. Fix operator=(uint64_t) to clear unused bits in case the client assigns a value that has more bits than the APInt allows. 4. Assert that bit widths are equal in operator== 5. Revise getHashValue() to put the bit width in the low order six bits. This should help to make i1 0, i2 0, ... i64 0 all distinct in the IntConstants DenseMap. llvm-svn: 34646
* Joining an interval with a dead copy instruction. Shorten the live range to ↵Evan Cheng2007-02-261-20/+46
| | | | | | the last use. llvm-svn: 34645
* Implement the getHashValue method.Reid Spencer2007-02-261-1/+16
| | | | | | Fix toString use of getValue to use getZExtValue() llvm-svn: 34642
* Use efficient container SmallPtrSetDevang Patel2007-02-261-3/+4
| | | | llvm-svn: 34640
* always lower to RETFLAG, never leave it as just ret.Chris Lattner2007-02-262-11/+7
| | | | llvm-svn: 34639
* Do not unswitch loop on same value again and again.Devang Patel2007-02-261-0/+7
| | | | llvm-svn: 34638
* fix attributionChris Lattner2007-02-261-1/+1
| | | | llvm-svn: 34637
* Add a description of the X86-64 calling convention and the returnChris Lattner2007-02-262-0/+143
| | | | | | conventions. This doesn't do anything yet, but may in the future. llvm-svn: 34636
* Re-enable this. The header was committed.Reid Spencer2007-02-261-4/+0
| | | | llvm-svn: 34634
* switch to smallvectorChris Lattner2007-02-261-3/+1
| | | | llvm-svn: 34633
* another missing header :( :( :(Chris Lattner2007-02-261-0/+4
| | | | llvm-svn: 34632
* initial hack at splitting the x86-64 calling convention info out from theChris Lattner2007-02-261-271/+299
| | | | | | | mechanics that process it. I'm still not happy with this, but it's a step in the right direction. llvm-svn: 34631
* 1. Remove redundant calls to clearUsedBits().Reid Spencer2007-02-261-44/+79
| | | | | | | | | | 2. Fix countTrailingZeros to use a faster algorithm. 3. Simplify sext() slightly by using isNegative(). 4. Implement ashr using word-at-a-time logic instead of bit-at-a-time 5. Rename locals named isNegative so they don't clash with method name. 6. Fix fromString to compute negated value correctly. llvm-svn: 34629
* the truncate must always be done, it's only the assert that is conditional.Chris Lattner2007-02-261-1/+1
| | | | llvm-svn: 34628
* reapply my previous patch with a bugfix.Chris Lattner2007-02-261-21/+31
| | | | llvm-svn: 34627
* revert my previous change, something strange is happening.Chris Lattner2007-02-261-29/+21
| | | | llvm-svn: 34626
* add an accessor.Chris Lattner2007-02-261-0/+4
| | | | llvm-svn: 34625
* in X86-64 CCC, i8/i16 arguments are already properly zext/sext'd on input.Chris Lattner2007-02-261-14/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Capture this so that downstream zext/sext's are optimized out. This compiles: int test(short X) { return (int)X; } to: _test: movl %edi, %eax ret instead of: _test: movswl %di, %eax ret GCC produces this bizarre code: _test: movw %di, -12(%rsp) movswl -12(%rsp),%eax ret llvm-svn: 34623
* Fold (sext (truncate x)) more aggressively, by avoiding creation of aChris Lattner2007-02-261-10/+34
| | | | | | | | | sextinreg if not needed. This is useful in two cases: before legalize, it avoids creating a sextinreg that will be trivially removed. After legalize if the target doesn't support sextinreg, the trunc/sext would not have been removed before. llvm-svn: 34621
OpenPOWER on IntegriCloud