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