|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | users.
llvm-svn: 93558 | 
| | 
| 
| 
| 
| 
| | of the code.
llvm-svn: 92295 | 
| | 
| 
| 
| 
| 
| | after their syntactic form, not their semantic form.
llvm-svn: 92294 | 
| | 
| 
| 
| | llvm-svn: 90738 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | $ llvm-as foo.ll -d -disable-output
which reads and prints the .ll file.  BC encoding is the
next project.  Testcase will go in once that works.
llvm-svn: 85368 | 
| | 
| 
| 
| | llvm-svn: 85351 | 
| | 
| 
| 
| 
| 
| 
| | (assembler,asmprinter, bc reader+writer) and document it.  Codegen
currently aborts on it.
llvm-svn: 85274 | 
| | 
| 
| 
| 
| 
| 
| | Remove LowerAllocations pass.
Update some more passes to treate free calls just like they were treating FreeInst.
llvm-svn: 85176 | 
| | 
| 
| 
| | llvm-svn: 84795 | 
| | 
| 
| 
| | llvm-svn: 84408 | 
| | 
| 
| 
| 
| 
| 
| 
| | Update testcases that rely on malloc insts being present.
Also prematurely remove MallocInst handling from IndMemRemoval and RaiseAllocations to help pass tests in this incremental step.
llvm-svn: 84292 | 
| | 
| 
| 
| 
| 
| 
| | A little ugliness is accepted to keep the binary file format
compatible.  No functional change yet.
llvm-svn: 84020 | 
| | 
| 
| 
| | llvm-svn: 83033 | 
| | 
| 
| 
| 
| 
| | causes regressions in the nightly tests.
llvm-svn: 82784 | 
| | 
| 
| 
| 
| 
| | Reviewed by Devang Patel.
llvm-svn: 82694 | 
| | 
| 
| 
| | llvm-svn: 82063 | 
| | 
| 
| 
| 
| 
| 
| 
| | code hints that it would be a good idea to inline
a function ("inline" keyword).  No functional change
yet; FEs do not emit this and inliner does not use it.
llvm-svn: 80063 | 
| | 
| 
| 
| 
| 
| | for EOF.
llvm-svn: 79908 | 
| | 
| 
| 
| | llvm-svn: 78948 | 
| | 
| 
| 
| 
| 
| | - Patch by Erick Tryzelaar, with some edits (and a bug fix) from me.
llvm-svn: 78885 | 
| | 
| 
| 
| | llvm-svn: 77516 | 
| | 
| 
| 
| | llvm-svn: 77410 | 
| | 
| 
| 
| 
| 
| | LangRef.html changes for details.
llvm-svn: 77259 | 
| | 
| 
| 
| 
| 
| | which stand for no-unsigned-wrap and no-signed-wrap.
llvm-svn: 76810 | 
| | 
| 
| 
| 
| 
| | exact sdiv flags.
llvm-svn: 76475 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | "private" symbols which the assember shouldn't strip, but which the linker may
remove after evaluation. This is mostly useful for Objective-C metadata.
This is plumbing, so we don't have a use of it yet. More to come, etc.
llvm-svn: 76385 | 
| | 
| 
| 
| | llvm-svn: 76198 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This adds location info for all llvm_unreachable calls (which is a macro now) in
!NDEBUG builds.
In NDEBUG builds location info and the message is off (it only prints
"UREACHABLE executed").
llvm-svn: 75640 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Make llvm_unreachable take an optional string, thus moving the cerr<< out of
line.
LLVM_UNREACHABLE is now a simple wrapper that makes the message go away for
NDEBUG builds.
llvm-svn: 75379 | 
| | 
| 
| 
| 
| 
| 
| | these instructions, no autoupgrade or backwards compatibility support is
provided.
llvm-svn: 74991 | 
| | 
| 
| 
| | llvm-svn: 74934 | 
| | 
| 
| 
| | llvm-svn: 74735 | 
| | 
| 
| 
| | llvm-svn: 74734 | 
| | 
| 
| 
| 
| 
| 
| | Dispatch C calling conv. to one of these conventions based on
target triple and subtarget features.
llvm-svn: 73530 | 
| | 
| 
| 
| 
| 
| 
| | Update code generator to use this attribute and remove NoImplicitFloat target option.
Update llc to set this attribute when -no-implicit-float command line option is used.
llvm-svn: 72959 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | integer and floating-point opcodes, introducing
FAdd, FSub, and FMul.
For now, the AsmParser, BitcodeReader, and IRBuilder all preserve
backwards compatability, and the Core LLVM APIs preserve backwards
compatibility for IR producers. Most front-ends won't need to change
immediately.
This implements the first step of the plan outlined here:
http://nondot.org/sabre/LLVMNotes/IntegerOverflow.txt
llvm-svn: 72897 | 
| | 
| 
| 
| 
| 
| 
| | Update code generator to use this attribute and remove DisableRedZone target option.
Update llc to set this attribute when -disable-red-zone command line option is used.
llvm-svn: 72894 | 
| | 
| 
| 
| | llvm-svn: 72610 | 
| | 
| 
| 
| 
| 
| 
| 
| | to support C99 inline, GNU extern inline, etc.  Related bugzilla's
include PR3517, PR3100, & PR2933.  Nothing uses this yet, but it
appears to work.
llvm-svn: 68940 | 
| | 
| 
| 
| 
| 
| 
| 
| | Constant, MDString and MDNode which can only be used by globals with a name
that starts with "llvm." or as arguments to a function with the same naming
restriction.
llvm-svn: 68420 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | same as a normal i80 {low64, high16} rather
than its own {high64, low16}.  A depressing number
of places know about this; I think I got them all.
Bitcode readers and writers convert back to the old
form to avoid breaking compatibility.
llvm-svn: 67562 | 
| | 
| 
| 
| 
| 
| | linkage, so remove it.
llvm-svn: 66690 | 
| | 
| 
| 
| 
| 
| 
| | linkage: this linkage type only applies to declarations,
but ODR is only relevant to globals with definitions.
llvm-svn: 66650 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and extern_weak_odr.  These are the same as the non-odr versions,
except that they indicate that the global will only be overridden
by an *equivalent* global.  In C, a function with weak linkage can
be overridden by a function which behaves completely differently.
This means that IP passes have to skip weak functions, since any
deductions made from the function definition might be wrong, since
the definition could be replaced by something completely different
at link time.   This is not allowed in C++, thanks to the ODR
(One-Definition-Rule): if a function is replaced by another at
link-time, then the new function must be the same as the original
function.  If a language knows that a function or other global can
only be overridden by an equivalent global, it can give it the
weak_odr linkage type, and the optimizers will understand that it
is alright to make deductions based on the function body.  The
code generators on the other hand map weak and weak_odr linkage
to the same thing.
llvm-svn: 66339 | 
| | 
| 
| 
| | llvm-svn: 62279 | 
| | 
| 
| 
| | llvm-svn: 61595 | 
| | 
| 
| 
| | llvm-svn: 61594 | 
| | 
| 
| 
| | llvm-svn: 61563 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and clean recursive descent parser.
This change has a couple of ramifications:
1. The parser code is about 400 lines shorter (in what we maintain, not
   including what is autogenerated).
2. The code should be significantly faster than the old code because we 
   don't have to work around bison's poor handling of datatypes with 
   ctors/dtors.  This also makes the code much more resistant to memory 
   leaks.
3. We now get caret diagnostics from the .ll parser, woo.
4. The actual diagnostics emited from the parser are completely different
   so a bunch of testcases had to be updated.
5. I now disallow "%ty = type opaque %ty = type i32".  There was no good
   reason to support this, it was just an accident of the old 
   implementation.  I have no reason to think that anyone is actually using
   this.
6. The syntax for sticking a global variable has changed to make it 
   unambiguous.  I don't think anyone is depending on this since only clang
   supports this and it is not solid yet, so I'm not worried about anything
   breaking.
7. This gets rid of the last use of bison, and along with it the .cvs files.
   I'll prune this from the makefiles as a subsequent commit.
There are a few minor cleanups that can be done after this commit (suggestions
welcome!) but this passes dejagnu testing and is ready for its time in the
limelight.
llvm-svn: 61558 | 
| | 
| 
| 
| | llvm-svn: 61240 |