X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=docs%2FReleaseNotes.html;h=2f83b9447d1d98613e3ac0451f8aef501a58bb0f;hb=a75ce9f5d2236d93c117e861e60e6f3f748c9555;hp=9b1c5788ca7db8922e252f1a9d3b8885a79e1b71;hpb=bb11771eb6ffaf6867486f47719c3d52c4a0d63e;p=oota-llvm.git diff --git a/docs/ReleaseNotes.html b/docs/ReleaseNotes.html index 9b1c5788ca7..2f83b9447d1 100644 --- a/docs/ReleaseNotes.html +++ b/docs/ReleaseNotes.html @@ -119,10 +119,27 @@ production-quality compiler for C, Objective-C, C++ and Objective-C++ on x86

In the LLVM 2.8 time-frame, the Clang team has made many improvements:

- + @@ -180,7 +197,6 @@ optimizers, rather than just a handful.
  • Fortran programs using common variables now link correctly.
  • GNU OMP constructs no longer crash the compiler.
  • -

    @@ -253,7 +269,7 @@ support new platforms, new languages, new architectures, and new features.

    -libc++ is another new member of the LLVM +libc++ is another new member of the LLVM family. It is an implementation of the C++ standard library, written from the ground up to specifically target the forthcoming C++'0X standard and focus on delivering great performance.

    @@ -267,6 +283,43 @@ looking forward to the C++ committee finalizing the C++'0x standard.
    + + +
    +KLEE: A Symbolic Execution Virtual Machine +
    + +
    +

    +KLEE is a symbolic execution framework for +programs in LLVM bitcode form. KLEE tries to symbolically evaluate "all" paths +through the application and records state transitions that lead to fault +states. This allows it to construct testcases that lead to faults and can even +be used to verify some algorithms. +

    + +

    Although KLEE does not have any major new features as of 2.8, we have made +various minor improvements, particular to ease development:

    + + +
    + +
    External Open Source Projects Using LLVM 2.8 @@ -313,8 +366,8 @@ recompilation of larger parts of the compiler chain.

    language and compiler written on top of LLVM, intended for producing single-address-space managed code operating systems that run faster than the equivalent multiple-address-space C systems. -More in-depth blurb is available on the wiki.

    +More in-depth blurb is available on the wiki.

    @@ -325,14 +378,14 @@ href="http://www.quokforge.org/projects/horizon/wiki/Wiki">the wiki.

    -Clam AntiVirus is an open source (GPL) +Clam AntiVirus is an open source (GPL) anti-virus toolkit for UNIX, designed especially for e-mail scanning on mail gateways. Since version 0.96 it has bytecode signatures that allow writing detections for complex malware. It uses LLVM's JIT to speed up the execution of bytecode on -X86,X86-64,PPC32/64, falling back to its own interpreter otherwise. -The git version was updated to work with LLVM 2.8 +X86, X86-64, PPC32/64, falling back to its own interpreter otherwise. +The git version was updated to work with LLVM 2.8.

    The

    Jade project is hosted as part of the Open @@ -490,14 +543,14 @@ builds on LLVM 2.8.

    DTMC provides support for Transactional Memory, which is an easy-to-use and efficient way to synchronize accesses to shared memory. Transactions can contain normal C/C++ code (e.g., -__transaction { list.remove(x); x.refCount--; }) and will be executed +__transaction { list.remove(x); x.refCount--; }) and will be executed virtually atomically and isolated from other transactions.

    -Kai Interpreter +Kai Programming Language
    @@ -547,23 +600,6 @@ in this section.
    - -
    -LLVM Community Changes -
    - -
    - -

    In addition to changes to the code, between LLVM 2.7 and 2.8, a number of -organization changes have happened: -

    - - -
    -
    Major New Features @@ -574,8 +610,16 @@ organization changes have happened:

    LLVM 2.8 includes several major new capabilities:

    @@ -590,13 +634,19 @@ organization changes have happened: expose new optimization opportunities:

    @@ -612,33 +662,38 @@ expose new optimization opportunities:

    release includes a few major enhancements and additions to the optimizers:

    -
  • + -
    -Interpreter and JIT Improvements -
    - -
    - - +-->
    @@ -671,9 +726,9 @@ in.

  • The MC disassembler now fully supports ARM and Thumb. ARM assembler support is still in early development though.
  • The X86 MC assembler now supports the X86 AES and AVX instruction set.
  • -
  • Work on ELF and COFF support is well underway, but isn't useful yet in LLVM - 2.8. Please contact the llvmdev mailing list if you're interested in - this.
  • +
  • Work on ELF and COFF object files and ARM target support is well underway, + but isn't useful yet in LLVM 2.8. Please contact the llvmdev mailing list + if you're interested in this.
  • For more information, please see the . -

    Target Independent Code Generator Improvements @@ -697,35 +751,57 @@ infrastructure, which allows us to implement more aggressive algorithms and make it run faster:

    @@ -736,38 +812,46 @@ it run faster:

    -

    New features of the X86 target include: +

    New features and major changes in the X86 target include:

    @@ -782,14 +866,22 @@ it run faster:

    - - - -
    -New Useful APIs -
    - -
    - -

    This release includes a number of new APIs that are used internally, which - may also be useful for external clients. -

    - - - -
    - - -
    -Other Improvements and New Features -
    - -
    -

    Other miscellaneous features include:

    - - -
    @@ -888,7 +949,7 @@ from the previous release.

    @@ -928,7 +992,7 @@ API changes are:

    operands are now address-space qualified. If you were creating these intrinsic calls and prototypes yourself (as opposed to using Intrinsic::getDeclaration), you can use - UpgradeIntrinsicFunction/UpgradeIntrinsicCall to be portable accross releases. + UpgradeIntrinsicFunction/UpgradeIntrinsicCall to be portable across releases.
  • SetCurrentDebugLocation takes a DebugLoc now instead of a MDNode. @@ -947,9 +1011,20 @@ API changes are:

    LLVM. The Triple::normalize utility method has been added to help front-ends deal with funky triples.
  • +
  • + The signature of the GCMetadataPrinter::finishAssembly virtual + function changed: the raw_ostream and MCAsmInfo arguments + were dropped. GC plugins which compute stack maps must be updated to avoid + having the old definition overload the new signature. +
  • +
  • + The signature of MemoryBuffer::getMemBuffer changed. Unfortunately + calls intended for the old version still compile, but will not work correctly, + leading to a confusing error about an invalid header in the bitcode. +
  • - Some APIs got renamed: + Some APIs were renamed:
  • +
  • + Some public headers were renamed: + + +
    +Development Infrastructure Changes +
    + +
    + +

    This section lists changes to the LLVM development infrastructure. This +mostly impacts users who actively work on LLVM or follow development on +mainline, but may also impact users who leverage the LLVM build infrastructure +or are interested in LLVM qualification.

    + + +
    @@ -993,7 +1114,7 @@ components, please contact us on the LLVMdev list.