diff options
-rw-r--r-- | lib/VMCore/AutoUpgrade.cpp | 10 | ||||
-rw-r--r-- | test/Bitcode/sse42_crc32.ll | 16 | ||||
-rw-r--r-- | test/Bitcode/sse42_crc32.ll.bc | bin | 0 -> 480 bytes |
3 files changed, 21 insertions, 5 deletions
diff --git a/lib/VMCore/AutoUpgrade.cpp b/lib/VMCore/AutoUpgrade.cpp index b2b3d0beb6..f8f15caec9 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 0000000000..2d770819b0 --- /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 Binary files differnew file mode 100644 index 0000000000..d895fad2ac --- /dev/null +++ b/test/Bitcode/sse42_crc32.ll.bc |