diff --git a/lib/VMCore/AutoUpgrade.cpp b/lib/VMCore/AutoUpgrade.cpp index b2b3d0beb66..f8f15caec91 100644 --- a/lib/VMCore/AutoUpgrade.cpp +++ b/lib/VMCore/AutoUpgrade.cpp @@ -290,18 +290,18 @@ static bool UpgradeIntrinsicFunction1(Function *F, Function *&NewFn) { if (Name.compare(5, 13, "x86.sse42.crc", 13) == 0) { const char* NewFnName = NULL; if (Name.compare(18, 2, "32", 2) == 0) { - if (Name.compare(20, 2, ".8") == 0) { + if (Name.compare(20, 2, ".8") == 0 && Name.length() == 22) { NewFnName = "llvm.x86.sse42.crc32.32.8"; - } else if (Name.compare(20, 2, ".16") == 0) { + } else if (Name.compare(20, 3, ".16") == 0 && Name.length() == 23) { NewFnName = "llvm.x86.sse42.crc32.32.16"; - } else if (Name.compare(20, 2, ".32") == 0) { + } else if (Name.compare(20, 3, ".32") == 0 && Name.length() == 23) { NewFnName = "llvm.x86.sse42.crc32.32.32"; } } else if (Name.compare(18, 2, "64", 2) == 0) { - if (Name.compare(20, 2, ".8") == 0) { + if (Name.compare(20, 2, ".8") == 0 && Name.length() == 22) { NewFnName = "llvm.x86.sse42.crc32.64.8"; - } else if (Name.compare(20, 2, ".64") == 0) { + } else if (Name.compare(20, 3, ".64") == 0 && Name.length() == 23) { NewFnName = "llvm.x86.sse42.crc32.64.64"; } } diff --git a/test/Bitcode/sse42_crc32.ll b/test/Bitcode/sse42_crc32.ll new file mode 100644 index 00000000000..2d770819b04 --- /dev/null +++ b/test/Bitcode/sse42_crc32.ll @@ -0,0 +1,16 @@ +; Check to make sure old CRC32 intrinsics are auto-upgraded +; correctly. +; +; Rdar: 9472944 +; +; RUN: llvm-dis < %s.bc | not grep {i32 @llvm.x86.sse42.crc32.8(} +; RUN: llvm-dis < %s.bc | grep {i32 @llvm.x86.sse42.crc32.32.8(} +; RUN: llvm-dis < %s.bc | not grep {i32 @llvm.x86.sse42.crc32.16(} +; RUN: llvm-dis < %s.bc | grep {i32 @llvm.x86.sse42.crc32.32.16(} +; RUN: llvm-dis < %s.bc | not grep {i32 @llvm.x86.sse42.crc32.32(} +; RUN: llvm-dis < %s.bc | grep {i32 @llvm.x86.sse42.crc32.32.32(} +; RUN: llvm-dis < %s.bc | not grep {i64 @llvm.x86.sse42.crc64.8(} +; RUN: llvm-dis < %s.bc | grep {i64 @llvm.x86.sse42.crc32.64.8(} +; RUN: llvm-dis < %s.bc | not grep {i64 @llvm.x86.sse42.crc64.8(} +; RUN: llvm-dis < %s.bc | grep {i64 @llvm.x86.sse42.crc32.64.8(} + diff --git a/test/Bitcode/sse42_crc32.ll.bc b/test/Bitcode/sse42_crc32.ll.bc new file mode 100644 index 00000000000..d895fad2ac4 Binary files /dev/null and b/test/Bitcode/sse42_crc32.ll.bc differ