|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | Clang itself was not using this. The only way to access it was via llc.
llvm-svn: 200862 | 
| | 
| 
| 
| 
| 
| 
| | With this the target streamers will be able to know the target features that
are in use.
llvm-svn: 200135 | 
| | 
| 
| 
| | llvm-svn: 199785 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The 'Deprecated' class allows you to specify a SubtargetFeature that the
instruction is deprecated on.
The 'ComplexDeprecationPredicate' class allows you to define a custom
predicate that is called to check for deprecation.
For example:
  ComplexDeprecationPredicate<"MCR">
would mean you would have to define the following function:
  bool getMCRDeprecationInfo(MCInst &MI, MCSubtargetInfo &STI,
                             std::string &Info)
Which returns 'false' for not deprecated, and 'true' for deprecated
and store the warning message in 'Info'.
The MCTargetAsmParser constructor was chaned to take an extra argument of
the MCInstrInfo class, so out-of-tree targets will need to be changed.
llvm-svn: 190598 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We used to generate the compact unwind encoding from the machine
instructions. However, this had the problem that if the user used `-save-temps'
or compiled their hand-written `.s' file (with CFI directives), we wouldn't
generate the compact unwind encoding.
Move the algorithm that generates the compact unwind encoding into the
MCAsmBackend. This way we can generate the encoding whether the code is from a
`.ll' or `.s' file.
<rdar://problem/13623355>
llvm-svn: 190290 | 
| | 
| 
| 
| 
| 
| 
| | This centralizes the handling of O_BINARY and opens the way for hiding more
differences (like how open behaves with directories).
llvm-svn: 186447 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Someone may want to do something crazy, like replace these objects if they
change or something.
No functionality change intended.
llvm-svn: 184175 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | It was just a less powerful and more confusing version of
MCCFIInstruction. A side effect is that, since MCCFIInstruction uses
dwarf register numbers, calls to getDwarfRegNum are pushed out, which
should allow further simplifications.
I left the MachineModuleInfo::addFrameMove interface unchanged since
this patch was already fairly big.
llvm-svn: 181680 | 
| | 
| 
| 
| 
| 
| | Patch by Jun Koi!
llvm-svn: 181231 | 
| | 
| 
| 
| 
| 
| | to NULL and use asserts to check in relevant places.
llvm-svn: 176134 | 
| | 
| 
| 
| | llvm-svn: 172642 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | AT_producer.  Which includes clang's version information so we can tell
which version of the compiler was used.
This is the first of two steps to allow us to do that.  This is the llvm-mc
change to provide a method to set the AT_producer string.  The second step,
coming soon to a clang near you, will have the clang driver pass the value
of getClangFullVersion() via an flag when invoking the integrated assembler
on assembly source files.
rdar://12955296
llvm-svn: 172630 | 
| | 
| 
| 
| 
| 
| | its only user, is gone.
llvm-svn: 170699 | 
| | 
| 
| 
| | llvm-svn: 170578 | 
| | 
| 
| 
| 
| 
| 
| 
| | the assembler.
Part of PR14624
llvm-svn: 170390 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | compilation directory.
This defaults to the current working directory, just as it always has,
but now an assembler can choose to override it with a custom directory.
I've taught llvm-mc about this option and added a test case.
llvm-svn: 170371 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is for the lldb team so most of but not all of the values are
to be printed as hex with this option.  Some small values like the
scale in an X86 address were requested to printed in decimal
without the leading 0x.
There may be some tweaks need to places that may still be in
decimal that they want in hex.  Specially for arm.  I made my best
guess.  Any tweaks from here should be simple.
I also did the best I know now with help from the C++ gurus
creating the cleanest formatImm() utility function and containing
the changes.  But if someone has a better idea to make something
cleaner I'm all ears and game for changing the implementation.
rdar://8109283
llvm-svn: 169393 | 
| | 
| 
| 
| 
| 
| 
| 
| | Again, tools are trickier to pick the main module header for than
library source files. I've started to follow the pattern of using
LLVMContext.h when it is included as a stub for program source files.
llvm-svn: 169252 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | it will expand any .cfi_* directives in the input assembly.
Unfortunately this cannot replace elf-dump in tests as the asm streamer
cannot relax the line advance opcodes.
llvm-svn: 168522 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Per the October 12, 2012 Proposal for annotated disassembly output sent out by
Jim Grosbach this set of changes implements this for X86 and arm.  The llvm-mc
tool now has a -mdis option to produced the marked up disassembly and a couple
of small example test cases have been added.
rdar://11764962
llvm-svn: 166445 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | store this and use it to not emit long nops when the CPU is geode which
doesnt support them.
Fixes PR11212.
llvm-svn: 164132 | 
| | 
| 
| 
| 
| 
| 
| 
| | Add the MCRegisterInfo to the factories and constructors.
Patch by Tom Stellard <Tom.Stellard@amd.com>.
llvm-svn: 156828 | 
| | 
| 
| 
| 
| 
| | PR12731.  Patch by Meador Inge!
llvm-svn: 156444 | 
| | 
| 
| 
| 
| 
| 
| 
| | Also refactor so all MC paraphernalia are created once for all uses as much as possible.
The test change is to account for the fact that the default disassembler behaviour has changed with regards to specifying the assembly syntax to use.
llvm-svn: 154809 | 
| | 
| 
| 
| 
| 
| | declarations. Remove an unnecessary include.
llvm-svn: 154775 | 
| | 
| 
| 
| 
| 
| | getInstructionName and the static data it contains since the same tables are already in MCInstrInfo.
llvm-svn: 153860 | 
| | 
| 
| 
| 
| 
| | Patch by jey.
llvm-svn: 152315 | 
| | 
| 
| 
| 
| 
| 
| | Used to allow context sensitive printing of super-register or sub-register
references.
llvm-svn: 152043 | 
| | 
| 
| 
| | llvm-svn: 149091 | 
| | 
| 
| 
| 
| 
| | necessary)
llvm-svn: 148284 | 
| | 
| 
| 
| | llvm-svn: 147855 | 
| | 
| 
| 
| | llvm-svn: 147820 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | generates the dwarf Compile Unit DIE and a dwarf subprogram DIE for each
non-temporary label.
The next part will be to get the clang driver to enable this when assembling
a .s file.  rdar://9275556
llvm-svn: 146262 | 
| | 
| 
| 
| | llvm-svn: 145870 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | -g flag.  In this part we generate the .file for the source being assembled and
the .loc's for the assembled instructions.
The next part will be to generate the dwarf Compile Unit DIE and a dwarf
subprogram DIE for each non-temporary label.
Once the next part is done test cases will be added.  rdar://9275556
llvm-svn: 143509 | 
| | 
| 
| 
| | llvm-svn: 143502 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | .file filenumber "directory" "filename"
This removes one join+split of the directory+filename in MC internals. Because
bitcode files have independent fields for directory and filenames in debug info,
this patch may change the .o files written by existing .bc files.
llvm-svn: 142300 | 
| | 
| 
| 
| 
| 
| 
| 
| | note/warning/error as a
string, pass it around as an enum.
llvm-svn: 142107 | 
| | 
| 
| 
| 
| 
| | handling to llvm-mc. Reviewed by Owen Anderson.
llvm-svn: 139237 | 
| | 
| 
| 
| 
| 
| | These are strictly utilities for registering targets and components.
llvm-svn: 138450 | 
| | 
| 
| 
| 
| 
| | The argument is unused, and is a layering violation in any case.
llvm-svn: 137735 | 
| | 
| 
| 
| | llvm-svn: 136115 | 
| | 
| 
| 
| 
| 
| | createMCObjectStreamer.
llvm-svn: 136031 | 
| | 
| 
| 
| 
| 
| | MCTargetAsmLexer; rename createAsmLexer to createMCAsmLexer and createAsmParser to createMCAsmParser.
llvm-svn: 136027 | 
| | 
| 
| 
| 
| 
| | createMCAsmBackend.
llvm-svn: 136010 | 
| | 
| 
| 
| | llvm-svn: 135974 | 
| | 
| 
| 
| 
| 
| | TargetMachine's anymore.
llvm-svn: 135963 | 
| | 
| 
| 
| 
| 
| | they belong.
llvm-svn: 135833 | 
| | 
| 
| 
| 
| 
| | InitializeX86MCInstrInfo, etc. are combined into InitializeX86TargetMC.
llvm-svn: 135812 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | the Support library. Now its part of the TargetRegistry, and the three
commands that care about this explicitly register this extra bit of
version information.
The set of commands which care was computed by intersecting those which
use the Support library's version string printing and those that
initialize all the registered targets in a way that produces
a meaningful list. The only odd ball out is that 'clang -cc1as -version'
no longer prints the registered targets. I don't think anyone is really
interested in that (especially as the fact that llvm-mc does so is under
a FIXME), but if someone really does want this back I'll happily apply
the same patch there.
llvm-svn: 135757 |