summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorMon P Wang <wangmp@apple.com>2008-10-15 06:18:34 +0000
committerMon P Wang <wangmp@apple.com>2008-10-15 06:18:34 +0000
commitd05269d13c45f1ee212f722edcda0318cd80d78f (patch)
tree761f7c56e8adbb29327445021d7fd26c3634c17d /clang
parent6e979020cdaf41789c0f57d88d2d128def54ab23 (diff)
downloadbcm5719-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.def4
-rw-r--r--clang/lib/CodeGen/CGBuiltin.cpp4
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:
OpenPOWER on IntegriCloud