|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | Patch by Matthew Gardiner with fixes by me.
llvm-svn: 212745 | 
| | 
| 
| 
| 
| 
| 
| 
| | Summary: This is a pre-requisite for supporting the mips-img-linux-gnu triple in clang.
Differential Revision: http://reviews.llvm.org/D4435
llvm-svn: 212626 | 
| | 
| 
| 
| 
| 
| | Two of those are use after frees. Found by clang-tidy, fixed by me.
llvm-svn: 212537 | 
| | 
| 
| 
| 
| 
| | This reverts commit 7b4a6882467e7fef4516a0cbc418cbfce0fc6f6d.
llvm-svn: 212521 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | According to a FIXME in ARMMCTargetDesc.cpp the ARM version parsing should be
in the Triple helper class.
Patch by: Gabor Ballabas
llvm-svn: 212479 | 
| | 
| 
| 
| | llvm-svn: 206197 | 
| | 
| 
| 
| | llvm-svn: 205697 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This generalises the object file type parsing to all Windows environments.  This
is used by cygwin as well as MSVC environments for MCJIT.  This also makes the
triple more similar to Chandler's suggestion of a separate field for the object
file format.
llvm-svn: 205219 | 
| | 
| 
| 
| 
| 
| 
| | This is causing the ARM build-bots to fail since they only include
the ARM backend and can't create an ARM64 target.
llvm-svn: 205132 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If the environment is unknown and no object file is provided, then assume an
"MSVC" environment, otherwise, set the environment to the object file format.
In the case that we have a known environment but a non-native file format for
Windows (COFF) which is used for MCJIT, then append the custom file format to
the triple as an additional component.
This fixes the MCJIT tests on Windows.
llvm-svn: 205130 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds a second implementation of the AArch64 architecture to LLVM,
accessible in parallel via the "arm64" triple. The plan over the
coming weeks & months is to merge the two into a single backend,
during which time thorough code review should naturally occur.
Everything will be easier with the target in-tree though, hence this
commit.
llvm-svn: 205090 | 
| | 
| 
| 
| 
| 
| | Reviewed at http://llvm-reviews.chandlerc.com/D3095
llvm-svn: 205007 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Construct a uniform Windows target triple nomenclature which is congruent to the
Linux counterpart.  The old triples are normalised to the new canonical form.
This cleans up the long-standing issue of odd naming for various Windows
environments.
There are four different environments on Windows:
MSVC: The MS ABI, MSVCRT environment as defined by Microsoft
GNU: The MinGW32/MinGW32-W64 environment which uses MSVCRT and auxiliary libraries
Itanium: The MSVCRT environment + libc++ built with Itanium ABI
Cygnus: The Cygwin environment which uses custom libraries for everything
The following spellings are now written as:
i686-pc-win32 => i686-pc-windows-msvc
i686-pc-mingw32 => i686-pc-windows-gnu
i686-pc-cygwin => i686-pc-windows-cygnus
This should be sufficiently flexible to allow us to target other windows
environments in the future as necessary.
llvm-svn: 204977 | 
| | 
| 
| 
| | llvm-svn: 203423 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is a preliminary setup change to support a renaming of Windows target
triples.  Split the object file format information out of the environment into a
separate entity.  Unfortunately, file format was previously treated as an
environment with an unknown OS.  This is most obvious in the ARM subtarget where
the handling for macho on an arbitrary platform switches to AAPCS rather than
APCS (as per Apple's needs).
llvm-svn: 203160 | 
| | 
| 
| 
| | llvm-svn: 202024 | 
| | 
| 
| 
| | llvm-svn: 199648 | 
| | 
| 
| 
| | llvm-svn: 197405 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Defaulting to iOS 3.0 when LLVM has to guess the version is no longer a useful
option and can give surprising results (like tail calls being disabled).
5.0 seems like a reasonable compromise as a platform that's still interesting
to some people.
rdar://problem/15567348
llvm-svn: 196912 | 
| | 
| 
| 
| | llvm-svn: 194906 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch provides basic support for powerpc64le as an LLVM target.
However, use of this target will not actually generate little-endian
code.  Instead, use of the target will cause the correct little-endian
built-in defines to be generated, so that code that tests for
__LITTLE_ENDIAN__, for example, will be correctly parsed for
syntax-only testing.  Code generation will otherwise be the same as
powerpc64 (big-endian), for now.
The patch leaves open the possibility of creating a little-endian
PowerPC64 back end, but there is no immediate intent to create such a
thing.
The LLVM portions of this patch simply add ppc64le coverage everywhere
that ppc64 coverage currently exists.  There is nothing of any import
worth testing until such time as little-endian code generation is
implemented.  In the corresponding Clang patch, there is a new test
case variant to ensure that correct built-in defines for little-endian
code are generated.
llvm-svn: 187179 | 
| | 
| 
| 
| 
| 
| | Approval in here http://lists.cs.uiuc.edu/pipermail/llvmdev/2013-July/064169.html
llvm-svn: 187145 | 
| | 
| 
| 
| 
| 
| | IR for CUDA should use "nvptx[64]-nvidia-cuda", and IR for NV OpenCL should use "nvptx[64]-nvidia-nvcl"
llvm-svn: 184579 | 
| | 
| 
| 
| 
| 
| | Patch by Brad Smith!
llvm-svn: 181808 | 
| | 
| 
| 
| 
| 
| 
| | First step towards reinstating the SystemZ backend.  Tests will be
included in the main backend patch.
llvm-svn: 181007 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch adds support for AArch64 (ARM's 64-bit architecture) to
LLVM in the "experimental" category. Currently, it won't be built
unless requested explicitly.
This initial commit should have support for:
    + Assembly of all scalar (i.e. non-NEON, non-Crypto) instructions
      (except the late addition CRC instructions).
    + CodeGen features required for C++03 and C99.
    + Compilation for the "small" memory model: code+static data <
      4GB.
    + Absolute and position-independent code.
    + GNU-style (i.e. "__thread") TLS.
    + Debugging information.
The principal omission, currently, is performance tuning.
This patch excludes the NEON support also reviewed due to an outbreak of
batshit insanity in our legal department. That will be committed soon bringing
the changes to precisely what has been approved.
Further reviews would be gratefully received.
llvm-svn: 174054 | 
| | 
| 
| 
| 
| 
| 
| 
| | Add the x32 environment kind to the triple, and separate the concept of
pointer size and callee save stack slot size, since they're not equal
on x32.
llvm-svn: 173175 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | textually as NativeClient. Also added a link to the native client project for
readers unfamiliar with it.
A Clang patch will follow shortly.
llvm-svn: 169291 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| 
| 
| | The new OpenCL SPIR extension spec will define separate SPIR for 32 and 64 bit architectures.
llvm-svn: 168036 | 
| | 
| 
| 
| 
| 
| | Approved by Chris Lattner.
llvm-svn: 167984 | 
| | 
| 
| 
| | llvm-svn: 167157 | 
| | 
| 
| 
| | llvm-svn: 165792 | 
| | 
| 
| 
| 
| 
| | This adds 'elf' as a recognized target triple environment value and overrides the default generated object format on Windows platforms if that value is present.  This patch also enables MCJIT tests on Windows using the new environment value.
llvm-svn: 165030 | 
| | 
| 
| 
| 
| 
| | calling conventions.
llvm-svn: 164948 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Most of the code guarded with ANDROIDEABI are not
ARM-specific, and having no relation with arm-eabi.
Thus, it will be more natural to call this
environment "Android" instead of "ANDROIDEABI".
Note: We are not using ANDROID because several projects
are using "-DANDROID" as the conditional compilation
flag.
llvm-svn: 163087 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Adds the vendor 'fsl' (used by Freescale SDK) to Triple. This will allow
clang support for Freescale cross-compile configurations.
Patch by Tobias von Koch.
llvm-svn: 162726 | 
| | 
| 
| 
| 
| 
| | Patch by David Hill.
llvm-svn: 161344 | 
| | 
| 
| 
| | llvm-svn: 159367 | 
| | 
| 
| 
| 
| 
| 
| 
| | This back-end was deprecated in favor of the NVPTX back-end.
NV_CONTRIB
llvm-svn: 157417 | 
| | 
| 
| 
| | llvm-svn: 156492 | 
| | 
| 
| 
| | llvm-svn: 156484 | 
| | 
| 
| 
| 
| 
| 
| | This new function provides a way to get the iOS version number from ios triples.
Part of rdar://11409204
llvm-svn: 156483 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | for NVIDIA PTX 3.0. This back-end will (eventually) replace the current PTX back-end, while maintaining compatibility with it.
The new target machines are:
nvptx (old ptx32) => 32-bit PTX
nvptx64 (old ptx64) => 64-bit PTX
The sources are based on the internal NVIDIA NVPTX back-end, and
contain more functionality than the current PTX back-end currently
provides.
NV_CONTRIB
llvm-svn: 156196 | 
| | 
| 
| 
| | llvm-svn: 153882 | 
| | 
| 
| 
| 
| 
| | Patch by Tom Stellard!
llvm-svn: 152400 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | chip in r139383, and the PSP components of the triple are really
annoying to parse. Let's leave this chapter behind. There is no reason
to expect LLVM to see a PSP-related triple these days, and so no
reasonable motivation to support them.
It might be reasonable to prune a few of the older MIPS triple forms in
general, but as those at least cause no burden on parsing (they aren't
both a chip and an OS!), I'm happy to leave them in for now.
llvm-svn: 151156 | 
| | 
| 
| 
| 
| 
| | the normalize routine, especially the empty while loops.
llvm-svn: 151050 | 
| | 
| 
| 
| 
| 
| | days. No functionality changed.
llvm-svn: 151048 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | They're private static methods but we can just make them static
functions in the implementation. It makes the implementations a touch
more wordy, but takes another chunk out of the header file.
Also, take the opportunity to switch the names to the new coding
conventions.
No functionality changed here.
llvm-svn: 151047 |