From: Renato Golin Date: Sat, 24 Aug 2013 14:44:35 +0000 (+0000) Subject: Add the -ffixed-r9 flag for ARM. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=45bd2946df2ff7460b7daf06a4fe34de8a58b8cf;p=clang Add the -ffixed-r9 flag for ARM. This patch adds the -ffixed-r9 flag to clang to instruct llvm to globally preserve the contents of r9. The flag is added to the newly created ARM specific group. While at it, also place marm / mno-thumb in that group. Patch by Jeroen Hofstee. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@189174 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Driver/Options.td b/include/clang/Driver/Options.td index 33a14a4b1b..24759ceffe 100644 --- a/include/clang/Driver/Options.td +++ b/include/clang/Driver/Options.td @@ -72,6 +72,7 @@ def clang_i_Group : OptionGroup<"">, Group; def m_Group : OptionGroup<"">, Group; def m_x86_Features_Group : OptionGroup<"">, Group; def m_hexagon_Features_Group : OptionGroup<"">, Group; +def m_arm_Features_Group : OptionGroup<"">, Group; def opencl_Group : OptionGroup<"">; def u_Group : OptionGroup<"">; def mips_CPUs_Group : OptionGroup<"">, @@ -986,8 +987,10 @@ def mno_rtm : Flag<["-"], "mno-rtm">, Group; def mno_prfchw : Flag<["-"], "mno-prfchw">, Group; def mno_rdseed : Flag<["-"], "mno-rdseed">, Group; -def mno_thumb : Flag<["-"], "mno-thumb">, Group; +def mno_thumb : Flag<["-"], "mno-thumb">, Group; def marm : Flag<["-"], "marm">, Alias; +def ffixed_r9 : Flag<["-"], "ffixed-r9">, Group, + HelpText<"Reserve the r9 register (ARM only)">; def mno_warn_nonportable_cfstrings : Flag<["-"], "mno-warn-nonportable-cfstrings">, Group; def mno_omit_leaf_frame_pointer : Flag<["-"], "mno-omit-leaf-frame-pointer">, Group; diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 25be6b48b6..71cbcb292f 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -795,6 +795,14 @@ void Clang::AddARMTargetArgs(const ArgList &Args, options::OPT_mno_implicit_float, true)) CmdArgs.push_back("-no-implicit-float"); + + // llvm does not support reserving registers in general. There is support + // for reserving r9 on ARM though (defined as a platform-specific register + // in ARM EABI). + if (Args.hasArg(options::OPT_ffixed_r9)) { + CmdArgs.push_back("-backend-option"); + CmdArgs.push_back("-arm-reserve-r9"); + } } // Translate MIPS CPU name alias option to CPU name.