]> granicus.if.org Git - clang/commitdiff
Require -pie when linking with ASan on Android.
authorEvgeniy Stepanov <eugeni.stepanov@gmail.com>
Mon, 4 Jun 2012 11:15:05 +0000 (11:15 +0000)
committerEvgeniy Stepanov <eugeni.stepanov@gmail.com>
Mon, 4 Jun 2012 11:15:05 +0000 (11:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@157923 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticDriverKinds.td
lib/Driver/Tools.cpp

index 469c8225840e4c8b548612c5b801af1c5c68dfb9..fdd3ff5881278d5f3584e7dfd0261c787b0662b5 100644 (file)
@@ -97,6 +97,8 @@ def err_arc_unsupported : Error<
   "-fobjc-arc is not supported on current deployment target">;
 def err_drv_mg_requires_m_or_mm : Error<
   "option '-MG' requires '-M' or '-MM'">;
+def err_drv_asan_android_requires_pie : Error<
+  "AddressSanitizer on Android requires '-pie'">;
 
 def warn_c_kext : Warning<
   "ignoring -fapple-kext which is valid for c++ and objective-c++ only">;
index 31626b39764e7af59501291f3d209a649194ccf9..9a157efce77e350b13d5acc0932f025086fdff46 100644 (file)
@@ -1290,6 +1290,8 @@ static void addAsanRTLinux(const ToolChain &TC, const ArgList &Args,
     return;
   if(TC.getTriple().getEnvironment() == llvm::Triple::ANDROIDEABI) {
     if (!Args.hasArg(options::OPT_shared)) {
+      if (!Args.hasArg(options::OPT_pie))
+        TC.getDriver().Diag(diag::err_drv_asan_android_requires_pie);
       // For an executable, we add a .preinit_array stub.
       CmdArgs.push_back("-u");
       CmdArgs.push_back("__asan_preinit");