diff options
author | Mon P Wang <wangmp@apple.com> | 2008-10-15 06:18:34 +0000 |
---|---|---|
committer | Mon P Wang <wangmp@apple.com> | 2008-10-15 06:18:34 +0000 |
commit | d05269d13c45f1ee212f722edcda0318cd80d78f (patch) | |
tree | 761f7c56e8adbb29327445021d7fd26c3634c17d /clang | |
parent | 6e979020cdaf41789c0f57d88d2d128def54ab23 (diff) | |
download | bcm5719-llvm-d05269d13c45f1ee212f722edcda0318cd80d78f.tar.gz bcm5719-llvm-d05269d13c45f1ee212f722edcda0318cd80d78f.zip |
Added pinsrd, pinsrq, and some other vector intrinsics
llvm-svn: 57563
Diffstat (limited to 'clang')
-rw-r--r-- | clang/include/clang/AST/X86Builtins.def | 4 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGBuiltin.cpp | 4 |
2 files changed, 8 insertions, 0 deletions
diff --git a/clang/include/clang/AST/X86Builtins.def b/clang/include/clang/AST/X86Builtins.def index 057ff91f12c..e9d4d703e9f 100644 --- a/clang/include/clang/AST/X86Builtins.def +++ b/clang/include/clang/AST/X86Builtins.def @@ -421,6 +421,10 @@ BUILTIN(__builtin_ia32_vec_ext_v4hi, "sV4si", "") BUILTIN(__builtin_ia32_vec_ext_v2si, "iV2ii", "") BUILTIN(__builtin_ia32_vec_set_v8hi, "V8sV8ssi", "") BUILTIN(__builtin_ia32_vec_set_v4hi, "V4sV4ssi", "") +BUILTIN(__builtin_ia32_vec_set_v16qi, "V16cV16cii", "") +BUILTIN(__builtin_ia32_vec_set_v4si, "V4iV4iii", "") +BUILTIN(__builtin_ia32_vec_set_v2di, "V2LLV2LLLLi", "") +BUILTIN(__builtin_ia32_insertps128, "V4fV4fV4fi", "") BUILTIN(__builtin_ia32_movqv4si, "V4iV4i", "") BUILTIN(__builtin_ia32_loadlv4si, "V4iV2i*", "") diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp index aa9fdd813f1..d08d9bc5f28 100644 --- a/clang/lib/CodeGen/CGBuiltin.cpp +++ b/clang/lib/CodeGen/CGBuiltin.cpp @@ -902,6 +902,10 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID, case X86::BI__builtin_ia32_vec_set_v4hi: case X86::BI__builtin_ia32_vec_set_v8hi: return Builder.CreateInsertElement(Ops[0], Ops[1], Ops[2], "pinsrw"); + case X86::BI__builtin_ia32_vec_set_v4si: + return Builder.CreateInsertElement(Ops[0], Ops[1], Ops[2], "pinsrd"); + case X86::BI__builtin_ia32_vec_set_v2di: + return Builder.CreateInsertElement(Ops[0], Ops[1], Ops[2], "pinsrq"); case X86::BI__builtin_ia32_andps: case X86::BI__builtin_ia32_andpd: case X86::BI__builtin_ia32_andnps: |