1 /* 2 * Copyright (C) 2012 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #include <fcntl.h> 18 #include <stdlib.h> 19 #include <unistd.h> 20 #include <sys/mman.h> 21 #include <sys/stat.h> 22 #include <sys/types.h> 23 24 #include <fstream> 25 #include <iostream> 26 27 #include <gtest/gtest.h> 28 29 #include <openssl/bn.h> 30 #include <openssl/evp.h> 31 #include <openssl/x509.h> 32 33 #define LOG_TAG "keymaster_test" 34 #include <utils/Log.h> 35 36 #include <UniquePtr.h> 37 38 #include <hardware/keymaster0.h> 39 40 namespace android { 41 42 class UniqueBlob : public UniquePtr<uint8_t[]> { 43 public: 44 UniqueBlob(size_t length) : 45 mLength(length) { 46 } 47 48 UniqueBlob(uint8_t* bytes, size_t length) : 49 UniquePtr<uint8_t[]>(bytes), mLength(length) { 50 } 51 52 bool operator==(const UniqueBlob &other) const { 53 if (other.length() != mLength) { 54 return false; 55 } 56 57 const uint8_t* mine = get(); 58 const uint8_t* theirs = other.get(); 59 60 for (size_t i = 0; i < mLength; i++) { 61 if (mine[i] != theirs[i]) { 62 return false; 63 } 64 } 65 66 return true; 67 } 68 69 size_t length() const { 70 return mLength; 71 } 72 73 friend std::ostream &operator<<(std::ostream &stream, const UniqueBlob& blob); 74 75 private: 76 size_t mLength; 77 }; 78 79 std::ostream &operator<<(std::ostream &stream, const UniqueBlob& blob) { 80 const size_t length = blob.mLength; 81 stream << "Blob length=" << length << " < "; 82 83 const uint8_t* data = blob.get(); 84 for (size_t i = 0; i < length; i++) { 85 stream << std::hex << std::setw(2) << std::setfill('0') 86 << static_cast<unsigned int>(data[i]) << ' '; 87 } 88 stream << '>' << std::endl; 89 90 return stream; 91 } 92 93 class UniqueKey : public UniqueBlob { 94 public: 95 UniqueKey(keymaster0_device_t** dev, uint8_t* bytes, size_t length) : 96 UniqueBlob(bytes, length), mDevice(dev) { 97 } 98 99 ~UniqueKey() { 100 if (mDevice != NULL && *mDevice != NULL) { 101 keymaster0_device_t* dev = *mDevice; 102 if (dev->delete_keypair != NULL) { 103 dev->delete_keypair(dev, get(), length()); 104 } 105 } 106 } 107 108 private: 109 keymaster0_device_t** mDevice; 110 }; 111 112 class UniqueReadOnlyBlob { 113 public: 114 UniqueReadOnlyBlob(uint8_t* data, size_t dataSize) : 115 mDataSize(dataSize) { 116 int pageSize = sysconf(_SC_PAGE_SIZE); 117 if (pageSize == -1) { 118 return; 119 } 120 121 int fd = open("/dev/zero", O_RDONLY); 122 if (fd == -1) { 123 return; 124 } 125 126 mBufferSize = (dataSize + pageSize - 1) & ~(pageSize - 1); 127 uint8_t* buffer = (uint8_t*) mmap(NULL, mBufferSize, PROT_READ | PROT_WRITE, 128 MAP_PRIVATE, fd, 0); 129 close(fd); 130 131 if (buffer == NULL) { 132 return; 133 } 134 135 memcpy(buffer, data, dataSize); 136 if (mprotect(buffer, mBufferSize, PROT_READ) == -1) { 137 munmap(buffer, mBufferSize); 138 return; 139 } 140 141 mBuffer = buffer; 142 } 143 144 ~UniqueReadOnlyBlob() { 145 munmap(mBuffer, mBufferSize); 146 } 147 148 uint8_t* get() const { 149 return mBuffer; 150 } 151 152 size_t length() const { 153 return mDataSize; 154 } 155 156 private: 157 uint8_t* mBuffer; 158 size_t mBufferSize; 159 size_t mDataSize; 160 }; 161 162 struct BIGNUM_Delete { 163 void operator()(BIGNUM* p) const { 164 BN_free(p); 165 } 166 }; 167 typedef UniquePtr<BIGNUM, BIGNUM_Delete> Unique_BIGNUM; 168 169 struct EVP_PKEY_Delete { 170 void operator()(EVP_PKEY* p) const { 171 EVP_PKEY_free(p); 172 } 173 }; 174 typedef UniquePtr<EVP_PKEY, EVP_PKEY_Delete> Unique_EVP_PKEY; 175 176 struct PKCS8_PRIV_KEY_INFO_Delete { 177 void operator()(PKCS8_PRIV_KEY_INFO* p) const { 178 PKCS8_PRIV_KEY_INFO_free(p); 179 } 180 }; 181 typedef UniquePtr<PKCS8_PRIV_KEY_INFO, PKCS8_PRIV_KEY_INFO_Delete> Unique_PKCS8_PRIV_KEY_INFO; 182 183 struct RSA_Delete { 184 void operator()(RSA* p) const { 185 RSA_free(p); 186 } 187 }; 188 typedef UniquePtr<RSA, RSA_Delete> Unique_RSA; 189 190 struct EC_KEY_Delete { 191 void operator()(EC_KEY* p) const { 192 EC_KEY_free(p); 193 } 194 }; 195 typedef UniquePtr<EC_KEY, EC_KEY_Delete> Unique_EC_KEY; 196 197 198 /* 199 * DER-encoded PKCS#8 format RSA key. Generated using: 200 * 201 * openssl genrsa 2048 | openssl pkcs8 -topk8 -nocrypt -outform der | recode ../x1 202 */ 203 static uint8_t TEST_RSA_KEY_1[] = { 204 0x30, 0x82, 0x04, 0xBE, 0x02, 0x01, 0x00, 0x30, 0x0D, 0x06, 0x09, 0x2A, 205 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82, 206 0x04, 0xA8, 0x30, 0x82, 0x04, 0xA4, 0x02, 0x01, 0x00, 0x02, 0x82, 0x01, 207 0x01, 0x00, 0xD8, 0x58, 0xD4, 0x9F, 0xC0, 0xE8, 0xF0, 0xFF, 0x87, 0x27, 208 0x43, 0xE6, 0x2E, 0xE6, 0x9A, 0x42, 0x3B, 0x39, 0x94, 0x84, 0x43, 0x55, 209 0x8D, 0x20, 0x5B, 0x71, 0x88, 0xE6, 0xD1, 0x62, 0xC8, 0xF2, 0x20, 0xD0, 210 0x75, 0x13, 0x83, 0xA3, 0x5D, 0x19, 0xA8, 0x62, 0xD0, 0x5F, 0x3E, 0x8A, 211 0x7C, 0x0E, 0x26, 0xA9, 0xFF, 0xB2, 0x5E, 0x63, 0xAA, 0x3C, 0x8D, 0x13, 212 0x41, 0xAA, 0xD5, 0x03, 0x01, 0x01, 0x53, 0xC9, 0x02, 0x1C, 0xEC, 0xE8, 213 0xC4, 0x70, 0x3F, 0x43, 0xE5, 0x51, 0xD0, 0x6E, 0x52, 0x0B, 0xC4, 0x0A, 214 0xA3, 0x61, 0xDE, 0xE3, 0x72, 0x0C, 0x94, 0xF1, 0x1C, 0x2D, 0x36, 0x77, 215 0xBB, 0x16, 0xA8, 0x63, 0x4B, 0xD1, 0x07, 0x00, 0x42, 0x2D, 0x2B, 0x10, 216 0x80, 0x45, 0xF3, 0x0C, 0xF9, 0xC5, 0xAC, 0xCC, 0x64, 0x87, 0xFD, 0x5D, 217 0xC8, 0x51, 0xD4, 0x1C, 0x9E, 0x6E, 0x9B, 0xC4, 0x27, 0x5E, 0x73, 0xA7, 218 0x2A, 0xF6, 0x90, 0x42, 0x0C, 0x34, 0x93, 0xB7, 0x02, 0x19, 0xA9, 0x64, 219 0x6C, 0x46, 0x3B, 0x40, 0x02, 0x2F, 0x54, 0x69, 0x79, 0x26, 0x7D, 0xF6, 220 0x85, 0x90, 0x01, 0xD0, 0x21, 0x07, 0xD0, 0x14, 0x00, 0x65, 0x9C, 0xAC, 221 0x24, 0xE8, 0x78, 0x42, 0x3B, 0x90, 0x75, 0x19, 0x55, 0x11, 0x4E, 0xD9, 222 0xE6, 0x97, 0x87, 0xBC, 0x8D, 0x2C, 0x9B, 0xF0, 0x1F, 0x14, 0xEB, 0x6A, 223 0x57, 0xCE, 0x78, 0xAD, 0xCE, 0xD9, 0xFB, 0xB9, 0xA1, 0xEF, 0x0C, 0x1F, 224 0xDD, 0xE3, 0x5B, 0x73, 0xA0, 0xEC, 0x37, 0x9C, 0xE1, 0xFD, 0x86, 0x28, 225 0xC3, 0x4A, 0x42, 0xD0, 0xA3, 0xFE, 0x57, 0x09, 0x29, 0xD8, 0xF6, 0xEC, 226 0xE3, 0xC0, 0x71, 0x7C, 0x29, 0x27, 0xC2, 0xD1, 0x3E, 0x22, 0xBC, 0xBD, 227 0x5A, 0x85, 0x41, 0xF6, 0x15, 0xDA, 0x0C, 0x58, 0x5A, 0x61, 0x5B, 0x78, 228 0xB8, 0xAA, 0xEC, 0x5C, 0x1C, 0x79, 0x02, 0x03, 0x01, 0x00, 0x01, 0x02, 229 0x82, 0x01, 0x00, 0x1D, 0x10, 0x31, 0xE0, 0x14, 0x26, 0x36, 0xD9, 0xDC, 230 0xEA, 0x25, 0x70, 0xF2, 0xB3, 0xFF, 0xDD, 0x0D, 0xDF, 0xBA, 0x57, 0xDA, 231 0x43, 0xCF, 0xE5, 0x9C, 0xE3, 0x2F, 0xA4, 0xF2, 0x53, 0xF6, 0xF2, 0xAF, 232 0xFD, 0xD0, 0xFC, 0x82, 0x1E, 0x9C, 0x0F, 0x2A, 0x53, 0xBB, 0xF2, 0x4F, 233 0x90, 0x83, 0x01, 0xD3, 0xA7, 0xDA, 0xB5, 0xB7, 0x80, 0x64, 0x0A, 0x26, 234 0x59, 0x83, 0xE4, 0xD3, 0x20, 0xC8, 0x2D, 0xC9, 0x77, 0xA3, 0x55, 0x07, 235 0x6E, 0x6D, 0x95, 0x36, 0xAA, 0x84, 0x4F, 0xED, 0x54, 0x24, 0xA9, 0x77, 236 0xF8, 0x85, 0xE2, 0x4B, 0xF2, 0xFA, 0x0B, 0x3E, 0xA6, 0xF5, 0x46, 0x0D, 237 0x9F, 0x1F, 0xFE, 0xF7, 0x37, 0xFF, 0xA3, 0x60, 0xF1, 0x63, 0xF2, 0x75, 238 0x6A, 0x8E, 0x10, 0xD7, 0x89, 0xD2, 0xB3, 0xFF, 0x76, 0xA5, 0xBA, 0xAF, 239 0x0A, 0xBE, 0x32, 0x5F, 0xF0, 0x48, 0x48, 0x4B, 0x9C, 0x9A, 0x3D, 0x12, 240 0xA7, 0xD2, 0x07, 0xC7, 0x59, 0x32, 0x94, 0x95, 0x65, 0x2F, 0x87, 0x34, 241 0x76, 0xBA, 0x7C, 0x08, 0x4B, 0xAB, 0xA6, 0x24, 0xDF, 0x64, 0xDB, 0x48, 242 0x63, 0x42, 0x06, 0xE2, 0x2C, 0x3D, 0xFB, 0xE5, 0x47, 0x81, 0x94, 0x98, 243 0xF7, 0x32, 0x4B, 0x28, 0xEB, 0x42, 0xB8, 0xE9, 0x8E, 0xFC, 0xC9, 0x43, 244 0xC9, 0x47, 0xE6, 0xE7, 0x1C, 0xDC, 0x71, 0xEF, 0x4D, 0x8A, 0xB1, 0xFC, 245 0x45, 0x37, 0xEC, 0xB3, 0x16, 0x88, 0x5B, 0xE2, 0xEC, 0x8B, 0x6B, 0x75, 246 0x16, 0xBE, 0x6B, 0xF8, 0x2C, 0xF8, 0xC9, 0xD1, 0xF7, 0x55, 0x87, 0x57, 247 0x5F, 0xDE, 0xF4, 0x7E, 0x72, 0x13, 0x06, 0x2A, 0x21, 0xB7, 0x78, 0x21, 248 0x05, 0xFD, 0xE2, 0x5F, 0x7B, 0x7C, 0xF0, 0x26, 0x2B, 0x75, 0x7F, 0x68, 249 0xF9, 0xA6, 0x98, 0xFD, 0x54, 0x0E, 0xCC, 0x22, 0x41, 0x7F, 0x29, 0x81, 250 0x2F, 0xA3, 0x3C, 0x3D, 0x64, 0xC8, 0x41, 0x02, 0x81, 0x81, 0x00, 0xFA, 251 0xFA, 0xE4, 0x2E, 0x30, 0xF0, 0x7A, 0x8D, 0x95, 0xB8, 0x39, 0x58, 0x27, 252 0x0F, 0x89, 0x0C, 0xDF, 0xFE, 0x2F, 0x55, 0x3B, 0x6F, 0xDD, 0x5F, 0x12, 253 0xB3, 0xD1, 0xCF, 0x5B, 0x8D, 0xB6, 0x10, 0x1C, 0x87, 0x0C, 0x30, 0x89, 254 0x2D, 0xBB, 0xB8, 0xA1, 0x78, 0x0F, 0x54, 0xA6, 0x36, 0x46, 0x05, 0x8B, 255 0x5A, 0xFF, 0x48, 0x03, 0x13, 0xAE, 0x95, 0x96, 0x5D, 0x6C, 0xDA, 0x5D, 256 0xF7, 0xAD, 0x1D, 0x33, 0xED, 0x23, 0xF5, 0x4B, 0x03, 0x78, 0xE7, 0x50, 257 0xD1, 0x2D, 0x95, 0x22, 0x35, 0x02, 0x5B, 0x4A, 0x4E, 0x73, 0xC9, 0xB7, 258 0x05, 0xC4, 0x21, 0x86, 0x1F, 0x1E, 0x40, 0x83, 0xBC, 0x8A, 0x3A, 0x95, 259 0x24, 0x62, 0xF4, 0x58, 0x38, 0x64, 0x4A, 0x89, 0x8A, 0x27, 0x59, 0x12, 260 0x9D, 0x21, 0xC3, 0xA6, 0x42, 0x1E, 0x2A, 0x3F, 0xD8, 0x65, 0x1F, 0x6E, 261 0x3E, 0x4D, 0x5C, 0xCC, 0xEA, 0x8E, 0x15, 0x02, 0x81, 0x81, 0x00, 0xDC, 262 0xAC, 0x9B, 0x00, 0xDB, 0xF9, 0xB2, 0xBF, 0xC4, 0x5E, 0xB6, 0xB7, 0x63, 263 0xEB, 0x13, 0x4B, 0xE2, 0xA6, 0xC8, 0x72, 0x90, 0xD8, 0xC2, 0x33, 0x33, 264 0xF0, 0x66, 0x75, 0xBD, 0x50, 0x7C, 0xA4, 0x8F, 0x82, 0xFB, 0xFF, 0x44, 265 0x3B, 0xE7, 0x15, 0x3A, 0x0C, 0x7A, 0xF8, 0x92, 0x86, 0x4A, 0x79, 0x32, 266 0x08, 0x82, 0x1D, 0x6A, 0xBA, 0xAD, 0x8A, 0xB3, 0x3D, 0x7F, 0xA5, 0xB4, 267 0x6F, 0x67, 0x86, 0x7E, 0xB2, 0x9C, 0x2A, 0xF6, 0x7C, 0x49, 0x21, 0xC5, 268 0x3F, 0x00, 0x3F, 0x9B, 0xF7, 0x0F, 0x6C, 0x35, 0x80, 0x75, 0x73, 0xC0, 269 0xF8, 0x3E, 0x30, 0x5F, 0x74, 0x2F, 0x15, 0x41, 0xEA, 0x0F, 0xCE, 0x0E, 270 0x18, 0x17, 0x68, 0xBA, 0xC4, 0x29, 0xF2, 0xE2, 0x2C, 0x1D, 0x55, 0x83, 271 0xB6, 0x64, 0x2E, 0x03, 0x12, 0xA4, 0x0D, 0xBF, 0x4F, 0x2E, 0xBE, 0x7C, 272 0x41, 0xD9, 0xCD, 0xD0, 0x52, 0x91, 0xD5, 0x02, 0x81, 0x81, 0x00, 0xD4, 273 0x55, 0xEB, 0x32, 0xC1, 0x28, 0xD3, 0x26, 0x72, 0x22, 0xB8, 0x31, 0x42, 274 0x6A, 0xBC, 0x52, 0x6E, 0x37, 0x48, 0xA8, 0x5D, 0x6E, 0xD8, 0xE5, 0x14, 275 0x97, 0x99, 0xCC, 0x4A, 0xF2, 0xEB, 0xB3, 0x59, 0xCF, 0x4F, 0x9A, 0xC8, 276 0x94, 0x2E, 0x9B, 0x97, 0xD0, 0x51, 0x78, 0x16, 0x5F, 0x18, 0x82, 0x9C, 277 0x51, 0xD2, 0x64, 0x84, 0x65, 0xE4, 0x70, 0x9E, 0x14, 0x50, 0x81, 0xB6, 278 0xBA, 0x52, 0x75, 0xC0, 0x76, 0xC2, 0xD3, 0x46, 0x31, 0x9B, 0xDA, 0x67, 279 0xDF, 0x71, 0x27, 0x19, 0x17, 0xAB, 0xF4, 0xBC, 0x3A, 0xFF, 0x6F, 0x0B, 280 0x2F, 0x0F, 0xAE, 0x25, 0x20, 0xB2, 0xA1, 0x76, 0x52, 0xCE, 0xC7, 0x9D, 281 0x62, 0x79, 0x6D, 0xAC, 0x2D, 0x99, 0x7C, 0x0E, 0x3D, 0x19, 0xE9, 0x1B, 282 0xFC, 0x60, 0x92, 0x7C, 0x58, 0xB7, 0xD8, 0x9A, 0xC7, 0x63, 0x56, 0x62, 283 0x18, 0xC7, 0xAE, 0xD9, 0x97, 0x1F, 0xB9, 0x02, 0x81, 0x81, 0x00, 0x91, 284 0x40, 0xC4, 0x1E, 0x82, 0xAD, 0x0F, 0x6D, 0x8E, 0xD2, 0x51, 0x2E, 0xD1, 285 0x84, 0x30, 0x85, 0x68, 0xC1, 0x23, 0x7B, 0xD5, 0xBF, 0xF7, 0xC4, 0x40, 286 0x51, 0xE2, 0xFF, 0x69, 0x07, 0x8B, 0xA3, 0xBE, 0x1B, 0x17, 0xC8, 0x64, 287 0x9F, 0x91, 0x71, 0xB5, 0x6D, 0xF5, 0x9B, 0x9C, 0xC6, 0xEC, 0x4A, 0x6E, 288 0x16, 0x8F, 0x9E, 0xD1, 0x5B, 0xE3, 0x53, 0x42, 0xBC, 0x1E, 0x43, 0x72, 289 0x4B, 0x4A, 0x37, 0x8B, 0x3A, 0x01, 0xF5, 0x7D, 0x9D, 0x3D, 0x7E, 0x0F, 290 0x19, 0x73, 0x0E, 0x6B, 0x98, 0xE9, 0xFB, 0xEE, 0x13, 0x8A, 0x3C, 0x11, 291 0x2E, 0xD5, 0xB0, 0x7D, 0x84, 0x3A, 0x61, 0xA1, 0xAB, 0x71, 0x8F, 0xCE, 292 0x53, 0x29, 0x45, 0x74, 0x7A, 0x1E, 0xAA, 0x93, 0x19, 0x3A, 0x8D, 0xC9, 293 0x4E, 0xCB, 0x0E, 0x46, 0x53, 0x84, 0xCC, 0xCF, 0xBA, 0x4D, 0x28, 0x71, 294 0x1D, 0xDF, 0x41, 0xCB, 0xF8, 0x2D, 0xA9, 0x02, 0x81, 0x80, 0x04, 0x8B, 295 0x4A, 0xEA, 0xBD, 0x39, 0x0B, 0x96, 0xC5, 0x1D, 0xA4, 0x47, 0xFD, 0x46, 296 0xD2, 0x8A, 0xEA, 0x2A, 0xF3, 0x9D, 0x3A, 0x7E, 0x16, 0x74, 0xFC, 0x13, 297 0xDE, 0x4D, 0xA9, 0x85, 0x42, 0x33, 0x02, 0x92, 0x0B, 0xB6, 0xDB, 0x7E, 298 0xEA, 0x85, 0xC2, 0x94, 0x43, 0x52, 0x37, 0x5A, 0x77, 0xAB, 0xCB, 0x61, 299 0x88, 0xDE, 0xF8, 0xFA, 0xDB, 0xE8, 0x0B, 0x95, 0x7D, 0x39, 0x19, 0xA2, 300 0x89, 0xB9, 0x32, 0xB2, 0x50, 0x38, 0xF7, 0x88, 0x69, 0xFD, 0xA4, 0x63, 301 0x1F, 0x9B, 0x03, 0xD8, 0xA6, 0x7A, 0x05, 0x76, 0x02, 0x28, 0x93, 0x82, 302 0x73, 0x7F, 0x14, 0xCC, 0xBE, 0x29, 0x10, 0xAD, 0x8A, 0x2E, 0xAC, 0xED, 303 0x11, 0xA7, 0x72, 0x7C, 0x60, 0x78, 0x72, 0xFB, 0x78, 0x20, 0x18, 0xC9, 304 0x7E, 0x63, 0xAD, 0x55, 0x54, 0x51, 0xDB, 0x9F, 0x7B, 0xD4, 0x8F, 0xB2, 305 0xDE, 0x3B, 0xF1, 0x70, 0x23, 0xE5, 306 }; 307 308 /* 309 * DER-encoded PKCS#8 format EC key. Generated using: 310 * 311 * openssl ecparam -name prime256v1 -genkey -noout | openssl pkcs8 -topk8 -nocrypt -outform der | recode ../x1 312 */ 313 static uint8_t TEST_EC_KEY_1[] = { 314 0x30, 0x81, 0x87, 0x02, 0x01, 0x00, 0x30, 0x13, 0x06, 0x07, 0x2A, 0x86, 315 0x48, 0xCE, 0x3D, 0x02, 0x01, 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 316 0x03, 0x01, 0x07, 0x04, 0x6D, 0x30, 0x6B, 0x02, 0x01, 0x01, 0x04, 0x20, 317 0x25, 0xAC, 0x77, 0x2B, 0x04, 0x33, 0xC8, 0x16, 0x59, 0xA3, 0xC7, 0xE7, 318 0x11, 0x42, 0xD0, 0x11, 0x71, 0x30, 0x7B, 0xB8, 0xD2, 0x67, 0xFF, 0x9C, 319 0x5F, 0x50, 0x2E, 0xAB, 0x67, 0xD4, 0x17, 0x51, 0xA1, 0x44, 0x03, 0x42, 320 0x00, 0x04, 0xCF, 0xCE, 0xB8, 0x7F, 0x88, 0x36, 0xC4, 0xF8, 0x51, 0x29, 321 0xE2, 0xA7, 0x21, 0xC3, 0x3B, 0xFF, 0x88, 0xE3, 0x87, 0x98, 0xD1, 0xA6, 322 0x4B, 0xB3, 0x4B, 0xD5, 0x44, 0xF8, 0xE0, 0x43, 0x6B, 0x50, 0x74, 0xFB, 323 0xB0, 0xAD, 0x41, 0x1C, 0x11, 0x9D, 0xC6, 0x1E, 0x83, 0x8C, 0x49, 0xCA, 324 0xBE, 0xC6, 0xCE, 0xB6, 0xC9, 0xA1, 0xBF, 0x69, 0xA9, 0xA0, 0xA3, 0x80, 325 0x14, 0x39, 0x57, 0x94, 0xDA, 0x5D 326 }; 327 328 329 /* 330 * Generated using keys on the keyboard and lack of imagination. 331 */ 332 static unsigned char BOGUS_KEY_1[] = { 0xFF, 0xFF, 0xFF, 0xFF }; 333 334 335 class KeymasterBaseTest : public ::testing::Test { 336 public: 337 static void SetUpTestCase() { 338 const hw_module_t* mod; 339 ASSERT_EQ(0, hw_get_module_by_class(KEYSTORE_HARDWARE_MODULE_ID, NULL, &mod)) 340 << "Should be able to find a keymaster hardware module"; 341 342 std::cout << "Using keymaster module: " << mod->name << std::endl; 343 344 ASSERT_EQ(0, keymaster0_open(mod, &sDevice)) 345 << "Should be able to open the keymaster device"; 346 347 ASSERT_EQ(KEYMASTER_MODULE_API_VERSION_0_2, mod->module_api_version) 348 << "Keymaster should implement API version 2"; 349 350 ASSERT_TRUE(sDevice->generate_keypair != NULL) 351 << "Should implement generate_keypair"; 352 353 ASSERT_TRUE(sDevice->import_keypair != NULL) 354 << "Should implement import_keypair"; 355 356 ASSERT_TRUE(sDevice->get_keypair_public != NULL) 357 << "Should implement get_keypair_public"; 358 359 ASSERT_TRUE(sDevice->sign_data != NULL) 360 << "Should implement sign_data"; 361 362 ASSERT_TRUE(sDevice->verify_data != NULL) 363 << "Should implement verify_data"; 364 } 365 366 static void TearDownTestCase() { 367 ASSERT_EQ(0, keymaster0_close(sDevice)); 368 } 369 370 protected: 371 static keymaster0_device_t* sDevice; 372 }; 373 374 keymaster0_device_t* KeymasterBaseTest::sDevice = NULL; 375 376 class KeymasterTest : public KeymasterBaseTest { 377 }; 378 379 class KeymasterAllTypesTest : public KeymasterBaseTest, 380 public ::testing::WithParamInterface<keymaster_keypair_t> { 381 }; 382 383 class KeymasterGenerateRSATest : public KeymasterBaseTest, 384 public ::testing::WithParamInterface<uint32_t> { 385 }; 386 387 class KeymasterGenerateDSATest : public KeymasterBaseTest, 388 public ::testing::WithParamInterface<uint32_t> { 389 }; 390 391 class KeymasterGenerateECTest : public KeymasterBaseTest, 392 public ::testing::WithParamInterface<uint32_t> { 393 }; 394 395 TEST_P(KeymasterGenerateRSATest, GenerateKeyPair_RSA_Success) { 396 keymaster_keypair_t key_type = TYPE_RSA; 397 keymaster_rsa_keygen_params_t params = { 398 .modulus_size = GetParam(), 399 .public_exponent = RSA_F4, 400 }; 401 402 uint8_t* key_blob; 403 size_t key_blob_length; 404 405 ASSERT_EQ(0, 406 sDevice->generate_keypair(sDevice, key_type, ¶ms, &key_blob, &key_blob_length)) 407 << "Should generate an RSA key with " << GetParam() << " bit modulus size"; 408 UniqueKey key(&sDevice, key_blob, key_blob_length); 409 410 uint8_t* x509_data = NULL; 411 size_t x509_data_length; 412 ASSERT_EQ(0, 413 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 414 &x509_data, &x509_data_length)) 415 << "Should be able to retrieve RSA public key successfully"; 416 UniqueBlob x509_blob(x509_data, x509_data_length); 417 ASSERT_FALSE(x509_blob.get() == NULL) 418 << "X509 data should be allocated"; 419 420 const unsigned char *tmp = static_cast<const unsigned char*>(x509_blob.get()); 421 Unique_EVP_PKEY actual(d2i_PUBKEY((EVP_PKEY**) NULL, &tmp, 422 static_cast<long>(x509_blob.length()))); 423 424 ASSERT_EQ(EVP_PKEY_RSA, EVP_PKEY_type(actual.get()->type)) 425 << "Generated key type should be of type RSA"; 426 427 Unique_RSA rsa(EVP_PKEY_get1_RSA(actual.get())); 428 ASSERT_FALSE(rsa.get() == NULL) 429 << "Should be able to extract RSA key from EVP_PKEY"; 430 431 ASSERT_EQ(static_cast<unsigned long>(RSA_F4), BN_get_word(rsa.get()->e)) 432 << "Exponent should be RSA_F4"; 433 434 ASSERT_EQ((GetParam() + 7) / 8, static_cast<uint32_t>(RSA_size(rsa.get()))) 435 << "Modulus size should be the specified parameter"; 436 } 437 438 INSTANTIATE_TEST_CASE_P(RSA, 439 KeymasterGenerateRSATest, 440 ::testing::Values(512U, 1024U, 2048U, 3072U, 4096U)); 441 442 443 TEST_P(KeymasterGenerateECTest, GenerateKeyPair_EC_Success) { 444 keymaster_keypair_t key_type = TYPE_EC; 445 keymaster_ec_keygen_params_t params = { 446 .field_size = GetParam(), 447 }; 448 449 uint8_t* key_blob; 450 size_t key_blob_length; 451 452 ASSERT_EQ(0, 453 sDevice->generate_keypair(sDevice, key_type, ¶ms, &key_blob, &key_blob_length)) 454 << "Should generate an EC key with " << GetParam() << " field size"; 455 UniqueKey key(&sDevice, key_blob, key_blob_length); 456 457 uint8_t* x509_data = NULL; 458 size_t x509_data_length; 459 ASSERT_EQ(0, 460 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 461 &x509_data, &x509_data_length)) 462 << "Should be able to retrieve EC public key successfully"; 463 UniqueBlob x509_blob(x509_data, x509_data_length); 464 ASSERT_FALSE(x509_blob.get() == NULL) 465 << "X509 data should be allocated"; 466 467 const unsigned char *tmp = static_cast<const unsigned char*>(x509_blob.get()); 468 Unique_EVP_PKEY actual(d2i_PUBKEY((EVP_PKEY**) NULL, &tmp, 469 static_cast<long>(x509_blob.length()))); 470 471 ASSERT_EQ(EVP_PKEY_EC, EVP_PKEY_type(actual.get()->type)) 472 << "Generated key type should be of type EC"; 473 474 Unique_EC_KEY ecKey(EVP_PKEY_get1_EC_KEY(actual.get())); 475 ASSERT_FALSE(ecKey.get() == NULL) 476 << "Should be able to extract EC key from EVP_PKEY"; 477 478 ASSERT_FALSE(EC_KEY_get0_group(ecKey.get()) == NULL) 479 << "EC key should have a EC_GROUP"; 480 481 ASSERT_TRUE(EC_KEY_check_key(ecKey.get())) 482 << "EC key should check correctly"; 483 } 484 485 INSTANTIATE_TEST_CASE_P(EC, 486 KeymasterGenerateECTest, 487 ::testing::Values(192U, 224U, 256U, 384U, 521U)); 488 489 490 TEST_P(KeymasterAllTypesTest, GenerateKeyPair_NullParams_Failure) { 491 keymaster_keypair_t key_type = GetParam(); 492 493 uint8_t* key_blob; 494 size_t key_blob_length; 495 496 ASSERT_EQ(-1, 497 sDevice->generate_keypair(sDevice, key_type, NULL, &key_blob, &key_blob_length)) 498 << "Should not be able to generate a key with null params"; 499 } 500 501 INSTANTIATE_TEST_CASE_P(Types, 502 KeymasterAllTypesTest, 503 ::testing::Values(TYPE_RSA, TYPE_DSA, TYPE_EC)); 504 505 TEST_F(KeymasterTest, GenerateKeyPair_UnknownType_Failure) { 506 keymaster_keypair_t key_type = static_cast<keymaster_keypair_t>(0xFFFF); 507 508 uint8_t* key_blob; 509 size_t key_blob_length; 510 511 ASSERT_EQ(-1, 512 sDevice->generate_keypair(sDevice, key_type, NULL, &key_blob, &key_blob_length)) 513 << "Should not generate an unknown key type"; 514 } 515 516 TEST_F(KeymasterTest, ImportKeyPair_RSA_Success) { 517 uint8_t* key_blob; 518 size_t key_blob_length; 519 520 ASSERT_EQ(0, 521 sDevice->import_keypair(sDevice, TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1), 522 &key_blob, &key_blob_length)) 523 << "Should successfully import an RSA key"; 524 UniqueKey key(&sDevice, key_blob, key_blob_length); 525 526 uint8_t* x509_data; 527 size_t x509_data_length; 528 ASSERT_EQ(0, 529 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 530 &x509_data, &x509_data_length)) 531 << "Should be able to retrieve RSA public key successfully"; 532 UniqueBlob x509_blob(x509_data, x509_data_length); 533 534 const unsigned char *tmp = static_cast<const unsigned char*>(x509_blob.get()); 535 Unique_EVP_PKEY actual(d2i_PUBKEY((EVP_PKEY**) NULL, &tmp, 536 static_cast<long>(x509_blob.length()))); 537 538 ASSERT_EQ(EVP_PKEY_type(actual.get()->type), EVP_PKEY_RSA) 539 << "Generated key type should be of type RSA"; 540 541 const unsigned char *expectedTmp = static_cast<const unsigned char*>(TEST_RSA_KEY_1); 542 Unique_PKCS8_PRIV_KEY_INFO expectedPkcs8( 543 d2i_PKCS8_PRIV_KEY_INFO((PKCS8_PRIV_KEY_INFO**) NULL, &expectedTmp, 544 sizeof(TEST_RSA_KEY_1))); 545 546 Unique_EVP_PKEY expected(EVP_PKCS82PKEY(expectedPkcs8.get())); 547 548 ASSERT_EQ(1, EVP_PKEY_cmp(expected.get(), actual.get())) 549 << "Expected and actual keys should match"; 550 } 551 552 TEST_F(KeymasterTest, ImportKeyPair_EC_Success) { 553 uint8_t* key_blob; 554 size_t key_blob_length; 555 556 ASSERT_EQ(0, 557 sDevice->import_keypair(sDevice, TEST_EC_KEY_1, sizeof(TEST_EC_KEY_1), 558 &key_blob, &key_blob_length)) 559 << "Should successfully import an EC key"; 560 UniqueKey key(&sDevice, key_blob, key_blob_length); 561 562 uint8_t* x509_data; 563 size_t x509_data_length; 564 ASSERT_EQ(0, 565 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 566 &x509_data, &x509_data_length)) 567 << "Should be able to retrieve EC public key successfully"; 568 UniqueBlob x509_blob(x509_data, x509_data_length); 569 570 const unsigned char *tmp = static_cast<const unsigned char*>(x509_blob.get()); 571 Unique_EVP_PKEY actual(d2i_PUBKEY((EVP_PKEY**) NULL, &tmp, 572 static_cast<long>(x509_blob.length()))); 573 574 ASSERT_EQ(EVP_PKEY_type(actual.get()->type), EVP_PKEY_EC) 575 << "Generated key type should be of type EC"; 576 577 const unsigned char *expectedTmp = static_cast<const unsigned char*>(TEST_EC_KEY_1); 578 Unique_PKCS8_PRIV_KEY_INFO expectedPkcs8( 579 d2i_PKCS8_PRIV_KEY_INFO((PKCS8_PRIV_KEY_INFO**) NULL, &expectedTmp, 580 sizeof(TEST_EC_KEY_1))); 581 582 Unique_EVP_PKEY expected(EVP_PKCS82PKEY(expectedPkcs8.get())); 583 584 ASSERT_EQ(1, EVP_PKEY_cmp(expected.get(), actual.get())) 585 << "Expected and actual keys should match"; 586 } 587 588 TEST_F(KeymasterTest, ImportKeyPair_BogusKey_Failure) { 589 uint8_t* key_blob; 590 size_t key_blob_length; 591 592 ASSERT_EQ(-1, 593 sDevice->import_keypair(sDevice, BOGUS_KEY_1, sizeof(BOGUS_KEY_1), 594 &key_blob, &key_blob_length)) 595 << "Should not import an unknown key type"; 596 } 597 598 TEST_F(KeymasterTest, ImportKeyPair_NullKey_Failure) { 599 uint8_t* key_blob; 600 size_t key_blob_length; 601 602 ASSERT_EQ(-1, 603 sDevice->import_keypair(sDevice, NULL, 0, 604 &key_blob, &key_blob_length)) 605 << "Should not import a null key"; 606 } 607 608 TEST_F(KeymasterTest, GetKeypairPublic_RSA_Success) { 609 uint8_t* key_blob; 610 size_t key_blob_length; 611 612 UniqueReadOnlyBlob testKey(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 613 ASSERT_TRUE(testKey.get() != NULL); 614 615 ASSERT_EQ(0, 616 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 617 &key_blob, &key_blob_length)) 618 << "Should successfully import an RSA key"; 619 UniqueKey key(&sDevice, key_blob, key_blob_length); 620 621 uint8_t* x509_data; 622 size_t x509_data_length; 623 ASSERT_EQ(0, 624 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 625 &x509_data, &x509_data_length)) 626 << "Should be able to retrieve RSA public key successfully"; 627 UniqueBlob x509_blob(x509_data, x509_data_length); 628 } 629 630 TEST_F(KeymasterTest, GetKeypairPublic_EC_Success) { 631 uint8_t* key_blob; 632 size_t key_blob_length; 633 634 UniqueReadOnlyBlob testKey(TEST_EC_KEY_1, sizeof(TEST_EC_KEY_1)); 635 ASSERT_TRUE(testKey.get() != NULL); 636 637 ASSERT_EQ(0, 638 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 639 &key_blob, &key_blob_length)) 640 << "Should successfully import an EC key"; 641 UniqueKey key(&sDevice, key_blob, key_blob_length); 642 643 uint8_t* x509_data; 644 size_t x509_data_length; 645 ASSERT_EQ(0, 646 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 647 &x509_data, &x509_data_length)) 648 << "Should be able to retrieve EC public key successfully"; 649 UniqueBlob x509_blob(x509_data, x509_data_length); 650 } 651 652 TEST_F(KeymasterTest, GetKeypairPublic_NullKey_Failure) { 653 uint8_t* key_blob; 654 size_t key_blob_length; 655 656 uint8_t* x509_data = NULL; 657 size_t x509_data_length; 658 ASSERT_EQ(-1, 659 sDevice->get_keypair_public(sDevice, NULL, 0, 660 &x509_data, &x509_data_length)) 661 << "Should not be able to retrieve public key from null key"; 662 UniqueBlob x509_blob(x509_data, x509_data_length); 663 } 664 665 TEST_F(KeymasterTest, GetKeypairPublic_RSA_NullDestination_Failure) { 666 uint8_t* key_blob; 667 size_t key_blob_length; 668 669 UniqueReadOnlyBlob testKey(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 670 ASSERT_TRUE(testKey.get() != NULL); 671 672 ASSERT_EQ(0, 673 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 674 &key_blob, &key_blob_length)) 675 << "Should successfully import an RSA key"; 676 UniqueKey key(&sDevice, key_blob, key_blob_length); 677 678 ASSERT_EQ(-1, 679 sDevice->get_keypair_public(sDevice, key.get(), key.length(), 680 NULL, NULL)) 681 << "Should not be able to succeed with NULL destination blob"; 682 } 683 684 TEST_F(KeymasterTest, GetKeypairPublic_EC_NullDestination_Failure) { 685 uint8_t* key_blob; 686 size_t key_blob_length; 687 688 UniqueReadOnlyBlob testKey(TEST_EC_KEY_1, sizeof(TEST_EC_KEY_1)); 689 ASSERT_TRUE(testKey.get() != NULL); 690 691 ASSERT_EQ(0, 692 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 693 &key_blob, &key_blob_length)) 694 << "Should successfully import an RSA key"; 695 UniqueKey key(&sDevice, key_blob, key_blob_length); 696 697 ASSERT_EQ(-1, 698 sDevice->get_keypair_public(sDevice, key.get(), key.length(), 699 NULL, NULL)) 700 << "Should not be able to succeed with NULL destination blob"; 701 } 702 703 TEST_F(KeymasterTest, DeleteKeyPair_RSA_Success) { 704 uint8_t* key_blob; 705 size_t key_blob_length; 706 707 UniqueReadOnlyBlob testKey(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 708 ASSERT_TRUE(testKey.get() != NULL); 709 710 ASSERT_EQ(0, 711 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 712 &key_blob, &key_blob_length)) 713 << "Should successfully import an RSA key"; 714 UniqueKey key(&sDevice, key_blob, key_blob_length); 715 } 716 717 TEST_F(KeymasterTest, DeleteKeyPair_RSA_DoubleDelete_Failure) { 718 uint8_t* key_blob; 719 size_t key_blob_length; 720 721 UniqueReadOnlyBlob testKey(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 722 ASSERT_TRUE(testKey.get() != NULL); 723 724 /* 725 * This is only run if the module indicates it implements key deletion 726 * by implementing delete_keypair. 727 */ 728 if (sDevice->delete_keypair != NULL) { 729 ASSERT_EQ(0, 730 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 731 &key_blob, &key_blob_length)) 732 << "Should successfully import an RSA key"; 733 UniqueBlob blob(key_blob, key_blob_length); 734 735 ASSERT_EQ(0, sDevice->delete_keypair(sDevice, key_blob, key_blob_length)) 736 << "Should delete key after import"; 737 738 ASSERT_EQ(-1, sDevice->delete_keypair(sDevice, key_blob, key_blob_length)) 739 << "Should not be able to delete key twice"; 740 } 741 } 742 743 TEST_F(KeymasterTest, DeleteKeyPair_RSA_NullKey_Failure) { 744 /* 745 * This is only run if the module indicates it implements key deletion 746 * by implementing delete_keypair. 747 */ 748 if (sDevice->delete_keypair != NULL) { 749 ASSERT_EQ(-1, sDevice->delete_keypair(sDevice, NULL, 0)) 750 << "Should not be able to delete null key"; 751 } 752 } 753 754 /* 755 * DER-encoded PKCS#8 format RSA key. Generated using: 756 * 757 * openssl genrsa 512 | openssl pkcs8 -topk8 -nocrypt -outform der | recode ../x1 758 */ 759 static uint8_t TEST_SIGN_RSA_KEY_1[] = { 760 0x30, 0x82, 0x01, 0x56, 0x02, 0x01, 0x00, 0x30, 0x0D, 0x06, 0x09, 0x2A, 761 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82, 762 0x01, 0x40, 0x30, 0x82, 0x01, 0x3C, 0x02, 0x01, 0x00, 0x02, 0x41, 0x00, 763 0xBD, 0xC0, 0x7F, 0xEF, 0x75, 0x1D, 0x63, 0x2A, 0xD0, 0x9A, 0x26, 0xE5, 764 0x5B, 0xB9, 0x84, 0x7C, 0xE5, 0xC7, 0xE7, 0xDE, 0xFE, 0xB6, 0x54, 0xD9, 765 0xF0, 0x9B, 0xC2, 0xCF, 0x36, 0xDA, 0xE5, 0x4D, 0xC5, 0xD9, 0x25, 0x78, 766 0xBD, 0x55, 0x05, 0xBD, 0x86, 0xFB, 0x37, 0x15, 0x33, 0x42, 0x52, 0xED, 767 0xE5, 0xCD, 0xCB, 0xB7, 0xA2, 0x51, 0xFA, 0x36, 0xE9, 0x9C, 0x2E, 0x5D, 768 0xE3, 0xA5, 0x1F, 0x01, 0x02, 0x03, 0x01, 0x00, 0x01, 0x02, 0x41, 0x00, 769 0x96, 0x71, 0xDE, 0xBD, 0x83, 0x94, 0x96, 0x40, 0xA6, 0xFD, 0xE1, 0xA2, 770 0xED, 0xD3, 0xAC, 0x28, 0xBE, 0xA2, 0x7D, 0xC3, 0xFF, 0x1D, 0x9F, 0x2E, 771 0xE0, 0xA7, 0x0E, 0x90, 0xEE, 0x44, 0x25, 0x92, 0xE3, 0x54, 0xDD, 0x55, 772 0xA3, 0xEF, 0x42, 0xF5, 0x52, 0x55, 0x41, 0x47, 0x5E, 0x00, 0xFB, 0x8B, 773 0x47, 0x5E, 0x45, 0x49, 0xEA, 0x3D, 0x2C, 0xFD, 0x9F, 0xEC, 0xC8, 0x4E, 774 0x4E, 0x86, 0x90, 0x31, 0x02, 0x21, 0x00, 0xE6, 0xA5, 0x55, 0xB3, 0x64, 775 0xAB, 0x90, 0x5E, 0xA2, 0xF5, 0x6B, 0x21, 0x4B, 0x15, 0xD6, 0x4A, 0xB6, 776 0x60, 0x24, 0x95, 0x65, 0xA2, 0xBE, 0xBA, 0x2A, 0x73, 0xFB, 0xFF, 0x2C, 777 0x61, 0x88, 0x9D, 0x02, 0x21, 0x00, 0xD2, 0x9C, 0x5B, 0xFE, 0x82, 0xA5, 778 0xFC, 0x52, 0x6A, 0x29, 0x38, 0xDB, 0x22, 0x3B, 0xEB, 0x74, 0x3B, 0xCA, 779 0xB4, 0xDD, 0x1D, 0xE4, 0x48, 0x60, 0x70, 0x19, 0x9B, 0x81, 0xC1, 0x83, 780 0x28, 0xB5, 0x02, 0x21, 0x00, 0x89, 0x2D, 0xFE, 0xF9, 0xF2, 0xBF, 0x43, 781 0xDF, 0xB5, 0xA6, 0xA8, 0x30, 0x26, 0x1B, 0x77, 0xD7, 0xF9, 0xFE, 0xD6, 782 0xE3, 0x70, 0x8E, 0xCA, 0x47, 0xA9, 0xA6, 0x50, 0x54, 0x25, 0xCE, 0x60, 783 0xD5, 0x02, 0x21, 0x00, 0xBE, 0x5A, 0xF8, 0x82, 0xE6, 0xCE, 0xE3, 0x6A, 784 0x11, 0xED, 0xC4, 0x27, 0xBB, 0x9F, 0x70, 0xC6, 0x93, 0xAC, 0x39, 0x20, 785 0x89, 0x7D, 0xE5, 0x34, 0xD4, 0xDD, 0x30, 0x42, 0x6D, 0x07, 0x00, 0xE9, 786 0x02, 0x20, 0x05, 0x91, 0xEF, 0x12, 0xD2, 0xD3, 0x6A, 0xD2, 0x96, 0x6B, 787 0x10, 0x62, 0xF9, 0xBA, 0xA4, 0x91, 0x48, 0x84, 0x40, 0x61, 0x67, 0x80, 788 0x68, 0x68, 0xC8, 0x60, 0xB3, 0x66, 0xC8, 0xF9, 0x08, 0x9A, 789 }; 790 791 /* 792 * DER-encoded PKCS#8 format EC key. Generated using: 793 * 794 * openssl ecparam -name prime256v1 -genkey -noout | openssl pkcs8 -topk8 -nocrypt -outform der | recode ../x1 795 */ 796 static uint8_t TEST_SIGN_EC_KEY_1[] = { 797 0x30, 0x81, 0x87, 0x02, 0x01, 0x00, 0x30, 0x13, 0x06, 0x07, 0x2A, 0x86, 798 0x48, 0xCE, 0x3D, 0x02, 0x01, 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 799 0x03, 0x01, 0x07, 0x04, 0x6D, 0x30, 0x6B, 0x02, 0x01, 0x01, 0x04, 0x20, 800 0x9E, 0x66, 0x11, 0x6A, 0x89, 0xF5, 0x78, 0x57, 0xF3, 0x35, 0xA2, 0x46, 801 0x09, 0x06, 0x4B, 0x4D, 0x81, 0xEC, 0xD3, 0x9B, 0x0A, 0xC4, 0x68, 0x06, 802 0xB8, 0x42, 0x24, 0x5E, 0x74, 0x2C, 0x62, 0x79, 0xA1, 0x44, 0x03, 0x42, 803 0x00, 0x04, 0x35, 0xB5, 0x9A, 0x5C, 0xE5, 0x52, 0x35, 0xF2, 0x10, 0x6C, 804 0xD9, 0x98, 0x67, 0xED, 0x5E, 0xCB, 0x6B, 0xB8, 0x96, 0x5E, 0x54, 0x7C, 805 0x34, 0x2A, 0xA3, 0x3B, 0xF3, 0xD1, 0x39, 0x48, 0x36, 0x7A, 0xEA, 0xD8, 806 0xCA, 0xDD, 0x40, 0x8F, 0xE9, 0xE0, 0x95, 0x2E, 0x3F, 0x95, 0x0F, 0x14, 807 0xD6, 0x14, 0x78, 0xB5, 0xAD, 0x17, 0xD2, 0x5A, 0x41, 0x96, 0x99, 0x20, 808 0xC7, 0x5B, 0x0F, 0x60, 0xFD, 0xBA 809 }; 810 811 /* 812 * PKCS#1 v1.5 padded raw "Hello, world" Can be generated be generated by verifying 813 * the signature below in no padding mode: 814 * 815 * openssl rsautl -keyform der -inkey rsa.der -raw -verify -in test.sig 816 */ 817 static uint8_t TEST_SIGN_DATA_1[] = { 818 0x00, 0x01, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 819 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 820 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 821 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 822 0xFF, 0xFF, 0xFF, 0x00, 0x48, 0x65, 0x6C, 0x6C, 0x6F, 0x2C, 0x20, 0x77, 823 0x6F, 0x72, 0x6C, 0x64, 824 }; 825 826 /* 827 * Signature of TEST_SIGN_DATA_1 using TEST_SIGN_RSA_KEY_1. Generated using: 828 * 829 * echo 'Hello, world' | openssl rsautl -keyform der -inkey rsa.der -sign | recode ../x1 830 */ 831 static uint8_t TEST_SIGN_RSA_SIGNATURE_1[] = { 832 0xA4, 0xBB, 0x76, 0x87, 0xFE, 0x61, 0x0C, 0x9D, 0xD6, 0xFF, 0x4B, 0x76, 833 0x96, 0x08, 0x36, 0x23, 0x11, 0xC6, 0x44, 0x3F, 0x88, 0x77, 0x97, 0xB2, 834 0xA8, 0x3B, 0xFB, 0x9C, 0x3C, 0xD3, 0x20, 0x65, 0xFD, 0x26, 0x3B, 0x2A, 835 0xB8, 0xB6, 0xD4, 0xDC, 0x91, 0xF7, 0xE2, 0xDE, 0x4D, 0xF7, 0x0E, 0xB9, 836 0x72, 0xA7, 0x29, 0x72, 0x82, 0x12, 0x7C, 0x53, 0x23, 0x21, 0xC4, 0xFF, 837 0x79, 0xE4, 0x91, 0x40, 838 }; 839 840 /* 841 * Identical to TEST_SIGN_RSA_SIGNATURE_1 except the last octet is '1' instead of '0' 842 * This should fail any test. 843 */ 844 static uint8_t TEST_SIGN_SIGNATURE_BOGUS_1[] = { 845 0xA4, 0xBB, 0x76, 0x87, 0xFE, 0x61, 0x0C, 0x9D, 0xD6, 0xFF, 0x4B, 0x76, 846 0x96, 0x08, 0x36, 0x23, 0x11, 0xC6, 0x44, 0x3F, 0x88, 0x77, 0x97, 0xB2, 847 0xA8, 0x3B, 0xFB, 0x9C, 0x3C, 0xD3, 0x20, 0x65, 0xFD, 0x26, 0x3B, 0x2A, 848 0xB8, 0xB6, 0xD4, 0xDC, 0x91, 0xF7, 0xE2, 0xDE, 0x4D, 0xF7, 0x0E, 0xB9, 849 0x72, 0xA7, 0x29, 0x72, 0x82, 0x12, 0x7C, 0x53, 0x23, 0x21, 0xC4, 0xFF, 850 0x79, 0xE4, 0x91, 0x41, 851 }; 852 853 TEST_F(KeymasterTest, SignData_RSA_Raw_Success) { 854 uint8_t* key_blob; 855 size_t key_blob_length; 856 857 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 858 ASSERT_TRUE(testKey.get() != NULL); 859 860 ASSERT_EQ(0, 861 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 862 &key_blob, &key_blob_length)) 863 << "Should successfully import an RSA key"; 864 UniqueKey key(&sDevice, key_blob, key_blob_length); 865 866 keymaster_rsa_sign_params_t params = { 867 .digest_type = DIGEST_NONE, 868 .padding_type = PADDING_NONE, 869 }; 870 871 uint8_t* sig; 872 size_t sig_length; 873 874 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 875 ASSERT_TRUE(testData.get() != NULL); 876 877 ASSERT_EQ(0, 878 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 879 testData.get(), testData.length(), 880 &sig, &sig_length)) 881 << "Should sign data successfully"; 882 UniqueBlob sig_blob(sig, sig_length); 883 884 UniqueBlob expected_sig(TEST_SIGN_RSA_SIGNATURE_1, sizeof(TEST_SIGN_RSA_SIGNATURE_1)); 885 886 ASSERT_EQ(expected_sig, sig_blob) 887 << "Generated signature should match expected signature"; 888 889 // The expected signature is actually stack data, so don't let it try to free. 890 uint8_t* unused __attribute__((unused)) = expected_sig.release(); 891 } 892 893 TEST_F(KeymasterTest, SignData_EC_Success) { 894 uint8_t* key_blob; 895 size_t key_blob_length; 896 897 UniqueReadOnlyBlob testKey(TEST_SIGN_EC_KEY_1, sizeof(TEST_SIGN_EC_KEY_1)); 898 ASSERT_TRUE(testKey.get() != NULL); 899 900 ASSERT_EQ(0, 901 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 902 &key_blob, &key_blob_length)) 903 << "Should successfully import an EC key"; 904 UniqueKey key(&sDevice, key_blob, key_blob_length); 905 906 keymaster_ec_sign_params_t params = { 907 .digest_type = DIGEST_NONE, 908 }; 909 910 uint8_t* sig; 911 size_t sig_length; 912 913 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 914 ASSERT_TRUE(testData.get() != NULL); 915 916 ASSERT_EQ(0, 917 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 918 testData.get(), testData.length(), 919 &sig, &sig_length)) 920 << "Should sign data successfully"; 921 UniqueBlob sig_blob(sig, sig_length); 922 923 uint8_t* x509_data; 924 size_t x509_data_length; 925 ASSERT_EQ(0, 926 sDevice->get_keypair_public(sDevice, key_blob, key_blob_length, 927 &x509_data, &x509_data_length)) 928 << "Should be able to retrieve RSA public key successfully"; 929 UniqueBlob x509_blob(x509_data, x509_data_length); 930 931 const unsigned char *tmp = static_cast<const unsigned char*>(x509_blob.get()); 932 Unique_EVP_PKEY expected(d2i_PUBKEY((EVP_PKEY**) NULL, &tmp, 933 static_cast<long>(x509_blob.length()))); 934 935 Unique_EC_KEY ecKey(EVP_PKEY_get1_EC_KEY(expected.get())); 936 937 ASSERT_EQ(1, ECDSA_verify(0, testData.get(), testData.length(), sig_blob.get(), sig_blob.length(), ecKey.get())) 938 << "Signature should verify"; 939 } 940 941 TEST_F(KeymasterTest, SignData_RSA_Raw_InvalidSizeInput_Failure) { 942 uint8_t* key_blob; 943 size_t key_blob_length; 944 945 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 946 ASSERT_TRUE(testKey.get() != NULL); 947 948 ASSERT_EQ(0, 949 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 950 &key_blob, &key_blob_length)) 951 << "Should successfully import an RSA key"; 952 UniqueKey key(&sDevice, key_blob, key_blob_length); 953 954 keymaster_rsa_sign_params_t params = { 955 .digest_type = DIGEST_NONE, 956 .padding_type = PADDING_NONE, 957 }; 958 959 uint8_t* sig; 960 size_t sig_length; 961 962 UniqueReadOnlyBlob testData(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 963 ASSERT_TRUE(testData.get() != NULL); 964 965 ASSERT_EQ(-1, 966 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 967 testData.get(), testData.length(), 968 &sig, &sig_length)) 969 << "Should not be able to do raw signature on incorrect size data"; 970 } 971 972 TEST_F(KeymasterTest, SignData_RSA_Raw_NullKey_Failure) { 973 keymaster_rsa_sign_params_t params = { 974 .digest_type = DIGEST_NONE, 975 .padding_type = PADDING_NONE, 976 }; 977 978 uint8_t* sig; 979 size_t sig_length; 980 981 UniqueReadOnlyBlob testData(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 982 ASSERT_TRUE(testData.get() != NULL); 983 984 ASSERT_EQ(-1, 985 sDevice->sign_data(sDevice, ¶ms, NULL, 0, 986 testData.get(), testData.length(), 987 &sig, &sig_length)) 988 << "Should not be able to do raw signature on incorrect size data"; 989 } 990 991 TEST_F(KeymasterTest, SignData_RSA_Raw_NullInput_Failure) { 992 uint8_t* key_blob; 993 size_t key_blob_length; 994 995 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 996 ASSERT_TRUE(testKey.get() != NULL); 997 998 ASSERT_EQ(0, 999 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1000 &key_blob, &key_blob_length)) 1001 << "Should successfully import an RSA key"; 1002 UniqueKey key(&sDevice, key_blob, key_blob_length); 1003 1004 keymaster_rsa_sign_params_t params = { 1005 .digest_type = DIGEST_NONE, 1006 .padding_type = PADDING_NONE, 1007 }; 1008 1009 uint8_t* sig; 1010 size_t sig_length; 1011 1012 ASSERT_EQ(-1, 1013 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 1014 NULL, 0, 1015 &sig, &sig_length)) 1016 << "Should error when input data is null"; 1017 } 1018 1019 TEST_F(KeymasterTest, SignData_RSA_Raw_NullOutput_Failure) { 1020 uint8_t* key_blob; 1021 size_t key_blob_length; 1022 1023 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1024 ASSERT_TRUE(testKey.get() != NULL); 1025 1026 ASSERT_EQ(0, 1027 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1028 &key_blob, &key_blob_length)) 1029 << "Should successfully import an RSA key"; 1030 UniqueKey key(&sDevice, key_blob, key_blob_length); 1031 1032 keymaster_rsa_sign_params_t params = { 1033 .digest_type = DIGEST_NONE, 1034 .padding_type = PADDING_NONE, 1035 }; 1036 1037 uint8_t* sig; 1038 size_t sig_length; 1039 1040 UniqueReadOnlyBlob testData(TEST_RSA_KEY_1, sizeof(TEST_RSA_KEY_1)); 1041 ASSERT_TRUE(testData.get() != NULL); 1042 1043 ASSERT_EQ(-1, 1044 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 1045 testData.get(), testData.length(), 1046 NULL, NULL)) 1047 << "Should error when output is null"; 1048 } 1049 1050 TEST_F(KeymasterTest, VerifyData_RSA_Raw_Success) { 1051 uint8_t* key_blob; 1052 size_t key_blob_length; 1053 1054 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1055 ASSERT_TRUE(testKey.get() != NULL); 1056 1057 ASSERT_EQ(0, 1058 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1059 &key_blob, &key_blob_length)) 1060 << "Should successfully import an RSA key"; 1061 UniqueKey key(&sDevice, key_blob, key_blob_length); 1062 1063 keymaster_rsa_sign_params_t params = { 1064 .digest_type = DIGEST_NONE, 1065 .padding_type = PADDING_NONE, 1066 }; 1067 1068 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 1069 ASSERT_TRUE(testData.get() != NULL); 1070 1071 UniqueReadOnlyBlob testSig(TEST_SIGN_RSA_SIGNATURE_1, sizeof(TEST_SIGN_RSA_SIGNATURE_1)); 1072 ASSERT_TRUE(testSig.get() != NULL); 1073 1074 ASSERT_EQ(0, 1075 sDevice->verify_data(sDevice, ¶ms, key_blob, key_blob_length, 1076 testData.get(), testData.length(), 1077 testSig.get(), testSig.length())) 1078 << "Should verify data successfully"; 1079 } 1080 1081 TEST_F(KeymasterTest, VerifyData_EC_Raw_Success) { 1082 uint8_t* key_blob; 1083 size_t key_blob_length; 1084 1085 UniqueReadOnlyBlob testKey(TEST_SIGN_EC_KEY_1, sizeof(TEST_SIGN_EC_KEY_1)); 1086 ASSERT_TRUE(testKey.get() != NULL); 1087 1088 ASSERT_EQ(0, 1089 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1090 &key_blob, &key_blob_length)) 1091 << "Should successfully import an RSA key"; 1092 UniqueKey key(&sDevice, key_blob, key_blob_length); 1093 1094 keymaster_ec_sign_params_t params = { 1095 .digest_type = DIGEST_NONE, 1096 }; 1097 1098 uint8_t* sig; 1099 size_t sig_length; 1100 1101 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 1102 ASSERT_TRUE(testData.get() != NULL); 1103 1104 ASSERT_EQ(0, 1105 sDevice->sign_data(sDevice, ¶ms, key_blob, key_blob_length, 1106 testData.get(), testData.length(), 1107 &sig, &sig_length)) 1108 << "Should sign data successfully"; 1109 UniqueBlob sig_blob(sig, sig_length); 1110 1111 ASSERT_EQ(0, 1112 sDevice->verify_data(sDevice, ¶ms, key_blob, key_blob_length, 1113 testData.get(), testData.length(), 1114 sig_blob.get(), sig_blob.length())) 1115 << "Should verify data successfully"; 1116 } 1117 1118 TEST_F(KeymasterTest, VerifyData_RSA_Raw_BadSignature_Failure) { 1119 uint8_t* key_blob; 1120 size_t key_blob_length; 1121 1122 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1123 ASSERT_TRUE(testKey.get() != NULL); 1124 1125 ASSERT_EQ(0, 1126 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1127 &key_blob, &key_blob_length)) 1128 << "Should successfully import an RSA key"; 1129 UniqueKey key(&sDevice, key_blob, key_blob_length); 1130 1131 keymaster_rsa_sign_params_t params = { 1132 .digest_type = DIGEST_NONE, 1133 .padding_type = PADDING_NONE, 1134 }; 1135 1136 ASSERT_EQ(-1, 1137 sDevice->verify_data(sDevice, ¶ms, key_blob, key_blob_length, 1138 TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1), 1139 TEST_SIGN_SIGNATURE_BOGUS_1, sizeof(TEST_SIGN_SIGNATURE_BOGUS_1))) 1140 << "Should sign data successfully"; 1141 } 1142 1143 TEST_F(KeymasterTest, VerifyData_EC_Raw_BadSignature_Failure) { 1144 uint8_t* key_blob; 1145 size_t key_blob_length; 1146 1147 UniqueReadOnlyBlob testKey(TEST_SIGN_EC_KEY_1, sizeof(TEST_SIGN_EC_KEY_1)); 1148 ASSERT_TRUE(testKey.get() != NULL); 1149 1150 ASSERT_EQ(0, 1151 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1152 &key_blob, &key_blob_length)) 1153 << "Should successfully import an RSA key"; 1154 UniqueKey key(&sDevice, key_blob, key_blob_length); 1155 1156 keymaster_ec_sign_params_t params = { 1157 .digest_type = DIGEST_NONE, 1158 }; 1159 1160 ASSERT_EQ(-1, 1161 sDevice->verify_data(sDevice, ¶ms, key_blob, key_blob_length, 1162 TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1), 1163 TEST_SIGN_SIGNATURE_BOGUS_1, sizeof(TEST_SIGN_SIGNATURE_BOGUS_1))) 1164 << "Should sign data successfully"; 1165 } 1166 1167 TEST_F(KeymasterTest, VerifyData_RSA_Raw_NullKey_Failure) { 1168 keymaster_rsa_sign_params_t params = { 1169 .digest_type = DIGEST_NONE, 1170 .padding_type = PADDING_NONE, 1171 }; 1172 1173 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 1174 ASSERT_TRUE(testData.get() != NULL); 1175 1176 UniqueReadOnlyBlob testSig(TEST_SIGN_SIGNATURE_BOGUS_1, sizeof(TEST_SIGN_SIGNATURE_BOGUS_1)); 1177 ASSERT_TRUE(testSig.get() != NULL); 1178 1179 ASSERT_EQ(-1, 1180 sDevice->verify_data(sDevice, ¶ms, NULL, 0, 1181 testData.get(), testData.length(), 1182 testSig.get(), testSig.length())) 1183 << "Should fail when key is null"; 1184 } 1185 1186 TEST_F(KeymasterTest, VerifyData_RSA_NullInput_Failure) { 1187 uint8_t* key_blob; 1188 size_t key_blob_length; 1189 1190 ASSERT_EQ(0, 1191 sDevice->import_keypair(sDevice, TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1), 1192 &key_blob, &key_blob_length)) 1193 << "Should successfully import an RSA key"; 1194 UniqueKey key(&sDevice, key_blob, key_blob_length); 1195 1196 keymaster_rsa_sign_params_t params = { 1197 .digest_type = DIGEST_NONE, 1198 .padding_type = PADDING_NONE, 1199 }; 1200 1201 UniqueReadOnlyBlob testSig(TEST_SIGN_RSA_SIGNATURE_1, sizeof(TEST_SIGN_RSA_SIGNATURE_1)); 1202 ASSERT_TRUE(testSig.get() != NULL); 1203 1204 ASSERT_EQ(-1, 1205 sDevice->verify_data(sDevice, ¶ms, key_blob, key_blob_length, 1206 NULL, 0, 1207 testSig.get(), testSig.length())) 1208 << "Should fail on null input"; 1209 } 1210 1211 TEST_F(KeymasterTest, VerifyData_RSA_NullSignature_Failure) { 1212 uint8_t* key_blob; 1213 size_t key_blob_length; 1214 1215 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1216 ASSERT_TRUE(testKey.get() != NULL); 1217 1218 ASSERT_EQ(0, 1219 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1220 &key_blob, &key_blob_length)) 1221 << "Should successfully import an RSA key"; 1222 UniqueKey key(&sDevice, key_blob, key_blob_length); 1223 1224 keymaster_rsa_sign_params_t params = { 1225 .digest_type = DIGEST_NONE, 1226 .padding_type = PADDING_NONE, 1227 }; 1228 1229 UniqueReadOnlyBlob testData(TEST_SIGN_DATA_1, sizeof(TEST_SIGN_DATA_1)); 1230 ASSERT_TRUE(testData.get() != NULL); 1231 1232 ASSERT_EQ(-1, 1233 sDevice->verify_data(sDevice, ¶ms, key.get(), key.length(), 1234 testData.get(), testData.length(), 1235 NULL, 0)) 1236 << "Should fail on null signature"; 1237 } 1238 1239 TEST_F(KeymasterTest, EraseAll_Success) { 1240 uint8_t *key1_blob, *key2_blob; 1241 size_t key1_blob_length, key2_blob_length; 1242 1243 // Only test this if the device says it supports delete_all 1244 if (sDevice->delete_all == NULL) { 1245 return; 1246 } 1247 1248 UniqueReadOnlyBlob testKey(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1249 ASSERT_TRUE(testKey.get() != NULL); 1250 1251 ASSERT_EQ(0, 1252 sDevice->import_keypair(sDevice, testKey.get(), testKey.length(), 1253 &key1_blob, &key1_blob_length)) 1254 << "Should successfully import an RSA key"; 1255 UniqueKey key1(&sDevice, key1_blob, key1_blob_length); 1256 1257 UniqueReadOnlyBlob testKey2(TEST_SIGN_RSA_KEY_1, sizeof(TEST_SIGN_RSA_KEY_1)); 1258 ASSERT_TRUE(testKey2.get() != NULL); 1259 1260 ASSERT_EQ(0, 1261 sDevice->import_keypair(sDevice, testKey2.get(), testKey2.length(), 1262 &key2_blob, &key2_blob_length)) 1263 << "Should successfully import an RSA key"; 1264 UniqueKey key2(&sDevice, key2_blob, key2_blob_length); 1265 1266 ASSERT_EQ(0, sDevice->delete_all(sDevice)) 1267 << "Should erase all keys"; 1268 1269 key1.reset(); 1270 1271 uint8_t* x509_data; 1272 size_t x509_data_length; 1273 ASSERT_EQ(-1, 1274 sDevice->get_keypair_public(sDevice, key1_blob, key1_blob_length, 1275 &x509_data, &x509_data_length)) 1276 << "Should be able to retrieve RSA public key 1 successfully"; 1277 1278 ASSERT_EQ(-1, 1279 sDevice->get_keypair_public(sDevice, key2_blob, key2_blob_length, 1280 &x509_data, &x509_data_length)) 1281 << "Should be able to retrieve RSA public key 2 successfully"; 1282 } 1283 1284 } 1285