blob: 0d54278ee80bfbf0990d313c56bd51fc35be0e54 [file] [log] [blame]
Daniel Dunbar2fcaa542010-05-20 17:49:16 +00001//===-- cc1_main.cpp - Clang CC1 Compiler Frontend ------------------------===//
Daniel Dunbar51cd8f02009-11-19 07:37:51 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000010// This is the entry point to the clang -cc1 functionality, which implements the
11// core compiler functionality along with a number of additional tools for
12// demonstration and testing purposes.
Daniel Dunbar51cd8f02009-11-19 07:37:51 +000013//
14//===----------------------------------------------------------------------===//
15
Reid Kleckner898229a2013-06-14 17:17:23 +000016#include "llvm/Option/Arg.h"
Adrian Prantlbc068582015-07-08 01:00:30 +000017#include "clang/CodeGen/ObjectFilePCHContainerOperations.h"
Chris Bienemana6b39ab2016-08-23 20:07:07 +000018#include "clang/Config/config.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000019#include "clang/Driver/DriverDiagnostic.h"
Chandler Carruthcc0694c2012-12-04 09:25:21 +000020#include "clang/Driver/Options.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000021#include "clang/Frontend/CompilerInstance.h"
22#include "clang/Frontend/CompilerInvocation.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000023#include "clang/Frontend/FrontendDiagnostic.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000024#include "clang/Frontend/TextDiagnosticBuffer.h"
25#include "clang/Frontend/TextDiagnosticPrinter.h"
Kostya Serebryanyce2c7262013-12-27 08:11:08 +000026#include "clang/Frontend/Utils.h"
Peter Collingbourne85dd0bd2010-08-24 00:31:22 +000027#include "clang/FrontendTool/Utils.h"
Douglas Gregor171b7802010-03-30 17:33:59 +000028#include "llvm/ADT/Statistic.h"
Chandler Carruthcc0694c2012-12-04 09:25:21 +000029#include "llvm/LinkAllPasses.h"
Reid Kleckner898229a2013-06-14 17:17:23 +000030#include "llvm/Option/ArgList.h"
31#include "llvm/Option/OptTable.h"
Richard Smith194b6a32016-08-17 01:05:07 +000032#include "llvm/Support/Compiler.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000033#include "llvm/Support/ErrorHandling.h"
34#include "llvm/Support/ManagedStatic.h"
Chad Rosier7ea73972012-11-12 19:39:37 +000035#include "llvm/Support/Signals.h"
Evan Cheng494eb062011-08-24 18:09:14 +000036#include "llvm/Support/TargetSelect.h"
Chris Lattner09f8cc82010-03-30 05:39:52 +000037#include "llvm/Support/Timer.h"
Daniel Dunbar51cd8f02009-11-19 07:37:51 +000038#include "llvm/Support/raw_ostream.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000039#include <cstdio>
Richard Smithc33b8372016-08-18 18:22:22 +000040
Chris Bienemana6b39ab2016-08-23 20:07:07 +000041#ifdef CLANG_HAVE_RLIMITS
Richard Smith194b6a32016-08-17 01:05:07 +000042#include <sys/resource.h>
43#endif
Richard Smithc33b8372016-08-18 18:22:22 +000044
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000045using namespace clang;
Reid Kleckner898229a2013-06-14 17:17:23 +000046using namespace llvm::opt;
Daniel Dunbar51cd8f02009-11-19 07:37:51 +000047
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000048//===----------------------------------------------------------------------===//
49// Main driver
50//===----------------------------------------------------------------------===//
51
Chad Rosier05c71aa2013-03-27 18:28:23 +000052static void LLVMErrorHandler(void *UserData, const std::string &Message,
53 bool GenCrashDiag) {
David Blaikie9c902b52011-09-25 23:23:43 +000054 DiagnosticsEngine &Diags = *static_cast<DiagnosticsEngine*>(UserData);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000055
56 Diags.Report(diag::err_fe_error_backend) << Message;
57
Chad Rosier7ea73972012-11-12 19:39:37 +000058 // Run the interrupt handlers to make sure any special cleanups get done, in
59 // particular that we remove files registered with RemoveFileOnSignal.
60 llvm::sys::RunInterruptHandlers();
61
Chad Rosierad6e96d2012-11-12 21:32:24 +000062 // We cannot recover from llvm errors. When reporting a fatal error, exit
Chad Rosier05c71aa2013-03-27 18:28:23 +000063 // with status 70 to generate crash diagnostics. For BSD systems this is
64 // defined as an internal software error. Otherwise, exit with status 1.
65 exit(GenCrashDiag ? 70 : 1);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000066}
67
Sebastian Pop17fac042014-03-14 04:04:27 +000068#ifdef LINK_POLLY_INTO_TOOLS
69namespace polly {
70void initializePollyPasses(llvm::PassRegistry &Registry);
71}
72#endif
73
Chris Bienemana6b39ab2016-08-23 20:07:07 +000074#ifdef CLANG_HAVE_RLIMITS
Richard Smith194b6a32016-08-17 01:05:07 +000075// The amount of stack we think is "sufficient". If less than this much is
76// available, we may be unable to reach our template instantiation depth
77// limit and other similar limits.
78// FIXME: Unify this with the stack we request when spawning a thread to build
79// a module.
80static const int kSufficientStack = 8 << 20;
81
82#if defined(__linux__) && defined(__PIE__)
Richard Smithf80a27e2016-10-14 19:51:36 +000083static size_t getCurrentStackAllocation() {
84 // If we can't compute the current stack usage, allow for 512K of command
85 // line arguments and environment.
86 size_t Usage = 512 * 1024;
87 if (FILE *StatFile = fopen("/proc/self/stat", "r")) {
88 // We assume that the stack extends from its current address to the end of
89 // the environment space. In reality, there is another string literal (the
90 // program name) after the environment, but this is close enough (we only
91 // need to be within 100K or so).
92 unsigned long StackPtr, EnvEnd;
93 if (fscanf(StatFile,
94 "%*d %*s %*c %*d %*d %*d %*d %*d %*u %*lu %*lu %*lu %*lu %*lu "
95 "%*lu %*ld %*ld %*ld %*ld %*ld %*ld %*llu %*lu %*ld %*lu %*lu "
96 "%*lu %*lu %lu %*lu %*lu %*lu %*lu %*lu %*llu %*lu %*lu %*d %*d "
97 "%*u %*u %*llu %*lu %*ld %*lu %*lu %*lu %*lu %*lu %*lu %lu %*d",
98 &StackPtr, &EnvEnd) == 2) {
99 Usage = StackPtr < EnvEnd ? EnvEnd - StackPtr : StackPtr - EnvEnd;
100 }
101 fclose(StatFile);
102 }
103 return Usage;
104}
105
106#include <alloca.h>
107
Richard Smith194b6a32016-08-17 01:05:07 +0000108LLVM_ATTRIBUTE_NOINLINE
Richard Smithf80a27e2016-10-14 19:51:36 +0000109static void ensureStackAddressSpace(int ExtraChunks = 0) {
Richard Smith194b6a32016-08-17 01:05:07 +0000110 // Linux kernels prior to 4.1 will sometimes locate the heap of a PIE binary
111 // relatively close to the stack (they are only guaranteed to be 128MiB
112 // apart). This results in crashes if we happen to heap-allocate more than
113 // 128MiB before we reach our stack high-water mark.
114 //
115 // To avoid these crashes, ensure that we have sufficient virtual memory
Richard Smithf80a27e2016-10-14 19:51:36 +0000116 // pages allocated before we start running.
117 size_t Curr = getCurrentStackAllocation();
118 const int kTargetStack = kSufficientStack - 256 * 1024;
119 if (Curr < kTargetStack) {
120 volatile char *volatile Alloc =
121 static_cast<volatile char *>(alloca(kTargetStack - Curr));
122 Alloc[0] = 0;
123 Alloc[kTargetStack - Curr - 1] = 0;
124 }
Richard Smith194b6a32016-08-17 01:05:07 +0000125}
126#else
127static void ensureStackAddressSpace() {}
128#endif
129
130/// Attempt to ensure that we have at least 8MiB of usable stack space.
131static void ensureSufficientStack() {
132 struct rlimit rlim;
133 if (getrlimit(RLIMIT_STACK, &rlim) != 0)
134 return;
135
136 // Increase the soft stack limit to our desired level, if necessary and
137 // possible.
138 if (rlim.rlim_cur != RLIM_INFINITY && rlim.rlim_cur < kSufficientStack) {
139 // Try to allocate sufficient stack.
140 if (rlim.rlim_max == RLIM_INFINITY || rlim.rlim_max >= kSufficientStack)
141 rlim.rlim_cur = kSufficientStack;
142 else if (rlim.rlim_cur == rlim.rlim_max)
143 return;
144 else
145 rlim.rlim_cur = rlim.rlim_max;
146
147 if (setrlimit(RLIMIT_STACK, &rlim) != 0 ||
148 rlim.rlim_cur != kSufficientStack)
149 return;
150 }
151
152 // We should now have a stack of size at least kSufficientStack. Ensure
153 // that we can actually use that much, if necessary.
154 ensureStackAddressSpace();
155}
156#else
Richard Smith525ce252016-08-17 02:22:39 +0000157static void ensureSufficientStack() {}
Richard Smith194b6a32016-08-17 01:05:07 +0000158#endif
159
Sean Silva070cd2d2014-08-15 21:38:36 +0000160int cc1_main(ArrayRef<const char *> Argv, const char *Argv0, void *MainAddr) {
Richard Smith194b6a32016-08-17 01:05:07 +0000161 ensureSufficientStack();
162
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000163 std::unique_ptr<CompilerInstance> Clang(new CompilerInstance());
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000164 IntrusiveRefCntPtr<DiagnosticIDs> DiagID(new DiagnosticIDs());
Daniel Dunbare922d9b2010-02-16 01:54:47 +0000165
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000166 // Register the support for object-file-wrapped Clang modules.
167 auto PCHOps = Clang->getPCHContainerOperations();
168 PCHOps->registerWriter(llvm::make_unique<ObjectFilePCHContainerWriter>());
169 PCHOps->registerReader(llvm::make_unique<ObjectFilePCHContainerReader>());
170
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000171 // Initialize targets first, so that --version shows registered targets.
172 llvm::InitializeAllTargets();
Evan Chengc391a582011-07-22 21:59:11 +0000173 llvm::InitializeAllTargetMCs();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000174 llvm::InitializeAllAsmPrinters();
Chris Lattner61955ab2010-04-05 23:33:20 +0000175 llvm::InitializeAllAsmParsers();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000176
Sebastian Pop17fac042014-03-14 04:04:27 +0000177#ifdef LINK_POLLY_INTO_TOOLS
178 llvm::PassRegistry &Registry = *llvm::PassRegistry::getPassRegistry();
179 polly::initializePollyPasses(Registry);
180#endif
181
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000182 // Buffer diagnostics from argument parsing so that we can output them using a
183 // well formed diagnostic object.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000184 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000185 TextDiagnosticBuffer *DiagsBuffer = new TextDiagnosticBuffer;
Douglas Gregor811db4e2012-10-23 22:26:28 +0000186 DiagnosticsEngine Diags(DiagID, &*DiagOpts, DiagsBuffer);
Sean Silva070cd2d2014-08-15 21:38:36 +0000187 bool Success = CompilerInvocation::CreateFromArgs(
188 Clang->getInvocation(), Argv.begin(), Argv.end(), Diags);
Daniel Dunbard6136772009-12-13 03:45:58 +0000189
190 // Infer the builtin include path if unspecified.
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000191 if (Clang->getHeaderSearchOpts().UseBuiltinIncludes &&
192 Clang->getHeaderSearchOpts().ResourceDir.empty())
193 Clang->getHeaderSearchOpts().ResourceDir =
Daniel Dunbara5a166d2009-12-15 00:06:45 +0000194 CompilerInvocation::GetResourcesPath(Argv0, MainAddr);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000195
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000196 // Create the actual diagnostics engine.
Sean Silvaf1b49e22013-01-20 01:58:28 +0000197 Clang->createDiagnostics();
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000198 if (!Clang->hasDiagnostics())
199 return 1;
200
201 // Set an error handler, so that any LLVM backend diagnostics go through our
202 // error handler.
203 llvm::install_fatal_error_handler(LLVMErrorHandler,
204 static_cast<void*>(&Clang->getDiagnostics()));
205
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000206 DiagsBuffer->FlushDiagnostics(Clang->getDiagnostics());
Argyrios Kyrtzidisbe6d89d2012-01-25 20:00:43 +0000207 if (!Success)
208 return 1;
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000209
Daniel Dunbare9e91b02010-08-12 02:53:12 +0000210 // Execute the frontend actions.
Dylan Noblesmithe99b27f2011-12-23 03:05:38 +0000211 Success = ExecuteCompilerInvocation(Clang.get());
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000212
Chris Lattner09f8cc82010-03-30 05:39:52 +0000213 // If any timers were active but haven't been destroyed yet, print their
214 // results now. This happens in -disable-free mode.
215 llvm::TimerGroup::printAll(llvm::errs());
Daniel Dunbar2be96742010-08-02 15:31:28 +0000216
Dan Gohmanb37af7d2010-08-18 21:23:17 +0000217 // Our error handler depends on the Diagnostics object, which we're
218 // potentially about to delete. Uninstall the handler now so that any
219 // later errors use the default handling behavior instead.
220 llvm::remove_fatal_error_handler();
221
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000222 // When running with -disable-free, don't do any destruction or shutdown.
223 if (Clang->getFrontendOpts().DisableFree) {
David Blaikie3c13a7f2014-08-29 17:02:26 +0000224 BuryPointer(std::move(Clang));
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000225 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000226 }
227
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000228 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000229}