summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-04-18 07:01:54 +0000
committerChris Lattner <sabre@nondot.org>2009-04-18 07:01:54 +0000
commitc2e868fd148155bb6a2f5abad4ea1719f684fdde (patch)
tree23bf957a1214c37a448a2f18a35d13874a8d8538 /clang/lib/CodeGen
parent032f7665d0236b0627b975918be2af5bb141074f (diff)
downloadbcm5719-llvm-c2e868fd148155bb6a2f5abad4ea1719f684fdde.tar.gz
bcm5719-llvm-c2e868fd148155bb6a2f5abad4ea1719f684fdde.zip
fix incorrect lowering of __builtin_ia32_shufpd, rdar://6803924
llvm-svn: 69428
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CGBuiltin.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp
index 5ef01ac5f0d..e7adf721909 100644
--- a/clang/lib/CodeGen/CGBuiltin.cpp
+++ b/clang/lib/CodeGen/CGBuiltin.cpp
@@ -891,7 +891,8 @@ Value *CodeGenFunction::EmitX86BuiltinExpr(unsigned BuiltinID,
}
case X86::BI__builtin_ia32_shufpd: {
unsigned i = cast<ConstantInt>(Ops[2])->getZExtValue();
- return EmitShuffleVector(Ops[0], Ops[1], i & 1, (i & 2) + 2, "shufpd");
+ return EmitShuffleVector(Ops[0], Ops[1], i & 1,
+ ((i & 2) >> 1)+2, "shufpd");
}
case X86::BI__builtin_ia32_punpcklbw128:
return EmitShuffleVector(Ops[0], Ops[1], 0, 16, 1, 17, 2, 18, 3, 19,
OpenPOWER on IntegriCloud