mirror of https://gitee.com/openkylin/linux.git
mtd: spi-nor: Move condition to avoid a NULL check
When the controller is not under the SPI-MEM interface it may implement the optional controller_ops->erase() method. nor->spimem and nor->controller_ops are mutually exclusive. Move the nor->controller_ops->erase != NULL check as an 'else if' case to nor->spimem, in order to avoid the nor->controller_ops != NULL check. Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Tudor Ambarus <tudor.ambarus@microchip.com> Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com>
This commit is contained in:
parent
ac82229d4e
commit
9326b4e078
|
@ -1367,9 +1367,6 @@ static int spi_nor_erase_sector(struct spi_nor *nor, u32 addr)
|
|||
|
||||
addr = spi_nor_convert_addr(nor, addr);
|
||||
|
||||
if (nor->controller_ops && nor->controller_ops->erase)
|
||||
return nor->controller_ops->erase(nor, addr);
|
||||
|
||||
if (nor->spimem) {
|
||||
struct spi_mem_op op =
|
||||
SPI_MEM_OP(SPI_MEM_OP_CMD(nor->erase_opcode, 1),
|
||||
|
@ -1378,6 +1375,8 @@ static int spi_nor_erase_sector(struct spi_nor *nor, u32 addr)
|
|||
SPI_MEM_OP_NO_DATA);
|
||||
|
||||
return spi_mem_exec_op(nor->spimem, &op);
|
||||
} else if (nor->controller_ops->erase) {
|
||||
return nor->controller_ops->erase(nor, addr);
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in New Issue