mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-23 21:29:39 +07:00
mtd: spi-nor: Split spi_nor_init_params()
Add functions to delimit what the chunks of code do: static void spi_nor_init_params() { spi_nor_info_init_params() spi_nor_manufacturer_init_params() spi_nor_sfdp_init_params() } Add descriptions to all methods. spi_nor_init_params() becomes of type void, as all its children return void. 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
22f2eaac3f
commit
1c1d8d98e1
@ -4186,7 +4186,34 @@ static void spi_nor_manufacturer_init_params(struct spi_nor *nor)
|
||||
nor->info->fixups->default_init(nor);
|
||||
}
|
||||
|
||||
static int spi_nor_init_params(struct spi_nor *nor)
|
||||
/**
|
||||
* spi_nor_sfdp_init_params() - Initialize the flash's parameters and settings
|
||||
* based on JESD216 SFDP standard.
|
||||
* @nor: pointer to a 'struct spi-nor'.
|
||||
*
|
||||
* The method has a roll-back mechanism: in case the SFDP parsing fails, the
|
||||
* legacy flash parameters and settings will be restored.
|
||||
*/
|
||||
static void spi_nor_sfdp_init_params(struct spi_nor *nor)
|
||||
{
|
||||
struct spi_nor_flash_parameter sfdp_params;
|
||||
|
||||
memcpy(&sfdp_params, &nor->params, sizeof(sfdp_params));
|
||||
|
||||
if (spi_nor_parse_sfdp(nor, &sfdp_params)) {
|
||||
nor->addr_width = 0;
|
||||
nor->flags &= ~SNOR_F_4B_OPCODES;
|
||||
} else {
|
||||
memcpy(&nor->params, &sfdp_params, sizeof(nor->params));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* spi_nor_info_init_params() - Initialize the flash's parameters and settings
|
||||
* based on nor->info data.
|
||||
* @nor: pointer to a 'struct spi-nor'.
|
||||
*/
|
||||
static void spi_nor_info_init_params(struct spi_nor *nor)
|
||||
{
|
||||
struct spi_nor_flash_parameter *params = &nor->params;
|
||||
struct spi_nor_erase_map *map = ¶ms->erase_map;
|
||||
@ -4260,25 +4287,43 @@ static int spi_nor_init_params(struct spi_nor *nor)
|
||||
spi_nor_set_erase_type(&map->erase_type[i], info->sector_size,
|
||||
SPINOR_OP_SE);
|
||||
spi_nor_init_uniform_erase_map(map, erase_mask, params->size);
|
||||
}
|
||||
|
||||
/**
|
||||
* spi_nor_init_params() - Initialize the flash's parameters and settings.
|
||||
* @nor: pointer to a 'struct spi-nor'.
|
||||
*
|
||||
* The flash parameters and settings are initialized based on a sequence of
|
||||
* calls that are ordered by priority:
|
||||
*
|
||||
* 1/ Default flash parameters initialization. The initializations are done
|
||||
* based on nor->info data:
|
||||
* spi_nor_info_init_params()
|
||||
*
|
||||
* which can be overwritten by:
|
||||
* 2/ Manufacturer flash parameters initialization. The initializations are
|
||||
* done based on MFR register, or when the decisions can not be done solely
|
||||
* based on MFR, by using specific flash_info tweeks, ->default_init():
|
||||
* spi_nor_manufacturer_init_params()
|
||||
*
|
||||
* which can be overwritten by:
|
||||
* 3/ SFDP flash parameters initialization. JESD216 SFDP is a standard and
|
||||
* should be more accurate that the above.
|
||||
* spi_nor_sfdp_init_params()
|
||||
*
|
||||
* Please note that there is a ->post_bfpt() fixup hook that can overwrite
|
||||
* the flash parameters and settings immediately after parsing the Basic
|
||||
* Flash Parameter Table.
|
||||
*/
|
||||
static void spi_nor_init_params(struct spi_nor *nor)
|
||||
{
|
||||
spi_nor_info_init_params(nor);
|
||||
|
||||
spi_nor_manufacturer_init_params(nor);
|
||||
|
||||
if ((info->flags & (SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ)) &&
|
||||
!(info->flags & SPI_NOR_SKIP_SFDP)) {
|
||||
struct spi_nor_flash_parameter sfdp_params;
|
||||
|
||||
memcpy(&sfdp_params, params, sizeof(sfdp_params));
|
||||
|
||||
if (spi_nor_parse_sfdp(nor, &sfdp_params)) {
|
||||
nor->addr_width = 0;
|
||||
nor->flags &= ~SNOR_F_4B_OPCODES;
|
||||
} else {
|
||||
memcpy(params, &sfdp_params, sizeof(*params));
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
if ((nor->info->flags & (SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ)) &&
|
||||
!(nor->info->flags & SPI_NOR_SKIP_SFDP))
|
||||
spi_nor_sfdp_init_params(nor);
|
||||
}
|
||||
|
||||
static int spi_nor_select_read(struct spi_nor *nor,
|
||||
@ -4670,10 +4715,8 @@ int spi_nor_scan(struct spi_nor *nor, const char *name,
|
||||
nor->info->flags & SPI_NOR_HAS_LOCK)
|
||||
nor->clear_sr_bp = spi_nor_clear_sr_bp;
|
||||
|
||||
/* Parse the Serial Flash Discoverable Parameters table. */
|
||||
ret = spi_nor_init_params(nor);
|
||||
if (ret)
|
||||
return ret;
|
||||
/* Init flash parameters based on flash_info struct and SFDP */
|
||||
spi_nor_init_params(nor);
|
||||
|
||||
if (!mtd->name)
|
||||
mtd->name = dev_name(dev);
|
||||
|
Loading…
Reference in New Issue
Block a user