230 lines
6.6 KiB
C
230 lines
6.6 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0-only
|
||
|
*
|
||
|
* Copyright (C) 2020-2021 Intel Corporation.
|
||
|
*/
|
||
|
|
||
|
#ifndef _IOSM_IPC_FLASH_H
|
||
|
#define _IOSM_IPC_FLASH_H
|
||
|
|
||
|
/* Buffer size used to read the fls image */
|
||
|
#define IOSM_FLS_BUF_SIZE 0x00100000
|
||
|
/* Full erase start address */
|
||
|
#define IOSM_ERASE_START_ADDR 0x00000000
|
||
|
/* Erase length for NAND flash */
|
||
|
#define IOSM_ERASE_LEN 0xFFFFFFFF
|
||
|
/* EBL response Header size */
|
||
|
#define IOSM_EBL_HEAD_SIZE 8
|
||
|
/* EBL payload size */
|
||
|
#define IOSM_EBL_W_PAYL_SIZE 2048
|
||
|
/* Total EBL pack size */
|
||
|
#define IOSM_EBL_W_PACK_SIZE (IOSM_EBL_HEAD_SIZE + IOSM_EBL_W_PAYL_SIZE)
|
||
|
/* EBL payload size */
|
||
|
#define IOSM_EBL_DW_PAYL_SIZE 16384
|
||
|
/* Total EBL pack size */
|
||
|
#define IOSM_EBL_DW_PACK_SIZE (IOSM_EBL_HEAD_SIZE + IOSM_EBL_DW_PAYL_SIZE)
|
||
|
/* EBL name size */
|
||
|
#define IOSM_EBL_NAME 32
|
||
|
/* Maximum supported error types */
|
||
|
#define IOSM_MAX_ERRORS 8
|
||
|
/* Read size for RPSI/EBL response */
|
||
|
#define IOSM_READ_SIZE 2
|
||
|
/* Link establishment response ack size */
|
||
|
#define IOSM_LER_ACK_SIZE 2
|
||
|
/* PSI ACK len */
|
||
|
#define IOSM_PSI_ACK 8
|
||
|
/* SWID capability for packed swid type */
|
||
|
#define IOSM_EXT_CAP_SWID_OOS_PACK 0x02
|
||
|
/* EBL error response buffer */
|
||
|
#define IOSM_EBL_RSP_BUFF 0x0041
|
||
|
/* SWID string length */
|
||
|
#define IOSM_SWID_STR 64
|
||
|
/* Load EBL command size */
|
||
|
#define IOSM_RPSI_LOAD_SIZE 0
|
||
|
/* EBL payload checksum */
|
||
|
#define IOSM_EBL_CKSM 0x0000FFFF
|
||
|
/* SWID msg len and argument */
|
||
|
#define IOSM_MSG_LEN_ARG 0
|
||
|
/* Data to be sent to modem */
|
||
|
#define IOSM_MDM_SEND_DATA 0x0000
|
||
|
/* Data received from modem as part of erase check */
|
||
|
#define IOSM_MDM_ERASE_RSP 0x0001
|
||
|
/* Bit shift to calculate Checksum */
|
||
|
#define IOSM_EBL_PAYL_SHIFT 16
|
||
|
/* Flag To be set */
|
||
|
#define IOSM_SET_FLAG 1
|
||
|
/* Set flash erase check timeout to 100 msec */
|
||
|
#define IOSM_FLASH_ERASE_CHECK_TIMEOUT 100
|
||
|
/* Set flash erase check interval to 20 msec */
|
||
|
#define IOSM_FLASH_ERASE_CHECK_INTERVAL 20
|
||
|
/* Link establishment response ack size */
|
||
|
#define IOSM_LER_RSP_SIZE 60
|
||
|
|
||
|
/**
|
||
|
* enum iosm_flash_package_type - Enum for the flashing operations
|
||
|
* @FLASH_SET_PROT_CONF: Write EBL capabilities
|
||
|
* @FLASH_SEC_START: Start writing the secpack
|
||
|
* @FLASH_SEC_END: Validate secpack end
|
||
|
* @FLASH_SET_ADDRESS: Set the address for flashing
|
||
|
* @FLASH_ERASE_START: Start erase before flashing
|
||
|
* @FLASH_ERASE_CHECK: Validate the erase functionality
|
||
|
* @FLASH_OOS_CONTROL: Retrieve data based on oos actions
|
||
|
* @FLASH_OOS_DATA_READ: Read data from EBL
|
||
|
* @FLASH_WRITE_IMAGE_RAW: Write the raw image to flash
|
||
|
*/
|
||
|
enum iosm_flash_package_type {
|
||
|
FLASH_SET_PROT_CONF = 0x0086,
|
||
|
FLASH_SEC_START = 0x0204,
|
||
|
FLASH_SEC_END,
|
||
|
FLASH_SET_ADDRESS = 0x0802,
|
||
|
FLASH_ERASE_START = 0x0805,
|
||
|
FLASH_ERASE_CHECK,
|
||
|
FLASH_OOS_CONTROL = 0x080C,
|
||
|
FLASH_OOS_DATA_READ = 0x080E,
|
||
|
FLASH_WRITE_IMAGE_RAW,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum iosm_out_of_session_action - Actions possible over the
|
||
|
* OutOfSession command interface
|
||
|
* @FLASH_OOSC_ACTION_READ: Read data according to its type
|
||
|
* @FLASH_OOSC_ACTION_ERASE: Erase data according to its type
|
||
|
*/
|
||
|
enum iosm_out_of_session_action {
|
||
|
FLASH_OOSC_ACTION_READ = 2,
|
||
|
FLASH_OOSC_ACTION_ERASE = 3,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum iosm_out_of_session_type - Data types that can be handled over the
|
||
|
* Out Of Session command Interface
|
||
|
* @FLASH_OOSC_TYPE_ALL_FLASH: The whole flash area
|
||
|
* @FLASH_OOSC_TYPE_SWID_TABLE: Read the swid table from the target
|
||
|
*/
|
||
|
enum iosm_out_of_session_type {
|
||
|
FLASH_OOSC_TYPE_ALL_FLASH = 8,
|
||
|
FLASH_OOSC_TYPE_SWID_TABLE = 16,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum iosm_ebl_caps - EBL capability settings
|
||
|
* @IOSM_CAP_NOT_ENHANCED: If capability not supported
|
||
|
* @IOSM_CAP_USE_EXT_CAP: To be set if extended capability is set
|
||
|
* @IOSM_EXT_CAP_ERASE_ALL: Set Erase all capability
|
||
|
* @IOSM_EXT_CAP_COMMIT_ALL: Set the commit all capability
|
||
|
*/
|
||
|
enum iosm_ebl_caps {
|
||
|
IOSM_CAP_NOT_ENHANCED = 0x00,
|
||
|
IOSM_CAP_USE_EXT_CAP = 0x01,
|
||
|
IOSM_EXT_CAP_ERASE_ALL = 0x08,
|
||
|
IOSM_EXT_CAP_COMMIT_ALL = 0x20,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum iosm_ebl_rsp - EBL response field
|
||
|
* @EBL_CAPS_FLAG: EBL capability flag
|
||
|
* @EBL_SKIP_ERASE: EBL skip erase flag
|
||
|
* @EBL_SKIP_CRC: EBL skip wr_pack crc
|
||
|
* @EBL_EXT_CAPS_HANDLED: EBL extended capability handled flag
|
||
|
* @EBL_OOS_CONFIG: EBL oos configuration
|
||
|
* @EBL_RSP_SW_INFO_VER: EBL SW info version
|
||
|
*/
|
||
|
enum iosm_ebl_rsp {
|
||
|
EBL_CAPS_FLAG = 50,
|
||
|
EBL_SKIP_ERASE = 54,
|
||
|
EBL_SKIP_CRC = 55,
|
||
|
EBL_EXT_CAPS_HANDLED = 57,
|
||
|
EBL_OOS_CONFIG = 64,
|
||
|
EBL_RSP_SW_INFO_VER = 70,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* enum iosm_mdm_send_recv_data - Data to send to modem
|
||
|
* @IOSM_MDM_SEND_2: Send 2 bytes of payload
|
||
|
* @IOSM_MDM_SEND_4: Send 4 bytes of payload
|
||
|
* @IOSM_MDM_SEND_8: Send 8 bytes of payload
|
||
|
* @IOSM_MDM_SEND_16: Send 16 bytes of payload
|
||
|
*/
|
||
|
enum iosm_mdm_send_recv_data {
|
||
|
IOSM_MDM_SEND_2 = 2,
|
||
|
IOSM_MDM_SEND_4 = 4,
|
||
|
IOSM_MDM_SEND_8 = 8,
|
||
|
IOSM_MDM_SEND_16 = 16,
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* struct iosm_ebl_one_error - Structure containing error details
|
||
|
* @error_class: Error type- standard, security and text error
|
||
|
* @error_code: Specific error from error type
|
||
|
*/
|
||
|
struct iosm_ebl_one_error {
|
||
|
u16 error_class;
|
||
|
u16 error_code;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* struct iosm_ebl_error- Structure with max error type supported
|
||
|
* @error: Array of one_error structure with max errors
|
||
|
*/
|
||
|
struct iosm_ebl_error {
|
||
|
struct iosm_ebl_one_error error[IOSM_MAX_ERRORS];
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* struct iosm_swid_table - SWID table data for modem
|
||
|
* @number_of_data_sets: Number of swid types
|
||
|
* @sw_id_type: SWID type - SWID
|
||
|
* @sw_id_val: SWID value
|
||
|
* @rf_engine_id_type: RF engine ID type - RF_ENGINE_ID
|
||
|
* @rf_engine_id_val: RF engine ID value
|
||
|
*/
|
||
|
struct iosm_swid_table {
|
||
|
u32 number_of_data_sets;
|
||
|
char sw_id_type[IOSM_EBL_NAME];
|
||
|
u32 sw_id_val;
|
||
|
char rf_engine_id_type[IOSM_EBL_NAME];
|
||
|
u32 rf_engine_id_val;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* struct iosm_flash_msg_control - Data sent to modem
|
||
|
* @action: Action to be performed
|
||
|
* @type: Type of action
|
||
|
* @length: Length of the action
|
||
|
* @arguments: Argument value sent to modem
|
||
|
*/
|
||
|
struct iosm_flash_msg_control {
|
||
|
__le32 action;
|
||
|
__le32 type;
|
||
|
__le32 length;
|
||
|
__le32 arguments;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* struct iosm_flash_data - Header Data to be sent to modem
|
||
|
* @checksum: Checksum value calculated for the payload data
|
||
|
* @pack_id: Flash Action type
|
||
|
* @msg_length: Payload length
|
||
|
*/
|
||
|
struct iosm_flash_data {
|
||
|
__le16 checksum;
|
||
|
__le16 pack_id;
|
||
|
__le32 msg_length;
|
||
|
};
|
||
|
|
||
|
int ipc_flash_boot_psi(struct iosm_devlink *ipc_devlink,
|
||
|
const struct firmware *fw);
|
||
|
|
||
|
int ipc_flash_boot_ebl(struct iosm_devlink *ipc_devlink,
|
||
|
const struct firmware *fw);
|
||
|
|
||
|
int ipc_flash_boot_set_capabilities(struct iosm_devlink *ipc_devlink,
|
||
|
u8 *mdm_rsp);
|
||
|
|
||
|
int ipc_flash_link_establish(struct iosm_imem *ipc_imem);
|
||
|
|
||
|
int ipc_flash_read_swid(struct iosm_devlink *ipc_devlink, u8 *mdm_rsp);
|
||
|
|
||
|
int ipc_flash_send_fls(struct iosm_devlink *ipc_devlink,
|
||
|
const struct firmware *fw, u8 *mdm_rsp);
|
||
|
#endif
|