diff options
author | Bill Wendling <isanbard@gmail.com> | 2013-12-29 08:00:04 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2013-12-29 08:00:04 +0000 |
commit | c956500eb6d0ef05cd4fcde83de8a46d22dcdbaf (patch) | |
tree | 44c8ed8de69d3a57107b12ec452358ad5889e5aa /lib/Target/ARM | |
parent | 827176c80c4279ab4e924c96c0f0880d47536f4a (diff) | |
download | llvm-c956500eb6d0ef05cd4fcde83de8a46d22dcdbaf.tar.gz llvm-c956500eb6d0ef05cd4fcde83de8a46d22dcdbaf.tar.bz2 llvm-c956500eb6d0ef05cd4fcde83de8a46d22dcdbaf.tar.xz |
Store the global variable that's created so that it's reclaimed afterwards.
This plugs a memory leak in ARM's FastISel by storing the GV in Module so that
it's reclaimed.
PR17978
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@198160 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM')
-rw-r--r-- | lib/Target/ARM/ARMFastISel.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMFastISel.cpp b/lib/Target/ARM/ARMFastISel.cpp index f696113b42..845bb145e8 100644 --- a/lib/Target/ARM/ARMFastISel.cpp +++ b/lib/Target/ARM/ARMFastISel.cpp @@ -77,6 +77,7 @@ class ARMFastISel : public FastISel { /// Subtarget - Keep a pointer to the ARMSubtarget around so that we can /// make the right decision when generating code for different targets. + Module &M; const ARMSubtarget *Subtarget; const TargetMachine &TM; const TargetInstrInfo &TII; @@ -91,6 +92,7 @@ class ARMFastISel : public FastISel { explicit ARMFastISel(FunctionLoweringInfo &funcInfo, const TargetLibraryInfo *libInfo) : FastISel(funcInfo, libInfo), + M(const_cast<Module&>(*funcInfo.Fn->getParent())), TM(funcInfo.MF->getTarget()), TII(*TM.getInstrInfo()), TLI(*TM.getTargetLowering()) { @@ -2244,7 +2246,7 @@ unsigned ARMFastISel::getLibcallReg(const Twine &Name) { EVT LCREVT = TLI.getValueType(GVTy); if (!LCREVT.isSimple()) return 0; - GlobalValue *GV = new GlobalVariable(Type::getInt32Ty(*Context), false, + GlobalValue *GV = new GlobalVariable(M, Type::getInt32Ty(*Context), false, GlobalValue::ExternalLinkage, 0, Name); assert(GV->getType() == GVTy && "We miscomputed the type for the global!"); return ARMMaterializeGV(GV, LCREVT.getSimpleVT()); |