aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/PIC16
diff options
context:
space:
mode:
authorSanjiv Gupta <sanjiv.gupta@microchip.com>2009-07-30 04:15:15 +0000
committerSanjiv Gupta <sanjiv.gupta@microchip.com>2009-07-30 04:15:15 +0000
commite409f0a779008ad71f8ebb88431630d1d9e33a86 (patch)
tree9d66e3368f9007416fffdc37246e5ef1324594cc /lib/Target/PIC16
parent0165a2ca897598bb95baec031362921565e24f2b (diff)
downloadexternal_llvm-e409f0a779008ad71f8ebb88431630d1d9e33a86.zip
external_llvm-e409f0a779008ad71f8ebb88431630d1d9e33a86.tar.gz
external_llvm-e409f0a779008ad71f8ebb88431630d1d9e33a86.tar.bz2
Keep track of references to mem(cpy,move,set) and then print only one extern
declaration for them. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77578 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/PIC16')
-rw-r--r--lib/Target/PIC16/PIC16.h14
-rw-r--r--lib/Target/PIC16/PIC16AsmPrinter.cpp29
2 files changed, 41 insertions, 2 deletions
diff --git a/lib/Target/PIC16/PIC16.h b/lib/Target/PIC16/PIC16.h
index 447beba..09453fb 100644
--- a/lib/Target/PIC16/PIC16.h
+++ b/lib/Target/PIC16/PIC16.h
@@ -255,6 +255,20 @@ namespace PIC16CC {
return false;
}
+ // FIXME: currently we track both @memcpy and memcpy, as
+ // the first one is generated by clang, and the second one by codegen
+ // while lowering intrinsics. One we fix codegen to use RTLIB, we can
+ // have only @memcpy here.
+ inline static bool isMemIntrinsic (const std::string &Name) {
+ if (Name.compare("@memcpy") == 0 || Name.compare("memcpy") == 0 ||
+ Name.compare("@memset") == 0 || Name.compare("memset") == 0 ||
+ Name.compare("@memmove") == 0 || Name.compare("memmove") == 0) {
+ return true;
+ }
+
+ return false;
+ }
+
inline static bool isLocalToFunc (std::string &Func, std::string &Var) {
if (! isLocalName(Var)) return false;
diff --git a/lib/Target/PIC16/PIC16AsmPrinter.cpp b/lib/Target/PIC16/PIC16AsmPrinter.cpp
index 4a35a1e..743ce9f 100644
--- a/lib/Target/PIC16/PIC16AsmPrinter.cpp
+++ b/lib/Target/PIC16/PIC16AsmPrinter.cpp
@@ -137,7 +137,15 @@ void PIC16AsmPrinter::printOperand(const MachineInstr *MI, int opNum) {
return;
case MachineOperand::MO_GlobalAddress: {
- O << Mang->getMangledName(MO.getGlobal());
+ std::string Sname = Mang->getMangledName(MO.getGlobal());
+ // FIXME: currently we do not have a memcpy def coming in the module
+ // by any chance, as we do not link in those as .bc lib. So these calls
+ // are always external and it is safe to emit an extern.
+ if (PAN::isMemIntrinsic(Sname)) {
+ LibcallDecls.push_back(createESName(Sname));
+ }
+
+ O << Sname;
break;
}
case MachineOperand::MO_ExternalSymbol: {
@@ -148,7 +156,14 @@ void PIC16AsmPrinter::printOperand(const MachineInstr *MI, int opNum) {
LibcallDecls.push_back(Sname);
}
- O << Sname;
+ // Record a call to intrinsic to print the extern declaration for it.
+ std::string Sym = Sname;
+ if (PAN::isMemIntrinsic(Sym)) {
+ Sym = PAN::addPrefix(Sym);
+ LibcallDecls.push_back(createESName(Sym));
+ }
+
+ O << Sym;
break;
}
case MachineOperand::MO_MachineBasicBlock:
@@ -253,6 +268,16 @@ void PIC16AsmPrinter::EmitFunctionDecls(Module &M) {
if (!I->isDeclaration() && !I->hasExternalLinkage())
continue;
+ // Do not emit memcpy, memset, and memmove here.
+ // Calls to these routines can be generated in two ways,
+ // 1. User calling the standard lib function
+ // 2. Codegen generating these calls for llvm intrinsics.
+ // In the first case a prototype is alread availale, while in
+ // second case the call is via and externalsym and the prototype is missing.
+ // So declarations for these are currently always getting printing by
+ // tracking both kind of references in printInstrunction.
+ if (I->isDeclaration() && PAN::isMemIntrinsic(Name)) continue;
+
const char *directive = I->isDeclaration() ? TAI->getExternDirective() :
TAI->getGlobalDirective();