blob: bc9dab230bc449ed7a1d15291cdcb33b2c609631 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
gaurav ranac3a50422015-02-27 09:45:35 +05302/*
3 * Copyright 2015 Freescale Semiconductor, Inc.
gaurav ranac3a50422015-02-27 09:45:35 +05304 */
5
6#ifndef _FSL_SECBOOT_ERR_H
7#define _FSL_SECBOOT_ERR_H
8
9#define ERROR_ESBC_PAMU_INIT 0x100000
10#define ERROR_ESBC_SEC_RESET 0x200000
11#define ERROR_ESBC_SEC_INIT 0x400000
12#define ERROR_ESBC_SEC_DEQ 0x800000
13#define ERROR_ESBC_SEC_DEQ_TO 0x1000000
14#define ERROR_ESBC_SEC_ENQ 0x2000000
15#define ERROR_ESBC_SEC_JOBQ_STATUS 0x4000000
16#define ERROR_ESBC_CLIENT_CPUID_NO_MATCH 0x1
17#define ERROR_ESBC_CLIENT_HDR_LOC 0x2
18#define ERROR_ESBC_CLIENT_HEADER_BARKER 0x4
19#define ERROR_ESBC_CLIENT_HEADER_KEY_LEN 0x8
20#define ERROR_ESBC_CLIENT_HEADER_SIG_LEN 0x10
21#define ERROR_ESBC_CLIENT_HEADER_KEY_REVOKED 0x11
22#define ERROR_ESBC_CLIENT_HEADER_INVALID_SRK_NUM_ENTRY 0x12
23#define ERROR_ESBC_CLIENT_HEADER_INVALID_KEY_NUM 0x13
24#define ERROR_ESBC_CLIENT_HEADER_INV_SRK_ENTRY_KEYLEN 0x14
25#define ERROR_ESBC_CLIENT_HEADER_IE_KEY_REVOKED 0x15
26#define ERROR_ESBC_CLIENT_HEADER_INVALID_IE_NUM_ENTRY 0x16
27#define ERROR_ESBC_CLIENT_HEADER_INVALID_IE_KEY_NUM 0x17
28#define ERROR_ESBC_CLIENT_HEADER_INV_IE_ENTRY_KEYLEN 0x18
29#define ERROR_IE_TABLE_NOT_FOUND 0x19
30#define ERROR_ESBC_CLIENT_HEADER_KEY_LEN_NOT_TWICE_SIG_LEN 0x20
Saksham Jain6121f082016-03-23 16:24:34 +053031#define ERROR_KEY_TABLE_NOT_FOUND 0x21
gaurav ranac3a50422015-02-27 09:45:35 +053032#define ERROR_ESBC_CLIENT_HEADER_KEY_MOD_1 0x40
33#define ERROR_ESBC_CLIENT_HEADER_KEY_MOD_2 0x80
34#define ERROR_ESBC_CLIENT_HEADER_SIG_KEY_MOD 0x100
35#define ERROR_ESBC_CLIENT_HEADER_SG_ESBC_EP 0x200
36#define ERROR_ESBC_CLIENT_HASH_COMPARE_KEY 0x400
37#define ERROR_ESBC_CLIENT_HASH_COMPARE_EM 0x800
38#define ERROR_ESBC_CLIENT_SSM_TRUSTSTS 0x1000
39#define ERROR_ESBC_CLIENT_BAD_ADDRESS 0x2000
40#define ERROR_ESBC_CLIENT_MISC 0x4000
41#define ERROR_ESBC_CLIENT_HEADER_SG_ENTIRES_BAD 0x8000
42#define ERROR_ESBC_CLIENT_HEADER_SG 0x10000
43#define ERROR_ESBC_CLIENT_HEADER_IMG_SIZE 0x20000
44#define ERROR_ESBC_WRONG_CMD 0x40000
45#define ERROR_ESBC_MISSING_BOOTM 0x80000
46#define ERROR_ESBC_CLIENT_MAX 0x0
47
48struct fsl_secboot_errcode {
49 int errcode;
50 const char *name;
51};
52
53static const struct fsl_secboot_errcode fsl_secboot_errcodes[] = {
54 { ERROR_ESBC_PAMU_INIT,
55 "Error in initializing PAMU"},
56 { ERROR_ESBC_SEC_RESET,
57 "Error in resetting Job ring of SEC"},
58 { ERROR_ESBC_SEC_INIT,
59 "Error in initializing SEC"},
60 { ERROR_ESBC_SEC_ENQ,
61 "Error in enqueue operation by SEC"},
62 { ERROR_ESBC_SEC_DEQ_TO,
63 "Dequeue operation by SEC is timed out"},
64 { ERROR_ESBC_SEC_DEQ,
65 "Error in dequeue operation by SEC"},
66 { ERROR_ESBC_SEC_JOBQ_STATUS,
67 "Error in status of the job submitted to SEC"},
68 { ERROR_ESBC_CLIENT_CPUID_NO_MATCH,
69 "Current core is not boot core i.e core0" },
70 { ERROR_ESBC_CLIENT_HDR_LOC,
71 "Header address not in allowed memory range" },
72 { ERROR_ESBC_CLIENT_HEADER_BARKER,
73 "Wrong barker code in header" },
74 { ERROR_ESBC_CLIENT_HEADER_KEY_LEN,
75 "Wrong public key length in header" },
76 { ERROR_ESBC_CLIENT_HEADER_SIG_LEN,
77 "Wrong signature length in header" },
78 { ERROR_ESBC_CLIENT_HEADER_KEY_LEN_NOT_TWICE_SIG_LEN,
79 "Public key length not twice of signature length" },
80 { ERROR_ESBC_CLIENT_HEADER_KEY_MOD_1,
81 "Public key Modulus most significant bit not set" },
82 { ERROR_ESBC_CLIENT_HEADER_KEY_MOD_2,
83 "Public key Modulus in header not odd" },
84 { ERROR_ESBC_CLIENT_HEADER_SIG_KEY_MOD,
85 "Signature not less than modulus" },
86 { ERROR_ESBC_CLIENT_HEADER_SG_ESBC_EP,
87 "Entry point not in allowed space or one of the SG entries" },
88 { ERROR_ESBC_CLIENT_HASH_COMPARE_KEY,
89 "Public key hash comparison failed" },
90 { ERROR_ESBC_CLIENT_HASH_COMPARE_EM,
91 "RSA verification failed" },
92 { ERROR_ESBC_CLIENT_SSM_TRUSTSTS,
93 "SNVS not in TRUSTED state" },
94 { ERROR_ESBC_CLIENT_BAD_ADDRESS,
95 "Bad address error" },
96 { ERROR_ESBC_CLIENT_MISC,
97 "Miscallaneous error" },
98 { ERROR_ESBC_CLIENT_HEADER_SG,
99 "No SG support" },
100 { ERROR_ESBC_CLIENT_HEADER_IMG_SIZE,
101 "Invalid Image size" },
102 { ERROR_ESBC_WRONG_CMD,
103 "Unknown cmd/Wrong arguments. Core in infinite loop"},
104 { ERROR_ESBC_MISSING_BOOTM,
105 "Bootm command missing from bootscript" },
106 { ERROR_ESBC_CLIENT_HEADER_KEY_REVOKED,
107 "Selected key is revoked" },
108 { ERROR_ESBC_CLIENT_HEADER_INVALID_SRK_NUM_ENTRY,
109 "Wrong key entry" },
110 { ERROR_ESBC_CLIENT_HEADER_INVALID_KEY_NUM,
111 "Wrong key is selected" },
112 { ERROR_ESBC_CLIENT_HEADER_INV_SRK_ENTRY_KEYLEN,
113 "Wrong srk public key len in header" },
114 { ERROR_ESBC_CLIENT_HEADER_IE_KEY_REVOKED,
115 "Selected IE key is revoked" },
116 { ERROR_ESBC_CLIENT_HEADER_INVALID_IE_NUM_ENTRY,
117 "Wrong key entry in IE Table" },
118 { ERROR_ESBC_CLIENT_HEADER_INVALID_IE_KEY_NUM,
119 "Wrong IE key is selected" },
120 { ERROR_ESBC_CLIENT_HEADER_INV_IE_ENTRY_KEYLEN,
121 "Wrong IE public key len in header" },
122 { ERROR_IE_TABLE_NOT_FOUND,
123 "Information about IE Table missing" },
Saksham Jain6121f082016-03-23 16:24:34 +0530124 { ERROR_KEY_TABLE_NOT_FOUND,
125 "No Key/ Key Table Found in header"},
gaurav ranac3a50422015-02-27 09:45:35 +0530126 { ERROR_ESBC_CLIENT_MAX, "NULL" }
127};
128
129void fsl_secboot_handle_error(int error);
130#endif