3e3332130f
This patch adds more nand headers in two new types: 1. HSM header, used for spi-nand thru SNFI interface 2. SPIM header, used for spi-nand thru spi-mem interface The original nand header is renamed to AP header. Tested-by: Daniel Golle <daniel@makrotopia.org> Signed-off-by: Weijie Gao <weijie.gao@mediatek.com>
166 lines
5.2 KiB
C
166 lines
5.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* MediaTek BootROM NAND header definitions
|
|
*
|
|
* Copyright (C) 2022 MediaTek Inc.
|
|
* Author: Weijie Gao <weijie.gao@mediatek.com>
|
|
*/
|
|
|
|
#ifndef _MTK_NAND_HEADERS_H
|
|
#define _MTK_NAND_HEADERS_H
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
|
|
struct nand_header_info {
|
|
uint32_t page_size;
|
|
uint32_t spare_size;
|
|
uint32_t gfh_offset;
|
|
bool snfi;
|
|
};
|
|
|
|
/* AP BROM Header for NAND */
|
|
union nand_boot_header {
|
|
struct {
|
|
char name[12];
|
|
char version[4];
|
|
char id[8];
|
|
uint16_t ioif; /* I/O interface */
|
|
uint16_t pagesize; /* NAND page size */
|
|
uint16_t addrcycles; /* Address cycles */
|
|
uint16_t oobsize; /* NAND page spare size */
|
|
uint16_t pages_of_block; /* Pages of one block */
|
|
uint16_t numblocks; /* Total blocks of NAND chip */
|
|
uint16_t writesize_shift;
|
|
uint16_t erasesize_shift;
|
|
uint8_t dummy[60];
|
|
uint8_t ecc_parity[28]; /* ECC parity of this header */
|
|
};
|
|
|
|
uint8_t data[0x80];
|
|
};
|
|
|
|
/* HSM BROM Header for NAND */
|
|
union hsm_nand_boot_header {
|
|
struct {
|
|
char id[8];
|
|
uint32_t version; /* Header version */
|
|
uint32_t config; /* Header config */
|
|
uint32_t sector_size; /* ECC step size */
|
|
uint32_t fdm_size; /* User OOB size of a step */
|
|
uint32_t fdm_ecc_size; /* ECC parity size of a step */
|
|
uint32_t lbs;
|
|
uint32_t page_size; /* NAND page size */
|
|
uint32_t spare_size; /* NAND page spare size */
|
|
uint32_t page_per_block; /* Pages of one block */
|
|
uint32_t blocks; /* Total blocks of NAND chip */
|
|
uint32_t plane_sel_position; /* Plane bit position */
|
|
uint32_t pll; /* Value of pll reg */
|
|
uint32_t acccon; /* Value of access timing reg */
|
|
uint32_t strobe_sel; /* Value of DQS selection reg*/
|
|
uint32_t acccon1; /* Value of access timing reg */
|
|
uint32_t dqs_mux; /* Value of DQS mux reg */
|
|
uint32_t dqs_ctrl; /* Value of DQS control reg */
|
|
uint32_t delay_ctrl; /* Value of delay ctrl reg */
|
|
uint32_t latch_lat; /* Value of latch latency reg */
|
|
uint32_t sample_delay; /* Value of sample delay reg */
|
|
uint32_t driving; /* Value of driving reg */
|
|
uint32_t bl_start; /* Bootloader start addr */
|
|
uint32_t bl_end; /* Bootloader end addr */
|
|
uint8_t ecc_parity[42]; /* ECC parity of this header */
|
|
};
|
|
|
|
uint8_t data[0x8E];
|
|
};
|
|
|
|
/* HSM2.0 BROM Header for NAND */
|
|
union hsm20_nand_boot_header {
|
|
struct {
|
|
char id[8];
|
|
uint32_t version; /* Header version */
|
|
uint32_t config; /* Header config */
|
|
uint32_t sector_size; /* ECC step size */
|
|
uint32_t fdm_size; /* User OOB size of a step */
|
|
uint32_t fdm_ecc_size; /* ECC parity size of a step */
|
|
uint32_t lbs;
|
|
uint32_t page_size; /* NAND page size */
|
|
uint32_t spare_size; /* NAND page spare size */
|
|
uint32_t page_per_block; /* Pages of one block */
|
|
uint32_t blocks; /* Total blocks of NAND chip */
|
|
uint32_t plane_sel_position; /* Plane bit position */
|
|
uint32_t pll; /* Value of pll reg */
|
|
uint32_t acccon; /* Value of access timing reg */
|
|
uint32_t strobe_sel; /* Value of DQS selection reg*/
|
|
uint32_t acccon1; /* Value of access timing reg */
|
|
uint32_t dqs_mux; /* Value of DQS mux reg */
|
|
uint32_t dqs_ctrl; /* Value of DQS control reg */
|
|
uint32_t delay_ctrl; /* Value of delay ctrl reg */
|
|
uint32_t latch_lat; /* Value of latch latency reg */
|
|
uint32_t sample_delay; /* Value of sample delay reg */
|
|
uint32_t driving; /* Value of driving reg */
|
|
uint32_t reserved;
|
|
uint32_t bl0_start; /* Bootloader start addr */
|
|
uint32_t bl0_end; /* Bootloader end addr */
|
|
uint32_t bl0_type; /* Bootloader type */
|
|
uint8_t bl_reserve[84];
|
|
uint8_t ecc_parity[42]; /* ECC parity of this header */
|
|
};
|
|
|
|
uint8_t data[0xEA];
|
|
};
|
|
|
|
/* SPIM BROM Header for SPI-NAND */
|
|
union spim_nand_boot_header {
|
|
struct {
|
|
char id[8];
|
|
uint32_t version; /* Header version */
|
|
uint32_t config; /* Header config */
|
|
uint32_t page_size; /* NAND page size */
|
|
uint32_t spare_size; /* NAND page spare size */
|
|
uint16_t page_per_block; /* Pages of one block */
|
|
uint16_t plane_sel_position; /* Plane bit position */
|
|
uint16_t reserve_reg;
|
|
uint16_t reserve_val;
|
|
uint16_t ecc_error; /* ECC error reg addr */
|
|
uint16_t ecc_mask; /* ECC error bit mask */
|
|
uint32_t bl_start; /* Bootloader start addr */
|
|
uint32_t bl_end; /* Bootloader end addr */
|
|
uint8_t ecc_parity[32]; /* ECC parity of this header */
|
|
uint32_t integrity_crc; /* CRC of this header */
|
|
};
|
|
|
|
uint8_t data[0x50];
|
|
};
|
|
|
|
enum nand_boot_header_type {
|
|
NAND_BOOT_AP_HEADER,
|
|
NAND_BOOT_HSM_HEADER,
|
|
NAND_BOOT_HSM20_HEADER,
|
|
NAND_BOOT_SPIM_HEADER
|
|
};
|
|
|
|
#define NAND_BOOT_NAME "BOOTLOADER!"
|
|
#define NAND_BOOT_VERSION "V006"
|
|
#define NAND_BOOT_ID "NFIINFO"
|
|
|
|
#define HSM_NAND_BOOT_NAME "NANDCFG!"
|
|
#define SPIM_NAND_BOOT_NAME "SPINAND!"
|
|
|
|
/* Find nand header data by name */
|
|
const struct nand_header_type *mtk_nand_header_find(const char *name);
|
|
|
|
/* Device header size using this nand header */
|
|
uint32_t mtk_nand_header_size(const struct nand_header_type *hdr_nand);
|
|
|
|
/* Get nand info from nand header (page size, spare size, ...) */
|
|
int mtk_nand_header_info(const void *ptr, struct nand_header_info *info);
|
|
|
|
/* Whether given header data is valid */
|
|
bool is_mtk_nand_header(const void *ptr);
|
|
|
|
/* Generate Device header using give nand header */
|
|
uint32_t mtk_nand_header_put(const struct nand_header_type *hdr_nand,
|
|
void *ptr);
|
|
|
|
#endif /* _MTK_NAND_HEADERS_H */
|