aboutsummaryrefslogtreecommitdiffstats
path: root/roms/skiboot/libstb/tss2/ibmtpm20tss/utils/ibmtss/tsserror12.h
blob: 46d2e3f67189d0887d6941c1955d05fbf3e268f5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
/********************************************************************************/
/*                                                                              */
/*                          TPM 1.2 Error Response                              */
/*                           Written by Ken Goldman                             */
/*                     IBM Thomas J. Watson Research Center                     */
/*                                                                              */
/* (c) Copyright IBM Corporation 2006, 2010.					*/
/*										*/
/* All rights reserved.								*/
/* 										*/
/* Redistribution and use in source and binary forms, with or without		*/
/* modification, are permitted provided that the following conditions are	*/
/* met:										*/
/* 										*/
/* Redistributions of source code must retain the above copyright notice,	*/
/* this list of conditions and the following disclaimer.			*/
/* 										*/
/* Redistributions in binary form must reproduce the above copyright		*/
/* notice, this list of conditions and the following disclaimer in the		*/
/* documentation and/or other materials provided with the distribution.		*/
/* 										*/
/* Neither the names of the IBM Corporation nor the names of its		*/
/* contributors may be used to endorse or promote products derived from		*/
/* this software without specific prior written permission.			*/
/* 										*/
/* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS		*/
/* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT		*/
/* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR	*/
/* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT		*/
/* HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,	*/
/* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT		*/
/* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,	*/
/* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY	*/
/* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT		*/
/* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE	*/
/* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.		*/
/********************************************************************************/

#ifndef TPM_ERROR_H
#define TPM_ERROR_H

/* 16. Return codes rev 99

   The TPM has five types of return code. One indicates successful operation and four indicate 
   failure. TPM_SUCCESS (00000000) indicates successful execution. The failure reports are: 
   TPM defined fatal errors (00000001 to 000003FF), vendor defined fatal errors (00000400 to 
   000007FF), TPM defined non-fatal errors (00000800 to 00000BFF), and vendor defined 
   non-fatal errors (00000C00 to 00000FFF).
   
   The range of vendor defined non-fatal errors was determined by the TSS-WG, which defined 
   XXXX YCCC with XXXX as OS specific and Y defining the TSS SW stack layer (0: TPM layer)
   
   All failure cases return only a non-authenticated fixed set of information. This is because 
   the failure may have been due to authentication or other factors, and there is no possibility 
   of producing an authenticated response.
   
   Fatal errors also terminate any authorization sessions. This is a result of returning only the 
   error code, as there is no way to return the nonces necessary to maintain an authorization 
   session. Non-fatal errors do not terminate authorization sessions.

   The return code MUST use the following base. The return code MAY be TCG defined or vendor
   defined. */

#define TPM_BASE                0x0             /*  The start of TPM return codes */
#define TPM_SUCCESS             TPM_BASE        /* Successful completion of the operation */
#define TPM_VENDOR_ERROR        TPM_Vendor_Specific32   /* Mask to indicate that the error code is
                                                           vendor specific for vendor specific
                                                           commands. */
#define TPM_NON_FATAL           0x00000800 /* Mask to indicate that the error code is a non-fatal
                                              failure. */

/* TPM-defined fatal error codes */

#define TPM_AUTHFAIL            TPM_BASE + 1  /* Authentication failed */
#define TPM_BADINDEX            TPM_BASE + 2  /* The index to a PCR, DIR or other register is
                                                 incorrect */
#define TPM_BAD_PARAMETER       TPM_BASE + 3  /* One or more parameter is bad */
#define TPM_AUDITFAILURE        TPM_BASE + 4  /* An operation completed successfully but the auditing
                                                 of that operation failed.  */
#define TPM_CLEAR_DISABLED      TPM_BASE + 5  /* The clear disable flag is set and all clear
                                                 operations now require physical access */
#define TPM_DEACTIVATED         TPM_BASE + 6  /* The TPM is deactivated */
#define TPM_DISABLED            TPM_BASE + 7  /* The TPM is disabled */
#define TPM_DISABLED_CMD        TPM_BASE + 8  /* The target command has been disabled */
#define TPM_FAIL                TPM_BASE + 9  /* The operation failed */
#define TPM_BAD_ORDINAL         TPM_BASE + 10 /* The ordinal was unknown or inconsistent */
#define TPM_INSTALL_DISABLED    TPM_BASE + 11 /* The ability to install an owner is disabled */
#define TPM_INVALID_KEYHANDLE   TPM_BASE + 12 /* The key handle presented was invalid */
#define TPM_KEYNOTFOUND         TPM_BASE + 13 /* The target key was not found */
#define TPM_INAPPROPRIATE_ENC   TPM_BASE + 14 /* Unacceptable encryption scheme */
#define TPM_MIGRATEFAIL         TPM_BASE + 15 /* Migration authorization failed */
#define TPM_INVALID_PCR_INFO    TPM_BASE + 16 /* PCR information could not be interpreted */
#define TPM_NOSPACE             TPM_BASE + 17 /* No room to load key.  */
#define TPM_NOSRK               TPM_BASE + 18 /* There is no SRK set */
#define TPM_NOTSEALED_BLOB      TPM_BASE + 19 /* An encrypted blob is invalid or was not created by
                                                 this TPM */
#define TPM_OWNER_SET           TPM_BASE + 20 /* There is already an Owner */
#define TPM_RESOURCES           TPM_BASE + 21 /* The TPM has insufficient internal resources to
                                                 perform the requested action.  */
#define TPM_SHORTRANDOM         TPM_BASE + 22 /* A random string was too short */
#define TPM_SIZE                TPM_BASE + 23 /* The TPM does not have the space to perform the
                                                 operation. */
#define TPM_WRONGPCRVAL         TPM_BASE + 24 /* The named PCR value does not match the current PCR
                                                 value. */
#define TPM_BAD_PARAM_SIZE      TPM_BASE + 25 /* The paramSize argument to the command has the
                                                 incorrect value */
#define TPM_SHA_THREAD          TPM_BASE + 26 /* There is no existing SHA-1 thread.  */
#define TPM_SHA_ERROR           TPM_BASE + 27 /* The calculation is unable to proceed because the
                                                 existing SHA-1 thread has already encountered an
                                                 error.  */
#define TPM_FAILEDSELFTEST      TPM_BASE + 28 /* Self-test has failed and the TPM has shutdown.  */
#define TPM_AUTH2FAIL           TPM_BASE + 29 /* The authorization for the second key in a 2 key
                                                 function failed authorization */
#define TPM_BADTAG              TPM_BASE + 30 /* The tag value sent to for a command is invalid */
#define TPM_IOERROR             TPM_BASE + 31 /* An IO error occurred transmitting information to
                                                 the TPM */
#define TPM_ENCRYPT_ERROR       TPM_BASE + 32 /* The encryption process had a problem.  */
#define TPM_DECRYPT_ERROR       TPM_BASE + 33 /* The decryption process did not complete.  */
#define TPM_INVALID_AUTHHANDLE  TPM_BASE + 34 /* An invalid handle was used.  */
#define TPM_NO_ENDORSEMENT      TPM_BASE + 35 /* The TPM does not a EK installed */
#define TPM_INVALID_KEYUSAGE    TPM_BASE + 36 /* The usage of a key is not allowed */
#define TPM_WRONG_ENTITYTYPE    TPM_BASE + 37 /* The submitted entity type is not allowed */
#define TPM_INVALID_POSTINIT    TPM_BASE + 38 /* The command was received in the wrong sequence
                                                 relative to TPM_Init and a subsequent TPM_Startup
                                                 */
#define TPM_INAPPROPRIATE_SIG   TPM_BASE + 39 /* Signed data cannot include additional DER
                                                 information */
#define TPM_BAD_KEY_PROPERTY    TPM_BASE + 40 /* The key properties in TPM_KEY_PARMs are not
                                                 supported by this TPM */
#define TPM_BAD_MIGRATION       TPM_BASE + 41 /* The migration properties of this key are incorrect.
                                               */
#define TPM_BAD_SCHEME          TPM_BASE + 42 /* The signature or encryption scheme for this key is
                                                 incorrect or not permitted in this situation.  */
#define TPM_BAD_DATASIZE        TPM_BASE + 43 /* The size of the data (or blob) parameter is bad or
                                                 inconsistent with the referenced key */
#define TPM_BAD_MODE            TPM_BASE + 44 /* A mode parameter is bad, such as capArea or
                                                 subCapArea for TPM_GetCapability, physicalPresence
                                                 parameter for TPM_PhysicalPresence, or
                                                 migrationType for TPM_CreateMigrationBlob.  */
#define TPM_BAD_PRESENCE        TPM_BASE + 45 /* Either the physicalPresence or physicalPresenceLock
                                                 bits have the wrong value */
#define TPM_BAD_VERSION         TPM_BASE + 46 /* The TPM cannot perform this version of the
                                                 capability */
#define TPM_NO_WRAP_TRANSPORT   TPM_BASE + 47 /* The TPM does not allow for wrapped transport
                                                 sessions */
#define TPM_AUDITFAIL_UNSUCCESSFUL TPM_BASE + 48 /* TPM audit construction failed and the
                                                    underlying command was returning a failure
                                                    code also */
#define TPM_AUDITFAIL_SUCCESSFUL   TPM_BASE + 49 /* TPM audit construction failed and the underlying
                                                    command was returning success */
#define TPM_NOTRESETABLE        TPM_BASE + 50 /* Attempt to reset a PCR register that does not have
                                                 the resettable attribute */
#define TPM_NOTLOCAL            TPM_BASE + 51 /* Attempt to reset a PCR register that requires
                                                 locality and locality modifier not part of command
                                                 transport */
#define TPM_BAD_TYPE            TPM_BASE + 52 /* Make identity blob not properly typed */
#define TPM_INVALID_RESOURCE    TPM_BASE + 53 /* When saving context identified resource type does
                                                 not match actual resource */
#define TPM_NOTFIPS             TPM_BASE + 54 /* The TPM is attempting to execute a command only
                                                 available when in FIPS mode */
#define TPM_INVALID_FAMILY      TPM_BASE + 55 /* The command is attempting to use an invalid family
                                                 ID */
#define TPM_NO_NV_PERMISSION    TPM_BASE + 56 /* The permission to manipulate the NV storage is not
                                                 available */
#define TPM_REQUIRES_SIGN       TPM_BASE + 57 /* The operation requires a signed command */
#define TPM_KEY_NOTSUPPORTED    TPM_BASE + 58 /* Wrong operation to load an NV key */
#define TPM_AUTH_CONFLICT       TPM_BASE + 59 /* NV_LoadKey blob requires both owner and blob
                                                 authorization */
#define TPM_AREA_LOCKED         TPM_BASE + 60 /* The NV area is locked and not writable */
#define TPM_BAD_LOCALITY        TPM_BASE + 61 /* The locality is incorrect for the attempted
                                                 operation */
#define TPM_READ_ONLY           TPM_BASE + 62 /* The NV area is read only and can't be written to
                                               */
#define TPM_PER_NOWRITE         TPM_BASE + 63 /* There is no protection on the write to the NV area
                                               */
#define TPM_FAMILYCOUNT         TPM_BASE + 64 /* The family count value does not match */
#define TPM_WRITE_LOCKED        TPM_BASE + 65 /* The NV area has already been written to */
#define TPM_BAD_ATTRIBUTES      TPM_BASE + 66 /* The NV area attributes conflict */
#define TPM_INVALID_STRUCTURE   TPM_BASE + 67 /* The structure tag and version are invalid or
                                                 inconsistent */
#define TPM_KEY_OWNER_CONTROL   TPM_BASE + 68 /* The key is under control of the TPM Owner and can
                                                 only be evicted by the TPM Owner.  */
#define TPM_BAD_COUNTER         TPM_BASE + 69 /* The counter handle is incorrect */
#define TPM_NOT_FULLWRITE       TPM_BASE + 70 /* The write is not a complete write of the area */
#define TPM_CONTEXT_GAP         TPM_BASE + 71 /* The gap between saved context counts is too large
                                               */
#define TPM_MAXNVWRITES         TPM_BASE + 72 /* The maximum number of NV writes without an owner
                                                 has been exceeded */
#define TPM_NOOPERATOR          TPM_BASE + 73 /* No operator authorization value is set */
#define TPM_RESOURCEMISSING     TPM_BASE + 74 /* The resource pointed to by context is not loaded
                                               */
#define TPM_DELEGATE_LOCK       TPM_BASE + 75 /* The delegate administration is locked */
#define TPM_DELEGATE_FAMILY     TPM_BASE + 76 /* Attempt to manage a family other then the delegated
                                                 family */
#define TPM_DELEGATE_ADMIN      TPM_BASE + 77 /* Delegation table management not enabled */
#define TPM_TRANSPORT_NOTEXCLUSIVE TPM_BASE + 78 /* There was a command executed outside of an
                                                 exclusive transport session */
#define TPM_OWNER_CONTROL       TPM_BASE + 79 /* Attempt to context save a owner evict controlled
                                                 key */
#define TPM_DAA_RESOURCES       TPM_BASE + 80 /* The DAA command has no resources available to
                                                 execute the command */
#define TPM_DAA_INPUT_DATA0     TPM_BASE + 81 /* The consistency check on DAA parameter inputData0
                                                 has failed. */
#define TPM_DAA_INPUT_DATA1     TPM_BASE + 82 /* The consistency check on DAA parameter inputData1
                                                 has failed. */
#define TPM_DAA_ISSUER_SETTINGS TPM_BASE + 83 /* The consistency check on DAA_issuerSettings has
                                                 failed. */
#define TPM_DAA_TPM_SETTINGS    TPM_BASE + 84 /* The consistency check on DAA_tpmSpecific has
                                                 failed. */
#define TPM_DAA_STAGE           TPM_BASE + 85 /* The atomic process indicated by the submitted DAA
                                                 command is not the expected process. */
#define TPM_DAA_ISSUER_VALIDITY TPM_BASE + 86 /* The issuer's validity check has detected an
                                                 inconsistency */
#define TPM_DAA_WRONG_W         TPM_BASE + 87 /* The consistency check on w has failed. */
#define TPM_BAD_HANDLE          TPM_BASE + 88 /* The handle is incorrect */
#define TPM_BAD_DELEGATE        TPM_BASE + 89 /* Delegation is not correct */
#define TPM_BADCONTEXT          TPM_BASE + 90 /* The context blob is invalid */
#define TPM_TOOMANYCONTEXTS     TPM_BASE + 91 /* Too many contexts held by the TPM */
#define TPM_MA_TICKET_SIGNATURE TPM_BASE + 92 /* Migration authority signature validation failure
                                               */
#define TPM_MA_DESTINATION      TPM_BASE + 93 /* Migration destination not authenticated */
#define TPM_MA_SOURCE           TPM_BASE + 94 /* Migration source incorrect */
#define TPM_MA_AUTHORITY        TPM_BASE + 95 /* Incorrect migration authority */
#define TPM_PERMANENTEK         TPM_BASE + 97 /* Attempt to revoke the EK and the EK is not revocable */
#define TPM_BAD_SIGNATURE       TPM_BASE + 98 /* Bad signature of CMK ticket */ 
#define TPM_NOCONTEXTSPACE      TPM_BASE + 99 /* There is no room in the context list for additional
                                                 contexts */

/* As error codes are added here, they should also be added to lib/miscfunc.c */

/* TPM-defined non-fatal errors */

#define TPM_RETRY               TPM_BASE + TPM_NON_FATAL /* The TPM is too busy to respond to the
                                                            command immediately, but the command
                                                            could be submitted at a later time */
#define TPM_NEEDS_SELFTEST      TPM_BASE + TPM_NON_FATAL + 1 /* TPM_ContinueSelfTest has has not
                                                                been run*/
#define TPM_DOING_SELFTEST      TPM_BASE + TPM_NON_FATAL + 2 /* The TPM is currently executing the
                                                                actions of TPM_ContinueSelfTest
                                                                because the ordinal required
                                                                resources that have not been
                                                                tested. */
#define TPM_DEFEND_LOCK_RUNNING TPM_BASE + TPM_NON_FATAL + 3
                                                        /* The TPM is defending against dictionary
                                                           attacks and is in some time-out
                                                           period. */

#endif