diff options
author | Reid Spencer <rspencer@reidspencer.com> | 2007-01-17 23:33:20 +0000 |
---|---|---|
committer | Reid Spencer <rspencer@reidspencer.com> | 2007-01-17 23:33:20 +0000 |
commit | a10dc506c0ea79a9689101edb37b2de6c36aa188 (patch) | |
tree | e6e257890fa9168a276cfb3d6008cc02a0d8f1de | |
parent | 4cbd542dfe6e1ba221e729ce58df7526a84458e4 (diff) |
For PR1028:
Add the llvm.stacksave and llvm.stackrestore intrinsics that correspond
to the GCC builtins __builtin_stack_save and __builtin_stack_restore. This
allows the CBE to execute these builtins, and fixes:
test/CodeGen/CBackend/2007-01-17-StackSaveNRestore.ll
External/SPEC/CINT2000/176.gcc (CBE)
Patch by Gordon Henriksen.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33313 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Intrinsics.td | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/include/llvm/Intrinsics.td b/include/llvm/Intrinsics.td index 6bcbd6895f..3fc55f79da 100644 --- a/include/llvm/Intrinsics.td +++ b/include/llvm/Intrinsics.td @@ -138,8 +138,10 @@ def int_gcwrite : Intrinsic<[llvm_void_ty, llvm_ptr_ty, llvm_ptr_ty, // def int_returnaddress : Intrinsic<[llvm_ptr_ty, llvm_i32_ty], [IntrNoMem]>; def int_frameaddress : Intrinsic<[llvm_ptr_ty, llvm_i32_ty], [IntrNoMem]>; -def int_stacksave : Intrinsic<[llvm_ptr_ty], [IntrReadMem]>; -def int_stackrestore : Intrinsic<[llvm_void_ty, llvm_ptr_ty]>; +def int_stacksave : Intrinsic<[llvm_ptr_ty], [IntrReadMem]>, + GCCBuiltin<"__builtin_stack_save">; +def int_stackrestore : Intrinsic<[llvm_void_ty, llvm_ptr_ty]>, + GCCBuiltin<"__builtin_stack_restore">; def int_prefetch : Intrinsic<[llvm_void_ty, llvm_ptr_ty, llvm_i32_ty, llvm_i32_ty]>; def int_pcmarker : Intrinsic<[llvm_void_ty, llvm_i32_ty]>; |