blob: b44108e8ad289366ba85f9c3687f94abfc2120cf [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"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000018#include "clang/Driver/DriverDiagnostic.h"
Chandler Carruthcc0694c2012-12-04 09:25:21 +000019#include "clang/Driver/Options.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000020#include "clang/Frontend/CompilerInstance.h"
21#include "clang/Frontend/CompilerInvocation.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000022#include "clang/Frontend/FrontendDiagnostic.h"
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000023#include "clang/Frontend/TextDiagnosticBuffer.h"
24#include "clang/Frontend/TextDiagnosticPrinter.h"
Kostya Serebryanyce2c7262013-12-27 08:11:08 +000025#include "clang/Frontend/Utils.h"
Peter Collingbourne85dd0bd2010-08-24 00:31:22 +000026#include "clang/FrontendTool/Utils.h"
Douglas Gregor171b7802010-03-30 17:33:59 +000027#include "llvm/ADT/Statistic.h"
Richard Smith194b6a32016-08-17 01:05:07 +000028#include "llvm/Config/config.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 Smith194b6a32016-08-17 01:05:07 +000040#if HAVE_SYS_RESOURCE_H
41#include <sys/resource.h>
42#endif
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000043using namespace clang;
Reid Kleckner898229a2013-06-14 17:17:23 +000044using namespace llvm::opt;
Daniel Dunbar51cd8f02009-11-19 07:37:51 +000045
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000046//===----------------------------------------------------------------------===//
47// Main driver
48//===----------------------------------------------------------------------===//
49
Chad Rosier05c71aa2013-03-27 18:28:23 +000050static void LLVMErrorHandler(void *UserData, const std::string &Message,
51 bool GenCrashDiag) {
David Blaikie9c902b52011-09-25 23:23:43 +000052 DiagnosticsEngine &Diags = *static_cast<DiagnosticsEngine*>(UserData);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000053
54 Diags.Report(diag::err_fe_error_backend) << Message;
55
Chad Rosier7ea73972012-11-12 19:39:37 +000056 // Run the interrupt handlers to make sure any special cleanups get done, in
57 // particular that we remove files registered with RemoveFileOnSignal.
58 llvm::sys::RunInterruptHandlers();
59
Chad Rosierad6e96d2012-11-12 21:32:24 +000060 // We cannot recover from llvm errors. When reporting a fatal error, exit
Chad Rosier05c71aa2013-03-27 18:28:23 +000061 // with status 70 to generate crash diagnostics. For BSD systems this is
62 // defined as an internal software error. Otherwise, exit with status 1.
63 exit(GenCrashDiag ? 70 : 1);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +000064}
65
Sebastian Pop17fac042014-03-14 04:04:27 +000066#ifdef LINK_POLLY_INTO_TOOLS
67namespace polly {
68void initializePollyPasses(llvm::PassRegistry &Registry);
69}
70#endif
71
Richard Smith194b6a32016-08-17 01:05:07 +000072#if HAVE_SYS_RESOURCE_H && HAVE_GETRLIMIT && HAVE_SETRLIMIT
73// The amount of stack we think is "sufficient". If less than this much is
74// available, we may be unable to reach our template instantiation depth
75// limit and other similar limits.
76// FIXME: Unify this with the stack we request when spawning a thread to build
77// a module.
78static const int kSufficientStack = 8 << 20;
79
80#if defined(__linux__) && defined(__PIE__)
81LLVM_ATTRIBUTE_NOINLINE
82static void ensureStackAddressSpace() {
83 // Linux kernels prior to 4.1 will sometimes locate the heap of a PIE binary
84 // relatively close to the stack (they are only guaranteed to be 128MiB
85 // apart). This results in crashes if we happen to heap-allocate more than
86 // 128MiB before we reach our stack high-water mark.
87 //
88 // To avoid these crashes, ensure that we have sufficient virtual memory
89 // pages allocated before we start running by touching an early page. (We
90 // allow 512KiB for kernel/libc-provided data such as command-line arguments
91 // and environment variables, and for main and cc1_main)
92 volatile char ReservedStack[kSufficientStack - 512 * 1024];
93 volatile int N = 0;
94 (void)+ReservedStack[N];
95}
96#else
97static void ensureStackAddressSpace() {}
98#endif
99
100/// Attempt to ensure that we have at least 8MiB of usable stack space.
101static void ensureSufficientStack() {
102 struct rlimit rlim;
103 if (getrlimit(RLIMIT_STACK, &rlim) != 0)
104 return;
105
106 // Increase the soft stack limit to our desired level, if necessary and
107 // possible.
108 if (rlim.rlim_cur != RLIM_INFINITY && rlim.rlim_cur < kSufficientStack) {
109 // Try to allocate sufficient stack.
110 if (rlim.rlim_max == RLIM_INFINITY || rlim.rlim_max >= kSufficientStack)
111 rlim.rlim_cur = kSufficientStack;
112 else if (rlim.rlim_cur == rlim.rlim_max)
113 return;
114 else
115 rlim.rlim_cur = rlim.rlim_max;
116
117 if (setrlimit(RLIMIT_STACK, &rlim) != 0 ||
118 rlim.rlim_cur != kSufficientStack)
119 return;
120 }
121
122 // We should now have a stack of size at least kSufficientStack. Ensure
123 // that we can actually use that much, if necessary.
124 ensureStackAddressSpace();
125}
126#else
Richard Smith525ce252016-08-17 02:22:39 +0000127static void ensureSufficientStack() {}
Richard Smith194b6a32016-08-17 01:05:07 +0000128#endif
129
Sean Silva070cd2d2014-08-15 21:38:36 +0000130int cc1_main(ArrayRef<const char *> Argv, const char *Argv0, void *MainAddr) {
Richard Smith194b6a32016-08-17 01:05:07 +0000131 ensureSufficientStack();
132
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000133 std::unique_ptr<CompilerInstance> Clang(new CompilerInstance());
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000134 IntrusiveRefCntPtr<DiagnosticIDs> DiagID(new DiagnosticIDs());
Daniel Dunbare922d9b2010-02-16 01:54:47 +0000135
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000136 // Register the support for object-file-wrapped Clang modules.
137 auto PCHOps = Clang->getPCHContainerOperations();
138 PCHOps->registerWriter(llvm::make_unique<ObjectFilePCHContainerWriter>());
139 PCHOps->registerReader(llvm::make_unique<ObjectFilePCHContainerReader>());
140
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000141 // Initialize targets first, so that --version shows registered targets.
142 llvm::InitializeAllTargets();
Evan Chengc391a582011-07-22 21:59:11 +0000143 llvm::InitializeAllTargetMCs();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000144 llvm::InitializeAllAsmPrinters();
Chris Lattner61955ab2010-04-05 23:33:20 +0000145 llvm::InitializeAllAsmParsers();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000146
Sebastian Pop17fac042014-03-14 04:04:27 +0000147#ifdef LINK_POLLY_INTO_TOOLS
148 llvm::PassRegistry &Registry = *llvm::PassRegistry::getPassRegistry();
149 polly::initializePollyPasses(Registry);
150#endif
151
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000152 // Buffer diagnostics from argument parsing so that we can output them using a
153 // well formed diagnostic object.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000154 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000155 TextDiagnosticBuffer *DiagsBuffer = new TextDiagnosticBuffer;
Douglas Gregor811db4e2012-10-23 22:26:28 +0000156 DiagnosticsEngine Diags(DiagID, &*DiagOpts, DiagsBuffer);
Sean Silva070cd2d2014-08-15 21:38:36 +0000157 bool Success = CompilerInvocation::CreateFromArgs(
158 Clang->getInvocation(), Argv.begin(), Argv.end(), Diags);
Daniel Dunbard6136772009-12-13 03:45:58 +0000159
160 // Infer the builtin include path if unspecified.
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000161 if (Clang->getHeaderSearchOpts().UseBuiltinIncludes &&
162 Clang->getHeaderSearchOpts().ResourceDir.empty())
163 Clang->getHeaderSearchOpts().ResourceDir =
Daniel Dunbara5a166d2009-12-15 00:06:45 +0000164 CompilerInvocation::GetResourcesPath(Argv0, MainAddr);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000165
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000166 // Create the actual diagnostics engine.
Sean Silvaf1b49e22013-01-20 01:58:28 +0000167 Clang->createDiagnostics();
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000168 if (!Clang->hasDiagnostics())
169 return 1;
170
171 // Set an error handler, so that any LLVM backend diagnostics go through our
172 // error handler.
173 llvm::install_fatal_error_handler(LLVMErrorHandler,
174 static_cast<void*>(&Clang->getDiagnostics()));
175
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000176 DiagsBuffer->FlushDiagnostics(Clang->getDiagnostics());
Argyrios Kyrtzidisbe6d89d2012-01-25 20:00:43 +0000177 if (!Success)
178 return 1;
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000179
Daniel Dunbare9e91b02010-08-12 02:53:12 +0000180 // Execute the frontend actions.
Dylan Noblesmithe99b27f2011-12-23 03:05:38 +0000181 Success = ExecuteCompilerInvocation(Clang.get());
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000182
Chris Lattner09f8cc82010-03-30 05:39:52 +0000183 // If any timers were active but haven't been destroyed yet, print their
184 // results now. This happens in -disable-free mode.
185 llvm::TimerGroup::printAll(llvm::errs());
Daniel Dunbar2be96742010-08-02 15:31:28 +0000186
Dan Gohmanb37af7d2010-08-18 21:23:17 +0000187 // Our error handler depends on the Diagnostics object, which we're
188 // potentially about to delete. Uninstall the handler now so that any
189 // later errors use the default handling behavior instead.
190 llvm::remove_fatal_error_handler();
191
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000192 // When running with -disable-free, don't do any destruction or shutdown.
193 if (Clang->getFrontendOpts().DisableFree) {
David Blaikie3c13a7f2014-08-29 17:02:26 +0000194 BuryPointer(std::move(Clang));
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000195 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000196 }
197
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000198 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000199}