| Index: unittests/Bitcode/NaClParseInstsTest.cpp
|
| diff --git a/unittests/Bitcode/NaClParseInstsTest.cpp b/unittests/Bitcode/NaClParseInstsTest.cpp
|
| index b3940abd4cf73947f29a12e3624717cb499172d5..a8f555d5abe8b2ed3b657c8d967d97fc34eee832 100644
|
| --- a/unittests/Bitcode/NaClParseInstsTest.cpp
|
| +++ b/unittests/Bitcode/NaClParseInstsTest.cpp
|
| @@ -55,32 +55,42 @@ TEST(NaClParseInstsTest, NonexistantCallArg) {
|
| // Show text of base input.
|
| NaClObjDumpMunger DumpMunger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| - EXPECT_FALSE(DumpMunger.runTestForAssembly("Nonexistant call arg"));
|
| + EXPECT_FALSE(DumpMunger.runTest("Nonexistant call arg"));
|
| EXPECT_EQ(
|
| - "module { // BlockID = 8\n"
|
| - " types { // BlockID = 17\n"
|
| - " count 3;\n"
|
| - " @t0 = i32;\n"
|
| - " @t1 = void;\n"
|
| - " @t2 = void (i32, i32);\n"
|
| - " }\n"
|
| - " declare external void @f0(i32, i32);\n"
|
| - " define external void @f1(i32, i32);\n"
|
| - " function void @f1(i32 %p0, i32 %p1) { // BlockID = 12\n"
|
| - " blocks 1;\n"
|
| - " %b0:\n"
|
| - " call void @f0(i32 %p0, i32 @f0);\n"
|
| + " 0:0|<65532, 80, 69, 88, 69, 1, 0,|Magic Number: 'PEXE' (80, 69, "
|
| + "88, 69)\n"
|
| + " | 8, 0, 17, 0, 4, 0, 2, 0, 0, |PNaCl Version: 2\n"
|
| + " | 0> |\n"
|
| + " 16:0|1: <65535, 8, 2> |module { // BlockID = 8\n"
|
| + " 24:0| 1: <65535, 17, 2> | types { // BlockID = 17\n"
|
| + " 32:0| 3: <1, 3> | count 3;\n"
|
| + " 34:4| 3: <7, 32> | @t0 = i32;\n"
|
| + " 37:6| 3: <2> | @t1 = void;\n"
|
| + " 39:4| 3: <21, 0, 1, 0, 0> | @t2 = void (i32, i32);\n"
|
| + " 44:2| 0: <65534> | }\n"
|
| + " 48:0| 3: <8, 2, 0, 1, 0> | declare external void @f0(i32"
|
| + ", i32);\n"
|
| + " 52:6| 3: <8, 2, 0, 0, 0> | define external void @f1(i32,"
|
| + " i32);\n"
|
| + " 57:4| 1: <65535, 12, 2> | function void @f1(i32 %p0, "
|
| + "i32 %p1) {\n"
|
| + " | | // BlockID "
|
| + "= 12\n"
|
| + " 64:0| 3: <1, 1> | blocks 1;\n"
|
| + " | | %b0:\n"
|
| + " 66:4| 3: <34, 0, 4, 2, 100> | call void @f0(i32 %p0, i32"
|
| + " @f0);\n"
|
| "Error(66:4): Invalid relative value id: 100 (Must be <= 4)\n"
|
| - " ret void;\n"
|
| - " }\n"
|
| - "}\n",
|
| + " 72:6| 3: <10> | ret void;\n"
|
| + " 74:4| 0: <65534> | }\n"
|
| + " 76:0|0: <65534> |}\n",
|
| DumpMunger.getTestResults());
|
|
|
| NaClParseBitcodeMunger Munger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| EXPECT_FALSE(Munger.runTest("Nonexistant call arg", true));
|
| EXPECT_EQ(
|
| - "Error: (56:6) Invalid call argument: Index 1\n"
|
| + "Error: (72:6) Invalid call argument: Index 1\n"
|
| "Error: Invalid value in record\n",
|
| Munger.getTestResults());
|
| }
|
| @@ -110,24 +120,33 @@ TEST(NaClParseInstsTests, BadAllocaAlignment) {
|
| // Show text when alignment is 1.
|
| NaClObjDumpMunger DumpMunger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| - EXPECT_TRUE(DumpMunger.runTestForAssembly("BadAllocaAlignment"));
|
| + EXPECT_TRUE(DumpMunger.runTest("BadAllocaAlignment"));
|
| EXPECT_EQ(
|
| - "module { // BlockID = 8\n"
|
| - " types { // BlockID = 17\n"
|
| - " count 4;\n"
|
| - " @t0 = i32;\n"
|
| - " @t1 = void;\n"
|
| - " @t2 = void (i32);\n"
|
| - " @t3 = i8;\n"
|
| - " }\n"
|
| - " define external void @f0(i32);\n"
|
| - " function void @f0(i32 %p0) { // BlockID = 12\n"
|
| - " blocks 1;\n"
|
| - " %b0:\n"
|
| - " %v0 = alloca i8, i32 %p0, align 1;\n"
|
| - " ret void;\n"
|
| - " }\n"
|
| - "}\n",
|
| + " 0:0|<65532, 80, 69, 88, 69, 1, 0,|Magic Number: 'PEXE' (80, 69, "
|
| + "88, 69)\n"
|
| + " | 8, 0, 17, 0, 4, 0, 2, 0, 0, |PNaCl Version: 2\n"
|
| + " | 0> |\n"
|
| + " 16:0|1: <65535, 8, 2> |module { // BlockID = 8\n"
|
| + " 24:0| 1: <65535, 17, 2> | types { // BlockID = 17\n"
|
| + " 32:0| 3: <1, 4> | count 4;\n"
|
| + " 34:4| 3: <7, 32> | @t0 = i32;\n"
|
| + " 37:6| 3: <2> | @t1 = void;\n"
|
| + " 39:4| 3: <21, 0, 1, 0> | @t2 = void (i32);\n"
|
| + " 43:4| 3: <7, 8> | @t3 = i8;\n"
|
| + " 46:0| 0: <65534> | }\n"
|
| + " 48:0| 3: <8, 2, 0, 0, 0> | define external void @f0(i32"
|
| + ");\n"
|
| + " 52:6| 1: <65535, 12, 2> | function void @f0(i32 %p0) {"
|
| + " \n"
|
| + " | | // BlockID "
|
| + "= 12\n"
|
| + " 60:0| 3: <1, 1> | blocks 1;\n"
|
| + " | | %b0:\n"
|
| + " 62:4| 3: <19, 1, 1> | %v0 = alloca i8, i32 %p0, "
|
| + "align 1;\n"
|
| + " 65:6| 3: <10> | ret void;\n"
|
| + " 67:4| 0: <65534> | }\n"
|
| + " 68:0|0: <65534> |}\n",
|
| DumpMunger.getTestResults());
|
| NaClParseBitcodeMunger Munger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| @@ -154,7 +173,7 @@ TEST(NaClParseInstsTests, BadAllocaAlignment) {
|
| EXPECT_FALSE(Munger.runTest(
|
| "BadAllocaAlignment-30", Align30, array_lengthof(Align30), true));
|
| EXPECT_EQ(
|
| - "Error: (49:6) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| + "Error: (65:6) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| "Error: Invalid value in record\n",
|
| Munger.getTestResults());
|
| EXPECT_FALSE(DumpMunger.runTestForAssembly(
|
| @@ -206,22 +225,31 @@ TEST(NaClParseInstsTests, BadLoadAlignment) {
|
| // Show text when alignment is 1.
|
| NaClObjDumpMunger DumpMunger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| - EXPECT_TRUE(DumpMunger.runTestForAssembly("BadLoadAlignment-1"));
|
| + EXPECT_TRUE(DumpMunger.runTest("BadLoadAlignment-1"));
|
| EXPECT_EQ(
|
| - "module { // BlockID = 8\n"
|
| - " types { // BlockID = 17\n"
|
| - " count 2;\n"
|
| - " @t0 = i32;\n"
|
| - " @t1 = i32 (i32);\n"
|
| - " }\n"
|
| - " define external i32 @f0(i32);\n"
|
| - " function i32 @f0(i32 %p0) { // BlockID = 12\n"
|
| - " blocks 1;\n"
|
| - " %b0:\n"
|
| - " %v0 = load i32* %p0, align 1;\n"
|
| - " ret i32 %v0;\n"
|
| - " }\n"
|
| - "}\n",
|
| + " 0:0|<65532, 80, 69, 88, 69, 1, 0,|Magic Number: 'PEXE' (80, 69, "
|
| + "88, 69)\n"
|
| + " | 8, 0, 17, 0, 4, 0, 2, 0, 0, |PNaCl Version: 2\n"
|
| + " | 0> |\n"
|
| + " 16:0|1: <65535, 8, 2> |module { // BlockID = 8\n"
|
| + " 24:0| 1: <65535, 17, 2> | types { // BlockID = 17\n"
|
| + " 32:0| 3: <1, 2> | count 2;\n"
|
| + " 34:4| 3: <7, 32> | @t0 = i32;\n"
|
| + " 37:6| 3: <21, 0, 0, 0> | @t1 = i32 (i32);\n"
|
| + " 41:6| 0: <65534> | }\n"
|
| + " 44:0| 3: <8, 1, 0, 0, 0> | define external i32 @f0(i32"
|
| + ");\n"
|
| + " 48:6| 1: <65535, 12, 2> | function i32 @f0(i32 %p0) {"
|
| + " \n"
|
| + " | | // BlockID "
|
| + "= 12\n"
|
| + " 56:0| 3: <1, 1> | blocks 1;\n"
|
| + " | | %b0:\n"
|
| + " 58:4| 3: <20, 1, 1, 0> | %v0 = load i32* %p0, "
|
| + "align 1;\n"
|
| + " 62:4| 3: <10, 1> | ret i32 %v0;\n"
|
| + " 65:0| 0: <65534> | }\n"
|
| + " 68:0|0: <65534> |}\n",
|
| DumpMunger.getTestResults());
|
| NaClParseBitcodeMunger Munger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| @@ -281,7 +309,7 @@ TEST(NaClParseInstsTests, BadLoadAlignment) {
|
| EXPECT_FALSE(Munger.runTest(
|
| "BadLoadAlignment-30", Align30, array_lengthof(Align30), true));
|
| EXPECT_EQ(
|
| - "Error: (46:4) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| + "Error: (62:4) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| "Error: Invalid value in record\n",
|
| Munger.getTestResults());
|
| EXPECT_FALSE(DumpMunger.runTestForAssembly(
|
| @@ -316,23 +344,34 @@ TEST(NaClParseInstsTests, BadStoreAlignment) {
|
| // Show text when alignment is 1.
|
| NaClObjDumpMunger DumpMunger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| - EXPECT_TRUE(DumpMunger.runTestForAssembly("BadStoreAlignment"));
|
| + EXPECT_TRUE(DumpMunger.runTest("BadStoreAlignment"));
|
| EXPECT_EQ(
|
| - "module { // BlockID = 8\n"
|
| - " types { // BlockID = 17\n"
|
| - " count 3;\n"
|
| - " @t0 = float;\n"
|
| - " @t1 = i32;\n"
|
| - " @t2 = float (i32, float);\n"
|
| - " }\n"
|
| - " define external float @f0(i32, float);\n"
|
| - " function float @f0(i32 %p0, float %p1) { // BlockID = 12\n"
|
| - " blocks 1;\n"
|
| - " %b0:\n"
|
| - " store float %p1, float* %p0, align 1;\n"
|
| - " ret float %p1;\n"
|
| - " }\n"
|
| - "}\n",
|
| + " 0:0|<65532, 80, 69, 88, 69, 1, 0,|Magic Number: 'PEXE' (80, 69, "
|
| + "88, 69)\n"
|
| + " | 8, 0, 17, 0, 4, 0, 2, 0, 0, |PNaCl Version: 2\n"
|
| + " | 0> |\n"
|
| + " 16:0|1: <65535, 8, 2> |module { // BlockID = 8\n"
|
| + " 24:0| 1: <65535, 17, 2> | types { // BlockID = 17\n"
|
| + " 32:0| 3: <1, 3> | count 3;\n"
|
| + " 34:4| 3: <3> | @t0 = float;\n"
|
| + " 36:2| 3: <7, 32> | @t1 = i32;\n"
|
| + " 39:4| 3: <21, 0, 0, 1, 0> | @t2 = float (i32, float);\n"
|
| + " 44:2| 0: <65534> | }\n"
|
| + " 48:0| 3: <8, 2, 0, 0, 0> | define external \n"
|
| + " | | float @f0(i32, float);\n"
|
| + " 52:6| 1: <65535, 12, 2> | function \n"
|
| + " | | float @f0(i32 %p0, float "
|
| + "%p1) { \n"
|
| + " | | // BlockID "
|
| + "= 12\n"
|
| + " 60:0| 3: <1, 1> | blocks 1;\n"
|
| + " | | %b0:\n"
|
| + " 62:4| 3: <24, 2, 1, 1> | store float %p1, float* "
|
| + "%p0, \n"
|
| + " | | align 1;\n"
|
| + " 66:4| 3: <10, 1> | ret float %p1;\n"
|
| + " 69:0| 0: <65534> | }\n"
|
| + " 72:0|0: <65534> |}\n",
|
| DumpMunger.getTestResults());
|
| NaClParseBitcodeMunger Munger(BitcodeRecords,
|
| array_lengthof(BitcodeRecords), Terminator);
|
| @@ -402,7 +441,7 @@ TEST(NaClParseInstsTests, BadStoreAlignment) {
|
| EXPECT_FALSE(Munger.runTest(
|
| "BadStoreAlignment-30", Align30, array_lengthof(Align30), true));
|
| EXPECT_EQ(
|
| - "Error: (50:4) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| + "Error: (66:4) Alignment can't be greater than 2**29. Found: 2**30\n"
|
| "Error: Invalid value in record\n",
|
| Munger.getTestResults());
|
| EXPECT_FALSE(DumpMunger.runTestForAssembly(
|
|
|