summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGBuiltin.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2008-12-22 04:54:32 +0000
committerAnders Carlsson <andersca@mac.com>2008-12-22 04:54:32 +0000
commit0462eb270ad5c4b68f9f85eaa16dbdf1a8a86d85 (patch)
treec041898968ec6d2895e764ccd08d61ea83ab3364 /clang/lib/CodeGen/CGBuiltin.cpp
parent70d5f46646435241b545c3d7cf78b9fd636f6e39 (diff)
downloadbcm5719-llvm-0462eb270ad5c4b68f9f85eaa16dbdf1a8a86d85.tar.gz
bcm5719-llvm-0462eb270ad5c4b68f9f85eaa16dbdf1a8a86d85.zip
Generate code for __builtin_ia32_pshufw
llvm-svn: 61324
Diffstat (limited to 'clang/lib/CodeGen/CGBuiltin.cpp')
-rw-r--r--clang/lib/CodeGen/CGBuiltin.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp
index a4b5973ec11..6877b317aa5 100644
--- a/clang/lib/CodeGen/CGBuiltin.cpp
+++ b/clang/lib/CodeGen/CGBuiltin.cpp
@@ -595,6 +595,13 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
llvm::Function *F = CGM.getIntrinsic(ID);
return Builder.CreateCall(F, &Ops[0], &Ops[0] + Ops.size(), name);
}
+ case X86::BI__builtin_ia32_pshufw: {
+ unsigned i = cast<ConstantInt>(Ops[1])->getZExtValue();
+ return EmitShuffleVector(Ops[0], Ops[0],
+ i & 0x3, (i & 0xc) >> 2,
+ (i & 0x30) >> 4, (i & 0xc0) >> 6,
+ "pshufw");
+ }
case X86::BI__builtin_ia32_pshuflw: {
unsigned i = cast<ConstantInt>(Ops[1])->getZExtValue();
return EmitShuffleVector(Ops[0], Ops[0],
OpenPOWER on IntegriCloud