1*8617a60dSAndroid Build Coastguard Worker /* Copyright 2013 The ChromiumOS Authors
2*8617a60dSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be
3*8617a60dSAndroid Build Coastguard Worker * found in the LICENSE file.
4*8617a60dSAndroid Build Coastguard Worker *
5*8617a60dSAndroid Build Coastguard Worker * Tests for TPM lite library
6*8617a60dSAndroid Build Coastguard Worker */
7*8617a60dSAndroid Build Coastguard Worker
8*8617a60dSAndroid Build Coastguard Worker #include <stdint.h>
9*8617a60dSAndroid Build Coastguard Worker #include <stdio.h>
10*8617a60dSAndroid Build Coastguard Worker #include <stdlib.h>
11*8617a60dSAndroid Build Coastguard Worker #include <string.h>
12*8617a60dSAndroid Build Coastguard Worker
13*8617a60dSAndroid Build Coastguard Worker #include "2api.h"
14*8617a60dSAndroid Build Coastguard Worker #include "common/tests.h"
15*8617a60dSAndroid Build Coastguard Worker #include "host_common.h"
16*8617a60dSAndroid Build Coastguard Worker #include "tlcl.h"
17*8617a60dSAndroid Build Coastguard Worker #include "tlcl_internal.h"
18*8617a60dSAndroid Build Coastguard Worker
19*8617a60dSAndroid Build Coastguard Worker /* Mock data */
20*8617a60dSAndroid Build Coastguard Worker static char debug_info[4096];
21*8617a60dSAndroid Build Coastguard Worker static vb2_error_t mock_retval;
22*8617a60dSAndroid Build Coastguard Worker
23*8617a60dSAndroid Build Coastguard Worker /* Call to mocked vb2ex_tpm_send_recv() */
24*8617a60dSAndroid Build Coastguard Worker struct srcall
25*8617a60dSAndroid Build Coastguard Worker {
26*8617a60dSAndroid Build Coastguard Worker const uint8_t *req; /* Request */
27*8617a60dSAndroid Build Coastguard Worker uint8_t *rsp; /* Response */
28*8617a60dSAndroid Build Coastguard Worker uint8_t rsp_buf[32]; /* Default response buffer, if not overridden */
29*8617a60dSAndroid Build Coastguard Worker int req_size; /* Request size */
30*8617a60dSAndroid Build Coastguard Worker uint32_t req_cmd; /* Request command code */
31*8617a60dSAndroid Build Coastguard Worker int rsp_size; /* Response size */
32*8617a60dSAndroid Build Coastguard Worker vb2_error_t retval; /* Value to return */
33*8617a60dSAndroid Build Coastguard Worker };
34*8617a60dSAndroid Build Coastguard Worker
35*8617a60dSAndroid Build Coastguard Worker #define MAXCALLS 8
36*8617a60dSAndroid Build Coastguard Worker static struct srcall calls[MAXCALLS];
37*8617a60dSAndroid Build Coastguard Worker static int ncalls;
38*8617a60dSAndroid Build Coastguard Worker
39*8617a60dSAndroid Build Coastguard Worker /**
40*8617a60dSAndroid Build Coastguard Worker * Reset mock data (for use before each test)
41*8617a60dSAndroid Build Coastguard Worker */
ResetMocks(void)42*8617a60dSAndroid Build Coastguard Worker static void ResetMocks(void)
43*8617a60dSAndroid Build Coastguard Worker {
44*8617a60dSAndroid Build Coastguard Worker int i;
45*8617a60dSAndroid Build Coastguard Worker
46*8617a60dSAndroid Build Coastguard Worker *debug_info = 0;
47*8617a60dSAndroid Build Coastguard Worker mock_retval = VB2_SUCCESS;
48*8617a60dSAndroid Build Coastguard Worker
49*8617a60dSAndroid Build Coastguard Worker memset(calls, 0, sizeof(calls));
50*8617a60dSAndroid Build Coastguard Worker for (i = 0; i < MAXCALLS; i++)
51*8617a60dSAndroid Build Coastguard Worker calls[i].rsp = calls[i].rsp_buf;
52*8617a60dSAndroid Build Coastguard Worker ncalls = 0;
53*8617a60dSAndroid Build Coastguard Worker }
54*8617a60dSAndroid Build Coastguard Worker
55*8617a60dSAndroid Build Coastguard Worker /**
56*8617a60dSAndroid Build Coastguard Worker * Set response code and length for call <call_idx>.
57*8617a60dSAndroid Build Coastguard Worker */
SetResponse(int call_idx,uint32_t response_code,int rsp_size)58*8617a60dSAndroid Build Coastguard Worker static void SetResponse(int call_idx, uint32_t response_code, int rsp_size)
59*8617a60dSAndroid Build Coastguard Worker {
60*8617a60dSAndroid Build Coastguard Worker struct srcall *c = calls + call_idx;
61*8617a60dSAndroid Build Coastguard Worker
62*8617a60dSAndroid Build Coastguard Worker c->rsp_size = rsp_size;
63*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(c->rsp_buf + 6, response_code);
64*8617a60dSAndroid Build Coastguard Worker }
65*8617a60dSAndroid Build Coastguard Worker
66*8617a60dSAndroid Build Coastguard Worker /* Mocks */
67*8617a60dSAndroid Build Coastguard Worker
vb2ex_tpm_init(void)68*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_tpm_init(void)
69*8617a60dSAndroid Build Coastguard Worker {
70*8617a60dSAndroid Build Coastguard Worker return mock_retval;
71*8617a60dSAndroid Build Coastguard Worker }
72*8617a60dSAndroid Build Coastguard Worker
vb2ex_tpm_close(void)73*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_tpm_close(void)
74*8617a60dSAndroid Build Coastguard Worker {
75*8617a60dSAndroid Build Coastguard Worker return mock_retval;
76*8617a60dSAndroid Build Coastguard Worker }
77*8617a60dSAndroid Build Coastguard Worker
vb2ex_tpm_send_recv(const uint8_t * request,uint32_t request_length,uint8_t * response,uint32_t * response_length)78*8617a60dSAndroid Build Coastguard Worker uint32_t vb2ex_tpm_send_recv(const uint8_t *request, uint32_t request_length,
79*8617a60dSAndroid Build Coastguard Worker uint8_t *response, uint32_t *response_length)
80*8617a60dSAndroid Build Coastguard Worker {
81*8617a60dSAndroid Build Coastguard Worker struct srcall *c = calls + ncalls++;
82*8617a60dSAndroid Build Coastguard Worker
83*8617a60dSAndroid Build Coastguard Worker c->req = request;
84*8617a60dSAndroid Build Coastguard Worker c->req_size = request_length;
85*8617a60dSAndroid Build Coastguard Worker
86*8617a60dSAndroid Build Coastguard Worker /* Parse out the command code */
87*8617a60dSAndroid Build Coastguard Worker FromTpmUint32(request + 6, &c->req_cmd);
88*8617a60dSAndroid Build Coastguard Worker
89*8617a60dSAndroid Build Coastguard Worker // KLUDGE - remove
90*8617a60dSAndroid Build Coastguard Worker printf("TSR [%d] %#x\n", ncalls-1, c->req_cmd);
91*8617a60dSAndroid Build Coastguard Worker
92*8617a60dSAndroid Build Coastguard Worker memset(response, 0, *response_length);
93*8617a60dSAndroid Build Coastguard Worker if (c->rsp_size)
94*8617a60dSAndroid Build Coastguard Worker memcpy(response, c->rsp, c->rsp_size);
95*8617a60dSAndroid Build Coastguard Worker *response_length = c->rsp_size;
96*8617a60dSAndroid Build Coastguard Worker
97*8617a60dSAndroid Build Coastguard Worker return c->retval;
98*8617a60dSAndroid Build Coastguard Worker }
99*8617a60dSAndroid Build Coastguard Worker
vb2ex_tpm_get_random(uint8_t * buf,uint32_t length)100*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_tpm_get_random(uint8_t *buf, uint32_t length)
101*8617a60dSAndroid Build Coastguard Worker {
102*8617a60dSAndroid Build Coastguard Worker memset(buf, 0xa5, length);
103*8617a60dSAndroid Build Coastguard Worker return VB2_SUCCESS;
104*8617a60dSAndroid Build Coastguard Worker }
105*8617a60dSAndroid Build Coastguard Worker
106*8617a60dSAndroid Build Coastguard Worker /**
107*8617a60dSAndroid Build Coastguard Worker * Test assorted tlcl functions
108*8617a60dSAndroid Build Coastguard Worker */
TlclTest(void)109*8617a60dSAndroid Build Coastguard Worker static void TlclTest(void)
110*8617a60dSAndroid Build Coastguard Worker {
111*8617a60dSAndroid Build Coastguard Worker uint8_t buf[32], buf2[32];
112*8617a60dSAndroid Build Coastguard Worker
113*8617a60dSAndroid Build Coastguard Worker ResetMocks();
114*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclLibInit(), VB2_SUCCESS, "Init");
115*8617a60dSAndroid Build Coastguard Worker
116*8617a60dSAndroid Build Coastguard Worker ResetMocks();
117*8617a60dSAndroid Build Coastguard Worker mock_retval = VB2_ERROR_MOCK;
118*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclLibInit(), mock_retval, "Init bad");
119*8617a60dSAndroid Build Coastguard Worker
120*8617a60dSAndroid Build Coastguard Worker ResetMocks();
121*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclLibClose(), VB2_SUCCESS, "Close");
122*8617a60dSAndroid Build Coastguard Worker
123*8617a60dSAndroid Build Coastguard Worker ResetMocks();
124*8617a60dSAndroid Build Coastguard Worker mock_retval = VB2_ERROR_MOCK;
125*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclLibClose(), mock_retval, "Close bad");
126*8617a60dSAndroid Build Coastguard Worker
127*8617a60dSAndroid Build Coastguard Worker ResetMocks();
128*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(buf + 2, 123);
129*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclPacketSize(buf), 123, "TlclPacketSize");
130*8617a60dSAndroid Build Coastguard Worker
131*8617a60dSAndroid Build Coastguard Worker ResetMocks();
132*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(buf + 2, 10);
133*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSendReceive(buf, buf2, sizeof(buf2)), 0, "SendReceive");
134*8617a60dSAndroid Build Coastguard Worker TEST_PTR_EQ(calls[0].req, buf, "SendReceive req ptr");
135*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_size, 10, "SendReceive size");
136*8617a60dSAndroid Build Coastguard Worker
137*8617a60dSAndroid Build Coastguard Worker ResetMocks();
138*8617a60dSAndroid Build Coastguard Worker calls[0].retval = VB2_ERROR_MOCK;
139*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(buf + 2, 10);
140*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSendReceive(buf, buf2, sizeof(buf2)), VB2_ERROR_MOCK,
141*8617a60dSAndroid Build Coastguard Worker "SendReceive fail");
142*8617a60dSAndroid Build Coastguard Worker
143*8617a60dSAndroid Build Coastguard Worker ResetMocks();
144*8617a60dSAndroid Build Coastguard Worker SetResponse(0, 123, 10);
145*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(buf + 2, 10);
146*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSendReceive(buf, buf2, sizeof(buf2)), 123,
147*8617a60dSAndroid Build Coastguard Worker "SendReceive error response");
148*8617a60dSAndroid Build Coastguard Worker
149*8617a60dSAndroid Build Coastguard Worker // TODO: continue self test (if needed or doing)
150*8617a60dSAndroid Build Coastguard Worker // TODO: then retry doing self test
151*8617a60dSAndroid Build Coastguard Worker
152*8617a60dSAndroid Build Coastguard Worker }
153*8617a60dSAndroid Build Coastguard Worker
154*8617a60dSAndroid Build Coastguard Worker
155*8617a60dSAndroid Build Coastguard Worker /**
156*8617a60dSAndroid Build Coastguard Worker * Test send-command functions
157*8617a60dSAndroid Build Coastguard Worker */
SendCommandTest(void)158*8617a60dSAndroid Build Coastguard Worker static void SendCommandTest(void)
159*8617a60dSAndroid Build Coastguard Worker {
160*8617a60dSAndroid Build Coastguard Worker ResetMocks();
161*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclStartup(), 0, "SaveState");
162*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Startup, " cmd");
163*8617a60dSAndroid Build Coastguard Worker
164*8617a60dSAndroid Build Coastguard Worker ResetMocks();
165*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSaveState(), 0, "SaveState");
166*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_SaveState, " cmd");
167*8617a60dSAndroid Build Coastguard Worker
168*8617a60dSAndroid Build Coastguard Worker ResetMocks();
169*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclResume(), 0, "Resume");
170*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Startup, " cmd");
171*8617a60dSAndroid Build Coastguard Worker
172*8617a60dSAndroid Build Coastguard Worker ResetMocks();
173*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSelfTestFull(), 0, "SelfTestFull");
174*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_SelfTestFull, " cmd");
175*8617a60dSAndroid Build Coastguard Worker
176*8617a60dSAndroid Build Coastguard Worker ResetMocks();
177*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclContinueSelfTest(), 0, "ContinueSelfTest");
178*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ContinueSelfTest, " cmd");
179*8617a60dSAndroid Build Coastguard Worker
180*8617a60dSAndroid Build Coastguard Worker ResetMocks();
181*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclAssertPhysicalPresence(), 0,
182*8617a60dSAndroid Build Coastguard Worker "AssertPhysicalPresence");
183*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TSC_ORD_PhysicalPresence, " cmd");
184*8617a60dSAndroid Build Coastguard Worker
185*8617a60dSAndroid Build Coastguard Worker ResetMocks();
186*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclPhysicalPresenceCMDEnable(), 0,
187*8617a60dSAndroid Build Coastguard Worker "PhysicalPresenceCMDEnable");
188*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TSC_ORD_PhysicalPresence, " cmd");
189*8617a60dSAndroid Build Coastguard Worker
190*8617a60dSAndroid Build Coastguard Worker ResetMocks();
191*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclFinalizePhysicalPresence(), 0,
192*8617a60dSAndroid Build Coastguard Worker "FinalizePhysicalPresence");
193*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TSC_ORD_PhysicalPresence, " cmd");
194*8617a60dSAndroid Build Coastguard Worker
195*8617a60dSAndroid Build Coastguard Worker ResetMocks();
196*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclAssertPhysicalPresenceResult(), 0,
197*8617a60dSAndroid Build Coastguard Worker "AssertPhysicalPresenceResult");
198*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TSC_ORD_PhysicalPresence, " cmd");
199*8617a60dSAndroid Build Coastguard Worker
200*8617a60dSAndroid Build Coastguard Worker ResetMocks();
201*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclLockPhysicalPresence(), 0,
202*8617a60dSAndroid Build Coastguard Worker "LockPhysicalPresence");
203*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TSC_ORD_PhysicalPresence, " cmd");
204*8617a60dSAndroid Build Coastguard Worker
205*8617a60dSAndroid Build Coastguard Worker ResetMocks();
206*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclIsOwned(), 0, "IsOwned");
207*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
208*8617a60dSAndroid Build Coastguard Worker ResetMocks();
209*8617a60dSAndroid Build Coastguard Worker calls[0].retval = VB2_ERROR_MOCK;
210*8617a60dSAndroid Build Coastguard Worker TEST_NEQ(TlclIsOwned(), 0, "IsOwned");
211*8617a60dSAndroid Build Coastguard Worker
212*8617a60dSAndroid Build Coastguard Worker ResetMocks();
213*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclForceClear(), 0, "ForceClear");
214*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ForceClear, " cmd");
215*8617a60dSAndroid Build Coastguard Worker
216*8617a60dSAndroid Build Coastguard Worker ResetMocks();
217*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSetEnable(), 0, "SetEnable");
218*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_PhysicalEnable, " cmd");
219*8617a60dSAndroid Build Coastguard Worker
220*8617a60dSAndroid Build Coastguard Worker ResetMocks();
221*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclClearEnable(), 0, "ClearEnable");
222*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_PhysicalDisable, " cmd");
223*8617a60dSAndroid Build Coastguard Worker
224*8617a60dSAndroid Build Coastguard Worker ResetMocks();
225*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSetDeactivated(0), 0, "SetDeactivated");
226*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_PhysicalSetDeactivated, " cmd");
227*8617a60dSAndroid Build Coastguard Worker }
228*8617a60dSAndroid Build Coastguard Worker
229*8617a60dSAndroid Build Coastguard Worker /**
230*8617a60dSAndroid Build Coastguard Worker * NV spaces test
231*8617a60dSAndroid Build Coastguard Worker *
232*8617a60dSAndroid Build Coastguard Worker * TODO: check params/data read/written.
233*8617a60dSAndroid Build Coastguard Worker */
ReadWriteTest(void)234*8617a60dSAndroid Build Coastguard Worker static void ReadWriteTest(void)
235*8617a60dSAndroid Build Coastguard Worker {
236*8617a60dSAndroid Build Coastguard Worker uint8_t buf[32];
237*8617a60dSAndroid Build Coastguard Worker
238*8617a60dSAndroid Build Coastguard Worker ResetMocks();
239*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpace(1, 2, 3), 0, "DefineSpace");
240*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_DefineSpace, " cmd");
241*8617a60dSAndroid Build Coastguard Worker
242*8617a60dSAndroid Build Coastguard Worker ResetMocks();
243*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclUndefineSpace(1), 0, "UndefineSpace");
244*8617a60dSAndroid Build Coastguard Worker // TPM1.2 use TPM_ORD_NV_DefineSpace with size 0 to delete space
245*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_DefineSpace, " cmd");
246*8617a60dSAndroid Build Coastguard Worker
247*8617a60dSAndroid Build Coastguard Worker ResetMocks();
248*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSetNvLocked(), 0, "SetNvLocked");
249*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_DefineSpace, " cmd");
250*8617a60dSAndroid Build Coastguard Worker
251*8617a60dSAndroid Build Coastguard Worker ResetMocks();
252*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclWrite(1, buf, 3), 0, "Write");
253*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_WriteValue, " cmd");
254*8617a60dSAndroid Build Coastguard Worker
255*8617a60dSAndroid Build Coastguard Worker ResetMocks();
256*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclRead(1, buf, 3), 0, "Read");
257*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_ReadValue, " cmd");
258*8617a60dSAndroid Build Coastguard Worker
259*8617a60dSAndroid Build Coastguard Worker ResetMocks();
260*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclWriteLock(1), 0, "WriteLock");
261*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_WriteValue, " cmd");
262*8617a60dSAndroid Build Coastguard Worker
263*8617a60dSAndroid Build Coastguard Worker ResetMocks();
264*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadLock(1), 0, "ReadLock");
265*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_ReadValue, " cmd");
266*8617a60dSAndroid Build Coastguard Worker
267*8617a60dSAndroid Build Coastguard Worker ResetMocks();
268*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclSetGlobalLock(), 0, "SetGlobalLock");
269*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_NV_WriteValue, " cmd");
270*8617a60dSAndroid Build Coastguard Worker }
271*8617a60dSAndroid Build Coastguard Worker
272*8617a60dSAndroid Build Coastguard Worker /**
273*8617a60dSAndroid Build Coastguard Worker * Test DefineSpaceEx
274*8617a60dSAndroid Build Coastguard Worker */
DefineSpaceExTest(void)275*8617a60dSAndroid Build Coastguard Worker static void DefineSpaceExTest(void) {
276*8617a60dSAndroid Build Coastguard Worker uint8_t osap_response[] = {
277*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x36, 0x00, 0x00,
278*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x02, 0x41, 0x3d, 0xce, 0x20, 0xa2,
279*8617a60dSAndroid Build Coastguard Worker 0x5a, 0xa5, 0x95, 0xbe, 0x26, 0xe8, 0x76, 0x74,
280*8617a60dSAndroid Build Coastguard Worker 0x6c, 0x61, 0xf7, 0xa7, 0x24, 0x17, 0xa1, 0x06,
281*8617a60dSAndroid Build Coastguard Worker 0xcf, 0x53, 0x6d, 0xd4, 0x26, 0x98, 0x68, 0x86,
282*8617a60dSAndroid Build Coastguard Worker 0xe6, 0xf6, 0x62, 0x58, 0xdb, 0xa2, 0x9f, 0x5b,
283*8617a60dSAndroid Build Coastguard Worker 0x18, 0xa6, 0xae, 0x36, 0x32, 0x5d,
284*8617a60dSAndroid Build Coastguard Worker };
285*8617a60dSAndroid Build Coastguard Worker uint8_t define_space_response[] = {
286*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc5, 0x00, 0x00, 0x00, 0x33, 0x00, 0x00,
287*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x42, 0xe6, 0x38, 0xc6, 0x37, 0x2a,
288*8617a60dSAndroid Build Coastguard Worker 0xf2, 0xfe, 0xb4, 0x01, 0x4b, 0x29, 0x63, 0x30,
289*8617a60dSAndroid Build Coastguard Worker 0x4e, 0x2f, 0x2e, 0x74, 0x58, 0xcd, 0x00, 0x40,
290*8617a60dSAndroid Build Coastguard Worker 0x42, 0x10, 0x40, 0xac, 0x93, 0x0c, 0xff, 0x8a,
291*8617a60dSAndroid Build Coastguard Worker 0xc4, 0x98, 0x78, 0xe3, 0xfe, 0x48, 0x5b, 0xb7,
292*8617a60dSAndroid Build Coastguard Worker 0xc8, 0x8d, 0xf4,
293*8617a60dSAndroid Build Coastguard Worker };
294*8617a60dSAndroid Build Coastguard Worker uint8_t owner_secret[TPM_AUTH_DATA_LEN] = { 0 };
295*8617a60dSAndroid Build Coastguard Worker TPM_NV_AUTH_POLICY policy;
296*8617a60dSAndroid Build Coastguard Worker
297*8617a60dSAndroid Build Coastguard Worker ResetMocks();
298*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = osap_response;
299*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(osap_response);
300*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = define_space_response;
301*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(define_space_response);
302*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpaceEx(owner_secret, sizeof(owner_secret),
303*8617a60dSAndroid Build Coastguard Worker 0x20000005, 0x2000, 0x10, NULL, 0),
304*8617a60dSAndroid Build Coastguard Worker TPM_SUCCESS, "DefineSpace");
305*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OSAP, " osap cmd");
306*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_NV_DefineSpace, " definespace cmd");
307*8617a60dSAndroid Build Coastguard Worker
308*8617a60dSAndroid Build Coastguard Worker /* Pass an auth policy. */
309*8617a60dSAndroid Build Coastguard Worker ResetMocks();
310*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = osap_response;
311*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(osap_response);
312*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = define_space_response;
313*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(define_space_response);
314*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpaceEx(owner_secret, sizeof(owner_secret),
315*8617a60dSAndroid Build Coastguard Worker 0x20000005, 0x2000, 0x10, &policy,
316*8617a60dSAndroid Build Coastguard Worker sizeof(policy)),
317*8617a60dSAndroid Build Coastguard Worker TPM_SUCCESS, "DefineSpace");
318*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OSAP, " osap cmd");
319*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_NV_DefineSpace, " definespace cmd");
320*8617a60dSAndroid Build Coastguard Worker
321*8617a60dSAndroid Build Coastguard Worker /* Verify that the response gets authenticated. */
322*8617a60dSAndroid Build Coastguard Worker ResetMocks();
323*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = osap_response;
324*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(osap_response);
325*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = define_space_response;
326*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(define_space_response);
327*8617a60dSAndroid Build Coastguard Worker define_space_response[31] = 0;
328*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpaceEx(owner_secret, sizeof(owner_secret),
329*8617a60dSAndroid Build Coastguard Worker 0x20000005, 0x2000, 0x10, NULL, 0),
330*8617a60dSAndroid Build Coastguard Worker TPM_E_AUTHFAIL, "DefineSpace - response auth");
331*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OSAP, " osap cmd");
332*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_NV_DefineSpace, " definespace cmd");
333*8617a60dSAndroid Build Coastguard Worker define_space_response[31] = 0x40;
334*8617a60dSAndroid Build Coastguard Worker
335*8617a60dSAndroid Build Coastguard Worker /* Verify that a short OSAP response gets caught. */
336*8617a60dSAndroid Build Coastguard Worker ResetMocks();
337*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = osap_response;
338*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(osap_response);
339*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(osap_response + sizeof(uint16_t),
340*8617a60dSAndroid Build Coastguard Worker kTpmRequestHeaderLength + sizeof(uint32_t) +
341*8617a60dSAndroid Build Coastguard Worker 2 * sizeof(TPM_NONCE) - 1);
342*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpaceEx(owner_secret, sizeof(owner_secret),
343*8617a60dSAndroid Build Coastguard Worker 0x20000005, 0x2000, 0x10, NULL, 0),
344*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "DefineSpace - short OSAP response");
345*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OSAP, " osap cmd");
346*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(osap_response + sizeof(uint16_t), sizeof(osap_response));
347*8617a60dSAndroid Build Coastguard Worker
348*8617a60dSAndroid Build Coastguard Worker /* Verify that a short DefineSpace response gets caught. */
349*8617a60dSAndroid Build Coastguard Worker ResetMocks();
350*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = osap_response;
351*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(osap_response);
352*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = define_space_response;
353*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(define_space_response);
354*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(define_space_response + sizeof(uint16_t),
355*8617a60dSAndroid Build Coastguard Worker kTpmResponseHeaderLength + kTpmResponseAuthBlockLength - 1);
356*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclDefineSpaceEx(owner_secret, sizeof(owner_secret),
357*8617a60dSAndroid Build Coastguard Worker 0x20000005, 0x2000, 0x10, NULL, 0),
358*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE,
359*8617a60dSAndroid Build Coastguard Worker "DefineSpace - short DefineSpace response");
360*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OSAP, " osap cmd");
361*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_NV_DefineSpace, " definespace cmd");
362*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(define_space_response + sizeof(uint16_t),
363*8617a60dSAndroid Build Coastguard Worker sizeof(define_space_response));
364*8617a60dSAndroid Build Coastguard Worker }
365*8617a60dSAndroid Build Coastguard Worker
366*8617a60dSAndroid Build Coastguard Worker /**
367*8617a60dSAndroid Build Coastguard Worker * Test TlclInitNvAuthPolicy.
368*8617a60dSAndroid Build Coastguard Worker */
InitNvAuthPolicyTest(void)369*8617a60dSAndroid Build Coastguard Worker static void InitNvAuthPolicyTest(void) {
370*8617a60dSAndroid Build Coastguard Worker const uint8_t empty_selection_digest[] = {
371*8617a60dSAndroid Build Coastguard Worker 0x79, 0xdd, 0xda, 0xfd, 0xc1, 0x97, 0xdc, 0xcc,
372*8617a60dSAndroid Build Coastguard Worker 0xe9, 0x98, 0x9a, 0xee, 0xf5, 0x52, 0x89, 0xee,
373*8617a60dSAndroid Build Coastguard Worker 0x24, 0x96, 0x4c, 0xac,
374*8617a60dSAndroid Build Coastguard Worker };
375*8617a60dSAndroid Build Coastguard Worker const uint8_t pcr0_selection_digest[] = {
376*8617a60dSAndroid Build Coastguard Worker 0xb3, 0x2b, 0x96, 0x30, 0xd3, 0x21, 0x1e, 0x99,
377*8617a60dSAndroid Build Coastguard Worker 0x78, 0x9e, 0xd3, 0x1f, 0x11, 0x8e, 0x96, 0xbc,
378*8617a60dSAndroid Build Coastguard Worker 0xf7, 0x7e, 0x7b, 0x06,
379*8617a60dSAndroid Build Coastguard Worker };
380*8617a60dSAndroid Build Coastguard Worker const uint8_t empty_selection_encoding[] = { 0x0, 0x0, 0x0 };
381*8617a60dSAndroid Build Coastguard Worker const uint8_t pcr0_selection_encoding[] = { 0x1, 0x0, 0x0 };
382*8617a60dSAndroid Build Coastguard Worker const uint8_t pcr_values[][TPM_PCR_DIGEST] = {
383*8617a60dSAndroid Build Coastguard Worker { 0x06, 0x4a, 0xec, 0x9b, 0xbd, 0x94, 0xde, 0xa1,
384*8617a60dSAndroid Build Coastguard Worker 0x23, 0x1a, 0xe7, 0x57, 0x67, 0x64, 0x7f, 0x09,
385*8617a60dSAndroid Build Coastguard Worker 0x8c, 0x39, 0x8e, 0x79, },
386*8617a60dSAndroid Build Coastguard Worker };
387*8617a60dSAndroid Build Coastguard Worker TPM_NV_AUTH_POLICY policy;
388*8617a60dSAndroid Build Coastguard Worker
389*8617a60dSAndroid Build Coastguard Worker /* Test empty selection. */
390*8617a60dSAndroid Build Coastguard Worker uint32_t policy_size = sizeof(policy);
391*8617a60dSAndroid Build Coastguard Worker TlclInitNvAuthPolicy(0x0, NULL, &policy, &policy_size);
392*8617a60dSAndroid Build Coastguard Worker TEST_EQ(policy_size, sizeof(policy), "policy size");
393*8617a60dSAndroid Build Coastguard Worker
394*8617a60dSAndroid Build Coastguard Worker uint16_t size_of_select;
395*8617a60dSAndroid Build Coastguard Worker FromTpmUint16(
396*8617a60dSAndroid Build Coastguard Worker (uint8_t*)&policy.pcr_info_read.pcrSelection.sizeOfSelect,
397*8617a60dSAndroid Build Coastguard Worker &size_of_select);
398*8617a60dSAndroid Build Coastguard Worker TEST_EQ(size_of_select, 3, "empty PCR selection read size of select");
399*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(policy.pcr_info_read.pcrSelection.pcrSelect,
400*8617a60dSAndroid Build Coastguard Worker empty_selection_encoding,
401*8617a60dSAndroid Build Coastguard Worker sizeof(empty_selection_encoding)), 0,
402*8617a60dSAndroid Build Coastguard Worker "empty PCR selection read selection encoding");
403*8617a60dSAndroid Build Coastguard Worker TEST_EQ(policy.pcr_info_read.localityAtRelease,
404*8617a60dSAndroid Build Coastguard Worker TPM_ALL_LOCALITIES & ~TPM_LOC_THREE,
405*8617a60dSAndroid Build Coastguard Worker "empty PCR selection read locality");
406*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(empty_selection_digest,
407*8617a60dSAndroid Build Coastguard Worker policy.pcr_info_read.digestAtRelease.digest,
408*8617a60dSAndroid Build Coastguard Worker TPM_PCR_DIGEST),
409*8617a60dSAndroid Build Coastguard Worker 0, "empty PCR selection read digest");
410*8617a60dSAndroid Build Coastguard Worker
411*8617a60dSAndroid Build Coastguard Worker FromTpmUint16(
412*8617a60dSAndroid Build Coastguard Worker (uint8_t*)&policy.pcr_info_write.pcrSelection.sizeOfSelect,
413*8617a60dSAndroid Build Coastguard Worker &size_of_select);
414*8617a60dSAndroid Build Coastguard Worker TEST_EQ(size_of_select, 3, "empty PCR selection write size of select");
415*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(policy.pcr_info_write.pcrSelection.pcrSelect,
416*8617a60dSAndroid Build Coastguard Worker empty_selection_encoding,
417*8617a60dSAndroid Build Coastguard Worker sizeof(empty_selection_encoding)), 0,
418*8617a60dSAndroid Build Coastguard Worker "empty PCR selection write selection encoding");
419*8617a60dSAndroid Build Coastguard Worker TEST_EQ(policy.pcr_info_write.localityAtRelease,
420*8617a60dSAndroid Build Coastguard Worker TPM_ALL_LOCALITIES & ~TPM_LOC_THREE,
421*8617a60dSAndroid Build Coastguard Worker "empty PCR selection write locality");
422*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(empty_selection_digest,
423*8617a60dSAndroid Build Coastguard Worker policy.pcr_info_write.digestAtRelease.digest,
424*8617a60dSAndroid Build Coastguard Worker TPM_PCR_DIGEST),
425*8617a60dSAndroid Build Coastguard Worker 0, "empty PCR selection write digest");
426*8617a60dSAndroid Build Coastguard Worker
427*8617a60dSAndroid Build Coastguard Worker /* Test PCR0 selection. */
428*8617a60dSAndroid Build Coastguard Worker TlclInitNvAuthPolicy(0x1, pcr_values, &policy, &policy_size);
429*8617a60dSAndroid Build Coastguard Worker TEST_EQ(policy_size, sizeof(policy), "policy size");
430*8617a60dSAndroid Build Coastguard Worker
431*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(policy.pcr_info_read.pcrSelection.pcrSelect,
432*8617a60dSAndroid Build Coastguard Worker pcr0_selection_encoding,
433*8617a60dSAndroid Build Coastguard Worker sizeof(pcr0_selection_encoding)), 0,
434*8617a60dSAndroid Build Coastguard Worker "PCR0 selection read selection encoding");
435*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(pcr0_selection_digest,
436*8617a60dSAndroid Build Coastguard Worker policy.pcr_info_read.digestAtRelease.digest,
437*8617a60dSAndroid Build Coastguard Worker TPM_PCR_DIGEST),
438*8617a60dSAndroid Build Coastguard Worker 0, "PCR0 selection read digest");
439*8617a60dSAndroid Build Coastguard Worker
440*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(policy.pcr_info_write.pcrSelection.pcrSelect,
441*8617a60dSAndroid Build Coastguard Worker pcr0_selection_encoding,
442*8617a60dSAndroid Build Coastguard Worker sizeof(pcr0_selection_encoding)), 0,
443*8617a60dSAndroid Build Coastguard Worker "PCR0 selection write selection encoding");
444*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(pcr0_selection_digest,
445*8617a60dSAndroid Build Coastguard Worker policy.pcr_info_write.digestAtRelease.digest,
446*8617a60dSAndroid Build Coastguard Worker TPM_PCR_DIGEST),
447*8617a60dSAndroid Build Coastguard Worker 0, "PCR0 selection write digest");
448*8617a60dSAndroid Build Coastguard Worker }
449*8617a60dSAndroid Build Coastguard Worker
450*8617a60dSAndroid Build Coastguard Worker /**
451*8617a60dSAndroid Build Coastguard Worker * Test PCR funcs
452*8617a60dSAndroid Build Coastguard Worker *
453*8617a60dSAndroid Build Coastguard Worker * TODO: check params/data read/written.
454*8617a60dSAndroid Build Coastguard Worker */
PcrTest(void)455*8617a60dSAndroid Build Coastguard Worker static void PcrTest(void)
456*8617a60dSAndroid Build Coastguard Worker {
457*8617a60dSAndroid Build Coastguard Worker uint8_t buf[kPcrDigestLength], buf2[kPcrDigestLength];
458*8617a60dSAndroid Build Coastguard Worker
459*8617a60dSAndroid Build Coastguard Worker ResetMocks();
460*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclPCRRead(1, buf, kPcrDigestLength), 0, "PCRRead");
461*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_PcrRead, " cmd");
462*8617a60dSAndroid Build Coastguard Worker
463*8617a60dSAndroid Build Coastguard Worker ResetMocks();
464*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclPCRRead(1, buf, kPcrDigestLength - 1), TPM_E_IOERROR,
465*8617a60dSAndroid Build Coastguard Worker "PCRRead too small");
466*8617a60dSAndroid Build Coastguard Worker
467*8617a60dSAndroid Build Coastguard Worker ResetMocks();
468*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclExtend(1, buf, buf2), 0, "Extend");
469*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Extend, " cmd");
470*8617a60dSAndroid Build Coastguard Worker }
471*8617a60dSAndroid Build Coastguard Worker
472*8617a60dSAndroid Build Coastguard Worker /**
473*8617a60dSAndroid Build Coastguard Worker * Test TlclGetSpaceInfo.
474*8617a60dSAndroid Build Coastguard Worker */
GetSpaceInfoTest(void)475*8617a60dSAndroid Build Coastguard Worker static void GetSpaceInfoTest(void)
476*8617a60dSAndroid Build Coastguard Worker {
477*8617a60dSAndroid Build Coastguard Worker uint8_t response[] = {
478*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x55, 0x00, 0x00,
479*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x47, 0x00, 0x18,
480*8617a60dSAndroid Build Coastguard Worker 0x20, 0x00, 0x00, 0x04, 0x00, 0x03, 0x01, 0x00,
481*8617a60dSAndroid Build Coastguard Worker 0x00, 0x01, 0xb3, 0x2b, 0x96, 0x30, 0xd3, 0x21,
482*8617a60dSAndroid Build Coastguard Worker 0x1e, 0x99, 0x78, 0x9e, 0xd3, 0x1f, 0x11, 0x8e,
483*8617a60dSAndroid Build Coastguard Worker 0x96, 0xbc, 0xf7, 0x7e, 0x7b, 0x06, 0x00, 0x03,
484*8617a60dSAndroid Build Coastguard Worker 0x20, 0x00, 0x00, 0x10, 0x3b, 0xb2, 0x69, 0x03,
485*8617a60dSAndroid Build Coastguard Worker 0x3d, 0x12, 0xe1, 0x99, 0x87, 0xe9, 0x3d, 0xf1,
486*8617a60dSAndroid Build Coastguard Worker 0x11, 0xe8, 0x69, 0xcb, 0x7f, 0xe7, 0xb7, 0x60,
487*8617a60dSAndroid Build Coastguard Worker 0x00, 0x17, 0x00, 0x00, 0x20, 0x00, 0x00, 0x01,
488*8617a60dSAndroid Build Coastguard Worker 0x01, 0x00, 0x00, 0x00, 0x45,
489*8617a60dSAndroid Build Coastguard Worker };
490*8617a60dSAndroid Build Coastguard Worker
491*8617a60dSAndroid Build Coastguard Worker uint32_t attributes = 0;
492*8617a60dSAndroid Build Coastguard Worker uint32_t size = 0;
493*8617a60dSAndroid Build Coastguard Worker TPM_NV_AUTH_POLICY policy;
494*8617a60dSAndroid Build Coastguard Worker uint32_t policy_size = sizeof(policy);
495*8617a60dSAndroid Build Coastguard Worker
496*8617a60dSAndroid Build Coastguard Worker /* Test successful parsing. */
497*8617a60dSAndroid Build Coastguard Worker ResetMocks();
498*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
499*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
500*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetSpaceInfo(0x20000004, &attributes, &size, &policy,
501*8617a60dSAndroid Build Coastguard Worker &policy_size),
502*8617a60dSAndroid Build Coastguard Worker TPM_SUCCESS, "GetSpaceInfo");
503*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
504*8617a60dSAndroid Build Coastguard Worker TEST_EQ(policy_size, sizeof(policy), " policy_size");
505*8617a60dSAndroid Build Coastguard Worker TEST_EQ(attributes, TPM_NV_PER_WRITEDEFINE, " attributes");
506*8617a60dSAndroid Build Coastguard Worker TEST_EQ(size, 0x45, " size");
507*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(&policy, response + 20, sizeof(policy)), 0, " policy");
508*8617a60dSAndroid Build Coastguard Worker
509*8617a60dSAndroid Build Coastguard Worker /* Test that GetPermissions returns the attributes as well. */
510*8617a60dSAndroid Build Coastguard Worker ResetMocks();
511*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
512*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
513*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetPermissions(0x20000004, &attributes),
514*8617a60dSAndroid Build Coastguard Worker TPM_SUCCESS, "GetPermissions");
515*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
516*8617a60dSAndroid Build Coastguard Worker TEST_EQ(attributes, TPM_NV_PER_WRITEDEFINE, " attributes");
517*8617a60dSAndroid Build Coastguard Worker
518*8617a60dSAndroid Build Coastguard Worker /* Test whether a short response gets detected. */
519*8617a60dSAndroid Build Coastguard Worker ResetMocks();
520*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
521*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
522*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 10, 0x46);
523*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetSpaceInfo(0x20000004, &attributes, &size, &policy,
524*8617a60dSAndroid Build Coastguard Worker &policy_size),
525*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "GetSpaceInfo short length");
526*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 10, 0x47);
527*8617a60dSAndroid Build Coastguard Worker
528*8617a60dSAndroid Build Coastguard Worker /* Test whether an overlong PCR selection length causes failure. */
529*8617a60dSAndroid Build Coastguard Worker ResetMocks();
530*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
531*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
532*8617a60dSAndroid Build Coastguard Worker ToTpmUint16(response + 20, 4);
533*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetSpaceInfo(0x20000004, &attributes, &size, &policy,
534*8617a60dSAndroid Build Coastguard Worker &policy_size),
535*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "GetSpaceInfo overlong pcr selection");
536*8617a60dSAndroid Build Coastguard Worker ToTpmUint16(response + 20, 3);
537*8617a60dSAndroid Build Coastguard Worker
538*8617a60dSAndroid Build Coastguard Worker /* Test that a short policy buffer triggers an error. */
539*8617a60dSAndroid Build Coastguard Worker ResetMocks();
540*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
541*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
542*8617a60dSAndroid Build Coastguard Worker policy_size = sizeof(policy) - 1;
543*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetSpaceInfo(0x20000004, &attributes, &size, &policy,
544*8617a60dSAndroid Build Coastguard Worker &policy_size),
545*8617a60dSAndroid Build Coastguard Worker TPM_E_BUFFER_SIZE, "GetSpaceInfo short policy buffer");
546*8617a60dSAndroid Build Coastguard Worker TEST_EQ(sizeof(policy), policy_size, " policy_size");
547*8617a60dSAndroid Build Coastguard Worker }
548*8617a60dSAndroid Build Coastguard Worker
549*8617a60dSAndroid Build Coastguard Worker /**
550*8617a60dSAndroid Build Coastguard Worker * Test flags / capabilities
551*8617a60dSAndroid Build Coastguard Worker *
552*8617a60dSAndroid Build Coastguard Worker * TODO: check params/data read/written.
553*8617a60dSAndroid Build Coastguard Worker */
FlagsTest(void)554*8617a60dSAndroid Build Coastguard Worker static void FlagsTest(void)
555*8617a60dSAndroid Build Coastguard Worker {
556*8617a60dSAndroid Build Coastguard Worker TPM_PERMANENT_FLAGS pflags;
557*8617a60dSAndroid Build Coastguard Worker TPM_STCLEAR_FLAGS vflags;
558*8617a60dSAndroid Build Coastguard Worker uint8_t disable = 0, deactivated = 0, nvlocked = 0;
559*8617a60dSAndroid Build Coastguard Worker uint8_t buf[32];
560*8617a60dSAndroid Build Coastguard Worker
561*8617a60dSAndroid Build Coastguard Worker ResetMocks();
562*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetPermanentFlags(&pflags), 0, "GetPermanentFlags");
563*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
564*8617a60dSAndroid Build Coastguard Worker
565*8617a60dSAndroid Build Coastguard Worker ResetMocks();
566*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetSTClearFlags(&vflags), 0, "GetSTClearFlags");
567*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
568*8617a60dSAndroid Build Coastguard Worker
569*8617a60dSAndroid Build Coastguard Worker ResetMocks();
570*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetFlags(NULL, NULL, NULL), 0, "GetFlags NULL");
571*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
572*8617a60dSAndroid Build Coastguard Worker ResetMocks();
573*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetFlags(&disable, &deactivated, &nvlocked), 0, "GetFlags");
574*8617a60dSAndroid Build Coastguard Worker
575*8617a60dSAndroid Build Coastguard Worker ResetMocks();
576*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetOwnership(buf), 0, "GetOwnership");
577*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
578*8617a60dSAndroid Build Coastguard Worker }
579*8617a60dSAndroid Build Coastguard Worker
580*8617a60dSAndroid Build Coastguard Worker /**
581*8617a60dSAndroid Build Coastguard Worker * Test random
582*8617a60dSAndroid Build Coastguard Worker *
583*8617a60dSAndroid Build Coastguard Worker * TODO: check params/data read/written.
584*8617a60dSAndroid Build Coastguard Worker * TODO: check overflow tests.
585*8617a60dSAndroid Build Coastguard Worker */
RandomTest(void)586*8617a60dSAndroid Build Coastguard Worker static void RandomTest(void)
587*8617a60dSAndroid Build Coastguard Worker {
588*8617a60dSAndroid Build Coastguard Worker uint8_t buf[32];
589*8617a60dSAndroid Build Coastguard Worker uint32_t size;
590*8617a60dSAndroid Build Coastguard Worker
591*8617a60dSAndroid Build Coastguard Worker ResetMocks();
592*8617a60dSAndroid Build Coastguard Worker size = sizeof(buf);
593*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetRandom(buf, sizeof(buf), &size), 0, "GetRandom");
594*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetRandom, " cmd");
595*8617a60dSAndroid Build Coastguard Worker TEST_EQ(size, 0, " size 0");
596*8617a60dSAndroid Build Coastguard Worker }
597*8617a60dSAndroid Build Coastguard Worker
598*8617a60dSAndroid Build Coastguard Worker /**
599*8617a60dSAndroid Build Coastguard Worker * Test GetVersion
600*8617a60dSAndroid Build Coastguard Worker */
GetVersionTest(void)601*8617a60dSAndroid Build Coastguard Worker static void GetVersionTest(void)
602*8617a60dSAndroid Build Coastguard Worker {
603*8617a60dSAndroid Build Coastguard Worker uint8_t response[] = {
604*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x2a, 0x00, 0x00,
605*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, 0x30,
606*8617a60dSAndroid Build Coastguard Worker 0x01, 0x02, 0x04, 0x20, 0x00, 0x02, 0x03, 0x49,
607*8617a60dSAndroid Build Coastguard Worker 0x46, 0x58, 0x00, 0x00, 0x0d, 0x04, 0x20, 0x03,
608*8617a60dSAndroid Build Coastguard Worker 0x6f, 0x00, 0x74, 0x70, 0x6d, 0x33, 0x38, 0xff,
609*8617a60dSAndroid Build Coastguard Worker 0xff, 0xff
610*8617a60dSAndroid Build Coastguard Worker };
611*8617a60dSAndroid Build Coastguard Worker
612*8617a60dSAndroid Build Coastguard Worker uint32_t vendor;
613*8617a60dSAndroid Build Coastguard Worker uint64_t firmware_version;
614*8617a60dSAndroid Build Coastguard Worker uint8_t vendor_specific[32];
615*8617a60dSAndroid Build Coastguard Worker size_t vendor_specific_size;
616*8617a60dSAndroid Build Coastguard Worker
617*8617a60dSAndroid Build Coastguard Worker ResetMocks();
618*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
619*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
620*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version, NULL, NULL), 0,
621*8617a60dSAndroid Build Coastguard Worker "GetVersion");
622*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
623*8617a60dSAndroid Build Coastguard Worker TEST_EQ(vendor, 0x49465800, " vendor");
624*8617a60dSAndroid Build Coastguard Worker TEST_EQ(firmware_version, 0x420, " firmware_version");
625*8617a60dSAndroid Build Coastguard Worker
626*8617a60dSAndroid Build Coastguard Worker ResetMocks();
627*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
628*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
629*8617a60dSAndroid Build Coastguard Worker vendor_specific_size = 100;
630*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version,
631*8617a60dSAndroid Build Coastguard Worker NULL, &vendor_specific_size), 0,
632*8617a60dSAndroid Build Coastguard Worker "GetVersion - vendor specific size");
633*8617a60dSAndroid Build Coastguard Worker TEST_EQ(vendor_specific_size, 0xd, " vendor specific size");
634*8617a60dSAndroid Build Coastguard Worker
635*8617a60dSAndroid Build Coastguard Worker ResetMocks();
636*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
637*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
638*8617a60dSAndroid Build Coastguard Worker vendor_specific_size = sizeof(vendor_specific);
639*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version,
640*8617a60dSAndroid Build Coastguard Worker vendor_specific, &vendor_specific_size), 0,
641*8617a60dSAndroid Build Coastguard Worker "GetVersion - vendor specific data");
642*8617a60dSAndroid Build Coastguard Worker TEST_EQ(vendor_specific_size, 0xd, " vendor specific size");
643*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(vendor_specific, response + 29, 0xd), 0,
644*8617a60dSAndroid Build Coastguard Worker " vendor specific data check");
645*8617a60dSAndroid Build Coastguard Worker
646*8617a60dSAndroid Build Coastguard Worker ResetMocks();
647*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
648*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
649*8617a60dSAndroid Build Coastguard Worker vendor_specific_size = 4;
650*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version,
651*8617a60dSAndroid Build Coastguard Worker vendor_specific, &vendor_specific_size), 0,
652*8617a60dSAndroid Build Coastguard Worker "GetVersion - vendor specific data, short buf");
653*8617a60dSAndroid Build Coastguard Worker TEST_EQ(vendor_specific_size, 4,
654*8617a60dSAndroid Build Coastguard Worker " min(vendor specific size, buf size)");
655*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(vendor_specific, response + 29, 4), 0,
656*8617a60dSAndroid Build Coastguard Worker " vendor specific data check");
657*8617a60dSAndroid Build Coastguard Worker
658*8617a60dSAndroid Build Coastguard Worker ResetMocks();
659*8617a60dSAndroid Build Coastguard Worker SetResponse(0, TPM_E_IOERROR, 0);
660*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version, NULL, NULL),
661*8617a60dSAndroid Build Coastguard Worker TPM_E_IOERROR, "GetVersion - error");
662*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
663*8617a60dSAndroid Build Coastguard Worker
664*8617a60dSAndroid Build Coastguard Worker /* Adjust response to indicate a 1 byte too short payload size. */
665*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + kTpmResponseHeaderLength, 14);
666*8617a60dSAndroid Build Coastguard Worker ResetMocks();
667*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
668*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
669*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version, NULL, NULL),
670*8617a60dSAndroid Build Coastguard Worker TPM_E_IOERROR, "GetVersion -- short");
671*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
672*8617a60dSAndroid Build Coastguard Worker
673*8617a60dSAndroid Build Coastguard Worker /* Adjust response to indicate a payload size too long for the
674*8617a60dSAndroid Build Coastguard Worker * response buffer. */
675*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + kTpmResponseHeaderLength,
676*8617a60dSAndroid Build Coastguard Worker TPM_LARGE_ENOUGH_COMMAND_SIZE - sizeof(uint32_t) -
677*8617a60dSAndroid Build Coastguard Worker kTpmResponseHeaderLength + 1);
678*8617a60dSAndroid Build Coastguard Worker ResetMocks();
679*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
680*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
681*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version, NULL, NULL),
682*8617a60dSAndroid Build Coastguard Worker TPM_E_IOERROR, "GetVersion -- long");
683*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
684*8617a60dSAndroid Build Coastguard Worker
685*8617a60dSAndroid Build Coastguard Worker /* Restore the original payload length and adjust response to contain
686*8617a60dSAndroid Build Coastguard Worker * less vendor specific data than indicated in its size. */
687*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + kTpmResponseHeaderLength, 0x1c);
688*8617a60dSAndroid Build Coastguard Worker ToTpmUint16(response + 27, 0xd + 1);
689*8617a60dSAndroid Build Coastguard Worker ResetMocks();
690*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
691*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
692*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclGetVersion(&vendor, &firmware_version,
693*8617a60dSAndroid Build Coastguard Worker NULL, &vendor_specific_size), TPM_E_IOERROR,
694*8617a60dSAndroid Build Coastguard Worker "GetVersion -- short with vendor specific");
695*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_GetCapability, " cmd");
696*8617a60dSAndroid Build Coastguard Worker }
697*8617a60dSAndroid Build Coastguard Worker
698*8617a60dSAndroid Build Coastguard Worker /**
699*8617a60dSAndroid Build Coastguard Worker * Test IFX FieldUpgradeInfoRequest2
700*8617a60dSAndroid Build Coastguard Worker */
IFXFieldUpgradeInfoTest(void)701*8617a60dSAndroid Build Coastguard Worker static void IFXFieldUpgradeInfoTest(void)
702*8617a60dSAndroid Build Coastguard Worker {
703*8617a60dSAndroid Build Coastguard Worker uint8_t version_response[] = {
704*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x2a, 0x00, 0x00,
705*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, 0x30,
706*8617a60dSAndroid Build Coastguard Worker 0x01, 0x02, 0x04, 0x20, 0x00, 0x02, 0x03, 0x49,
707*8617a60dSAndroid Build Coastguard Worker 0x46, 0x58, 0x00, 0x00, 0x0d, 0x04, 0x20, 0x03,
708*8617a60dSAndroid Build Coastguard Worker 0x6f, 0x00, 0x74, 0x70, 0x6d, 0x33, 0x38, 0xff,
709*8617a60dSAndroid Build Coastguard Worker 0xff, 0xff
710*8617a60dSAndroid Build Coastguard Worker };
711*8617a60dSAndroid Build Coastguard Worker uint8_t upgrade_info_response[] = {
712*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x76, 0x00, 0x00,
713*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x6a, 0x03, 0x02, 0x04, 0x9c,
714*8617a60dSAndroid Build Coastguard Worker 0x04, 0x01, 0x00, 0x00, 0x01, 0x02, 0x00, 0x08,
715*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
716*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
717*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
718*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
719*8617a60dSAndroid Build Coastguard Worker 0x00, 0x05, 0x01, 0x00, 0x00, 0x00, 0xff, 0xff,
720*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x04, 0x01,
721*8617a60dSAndroid Build Coastguard Worker 0x01, 0x00, 0x00, 0x00, 0x00, 0xbe, 0x00, 0x00,
722*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x04, 0x01, 0x02, 0x00, 0x00, 0x00,
723*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0xff, 0xff, 0xee, 0xee, 0x5a, 0x3c,
724*8617a60dSAndroid Build Coastguard Worker 0x04, 0x01, 0x02, 0x00, 0x00, 0x00, 0x08, 0x32,
725*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x06, 0x00, 0x00,
726*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x3f
727*8617a60dSAndroid Build Coastguard Worker };
728*8617a60dSAndroid Build Coastguard Worker
729*8617a60dSAndroid Build Coastguard Worker ResetMocks();
730*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = version_response;
731*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(version_response);
732*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = upgrade_info_response;
733*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(upgrade_info_response);
734*8617a60dSAndroid Build Coastguard Worker TPM_IFX_FIELDUPGRADEINFO info;
735*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclIFXFieldUpgradeInfo(&info), 0, "IFXFieldUpgradeInfo");
736*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_FieldUpgrade, " cmd");
737*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.wMaxDataSize, 1180, " wMaxDatasize");
738*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sBootloaderFirmwarePackage.FwPackageIdentifier, 0x50100,
739*8617a60dSAndroid Build Coastguard Worker " bootloader FWPackageIdeintifier");
740*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sBootloaderFirmwarePackage.Version, 0xffff,
741*8617a60dSAndroid Build Coastguard Worker " bootloader Version");
742*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sBootloaderFirmwarePackage.StaleVersion, 0x0,
743*8617a60dSAndroid Build Coastguard Worker " bootloader StaleVersion");
744*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[0].FwPackageIdentifier, 0x4010100,
745*8617a60dSAndroid Build Coastguard Worker " fw[0] FWPackageIdeintifier");
746*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[0].Version, 0xbe,
747*8617a60dSAndroid Build Coastguard Worker " fw[0] Version");
748*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[0].StaleVersion, 0x0,
749*8617a60dSAndroid Build Coastguard Worker " fw[0] StaleVersion");
750*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[1].FwPackageIdentifier, 0x4010200,
751*8617a60dSAndroid Build Coastguard Worker " fw[1] FWPackageIdeintifier");
752*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[1].Version, 0x0,
753*8617a60dSAndroid Build Coastguard Worker " fw[1] Version");
754*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sFirmwarePackages[1].StaleVersion, 0xffffeeee,
755*8617a60dSAndroid Build Coastguard Worker " fw[1] StaleVersion");
756*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.wSecurityModuleStatus, 0x5a3c, " wSecurityModuleStatus");
757*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sProcessFirmwarePackage.FwPackageIdentifier, 0x4010200,
758*8617a60dSAndroid Build Coastguard Worker " process FWPackageIdeintifier");
759*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sProcessFirmwarePackage.Version, 0x832,
760*8617a60dSAndroid Build Coastguard Worker " process Version");
761*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.sProcessFirmwarePackage.StaleVersion, 0x0,
762*8617a60dSAndroid Build Coastguard Worker " process StaleVersion");
763*8617a60dSAndroid Build Coastguard Worker TEST_EQ(info.wFieldUpgradeCounter, 0x3f, " wFieldUpgradeCounter");
764*8617a60dSAndroid Build Coastguard Worker
765*8617a60dSAndroid Build Coastguard Worker ResetMocks();
766*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = version_response;
767*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(version_response);
768*8617a60dSAndroid Build Coastguard Worker SetResponse(1, TPM_E_IOERROR, sizeof(upgrade_info_response) - 1);
769*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclIFXFieldUpgradeInfo(&info), TPM_E_IOERROR,
770*8617a60dSAndroid Build Coastguard Worker "IFXFieldUpgradeInfo - error");
771*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_FieldUpgrade, " cmd");
772*8617a60dSAndroid Build Coastguard Worker
773*8617a60dSAndroid Build Coastguard Worker /* Adjust response to indicate a 1 byte too short payload size. */
774*8617a60dSAndroid Build Coastguard Worker ToTpmUint16(upgrade_info_response + kTpmRequestHeaderLength,
775*8617a60dSAndroid Build Coastguard Worker sizeof(upgrade_info_response) - kTpmRequestHeaderLength -
776*8617a60dSAndroid Build Coastguard Worker sizeof(uint16_t) - 1);
777*8617a60dSAndroid Build Coastguard Worker ResetMocks();
778*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = version_response;
779*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(version_response);
780*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = upgrade_info_response;
781*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(upgrade_info_response);
782*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclIFXFieldUpgradeInfo(&info), TPM_E_INVALID_RESPONSE,
783*8617a60dSAndroid Build Coastguard Worker "IFXFieldUpgradeInfo - short");
784*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_FieldUpgrade, " cmd");
785*8617a60dSAndroid Build Coastguard Worker
786*8617a60dSAndroid Build Coastguard Worker /* Adjust version response to claim a non-IFX vendor. */
787*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(version_response + kTpmResponseHeaderLength +
788*8617a60dSAndroid Build Coastguard Worker sizeof(uint32_t), 0);
789*8617a60dSAndroid Build Coastguard Worker ResetMocks();
790*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = version_response;
791*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(version_response);
792*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclIFXFieldUpgradeInfo(&info), TPM_E_INVALID_RESPONSE,
793*8617a60dSAndroid Build Coastguard Worker "IFXFieldUpgradeInfo - bad vendor");
794*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_FieldUpgrade, " cmd");
795*8617a60dSAndroid Build Coastguard Worker }
796*8617a60dSAndroid Build Coastguard Worker
797*8617a60dSAndroid Build Coastguard Worker /**
798*8617a60dSAndroid Build Coastguard Worker * Test ReadPubek
799*8617a60dSAndroid Build Coastguard Worker */
ReadPubekTest(void)800*8617a60dSAndroid Build Coastguard Worker static void ReadPubekTest(void) {
801*8617a60dSAndroid Build Coastguard Worker uint8_t response[] = {
802*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x01, 0x3a, 0x00, 0x00,
803*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x03,
804*8617a60dSAndroid Build Coastguard Worker 0x00, 0x01, 0x00, 0x00, 0x00, 0x0c, 0x00, 0x00,
805*8617a60dSAndroid Build Coastguard Worker 0x08, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00,
806*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x9c, 0xa8,
807*8617a60dSAndroid Build Coastguard Worker 0x8f, 0x15, 0x6d, 0xbf, 0x37, 0x6f, 0x8d, 0xb7,
808*8617a60dSAndroid Build Coastguard Worker 0xb2, 0xe2, 0x79, 0x81, 0xf7, 0xc2, 0x3c, 0x84,
809*8617a60dSAndroid Build Coastguard Worker 0x64, 0x35, 0x38, 0x59, 0x6a, 0x87, 0x23, 0xe0,
810*8617a60dSAndroid Build Coastguard Worker 0x2a, 0xca, 0x40, 0x37, 0x78, 0x75, 0x18, 0xfc,
811*8617a60dSAndroid Build Coastguard Worker 0x2d, 0xbe, 0x2b, 0xd9, 0x77, 0x49, 0x4b, 0x8c,
812*8617a60dSAndroid Build Coastguard Worker 0xea, 0xe3, 0xcd, 0xa5, 0x27, 0x2b, 0x48, 0x2f,
813*8617a60dSAndroid Build Coastguard Worker 0xbe, 0x3b, 0x14, 0xca, 0xe5, 0x22, 0x31, 0xb8,
814*8617a60dSAndroid Build Coastguard Worker 0xa1, 0x14, 0xc6, 0x06, 0x8d, 0x14, 0xe8, 0x4a,
815*8617a60dSAndroid Build Coastguard Worker 0x36, 0x4d, 0xd3, 0x5f, 0xde, 0x23, 0xd1, 0x7b,
816*8617a60dSAndroid Build Coastguard Worker 0xec, 0x3b, 0xdd, 0x84, 0xa4, 0xd4, 0xe9, 0x9a,
817*8617a60dSAndroid Build Coastguard Worker 0x89, 0x94, 0x5c, 0xa0, 0x01, 0xfb, 0x95, 0x61,
818*8617a60dSAndroid Build Coastguard Worker 0x01, 0xaf, 0x6b, 0x17, 0x39, 0x44, 0x7e, 0x25,
819*8617a60dSAndroid Build Coastguard Worker 0x9b, 0x73, 0xfa, 0xde, 0x20, 0xb6, 0x92, 0x95,
820*8617a60dSAndroid Build Coastguard Worker 0x7b, 0x76, 0x9f, 0x44, 0xb0, 0xfb, 0x86, 0x9f,
821*8617a60dSAndroid Build Coastguard Worker 0xc5, 0xe2, 0x38, 0x9d, 0xcf, 0xce, 0x32, 0x53,
822*8617a60dSAndroid Build Coastguard Worker 0x3b, 0x3d, 0x10, 0xb7, 0x89, 0x53, 0x54, 0xc0,
823*8617a60dSAndroid Build Coastguard Worker 0x28, 0x52, 0xfc, 0x7a, 0xa9, 0x5b, 0x03, 0xd7,
824*8617a60dSAndroid Build Coastguard Worker 0x55, 0x2b, 0x07, 0xa7, 0x22, 0x5b, 0x1e, 0xe5,
825*8617a60dSAndroid Build Coastguard Worker 0x4f, 0x43, 0x70, 0x7d, 0x81, 0xbb, 0x3d, 0x56,
826*8617a60dSAndroid Build Coastguard Worker 0xfe, 0x5c, 0x47, 0xcc, 0xc0, 0x6e, 0xc8, 0xc7,
827*8617a60dSAndroid Build Coastguard Worker 0xd9, 0x96, 0x53, 0x2d, 0xd2, 0x28, 0xc7, 0xdf,
828*8617a60dSAndroid Build Coastguard Worker 0x5a, 0x07, 0x50, 0x3b, 0x17, 0x25, 0xe7, 0x51,
829*8617a60dSAndroid Build Coastguard Worker 0xed, 0xf7, 0x94, 0x02, 0x2a, 0x4c, 0x31, 0x57,
830*8617a60dSAndroid Build Coastguard Worker 0x34, 0x51, 0x05, 0x26, 0x43, 0xd4, 0x40, 0x47,
831*8617a60dSAndroid Build Coastguard Worker 0x3e, 0x02, 0xfe, 0xa5, 0x08, 0xc7, 0x94, 0xaa,
832*8617a60dSAndroid Build Coastguard Worker 0xd3, 0x14, 0x02, 0x1b, 0x41, 0x4c, 0xcd, 0xd6,
833*8617a60dSAndroid Build Coastguard Worker 0x8c, 0xad, 0x8e, 0x72, 0x1a, 0x36, 0xc7, 0x23,
834*8617a60dSAndroid Build Coastguard Worker 0xd1, 0x38, 0x83, 0x9f, 0xac, 0x66, 0xc5, 0x25,
835*8617a60dSAndroid Build Coastguard Worker 0x82, 0x9d, 0x18, 0x67, 0x78, 0xca, 0x15, 0x63,
836*8617a60dSAndroid Build Coastguard Worker 0x15, 0xd8, 0x83, 0xbd, 0xcc, 0xe7, 0xf7, 0xe9,
837*8617a60dSAndroid Build Coastguard Worker 0xba, 0xda, 0x23, 0xdf, 0x53, 0x30, 0x51, 0x1a,
838*8617a60dSAndroid Build Coastguard Worker 0xf1, 0x0c, 0x02, 0xe7, 0x65, 0x0d, 0x95, 0x52,
839*8617a60dSAndroid Build Coastguard Worker 0x76, 0xd1, 0x1b, 0xb0, 0x77, 0xba, 0x31, 0x0b,
840*8617a60dSAndroid Build Coastguard Worker 0x17, 0xb5, 0x63, 0x0d, 0x50, 0x7c, 0xbc, 0x63,
841*8617a60dSAndroid Build Coastguard Worker 0xbf, 0xc3,
842*8617a60dSAndroid Build Coastguard Worker };
843*8617a60dSAndroid Build Coastguard Worker uint32_t exponent = 0;
844*8617a60dSAndroid Build Coastguard Worker uint8_t modulus[TPM_RSA_2048_LEN];
845*8617a60dSAndroid Build Coastguard Worker uint32_t modulus_size = TPM_RSA_2048_LEN;
846*8617a60dSAndroid Build Coastguard Worker
847*8617a60dSAndroid Build Coastguard Worker ResetMocks();
848*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
849*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
850*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, modulus, &modulus_size), TPM_SUCCESS,
851*8617a60dSAndroid Build Coastguard Worker "ReadPubek");
852*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
853*8617a60dSAndroid Build Coastguard Worker TEST_EQ(exponent, 0x10001, " exponent");
854*8617a60dSAndroid Build Coastguard Worker TEST_EQ(memcmp(modulus, response + 38, sizeof(modulus)), TPM_SUCCESS,
855*8617a60dSAndroid Build Coastguard Worker " modulus");
856*8617a60dSAndroid Build Coastguard Worker TEST_EQ(modulus_size, 0x100, " modulus_size");
857*8617a60dSAndroid Build Coastguard Worker
858*8617a60dSAndroid Build Coastguard Worker /* Test that the command returns the full size of the modulus if the
859*8617a60dSAndroid Build Coastguard Worker * input buffer is too small. */
860*8617a60dSAndroid Build Coastguard Worker ResetMocks();
861*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
862*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
863*8617a60dSAndroid Build Coastguard Worker modulus_size = 0;
864*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
865*8617a60dSAndroid Build Coastguard Worker TPM_E_BUFFER_SIZE, "ReadPubek - returns modulus size");
866*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
867*8617a60dSAndroid Build Coastguard Worker TEST_EQ(modulus_size, 0x100, " modulus_size");
868*8617a60dSAndroid Build Coastguard Worker
869*8617a60dSAndroid Build Coastguard Worker /* Test that a too large parm_size value gets handled correctly. */
870*8617a60dSAndroid Build Coastguard Worker ResetMocks();
871*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
872*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
873*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 18, 1 << 24);
874*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
875*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "ReadPubek - large parm_size");
876*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
877*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 18, 12);
878*8617a60dSAndroid Build Coastguard Worker
879*8617a60dSAndroid Build Coastguard Worker /* Test that a too small parm_size value gets handled correctly. */
880*8617a60dSAndroid Build Coastguard Worker ResetMocks();
881*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
882*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
883*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 18, 11);
884*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
885*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "ReadPubek - small parm_size");
886*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
887*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 18, 12);
888*8617a60dSAndroid Build Coastguard Worker
889*8617a60dSAndroid Build Coastguard Worker /* Test that an overlong modulus size gets handled correctly. */
890*8617a60dSAndroid Build Coastguard Worker ResetMocks();
891*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
892*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
893*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 34, 1 << 24);
894*8617a60dSAndroid Build Coastguard Worker modulus_size = sizeof(modulus);
895*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
896*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "ReadPubek - large modulus size");
897*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
898*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 34, TPM_RSA_2048_LEN);
899*8617a60dSAndroid Build Coastguard Worker
900*8617a60dSAndroid Build Coastguard Worker /* Test that a large exponent size gets handled correctly. */
901*8617a60dSAndroid Build Coastguard Worker ResetMocks();
902*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
903*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
904*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 20, 1 << 24);
905*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
906*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "ReadPubek - large exponent size");
907*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
908*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + 20, 0);
909*8617a60dSAndroid Build Coastguard Worker
910*8617a60dSAndroid Build Coastguard Worker /* Test that an incorrect auth tag causes an error. */
911*8617a60dSAndroid Build Coastguard Worker ResetMocks();
912*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
913*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
914*8617a60dSAndroid Build Coastguard Worker response[294] = 0;
915*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadPubek(&exponent, NULL, &modulus_size),
916*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "ReadPubek - incorrect auth");
917*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_ReadPubek, " cmd");
918*8617a60dSAndroid Build Coastguard Worker response[294] = 0x60;
919*8617a60dSAndroid Build Coastguard Worker }
920*8617a60dSAndroid Build Coastguard Worker
921*8617a60dSAndroid Build Coastguard Worker /**
922*8617a60dSAndroid Build Coastguard Worker * Test TakeOwnership
923*8617a60dSAndroid Build Coastguard Worker */
TakeOwnershipTest(void)924*8617a60dSAndroid Build Coastguard Worker static void TakeOwnershipTest(void) {
925*8617a60dSAndroid Build Coastguard Worker uint8_t oiap_response[] = {
926*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x22, 0x00, 0x00,
927*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x4c, 0x04, 0x1a, 0x18, 0xa9,
928*8617a60dSAndroid Build Coastguard Worker 0xf7, 0x9b, 0x2e, 0xe1, 0xf2, 0x16, 0x99, 0xa0,
929*8617a60dSAndroid Build Coastguard Worker 0x27, 0x5f, 0x0c, 0x8f, 0x24, 0x55, 0x1d, 0xaf,
930*8617a60dSAndroid Build Coastguard Worker 0x96, 0x49,
931*8617a60dSAndroid Build Coastguard Worker };
932*8617a60dSAndroid Build Coastguard Worker uint8_t take_ownership_response[] = {
933*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc5, 0x00, 0x00, 0x01, 0x62, 0x00, 0x00,
934*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x28, 0x00, 0x00, 0x00, 0x11,
935*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
936*8617a60dSAndroid Build Coastguard Worker 0x01, 0x00, 0x03, 0x00, 0x01, 0x00, 0x00, 0x00,
937*8617a60dSAndroid Build Coastguard Worker 0x0c, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00,
938*8617a60dSAndroid Build Coastguard Worker 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
939*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x01, 0x00, 0x92, 0x61, 0xa5,
940*8617a60dSAndroid Build Coastguard Worker 0x30, 0x5f, 0x39, 0xb7, 0xc3, 0x51, 0x53, 0x84,
941*8617a60dSAndroid Build Coastguard Worker 0xaf, 0x51, 0x64, 0x65, 0xd7, 0x58, 0xda, 0x15,
942*8617a60dSAndroid Build Coastguard Worker 0xb0, 0xb8, 0xe8, 0xea, 0xf5, 0xb2, 0x21, 0x34,
943*8617a60dSAndroid Build Coastguard Worker 0x09, 0x71, 0xa0, 0xd5, 0x2b, 0x21, 0xd6, 0x16,
944*8617a60dSAndroid Build Coastguard Worker 0xbd, 0x03, 0xc3, 0x83, 0x7e, 0x48, 0x36, 0xd7,
945*8617a60dSAndroid Build Coastguard Worker 0xfa, 0xc7, 0x5e, 0x5e, 0xb4, 0xc3, 0x9f, 0x00,
946*8617a60dSAndroid Build Coastguard Worker 0xcc, 0x7a, 0x3e, 0x0a, 0x00, 0x34, 0xbd, 0xbc,
947*8617a60dSAndroid Build Coastguard Worker 0x7b, 0x28, 0x0e, 0x4a, 0xef, 0xa5, 0x86, 0x50,
948*8617a60dSAndroid Build Coastguard Worker 0xa5, 0xfe, 0x8f, 0x7d, 0xbc, 0x86, 0xf3, 0x3d,
949*8617a60dSAndroid Build Coastguard Worker 0x8c, 0x65, 0x4c, 0x3b, 0x29, 0x3b, 0x40, 0x8b,
950*8617a60dSAndroid Build Coastguard Worker 0xca, 0xf9, 0xa1, 0xc8, 0x62, 0x52, 0xe1, 0x1f,
951*8617a60dSAndroid Build Coastguard Worker 0x0d, 0x89, 0x71, 0xca, 0xbb, 0x64, 0xef, 0x3f,
952*8617a60dSAndroid Build Coastguard Worker 0x97, 0x97, 0xed, 0x57, 0xb3, 0xd8, 0x67, 0x4c,
953*8617a60dSAndroid Build Coastguard Worker 0x46, 0x1c, 0x35, 0x0c, 0xba, 0x12, 0xae, 0x2e,
954*8617a60dSAndroid Build Coastguard Worker 0x6d, 0xa7, 0x48, 0xd6, 0x9a, 0x8a, 0x60, 0x22,
955*8617a60dSAndroid Build Coastguard Worker 0xd9, 0xe5, 0x97, 0x50, 0xc1, 0x24, 0xaf, 0xb6,
956*8617a60dSAndroid Build Coastguard Worker 0x41, 0xfe, 0x6d, 0xfe, 0x28, 0x3f, 0xce, 0x35,
957*8617a60dSAndroid Build Coastguard Worker 0x9b, 0x77, 0xe9, 0xd5, 0x36, 0xdb, 0x70, 0x5e,
958*8617a60dSAndroid Build Coastguard Worker 0xd7, 0xb9, 0x89, 0xac, 0xae, 0x55, 0x59, 0x00,
959*8617a60dSAndroid Build Coastguard Worker 0x7d, 0x47, 0x5d, 0x73, 0x4f, 0x1b, 0x17, 0xfa,
960*8617a60dSAndroid Build Coastguard Worker 0xae, 0xb0, 0xf7, 0xb7, 0x63, 0x4d, 0xa9, 0x94,
961*8617a60dSAndroid Build Coastguard Worker 0x0c, 0x1e, 0x02, 0x59, 0x8d, 0x34, 0x1f, 0x01,
962*8617a60dSAndroid Build Coastguard Worker 0x6d, 0xa7, 0x05, 0xa7, 0xae, 0xbd, 0x9b, 0xfa,
963*8617a60dSAndroid Build Coastguard Worker 0xed, 0xe6, 0xe3, 0xf2, 0xc0, 0xa9, 0x16, 0xb6,
964*8617a60dSAndroid Build Coastguard Worker 0xd2, 0x23, 0x37, 0x2e, 0x43, 0x5e, 0x5f, 0xe6,
965*8617a60dSAndroid Build Coastguard Worker 0x77, 0x0d, 0x49, 0x48, 0x07, 0x57, 0x64, 0xd2,
966*8617a60dSAndroid Build Coastguard Worker 0xd9, 0x60, 0xff, 0xe3, 0x60, 0xb6, 0xd7, 0xa5,
967*8617a60dSAndroid Build Coastguard Worker 0xe3, 0xd8, 0xa3, 0x93, 0xb3, 0xe9, 0xeb, 0x1c,
968*8617a60dSAndroid Build Coastguard Worker 0x53, 0x42, 0x08, 0x9f, 0x0c, 0x13, 0x72, 0x3c,
969*8617a60dSAndroid Build Coastguard Worker 0x80, 0xf8, 0xa1, 0x8c, 0x4d, 0xe5, 0x1e, 0xe7,
970*8617a60dSAndroid Build Coastguard Worker 0xef, 0x2b, 0x33, 0x23, 0x1e, 0x5a, 0xf6, 0xc1,
971*8617a60dSAndroid Build Coastguard Worker 0x46, 0x78, 0x06, 0x7e, 0xe7, 0x00, 0x00, 0x00,
972*8617a60dSAndroid Build Coastguard Worker 0x00, 0xef, 0x84, 0x26, 0xd3, 0xb6, 0x27, 0x4a,
973*8617a60dSAndroid Build Coastguard Worker 0x4a, 0x0f, 0x84, 0x65, 0x4b, 0xff, 0x80, 0x7e,
974*8617a60dSAndroid Build Coastguard Worker 0xb5, 0xf6, 0xbe, 0x8c, 0xed, 0x00, 0xad, 0xd1,
975*8617a60dSAndroid Build Coastguard Worker 0x73, 0x8a, 0x55, 0x9f, 0x50, 0xb4, 0x34, 0xba,
976*8617a60dSAndroid Build Coastguard Worker 0x2d, 0x6d, 0x80, 0x3a, 0xdc, 0x82, 0x94, 0x3b,
977*8617a60dSAndroid Build Coastguard Worker 0x96, 0x58,
978*8617a60dSAndroid Build Coastguard Worker };
979*8617a60dSAndroid Build Coastguard Worker uint8_t encrypted_secret[] = {
980*8617a60dSAndroid Build Coastguard Worker 0x46, 0x9a, 0x17, 0x31, 0x04, 0x72, 0x58, 0xcd,
981*8617a60dSAndroid Build Coastguard Worker 0xac, 0xe7, 0xa4, 0x1f, 0x48, 0xa3, 0x89, 0x10,
982*8617a60dSAndroid Build Coastguard Worker 0xac, 0x40, 0xe2, 0x66, 0xfa, 0xfd, 0xe9, 0xab,
983*8617a60dSAndroid Build Coastguard Worker 0x7a, 0x55, 0xd3, 0xc0, 0x61, 0xca, 0x28, 0x0d,
984*8617a60dSAndroid Build Coastguard Worker 0x29, 0x4a, 0xe4, 0x9a, 0xbe, 0x62, 0x51, 0xe8,
985*8617a60dSAndroid Build Coastguard Worker 0x3f, 0xbf, 0x84, 0xae, 0x4e, 0x6c, 0x0e, 0x11,
986*8617a60dSAndroid Build Coastguard Worker 0x2b, 0xba, 0x62, 0x5d, 0xf5, 0x9d, 0xf8, 0xcd,
987*8617a60dSAndroid Build Coastguard Worker 0x5c, 0x9d, 0x5b, 0xee, 0x5e, 0xdc, 0xaf, 0xc1,
988*8617a60dSAndroid Build Coastguard Worker 0xbf, 0x22, 0x14, 0x0d, 0x68, 0xdf, 0xe1, 0x94,
989*8617a60dSAndroid Build Coastguard Worker 0x6b, 0x06, 0xc4, 0x5b, 0xdd, 0xee, 0xd3, 0xef,
990*8617a60dSAndroid Build Coastguard Worker 0x67, 0xb5, 0xb0, 0xee, 0x58, 0x88, 0x2d, 0x5c,
991*8617a60dSAndroid Build Coastguard Worker 0x7d, 0xda, 0x83, 0xd5, 0xb5, 0x72, 0x43, 0x33,
992*8617a60dSAndroid Build Coastguard Worker 0xf7, 0x9e, 0xf0, 0x52, 0x8c, 0xc1, 0xf1, 0xea,
993*8617a60dSAndroid Build Coastguard Worker 0xcf, 0x9f, 0x0e, 0xfb, 0xb3, 0x03, 0xfe, 0xb3,
994*8617a60dSAndroid Build Coastguard Worker 0xb4, 0x38, 0xa2, 0xfb, 0x2f, 0x64, 0xb6, 0x42,
995*8617a60dSAndroid Build Coastguard Worker 0x4c, 0x76, 0x70, 0xfa, 0x67, 0xc0, 0x48, 0x98,
996*8617a60dSAndroid Build Coastguard Worker 0x52, 0x3e, 0xdb, 0xe6, 0xfe, 0x44, 0x96, 0x14,
997*8617a60dSAndroid Build Coastguard Worker 0x5a, 0x6a, 0x19, 0x53, 0x46, 0x13, 0xe6, 0xc9,
998*8617a60dSAndroid Build Coastguard Worker 0x21, 0xee, 0x8e, 0xc2, 0xf2, 0x39, 0x2d, 0xba,
999*8617a60dSAndroid Build Coastguard Worker 0x6f, 0xeb, 0x80, 0x89, 0xf3, 0xea, 0xfa, 0x5c,
1000*8617a60dSAndroid Build Coastguard Worker 0x9c, 0x88, 0xe0, 0xb1, 0x53, 0xa0, 0xe5, 0xe0,
1001*8617a60dSAndroid Build Coastguard Worker 0x90, 0x33, 0x9d, 0x9d, 0x5f, 0xba, 0x6d, 0x68,
1002*8617a60dSAndroid Build Coastguard Worker 0xb2, 0x9f, 0x4f, 0xa1, 0x28, 0xf9, 0xc4, 0x53,
1003*8617a60dSAndroid Build Coastguard Worker 0x72, 0x51, 0x48, 0x4b, 0xb3, 0xf9, 0x18, 0x43,
1004*8617a60dSAndroid Build Coastguard Worker 0x3a, 0x85, 0xdc, 0x70, 0x46, 0x0c, 0x3c, 0xe1,
1005*8617a60dSAndroid Build Coastguard Worker 0x17, 0x1c, 0x18, 0x6f, 0xfd, 0xff, 0x77, 0x8d,
1006*8617a60dSAndroid Build Coastguard Worker 0x04, 0xfc, 0xb3, 0xc0, 0x9a, 0x03, 0x74, 0x1d,
1007*8617a60dSAndroid Build Coastguard Worker 0x06, 0x8f, 0xb6, 0x0a, 0x3e, 0xea, 0x91, 0x87,
1008*8617a60dSAndroid Build Coastguard Worker 0xa9, 0x68, 0x26, 0x91, 0x81, 0x02, 0xe4, 0x10,
1009*8617a60dSAndroid Build Coastguard Worker 0x66, 0xb6, 0x5f, 0x43, 0x47, 0x55, 0x25, 0xe0,
1010*8617a60dSAndroid Build Coastguard Worker 0xbd, 0xd3, 0xab, 0xbd, 0xfd, 0x15, 0x85, 0x39,
1011*8617a60dSAndroid Build Coastguard Worker 0x22, 0x93, 0xfc, 0x9d, 0x74, 0x0e, 0xcf, 0x5a,
1012*8617a60dSAndroid Build Coastguard Worker };
1013*8617a60dSAndroid Build Coastguard Worker uint8_t owner_secret[TPM_AUTH_DATA_LEN] = { 0 };
1014*8617a60dSAndroid Build Coastguard Worker
1015*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1016*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = oiap_response;
1017*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(oiap_response);
1018*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = take_ownership_response;
1019*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(take_ownership_response);
1020*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclTakeOwnership(encrypted_secret, encrypted_secret,
1021*8617a60dSAndroid Build Coastguard Worker owner_secret), TPM_SUCCESS, "TakeOwnership");
1022*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OIAP, " oiap cmd");
1023*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_TakeOwnership, " takeownership cmd");
1024*8617a60dSAndroid Build Coastguard Worker
1025*8617a60dSAndroid Build Coastguard Worker /* Verify that the response gets authenticated. */
1026*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1027*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = oiap_response;
1028*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(oiap_response);
1029*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = take_ownership_response;
1030*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(take_ownership_response);
1031*8617a60dSAndroid Build Coastguard Worker take_ownership_response[334] = 0;
1032*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclTakeOwnership(encrypted_secret, encrypted_secret,
1033*8617a60dSAndroid Build Coastguard Worker owner_secret),
1034*8617a60dSAndroid Build Coastguard Worker TPM_E_AUTHFAIL, "TakeOwnership - response auth");
1035*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OIAP, " oiap cmd");
1036*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_TakeOwnership, " takeownership cmd");
1037*8617a60dSAndroid Build Coastguard Worker take_ownership_response[334] = 0xad;
1038*8617a60dSAndroid Build Coastguard Worker
1039*8617a60dSAndroid Build Coastguard Worker /* Verify that a short OIAP response gets caught. */
1040*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1041*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = oiap_response;
1042*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(oiap_response);
1043*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(oiap_response + sizeof(uint16_t),
1044*8617a60dSAndroid Build Coastguard Worker kTpmRequestHeaderLength + sizeof(uint32_t) +
1045*8617a60dSAndroid Build Coastguard Worker sizeof(TPM_NONCE) - 1);
1046*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclTakeOwnership(encrypted_secret, encrypted_secret,
1047*8617a60dSAndroid Build Coastguard Worker owner_secret),
1048*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE, "TakeOwnership - short OIAP response");
1049*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OIAP, " oiap cmd");
1050*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(oiap_response + sizeof(uint16_t), sizeof(oiap_response));
1051*8617a60dSAndroid Build Coastguard Worker
1052*8617a60dSAndroid Build Coastguard Worker /* Verify that a short TakeOwnership response gets caught. */
1053*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1054*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = oiap_response;
1055*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(oiap_response);
1056*8617a60dSAndroid Build Coastguard Worker calls[1].rsp = take_ownership_response;
1057*8617a60dSAndroid Build Coastguard Worker calls[1].rsp_size = sizeof(take_ownership_response);
1058*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(take_ownership_response + sizeof(uint16_t),
1059*8617a60dSAndroid Build Coastguard Worker kTpmResponseHeaderLength + kTpmResponseAuthBlockLength - 1);
1060*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclTakeOwnership(encrypted_secret, encrypted_secret,
1061*8617a60dSAndroid Build Coastguard Worker owner_secret),
1062*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE,
1063*8617a60dSAndroid Build Coastguard Worker "TakeOwnership - short TakeOwnership response");
1064*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_OIAP, " oiap cmd");
1065*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[1].req_cmd, TPM_ORD_TakeOwnership, " takeownership cmd");
1066*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(take_ownership_response + sizeof(uint16_t),
1067*8617a60dSAndroid Build Coastguard Worker sizeof(take_ownership_response));
1068*8617a60dSAndroid Build Coastguard Worker }
1069*8617a60dSAndroid Build Coastguard Worker
1070*8617a60dSAndroid Build Coastguard Worker /**
1071*8617a60dSAndroid Build Coastguard Worker * Test ReadDelegationFamilyTable
1072*8617a60dSAndroid Build Coastguard Worker */
ReadDelegationFamilyTableTest(void)1073*8617a60dSAndroid Build Coastguard Worker static void ReadDelegationFamilyTableTest(void) {
1074*8617a60dSAndroid Build Coastguard Worker uint8_t response[] = {
1075*8617a60dSAndroid Build Coastguard Worker 0x00, 0xc4, 0x00, 0x00, 0x00, 0x30, 0x00, 0x00,
1076*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x1e, 0x00, 0x25,
1077*8617a60dSAndroid Build Coastguard Worker 0x17, 0x00, 0x00, 0x00, 0x4f, 0x00, 0x00, 0x00,
1078*8617a60dSAndroid Build Coastguard Worker 0x01, 0x00, 0x00, 0x00, 0x02, 0x00, 0x25, 0x42,
1079*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x50, 0x00, 0x00, 0x00, 0x01,
1080*8617a60dSAndroid Build Coastguard Worker 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
1081*8617a60dSAndroid Build Coastguard Worker };
1082*8617a60dSAndroid Build Coastguard Worker
1083*8617a60dSAndroid Build Coastguard Worker TPM_FAMILY_TABLE_ENTRY table[20];
1084*8617a60dSAndroid Build Coastguard Worker uint32_t table_size;
1085*8617a60dSAndroid Build Coastguard Worker
1086*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1087*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
1088*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
1089*8617a60dSAndroid Build Coastguard Worker table_size = 8;
1090*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadDelegationFamilyTable(table, &table_size),
1091*8617a60dSAndroid Build Coastguard Worker TPM_SUCCESS, "ReadDelegationFamilyTable");
1092*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Delegate_ReadTable, " cmd");
1093*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table_size, 2, " table_size");
1094*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[0].tag, 0x25, " table[0].tag");
1095*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[0].familyLabel, 0x17, " table[0].familyLabel");
1096*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[0].familyID, 0x4f, " table[0].familyID");
1097*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[0].verificationCount, 0x1,
1098*8617a60dSAndroid Build Coastguard Worker " table[0].verificationCount");
1099*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[0].flags, 0x2, " table[0].flags");
1100*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[1].tag, 0x25, " table[1].tag");
1101*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[1].familyLabel, 0x42, " table[1].familyLabel");
1102*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[1].familyID, 0x50, " table[1].familyID");
1103*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[1].verificationCount, 0x1,
1104*8617a60dSAndroid Build Coastguard Worker " table[1].verificationCount");
1105*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table[1].flags, 0x0, " table[1].flags");
1106*8617a60dSAndroid Build Coastguard Worker
1107*8617a60dSAndroid Build Coastguard Worker /* Test that required table size is returned if more space required. */
1108*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1109*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
1110*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
1111*8617a60dSAndroid Build Coastguard Worker table_size = 1;
1112*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadDelegationFamilyTable(table, &table_size),
1113*8617a60dSAndroid Build Coastguard Worker TPM_E_BUFFER_SIZE, "ReadDelegationFamilyTable");
1114*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Delegate_ReadTable, " cmd");
1115*8617a60dSAndroid Build Coastguard Worker TEST_EQ(table_size, 2, " table_size");
1116*8617a60dSAndroid Build Coastguard Worker
1117*8617a60dSAndroid Build Coastguard Worker /* Test that an overlong response gets caught. */
1118*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1119*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
1120*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
1121*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + sizeof(uint16_t), TPM_LARGE_ENOUGH_COMMAND_SIZE +
1122*8617a60dSAndroid Build Coastguard Worker 1);
1123*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadDelegationFamilyTable(table, &table_size),
1124*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE,
1125*8617a60dSAndroid Build Coastguard Worker "ReadDelegationFamilyTable - too long response");
1126*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Delegate_ReadTable, " cmd");
1127*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + sizeof(uint16_t), sizeof(response));
1128*8617a60dSAndroid Build Coastguard Worker
1129*8617a60dSAndroid Build Coastguard Worker /* Test that a short response gets caught. */
1130*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1131*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
1132*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
1133*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + sizeof(uint16_t),
1134*8617a60dSAndroid Build Coastguard Worker kTpmRequestHeaderLength + sizeof(uint32_t) - 1);
1135*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadDelegationFamilyTable(table, &table_size),
1136*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE,
1137*8617a60dSAndroid Build Coastguard Worker "ReadDelegationFamilyTable - too short response");
1138*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Delegate_ReadTable, " cmd");
1139*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + sizeof(uint16_t), sizeof(response));
1140*8617a60dSAndroid Build Coastguard Worker
1141*8617a60dSAndroid Build Coastguard Worker /* Test that long table size in response gets caught. */
1142*8617a60dSAndroid Build Coastguard Worker ResetMocks();
1143*8617a60dSAndroid Build Coastguard Worker calls[0].rsp = response;
1144*8617a60dSAndroid Build Coastguard Worker calls[0].rsp_size = sizeof(response);
1145*8617a60dSAndroid Build Coastguard Worker table_size = 20;
1146*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + kTpmResponseHeaderLength,
1147*8617a60dSAndroid Build Coastguard Worker TPM_LARGE_ENOUGH_COMMAND_SIZE);
1148*8617a60dSAndroid Build Coastguard Worker TEST_EQ(TlclReadDelegationFamilyTable(table, &table_size),
1149*8617a60dSAndroid Build Coastguard Worker TPM_E_INVALID_RESPONSE,
1150*8617a60dSAndroid Build Coastguard Worker "ReadDelegationFamilyTable - overlong family table");
1151*8617a60dSAndroid Build Coastguard Worker TEST_EQ(calls[0].req_cmd, TPM_ORD_Delegate_ReadTable, " cmd");
1152*8617a60dSAndroid Build Coastguard Worker ToTpmUint32(response + kTpmResponseHeaderLength, 0x1e);
1153*8617a60dSAndroid Build Coastguard Worker }
1154*8617a60dSAndroid Build Coastguard Worker
main(void)1155*8617a60dSAndroid Build Coastguard Worker int main(void)
1156*8617a60dSAndroid Build Coastguard Worker {
1157*8617a60dSAndroid Build Coastguard Worker TlclTest();
1158*8617a60dSAndroid Build Coastguard Worker SendCommandTest();
1159*8617a60dSAndroid Build Coastguard Worker ReadWriteTest();
1160*8617a60dSAndroid Build Coastguard Worker DefineSpaceExTest();
1161*8617a60dSAndroid Build Coastguard Worker InitNvAuthPolicyTest();
1162*8617a60dSAndroid Build Coastguard Worker PcrTest();
1163*8617a60dSAndroid Build Coastguard Worker GetSpaceInfoTest();
1164*8617a60dSAndroid Build Coastguard Worker FlagsTest();
1165*8617a60dSAndroid Build Coastguard Worker RandomTest();
1166*8617a60dSAndroid Build Coastguard Worker GetVersionTest();
1167*8617a60dSAndroid Build Coastguard Worker IFXFieldUpgradeInfoTest();
1168*8617a60dSAndroid Build Coastguard Worker ReadPubekTest();
1169*8617a60dSAndroid Build Coastguard Worker TakeOwnershipTest();
1170*8617a60dSAndroid Build Coastguard Worker ReadDelegationFamilyTableTest();
1171*8617a60dSAndroid Build Coastguard Worker
1172*8617a60dSAndroid Build Coastguard Worker return gTestSuccess ? 0 : 255;
1173*8617a60dSAndroid Build Coastguard Worker }
1174