summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/CBackend/Writer.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-02-14 02:55:36 +0000
committerChris Lattner <sabre@nondot.org>2004-02-14 02:55:36 +0000
commitf7c1088a361f6a032294b30e048501a4b3971855 (patch)
treedcfede65035439720a45afb81b979976a233a717 /llvm/lib/Target/CBackend/Writer.cpp
parent3c4bc03c8a8e817a5a3f83cbbdc0b1f2cd2fce0d (diff)
downloadbcm5719-llvm-f7c1088a361f6a032294b30e048501a4b3971855.tar.gz
bcm5719-llvm-f7c1088a361f6a032294b30e048501a4b3971855.zip
Add support for the returnaddress and frameaddress intrinsics
llvm-svn: 11433
Diffstat (limited to 'llvm/lib/Target/CBackend/Writer.cpp')
-rw-r--r--llvm/lib/Target/CBackend/Writer.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Target/CBackend/Writer.cpp b/llvm/lib/Target/CBackend/Writer.cpp
index 493e7ec5fcc..74ed208f078 100644
--- a/llvm/lib/Target/CBackend/Writer.cpp
+++ b/llvm/lib/Target/CBackend/Writer.cpp
@@ -1157,6 +1157,8 @@ void CWriter::lowerIntrinsics(Module &M) {
case Intrinsic::va_start:
case Intrinsic::va_copy:
case Intrinsic::va_end:
+ case Intrinsic::returnaddress:
+ case Intrinsic::frameaddress:
// We directly implement these intrinsics
break;
default:
@@ -1205,6 +1207,16 @@ void CWriter::visitCallInst(CallInst &I) {
writeOperand(I.getOperand(1));
Out << ")";
return;
+ case Intrinsic::returnaddress:
+ Out << "__builtin_return_address(";
+ writeOperand(I.getOperand(1));
+ Out << ")";
+ return;
+ case Intrinsic::frameaddress:
+ Out << "__builtin_frame_address(";
+ writeOperand(I.getOperand(1));
+ Out << ")";
+ return;
}
}
visitCallSite(&I);
OpenPOWER on IntegriCloud