diff options
| author | Marek Vasut <marek.vasut@gmail.com> | 2019-04-02 02:52:53 +0200 | 
|---|---|---|
| committer | Jagan Teki <jagan@amarulasolutions.com> | 2019-04-12 11:42:48 +0530 | 
| commit | f909ddb3e1770a5ef18606b46000e0d3eaf63b2e (patch) | |
| tree | 12e1bdaac619b8b6674b58804bf67e65e39c04dc | |
| parent | 40264c0ca89a6953e05e89b6abe491f4b6e4a149 (diff) | |
mtd: spi: Replace ad-hoc default implementation with spi_mem_op
Replace the ad-hoc erase operation implementation with a simple spi_mem_op
implementation of the same functionality. This is a minor optimization and
removal of the ad-hoc code.
This however also changes the behavior of the execution of the erase
opcode from two separate transfer requests to the SPI NOR driver to
one transfer request to the SPI NOR driver. The former was how U-Boot
behaved before the SPI NOR framework was imported and the later was
introduced by the SPI NOR framework. The former is more optimal, so
keep that.
Signed-off-by: Marek Vasut <marek.vasut+renesas@gmail.com>
Cc: Horatiu Vultur <horatiu.vultur@microchip.com>
Cc: Jagan Teki <jagan@openedev.com>
Cc: Simon Goldschmidt <simon.k.r.goldschmidt@gmail.com>
Cc: Stefan Roese <sr@denx.de>
Cc: Vignesh R <vigneshr@ti.com>
Tested-by: Ashish Kumar <Ashish.kumar@nxp.com>
| -rw-r--r-- | drivers/mtd/spi/spi-nor-core.c | 14 | 
1 files changed, 6 insertions, 8 deletions
| diff --git a/drivers/mtd/spi/spi-nor-core.c b/drivers/mtd/spi/spi-nor-core.c index b7f07338779..c4e2f6a08fa 100644 --- a/drivers/mtd/spi/spi-nor-core.c +++ b/drivers/mtd/spi/spi-nor-core.c @@ -524,8 +524,11 @@ static int read_bar(struct spi_nor *nor, const struct flash_info *info)   */  static int spi_nor_erase_sector(struct spi_nor *nor, u32 addr)  { -	u8 buf[SPI_NOR_MAX_ADDR_WIDTH]; -	int i; +	struct spi_mem_op op = +		SPI_MEM_OP(SPI_MEM_OP_CMD(nor->erase_opcode, 1), +			   SPI_MEM_OP_ADDR(nor->addr_width, addr, 1), +			   SPI_MEM_OP_NO_DUMMY, +			   SPI_MEM_OP_NO_DATA);  	if (nor->erase)  		return nor->erase(nor, addr); @@ -534,12 +537,7 @@ static int spi_nor_erase_sector(struct spi_nor *nor, u32 addr)  	 * Default implementation, if driver doesn't have a specialized HW  	 * control  	 */ -	for (i = nor->addr_width - 1; i >= 0; i--) { -		buf[i] = addr & 0xff; -		addr >>= 8; -	} - -	return nor->write_reg(nor, nor->erase_opcode, buf, nor->addr_width); +	return spi_mem_exec_op(nor->spi, &op);  }  /* | 
