xref: /aosp_15_r20/external/vboot_reference/tests/tlcl_tests.c (revision 8617a60d3594060b7ecbd21bc622a7c14f3cf2bc)
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