diff options
author | Sander de Smalen <sander.desmalen@arm.com> | 2019-06-13 08:19:33 +0000 |
---|---|---|
committer | Sander de Smalen <sander.desmalen@arm.com> | 2019-06-13 08:19:33 +0000 |
commit | 7957fc6547e1b8af8e6586e2c25446b724eabb75 (patch) | |
tree | dec114bbf1ff2c4f035809383388b433c773a48e /llvm/lib/CodeGen/MachineFunction.cpp | |
parent | 02eac87ba3e60ae5f576a38cbe00e435a4d5a4a6 (diff) | |
download | llvm-7957fc6547e1b8af8e6586e2c25446b724eabb75.zip llvm-7957fc6547e1b8af8e6586e2c25446b724eabb75.tar.gz llvm-7957fc6547e1b8af8e6586e2c25446b724eabb75.tar.bz2 |
[IntrinsicEmitter] Extend argument overloading with forward references.
Extend the mechanism to overload intrinsic arguments by using either
backward or forward references to the overloadable arguments.
In for example:
def int_something : Intrinsic<[LLVMPointerToElt<0>],
[llvm_anyvector_ty], []>;
LLVMPointerToElt<0> is a forward reference to the overloadable operand
of type 'llvm_anyvector_ty' and would allow intrinsics such as:
declare i32* @llvm.something.v4i32(<4 x i32>);
declare i64* @llvm.something.v2i64(<2 x i64>);
where the result pointer type is deduced from the element type of the
first argument.
If the returned pointer is not a pointer to the element type, LLVM will
give an error:
Intrinsic has incorrect return type!
i64* (<4 x i32>)* @llvm.something.v4i32
Reviewers: RKSimon, arsenm, rnk, greened
Reviewed By: arsenm
Differential Revision: https://reviews.llvm.org/D62995
llvm-svn: 363233
Diffstat (limited to 'llvm/lib/CodeGen/MachineFunction.cpp')
0 files changed, 0 insertions, 0 deletions