1 /*
2 * Copyright (C) 2014 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 <keymaster/UniquePtr.h>
18
19 #include <gtest/gtest.h>
20
21 #include <keymaster/android_keymaster.h>
22 #include <keymaster/android_keymaster_utils.h>
23 #include <keymaster/keymaster_tags.h>
24
25 #include "android_keymaster_test_utils.h"
26
27 namespace keymaster {
28 namespace test {
29
30 /**
31 * Serialize and deserialize a message.
32 */
33 template <typename Message>
round_trip(int32_t ver,const Message & message,size_t expected_size)34 Message* round_trip(int32_t ver, const Message& message, size_t expected_size) {
35 size_t size = message.SerializedSize();
36 EXPECT_EQ(expected_size, size);
37 if (size == 0)
38 return NULL;
39
40 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
41 EXPECT_EQ(buf.get() + size, message.Serialize(buf.get(), buf.get() + size));
42
43 Message* deserialized = new Message(ver);
44 const uint8_t* p = buf.get();
45 EXPECT_TRUE(deserialized->Deserialize(&p, p + size));
46 EXPECT_EQ((ptrdiff_t)size, p - buf.get());
47 return deserialized;
48 }
49
50 struct EmptyKeymasterResponse : public KeymasterResponse {
EmptyKeymasterResponsekeymaster::test::EmptyKeymasterResponse51 explicit EmptyKeymasterResponse(int32_t ver) : KeymasterResponse(ver) {}
NonErrorSerializedSizekeymaster::test::EmptyKeymasterResponse52 size_t NonErrorSerializedSize() const { return 1; }
NonErrorSerializekeymaster::test::EmptyKeymasterResponse53 uint8_t* NonErrorSerialize(uint8_t* buf, const uint8_t* /* end */) const {
54 *buf++ = 0;
55 return buf;
56 }
NonErrorDeserializekeymaster::test::EmptyKeymasterResponse57 bool NonErrorDeserialize(const uint8_t** buf_ptr, const uint8_t* end) {
58 if (*buf_ptr >= end)
59 return false;
60 EXPECT_EQ(0, **buf_ptr);
61 (*buf_ptr)++;
62 return true;
63 }
64 };
65
TEST(RoundTrip,EmptyKeymasterResponse)66 TEST(RoundTrip, EmptyKeymasterResponse) {
67 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
68 EmptyKeymasterResponse msg(ver);
69 msg.error = KM_ERROR_OK;
70
71 UniquePtr<EmptyKeymasterResponse> deserialized(round_trip(ver, msg, 5));
72 }
73 }
74
TEST(RoundTrip,EmptyKeymasterResponseError)75 TEST(RoundTrip, EmptyKeymasterResponseError) {
76 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
77 EmptyKeymasterResponse msg(ver);
78 msg.error = KM_ERROR_MEMORY_ALLOCATION_FAILED;
79
80 UniquePtr<EmptyKeymasterResponse> deserialized(round_trip(ver, msg, 4));
81 }
82 }
83
TEST(RoundTrip,SupportedByAlgorithmRequest)84 TEST(RoundTrip, SupportedByAlgorithmRequest) {
85 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
86 SupportedByAlgorithmRequest req(ver);
87 req.algorithm = KM_ALGORITHM_EC;
88
89 UniquePtr<SupportedByAlgorithmRequest> deserialized(round_trip(ver, req, 4));
90 EXPECT_EQ(KM_ALGORITHM_EC, deserialized->algorithm);
91 }
92 }
93
TEST(RoundTrip,SupportedByAlgorithmAndPurposeRequest)94 TEST(RoundTrip, SupportedByAlgorithmAndPurposeRequest) {
95 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
96 SupportedByAlgorithmAndPurposeRequest req(ver);
97 req.algorithm = KM_ALGORITHM_EC;
98 req.purpose = KM_PURPOSE_DECRYPT;
99
100 UniquePtr<SupportedByAlgorithmAndPurposeRequest> deserialized(round_trip(ver, req, 8));
101 EXPECT_EQ(KM_ALGORITHM_EC, deserialized->algorithm);
102 EXPECT_EQ(KM_PURPOSE_DECRYPT, deserialized->purpose);
103 }
104 }
105
TEST(RoundTrip,SupportedResponse)106 TEST(RoundTrip, SupportedResponse) {
107 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
108 SupportedResponse<keymaster_digest_t> rsp(ver);
109 keymaster_digest_t digests[] = {KM_DIGEST_NONE, KM_DIGEST_MD5, KM_DIGEST_SHA1};
110 rsp.error = KM_ERROR_OK;
111 rsp.SetResults(digests);
112
113 UniquePtr<SupportedResponse<keymaster_digest_t>> deserialized(round_trip(ver, rsp, 20));
114 EXPECT_EQ(array_length(digests), deserialized->results_length);
115 EXPECT_EQ(0, memcmp(deserialized->results, digests, array_size(digests)));
116 }
117 }
118
119 static keymaster_key_param_t params[] = {
120 Authorization(TAG_PURPOSE, KM_PURPOSE_SIGN),
121 Authorization(TAG_PURPOSE, KM_PURPOSE_VERIFY),
122 Authorization(TAG_ALGORITHM, KM_ALGORITHM_RSA),
123 Authorization(TAG_USER_ID, 7),
124 Authorization(TAG_USER_AUTH_TYPE, HW_AUTH_PASSWORD),
125 Authorization(TAG_APPLICATION_ID, "app_id", 6),
126 Authorization(TAG_AUTH_TIMEOUT, 300),
127 };
128 uint8_t TEST_DATA[] = "a key blob";
129
TEST(RoundTrip,GenerateKeyRequest)130 TEST(RoundTrip, GenerateKeyRequest) {
131 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
132 GenerateKeyRequest req(ver);
133 req.key_description.Reinitialize(params, array_length(params));
134 UniquePtr<GenerateKeyRequest> deserialized(round_trip(ver, req, 78));
135 EXPECT_EQ(deserialized->key_description, req.key_description);
136 }
137 }
138
TEST(RoundTrip,GenerateKeyResponse)139 TEST(RoundTrip, GenerateKeyResponse) {
140 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
141 GenerateKeyResponse rsp(ver);
142 rsp.error = KM_ERROR_OK;
143 rsp.key_blob.key_material = dup_array(TEST_DATA);
144 rsp.key_blob.key_material_size = array_length(TEST_DATA);
145 rsp.enforced.Reinitialize(params, array_length(params));
146
147 UniquePtr<GenerateKeyResponse> deserialized(round_trip(ver, rsp, 109));
148 EXPECT_EQ(KM_ERROR_OK, deserialized->error);
149 EXPECT_EQ(deserialized->enforced, rsp.enforced);
150 EXPECT_EQ(deserialized->unenforced, rsp.unenforced);
151 }
152 }
153
TEST(RoundTrip,GenerateKeyResponseTestError)154 TEST(RoundTrip, GenerateKeyResponseTestError) {
155 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
156 GenerateKeyResponse rsp(ver);
157 rsp.error = KM_ERROR_UNSUPPORTED_ALGORITHM;
158 rsp.key_blob.key_material = dup_array(TEST_DATA);
159 rsp.key_blob.key_material_size = array_length(TEST_DATA);
160 rsp.enforced.Reinitialize(params, array_length(params));
161
162 UniquePtr<GenerateKeyResponse> deserialized(round_trip(ver, rsp, 4));
163 EXPECT_EQ(KM_ERROR_UNSUPPORTED_ALGORITHM, deserialized->error);
164 EXPECT_EQ(0U, deserialized->enforced.size());
165 EXPECT_EQ(0U, deserialized->unenforced.size());
166 EXPECT_EQ(0U, deserialized->key_blob.key_material_size);
167 }
168 }
169
TEST(RoundTrip,GetKeyCharacteristicsRequest)170 TEST(RoundTrip, GetKeyCharacteristicsRequest) {
171 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
172 GetKeyCharacteristicsRequest req(ver);
173 req.additional_params.Reinitialize(params, array_length(params));
174 req.SetKeyMaterial("foo", 3);
175
176 UniquePtr<GetKeyCharacteristicsRequest> deserialized(round_trip(ver, req, 85));
177 EXPECT_EQ(7U, deserialized->additional_params.size());
178 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
179 EXPECT_EQ(0, memcmp(deserialized->key_blob.key_material, "foo", 3));
180 }
181 }
182
TEST(RoundTrip,GetKeyCharacteristicsResponse)183 TEST(RoundTrip, GetKeyCharacteristicsResponse) {
184 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
185 GetKeyCharacteristicsResponse msg(ver);
186 msg.error = KM_ERROR_OK;
187 msg.enforced.Reinitialize(params, array_length(params));
188 msg.unenforced.Reinitialize(params, array_length(params));
189
190 UniquePtr<GetKeyCharacteristicsResponse> deserialized(round_trip(ver, msg, 160));
191 EXPECT_EQ(msg.enforced, deserialized->enforced);
192 EXPECT_EQ(msg.unenforced, deserialized->unenforced);
193 }
194 }
195
TEST(RoundTrip,BeginOperationRequest)196 TEST(RoundTrip, BeginOperationRequest) {
197 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
198 BeginOperationRequest msg(ver);
199 msg.purpose = KM_PURPOSE_SIGN;
200 msg.SetKeyMaterial("foo", 3);
201 msg.additional_params.Reinitialize(params, array_length(params));
202
203 UniquePtr<BeginOperationRequest> deserialized(round_trip(ver, msg, 89));
204 EXPECT_EQ(KM_PURPOSE_SIGN, deserialized->purpose);
205 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
206 EXPECT_EQ(0, memcmp(deserialized->key_blob.key_material, "foo", 3));
207 EXPECT_EQ(msg.additional_params, deserialized->additional_params);
208 }
209 }
210
TEST(RoundTrip,BeginOperationResponse)211 TEST(RoundTrip, BeginOperationResponse) {
212 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
213 BeginOperationResponse msg(ver);
214 msg.error = KM_ERROR_OK;
215 msg.op_handle = 0xDEADBEEF;
216 msg.output_params.push_back(Authorization(TAG_NONCE, "foo", 3));
217
218 UniquePtr<BeginOperationResponse> deserialized;
219 switch (ver) {
220 case 0:
221 deserialized.reset(round_trip(ver, msg, 12));
222 break;
223 case 1:
224 case 2:
225 case 3:
226 deserialized.reset(round_trip(ver, msg, 39));
227 break;
228 default:
229 FAIL();
230 }
231
232 EXPECT_EQ(KM_ERROR_OK, deserialized->error);
233 EXPECT_EQ(0xDEADBEEF, deserialized->op_handle);
234
235 switch (ver) {
236 case 0:
237 EXPECT_EQ(0U, deserialized->output_params.size());
238 break;
239 case 1:
240 case 2:
241 case 3:
242 EXPECT_EQ(msg.output_params, deserialized->output_params);
243 break;
244 default:
245 FAIL();
246 }
247 }
248 }
249
TEST(RoundTrip,BeginOperationResponseError)250 TEST(RoundTrip, BeginOperationResponseError) {
251 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
252 BeginOperationResponse msg(ver);
253 msg.error = KM_ERROR_INVALID_OPERATION_HANDLE;
254 msg.op_handle = 0xDEADBEEF;
255
256 UniquePtr<BeginOperationResponse> deserialized(round_trip(ver, msg, 4));
257 EXPECT_EQ(KM_ERROR_INVALID_OPERATION_HANDLE, deserialized->error);
258 }
259 }
260
TEST(RoundTrip,UpdateOperationRequest)261 TEST(RoundTrip, UpdateOperationRequest) {
262 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
263 UpdateOperationRequest msg(ver);
264 msg.op_handle = 0xDEADBEEF;
265 msg.input.Reinitialize("foo", 3);
266
267 UniquePtr<UpdateOperationRequest> deserialized;
268 switch (ver) {
269 case 0:
270 deserialized.reset(round_trip(ver, msg, 15));
271 break;
272 case 1:
273 case 2:
274 case 3:
275 deserialized.reset(round_trip(ver, msg, 27));
276 break;
277 default:
278 FAIL();
279 }
280 EXPECT_EQ(3U, deserialized->input.available_read());
281 EXPECT_EQ(0, memcmp(deserialized->input.peek_read(), "foo", 3));
282 }
283 }
284
TEST(RoundTrip,UpdateOperationResponse)285 TEST(RoundTrip, UpdateOperationResponse) {
286 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
287 UpdateOperationResponse msg(ver);
288 msg.error = KM_ERROR_OK;
289 msg.output.Reinitialize("foo", 3);
290 msg.input_consumed = 99;
291 msg.output_params.push_back(TAG_APPLICATION_ID, "bar", 3);
292
293 UniquePtr<UpdateOperationResponse> deserialized;
294 switch (ver) {
295 case 0:
296 deserialized.reset(round_trip(ver, msg, 11));
297 break;
298 case 1:
299 deserialized.reset(round_trip(ver, msg, 15));
300 break;
301 case 2:
302 case 3:
303 deserialized.reset(round_trip(ver, msg, 42));
304 break;
305 default:
306 FAIL();
307 }
308 EXPECT_EQ(KM_ERROR_OK, deserialized->error);
309 EXPECT_EQ(3U, deserialized->output.available_read());
310 EXPECT_EQ(0, memcmp(deserialized->output.peek_read(), "foo", 3));
311
312 switch (ver) {
313 case 0:
314 EXPECT_EQ(0U, deserialized->input_consumed);
315 break;
316 case 1:
317 EXPECT_EQ(99U, deserialized->input_consumed);
318 break;
319 case 2:
320 case 3:
321 EXPECT_EQ(99U, deserialized->input_consumed);
322 EXPECT_EQ(1U, deserialized->output_params.size());
323 break;
324 default:
325 FAIL();
326 }
327 }
328 }
329
TEST(RoundTrip,FinishOperationRequest)330 TEST(RoundTrip, FinishOperationRequest) {
331 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
332 FinishOperationRequest msg(ver);
333 msg.op_handle = 0xDEADBEEF;
334 msg.signature.Reinitialize("bar", 3);
335 msg.input.Reinitialize("baz", 3);
336
337 UniquePtr<FinishOperationRequest> deserialized;
338 switch (ver) {
339 case 0:
340 deserialized.reset(round_trip(ver, msg, 15));
341 break;
342 case 1:
343 case 2:
344 deserialized.reset(round_trip(ver, msg, 27));
345 break;
346 case 3:
347 deserialized.reset(round_trip(ver, msg, 34));
348 break;
349 default:
350 FAIL();
351 }
352 EXPECT_EQ(0xDEADBEEF, deserialized->op_handle);
353 EXPECT_EQ(3U, deserialized->signature.available_read());
354 EXPECT_EQ(0, memcmp(deserialized->signature.peek_read(), "bar", 3));
355 }
356 }
357
TEST(Round_Trip,FinishOperationResponse)358 TEST(Round_Trip, FinishOperationResponse) {
359 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
360 FinishOperationResponse msg(ver);
361 msg.error = KM_ERROR_OK;
362 msg.output.Reinitialize("foo", 3);
363
364 UniquePtr<FinishOperationResponse> deserialized;
365 switch (ver) {
366 case 0:
367 case 1:
368 deserialized.reset(round_trip(ver, msg, 11));
369 break;
370 case 2:
371 case 3:
372 deserialized.reset(round_trip(ver, msg, 23));
373 break;
374 default:
375 FAIL();
376 }
377 EXPECT_EQ(msg.error, deserialized->error);
378 EXPECT_EQ(msg.output.available_read(), deserialized->output.available_read());
379 EXPECT_EQ(0, memcmp(msg.output.peek_read(), deserialized->output.peek_read(),
380 msg.output.available_read()));
381 }
382 }
383
TEST(RoundTrip,ImportKeyRequest)384 TEST(RoundTrip, ImportKeyRequest) {
385 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
386 ImportKeyRequest msg(ver);
387 msg.key_description.Reinitialize(params, array_length(params));
388 msg.key_format = KM_KEY_FORMAT_X509;
389 msg.SetKeyMaterial("foo", 3);
390
391 UniquePtr<ImportKeyRequest> deserialized(round_trip(ver, msg, 89));
392 EXPECT_EQ(msg.key_description, deserialized->key_description);
393 EXPECT_EQ(msg.key_format, deserialized->key_format);
394 EXPECT_EQ(msg.key_data_length, deserialized->key_data_length);
395 EXPECT_EQ(0, memcmp(msg.key_data, deserialized->key_data, msg.key_data_length));
396 }
397 }
398
TEST(RoundTrip,ImportKeyResponse)399 TEST(RoundTrip, ImportKeyResponse) {
400 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
401 ImportKeyResponse msg(ver);
402 msg.error = KM_ERROR_OK;
403 msg.SetKeyMaterial("foo", 3);
404 msg.enforced.Reinitialize(params, array_length(params));
405 msg.unenforced.Reinitialize(params, array_length(params));
406
407 UniquePtr<ImportKeyResponse> deserialized(round_trip(ver, msg, 167));
408 EXPECT_EQ(msg.error, deserialized->error);
409 EXPECT_EQ(msg.key_blob.key_material_size, deserialized->key_blob.key_material_size);
410 EXPECT_EQ(0, memcmp(msg.key_blob.key_material, deserialized->key_blob.key_material,
411 msg.key_blob.key_material_size));
412 EXPECT_EQ(msg.enforced, deserialized->enforced);
413 EXPECT_EQ(msg.unenforced, deserialized->unenforced);
414 }
415 }
416
TEST(RoundTrip,ExportKeyRequest)417 TEST(RoundTrip, ExportKeyRequest) {
418 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
419 ExportKeyRequest msg(ver);
420 msg.additional_params.Reinitialize(params, array_length(params));
421 msg.key_format = KM_KEY_FORMAT_X509;
422 msg.SetKeyMaterial("foo", 3);
423
424 UniquePtr<ExportKeyRequest> deserialized(round_trip(ver, msg, 89));
425 EXPECT_EQ(msg.additional_params, deserialized->additional_params);
426 EXPECT_EQ(msg.key_format, deserialized->key_format);
427 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
428 EXPECT_EQ(0, memcmp("foo", deserialized->key_blob.key_material, 3));
429 }
430 }
431
TEST(RoundTrip,ExportKeyResponse)432 TEST(RoundTrip, ExportKeyResponse) {
433 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
434 ExportKeyResponse msg(ver);
435 msg.error = KM_ERROR_OK;
436 msg.SetKeyMaterial("foo", 3);
437
438 UniquePtr<ExportKeyResponse> deserialized(round_trip(ver, msg, 11));
439 EXPECT_EQ(3U, deserialized->key_data_length);
440 EXPECT_EQ(0, memcmp("foo", deserialized->key_data, 3));
441 }
442 }
443
TEST(RoundTrip,DeleteKeyRequest)444 TEST(RoundTrip, DeleteKeyRequest) {
445 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
446 DeleteKeyRequest msg(ver);
447 msg.SetKeyMaterial("foo", 3);
448
449 UniquePtr<DeleteKeyRequest> deserialized(round_trip(ver, msg, 7));
450 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
451 EXPECT_EQ(0, memcmp("foo", deserialized->key_blob.key_material, 3));
452 }
453 }
454
TEST(RoundTrip,DeleteKeyResponse)455 TEST(RoundTrip, DeleteKeyResponse) {
456 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
457 DeleteKeyResponse msg(ver);
458 UniquePtr<DeleteKeyResponse> deserialized(round_trip(ver, msg, 4));
459 }
460 }
461
TEST(RoundTrip,DeleteAllKeysRequest)462 TEST(RoundTrip, DeleteAllKeysRequest) {
463 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
464 DeleteAllKeysRequest msg(ver);
465 UniquePtr<DeleteAllKeysRequest> deserialized(round_trip(ver, msg, 0));
466 }
467 }
468
TEST(RoundTrip,DeleteAllKeysResponse)469 TEST(RoundTrip, DeleteAllKeysResponse) {
470 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
471 DeleteAllKeysResponse msg(ver);
472 UniquePtr<DeleteAllKeysResponse> deserialized(round_trip(ver, msg, 4));
473 }
474 }
475
TEST(RoundTrip,GetVersionRequest)476 TEST(RoundTrip, GetVersionRequest) {
477 GetVersionRequest msg;
478
479 size_t size = msg.SerializedSize();
480 ASSERT_EQ(0U, size);
481
482 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
483 EXPECT_EQ(buf.get() + size, msg.Serialize(buf.get(), buf.get() + size));
484
485 GetVersionRequest deserialized;
486 const uint8_t* p = buf.get();
487 EXPECT_TRUE(deserialized.Deserialize(&p, p + size));
488 EXPECT_EQ((ptrdiff_t)size, p - buf.get());
489 }
490
TEST(RoundTrip,GetVersionResponse)491 TEST(RoundTrip, GetVersionResponse) {
492 GetVersionResponse msg;
493 msg.error = KM_ERROR_OK;
494 msg.major_ver = 9;
495 msg.minor_ver = 98;
496 msg.subminor_ver = 38;
497
498 size_t size = msg.SerializedSize();
499 ASSERT_EQ(7U, size);
500
501 UniquePtr<uint8_t[]> buf(new uint8_t[size]);
502 EXPECT_EQ(buf.get() + size, msg.Serialize(buf.get(), buf.get() + size));
503
504 GetVersionResponse deserialized;
505 const uint8_t* p = buf.get();
506 EXPECT_TRUE(deserialized.Deserialize(&p, p + size));
507 EXPECT_EQ((ptrdiff_t)size, p - buf.get());
508 EXPECT_EQ(9U, msg.major_ver);
509 EXPECT_EQ(98U, msg.minor_ver);
510 EXPECT_EQ(38U, msg.subminor_ver);
511 }
512
TEST(RoundTrip,ConfigureRequest)513 TEST(RoundTrip, ConfigureRequest) {
514 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
515 ConfigureRequest req(ver);
516 req.os_version = 1;
517 req.os_patchlevel = 1;
518
519 UniquePtr<ConfigureRequest> deserialized(round_trip(ver, req, 8));
520 EXPECT_EQ(deserialized->os_version, req.os_version);
521 EXPECT_EQ(deserialized->os_patchlevel, req.os_patchlevel);
522 }
523 }
524
TEST(RoundTrip,ConfigureResponse)525 TEST(RoundTrip, ConfigureResponse) {
526 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
527 ConfigureResponse rsp(ver);
528 UniquePtr<ConfigureResponse> deserialized(round_trip(ver, rsp, 4));
529 }
530 }
531
TEST(RoundTrip,AddEntropyRequest)532 TEST(RoundTrip, AddEntropyRequest) {
533 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
534 AddEntropyRequest msg(ver);
535 msg.random_data.Reinitialize("foo", 3);
536
537 UniquePtr<AddEntropyRequest> deserialized(round_trip(ver, msg, 7));
538 EXPECT_EQ(3U, deserialized->random_data.available_read());
539 EXPECT_EQ(0, memcmp("foo", deserialized->random_data.peek_read(), 3));
540 }
541 }
542
TEST(RoundTrip,AddEntropyResponse)543 TEST(RoundTrip, AddEntropyResponse) {
544 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
545 AddEntropyResponse msg(ver);
546 UniquePtr<AddEntropyResponse> deserialized(round_trip(ver, msg, 4));
547 }
548 }
549
TEST(RoundTrip,AbortOperationRequest)550 TEST(RoundTrip, AbortOperationRequest) {
551 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
552 AbortOperationRequest msg(ver);
553 UniquePtr<AbortOperationRequest> deserialized(round_trip(ver, msg, 8));
554 }
555 }
556
TEST(RoundTrip,AbortOperationResponse)557 TEST(RoundTrip, AbortOperationResponse) {
558 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
559 AbortOperationResponse msg(ver);
560 UniquePtr<AbortOperationResponse> deserialized(round_trip(ver, msg, 4));
561 }
562 }
563
TEST(RoundTrip,AttestKeyRequest)564 TEST(RoundTrip, AttestKeyRequest) {
565 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
566 AttestKeyRequest msg(ver);
567 msg.SetKeyMaterial("foo", 3);
568 msg.attest_params.Reinitialize(params, array_length(params));
569
570 UniquePtr<AttestKeyRequest> deserialized(round_trip(ver, msg, 85));
571 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
572 EXPECT_EQ(0, memcmp("foo", deserialized->key_blob.key_material, 3));
573 EXPECT_EQ(msg.attest_params, deserialized->attest_params);
574 }
575 }
576
TEST(RoundTrip,AttestKeyResponse)577 TEST(RoundTrip, AttestKeyResponse) {
578 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
579 AttestKeyResponse msg(ver);
580 msg.error = KM_ERROR_OK;
581 EXPECT_TRUE(msg.AllocateChain(3));
582 msg.certificate_chain.entries[0] = {dup_buffer("foo", 3), 3};
583 msg.certificate_chain.entries[1] = {dup_buffer("bar", 3), 3};
584 msg.certificate_chain.entries[2] = {dup_buffer("baz", 3), 3};
585
586 UniquePtr<AttestKeyResponse> deserialized(round_trip(ver, msg, 29));
587 keymaster_cert_chain_t* chain = &deserialized->certificate_chain;
588
589 EXPECT_NE(nullptr, chain->entries);
590 EXPECT_EQ(3U, chain->entry_count);
591 EXPECT_EQ(3U, chain->entries[0].data_length);
592 EXPECT_EQ(0, memcmp("foo", chain->entries[0].data, 3));
593 EXPECT_EQ(3U, chain->entries[1].data_length);
594 EXPECT_EQ(0, memcmp("bar", chain->entries[1].data, 3));
595 EXPECT_EQ(3U, chain->entries[2].data_length);
596 EXPECT_EQ(0, memcmp("baz", chain->entries[2].data, 3));
597 }
598 }
599
TEST(RoundTrip,UpgradeKeyRequest)600 TEST(RoundTrip, UpgradeKeyRequest) {
601 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
602 UpgradeKeyRequest msg(ver);
603 msg.SetKeyMaterial("foo", 3);
604 msg.upgrade_params.Reinitialize(params, array_length(params));
605
606 UniquePtr<UpgradeKeyRequest> deserialized(round_trip(ver, msg, 85));
607 EXPECT_EQ(3U, deserialized->key_blob.key_material_size);
608 EXPECT_EQ(0, memcmp("foo", deserialized->key_blob.key_material, 3));
609 EXPECT_EQ(msg.upgrade_params, deserialized->upgrade_params);
610 }
611 }
612
TEST(RoundTrip,UpgradeKeyResponse)613 TEST(RoundTrip, UpgradeKeyResponse) {
614 for (int ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
615 UpgradeKeyResponse req(ver);
616 req.error = KM_ERROR_OK;
617 req.upgraded_key.key_material = dup_array(TEST_DATA);
618 req.upgraded_key.key_material_size = array_length(TEST_DATA);
619
620 UniquePtr<UpgradeKeyResponse> deserialized(round_trip(ver, req, 19));
621 EXPECT_EQ(KM_ERROR_OK, deserialized->error);
622 EXPECT_EQ(req.upgraded_key.key_material_size, deserialized->upgraded_key.key_material_size);
623 EXPECT_EQ(0, memcmp(req.upgraded_key.key_material, deserialized->upgraded_key.key_material,
624 req.upgraded_key.key_material_size));
625 }
626 }
627
628 uint8_t msgbuf[] = {
629 220, 88, 183, 255, 71, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
630 0, 173, 0, 0, 0, 228, 174, 98, 187, 191, 135, 253, 200, 51, 230, 114, 247, 151, 109,
631 237, 79, 87, 32, 94, 5, 204, 46, 154, 30, 91, 6, 103, 148, 254, 129, 65, 171, 228,
632 167, 224, 163, 9, 15, 206, 90, 58, 11, 205, 55, 211, 33, 87, 178, 149, 91, 28, 236,
633 218, 112, 231, 34, 82, 82, 134, 103, 137, 115, 27, 156, 102, 159, 220, 226, 89, 42, 25,
634 37, 9, 84, 239, 76, 161, 198, 72, 167, 163, 39, 91, 148, 191, 17, 191, 87, 169, 179,
635 136, 10, 194, 154, 4, 40, 107, 109, 61, 161, 20, 176, 247, 13, 214, 106, 229, 45, 17,
636 5, 60, 189, 64, 39, 166, 208, 14, 57, 25, 140, 148, 25, 177, 246, 189, 43, 181, 88,
637 204, 29, 126, 224, 100, 143, 93, 60, 57, 249, 55, 0, 87, 83, 227, 224, 166, 59, 214,
638 81, 144, 129, 58, 6, 57, 46, 254, 232, 41, 220, 209, 230, 167, 138, 158, 94, 180, 125,
639 247, 26, 162, 116, 238, 202, 187, 100, 65, 13, 180, 44, 245, 159, 83, 161, 176, 58, 72,
640 236, 109, 105, 160, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
641 0, 11, 0, 0, 0, 98, 0, 0, 0, 1, 0, 0, 32, 2, 0, 0, 0, 1, 0,
642 0, 32, 3, 0, 0, 0, 2, 0, 0, 16, 1, 0, 0, 0, 3, 0, 0, 48, 0,
643 1, 0, 0, 200, 0, 0, 80, 3, 0, 0, 0, 0, 0, 0, 0, 244, 1, 0, 112,
644 1, 246, 1, 0, 112, 1, 189, 2, 0, 96, 144, 178, 236, 250, 255, 255, 255, 255, 145,
645 1, 0, 96, 144, 226, 33, 60, 222, 2, 0, 0, 189, 2, 0, 96, 0, 0, 0, 0,
646 0, 0, 0, 0, 190, 2, 0, 16, 1, 0, 0, 0, 12, 0, 0, 0, 0, 0, 0,
647 0, 0, 0, 0, 0, 0, 0, 0, 0, 110, 0, 0, 0, 0, 0, 0, 0, 11, 0,
648 0, 0, 98, 0, 0, 0, 1, 0, 0, 32, 2, 0, 0, 0, 1, 0, 0, 32, 3,
649 0, 0, 0, 2, 0, 0, 16, 1, 0, 0, 0, 3, 0, 0, 48, 0, 1, 0, 0,
650 200, 0, 0, 80, 3, 0, 0, 0, 0, 0, 0, 0, 244, 1, 0, 112, 1, 246, 1,
651 0, 112, 1, 189, 2, 0, 96, 144, 178, 236, 250, 255, 255, 255, 255, 145, 1, 0, 96,
652 144, 226, 33, 60, 222, 2, 0, 0, 189, 2, 0, 96, 0, 0, 0, 0, 0, 0, 0,
653 0, 190, 2, 0, 16, 1, 0, 0, 0,
654 };
655
656 /*
657 * These tests don't have any assertions or expectations. They just try to parse garbage, to see if
658 * the result will be a crash. This is especially informative when run under Valgrind memcheck.
659 */
660
parse_garbage()661 template <typename Message> void parse_garbage() {
662 for (int32_t ver = 0; ver <= MAX_MESSAGE_VERSION; ++ver) {
663 Message msg(ver);
664 const uint8_t* end = msgbuf + array_length(msgbuf);
665 for (size_t i = 0; i < array_length(msgbuf); ++i) {
666 const uint8_t* begin = msgbuf + i;
667 const uint8_t* p = begin;
668 msg.Deserialize(&p, end);
669 }
670 }
671
672 time_t now = time(NULL);
673 std::cout << "Seeding rand() with " << now << " for fuzz test." << std::endl;
674 srand(now);
675
676 // Fill large buffer with random bytes.
677 const int kBufSize = 10000;
678 UniquePtr<uint8_t[]> buf(new uint8_t[kBufSize]);
679 for (size_t i = 0; i < kBufSize; ++i)
680 buf[i] = static_cast<uint8_t>(rand());
681
682 for (uint32_t ver = 0; ver < MAX_MESSAGE_VERSION; ++ver) {
683 Message msg(ver);
684 const uint8_t* end = buf.get() + kBufSize;
685 for (size_t i = 0; i < kBufSize; ++i) {
686 const uint8_t* begin = buf.get() + i;
687 const uint8_t* p = begin;
688 msg.Deserialize(&p, end);
689 }
690 }
691 }
692
693 #define GARBAGE_TEST(Message) \
694 TEST(GarbageTest, Message) { parse_garbage<Message>(); }
695
696 GARBAGE_TEST(AbortOperationRequest);
697 GARBAGE_TEST(AbortOperationResponse);
698 GARBAGE_TEST(AddEntropyRequest);
699 GARBAGE_TEST(AddEntropyResponse);
700 GARBAGE_TEST(BeginOperationRequest);
701 GARBAGE_TEST(BeginOperationResponse);
702 GARBAGE_TEST(DeleteAllKeysRequest);
703 GARBAGE_TEST(DeleteAllKeysResponse);
704 GARBAGE_TEST(DeleteKeyRequest);
705 GARBAGE_TEST(DeleteKeyResponse);
706 GARBAGE_TEST(ExportKeyRequest);
707 GARBAGE_TEST(ExportKeyResponse);
708 GARBAGE_TEST(FinishOperationRequest);
709 GARBAGE_TEST(FinishOperationResponse);
710 GARBAGE_TEST(GenerateKeyRequest);
711 GARBAGE_TEST(GenerateKeyResponse);
712 GARBAGE_TEST(GetKeyCharacteristicsRequest);
713 GARBAGE_TEST(GetKeyCharacteristicsResponse);
714 GARBAGE_TEST(ImportKeyRequest);
715 GARBAGE_TEST(ImportKeyResponse);
716 GARBAGE_TEST(SupportedByAlgorithmAndPurposeRequest)
717 GARBAGE_TEST(SupportedByAlgorithmRequest)
718 GARBAGE_TEST(UpdateOperationRequest);
719 GARBAGE_TEST(UpdateOperationResponse);
720 GARBAGE_TEST(AttestKeyRequest);
721 GARBAGE_TEST(AttestKeyResponse);
722 GARBAGE_TEST(UpgradeKeyRequest);
723 GARBAGE_TEST(UpgradeKeyResponse);
724
725 // The macro doesn't work on this one.
TEST(GarbageTest,SupportedResponse)726 TEST(GarbageTest, SupportedResponse) {
727 parse_garbage<SupportedResponse<keymaster_digest_t>>();
728 }
729
730 } // namespace test
731
732 } // namespace keymaster
733