pinebuds/platform/hal/hal_norflash.h

186 lines
7.8 KiB
C

/***************************************************************************
*
* Copyright 2015-2019 BES.
* All rights reserved. All unpublished rights reserved.
*
* No part of this work may be used or reproduced in any form or by any
* means, or stored in a database or retrieval system, without prior written
* permission of BES.
*
* Use of this work is governed by a license granted by BES.
* This work contains confidential and proprietary information of
* BES. which is protected by copyright, trade secret,
* trademark and other intellectual property rights.
*
****************************************************************************/
#ifndef NORFLASH_HAL_H
#define NORFLASH_HAL_H
#ifdef __cplusplus
extern "C" {
#endif
#include "plat_types.h"
#include "hal_cmu.h"
#define HAL_NORFLASH_DEVICE_ID_LEN 3
#define HAL_NORFLASH_UNIQUE_ID_LEN 16
enum HAL_NORFLASH_ID_T {
HAL_NORFLASH_ID_0 = 0,
HAL_NORFLASH_ID_NUM,
};
enum HAL_NORFLASH_RET_T {
HAL_NORFLASH_OK,
HAL_NORFLASH_SUSPENDED,
HAL_NORFLASH_ERR,
HAL_NORFLASH_BAD_ID,
HAL_NORFLASH_BAD_DIV,
HAL_NORFLASH_BAD_CALIB_ID,
HAL_NORFLASH_BAD_CFG,
HAL_NORFLASH_BAD_OP,
HAL_NORFLASH_BAD_CALIB_MAGIC,
HAL_NORFLASH_BAD_ADDR,
HAL_NORFLASH_BAD_LEN,
HAL_NORFLASH_NOT_OPENED,
HAL_NORFLASH_CFG_NULL,
};
enum HAL_NORFLASH_SPEED {
HAL_NORFLASH_SPEED_13M = 13000000,
HAL_NORFLASH_SPEED_26M = 26000000,
HAL_NORFLASH_SPEED_52M = 52000000,
HAL_NORFLASH_SPEED_78M = 78000000,
HAL_NORFLASH_SPEED_104M = 104000000,
HAL_NORFLASH_SPEED_130M = 130000000,
HAL_NORFLASH_SPEED_156M = 156000000,
HAL_NORFLASH_SPEED_182M = 182000000,
HAL_NORFLASH_SPEED_208M = 208000000,
HAL_NORFLASH_SPEED_234M = 234000000,
};
enum HAL_NORFLASH_OP_MODE {
// Different groups can be used together, different flash-device may support different option(s)
// (1) basic read mode
/* standard spi mode */
HAL_NORFLASH_OP_MODE_STAND_SPI = 0x1,
/* fast spi mode*/
HAL_NORFLASH_OP_MODE_FAST_SPI = 0x2,
/* dual mode */
HAL_NORFLASH_OP_MODE_DUAL_OUTPUT = 0x4,
/* dual mode */
HAL_NORFLASH_OP_MODE_DUAL_IO = 0x8,
/* quad mode */
HAL_NORFLASH_OP_MODE_QUAD_OUTPUT = 0x10,
/* quad mode */
HAL_NORFLASH_OP_MODE_QUAD_IO = 0x20,
// (2) extend read mode
// read accelerate (no cmd bettween read operation) :
// may need Dual or Quad Mode
HAL_NORFLASH_OP_MODE_CONTINUOUS_READ = 0x40,
// read high performance mode
HAL_NORFLASH_OP_MODE_HIGH_PERFORMANCE = 0x80,
// read wrap mode
HAL_NORFLASH_OP_MODE_READ_WRAP = 0x100,
// (3) program mode.
// page program mode
HAL_NORFLASH_OP_MODE_PAGE_PROGRAM = 0x200,
// dual program mode
HAL_NORFLASH_OP_MODE_DUAL_PAGE_PROGRAM = 0x400,
// quad program mode
HAL_NORFLASH_OP_MODE_QUAD_PAGE_PROGRAM = 0x800,
// (4) advanced features
// suspend and resume
HAL_NORFLASH_OP_MODE_SUSPEND = 0x1000,
// erase in standard spi mode
HAL_NORFLASH_OP_MODE_ERASE_IN_STD = 0x2000,
HAL_NORFLASH_OP_MODE_RESERVED = 0xFFFFFFFF,
};
struct HAL_NORFLASH_CONFIG_T {
uint32_t source_clk;
uint32_t speed;
enum HAL_NORFLASH_OP_MODE mode;
/* internal use : can be config if need to (useful for rom) */
uint8_t override_config:1;
uint8_t neg_phase:1;
uint8_t pos_neg:1;
uint8_t cmdquad:1;
uint8_t samdly:3;
uint8_t div; /* least 2 */
uint8_t dualmode:1;
uint8_t holdpin:1;
uint8_t wprpin:1;
uint8_t quadmode:1;
uint8_t spiruen:3;
uint8_t spirden:3;
uint8_t dualiocmd;
uint8_t rdcmd;
uint8_t frdcmd;
uint8_t qrdcmd; /* quad io cmd */
#if defined(CHIP_BEST1400) || defined(CHIP_BEST1402)
uint8_t dec_enable; /* 1: enable decoder, 0: disable decoder */
uint8_t dec_idx; /* decoder key index ,from 0 to 3 */
uint32_t dec_addr; /* start address where to decode */
uint32_t dec_size; /* bytes number will be decoded */
#endif
};
/* hal api */
void hal_norflash_set_freq(enum HAL_CMU_FREQ_T freq);
const struct HAL_NORFLASH_CONFIG_T *hal_norflash_get_init_config(void);
enum HAL_NORFLASH_RET_T hal_norflash_init(void);
enum HAL_NORFLASH_RET_T hal_norflash_deinit(void);
enum HAL_NORFLASH_RET_T hal_norflash_open(enum HAL_NORFLASH_ID_T id, const struct HAL_NORFLASH_CONFIG_T *cfg);
enum HAL_NORFLASH_RET_T hal_norflash_reopen(enum HAL_NORFLASH_ID_T id, const struct HAL_NORFLASH_CONFIG_T *cfg);
enum HAL_NORFLASH_RET_T hal_norflash_apply_config(enum HAL_NORFLASH_ID_T id, const struct HAL_NORFLASH_CONFIG_T *cfg, uint32_t timing_idx);
uint32_t hal_norflash_get_timing_index(enum HAL_NORFLASH_ID_T id);
void hal_norflash_show_calib_result(void);
enum HAL_CMU_FREQ_T hal_norflash_clk_to_cmu_freq(uint32_t clk);
enum HAL_NORFLASH_RET_T hal_norflash_get_size(enum HAL_NORFLASH_ID_T id, uint32_t *total_size, uint32_t *block_size, uint32_t *sector_size, uint32_t *page_size);
enum HAL_NORFLASH_RET_T hal_norflash_get_boundary(enum HAL_NORFLASH_ID_T id, uint32_t address, uint32_t* block_boundary, uint32_t* sector_boundary);
enum HAL_NORFLASH_RET_T hal_norflash_get_id(enum HAL_NORFLASH_ID_T id, uint8_t *value, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_get_unique_id(enum HAL_NORFLASH_ID_T id, uint8_t *value, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_enable_protection(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_disable_protection(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_erase_chip(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_erase_suspend(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint32_t len, int suspend);
enum HAL_NORFLASH_RET_T hal_norflash_erase(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_erase_resume(enum HAL_NORFLASH_ID_T id, int suspend);
enum HAL_NORFLASH_RET_T hal_norflash_write_suspend(enum HAL_NORFLASH_ID_T id, uint32_t start_address, const uint8_t *buffer, uint32_t len, int suspend);
enum HAL_NORFLASH_RET_T hal_norflash_write(enum HAL_NORFLASH_ID_T id, uint32_t start_address, const uint8_t *buffer, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_write_resume(enum HAL_NORFLASH_ID_T id, int suspend);
enum HAL_NORFLASH_RET_T hal_norflash_suspend_check_irq(enum HAL_NORFLASH_ID_T id, uint32_t irq_num);
enum HAL_NORFLASH_RET_T hal_norflash_read(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint8_t *buffer, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_close(enum HAL_NORFLASH_ID_T id);
void hal_norflash_sleep(enum HAL_NORFLASH_ID_T id);
void hal_norflash_wakeup(enum HAL_NORFLASH_ID_T id);
int hal_norflash_busy(void);
uint32_t hal_norflash_get_flash_total_size(enum HAL_NORFLASH_ID_T id);
int hal_norflash_opened(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_get_open_state(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_security_register_lock(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_security_register_erase(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_security_register_write(enum HAL_NORFLASH_ID_T id, uint32_t start_address, const uint8_t *buffer, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_security_register_read(enum HAL_NORFLASH_ID_T id, uint32_t start_address, uint8_t *buffer, uint32_t len);
enum HAL_NORFLASH_RET_T hal_norflash_enable_remap(enum HAL_NORFLASH_ID_T id, uint32_t addr, uint32_t len, uint32_t offset);
enum HAL_NORFLASH_RET_T hal_norflash_disable_remap(enum HAL_NORFLASH_ID_T id);
enum HAL_NORFLASH_RET_T hal_norflash_re_enable_remap(enum HAL_NORFLASH_ID_T id);
int hal_norflash_get_remap_status(enum HAL_NORFLASH_ID_T id);
#ifdef __cplusplus
}
#endif
#endif /* NORFLASH_HAL_H */