blob: 1a16746d589d3a6508509a4e28ec2071ef8029fa [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;
Richard Smith49db68d2016-10-15 01:59:52 +000093 // Disable silly GCC -Wformat warning that complains about length
94 // modifiers on ignored format specifiers. We want to retain these
95 // for documentation purposes even though they have no effect.
96#if defined(__GNUC__) && !defined(__clang__)
97#pragma GCC diagnostic push
98#pragma GCC diagnostic ignored "-Wformat"
99#endif
Richard Smithf80a27e2016-10-14 19:51:36 +0000100 if (fscanf(StatFile,
101 "%*d %*s %*c %*d %*d %*d %*d %*d %*u %*lu %*lu %*lu %*lu %*lu "
102 "%*lu %*ld %*ld %*ld %*ld %*ld %*ld %*llu %*lu %*ld %*lu %*lu "
103 "%*lu %*lu %lu %*lu %*lu %*lu %*lu %*lu %*llu %*lu %*lu %*d %*d "
104 "%*u %*u %*llu %*lu %*ld %*lu %*lu %*lu %*lu %*lu %*lu %lu %*d",
105 &StackPtr, &EnvEnd) == 2) {
Richard Smith49db68d2016-10-15 01:59:52 +0000106#if defined(__GNUC__) && !defined(__clang__)
107#pragma GCC diagnostic pop
108#endif
Richard Smithf80a27e2016-10-14 19:51:36 +0000109 Usage = StackPtr < EnvEnd ? EnvEnd - StackPtr : StackPtr - EnvEnd;
110 }
111 fclose(StatFile);
112 }
113 return Usage;
114}
115
116#include <alloca.h>
117
Richard Smith194b6a32016-08-17 01:05:07 +0000118LLVM_ATTRIBUTE_NOINLINE
Richard Smithf80a27e2016-10-14 19:51:36 +0000119static void ensureStackAddressSpace(int ExtraChunks = 0) {
Richard Smith194b6a32016-08-17 01:05:07 +0000120 // Linux kernels prior to 4.1 will sometimes locate the heap of a PIE binary
121 // relatively close to the stack (they are only guaranteed to be 128MiB
122 // apart). This results in crashes if we happen to heap-allocate more than
123 // 128MiB before we reach our stack high-water mark.
124 //
125 // To avoid these crashes, ensure that we have sufficient virtual memory
Richard Smithf80a27e2016-10-14 19:51:36 +0000126 // pages allocated before we start running.
127 size_t Curr = getCurrentStackAllocation();
128 const int kTargetStack = kSufficientStack - 256 * 1024;
129 if (Curr < kTargetStack) {
130 volatile char *volatile Alloc =
131 static_cast<volatile char *>(alloca(kTargetStack - Curr));
132 Alloc[0] = 0;
133 Alloc[kTargetStack - Curr - 1] = 0;
134 }
Richard Smith194b6a32016-08-17 01:05:07 +0000135}
136#else
137static void ensureStackAddressSpace() {}
138#endif
139
140/// Attempt to ensure that we have at least 8MiB of usable stack space.
141static void ensureSufficientStack() {
142 struct rlimit rlim;
143 if (getrlimit(RLIMIT_STACK, &rlim) != 0)
144 return;
145
146 // Increase the soft stack limit to our desired level, if necessary and
147 // possible.
148 if (rlim.rlim_cur != RLIM_INFINITY && rlim.rlim_cur < kSufficientStack) {
149 // Try to allocate sufficient stack.
150 if (rlim.rlim_max == RLIM_INFINITY || rlim.rlim_max >= kSufficientStack)
151 rlim.rlim_cur = kSufficientStack;
152 else if (rlim.rlim_cur == rlim.rlim_max)
153 return;
154 else
155 rlim.rlim_cur = rlim.rlim_max;
156
157 if (setrlimit(RLIMIT_STACK, &rlim) != 0 ||
158 rlim.rlim_cur != kSufficientStack)
159 return;
160 }
161
162 // We should now have a stack of size at least kSufficientStack. Ensure
163 // that we can actually use that much, if necessary.
164 ensureStackAddressSpace();
165}
166#else
Richard Smith525ce252016-08-17 02:22:39 +0000167static void ensureSufficientStack() {}
Richard Smith194b6a32016-08-17 01:05:07 +0000168#endif
169
Sean Silva070cd2d2014-08-15 21:38:36 +0000170int cc1_main(ArrayRef<const char *> Argv, const char *Argv0, void *MainAddr) {
Richard Smith194b6a32016-08-17 01:05:07 +0000171 ensureSufficientStack();
172
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000173 std::unique_ptr<CompilerInstance> Clang(new CompilerInstance());
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000174 IntrusiveRefCntPtr<DiagnosticIDs> DiagID(new DiagnosticIDs());
Daniel Dunbare922d9b2010-02-16 01:54:47 +0000175
Adrian Prantlfb2398d2015-07-17 01:19:54 +0000176 // Register the support for object-file-wrapped Clang modules.
177 auto PCHOps = Clang->getPCHContainerOperations();
178 PCHOps->registerWriter(llvm::make_unique<ObjectFilePCHContainerWriter>());
179 PCHOps->registerReader(llvm::make_unique<ObjectFilePCHContainerReader>());
180
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000181 // Initialize targets first, so that --version shows registered targets.
182 llvm::InitializeAllTargets();
Evan Chengc391a582011-07-22 21:59:11 +0000183 llvm::InitializeAllTargetMCs();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000184 llvm::InitializeAllAsmPrinters();
Chris Lattner61955ab2010-04-05 23:33:20 +0000185 llvm::InitializeAllAsmParsers();
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000186
Sebastian Pop17fac042014-03-14 04:04:27 +0000187#ifdef LINK_POLLY_INTO_TOOLS
188 llvm::PassRegistry &Registry = *llvm::PassRegistry::getPassRegistry();
189 polly::initializePollyPasses(Registry);
190#endif
191
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000192 // Buffer diagnostics from argument parsing so that we can output them using a
193 // well formed diagnostic object.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000194 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000195 TextDiagnosticBuffer *DiagsBuffer = new TextDiagnosticBuffer;
Douglas Gregor811db4e2012-10-23 22:26:28 +0000196 DiagnosticsEngine Diags(DiagID, &*DiagOpts, DiagsBuffer);
Sean Silva070cd2d2014-08-15 21:38:36 +0000197 bool Success = CompilerInvocation::CreateFromArgs(
198 Clang->getInvocation(), Argv.begin(), Argv.end(), Diags);
Daniel Dunbard6136772009-12-13 03:45:58 +0000199
200 // Infer the builtin include path if unspecified.
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000201 if (Clang->getHeaderSearchOpts().UseBuiltinIncludes &&
202 Clang->getHeaderSearchOpts().ResourceDir.empty())
203 Clang->getHeaderSearchOpts().ResourceDir =
Daniel Dunbara5a166d2009-12-15 00:06:45 +0000204 CompilerInvocation::GetResourcesPath(Argv0, MainAddr);
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000205
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000206 // Create the actual diagnostics engine.
Sean Silvaf1b49e22013-01-20 01:58:28 +0000207 Clang->createDiagnostics();
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000208 if (!Clang->hasDiagnostics())
209 return 1;
210
211 // Set an error handler, so that any LLVM backend diagnostics go through our
212 // error handler.
213 llvm::install_fatal_error_handler(LLVMErrorHandler,
214 static_cast<void*>(&Clang->getDiagnostics()));
215
Douglas Gregor2dd19f12010-08-18 22:29:43 +0000216 DiagsBuffer->FlushDiagnostics(Clang->getDiagnostics());
Argyrios Kyrtzidisbe6d89d2012-01-25 20:00:43 +0000217 if (!Success)
218 return 1;
Daniel Dunbar1cdf04c2010-08-12 02:53:07 +0000219
Daniel Dunbare9e91b02010-08-12 02:53:12 +0000220 // Execute the frontend actions.
Dylan Noblesmithe99b27f2011-12-23 03:05:38 +0000221 Success = ExecuteCompilerInvocation(Clang.get());
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000222
Chris Lattner09f8cc82010-03-30 05:39:52 +0000223 // If any timers were active but haven't been destroyed yet, print their
224 // results now. This happens in -disable-free mode.
225 llvm::TimerGroup::printAll(llvm::errs());
Daniel Dunbar2be96742010-08-02 15:31:28 +0000226
Dan Gohmanb37af7d2010-08-18 21:23:17 +0000227 // Our error handler depends on the Diagnostics object, which we're
228 // potentially about to delete. Uninstall the handler now so that any
229 // later errors use the default handling behavior instead.
230 llvm::remove_fatal_error_handler();
231
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000232 // When running with -disable-free, don't do any destruction or shutdown.
233 if (Clang->getFrontendOpts().DisableFree) {
David Blaikie3c13a7f2014-08-29 17:02:26 +0000234 BuryPointer(std::move(Clang));
Daniel Dunbar30b24e92010-03-23 05:09:16 +0000235 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000236 }
237
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000238 return !Success;
Daniel Dunbarf72bdf72009-12-11 22:20:12 +0000239}