|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | It's more flexible and arguably better layering to set flags to modify
compiling for diagnostics in the CC1 job themselves, rather than
tweaking the driver flags and letting them propagate.
There is one visible change this causes: crash report files will now
get preprocessed names (.i and friends).
llvm-svn: 211411 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Patch by Ehsan Akhgari!
(Tiny tweak by me: renamed PathSegment to LibDir.)
Differential Revision: http://reviews.llvm.org/D4192
llvm-svn: 211189 | 
| | 
| 
| 
| 
| 
| 
| 
| | Patch by Ehsan Akhgari!
Differential Revision: http://reviews.llvm.org/D4143
llvm-svn: 211081 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This maps the /EP argument to both -E and -P.
Patch by Ehsan Akhgari!
Differential Reviion: http://reviews.llvm.org/D4133
llvm-svn: 210935 | 
| | 
| 
| 
| | llvm-svn: 210780 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This corrects long-standing misuses of LLVM's internal config.h.
In most cases the public llvm-config.h header was intended and we can now
remove the old hacks thanks to LLVM r210144.
The config.h header is private, won't be installed and should no longer be
included by clang or other modules.
llvm-svn: 210145 | 
| | 
| 
| 
| | llvm-svn: 209069 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | All callers were passing in "a.out" or garbage so a sensible default works fine
here as a cleanup.
This also brings about the possibility of adapting the value based on the
driver's compatibility mode in future.
The setting can still be changed via Driver::DefaultImageName as needed.
llvm-svn: 208926 | 
| | 
| 
| 
| 
| 
| 
| | We were synthesizing new arguments from e.g. '/Tcfile.c' arguments,
but didn't handle ownership correctly.
llvm-svn: 207880 | 
| | 
| 
| 
| 
| 
| 
| | inputs to the preprocessor, check for invalid types first because not
all linker inputs have an option value to retrieve.
llvm-svn: 207454 | 
| | 
| 
| 
| 
| 
| | missing.
llvm-svn: 206462 | 
| | 
| 
| 
| | llvm-svn: 205966 | 
| | 
| 
| 
| | llvm-svn: 205051 | 
| | 
| 
| 
| 
| 
| 
| | This should fix the clang-cl tests after the Windows target triple
canonicalization (r204978)
llvm-svn: 204985 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This follows the LLVM change to canonicalise the Windows target triple
spellings.  Rather than treating each Windows environment as a single entity,
the environments are now modelled properly as an environment.  This is a
mechanical change to convert the triple use to reflect that change.
llvm-svn: 204978 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | when -Ofast is used without -ffast-math
In gcc using -Ofast forces linking of crtfastmath.o.
In the current clang crtfastmath.o is only linked when -ffast-math/-funsafe-math-optimizations passed. It can lead to performance issues, when using only -Ofast without explicit -ffast-math (I faced with it).
My patch fixes inconsistency with gcc behaviour and also introduces few tests on it.
Patch by Zinovy Nis!
Differential Revision: http://llvm-reviews.chandlerc.com/D3114
llvm-svn: 204742 | 
| | 
| 
| 
| 
| 
| 
| | that implicitly converts to 'bool' (such as pointers, and the first operand of
?:). Clean up issues found by this. Patch by Stephan Tolksdorf!
llvm-svn: 203735 | 
| | 
| 
| 
| | llvm-svn: 203389 | 
| | 
| 
| 
| 
| 
| | This compiles cleanly with lldb/lld/clang-tools-extra/llvm.
llvm-svn: 203279 | 
| | 
| 
| 
| 
| 
| | This is a precursor to moving to std::unique_ptr.
llvm-svn: 203275 | 
| | 
| 
| 
| 
| 
| 
| | Use the new getObjectFormat/setObjectFormat instead of Environment now that the
file format is a separate field.
llvm-svn: 203161 | 
| | 
| 
| 
| | llvm-svn: 202639 | 
| | 
| 
| 
| | llvm-svn: 202053 | 
| | 
| 
| 
| | llvm-svn: 201739 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch improves the support for picking Multilibs from gcc installations.
It also provides a better approximation for the flags '-print-multi-directory'
and '-print-multi-lib'.
This reverts r201203 (i.e. re-applying r201202 with small fixes in
unittests/CMakeLists.txtto make the build bots happy).
review: http://llvm-reviews.chandlerc.com/D2538
llvm-svn: 201205 | 
| | 
| 
| 
| 
| 
| | Breaks cmake configure of new unit tests directory
llvm-svn: 201203 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This patch improves the support for picking Multilibs from gcc installations.
It also provides a better approximation for the flags '-print-multi-directory'
and '-print-multi-lib'.
review: http://llvm-reviews.chandlerc.com/D2538
llvm-svn: 201202 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Use the verify hook rather than the compile hook to represent the
-verify-pch action, and move the exising --verify-debug-info action
into its own subclass of VerifyJobAction.  Incidentally change the name
printed by -ccc-print-phases for --verify-debug-info.
llvm-svn: 200938 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This option will:
- load the given pch file
- verify it is not out of date by stat'ing dependencies, and
- return 0 on success and non-zero on error
llvm-svn: 200884 | 
| | 
| 
| 
| 
| 
| 
| | We should suggest using /Tc or /Tp to set the input type, instead of
erroneously suggesting -x, which isn't a clang-cl flag.
llvm-svn: 200362 | 
| | 
| 
| 
| 
| 
| 
| | Also make the -m16 check x86-specific. Other archs may have a different take on
things.
llvm-svn: 199755 | 
| | 
| 
| 
| | llvm-svn: 199754 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Instead of dual-purposing a single flag, rename the driver option to
--verify-debug-info.
The frontend -verify option that enables diagnostic verification remains
unchanged except that it's now a pure CC1Option.
Both have been given proper help text.
llvm-svn: 199451 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Previously we had bodged together some hacks mapping MachO embedded
targets (i.e. mainly ARM v6M and v7M) to the "*-*-darwin-eabi" triple.
This is incorrect in both details (they don't run Darwin and they're
not EABI in any real sense).
This commit appropriates the existing "MachO" environment for the
purpose instead.
llvm-svn: 199367 | 
| | 
| 
| 
| 
| 
| | Don't repeat the 32 <-> 64 architecture mapping incompletely.
llvm-svn: 198943 | 
| | 
| 
| 
| | llvm-svn: 198940 | 
| | 
| 
| 
| 
| 
| | <rdar://problem/15711488>
llvm-svn: 198722 | 
| | 
| 
| 
| 
| 
| 
| | encodes the canonical rules for LLVM's style. I noticed this had drifted
quite a bit when cleaning up LLVM, so wanted to clean up Clang as well.
llvm-svn: 198686 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This is a follow-up to r194907, which added a new -arch setting to make it
easier to specify AVX2 targets. The "-arch x86_64h" option needs to be passed
on to the linker, but it was getting canonicalized to x86_64 by the code
in getArchTypeForDarwinArchName.
llvm-svn: 198096 | 
| | 
| 
| 
| | llvm-svn: 197827 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This commit adds the flag '-via-file-asm' to the clang driver. The
purpose of this flag is to have a way to test that clang can consume
the assembly code that it outputs. When passed this flag, clang will
generate a temporary file that contains the assembly output from the
compile step. This assembly file will then be consumed by either the
integrated assembler or the external assembler. To test that the
integrated assembler can consume its own output compile with:
  $ clang -integrated-assembler -via-file-asm
Without the '-via-file-asm' flag, clang would directly create the
object file when using the integrated assembler. With the flag it
will first create the temporary assembly file and then read that
file and assemble it with the integrated assembler.
The flow is similar to -save-temps, except that it only effects
the assembly input and the temporary file is not saved.
llvm-svn: 196606 | 
| | 
| 
| 
| | llvm-svn: 196214 | 
| | 
| 
| 
| 
| 
| 
| | There are about 30 removed in this patch, generated by a new FixIt I haven't
got round to submitting yet.
llvm-svn: 195814 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is currently unused by any test. The code path would still be hit
by clang on ppc, but
* PPC has not been supported on current versions of OS X
* A port of current clang to older OS X on ppc should be using
toolchains::DarwinClang.
llvm-svn: 195585 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The thread, memory, dataflow and function sanitizers are now diagnosed if
enabled explicitly on an unsupported platform.  Unsupported sanitizers which
are enabled implicitly (as part of a larger group) are silently disabled.  As a
side effect, this makes SanitizerArgs parsing toolchain-dependent (and thus
essentially reverts r188058), and moves SanitizerArgs ownership to ToolChain.
Differential Revision: http://llvm-reviews.chandlerc.com/D1990
llvm-svn: 193875 | 
| | 
| 
| 
| | llvm-svn: 193006 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds support for outputing the assembly to a file during compilation.
It does this by changing the compilation pipeling to not use the integrated
assembler, and keep the intermediate assembler file.
Differential Revision: http://llvm-reviews.chandlerc.com/D1946
llvm-svn: 192902 | 
| | 
| 
| 
| | llvm-svn: 192437 | 
| | 
| 
| 
| | llvm-svn: 191380 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This doesn't change a lot since clang still thinks it knows all of the
-f*, -m* and -W* options for example.
Other than the options clang explicitly claims to know, this fixes pr9701.
llvm-svn: 191249 |