Commit graph

123 commits

Author SHA1 Message Date
Martin
d01a91f755 Allow multiple occurrences for almost all command-line flags
Except for `-sanitize` and `-cache-prune*`.
2017-05-23 20:53:57 +02:00
Adrian Matoga
aafd6541c7 Add switch '-Xcc <ccflag>'. Fix #2093. (#2104) 2017-05-16 20:23:02 +02:00
Martin
a38cae7831 MSVC: Remove useless (and disabled) /LTCG linker flag
`global.params.optimize` is never changed from its initial `false` state.
When experimentally enabling it, the MS linker produces warnings like

LINK : /LTCG specified but no code generation required; remove /LTCG from
the link command line to improve linker performance
2017-05-12 23:40:07 +02:00
kinke
a5139499a3 Add -mscrtlib cmdline option and support -static on Windows (#2041)
The default MS C runtime library doesn't depend on the `LINK_WITH_MSVCRT`
CMake variable anymore.

The user can freely choose among the 4 variants libcmt[d] / msvcrt[d] via
-mscrtlib or choose between static/dynamic release variant via -static.

LDC keeps on defaulting to the static release C runtime, so
`-static=false` or `-mscrtlib=msvcrt[d]` must be used explicitly in order
to link against the runtime DLLs.
2017-04-09 01:17:28 +02:00
Martin
ab85d209ab Don't set up MSVC environment *after* locating tools
And warn if no Visual C++ installation is detected, similar to the now
suppressed warning issued by the batch file.
2017-03-14 00:40:52 +01:00
Martin
1c70b12e4c Slightly refactor module driver/tool
And get rid of redundant cmdline option -archiver.
2017-03-13 23:51:16 +01:00
Martin
95c1d38e2e Integrate module gen/programs into driver/tool 2017-03-13 23:31:32 +01:00
Martin
0842277572 Move MSVC environment setup to driver/tool.cpp [NFC] 2017-03-13 23:03:33 +01:00
Martin
cab165f3d8 Set up the MSVC environment in a more flexible way
For invoking MS tools such as link.exe and lib.exe, which require
compatible PATH, LIB, LIBPATH etc.

We previously wrapped the invokation of the tool with a batch file taking
care of setting up the environment and then calling the actual tool.

I changed this to first invoke another batch file setting up its
environment and then dumping all environment variables to a file. LDC then
parses this file and updates its own environment variables. Later spawned
child processes then inherit the updated environment, and the tools will
be located by LLVM in updated PATH.

This allows LDC to keep track of the used Visual C++ installation (and
could so set up additional runtime libs required since VS 2015, something
we would have needed some time back when we still supported VS 2013). It's
also required as a prerequisite for integrating LLD as in-process linker
on Windows.

I quickly looked into the option of setting up the environment manually,
but the MS batch files are full of quirks, mixtures of registry and
file-system lookups, checking for existence of misc. headers to filter out
bogus installations etc. With VS 2017, there's nothing in the registry at
all anymore (at least for the Build Tools); MS expose a COM interface for
querying the VS installer... But at least they still provide the batch
files.
2017-03-13 00:36:45 +01:00
Martin
ad3294b3ae Enable cross-static-lib generation for LLVM 3.9+
By directly integrating LLVM's `llvm-lib.exe` driver to generate static
libs for MSVC targets and a stripped-down version of the `llvm-ar` tool
for the other targets.

Introduce command-line option `-archiver=<file>` to allow the user to
specify an external archiver to be invoked.
2017-03-12 03:56:46 +01:00
Martin
7fc885e59f Append default file extension for LDMD only 2017-03-08 19:47:04 +01:00
Martin
9a1c4adbbc Add hidden -ldmd option when invoking LDC via LDMD
Thus providing a generic way to slightly alter some command-line semantics
in DMD compatibility mode.
2017-03-08 19:47:04 +01:00
Martin
5f8cae7b34 Append default file extension if -of doesn't contain any
Resolves issue #2001.
2017-03-08 19:47:04 +01:00
Martin
505a01b278 Forward -L linker args starting with -Wl, to gcc driver 2016-12-04 17:39:52 +01:00
Johan Engelen
56b62b2208 LTO: add extra search locations for the LLVMgold.so plugin. 2016-11-30 17:30:37 +01:00
Johan Engelen
3b59879a45 Allow user to specify LTO plugin file. 2016-11-28 19:28:20 +01:00
Johan Engelen
788add6155 Revert "Move the LTO plugin to the bin dir."
This reverts commit 23a677d001.
2016-11-28 13:58:09 +01:00
Johan Engelen
23a677d001 Move the LTO plugin to the bin dir. 2016-11-27 19:34:08 +01:00
Johan Engelen
d4f5b8ab6c Suffix the LTO plugin packaged with LDC with "-ldc", to prevent installation conflicts. 2016-11-27 17:42:42 +01:00
Rainer Schuetze
27c395caa9 fix issue 1876: passing /LARGEADDRESSAWARE:NO is a workaround for DWARF debug info, it causes trouble with CodeView debug info 2016-11-13 14:37:38 +01:00
Johan Engelen
bb24fb2816 Add LTO support (full and thin), with -flto=thin|full.
LTO needs linker support: I am only aware of support on OS X and Linux (through the LLVMgold plugin).

Resolves #693
2016-11-09 14:30:13 +01:00
Martin
8276269ab1 Create static libs in -od directory for LDMD only
Let LDC treat relative output paths as relative to the current working
directory again (as it always used to until a few weeks ago). It's more
intuitive and avoids breaking build systems/scripts using LDC directly.

Only LDMD continues to prepend the -od directory to the relative output
path, for DMD compatibility.

Fixes issue #1819.
2016-10-14 21:47:27 +02:00
Martin
a8c6293865 Create output directories recursively
Fixes issue #1819.
2016-10-09 23:21:35 +02:00
Martin
8f2665d7bb Windows: Support .res and .def files in command-line 2016-09-27 01:34:05 +02:00
Martin
b1a6315ee4 Don't reverse order of object file names
Make sure the overall order corresponds to the user's command-line order
of object and source files. The only exception being singleObj builds,
for which the single object file for all source files is always the first
entry in the object files list (which is forwarded to the linker in that
order). This is done so that we can easily get hold of the name when
emitting the single object file later in the `ldc::CodeGenerator` dtor.
It should also clearly define the linking order (affecting comdat
selections etc.) for special singleObj builds.

Also reuse some more code (wrt. output filenames) from DMD's main().
2016-09-27 01:34:05 +02:00
Martin
d85986be3d Infer output names from first object file alone (ignore root module) 2016-09-07 09:53:35 +02:00
Martin
6c03a3d725 Streamline output filenames and -singleObj behavior some more with DMD 2016-09-07 09:53:35 +02:00
Martin
aed881350a Refactor output filename generation/validation 2016-09-07 09:53:35 +02:00
Martin
24cecc268c Streamline main() with DMD's (ddmd/mars.d) 2016-08-27 20:40:26 +02:00
kinke
dbc9733a05 Merge pull request #1649 from JohanEngelen/warningfix1
Fix a few clang warnings [NFC]
2016-07-28 00:46:53 +02:00
Johan Engelen
c6ba2dc29b Fix a few clang warnings. [NFC] 2016-07-27 20:21:02 +02:00
Johan Engelen
0fcd50fb0d Do the check that gExePath is not a directory (before deleting it) also in release builds. 2016-07-27 19:47:51 +02:00
Rainer Schuetze
9f85baee90 use *W-functions if UNICODE #defined on windows 2016-06-28 08:29:49 +02:00
Johan Engelen
33a54a9900 [PGO] Fix ldc-profile-rt.lib linking on Windows. 2016-06-20 17:28:35 +02:00
Johan Engelen
20c9f3fbec [PGO] Fix profile-rt linking: put it before Phobos. 2016-06-20 17:28:32 +02:00
Johan Engelen
e0d9c58443 [PGO] Add PGO to LDC. Supported for LLVM >= 3.7
Add the commandline options -fprofile-instr-generate[=filename] and -profile-instr-use=filename
-fprofile-instr-generate
-- Add instrumentation on branches, switches, and function entry; uses LLVM's InstrProf pass.
-- Link to profile runtime that writes instrumentation counters to a file.
-fprofile-instr-use
-- Read profile data from a file and apply branch weights to branches and switches, and annotate functions with entrycount in LLVM IR.
-- Functions with low or high entrycount are marked with 'cold' or 'inlinehint'.

The only statement type without PGO yet is "try-finally".

A new pragma, `pragma(LDC_profile_instr, [ true | false ])`, is added to selectively disable/enable instrumentation of functions (granularity = whole functions).

The runtime library ldc-profile-rt is a copy of LLVM compiler-rt lib/profile. It has to be exactly in-sync with the LLVM version, and thus we need a copy for each PGO-supported LLVM (>=3.7).
import ldc.profile for a D interface to ldc-profile-rt (for example to reset execution counts after a program startup phase).

The instrumentation data is mainly passed on to LLVM: function-entry counts and branch counts/probabilities. LDC marks functions as hot when "execution count is 30% of the maximum function execution count", and marks functions as cold if their count is 1% of maximum function execution count.

The source of LLVM's llvm-profdata tool is hereby included in LDCs repository (different source for each LLVM version), and the binary is included in the install bin folder.
The executable is named "ldc-profdata" to avoid clashing with llvm-profdata on the same machine. This is needed because profdata executable has to be in-sync with the LLVM version used to build LDC.

Maintenance burden: for trunk LLVM, we have to keep ldc-profile-rt and llvm-profdata in sync. There is no diff with upstream; but because of active development there are the occasional API changes.
2016-06-20 17:28:22 +02:00
Johan Engelen
ef91385223 Making bitcode file argument errors fatal. 2016-06-10 12:47:46 +02:00
Johan Engelen
404d483c2a Bitcode cmd arguments: fix compilation for LLVM < 3.8, and disable for LLVM 3.5. 2016-06-10 12:43:31 +02:00
Johan Engelen
d9b267a4be Accept LLVM bitcode files (*.bc) on the commandline and add the code to the first source file on the cmdline (the first emitted module). 2016-06-05 16:07:14 +02:00
Johan Engelen
4515033381 Merge pull request #1470 from JohanEngelen/random_file
Use random output filenames for `-run`.
2016-05-10 13:08:18 +02:00
Johan Engelen
ac23473525 Use random output filenames for -run.
The temporary files created should be unique for parallel processes (e.g. in a test suite where LDC is called in parallel with perhaps same input).
These files will be deleted after execution so their name is not relevant. For better linking errors, the new filenames are created by appending random characters to their name.
2016-05-09 20:14:00 +02:00
Kai Nacke
0b2d7e7969 Merge remote-tracking branch 'origin/ltsmaster' 2016-04-30 16:35:00 -04:00
Kai Nacke
1cfb6d46ee Do not use -Xlinker for linker options starting with -shared or -static.
This is part of fixing the CMAKE_EXE_LINKER_FLAGS problem of the 1.0 build.
2016-04-30 16:11:02 +02:00
Kai Nacke
ee8c6b106b Fix merge errors 2016-04-23 14:58:39 +02:00
Kai Nacke
e55823fd09 Merge remote-tracking branch 'origin/ltsmaster' 2016-04-23 11:19:20 +02:00
Joakim
ee8a832c49 Add a handful of fixes for Android 2016-04-19 22:09:14 +05:30
Kai Nacke
d4dc52d4aa Fix compile errors caused by D frontend
- scope is now _scope
- targetTriple requires -> instead of .
- factory method createTypeIdentifier() instead of new TypeIdentifier()
2016-03-03 21:41:46 +01:00
Kai Nacke
24adf155ff Revert "Revert "Merge branch 'ltsmaster'""
This reverts commit 1653911600.
2016-03-03 21:12:53 +01:00
Kai Nacke
1653911600 Revert "Merge branch 'ltsmaster'"
This reverts commit dcb781004b, reversing
changes made to 3c6f09faf0.
2016-03-03 13:14:39 +01:00
Kai Nacke
dcb781004b Merge branch 'ltsmaster' 2016-03-03 07:50:17 +01:00