aboutsummaryrefslogtreecommitdiff
path: root/src/vendorcode/amd/fsp/picasso/include/bl_uapp/bl_errorcodes_public.h
blob: 1d5e86ffb172a482aa6b2453bc8eca76f1efb902 (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
/*****************************************************************************
 *
 * Copyright (c) 2020, Advanced Micro Devices, Inc.
 * 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 name of Advanced Micro Devices, Inc. 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 ADVANCED MICRO DEVICES, INC. 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 BL_ERRORCODES_PUBLIC_H
#define BL_ERRORCODES_PUBLIC_H

/* Bootloader Return Codes, Error only (0x00 through 0x9F) */
#define BL_OK					0x00	// General - Success
#define BL_ERR_GENERIC				0x01	// Generic Error Code
#define BL_ERR_MEMORY				0x02	// Generic Memory Error
#define BL_ERR_BUFFER_OVERFLOW			0x03	// Buffer Overflow
#define BL_ERR_INVALID_PARAMETER		0x04	// Invalid Parameter(s)
#define BL_ERR_DATA_ALIGNMENT			0x06	// Data Alignment Error
#define BL_ERR_NULL_PTR				0x07	// Null Pointer Error
#define BL_ERR_INVALID_ADDRESS			0x0A	// Invalid Address
#define BL_ERR_OUT_OF_RESOURCES			0x0B	// Out of Resource Error
#define BL_ERR_DATA_ABORT			0x0D	// Data Abort exception
#define BL_ERR_PREFETCH_ABORT			0x0E	// Prefetch Abort exception
#define BL_ERR_GET_FW_HEADER			0x13	// Failure in retrieving firmware
							// header
#define BL_ERR_KEY_SIZE				0x14	// Key size not supported
#define BL_ERR_ENTRY_NOT_FOUND			0x15	// Entry not found at requested
							// location
#define BL_ERR_UNSUPPORTED_PLATFORM		0x16	// Error when feature is not enabled
							// on a given platform.
#define BL_ERR_FWVALIDATION			0x18	// Generic FW Validation error
#define BL_ERR_CCP_RSA				0x19	// RSA operation fail - bootloader
#define BL_ERR_CCP_PASSTHR			0x1A	// CCP Passthrough operation failed
#define BL_ERR_CCP_AES				0x1B	// AES operation failed
#define BL_ERR_SHA				0x1E	// SHA256/SHA384 operation failed
#define BL_ERR_ZLIB				0x1F	// ZLib Decompression operation fail
#define BL_ERR_DIR_ENTRY_NOT_FOUND		0x22	// PSP directory entry not found
#define BL_ERR_SYSHUBMAP_FAILED			0x3A	// Unable to map a SYSHUB address to
							// AXI space
#define BL_ERR_UAPP_PSP_HEADER_NOT_MATCH	0x7A	// PSP level directory from OEM user-
							// app does not match expected value.
#define BL_ERR_UAPP_BIOS_HEADER_NOT_MATCH	0x7B	// BIOS level directory from OEM
							// user-app not match expected value.
#define BL_ERR_UAPP_PSP_DIR_OFFSET_NOT_SET	0x7C	// PSP Directory offset is not set
							// by OEM user-app.
#define BL_ERR_UAPP_BIOS_DIR_OFFSET_NOT_SET	0x7D	// BIOS Directory offset is not set
							// by OEM user-app.
#define BL_ERR_POSTCODE_MAX_VALUE		0x9F	// The maximum allowable error post

/* Bootloader Return Codes, Success only (0xA0 through 0xFF) */
#define BL_SUCCESS_USERMODE_OEM_APP		0xF7	// Updated only PSPFW Status when OEM
							// PSP BL user app returns success.
#define BL_SUCCESS_PSP_BIOS_DIRECTORY_UPDATE	0xF8	// PSP and BIOS directories are loaded
							// into SRAM from the offset provided
							// by OEM user app.

#define BL_SUCCESS_LAST_CODE			0xFF	// Bootloader sequence finished

#endif /* BL_ERRORCODES_PUBLIC_H */