mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-06-29 10:01:25 +00:00
mtd: spi-nor: Regroup flash parameter and settings
The scope is to move all [FLASH-SPECIFIC] parameters and settings from 'struct spi_nor' to 'struct spi_nor_flash_parameter'. 'struct spi_nor_flash_parameter' describes the hardware capabilities and associated settings of the SPI NOR flash memory. It includes legacy flash parameters and settings that can be overwritten by the spi_nor_fixups hooks, or dynamically when parsing the JESD216 Serial Flash Discoverable Parameters (SFDP) tables. All SFDP params and settings will fit inside 'struct spi_nor_flash_parameter'. Move spi_nor_hwcaps related code to avoid forward declarations. Add a forward declaration that we can't avoid: 'struct spi_nor' will be used in 'struct spi_nor_flash_parameter'. Signed-off-by: Tudor Ambarus <tudor.ambarus@microchip.com> Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com> Reviewed-by: Vignesh Raghavendra <vigneshr@ti.com>
This commit is contained in:
parent
92b6d38f1a
commit
47599127a2
2 changed files with 218 additions and 194 deletions
|
@ -40,71 +40,6 @@
|
||||||
#define SPI_NOR_MAX_ID_LEN 6
|
#define SPI_NOR_MAX_ID_LEN 6
|
||||||
#define SPI_NOR_MAX_ADDR_WIDTH 4
|
#define SPI_NOR_MAX_ADDR_WIDTH 4
|
||||||
|
|
||||||
struct spi_nor_read_command {
|
|
||||||
u8 num_mode_clocks;
|
|
||||||
u8 num_wait_states;
|
|
||||||
u8 opcode;
|
|
||||||
enum spi_nor_protocol proto;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct spi_nor_pp_command {
|
|
||||||
u8 opcode;
|
|
||||||
enum spi_nor_protocol proto;
|
|
||||||
};
|
|
||||||
|
|
||||||
enum spi_nor_read_command_index {
|
|
||||||
SNOR_CMD_READ,
|
|
||||||
SNOR_CMD_READ_FAST,
|
|
||||||
SNOR_CMD_READ_1_1_1_DTR,
|
|
||||||
|
|
||||||
/* Dual SPI */
|
|
||||||
SNOR_CMD_READ_1_1_2,
|
|
||||||
SNOR_CMD_READ_1_2_2,
|
|
||||||
SNOR_CMD_READ_2_2_2,
|
|
||||||
SNOR_CMD_READ_1_2_2_DTR,
|
|
||||||
|
|
||||||
/* Quad SPI */
|
|
||||||
SNOR_CMD_READ_1_1_4,
|
|
||||||
SNOR_CMD_READ_1_4_4,
|
|
||||||
SNOR_CMD_READ_4_4_4,
|
|
||||||
SNOR_CMD_READ_1_4_4_DTR,
|
|
||||||
|
|
||||||
/* Octal SPI */
|
|
||||||
SNOR_CMD_READ_1_1_8,
|
|
||||||
SNOR_CMD_READ_1_8_8,
|
|
||||||
SNOR_CMD_READ_8_8_8,
|
|
||||||
SNOR_CMD_READ_1_8_8_DTR,
|
|
||||||
|
|
||||||
SNOR_CMD_READ_MAX
|
|
||||||
};
|
|
||||||
|
|
||||||
enum spi_nor_pp_command_index {
|
|
||||||
SNOR_CMD_PP,
|
|
||||||
|
|
||||||
/* Quad SPI */
|
|
||||||
SNOR_CMD_PP_1_1_4,
|
|
||||||
SNOR_CMD_PP_1_4_4,
|
|
||||||
SNOR_CMD_PP_4_4_4,
|
|
||||||
|
|
||||||
/* Octal SPI */
|
|
||||||
SNOR_CMD_PP_1_1_8,
|
|
||||||
SNOR_CMD_PP_1_8_8,
|
|
||||||
SNOR_CMD_PP_8_8_8,
|
|
||||||
|
|
||||||
SNOR_CMD_PP_MAX
|
|
||||||
};
|
|
||||||
|
|
||||||
struct spi_nor_flash_parameter {
|
|
||||||
u64 size;
|
|
||||||
u32 page_size;
|
|
||||||
|
|
||||||
struct spi_nor_hwcaps hwcaps;
|
|
||||||
struct spi_nor_read_command reads[SNOR_CMD_READ_MAX];
|
|
||||||
struct spi_nor_pp_command page_programs[SNOR_CMD_PP_MAX];
|
|
||||||
|
|
||||||
int (*quad_enable)(struct spi_nor *nor);
|
|
||||||
};
|
|
||||||
|
|
||||||
struct sfdp_parameter_header {
|
struct sfdp_parameter_header {
|
||||||
u8 id_lsb;
|
u8 id_lsb;
|
||||||
u8 minor;
|
u8 minor;
|
||||||
|
|
|
@ -333,135 +333,6 @@ struct spi_nor_erase_map {
|
||||||
u8 uniform_erase_type;
|
u8 uniform_erase_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* struct flash_info - Forward declaration of a structure used internally by
|
|
||||||
* spi_nor_scan()
|
|
||||||
*/
|
|
||||||
struct flash_info;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* struct spi_nor - Structure for defining a the SPI NOR layer
|
|
||||||
* @mtd: point to a mtd_info structure
|
|
||||||
* @lock: the lock for the read/write/erase/lock/unlock operations
|
|
||||||
* @dev: point to a spi device, or a spi nor controller device.
|
|
||||||
* @spimem: point to the spi mem device
|
|
||||||
* @bouncebuf: bounce buffer used when the buffer passed by the MTD
|
|
||||||
* layer is not DMA-able
|
|
||||||
* @bouncebuf_size: size of the bounce buffer
|
|
||||||
* @info: spi-nor part JDEC MFR id and other info
|
|
||||||
* @page_size: the page size of the SPI NOR
|
|
||||||
* @addr_width: number of address bytes
|
|
||||||
* @erase_opcode: the opcode for erasing a sector
|
|
||||||
* @read_opcode: the read opcode
|
|
||||||
* @read_dummy: the dummy needed by the read operation
|
|
||||||
* @program_opcode: the program opcode
|
|
||||||
* @sst_write_second: used by the SST write operation
|
|
||||||
* @flags: flag options for the current SPI-NOR (SNOR_F_*)
|
|
||||||
* @read_proto: the SPI protocol for read operations
|
|
||||||
* @write_proto: the SPI protocol for write operations
|
|
||||||
* @reg_proto the SPI protocol for read_reg/write_reg/erase operations
|
|
||||||
* @erase_map: the erase map of the SPI NOR
|
|
||||||
* @prepare: [OPTIONAL] do some preparations for the
|
|
||||||
* read/write/erase/lock/unlock operations
|
|
||||||
* @unprepare: [OPTIONAL] do some post work after the
|
|
||||||
* read/write/erase/lock/unlock operations
|
|
||||||
* @read_reg: [DRIVER-SPECIFIC] read out the register
|
|
||||||
* @write_reg: [DRIVER-SPECIFIC] write data to the register
|
|
||||||
* @read: [DRIVER-SPECIFIC] read data from the SPI NOR
|
|
||||||
* @write: [DRIVER-SPECIFIC] write data to the SPI NOR
|
|
||||||
* @erase: [DRIVER-SPECIFIC] erase a sector of the SPI NOR
|
|
||||||
* at the offset @offs; if not provided by the driver,
|
|
||||||
* spi-nor will send the erase opcode via write_reg()
|
|
||||||
* @flash_lock: [FLASH-SPECIFIC] lock a region of the SPI NOR
|
|
||||||
* @flash_unlock: [FLASH-SPECIFIC] unlock a region of the SPI NOR
|
|
||||||
* @flash_is_locked: [FLASH-SPECIFIC] check if a region of the SPI NOR is
|
|
||||||
* completely locked
|
|
||||||
* @quad_enable: [FLASH-SPECIFIC] enables SPI NOR quad mode
|
|
||||||
* @clear_sr_bp: [FLASH-SPECIFIC] clears the Block Protection Bits from
|
|
||||||
* the SPI NOR Status Register.
|
|
||||||
* @priv: the private data
|
|
||||||
*/
|
|
||||||
struct spi_nor {
|
|
||||||
struct mtd_info mtd;
|
|
||||||
struct mutex lock;
|
|
||||||
struct device *dev;
|
|
||||||
struct spi_mem *spimem;
|
|
||||||
u8 *bouncebuf;
|
|
||||||
size_t bouncebuf_size;
|
|
||||||
const struct flash_info *info;
|
|
||||||
u32 page_size;
|
|
||||||
u8 addr_width;
|
|
||||||
u8 erase_opcode;
|
|
||||||
u8 read_opcode;
|
|
||||||
u8 read_dummy;
|
|
||||||
u8 program_opcode;
|
|
||||||
enum spi_nor_protocol read_proto;
|
|
||||||
enum spi_nor_protocol write_proto;
|
|
||||||
enum spi_nor_protocol reg_proto;
|
|
||||||
bool sst_write_second;
|
|
||||||
u32 flags;
|
|
||||||
struct spi_nor_erase_map erase_map;
|
|
||||||
|
|
||||||
int (*prepare)(struct spi_nor *nor, enum spi_nor_ops ops);
|
|
||||||
void (*unprepare)(struct spi_nor *nor, enum spi_nor_ops ops);
|
|
||||||
int (*read_reg)(struct spi_nor *nor, u8 opcode, u8 *buf, int len);
|
|
||||||
int (*write_reg)(struct spi_nor *nor, u8 opcode, u8 *buf, int len);
|
|
||||||
|
|
||||||
ssize_t (*read)(struct spi_nor *nor, loff_t from,
|
|
||||||
size_t len, u_char *read_buf);
|
|
||||||
ssize_t (*write)(struct spi_nor *nor, loff_t to,
|
|
||||||
size_t len, const u_char *write_buf);
|
|
||||||
int (*erase)(struct spi_nor *nor, loff_t offs);
|
|
||||||
|
|
||||||
int (*flash_lock)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
|
||||||
int (*flash_unlock)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
|
||||||
int (*flash_is_locked)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
|
||||||
int (*quad_enable)(struct spi_nor *nor);
|
|
||||||
int (*clear_sr_bp)(struct spi_nor *nor);
|
|
||||||
|
|
||||||
void *priv;
|
|
||||||
};
|
|
||||||
|
|
||||||
static u64 __maybe_unused
|
|
||||||
spi_nor_region_is_last(const struct spi_nor_erase_region *region)
|
|
||||||
{
|
|
||||||
return region->offset & SNOR_LAST_REGION;
|
|
||||||
}
|
|
||||||
|
|
||||||
static u64 __maybe_unused
|
|
||||||
spi_nor_region_end(const struct spi_nor_erase_region *region)
|
|
||||||
{
|
|
||||||
return (region->offset & ~SNOR_ERASE_FLAGS_MASK) + region->size;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __maybe_unused
|
|
||||||
spi_nor_region_mark_end(struct spi_nor_erase_region *region)
|
|
||||||
{
|
|
||||||
region->offset |= SNOR_LAST_REGION;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __maybe_unused
|
|
||||||
spi_nor_region_mark_overlay(struct spi_nor_erase_region *region)
|
|
||||||
{
|
|
||||||
region->offset |= SNOR_OVERLAID_REGION;
|
|
||||||
}
|
|
||||||
|
|
||||||
static bool __maybe_unused spi_nor_has_uniform_erase(const struct spi_nor *nor)
|
|
||||||
{
|
|
||||||
return !!nor->erase_map.uniform_erase_type;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void spi_nor_set_flash_node(struct spi_nor *nor,
|
|
||||||
struct device_node *np)
|
|
||||||
{
|
|
||||||
mtd_set_of_node(&nor->mtd, np);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline struct device_node *spi_nor_get_flash_node(struct spi_nor *nor)
|
|
||||||
{
|
|
||||||
return mtd_get_of_node(&nor->mtd);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct spi_nor_hwcaps - Structure for describing the hardware capabilies
|
* struct spi_nor_hwcaps - Structure for describing the hardware capabilies
|
||||||
* supported by the SPI controller (bus master).
|
* supported by the SPI controller (bus master).
|
||||||
|
@ -537,6 +408,224 @@ struct spi_nor_hwcaps {
|
||||||
#define SNOR_HWCAPS_ALL (SNOR_HWCAPS_READ_MASK | \
|
#define SNOR_HWCAPS_ALL (SNOR_HWCAPS_READ_MASK | \
|
||||||
SNOR_HWCAPS_PP_MASK)
|
SNOR_HWCAPS_PP_MASK)
|
||||||
|
|
||||||
|
struct spi_nor_read_command {
|
||||||
|
u8 num_mode_clocks;
|
||||||
|
u8 num_wait_states;
|
||||||
|
u8 opcode;
|
||||||
|
enum spi_nor_protocol proto;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct spi_nor_pp_command {
|
||||||
|
u8 opcode;
|
||||||
|
enum spi_nor_protocol proto;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum spi_nor_read_command_index {
|
||||||
|
SNOR_CMD_READ,
|
||||||
|
SNOR_CMD_READ_FAST,
|
||||||
|
SNOR_CMD_READ_1_1_1_DTR,
|
||||||
|
|
||||||
|
/* Dual SPI */
|
||||||
|
SNOR_CMD_READ_1_1_2,
|
||||||
|
SNOR_CMD_READ_1_2_2,
|
||||||
|
SNOR_CMD_READ_2_2_2,
|
||||||
|
SNOR_CMD_READ_1_2_2_DTR,
|
||||||
|
|
||||||
|
/* Quad SPI */
|
||||||
|
SNOR_CMD_READ_1_1_4,
|
||||||
|
SNOR_CMD_READ_1_4_4,
|
||||||
|
SNOR_CMD_READ_4_4_4,
|
||||||
|
SNOR_CMD_READ_1_4_4_DTR,
|
||||||
|
|
||||||
|
/* Octal SPI */
|
||||||
|
SNOR_CMD_READ_1_1_8,
|
||||||
|
SNOR_CMD_READ_1_8_8,
|
||||||
|
SNOR_CMD_READ_8_8_8,
|
||||||
|
SNOR_CMD_READ_1_8_8_DTR,
|
||||||
|
|
||||||
|
SNOR_CMD_READ_MAX
|
||||||
|
};
|
||||||
|
|
||||||
|
enum spi_nor_pp_command_index {
|
||||||
|
SNOR_CMD_PP,
|
||||||
|
|
||||||
|
/* Quad SPI */
|
||||||
|
SNOR_CMD_PP_1_1_4,
|
||||||
|
SNOR_CMD_PP_1_4_4,
|
||||||
|
SNOR_CMD_PP_4_4_4,
|
||||||
|
|
||||||
|
/* Octal SPI */
|
||||||
|
SNOR_CMD_PP_1_1_8,
|
||||||
|
SNOR_CMD_PP_1_8_8,
|
||||||
|
SNOR_CMD_PP_8_8_8,
|
||||||
|
|
||||||
|
SNOR_CMD_PP_MAX
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Forward declaration that will be used in 'struct spi_nor_flash_parameter' */
|
||||||
|
struct spi_nor;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct spi_nor_flash_parameter - SPI NOR flash parameters and settings.
|
||||||
|
* Includes legacy flash parameters and settings that can be overwritten
|
||||||
|
* by the spi_nor_fixups hooks, or dynamically when parsing the JESD216
|
||||||
|
* Serial Flash Discoverable Parameters (SFDP) tables.
|
||||||
|
*
|
||||||
|
* @size: the flash memory density in bytes.
|
||||||
|
* @page_size: the page size of the SPI NOR flash memory.
|
||||||
|
* @hwcaps: describes the read and page program hardware
|
||||||
|
* capabilities.
|
||||||
|
* @reads: read capabilities ordered by priority: the higher index
|
||||||
|
* in the array, the higher priority.
|
||||||
|
* @page_programs: page program capabilities ordered by priority: the
|
||||||
|
* higher index in the array, the higher priority.
|
||||||
|
* @quad_enable: enables SPI NOR quad mode.
|
||||||
|
*/
|
||||||
|
struct spi_nor_flash_parameter {
|
||||||
|
u64 size;
|
||||||
|
u32 page_size;
|
||||||
|
|
||||||
|
struct spi_nor_hwcaps hwcaps;
|
||||||
|
struct spi_nor_read_command reads[SNOR_CMD_READ_MAX];
|
||||||
|
struct spi_nor_pp_command page_programs[SNOR_CMD_PP_MAX];
|
||||||
|
|
||||||
|
int (*quad_enable)(struct spi_nor *nor);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct flash_info - Forward declaration of a structure used internally by
|
||||||
|
* spi_nor_scan()
|
||||||
|
*/
|
||||||
|
struct flash_info;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct spi_nor - Structure for defining a the SPI NOR layer
|
||||||
|
* @mtd: point to a mtd_info structure
|
||||||
|
* @lock: the lock for the read/write/erase/lock/unlock operations
|
||||||
|
* @dev: point to a spi device, or a spi nor controller device.
|
||||||
|
* @spimem: point to the spi mem device
|
||||||
|
* @bouncebuf: bounce buffer used when the buffer passed by the MTD
|
||||||
|
* layer is not DMA-able
|
||||||
|
* @bouncebuf_size: size of the bounce buffer
|
||||||
|
* @info: spi-nor part JDEC MFR id and other info
|
||||||
|
* @page_size: the page size of the SPI NOR
|
||||||
|
* @addr_width: number of address bytes
|
||||||
|
* @erase_opcode: the opcode for erasing a sector
|
||||||
|
* @read_opcode: the read opcode
|
||||||
|
* @read_dummy: the dummy needed by the read operation
|
||||||
|
* @program_opcode: the program opcode
|
||||||
|
* @sst_write_second: used by the SST write operation
|
||||||
|
* @flags: flag options for the current SPI-NOR (SNOR_F_*)
|
||||||
|
* @read_proto: the SPI protocol for read operations
|
||||||
|
* @write_proto: the SPI protocol for write operations
|
||||||
|
* @reg_proto the SPI protocol for read_reg/write_reg/erase operations
|
||||||
|
* @erase_map: the erase map of the SPI NOR
|
||||||
|
* @prepare: [OPTIONAL] do some preparations for the
|
||||||
|
* read/write/erase/lock/unlock operations
|
||||||
|
* @unprepare: [OPTIONAL] do some post work after the
|
||||||
|
* read/write/erase/lock/unlock operations
|
||||||
|
* @read_reg: [DRIVER-SPECIFIC] read out the register
|
||||||
|
* @write_reg: [DRIVER-SPECIFIC] write data to the register
|
||||||
|
* @read: [DRIVER-SPECIFIC] read data from the SPI NOR
|
||||||
|
* @write: [DRIVER-SPECIFIC] write data to the SPI NOR
|
||||||
|
* @erase: [DRIVER-SPECIFIC] erase a sector of the SPI NOR
|
||||||
|
* at the offset @offs; if not provided by the driver,
|
||||||
|
* spi-nor will send the erase opcode via write_reg()
|
||||||
|
* @flash_lock: [FLASH-SPECIFIC] lock a region of the SPI NOR
|
||||||
|
* @flash_unlock: [FLASH-SPECIFIC] unlock a region of the SPI NOR
|
||||||
|
* @flash_is_locked: [FLASH-SPECIFIC] check if a region of the SPI NOR is
|
||||||
|
* completely locked
|
||||||
|
* @quad_enable: [FLASH-SPECIFIC] enables SPI NOR quad mode
|
||||||
|
* @clear_sr_bp: [FLASH-SPECIFIC] clears the Block Protection Bits from
|
||||||
|
* the SPI NOR Status Register.
|
||||||
|
* @params: [FLASH-SPECIFIC] SPI-NOR flash parameters and settings.
|
||||||
|
* The structure includes legacy flash parameters and
|
||||||
|
* settings that can be overwritten by the spi_nor_fixups
|
||||||
|
* hooks, or dynamically when parsing the SFDP tables.
|
||||||
|
* @priv: the private data
|
||||||
|
*/
|
||||||
|
struct spi_nor {
|
||||||
|
struct mtd_info mtd;
|
||||||
|
struct mutex lock;
|
||||||
|
struct device *dev;
|
||||||
|
struct spi_mem *spimem;
|
||||||
|
u8 *bouncebuf;
|
||||||
|
size_t bouncebuf_size;
|
||||||
|
const struct flash_info *info;
|
||||||
|
u32 page_size;
|
||||||
|
u8 addr_width;
|
||||||
|
u8 erase_opcode;
|
||||||
|
u8 read_opcode;
|
||||||
|
u8 read_dummy;
|
||||||
|
u8 program_opcode;
|
||||||
|
enum spi_nor_protocol read_proto;
|
||||||
|
enum spi_nor_protocol write_proto;
|
||||||
|
enum spi_nor_protocol reg_proto;
|
||||||
|
bool sst_write_second;
|
||||||
|
u32 flags;
|
||||||
|
struct spi_nor_erase_map erase_map;
|
||||||
|
|
||||||
|
int (*prepare)(struct spi_nor *nor, enum spi_nor_ops ops);
|
||||||
|
void (*unprepare)(struct spi_nor *nor, enum spi_nor_ops ops);
|
||||||
|
int (*read_reg)(struct spi_nor *nor, u8 opcode, u8 *buf, int len);
|
||||||
|
int (*write_reg)(struct spi_nor *nor, u8 opcode, u8 *buf, int len);
|
||||||
|
|
||||||
|
ssize_t (*read)(struct spi_nor *nor, loff_t from,
|
||||||
|
size_t len, u_char *read_buf);
|
||||||
|
ssize_t (*write)(struct spi_nor *nor, loff_t to,
|
||||||
|
size_t len, const u_char *write_buf);
|
||||||
|
int (*erase)(struct spi_nor *nor, loff_t offs);
|
||||||
|
|
||||||
|
int (*flash_lock)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
||||||
|
int (*flash_unlock)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
||||||
|
int (*flash_is_locked)(struct spi_nor *nor, loff_t ofs, uint64_t len);
|
||||||
|
int (*quad_enable)(struct spi_nor *nor);
|
||||||
|
int (*clear_sr_bp)(struct spi_nor *nor);
|
||||||
|
struct spi_nor_flash_parameter params;
|
||||||
|
|
||||||
|
void *priv;
|
||||||
|
};
|
||||||
|
|
||||||
|
static u64 __maybe_unused
|
||||||
|
spi_nor_region_is_last(const struct spi_nor_erase_region *region)
|
||||||
|
{
|
||||||
|
return region->offset & SNOR_LAST_REGION;
|
||||||
|
}
|
||||||
|
|
||||||
|
static u64 __maybe_unused
|
||||||
|
spi_nor_region_end(const struct spi_nor_erase_region *region)
|
||||||
|
{
|
||||||
|
return (region->offset & ~SNOR_ERASE_FLAGS_MASK) + region->size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __maybe_unused
|
||||||
|
spi_nor_region_mark_end(struct spi_nor_erase_region *region)
|
||||||
|
{
|
||||||
|
region->offset |= SNOR_LAST_REGION;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __maybe_unused
|
||||||
|
spi_nor_region_mark_overlay(struct spi_nor_erase_region *region)
|
||||||
|
{
|
||||||
|
region->offset |= SNOR_OVERLAID_REGION;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool __maybe_unused spi_nor_has_uniform_erase(const struct spi_nor *nor)
|
||||||
|
{
|
||||||
|
return !!nor->erase_map.uniform_erase_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void spi_nor_set_flash_node(struct spi_nor *nor,
|
||||||
|
struct device_node *np)
|
||||||
|
{
|
||||||
|
mtd_set_of_node(&nor->mtd, np);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline struct device_node *spi_nor_get_flash_node(struct spi_nor *nor)
|
||||||
|
{
|
||||||
|
return mtd_get_of_node(&nor->mtd);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* spi_nor_scan() - scan the SPI NOR
|
* spi_nor_scan() - scan the SPI NOR
|
||||||
* @nor: the spi_nor structure
|
* @nor: the spi_nor structure
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue