From d3e22dfb776971f140c1b891e35fbcb08bb6faf7 Mon Sep 17 00:00:00 2001 From: Eric Christopher Date: Wed, 3 Apr 2013 01:58:53 +0000 Subject: [PATCH] From PR9121 gcc defaulted to omitting the frame pointer on linux, however, it doesn't do that unless we're optimizing. Change that and haul out to a helper function. Also make this a driver test appropriate rather than an assembly test. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@178606 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Driver/Tools.cpp | 23 +++++++++++--- test/CodeGen/frame-pointer-elim.c | 50 +++++++++++++------------------ 2 files changed, 39 insertions(+), 34 deletions(-) diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index 8699056417..5ddb95c022 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -1743,6 +1743,24 @@ static bool shouldUseFramePointer(const ArgList &Args, return true; } +static bool shouldUseLeafFramePointer(const ArgList &Args, + const llvm::Triple &Triple) { + if (Arg *A = Args.getLastArg(options::OPT_mno_omit_leaf_frame_pointer, + options::OPT_momit_leaf_frame_pointer)) + return A->getOption().matches(options::OPT_mno_omit_leaf_frame_pointer); + + // Don't use a leaf frame pointer on linux x86 and x86_64 if optimizing. + if ((Triple.getArch() == llvm::Triple::x86_64 || + Triple.getArch() == llvm::Triple::x86) && + Triple.getOS() == llvm::Triple::Linux) { + if (Arg *A = Args.getLastArg(options::OPT_O_Group)) + if (!A->getOption().matches(options::OPT_O0)) + return false; + } + + return true; +} + /// If the PWD environment variable is set, add a CC1 option to specify the /// debug compilation directory. static void addDebugCompDirArg(const ArgList &Args, ArgStringList &CmdArgs) { @@ -2319,10 +2337,7 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, CmdArgs.push_back(A->getValue()); } - // -mno-omit-leaf-frame-pointer is the default on Darwin. - if (Args.hasFlag(options::OPT_momit_leaf_frame_pointer, - options::OPT_mno_omit_leaf_frame_pointer, - !getToolChain().getTriple().isOSDarwin())) + if (!shouldUseLeafFramePointer(Args, getToolChain().getTriple())) CmdArgs.push_back("-momit-leaf-frame-pointer"); // Explicitly error on some things we know we don't support and can't just diff --git a/test/CodeGen/frame-pointer-elim.c b/test/CodeGen/frame-pointer-elim.c index b105a199f1..286cd6e61f 100644 --- a/test/CodeGen/frame-pointer-elim.c +++ b/test/CodeGen/frame-pointer-elim.c @@ -1,40 +1,30 @@ -// REQUIRES: x86-registered-target +// For these next two tests when optimized we should omit the leaf frame +// pointer, for unoptimized we should have a leaf frame pointer. +// RUN: %clang -### -target i386-pc-linux-gnu -S -O1 %s 2>&1 | \ +// RUN: FileCheck --check-prefix=LINUX-OPT %s +// LINUX-OPT: "-momit-leaf-frame-pointer" -// RUN: %clang -target i386-apple-darwin -S -o - %s | \ +// RUN: %clang -### -target i386-pc-linux-gnu -S %s 2>&1 | \ +// RUN: FileCheck --check-prefix=LINUX %s +// LINUX-NOT: "-momit-leaf-frame-pointer" + +// Darwin disables omitting the leaf frame pointer even under optimization +// unless the command lines are given. +// RUN: %clang -### -target i386-apple-darwin -S %s 2>&1 | \ // RUN: FileCheck --check-prefix=DARWIN %s -// DARWIN: f0: -// DARWIN: pushl %ebp -// DARWIN: ret -// DARWIN: f1: -// DARWIN: pushl %ebp -// DARWIN: ret +// DARWIN: "-mdisable-fp-elim" -// RUN: %clang -target i386-pc-linux-gnu -S -o - %s | \ -// RUN: FileCheck --check-prefix=LINUX %s -// LINUX: f0: -// LINUX-NOT: pushl %ebp -// LINUX: ret -// LINUX: f1: -// LINUX: pushl %ebp -// LINUX: ret +// RUN: %clang -### -target i386-apple-darwin -S -O1 %s 2>&1 | \ +// RUN: FileCheck --check-prefix=DARWIN-OPT %s +// DARWIN-OPT-NOT: "-momit-leaf-frame-pointer" -// RUN: %clang -target i386-darwin -S -o - -fomit-frame-pointer %s | \ +// RUN: %clang -### -target i386-darwin -S -fomit-frame-pointer %s 2>&1 | \ // RUN: FileCheck --check-prefix=OMIT_ALL %s -// OMIT_ALL: f0: -// OMIT_ALL-NOT: pushl %ebp -// OMIT_ALL: ret -// OMIT_ALL: f1: -// OMIT_ALL-NOT: pushl %ebp -// OMIT_ALL: ret +// OMIT_ALL-NOT: "-mdisable-fp-elim" -// RUN: %clang -target i386-darwin -S -o - -momit-leaf-frame-pointer %s | \ +// RUN: %clang -### -target i386-darwin -S -momit-leaf-frame-pointer %s 2>&1 | \ // RUN: FileCheck --check-prefix=OMIT_LEAF %s -// OMIT_LEAF: f0: -// OMIT_LEAF-NOT: pushl %ebp -// OMIT_LEAF: ret -// OMIT_LEAF: f1: -// OMIT_LEAF: pushl %ebp -// OMIT_LEAF: ret +// OMIT_LEAF: "-momit-leaf-frame-pointer" void f0() {} void f1() { f0(); } -- 2.40.0