drivers: flash: spi_nor: improve diagnostics/behavior of erase
Erase can only succeed if the address is sector-aligned, and the span to erase is an integer multiple of the sector size. Validate this before starting the process of erasing things. Signed-off-by: Peter Bigot <peter.bigot@nordicsemi.no>
This commit is contained in:
parent
8e2e7aee51
commit
f6cfdf79ba
1 changed files with 11 additions and 1 deletions
|
@ -385,11 +385,21 @@ static int spi_nor_erase(struct device *dev, off_t addr, size_t size)
|
|||
const struct spi_nor_config *params = dev->config_info;
|
||||
int ret = 0;
|
||||
|
||||
/* should be between 0 and flash size */
|
||||
/* erase area must be subregion of device */
|
||||
if ((addr < 0) || ((size + addr) > params->size)) {
|
||||
return -ENODEV;
|
||||
}
|
||||
|
||||
/* address must be sector-aligned */
|
||||
if (!SPI_NOR_IS_SECTOR_ALIGNED(addr)) {
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* size must be a multiple of sectors */
|
||||
if ((size % SPI_NOR_SECTOR_SIZE) != 0) {
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
acquire_device(dev);
|
||||
|
||||
while (size) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue