| OLD | NEW |
| 1 /* Copyright (c) 2010 The Chromium OS Authors. All rights reserved. | 1 /* Copyright (c) 2010 The Chromium OS Authors. All rights reserved. |
| 2 * Use of this source code is governed by a BSD-style license that can be | 2 * Use of this source code is governed by a BSD-style license that can be |
| 3 * found in the LICENSE file. | 3 * found in the LICENSE file. |
| 4 * | 4 * |
| 5 * Tests for firmware image library. | 5 * Tests for firmware image library. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include <stdio.h> | 8 #include <stdio.h> |
| 9 #include <stdlib.h> | 9 #include <stdlib.h> |
| 10 | 10 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 TEST_EQ(EXPECTED_VBKERNELPREAMBLEHEADER_SIZE, | 24 TEST_EQ(EXPECTED_VBKERNELPREAMBLEHEADER_SIZE, |
| 25 sizeof(VbKernelPreambleHeader), "sizeof(VbKernelPreambleHeader)"); | 25 sizeof(VbKernelPreambleHeader), "sizeof(VbKernelPreambleHeader)"); |
| 26 } | 26 } |
| 27 | 27 |
| 28 | 28 |
| 29 /* Helper functions not dependent on specific key sizes */ | 29 /* Helper functions not dependent on specific key sizes */ |
| 30 static void VerifyHelperFunctions(void) { | 30 static void VerifyHelperFunctions(void) { |
| 31 | 31 |
| 32 { | 32 { |
| 33 uint8_t p[1]; | 33 uint8_t p[1]; |
| 34 TEST_EQ(OffsetOf(p, p), 0, "OffsetOf() equal"); | 34 TEST_EQ((int)OffsetOf(p, p), 0, "OffsetOf() equal"); |
| 35 TEST_EQ(OffsetOf(p, p+10), 10, "OffsetOf() positive"); | 35 TEST_EQ((int)OffsetOf(p, p+10), 10, "OffsetOf() positive"); |
| 36 TEST_EQ(OffsetOf(p, p+0x12345678), 0x12345678, "OffsetOf() large"); | 36 TEST_EQ((int)OffsetOf(p, p+0x12345678), 0x12345678, "OffsetOf() large"); |
| 37 } | 37 } |
| 38 | 38 |
| 39 { | 39 { |
| 40 VbPublicKey k = {sizeof(k), 2, 3, 4}; | 40 VbPublicKey k = {sizeof(k), 2, 3, 4}; |
| 41 TEST_EQ(OffsetOf(&k, GetPublicKeyData(&k)), sizeof(k), | 41 TEST_EQ((int)OffsetOf(&k, GetPublicKeyData(&k)), sizeof(k), |
| 42 "GetPublicKeyData() adjacent"); | 42 "GetPublicKeyData() adjacent"); |
| 43 TEST_EQ(OffsetOf(&k, GetPublicKeyDataC(&k)), sizeof(k), | 43 TEST_EQ((int)OffsetOf(&k, GetPublicKeyDataC(&k)), sizeof(k), |
| 44 "GetPublicKeyDataC() adjacent"); | 44 "GetPublicKeyDataC() adjacent"); |
| 45 } | 45 } |
| 46 | 46 |
| 47 { | 47 { |
| 48 VbPublicKey k = {123, 2, 3, 4}; | 48 VbPublicKey k = {123, 2, 3, 4}; |
| 49 TEST_EQ(OffsetOf(&k, GetPublicKeyData(&k)), 123, | 49 TEST_EQ((int)OffsetOf(&k, GetPublicKeyData(&k)), 123, |
| 50 "GetPublicKeyData() spaced"); | 50 "GetPublicKeyData() spaced"); |
| 51 TEST_EQ(OffsetOf(&k, GetPublicKeyDataC(&k)), 123, | 51 TEST_EQ((int)OffsetOf(&k, GetPublicKeyDataC(&k)), 123, |
| 52 "GetPublicKeyDataC() spaced"); | 52 "GetPublicKeyDataC() spaced"); |
| 53 } | 53 } |
| 54 | 54 |
| 55 { | 55 { |
| 56 uint8_t p[1]; | 56 uint8_t p[1]; |
| 57 TEST_EQ(VerifyMemberInside(p, 20, p, 6, 11, 3), 0, "MemberInside ok 1"); | 57 TEST_EQ(VerifyMemberInside(p, 20, p, 6, 11, 3), 0, "MemberInside ok 1"); |
| 58 TEST_EQ(VerifyMemberInside(p, 20, p+4, 4, 8, 4), 0, "MemberInside ok 2"); | 58 TEST_EQ(VerifyMemberInside(p, 20, p+4, 4, 8, 4), 0, "MemberInside ok 2"); |
| 59 TEST_EQ(VerifyMemberInside(p, 20, p-4, 4, 8, 4), 1, | 59 TEST_EQ(VerifyMemberInside(p, 20, p-4, 4, 8, 4), 1, |
| 60 "MemberInside member before parent"); | 60 "MemberInside member before parent"); |
| 61 TEST_EQ(VerifyMemberInside(p, 20, p+20, 4, 8, 4), 1, | 61 TEST_EQ(VerifyMemberInside(p, 20, p+20, 4, 8, 4), 1, |
| 62 "MemberInside member after parent"); | 62 "MemberInside member after parent"); |
| 63 TEST_EQ(VerifyMemberInside(p, 20, p, 21, 0, 0), 1, | 63 TEST_EQ(VerifyMemberInside(p, 20, p, 21, 0, 0), 1, |
| 64 "MemberInside member too big"); | 64 "MemberInside member too big"); |
| 65 TEST_EQ(VerifyMemberInside(p, 20, p, 4, 21, 0), 1, | 65 TEST_EQ(VerifyMemberInside(p, 20, p, 4, 21, 0), 1, |
| 66 "MemberInside data after parent"); | 66 "MemberInside data after parent"); |
| 67 TEST_EQ(VerifyMemberInside(p, 20, p, 4, -1, 0), 1, | 67 TEST_EQ(VerifyMemberInside(p, 20, p, 4, (uint64_t)-1, 0), 1, |
| 68 "MemberInside data before parent"); | 68 "MemberInside data before parent"); |
| 69 TEST_EQ(VerifyMemberInside(p, 20, p, 4, 4, 17), 1, | 69 TEST_EQ(VerifyMemberInside(p, 20, p, 4, 4, 17), 1, |
| 70 "MemberInside data too big"); | 70 "MemberInside data too big"); |
| 71 } | 71 } |
| 72 | 72 |
| 73 { | 73 { |
| 74 VbPublicKey k = {sizeof(k), 128, 0, 0}; | 74 VbPublicKey k = {sizeof(k), 128, 0, 0}; |
| 75 TEST_EQ(VerifyPublicKeyInside(&k, sizeof(k)+128, &k), 0, | 75 TEST_EQ(VerifyPublicKeyInside(&k, sizeof(k)+128, &k), 0, |
| 76 "PublicKeyInside ok 1"); | 76 "PublicKeyInside ok 1"); |
| 77 TEST_EQ(VerifyPublicKeyInside(&k - 1, 2*sizeof(k)+128, &k), 0, | 77 TEST_EQ(VerifyPublicKeyInside(&k - 1, 2*sizeof(k)+128, &k), 0, |
| (...skipping 16 matching lines...) Expand all Loading... |
| 94 "SignatureInside sig too big"); | 94 "SignatureInside sig too big"); |
| 95 } | 95 } |
| 96 { | 96 { |
| 97 VbSignature s = {100, 4, 0}; | 97 VbSignature s = {100, 4, 0}; |
| 98 TEST_EQ(VerifySignatureInside(&s, 99, &s), 1, | 98 TEST_EQ(VerifySignatureInside(&s, 99, &s), 1, |
| 99 "SignatureInside offset too big"); | 99 "SignatureInside offset too big"); |
| 100 } | 100 } |
| 101 | 101 |
| 102 } | 102 } |
| 103 | 103 |
| 104 /* disable MSVC warnings on unused arguments */ |
| 105 __pragma(warning (disable: 4100)) |
| 104 | 106 |
| 105 int main(int argc, char* argv[]) { | 107 int main(int argc, char* argv[]) { |
| 106 int error_code = 0; | 108 int error_code = 0; |
| 107 | 109 |
| 108 StructPackingTest(); | 110 StructPackingTest(); |
| 109 VerifyHelperFunctions(); | 111 VerifyHelperFunctions(); |
| 110 | 112 |
| 111 if (!gTestSuccess) | 113 if (!gTestSuccess) |
| 112 error_code = 255; | 114 error_code = 255; |
| 113 | 115 |
| 114 return error_code; | 116 return error_code; |
| 115 } | 117 } |
| OLD | NEW |