|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | There is still a bit more refactoring left to do in Targets. But we are now very
close to fixing all the layering issues in MC.
llvm-svn: 135611 | 
| | 
| 
| 
| 
| 
| 
| 
| | TargetLoweringObjectFileImpl down to MCObjectFileInfo.
TargetAsmInfo is done to one last method. It's *almost* gone!
llvm-svn: 135569 | 
| | 
| 
| 
| | llvm-svn: 135478 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | to MCRegisterInfo. Also initialize the mapping at construction time.
This patch eliminate TargetRegisterInfo from TargetAsmInfo. It's another step
towards fixing the layering violation.
llvm-svn: 135424 | 
| | 
| 
| 
| | llvm-svn: 135375 | 
| | 
| 
| 
| 
| 
| | const Constant *.
llvm-svn: 133400 | 
| | 
| 
| 
| 
| 
| | Luis Felipe Strano Moraes!
llvm-svn: 129558 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | mean that it has to be ConstantArray of ConstantStruct. We might have
ConstantAggregateZero, at either level, so don't crash on that.
Also, semi-deprecate the sentinal value. The linker isn't aware of sentinals so
we end up with the two lists appended, each with their "sentinals" on them.
Different parts of LLVM treated sentinals differently, so make them all just
ignore the single entry and continue on with the rest of the list.
llvm-svn: 129307 | 
| | 
| 
| 
| 
| 
| 
| | of { i32, void ()* }. Teach the verifier to verify that, deleting copies of
checks strewn about.
llvm-svn: 129128 | 
| | 
| 
| 
| | llvm-svn: 125490 | 
| | 
| 
| 
| | llvm-svn: 121471 | 
| | 
| 
| 
| | llvm-svn: 121461 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | f:
        .cfi_startproc
        nop
        .cfi_endproc
assembled (on ELF).
llvm-svn: 121434 | 
| | 
| 
| 
| | llvm-svn: 110460 | 
| | 
| 
| 
| | llvm-svn: 110410 | 
| | 
| 
| 
| 
| 
| 
| 
| | address of the static
ID member as the sole unique type identifier.  Clean up APIs related to this change.
llvm-svn: 110396 | 
| | 
| 
| 
| | llvm-svn: 108520 | 
| | 
| 
| 
| | llvm-svn: 101342 | 
| | 
| 
| 
| 
| 
| | readability.
llvm-svn: 100756 | 
| | 
| 
| 
| | llvm-svn: 100709 | 
| | 
| 
| 
| | llvm-svn: 98378 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 98363 | 
| | 
| 
| 
| | llvm-svn: 98293 | 
| | 
| 
| 
| | llvm-svn: 95150 | 
| | 
| 
| 
| 
| 
| 
| | Now the only use of the ELF writer is the JIT, which won't be
easy to fix in the short term. :( :(
llvm-svn: 95148 | 
| | 
| 
| 
| | llvm-svn: 94297 | 
| | 
| 
| 
| 
| 
| | having to pass various fields from it in.  Simplify.
llvm-svn: 93686 | 
| | 
| 
| 
| | llvm-svn: 93664 | 
| | 
| 
| 
| | llvm-svn: 93627 | 
| | 
| 
| 
| | llvm-svn: 92502 | 
| | 
| 
| 
| 
| 
| 
| 
| | the new predicates I added) instead of going through a context and doing a
pointer comparison.  Besides being cheaper, this allows a smart compiler
to turn the if sequence into a switch.
llvm-svn: 83297 | 
| | 
| 
| 
| | llvm-svn: 80717 | 
| | 
| 
| 
| | llvm-svn: 79777 | 
| | 
| 
| 
| | llvm-svn: 79763 | 
| | 
| 
| 
| | llvm-svn: 79749 | 
| | 
| 
| 
| 
| 
| | elf object file.
llvm-svn: 79029 | 
| | 
| 
| 
| | llvm-svn: 78948 | 
| | 
| 
| 
| 
| 
| 
| | Use MCSectionELF methods as much as possible, removing some
ELFWriter methods which are now unused
llvm-svn: 78940 | 
| | 
| 
| 
| 
| 
| 
| | syntactically as a string, very similiar to what Chris did with MachO.
The parsing support and validation is not introduced yet.
llvm-svn: 78890 | 
| | 
| 
| 
| 
| 
| | add support for PtrToInt, Add, Mul.
llvm-svn: 78552 | 
| | 
| 
| 
| 
| 
| 
| 
| | classes.
This totally optimizes PIC16 sections by not having an 'isdirective' bit anymore!! ;-)
llvm-svn: 78517 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Handle large integers, x86_fp80, ConstantAggregateZero, and two more ConstantExpr:
GetElementPtr and IntToPtr
Set SHF_MERGE bit for mergeable strings
Avoid zero initialized strings to be classified as a bss symbol
Don't allow common symbols to be classified as STB_WEAK
Add a constant to be used as a global value offset in data relocations 
llvm-svn: 78476 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | a dirty hack and isn't need anymore since the last x86 code emitter patch)
- Add a target-dependent modifier to addend calculation
- Use R_X86_64_32S relocation for X86::reloc_absolute_word_sext
- Use getELFSectionFlags whenever possible
- fix getTextSection to use TLOF and emit the right text section 
- Handle global emission for static ctors, dtors and Type::PointerTyID
- Some minor fixes
llvm-svn: 78176 | 
| | 
| 
| 
| 
| 
| | defaults to being ELF.
llvm-svn: 77866 | 
| | 
| 
| 
| | llvm-svn: 77834 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | compute it based on what it knows.  As part of this, rename getSectionForMergeableConstant
to getSectionForConstant because it works for non-mergable constants also.
The only functionality change from this is that Xcore will start dropping
its jump tables into readonly section instead of data section in -static mode.
This should be fine as the linker resolves the relocations.  If this is a
problem, let me know and we'll come up with another solution.
llvm-svn: 77833 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | should have no state that is specific to particular globals in the
section.  In this case, it means the removal of the "isWeak" and
"ExplicitSection" bits.  MCSection uses the new form of SectionKind.
To handle isWeak, I introduced a new SectionInfo class, which is
SectionKind + isWeak, and it is used by the part of the code generator
that does classification of a specific global.
The ExplicitSection disappears.  It is moved onto MCSection as a new
"IsDirective" bit.  Since the Name of a section is either a section
or directive, it makes sense to keep this bit in MCSection.  Ultimately
the creator of MCSection should canonicalize (e.g.) .text to whatever
the actual section is.
llvm-svn: 77803 | 
| | 
| 
| 
| 
| 
| | MCSection subclasses yet, but this is a step in the right direction.
llvm-svn: 77708 | 
| | 
| 
| 
| 
| 
| | initialize method, which can be called when an MCContext is available.
llvm-svn: 77687 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 77432 |