nt9856x/BSP/u-boot/arch/arm/include/asm/nvt-common/shm_info.h
2023-03-28 15:07:53 +08:00

132 lines
4.4 KiB
C
Executable File

/**
@file shm_info.h
@ingroup
@note THESE STRUCTS ARE VERY VERY IMPORTANT FORMAT DEFINITION OF SYSTEM,
DO NOT MODIFY ANY ITEM OR INSERT/REMOVE ANY ITEM OF THESE STRUCTS!!!
Copyright Novatek Microelectronics Corp. 2018. All rights reserved.
*/
#ifndef __ARCH_COMMON_SHM_INFO_H
#define __ARCH_COMMON_SHM_INFO_H
#if defined(__UITRON)
#include "Type.h"
#elif defined(_NVT_LINUX_)
#include <mach/nvt_type.h>
#else
#include <asm/nvt-common/nvt_types.h>
#endif
#define SHM_INFO_VER 0x18060815 ///< YYYY/MM/DD HH
/**
@name Ld control flag for LDINFO.LdCtrl
*/
//@{
#define LDCF_PARTLOAD_EN 0x0000001 ///< BIT 0.PARTLOAD_EN (0=no,1=yes)
//@}
/**
@name Ld control flag for LDINFO.LdCtrl2
*/
//@{
#define LDCF_UPDATE_FW 0x0000001 ///< BIT 0.UPDATE_FW (0=no,1=yes)
#define LDCF_UPDATE_LD 0x0000002 ///< BIT 1.UPDATE_LD (0=no,1=yes)
#define LDCF_BOOT_CARD 0x0000004 ///< BIT 2.BOOT_CARD (0=no,1=yes)
#define LDCF_BOOT_FLASH 0x0000008 ///< BIT 3.BOOT_FLASH (0=no,1=yes)
#define LDCF_UPDATE_CAL 0x0000010 ///< BIT 4.UPDATE_CAL (0=no,1=yes)
#define LDCF_UPDATE_FW_DONE 0x0000100 ///< BIT 8.UPDATE_FW_DONE (0=no,1=yes)
#define LDCF_S3_BOOT 0x0000200 ///< BIT 9.BOOT FROM S3 STATE (0=no,1=yes)
//@}
/**
Loader information
MUST 28 WORDS
*/
typedef struct _BOOTINFO {
char LdInfo_1[16]; ///< LD-NAME(16) ------ w by Ld
__be32 LdCtrl; ///< Fw flag (4) ----------- r by Ld
///< BIT 0.enable part-load (0=full load,1=part load)
__be32 LdCtrl2; ///< Ld flag (4) ----------- w by Ld
///< BIT 0.UPDATE_FW (0=no,1=yes)
///< BIT 1.UPDATE_LOADER (0=no,1=yes)
///< BIT 2.BOOT_CARD (0=no,1=yes)
///< BIT 3.BOOT_FLASH (0=no,1=yes)
///< BIT 4.UPDATE_CAL (0=no,1=yes)
///< BIT 8.UPDATE_FW_DONE (0=no,1=yes)
//< BIT 9.BOOT FROM S3 STATE (0=no,1=yes)
__be32 LdLoadSize; ///< Ld load size (4) ------ w by Ld (NOTE: this value must be block size align)
__be32 LdLoadTime; ///< Ld exec time(us) (4) -- w by Ld
__be32 LdResvSize; ///< Ld size (by bytes, reserved size in partition) (4) ------ w by Ld
__be32 FWResvSize; ///< FW reserved size (4) ------ w by Ld
__be16 LdPackage; ///< IC package expected by Ld (0xFF: ES, 0: 660, 3: 663, 5: 665, etc...)
__be16 LdStorage; ///< Internal storage expected by Ld (0: unkown, 1: nand, 2: spi nand, 3: spi nor)
__be32 fdt_addr;
__be32 Resv[16]; ///< (4*5) ------------ reserved for project Ld
} BOOTINFO;
STATIC_ASSERT(sizeof(BOOTINFO) == 112);
/**
communication information
MUST 54 WORDS
*/
//BOOT_REASON
#define BOOT_REASON_NORMAL 0 // normal or from sd
#define BOOT_REASON_FWUPDFW 1 // Firmware update Firmware
#define BOOT_REASON_FROM_USB 2 // Update from USB
#define BOOT_REASON_FROM_ETH 3 // Update from ethernet
#define BOOT_REASON_FORMAT_ROOTFS 4 // Format rootfs because rootfs broken is detected
#define BOOT_REASON_RECOVERY_SYS 5 // System recovery from eMMC
#define BOOT_REASON_FROM_UART 6 // Update from uart
//COMMINFO::Resv field definition
typedef enum _COMM_RESV_IDX_{
COMM_RESV_IDX_BOOT_REASON = 0,
COMM_RESV_IDX_CORE1_START = 1,
COMM_RESV_IDX_CORE2_START = 2,
COMM_RESV_IDX_UITRON_COMP_ADDR = 3,
COMM_RESV_IDX_UITRON_COMP_LEN = 4,
COMM_RESV_IDX_FW_UPD_ADDR = 5,
COMM_RESV_IDX_FW_UPD_LEN = 6,
COMM_RESV_IDX_OTA_NAME_ADDR = 7,
COMM_RESV_IDX_S3_APB_ADDR = 8,
COMM_RESV_IDX_S3_APB_LEN = 9,
} COMM_RESV_IDX;
typedef struct _COMMINFO {
char CommInfo_1[16];///< COMMINFO (16)
__be32 Resv[45];///< reversed data for communication between loader, uboot, uitron, linux
// Resv[0]: COMM_RESV_IDX_BOOT_REASON,
// BYTE[0]: BOOT_REASON: use #define COMM_BOOT_REASON_
// BYTE[1]: BOOT_DONE: 0:Not yet, 1:Done 2:NG
// BYTE[2]: DSP_DONE: 0:Not yet, 1:Done 2:NG
// Resv[1]: COMM_CORE1_START (used on uboot trigger loader to start uitron)
// Resv[2]: COMM_CORE2_START (used on uitron trigger linux resume)
// Resv[3]: COMM_UITRON_COMP_ADDR
// Resv[4]: COMM_UITRON_COMP_LEN
// Resv[5]: COMM_FW_UPD_ADDR
// Resv[6]: COMM_FW_UPD_LEN
// Resv[7]: COMM_OTA_NAME_ADDR : OTA name
// Resv[8]: COMM_S3_APB_ADDR : S3-resume's apb register info addr
// Resv[9]: COMM_S3_APB_LEN : S3-resume's apb register info len
__be32 UserDef[5]; ///< can be used for customer
} COMMINFO;
STATIC_ASSERT(sizeof(COMMINFO) == 216);
/**
Binary file information
MUST 82 WORDS
*/
typedef struct _SHMINFO {
BOOTINFO boot;
COMMINFO comm;
} SHMINFO;
STATIC_ASSERT(sizeof(SHMINFO) == 328);
#endif /* __ARCH_COMMON_SHM_INFO_H */