forked from OSchip/llvm-project
Objective C functions may use a magic '\1' on the name. Handle that when
dealing with them in the MCJIT. llvm-svn: 131601
This commit is contained in:
parent
d1b0f0f1b8
commit
b098471538
|
@ -102,7 +102,12 @@ void *MCJIT::getPointerToFunction(Function *F) {
|
|||
return Addr;
|
||||
}
|
||||
|
||||
Twine Name = TM->getMCAsmInfo()->getGlobalPrefix() + F->getName();
|
||||
// FIXME: Should we be using the mangler for this? Probably.
|
||||
StringRef BaseName = F->getName();
|
||||
if (BaseName[0] == '\1')
|
||||
BaseName = BaseName.substr(1);
|
||||
else
|
||||
Twine Name = TM->getMCAsmInfo()->getGlobalPrefix() + BaseName;
|
||||
return (void*)Dyld.getSymbolAddress(Name.str());
|
||||
}
|
||||
|
||||
|
|
|
@ -36,6 +36,11 @@ public:
|
|||
// prefix.
|
||||
if (Name[0] == '_') ++Name;
|
||||
Function *F = M->getFunction(Name);
|
||||
// Some ObjC names have a prefixed \01 in the IR. If we failed to find
|
||||
// the symbol and it's of the ObjC conventions (starts with "-"), try
|
||||
// prepending a \01 and see if we can find it that way.
|
||||
if (!F && Name[0] == '-')
|
||||
F = M->getFunction((Twine("\1") + Name).str());
|
||||
assert(F && "No matching function in JIT IR Module!");
|
||||
return JMM->startFunctionBody(F, Size);
|
||||
}
|
||||
|
@ -48,6 +53,11 @@ public:
|
|||
// prefix.
|
||||
if (Name[0] == '_') ++Name;
|
||||
Function *F = M->getFunction(Name);
|
||||
// Some ObjC names have a prefixed \01 in the IR. If we failed to find
|
||||
// the symbol and it's of the ObjC conventions (starts with "-"), try
|
||||
// prepending a \01 and see if we can find it that way.
|
||||
if (!F && Name[0] == '-')
|
||||
F = M->getFunction((Twine("\1") + Name).str());
|
||||
assert(F && "No matching function in JIT IR Module!");
|
||||
JMM->endFunctionBody(F, FunctionStart, FunctionEnd);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue