blob: d05c564669dd4c22cc2da931aeae0dbc74cded99 [file] [log] [blame]
Vadim Bendebury245d4572016-04-05 16:01:57 -07001/*
2 * Copyright 2016 The Chromium OS Authors. All rights reserved.
3 * Use of this source code is governed by a BSD-style license that can be
4 * found in the LICENSE file.
5 */
6
7#ifndef __SRC_LIB_TPM2_TLCL_STRUCTURES_H
8#define __SRC_LIB_TPM2_TLCL_STRUCTURES_H
9
10/*
11 * This file includes a subset of definitions of TPM protocol version 2.x
12 * constants and structures needed for functions used in coreboot.
13 */
14#include <stdint.h>
15#include <tpm_lite/tlcl.h>
16#include <types.h>
17
18/* This should be plenty for what firmware needs. */
19#define TPM_BUFFER_SIZE 256
20
21/* Basic TPM2 types. */
22typedef uint16_t TPM_SU;
23typedef uint16_t TPM_ALG_ID;
24typedef uint32_t TPM_CC;
25typedef uint32_t TPM_HANDLE;
26typedef uint32_t TPM_RC;
27typedef uint8_t TPMI_YES_NO;
28typedef TPM_HANDLE TPMI_RH_NV_INDEX;
29typedef TPM_HANDLE TPMI_RH_PROVISION;
30typedef TPM_HANDLE TPMI_SH_AUTH_SESSION;
31typedef TPM_HANDLE TPM_RH;
32typedef TPM_ALG_ID TPMI_ALG_HASH;
33
34/* Some hardcoded algorithm values. */
35#define TPM_ALG_HMAC ((TPM_ALG_ID)0x0005)
36#define TPM_ALG_NULL ((TPM_ALG_ID)0x0010)
37#define TPM_ALG_SHA1 ((TPM_ALG_ID)0x0004)
38#define TPM_ALG_SHA256 ((TPM_ALG_ID)0x000b)
39
40/* Some hardcoded hierarchies. */
41#define TPM_RH_NULL 0x40000007
42#define TPM_RS_PW 0x40000009
43#define TPM_RH_PLATFORM 0x4000000C
44
45typedef struct {
46 uint16_t size;
47 uint8_t *buffer;
48} TPM2B;
49
Vadim Bendebury245d4572016-04-05 16:01:57 -070050/* Relevant TPM Command's structures. */
51/* Common command/response header. */
52struct tpm_header {
53 uint16_t tpm_tag;
54 uint32_t tpm_size;
55 TPM_CC tpm_code;
56} __attribute__((packed));
57
58/* TPM command codes. */
59#define TPM2_NV_DefineSpace ((TPM_CC)0x0000012A)
60#define TPM2_NV_Write ((TPM_CC)0x00000137)
61#define TPM2_SelfTest ((TPM_CC)0x00000143)
62#define TPM2_Startup ((TPM_CC)0x00000144)
63#define TPM2_NV_Read ((TPM_CC)0x0000014E)
64#define TPM2_GetCapability ((TPM_CC)0x0000017A)
65
66/* Startup values. */
67#define TPM_SU_CLEAR 0
68#define TPM_SU_STATE 1
69
70#define TPM_HT_NV_INDEX 0x01
71#define TPM_HT_HMAC_SESSION 0x02
72#define TPM_HT_POLICY_SESSION 0x03
73
74#define HR_SHIFT 24
75#define HR_PCR (TPM_HT_PCR << HR_SHIFT)
76#define HR_HMAC_SESSION (TPM_HT_HMAC_SESSION << HR_SHIFT)
77#define HR_POLICY_SESSION (TPM_HT_POLICY_SESSION << HR_SHIFT)
78#define HR_TRANSIENT (TPM_HT_TRANSIENT << HR_SHIFT)
79#define HR_PERSISTENT (TPM_HT_PERSISTENT << HR_SHIFT)
80#define HR_NV_INDEX (TPM_HT_NV_INDEX << HR_SHIFT)
81#define HR_PERMANENT (TPM_HT_PERMANENT << HR_SHIFT)
82#define PCR_FIRST (HR_PCR + 0)
83#define PCR_LAST (PCR_FIRST + IMPLEMENTATION_PCR-1)
84#define HMAC_SESSION_FIRST (HR_HMAC_SESSION + 0)
85#define HMAC_SESSION_LAST (HMAC_SESSION_FIRST+MAX_ACTIVE_SESSIONS-1)
86#define LOADED_SESSION_FIRST HMAC_SESSION_FIRST
87#define LOADED_SESSION_LAST HMAC_SESSION_LAST
88#define POLICY_SESSION_FIRST (HR_POLICY_SESSION + 0)
89#define POLICY_SESSION_LAST (POLICY_SESSION_FIRST + MAX_ACTIVE_SESSIONS-1)
90#define TRANSIENT_FIRST (HR_TRANSIENT + 0)
91#define ACTIVE_SESSION_FIRST POLICY_SESSION_FIRST
92#define ACTIVE_SESSION_LAST POLICY_SESSION_LAST
93#define TRANSIENT_LAST (TRANSIENT_FIRST+MAX_LOADED_OBJECTS-1)
94#define PERSISTENT_FIRST (HR_PERSISTENT + 0)
95#define PERSISTENT_LAST (PERSISTENT_FIRST + 0x00FFFFFF)
96#define PLATFORM_PERSISTENT (PERSISTENT_FIRST + 0x00800000)
97#define NV_INDEX_FIRST (HR_NV_INDEX + 0)
98#define NV_INDEX_LAST (NV_INDEX_FIRST + 0x00FFFFFF)
99#define PERMANENT_FIRST TPM_RH_FIRST
100#define PERMANENT_LAST TPM_RH_LAST
101
102/* Tpm2 command tags. */
103#define TPM_ST_NO_SESSIONS 0x8001
104#define TPM_ST_SESSIONS 0x8002
105
106#define RC_VER1 0x100
107#define TPM_RC_INITIALIZE ((TPM_RC)(RC_VER1 + 0x000))
108
109/* TPM command structures. */
110
111struct tpm2_startup {
112 TPM_SU startup_type;
113};
114
115/* Various TPM capability types to use when querying the device. */
116typedef uint32_t TPM_CAP;
117#define TPM_CAP_TPM_PROPERTIES ((TPM_CAP)0x00000006)
118
119typedef TPM_HANDLE TPMI_RH_NV_AUTH;
120typedef TPM_HANDLE TPMI_RH_NV_INDEX;
121
122/* TPM Property capability constants. */
123typedef uint32_t TPM_PT;
124#define PT_GROUP 0x00000100
125#define PT_VAR (PT_GROUP * 2)
126#define TPM_PT_PERMANENT ((TPM_PT)(PT_VAR + 0))
127
128/* Structures of payloads of various TPM2 commands. */
129struct tpm2_get_capability {
130 TPM_CAP capability;
131 uint32_t property;
132 uint32_t propertyCount;
133};
134
135/* get_capability response when PT_PERMANENT is requested. */
136typedef struct {
137 uint32_t ownerAuthSet : 1;
138 uint32_t endorsementAuthSet : 1;
139 uint32_t lockoutAuthSet : 1;
140 uint32_t reserved3_7 : 5;
141 uint32_t disableClear : 1;
142 uint32_t inLockout : 1;
143 uint32_t tpmGeneratedEPS : 1;
144 uint32_t reserved11_31 : 21;
145} TPMA_PERMANENT;
146
147typedef struct {
148 uint32_t TPMA_NV_PPWRITE : 1;
149 uint32_t TPMA_NV_OWNERWRITE : 1;
150 uint32_t TPMA_NV_AUTHWRITE : 1;
151 uint32_t TPMA_NV_POLICYWRITE : 1;
152 uint32_t TPMA_NV_COUNTER : 1;
153 uint32_t TPMA_NV_BITS : 1;
154 uint32_t TPMA_NV_EXTEND : 1;
155 uint32_t reserved7_9 : 3;
156 uint32_t TPMA_NV_POLICY_DELETE : 1;
157 uint32_t TPMA_NV_WRITELOCKED : 1;
158 uint32_t TPMA_NV_WRITEALL : 1;
159 uint32_t TPMA_NV_WRITEDEFINE : 1;
160 uint32_t TPMA_NV_WRITE_STCLEAR : 1;
161 uint32_t TPMA_NV_GLOBALLOCK : 1;
162 uint32_t TPMA_NV_PPREAD : 1;
163 uint32_t TPMA_NV_OWNERREAD : 1;
164 uint32_t TPMA_NV_AUTHREAD : 1;
165 uint32_t TPMA_NV_POLICYREAD : 1;
166 uint32_t reserved20_24 : 5;
167 uint32_t TPMA_NV_NO_DA : 1;
168 uint32_t TPMA_NV_ORDERLY : 1;
169 uint32_t TPMA_NV_CLEAR_STCLEAR : 1;
170 uint32_t TPMA_NV_READLOCKED : 1;
171 uint32_t TPMA_NV_WRITTEN : 1;
172 uint32_t TPMA_NV_PLATFORMCREATE : 1;
173 uint32_t TPMA_NV_READ_STCLEAR : 1;
174} TPMA_NV;
175
176typedef union {
177 struct {
178 uint16_t size;
Vadim Bendebury1a980502016-07-07 11:15:47 -0700179 const uint8_t *buffer;
Vadim Bendebury245d4572016-04-05 16:01:57 -0700180 } t;
181 TPM2B b;
182} TPM2B_DIGEST;
183
184typedef TPM2B_DIGEST TPM2B_AUTH;
185typedef TPM2B_DIGEST TPM2B_NONCE;
186
187typedef struct {
188 TPM_PT property;
189 uint32_t value;
190} TPMS_TAGGED_PROPERTY;
191
192#define MAX_CAP_DATA (TPM_BUFFER_SIZE - sizeof(struct tpm_header) - \
193 sizeof(TPMI_YES_NO) - sizeof(TPM_CAP) - sizeof(uint32_t))
194#define MAX_TPM_PROPERTIES (MAX_CAP_DATA/sizeof(TPMS_TAGGED_PROPERTY))
195
196/* Somewhat arbitrary, leave enough room for command wrappers. */
197#define MAX_NV_BUFFER_SIZE (TPM_BUFFER_SIZE - sizeof(struct tpm_header) - 50)
198
199typedef struct {
200 uint32_t count;
201 TPMS_TAGGED_PROPERTY tpmProperty[MAX_TPM_PROPERTIES];
202} TPML_TAGGED_TPM_PROPERTY;
203
204typedef union {
205 TPML_TAGGED_TPM_PROPERTY tpmProperties;
206} TPMU_CAPABILITIES;
207
208typedef struct {
209 TPM_CAP capability;
210 TPMU_CAPABILITIES data;
211} TPMS_CAPABILITY_DATA;
212
213struct get_cap_response {
214 TPMI_YES_NO more_data;
215 TPMS_CAPABILITY_DATA cd;
216};
217
218typedef struct {
219 TPMI_RH_NV_INDEX nvIndex;
220 TPMI_ALG_HASH nameAlg;
221 TPMA_NV attributes;
222 TPM2B_DIGEST authPolicy;
223 uint16_t dataSize;
224} TPMS_NV_PUBLIC;
225
226typedef union {
227 struct {
228 uint16_t size;
229 TPMS_NV_PUBLIC nvPublic;
230 } t;
231 TPM2B b;
232} TPM2B_NV_PUBLIC;
233
234typedef union {
235 struct {
236 uint16_t size;
237 const uint8_t *buffer;
238 } t;
239 TPM2B b;
240} TPM2B_MAX_NV_BUFFER;
241
242struct nv_read_response {
243 uint32_t params_size;
244 TPM2B_MAX_NV_BUFFER buffer;
245};
246
247struct tpm2_session_attrs {
248 uint8_t continueSession : 1;
249 uint8_t auditExclusive : 1;
250 uint8_t auditReset : 1;
251 uint8_t reserved3_4 : 2;
252 uint8_t decrypt : 1;
253 uint8_t encrypt : 1;
254 uint8_t audit : 1;
255};
256
257/*
258 * TPM session header for commands requiring session information. Also
259 * included in the responses to those commands.
260 */
261struct tpm2_session_header {
262 uint32_t session_handle;
263 uint16_t nonce_size;
264 uint8_t *nonce;
265 union {
266 struct tpm2_session_attrs session_attr_bits;
267 uint8_t session_attrs;
268 } __attribute__((packed));
269 uint16_t auth_size;
270 uint8_t *auth;
271};
272
273struct tpm2_response {
274 struct tpm_header hdr;
275 union {
276 struct get_cap_response gc;
277 struct nv_read_response nvr;
278 struct tpm2_session_header def_space;
279 };
280};
281
282struct tpm2_nv_define_space_cmd {
283 TPM2B_AUTH auth;
284 TPMS_NV_PUBLIC publicInfo;
285};
286
287struct tpm2_nv_write_cmd {
288 TPMI_RH_NV_INDEX nvIndex;
289 TPM2B_MAX_NV_BUFFER data;
290 uint16_t offset;
291};
292
293struct tpm2_self_test {
294 TPMI_YES_NO yes_no;
295};
296
297struct tpm2_nv_read_cmd {
298 TPMI_RH_NV_INDEX nvIndex;
299 uint16_t size;
300 uint16_t offset;
301};
302
303#endif // __SRC_LIB_TPM2_TLCL_STRUCTURES_H