2008-03-01 15:38:40 +08:00
|
|
|
; RUN: llvm-as < %s | llvm-dis > %t1.ll
|
2005-05-07 06:33:44 +08:00
|
|
|
; RUN: llvm-as %t1.ll -o - | llvm-dis > %t2.ll
|
|
|
|
; RUN: diff %t1.ll %t2.ll
|
|
|
|
|
2008-03-01 15:38:40 +08:00
|
|
|
define fastcc void @foo() {
|
|
|
|
ret void
|
2005-05-07 06:33:44 +08:00
|
|
|
}
|
|
|
|
|
2008-03-01 15:38:40 +08:00
|
|
|
define coldcc void @bar() {
|
|
|
|
call fastcc void @foo( )
|
|
|
|
ret void
|
2005-05-07 06:33:44 +08:00
|
|
|
}
|
|
|
|
|
2020-11-21 03:07:11 +08:00
|
|
|
define void @structret({ i8 }* sret({ i8 }) %P) {
|
|
|
|
call void @structret( { i8 }* sret({ i8 }) %P )
|
2008-03-01 15:38:40 +08:00
|
|
|
ret void
|
2006-05-20 06:00:54 +08:00
|
|
|
}
|
|
|
|
|
2008-03-01 15:38:40 +08:00
|
|
|
define void @foo2() {
|
|
|
|
ret void
|
2005-05-07 06:33:44 +08:00
|
|
|
}
|
|
|
|
|
2008-03-01 15:38:40 +08:00
|
|
|
define coldcc void @bar2() {
|
|
|
|
call fastcc void @foo( )
|
|
|
|
ret void
|
2005-05-07 06:33:44 +08:00
|
|
|
}
|
|
|
|
|
2015-06-18 04:52:32 +08:00
|
|
|
define cc42 void @bar3() personality i32 (...)* @__gxx_personality_v0 {
|
2011-08-25 09:30:18 +08:00
|
|
|
invoke fastcc void @foo( )
|
|
|
|
to label %Ok unwind label %U
|
2005-05-07 06:33:44 +08:00
|
|
|
|
2011-08-25 09:30:18 +08:00
|
|
|
Ok:
|
|
|
|
ret void
|
2005-05-07 06:33:44 +08:00
|
|
|
|
2011-08-25 09:30:18 +08:00
|
|
|
U:
|
2015-06-18 04:52:32 +08:00
|
|
|
%exn = landingpad {i8*, i32}
|
2011-08-25 09:30:18 +08:00
|
|
|
cleanup
|
|
|
|
resume { i8*, i32 } %exn
|
2005-05-07 06:33:44 +08:00
|
|
|
}
|
|
|
|
|
2015-06-18 04:52:32 +08:00
|
|
|
define void @bar4() personality i32 (...)* @__gxx_personality_v0 {
|
2011-08-25 09:30:18 +08:00
|
|
|
call cc42 void @bar( )
|
|
|
|
invoke cc42 void @bar3( )
|
|
|
|
to label %Ok unwind label %U
|
2008-03-01 15:38:40 +08:00
|
|
|
|
2011-08-25 09:30:18 +08:00
|
|
|
Ok:
|
|
|
|
ret void
|
2008-03-01 15:38:40 +08:00
|
|
|
|
2011-08-25 09:30:18 +08:00
|
|
|
U:
|
2015-06-18 04:52:32 +08:00
|
|
|
%exn = landingpad {i8*, i32}
|
2011-08-25 09:30:18 +08:00
|
|
|
cleanup
|
|
|
|
resume { i8*, i32 } %exn
|
2008-03-01 15:38:40 +08:00
|
|
|
}
|
2005-05-07 06:33:44 +08:00
|
|
|
|
2014-12-02 05:04:44 +08:00
|
|
|
declare ghccc void @ghc_callee()
|
|
|
|
|
|
|
|
define void @ghc_caller() {
|
|
|
|
call ghccc void @ghc_callee()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
HHVM calling conventions.
HHVM calling convention, hhvmcc, is used by HHVM JIT for
functions in translated cache. We currently support LLVM back end to
generate code for X86-64 and may support other architectures in the
future.
In HHVM calling convention any GP register could be used to pass and
return values, with the exception of R12 which is reserved for
thread-local area and is callee-saved. Other than R12, we always
pass RBX and RBP as args, which are our virtual machine's stack pointer
and frame pointer respectively.
When we enter translation cache via hhvmcc function, we expect
the stack to be aligned at 16 bytes, i.e. skewed by 8 bytes as opposed
to standard ABI alignment. This affects stack object alignment and stack
adjustments for function calls.
One extra calling convention, hhvm_ccc, is used to call C++ helpers from
HHVM's translation cache. It is almost identical to standard C calling
convention with an exception of first argument which is passed in RBP
(before we use RDI, RSI, etc.)
Differential Revision: http://reviews.llvm.org/D12681
llvm-svn: 248832
2015-09-30 06:09:16 +08:00
|
|
|
declare hhvm_ccc void @hhvm_c_callee()
|
|
|
|
|
|
|
|
define hhvmcc void @hhvm_caller() {
|
|
|
|
call hhvm_ccc void @hhvm_c_callee()
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2011-08-25 09:30:18 +08:00
|
|
|
declare i32 @__gxx_personality_v0(...)
|