xref: /freebsd/sys/dev/qlnx/qlnxe/spad_layout.h (revision 95ee2897)
111e25f0dSDavid C Somayajulu /*
211e25f0dSDavid C Somayajulu  * Copyright (c) 2017-2018 Cavium, Inc.
311e25f0dSDavid C Somayajulu  * All rights reserved.
411e25f0dSDavid C Somayajulu  *
511e25f0dSDavid C Somayajulu  *  Redistribution and use in source and binary forms, with or without
611e25f0dSDavid C Somayajulu  *  modification, are permitted provided that the following conditions
711e25f0dSDavid C Somayajulu  *  are met:
811e25f0dSDavid C Somayajulu  *
911e25f0dSDavid C Somayajulu  *  1. Redistributions of source code must retain the above copyright
1011e25f0dSDavid C Somayajulu  *     notice, this list of conditions and the following disclaimer.
1111e25f0dSDavid C Somayajulu  *  2. Redistributions in binary form must reproduce the above copyright
1211e25f0dSDavid C Somayajulu  *     notice, this list of conditions and the following disclaimer in the
1311e25f0dSDavid C Somayajulu  *     documentation and/or other materials provided with the distribution.
1411e25f0dSDavid C Somayajulu  *
1511e25f0dSDavid C Somayajulu  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1611e25f0dSDavid C Somayajulu  *  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1711e25f0dSDavid C Somayajulu  *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1811e25f0dSDavid C Somayajulu  *  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
1911e25f0dSDavid C Somayajulu  *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2011e25f0dSDavid C Somayajulu  *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2111e25f0dSDavid C Somayajulu  *  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2211e25f0dSDavid C Somayajulu  *  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2311e25f0dSDavid C Somayajulu  *  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2411e25f0dSDavid C Somayajulu  *  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2511e25f0dSDavid C Somayajulu  *  POSSIBILITY OF SUCH DAMAGE.
2611e25f0dSDavid C Somayajulu  *
2711e25f0dSDavid C Somayajulu  */
2811e25f0dSDavid C Somayajulu 
2911e25f0dSDavid C Somayajulu /****************************************************************************
3011e25f0dSDavid C Somayajulu  * Name:        spad_layout.h
3111e25f0dSDavid C Somayajulu  *
3211e25f0dSDavid C Somayajulu  * Description: Global definitions
3311e25f0dSDavid C Somayajulu  *
3411e25f0dSDavid C Somayajulu  * Created:     01/09/2013
3511e25f0dSDavid C Somayajulu  *
3611e25f0dSDavid C Somayajulu  ****************************************************************************/
3711e25f0dSDavid C Somayajulu /*
3811e25f0dSDavid C Somayajulu  *          Spad Layout                                NVM CFG                         MCP public
3911e25f0dSDavid C Somayajulu  *==========================================================================================================
4011e25f0dSDavid C Somayajulu  *     MCP_REG_SCRATCH                         REG_RD(MISC_REG_GEN_PURP_CR0)       REG_RD(MISC_REG_SHARED_MEM_ADDR)
4111e25f0dSDavid C Somayajulu  *    +------------------+                      +-------------------------+        +-------------------+
4211e25f0dSDavid C Somayajulu  *    |  Num Sections(4B)|Currently 4           |   Num Sections(4B)      |        |   Num Sections(4B)|Currently 6
4311e25f0dSDavid C Somayajulu  *    +------------------+                      +-------------------------+        +-------------------+
4411e25f0dSDavid C Somayajulu  *    | Offsize(Trace)   |4B -+             +-- | Offset(NVM_CFG1)        |        | Offsize(drv_mb)   |
4511e25f0dSDavid C Somayajulu  *  +-| Offsize(NVM_CFG) |4B  |             |   | (Size is fixed)         |        | Offsize(mfw_mb)   |
4611e25f0dSDavid C Somayajulu  *+-|-| Offsize(Public)  |4B  |             +-> +-------------------------+        | Offsize(global)   |
4711e25f0dSDavid C Somayajulu  *| | | Offsize(Private) |4B  |                 |                         |        | Offsize(path)     |
4811e25f0dSDavid C Somayajulu  *| | +------------------+ <--+                 | nvm_cfg1_glob           |        | Offsize(port)     |
4911e25f0dSDavid C Somayajulu  *| | |                  |                      +-------------------------+        | Offsize(func)     |
5011e25f0dSDavid C Somayajulu  *| | |      Trace       |                      | nvm_cfg1_path 0         |        +-------------------+
5111e25f0dSDavid C Somayajulu  *| +>+------------------+                      | nvm_cfg1_path 1         |        | drv_mb   PF0/2/4..|8 Funcs of engine0
5211e25f0dSDavid C Somayajulu  *|   |                  |                      +-------------------------+        | drv_mb   PF1/3/5..|8 Funcs of engine1
5311e25f0dSDavid C Somayajulu  *|   |     NVM_CFG      |                      | nvm_cfg1_port 0         |        +-------------------+
5411e25f0dSDavid C Somayajulu  *+-> +------------------+                      |            ....         |        | mfw_mb   PF0/2/4..|8 Funcs of engine0
5511e25f0dSDavid C Somayajulu  *    |                  |                      | nvm_cfg1_port 3         |        | mfw_mb   PF1/3/5..|8 Funcs of engine1
5611e25f0dSDavid C Somayajulu  *    |   Public Data    |                      +-------------------------+        +-------------------+
5711e25f0dSDavid C Somayajulu  *    +------------------+   8 Funcs of Engine 0| nvm_cfg1_func PF0/2/4/..|        |                   |
5811e25f0dSDavid C Somayajulu  *    |                  |   8 Funcs of Engine 1| nvm_cfg1_func PF1/3/5/..|        | public_global     |
5911e25f0dSDavid C Somayajulu  *    |   Private Data   |                      +-------------------------+        +-------------------+
6011e25f0dSDavid C Somayajulu  *    +------------------+                                                         | public_path 0     |
6111e25f0dSDavid C Somayajulu  *    |       Code       |                                                         | public_path 1     |
6211e25f0dSDavid C Somayajulu  *    |   Static Area    |                                                         +-------------------+
6311e25f0dSDavid C Somayajulu  *    +---            ---+                                                         | public_port 0     |
6411e25f0dSDavid C Somayajulu  *    |       Code       |                                                         |        ....       |
6511e25f0dSDavid C Somayajulu  *    |      PIM Area    |                                                         | public_port 3     |
6611e25f0dSDavid C Somayajulu  *    +------------------+                                                         +-------------------+
6711e25f0dSDavid C Somayajulu  *                                                                                 | public_func 0/2/4.|8 Funcs of engine0
6811e25f0dSDavid C Somayajulu  *                                                                                 | public_func 1/3/5.|8 Funcs of engine1
6911e25f0dSDavid C Somayajulu  *                                                                                 +-------------------+
7011e25f0dSDavid C Somayajulu */
7111e25f0dSDavid C Somayajulu #ifndef SPAD_LAYOUT_H
7211e25f0dSDavid C Somayajulu #define SPAD_LAYOUT_H
7311e25f0dSDavid C Somayajulu 
7411e25f0dSDavid C Somayajulu #ifndef MDUMP_PARSE_TOOL
7511e25f0dSDavid C Somayajulu 
7611e25f0dSDavid C Somayajulu #define PORT_0		0
7711e25f0dSDavid C Somayajulu #define PORT_1		1
7811e25f0dSDavid C Somayajulu #define PORT_2		2
7911e25f0dSDavid C Somayajulu #define PORT_3		3
8011e25f0dSDavid C Somayajulu 
8111e25f0dSDavid C Somayajulu #include "mcp_public.h"
8211e25f0dSDavid C Somayajulu #include "mfw_hsi.h"
8311e25f0dSDavid C Somayajulu #include "nvm_cfg.h"
8411e25f0dSDavid C Somayajulu 
8511e25f0dSDavid C Somayajulu #ifdef MFW
8611e25f0dSDavid C Somayajulu #include "mcp_private.h"
8711e25f0dSDavid C Somayajulu #endif
8811e25f0dSDavid C Somayajulu 
8911e25f0dSDavid C Somayajulu extern struct spad_layout g_spad;
9011e25f0dSDavid C Somayajulu 
9111e25f0dSDavid C Somayajulu /* TBD - Consider renaming to MCP_STATIC_SPAD_SIZE, since the real size includes another 64kb */
9211e25f0dSDavid C Somayajulu #define MCP_SPAD_SIZE                       0x00028000	/* 160 KB */
9311e25f0dSDavid C Somayajulu 
9411e25f0dSDavid C Somayajulu #define SPAD_OFFSET(addr) (((u32)addr - (u32)CPU_SPAD_BASE))
9511e25f0dSDavid C Somayajulu #endif /* MDUMP_PARSE_TOOL */
9611e25f0dSDavid C Somayajulu 
9711e25f0dSDavid C Somayajulu #define TO_OFFSIZE(_offset, _size) \
989efd0ba7SDavid C Somayajulu     (u32)((((u32)(_offset) >> 2) << OFFSIZE_OFFSET_OFFSET) | \
999efd0ba7SDavid C Somayajulu 	  (((u32)(_size) >> 2) << OFFSIZE_SIZE_OFFSET))
10011e25f0dSDavid C Somayajulu 
10111e25f0dSDavid C Somayajulu enum spad_sections {
10211e25f0dSDavid C Somayajulu 	SPAD_SECTION_TRACE,
10311e25f0dSDavid C Somayajulu 	SPAD_SECTION_NVM_CFG,
10411e25f0dSDavid C Somayajulu 	SPAD_SECTION_PUBLIC,
10511e25f0dSDavid C Somayajulu 	SPAD_SECTION_PRIVATE,
106217ec208SDavid C Somayajulu 	SPAD_SECTION_MAX /* Cannot be modified anymore since ROM relying on this size !! */
10711e25f0dSDavid C Somayajulu };
10811e25f0dSDavid C Somayajulu 
10911e25f0dSDavid C Somayajulu #ifndef MDUMP_PARSE_TOOL
11011e25f0dSDavid C Somayajulu struct spad_layout {
11111e25f0dSDavid C Somayajulu 	struct nvm_cfg nvm_cfg;
11211e25f0dSDavid C Somayajulu 	struct mcp_public_data public_data;
11311e25f0dSDavid C Somayajulu #ifdef MFW			/* Drivers will not be compiled with this flag. */
11411e25f0dSDavid C Somayajulu 	/* Linux should remove this appearance at all. */
11511e25f0dSDavid C Somayajulu 	struct mcp_private_data private_data;
11611e25f0dSDavid C Somayajulu #endif
11711e25f0dSDavid C Somayajulu };
11811e25f0dSDavid C Somayajulu 
11911e25f0dSDavid C Somayajulu #endif /* MDUMP_PARSE_TOOL */
12011e25f0dSDavid C Somayajulu 
12111e25f0dSDavid C Somayajulu #define STRUCT_OFFSET(f)    (STATIC_INIT_BASE + __builtin_offsetof(struct static_init, f))
12211e25f0dSDavid C Somayajulu 
12311e25f0dSDavid C Somayajulu /* This section is located at a fixed location in the beginning of the scratchpad,
12411e25f0dSDavid C Somayajulu  * to ensure that the MCP trace is not run over during MFW upgrade.
12511e25f0dSDavid C Somayajulu  * All the rest of data has a floating location which differs from version to version,
12611e25f0dSDavid C Somayajulu  * and is pointed by the mcp_meta_data below.
12711e25f0dSDavid C Somayajulu  * Moreover, the spad_layout section is part of the MFW firmware, and is loaded with it
12811e25f0dSDavid C Somayajulu  * from nvram in order to clear this portion.
12911e25f0dSDavid C Somayajulu  */
130217ec208SDavid C Somayajulu 
13111e25f0dSDavid C Somayajulu struct static_init {
13211e25f0dSDavid C Somayajulu 	u32 num_sections;						/* 0xe20000 */
13311e25f0dSDavid C Somayajulu 	offsize_t sections[SPAD_SECTION_MAX];				/* 0xe20004 */
13411e25f0dSDavid C Somayajulu #define SECTION(_sec_) *((offsize_t*)(STRUCT_OFFSET(sections[_sec_])))
13511e25f0dSDavid C Somayajulu 
136217ec208SDavid C Somayajulu #ifdef SECURE_BOOT
137217ec208SDavid C Somayajulu 	u32 tim_sha256[8];	/* Used by E5 ROM. Do not relocate */
138217ec208SDavid C Somayajulu 	u32 rom_status_code; 	/* Used by E5 ROM. Do not relocate */
139217ec208SDavid C Somayajulu 	u32 secure_running_mfw;	/* Instead of the one after the trace_buffer */ /* Used by E5 ROM. Do not relocate */
140217ec208SDavid C Somayajulu #define SECURE_RUNNING_MFW *((u32*)(STRUCT_OFFSET(secure_running_mfw)))
141217ec208SDavid C Somayajulu #endif
142217ec208SDavid C Somayajulu 
14311e25f0dSDavid C Somayajulu 	struct mcp_trace trace;						/* 0xe20014 */
144217ec208SDavid C Somayajulu 
145217ec208SDavid C Somayajulu #ifdef MFW
14611e25f0dSDavid C Somayajulu #define MCP_TRACE_P ((struct mcp_trace*)(STRUCT_OFFSET(trace)))
14711e25f0dSDavid C Somayajulu 	u8 trace_buffer[MCP_TRACE_SIZE];				/* 0xe20030 */
14811e25f0dSDavid C Somayajulu #define MCP_TRACE_BUF ((u8*)(STRUCT_OFFSET(trace_buffer)))
14911e25f0dSDavid C Somayajulu 	/* running_mfw has the same definition as in nvm_map.h.
15011e25f0dSDavid C Somayajulu 	 * This bit indicate both the running dir, and the running bundle.
15111e25f0dSDavid C Somayajulu 	 * It is set once when the LIM is loaded.
15211e25f0dSDavid C Somayajulu 	 */
15311e25f0dSDavid C Somayajulu 	u32 running_mfw;						/* 0xe20830 */
15411e25f0dSDavid C Somayajulu #define RUNNING_MFW *((u32*)(STRUCT_OFFSET(running_mfw)))
15511e25f0dSDavid C Somayajulu 	u32 build_time;							/* 0xe20834 */
15611e25f0dSDavid C Somayajulu #define MFW_BUILD_TIME *((u32*)(STRUCT_OFFSET(build_time)))
15711e25f0dSDavid C Somayajulu 	u32 reset_type;							/* 0xe20838 */
15811e25f0dSDavid C Somayajulu #define RESET_TYPE *((u32*)(STRUCT_OFFSET(reset_type)))
15911e25f0dSDavid C Somayajulu 	u32 mfw_secure_mode;						/* 0xe2083c */
16011e25f0dSDavid C Somayajulu #define MFW_SECURE_MODE *((u32*)(STRUCT_OFFSET(mfw_secure_mode)))
16111e25f0dSDavid C Somayajulu 	u16 pme_status_pf_bitmap;					/* 0xe20840 */
16211e25f0dSDavid C Somayajulu #define PME_STATUS_PF_BITMAP *((u16*)(STRUCT_OFFSET(pme_status_pf_bitmap)))
16311e25f0dSDavid C Somayajulu 	u16 pme_enable_pf_bitmap;
16411e25f0dSDavid C Somayajulu #define PME_ENABLE_PF_BITMAP *((u16*)(STRUCT_OFFSET(pme_enable_pf_bitmap)))
16511e25f0dSDavid C Somayajulu 	u32 mim_nvm_addr;						/* 0xe20844 */
16611e25f0dSDavid C Somayajulu 	u32 mim_start_addr;						/* 0xe20848 */
16711e25f0dSDavid C Somayajulu 	u32 ah_pcie_link_params; /* 0xe20850 Stores PCIe link configuration at start, so they can be used later also for Hot-Reset, without the need to re-reading them from nvm cfg. */
16811e25f0dSDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_LINK_SPEED_MASK	(0x000000ff)
1699efd0ba7SDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_LINK_SPEED_OFFSET	(0)
17011e25f0dSDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_LINK_WIDTH_MASK	(0x0000ff00)
1719efd0ba7SDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_LINK_WIDTH_OFFSET	(8)
17211e25f0dSDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_ASPM_MODE_MASK	(0x00ff0000)
1739efd0ba7SDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_ASPM_MODE_OFFSET	(16)
17411e25f0dSDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_ASPM_CAP_MASK	(0xff000000)
1759efd0ba7SDavid C Somayajulu #define AH_PCIE_LINK_PARAMS_ASPM_CAP_OFFSET	(24)
17611e25f0dSDavid C Somayajulu #define AH_PCIE_LINK_PARAMS *((u32*)(STRUCT_OFFSET(ah_pcie_link_params)))
17711e25f0dSDavid C Somayajulu 
17811e25f0dSDavid C Somayajulu 	u32 flags;							/* 0xe20850 */
17911e25f0dSDavid C Somayajulu #define M_GLOB_FLAGS		*((u32*)(STRUCT_OFFSET(flags)))
18011e25f0dSDavid C Somayajulu #define FLAGS_VAUX_REQUIRED		(1 << 0)
18111e25f0dSDavid C Somayajulu #define FLAGS_WAIT_AVS_READY		(1 << 1)
18211e25f0dSDavid C Somayajulu #define FLAGS_FAILURE_ISSUED		(1 << 2)
18311e25f0dSDavid C Somayajulu #define FLAGS_FAILURE_DETECTED		(1 << 3)
18411e25f0dSDavid C Somayajulu #define FLAGS_VAUX			(1 << 4)
18511e25f0dSDavid C Somayajulu #define FLAGS_PERST_ASSERT_OCCURED	(1 << 5)
18611e25f0dSDavid C Somayajulu #define FLAGS_HOT_RESET_STEP2		(1 << 6)
18711e25f0dSDavid C Somayajulu #define FLAGS_MSIX_SYNC_ALLOWED		(1 << 7)
18811e25f0dSDavid C Somayajulu #define FLAGS_PROGRAM_PCI_COMPLETED	(1 << 8)
18911e25f0dSDavid C Somayajulu #define FLAGS_SMBUS_AUX_MODE		(1 << 9)
19011e25f0dSDavid C Somayajulu #define FLAGS_PEND_SMBUS_VMAIN_TO_AUX	(1 << 10)
19111e25f0dSDavid C Somayajulu #define FLAGS_NVM_CFG_EFUSE_FAILURE	(1 << 11)
1929efd0ba7SDavid C Somayajulu #define FLAGS_POWER_TRANSITION		(1 << 12)
193217ec208SDavid C Somayajulu #define FLAGS_MCTP_CHECK_PUMA_TIMEOUT	(1 << 13)
194217ec208SDavid C Somayajulu #define FLAGS_MCTP_TX_PLDM_UPDATE	(1 << 14)
195217ec208SDavid C Somayajulu #define FLAGS_MCTP_SENSOR_EVENT	    (1 << 15)
196217ec208SDavid C Somayajulu #define FLAGS_PMBUS_ERROR           (1 << 28)
19711e25f0dSDavid C Somayajulu #define FLAGS_OS_DRV_LOADED 		(1 << 29)
19811e25f0dSDavid C Somayajulu #define FLAGS_OVER_TEMP_OCCUR		(1 << 30)
19911e25f0dSDavid C Somayajulu #define FLAGS_FAN_FAIL_OCCUR		(1 << 31)
20011e25f0dSDavid C Somayajulu 	u32 rsrv_persist[4]; /* Persist reserved for MFW upgrades */	/* 0xe20854 */
201217ec208SDavid C Somayajulu #endif /* MFW */
20211e25f0dSDavid C Somayajulu };
20311e25f0dSDavid C Somayajulu 
20411e25f0dSDavid C Somayajulu #ifndef MDUMP_PARSE_TOOL
20511e25f0dSDavid C Somayajulu #define NVM_CFG1(x)             g_spad.nvm_cfg.cfg1.x
20611e25f0dSDavid C Somayajulu #define NVM_GLOB(x)		NVM_CFG1(glob).x
20711e25f0dSDavid C Somayajulu #define NVM_GLOB_VAL(n, m, o)   ((NVM_GLOB(n) & m) >> o)
20811e25f0dSDavid C Somayajulu #endif /* MDUMP_PARSE_TOOL */
20911e25f0dSDavid C Somayajulu 
21011e25f0dSDavid C Somayajulu #endif				/* SPAD_LAYOUT_H */
211