r205144 - [PowerPC] Make -pg generate calls to _mcount not mcount

Tom Stellard tom at stellard.net
Fri Apr 11 12:46:25 PDT 2014


On Tue, Apr 08, 2014 at 06:48:21AM -0500, Hal Finkel wrote:
> Doug, Tom,
> 
> I'd like to pull this into 3.4.1.
> 

This patch has been merged.

>  -Hal
> 
> ----- Original Message -----
> > From: "Hal Finkel" <hfinkel at anl.gov>
> > To: cfe-commits at cs.uiuc.edu
> > Sent: Sunday, March 30, 2014 8:00:07 AM
> > Subject: r205144 - [PowerPC] Make -pg generate calls to _mcount not mcount
> > 
> > Author: hfinkel
> > Date: Sun Mar 30 08:00:06 2014
> > New Revision: 205144
> > 
> > URL: http://llvm.org/viewvc/llvm-project?rev=205144&view=rev
> > Log:
> > [PowerPC] Make -pg generate calls to _mcount not mcount
> > 
> > At least on REL6 (Linux/glibc 2.12), the proper symbol for generating
> > gprof
> > data is _mcount, not mcount. Prior to this change, compiling with -pg
> > would
> > generate linking errors (because of unresolved references to mcount),
> > after
> > this change -pg seems at least minimally functional.
> > 
> > Modified:
> >     cfe/trunk/lib/Basic/Targets.cpp
> >     cfe/trunk/test/CodeGen/mcount.c
> > 
> > Modified: cfe/trunk/lib/Basic/Targets.cpp
> > URL:
> > http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Basic/Targets.cpp?rev=205144&r1=205143&r2=205144&view=diff
> > ==============================================================================
> > --- cfe/trunk/lib/Basic/Targets.cpp (original)
> > +++ cfe/trunk/lib/Basic/Targets.cpp Sun Mar 30 08:00:06 2014
> > @@ -355,6 +355,16 @@ public:
> >    LinuxTargetInfo(const llvm::Triple &Triple) :
> >    OSTargetInfo<Target>(Triple) {
> >      this->UserLabelPrefix = "";
> >      this->WIntType = TargetInfo::UnsignedInt;
> > +
> > +    switch (Triple.getArch()) {
> > +    default:
> > +      break;
> > +    case llvm::Triple::ppc:
> > +    case llvm::Triple::ppc64:
> > +    case llvm::Triple::ppc64le:
> > +      this->MCountName = "_mcount";
> > +      break;
> > +    }
> >    }
> >  
> >    const char *getStaticInitSectionSpecifier() const override {
> > 
> > Modified: cfe/trunk/test/CodeGen/mcount.c
> > URL:
> > http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/mcount.c?rev=205144&r1=205143&r2=205144&view=diff
> > ==============================================================================
> > --- cfe/trunk/test/CodeGen/mcount.c (original)
> > +++ cfe/trunk/test/CodeGen/mcount.c Sun Mar 30 08:00:06 2014
> > @@ -1,4 +1,8 @@
> >  // RUN: %clang_cc1 -pg -triple i386-unknown-unknown -emit-llvm -o -
> >  %s | FileCheck %s
> > +// RUN: %clang_cc1 -pg -triple powerpc-unknown-gnu-linux -emit-llvm
> > -o - %s | FileCheck -check-prefix=CHECK-PPC %s
> > +// RUN: %clang_cc1 -pg -triple powerpc64-unknown-gnu-linux
> > -emit-llvm -o - %s | FileCheck -check-prefix=CHECK-PPC %s
> > +// RUN: %clang_cc1 -pg -triple powerpc64le-unknown-gnu-linux
> > -emit-llvm -o - %s | FileCheck -check-prefix=CHECK-PPC %s
> >  void foo(void) {
> >  // CHECK: call void @mcount()
> > +// CHECK-PPC: call void @_mcount()
> >  }
> > 
> > 
> > _______________________________________________
> > cfe-commits mailing list
> > cfe-commits at cs.uiuc.edu
> > http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
> > 
> 
> -- 
> Hal Finkel
> Assistant Computational Scientist
> Leadership Computing Facility
> Argonne National Laboratory



More information about the cfe-commits mailing list