1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:12:57 +01:00

mtd: Change API to return 0 on success

Returning the number of bytes written/read could return a negative integer
because a uint32_t is expected for the length in read()/write() operations.
This commit is contained in:
fabian18 2020-04-17 19:41:43 +02:00
parent c7b15f4abe
commit a3a1c160ee
18 changed files with 88 additions and 124 deletions

View File

@ -508,7 +508,7 @@ static int _flash_read (mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t siz
/* size must be within the flash address space */ /* size must be within the flash address space */
CHECK_PARAM_RET (_flash_beg + addr + size <= _flash_end, -EOVERFLOW); CHECK_PARAM_RET (_flash_beg + addr + size <= _flash_end, -EOVERFLOW);
return (spi_flash_read(_flash_beg + addr, buff, size) == ESP_OK) ? (int)size : -EIO; return (spi_flash_read(_flash_beg + addr, buff, size) == ESP_OK) ? 0 : -EIO;
} }
static int _flash_write (mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int _flash_write (mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -525,7 +525,7 @@ static int _flash_write (mtd_dev_t *dev, const void *buff, uint32_t addr, uint32
CHECK_PARAM_RET (size <= _flashchip->page_size, -EOVERFLOW); CHECK_PARAM_RET (size <= _flashchip->page_size, -EOVERFLOW);
CHECK_PARAM_RET ((addr % _flashchip->page_size) + size <= _flashchip->page_size, -EOVERFLOW); CHECK_PARAM_RET ((addr % _flashchip->page_size) + size <= _flashchip->page_size, -EOVERFLOW);
return (spi_flash_write(_flash_beg + addr, buff, size) == ESP_OK) ? (int)size : -EIO; return (spi_flash_write(_flash_beg + addr, buff, size) == ESP_OK) ? 0 : -EIO;
} }
static int _flash_erase (mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _flash_erase (mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -69,10 +69,10 @@ static int _read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
return -EIO; return -EIO;
} }
real_fseek(f, addr, SEEK_SET); real_fseek(f, addr, SEEK_SET);
size = real_fread(buff, 1, size, f); size_t nread = real_fread(buff, 1, size, f);
real_fclose(f); real_fclose(f);
return size; return (nread == size) ? 0 : -EIO;
} }
static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -101,7 +101,7 @@ static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size
} }
real_fclose(f); real_fclose(f);
return size; return 0;
} }
static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -93,7 +93,7 @@ struct mtd_desc {
* @param[in] addr Starting address * @param[in] addr Starting address
* @param[in] size Number of bytes * @param[in] size Number of bytes
* *
* @return the number of bytes actually read * @return 0 on success
* @return < 0 value on error * @return < 0 value on error
*/ */
int (*read)(mtd_dev_t *dev, int (*read)(mtd_dev_t *dev,
@ -112,7 +112,7 @@ struct mtd_desc {
* @param[in] addr Starting address * @param[in] addr Starting address
* @param[in] size Number of bytes * @param[in] size Number of bytes
* *
* @return the number of bytes actually written * @return 0 on success
* @return < 0 value on error * @return < 0 value on error
*/ */
int (*write)(mtd_dev_t *dev, int (*write)(mtd_dev_t *dev,
@ -167,7 +167,7 @@ int mtd_init(mtd_dev_t *mtd);
* @param[in] addr the start address to read from * @param[in] addr the start address to read from
* @param[in] count the number of bytes to read * @param[in] count the number of bytes to read
* *
* @return the number of byte actually read * @return 0 on success
* @return < 0 if an error occurred * @return < 0 if an error occurred
* @return -ENODEV if @p mtd is not a valid device * @return -ENODEV if @p mtd is not a valid device
* @return -ENOTSUP if operation is not supported on @p mtd * @return -ENOTSUP if operation is not supported on @p mtd
@ -188,7 +188,7 @@ int mtd_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t count);
* @param[in] addr the start address to write to * @param[in] addr the start address to write to
* @param[in] count the number of bytes to write * @param[in] count the number of bytes to write
* *
* @return the number of byte actually written * @return 0 on success
* @return < 0 if an error occurred * @return < 0 if an error occurred
* @return -ENODEV if @p mtd is not a valid device * @return -ENODEV if @p mtd is not a valid device
* @return -ENOTSUP if operation is not supported on @p mtd * @return -ENOTSUP if operation is not supported on @p mtd

View File

@ -100,12 +100,12 @@ static ssize_t mtd_vfs_read(vfs_file_t *filp, void *dest, size_t nbytes)
nbytes = size - src; nbytes = size - src;
} }
int res = mtd_read(mtd, dest, src, nbytes); int res = mtd_read(mtd, dest, src, nbytes);
if (res < 0) { if (res != 0) {
return res; return -EIO;
} }
/* Advance file position */ /* Advance file position */
filp->pos += res; filp->pos += nbytes;
return res; return nbytes;
} }
static ssize_t mtd_vfs_write(vfs_file_t *filp, const void *src, size_t nbytes) static ssize_t mtd_vfs_write(vfs_file_t *filp, const void *src, size_t nbytes)
@ -124,12 +124,12 @@ static ssize_t mtd_vfs_write(vfs_file_t *filp, const void *src, size_t nbytes)
nbytes = size - dest; nbytes = size - dest;
} }
int res = mtd_write(mtd, src, dest, nbytes); int res = mtd_write(mtd, src, dest, nbytes);
if (res < 0) { if (res != 0) {
return res; return -EIO;
} }
/* Advance file position */ /* Advance file position */
filp->pos += res; filp->pos += nbytes;
return res; return nbytes;
} }
/** @} */ /** @} */

View File

@ -54,7 +54,7 @@ static int _read(mtd_dev_t *dev, void *buf, uint32_t addr, uint32_t size)
memcpy(buf, (void *)dst_addr, size); memcpy(buf, (void *)dst_addr, size);
return size; return 0;
} }
static int _write(mtd_dev_t *dev, const void *buf, uint32_t addr, uint32_t size) static int _write(mtd_dev_t *dev, const void *buf, uint32_t addr, uint32_t size)
@ -82,7 +82,7 @@ static int _write(mtd_dev_t *dev, const void *buf, uint32_t addr, uint32_t size)
flashpage_write_raw((void *)dst_addr, buf, size); flashpage_write_raw((void *)dst_addr, buf, size);
return size; return 0;
} }
int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -69,12 +69,12 @@ static int mtd_sdcard_read(mtd_dev_t *dev, void *buff, uint32_t addr,
DEBUG("mtd_sdcard_read: addr:%" PRIu32 " size:%" PRIu32 "\n", addr, size); DEBUG("mtd_sdcard_read: addr:%" PRIu32 " size:%" PRIu32 "\n", addr, size);
mtd_sdcard_t *mtd_sd = (mtd_sdcard_t*)dev; mtd_sdcard_t *mtd_sd = (mtd_sdcard_t*)dev;
sd_rw_response_t err; sd_rw_response_t err;
int res = sdcard_spi_read_blocks(mtd_sd->sd_card, addr / SD_HC_BLOCK_SIZE, sdcard_spi_read_blocks(mtd_sd->sd_card, addr / SD_HC_BLOCK_SIZE,
buff, SD_HC_BLOCK_SIZE, buff, SD_HC_BLOCK_SIZE,
size / SD_HC_BLOCK_SIZE, &err); size / SD_HC_BLOCK_SIZE, &err);
if (err == SD_RW_OK) { if (err == SD_RW_OK) {
return res * SD_HC_BLOCK_SIZE; return 0;
} }
return -EIO; return -EIO;
} }
@ -85,12 +85,12 @@ static int mtd_sdcard_write(mtd_dev_t *dev, const void *buff, uint32_t addr,
DEBUG("mtd_sdcard_write: addr:%" PRIu32 " size:%" PRIu32 "\n", addr, size); DEBUG("mtd_sdcard_write: addr:%" PRIu32 " size:%" PRIu32 "\n", addr, size);
mtd_sdcard_t *mtd_sd = (mtd_sdcard_t*)dev; mtd_sdcard_t *mtd_sd = (mtd_sdcard_t*)dev;
sd_rw_response_t err; sd_rw_response_t err;
int res = sdcard_spi_write_blocks(mtd_sd->sd_card, addr / SD_HC_BLOCK_SIZE, sdcard_spi_write_blocks(mtd_sd->sd_card, addr / SD_HC_BLOCK_SIZE,
buff, SD_HC_BLOCK_SIZE, buff, SD_HC_BLOCK_SIZE,
size / SD_HC_BLOCK_SIZE, &err); size / SD_HC_BLOCK_SIZE, &err);
if (err == SD_RW_OK) { if (err == SD_RW_OK) {
return res * SD_HC_BLOCK_SIZE; return 0;
} }
return -EIO; return -EIO;
} }

View File

@ -432,7 +432,7 @@ static int mtd_spi_nor_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t
mtd_spi_cmd_addr_read(dev, dev->params->opcode->read, addr_be, dest, size); mtd_spi_cmd_addr_read(dev, dev->params->opcode->read, addr_be, dest, size);
mtd_spi_release(dev); mtd_spi_release(dev);
return size; return 0;
} }
static int mtd_spi_nor_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t size) static int mtd_spi_nor_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t size)
@ -470,7 +470,7 @@ static int mtd_spi_nor_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uin
wait_for_write_complete(dev, 0); wait_for_write_complete(dev, 0);
mtd_spi_release(dev); mtd_spi_release(dev);
return size; return 0;
} }
static int mtd_spi_nor_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size) static int mtd_spi_nor_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size)

View File

@ -95,16 +95,16 @@ DRESULT disk_read(BYTE pdrv, BYTE *buff, DWORD sector, UINT count)
return RES_PARERR; return RES_PARERR;
} }
uint32_t nread = count * fatfs_mtd_devs[pdrv]->page_size;
int res = mtd_read(fatfs_mtd_devs[pdrv], buff, int res = mtd_read(fatfs_mtd_devs[pdrv], buff,
sector * fatfs_mtd_devs[pdrv]->page_size, sector * fatfs_mtd_devs[pdrv]->page_size,
count * fatfs_mtd_devs[pdrv]->page_size); nread);
if (res >= 0) { if (res != 0) {
uint32_t r_sect = ((unsigned)res) / fatfs_mtd_devs[pdrv]->page_size; return RES_ERROR;
return ((r_sect == count) ? RES_OK : RES_ERROR);
} }
assert((nread / fatfs_mtd_devs[pdrv]->page_size) == count);
return RES_ERROR; return RES_OK;
} }
/** /**
@ -135,16 +135,16 @@ DRESULT disk_write(BYTE pdrv, const BYTE *buff, DWORD sector, UINT count)
return RES_ERROR; /* erase failed! */ return RES_ERROR; /* erase failed! */
} }
uint32_t nwrite = count * fatfs_mtd_devs[pdrv]->page_size;
res = mtd_write(fatfs_mtd_devs[pdrv], buff, res = mtd_write(fatfs_mtd_devs[pdrv], buff,
sector * fatfs_mtd_devs[pdrv]->page_size, sector * fatfs_mtd_devs[pdrv]->page_size,
count * fatfs_mtd_devs[pdrv]->page_size); nwrite);
if (res >= 0) { if (res != 0) {
uint32_t w_sect = ((unsigned)res) / fatfs_mtd_devs[pdrv]->page_size; return RES_ERROR;
return ((w_sect == count) ? RES_OK : RES_ERROR);
} }
assert((nwrite / fatfs_mtd_devs[pdrv]->page_size) == count);
return RES_ERROR; return RES_OK;
} }
/** /**

View File

@ -72,12 +72,7 @@ static int _dev_read(const struct lfs_config *c, lfs_block_t block,
DEBUG("lfs_read: c=%p, block=%" PRIu32 ", off=%" PRIu32 ", buf=%p, size=%" PRIu32 "\n", DEBUG("lfs_read: c=%p, block=%" PRIu32 ", off=%" PRIu32 ", buf=%p, size=%" PRIu32 "\n",
(void *)c, block, off, buffer, size); (void *)c, block, off, buffer, size);
int ret = mtd_read(mtd, buffer, ((fs->base_addr + block) * c->block_size) + off, size); return mtd_read(mtd, buffer, ((fs->base_addr + block) * c->block_size) + off, size);
if (ret >= 0) {
return 0;
}
return ret;
} }
static int _dev_write(const struct lfs_config *c, lfs_block_t block, static int _dev_write(const struct lfs_config *c, lfs_block_t block,
@ -94,12 +89,9 @@ static int _dev_write(const struct lfs_config *c, lfs_block_t block,
for (const uint8_t *part = buf; part < buf + size; part += c->prog_size, for (const uint8_t *part = buf; part < buf + size; part += c->prog_size,
addr += c->prog_size) { addr += c->prog_size) {
int ret = mtd_write(mtd, part, addr, c->prog_size); int ret = mtd_write(mtd, part, addr, c->prog_size);
if (ret < 0) { if (ret != 0) {
return ret; return ret;
} }
else if ((unsigned)ret != c->prog_size) {
return -EIO;
}
} }
return 0; return 0;

View File

@ -72,12 +72,7 @@ static int _dev_read(const struct lfs_config *c, lfs_block_t block,
DEBUG("lfs_read: c=%p, block=%" PRIu32 ", off=%" PRIu32 ", buf=%p, size=%" PRIu32 "\n", DEBUG("lfs_read: c=%p, block=%" PRIu32 ", off=%" PRIu32 ", buf=%p, size=%" PRIu32 "\n",
(void *)c, block, off, buffer, size); (void *)c, block, off, buffer, size);
int ret = mtd_read(mtd, buffer, ((fs->base_addr + block) * c->block_size) + off, size); return mtd_read(mtd, buffer, ((fs->base_addr + block) * c->block_size) + off, size);
if (ret >= 0) {
return 0;
}
return ret;
} }
static int _dev_write(const struct lfs_config *c, lfs_block_t block, static int _dev_write(const struct lfs_config *c, lfs_block_t block,
@ -94,12 +89,9 @@ static int _dev_write(const struct lfs_config *c, lfs_block_t block,
for (const uint8_t *part = buf; part < buf + size; part += c->prog_size, for (const uint8_t *part = buf; part < buf + size; part += c->prog_size,
addr += c->prog_size) { addr += c->prog_size) {
int ret = mtd_write(mtd, part, addr, c->prog_size); int ret = mtd_write(mtd, part, addr, c->prog_size);
if (ret < 0) { if (ret != 0) {
return ret; return ret;
} }
else if ((unsigned)ret != c->prog_size) {
return -EIO;
}
} }
return 0; return 0;

View File

@ -39,12 +39,7 @@ static int32_t _dev_read(struct spiffs_t *fs, u32_t addr, u32_t size, u8_t *dst)
DEBUG("spiffs: read: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size); DEBUG("spiffs: read: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size);
if (mtd_read(dev, dst, addr, size) > 0) { return mtd_read(dev, dst, addr, size);
return 0;
}
else {
return -EIO;
}
} }
static int32_t _dev_write(struct spiffs_t *fs, u32_t addr, u32_t size, const u8_t *src) static int32_t _dev_write(struct spiffs_t *fs, u32_t addr, u32_t size, const u8_t *src)
@ -53,12 +48,7 @@ static int32_t _dev_write(struct spiffs_t *fs, u32_t addr, u32_t size, const u8_
DEBUG("spiffs: write: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size); DEBUG("spiffs: write: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size);
if (mtd_write(dev, src, addr, size) > 0) { return mtd_write(dev, src, addr, size);
return 0;
}
else {
return -EIO;
}
} }
static int32_t _dev_erase(struct spiffs_t *fs, u32_t addr, u32_t size) static int32_t _dev_erase(struct spiffs_t *fs, u32_t addr, u32_t size)
@ -77,24 +67,14 @@ static int32_t _dev_read(u32_t addr, u32_t size, u8_t *dst)
{ {
DEBUG("spiffs: read: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size); DEBUG("spiffs: read: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size);
if (mtd_read(SPIFFS_MTD_DEV, dst, addr, size) > 0) { return mtd_read(SPIFFS_MTD_DEV, dst, addr, size);
return 0;
}
else {
return -EIO;
}
} }
static int32_t _dev_write(u32_t addr, u32_t size, const u8_t *src) static int32_t _dev_write(u32_t addr, u32_t size, const u8_t *src)
{ {
DEBUG("spiffs: write: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size); DEBUG("spiffs: write: from addr 0x%" PRIx32 " size 0x%" PRIx32 "\n", addr, size);
if (mtd_write(SPIFFS_MTD_DEV, src, addr, size) > 0) { return mtd_write(SPIFFS_MTD_DEV, src, addr, size);
return 0;
}
else {
return -EIO;
}
} }
static int32_t _dev_erase(u32_t addr, u32_t size) static int32_t _dev_erase(u32_t addr, u32_t size)

View File

@ -68,7 +68,7 @@ static void test_mtd_write_erase(void)
memset(buf_read, 0, sizeof(buf_read)); memset(buf_read, 0, sizeof(buf_read));
int ret = mtd_write(dev, buf, TEST_ADDRESS, sizeof(buf)); int ret = mtd_write(dev, buf, TEST_ADDRESS, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_erase(dev, TEST_ADDRESS, dev->pages_per_sector * dev->page_size); ret = mtd_erase(dev, TEST_ADDRESS, dev->pages_per_sector * dev->page_size);
TEST_ASSERT_EQUAL_INT(0, ret); TEST_ASSERT_EQUAL_INT(0, ret);
@ -76,7 +76,7 @@ static void test_mtd_write_erase(void)
uint8_t expected[sizeof(buf_read)]; uint8_t expected[sizeof(buf_read)];
memset(expected, 0, sizeof(expected)); memset(expected, 0, sizeof(expected));
ret = mtd_read(dev, buf_read, TEST_ADDRESS, sizeof(buf_read)); ret = mtd_read(dev, buf_read, TEST_ADDRESS, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read))); TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read)));
} }
@ -90,10 +90,10 @@ static void test_mtd_write_read(void)
/* Basic write / read */ /* Basic write / read */
int ret = mtd_write(dev, buf, TEST_ADDRESS, sizeof(buf)); int ret = mtd_write(dev, buf, TEST_ADDRESS, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_read(dev, buf_read, TEST_ADDRESS, sizeof(buf_read)); ret = mtd_read(dev, buf_read, TEST_ADDRESS, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf)));
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty)));

View File

@ -98,7 +98,7 @@ static void test_mtd_write_erase(void)
memset(buf_read, 0, sizeof(buf_read)); memset(buf_read, 0, sizeof(buf_read));
int ret = mtd_write(dev, buf, TEST_ADDRESS1, sizeof(buf)); int ret = mtd_write(dev, buf, TEST_ADDRESS1, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_erase(dev, TEST_ADDRESS1, dev->pages_per_sector * dev->page_size); ret = mtd_erase(dev, TEST_ADDRESS1, dev->pages_per_sector * dev->page_size);
TEST_ASSERT_EQUAL_INT(0, ret); TEST_ASSERT_EQUAL_INT(0, ret);
@ -110,7 +110,7 @@ static void test_mtd_write_erase(void)
memset(expected, 0xff, sizeof(expected)); memset(expected, 0xff, sizeof(expected));
#endif #endif
ret = mtd_read(dev, buf_read, TEST_ADDRESS1, sizeof(buf_read)); ret = mtd_read(dev, buf_read, TEST_ADDRESS1, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read))); TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read)));
} }
@ -129,10 +129,10 @@ static void test_mtd_write_read(void)
/* Basic write / read */ /* Basic write / read */
int ret = mtd_write(dev, buf, TEST_ADDRESS1, sizeof(buf)); int ret = mtd_write(dev, buf, TEST_ADDRESS1, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_read(dev, buf_read, TEST_ADDRESS1, sizeof(buf_read)); ret = mtd_read(dev, buf_read, TEST_ADDRESS1, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf)));
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty)));

View File

@ -62,7 +62,7 @@ static int _read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
} }
memcpy(buff, _dummy_memory + addr, size); memcpy(buff, _dummy_memory + addr, size);
return size; return 0;
} }
static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr,
@ -78,7 +78,7 @@ static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr,
} }
memcpy(_dummy_memory + addr, buff, size); memcpy(_dummy_memory + addr, buff, size);
return size; return 0;
} }
static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -56,7 +56,7 @@ static int _read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
} }
memcpy(buff, dummy_memory + addr, size); memcpy(buff, dummy_memory + addr, size);
return size; return 0;
} }
static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -71,7 +71,7 @@ static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size
} }
memcpy(dummy_memory + addr, buff, size); memcpy(dummy_memory + addr, buff, size);
return size; return 0;
} }
static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -56,7 +56,7 @@ static int _read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
} }
memcpy(buff, dummy_memory + addr, size); memcpy(buff, dummy_memory + addr, size);
return size; return 0;
} }
static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -71,7 +71,7 @@ static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size
} }
memcpy(dummy_memory + addr, buff, size); memcpy(dummy_memory + addr, buff, size);
return size; return 0;
} }
static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)

View File

@ -54,7 +54,7 @@ static int _read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
} }
memcpy(buff, dummy_memory + addr, size); memcpy(buff, dummy_memory + addr, size);
return size; return 0;
} }
static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -69,7 +69,7 @@ static int _write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size
} }
memcpy(dummy_memory + addr, buff, size); memcpy(dummy_memory + addr, buff, size);
return size; return 0;
} }
static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int _erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)
@ -400,34 +400,34 @@ static void tests_spiffs_partition(void)
/* if SPIFFS_USE_MAGIC is used, a magic word is written in each sector */ /* if SPIFFS_USE_MAGIC is used, a magic word is written in each sector */
uint8_t buf[4]; uint8_t buf[4];
const uint8_t buf_erased[4] = {0xff, 0xff, 0xff, 0xff}; const uint8_t buf_erased[4] = {0xff, 0xff, 0xff, 0xff};
int nread; int ret;
res = 0; res = 0;
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) { for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
nread = mtd_read(_dev, buf, _dev->page_size * _dev->pages_per_sector + i, sizeof(buf)); ret = mtd_read(_dev, buf, _dev->page_size * _dev->pages_per_sector + i, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread); TEST_ASSERT_EQUAL_INT(0, ret);
res |= memcmp(buf, buf_erased, sizeof(buf)); res |= memcmp(buf, buf_erased, sizeof(buf));
} }
TEST_ASSERT(res != 0); TEST_ASSERT(res != 0);
res = 0; res = 0;
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) { for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
nread = mtd_read(_dev, buf, (2 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf)); ret = mtd_read(_dev, buf, (2 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread); TEST_ASSERT_EQUAL_INT(0, ret);
res |= memcmp(buf, buf_erased, sizeof(buf)); res |= memcmp(buf, buf_erased, sizeof(buf));
} }
TEST_ASSERT(res != 0); TEST_ASSERT(res != 0);
/* Check previous sector (must be erased) */ /* Check previous sector (must be erased) */
res = 0; res = 0;
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) { for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
nread = mtd_read(_dev, buf, i, sizeof(buf)); ret = mtd_read(_dev, buf, i, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread); TEST_ASSERT_EQUAL_INT(0, ret);
res |= memcmp(buf, buf_erased, sizeof(buf)); res |= memcmp(buf, buf_erased, sizeof(buf));
} }
TEST_ASSERT(res == 0); TEST_ASSERT(res == 0);
/* Check next sector (must be erased) */ /* Check next sector (must be erased) */
res = 0; res = 0;
for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) { for (size_t i = 0; i < _dev->page_size * _dev->pages_per_sector; i += sizeof(buf)) {
nread = mtd_read(_dev, buf, (3 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf)); ret = mtd_read(_dev, buf, (3 * _dev->page_size * _dev->pages_per_sector) + i, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), nread); TEST_ASSERT_EQUAL_INT(0, ret);
res |= memcmp(buf, buf_erased, sizeof(buf)); res |= memcmp(buf, buf_erased, sizeof(buf));
} }
TEST_ASSERT(res == 0); TEST_ASSERT(res == 0);

View File

@ -59,7 +59,7 @@ static int read(mtd_dev_t *dev, void *buff, uint32_t addr, uint32_t size)
} }
memcpy(buff, dummy_memory + addr, size); memcpy(buff, dummy_memory + addr, size);
return size; return 0;
} }
static int write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size) static int write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
@ -74,7 +74,7 @@ static int write(mtd_dev_t *dev, const void *buff, uint32_t addr, uint32_t size)
} }
memcpy(dummy_memory + addr, buff, size); memcpy(dummy_memory + addr, buff, size);
return size; return 0;
} }
static int erase(mtd_dev_t *dev, uint32_t addr, uint32_t size) static int erase(mtd_dev_t *dev, uint32_t addr, uint32_t size)
@ -165,7 +165,7 @@ static void test_mtd_write_erase(void)
memset(buf_read, 0, sizeof(buf_read)); memset(buf_read, 0, sizeof(buf_read));
int ret = mtd_write(dev, buf, sizeof(buf_empty), sizeof(buf)); int ret = mtd_write(dev, buf, sizeof(buf_empty), sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_erase(dev, 0, dev->pages_per_sector * dev->page_size); ret = mtd_erase(dev, 0, dev->pages_per_sector * dev->page_size);
TEST_ASSERT_EQUAL_INT(0, ret); TEST_ASSERT_EQUAL_INT(0, ret);
@ -173,7 +173,7 @@ static void test_mtd_write_erase(void)
uint8_t expected[sizeof(buf_read)]; uint8_t expected[sizeof(buf_read)];
memset(expected, 0xff, sizeof(expected)); memset(expected, 0xff, sizeof(expected));
ret = mtd_read(dev, buf_read, 0, sizeof(buf_read)); ret = mtd_read(dev, buf_read, 0, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read))); TEST_ASSERT_EQUAL_INT(0, memcmp(expected, buf_read, sizeof(buf_read)));
} }
@ -187,19 +187,19 @@ static void test_mtd_write_read(void)
/* Basic write / read */ /* Basic write / read */
int ret = mtd_write(dev, buf, 0, sizeof(buf)); int ret = mtd_write(dev, buf, 0, sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_read(dev, buf_read, 0, sizeof(buf_read)); ret = mtd_read(dev, buf_read, 0, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read, sizeof(buf)));
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf), sizeof(buf_empty)));
/* Unaligned write / read */ /* Unaligned write / read */
ret = mtd_write(dev, buf, dev->page_size + sizeof(buf_empty), sizeof(buf)); ret = mtd_write(dev, buf, dev->page_size + sizeof(buf_empty), sizeof(buf));
TEST_ASSERT_EQUAL_INT(sizeof(buf), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_read(dev, buf_read, dev->page_size, sizeof(buf_read)); ret = mtd_read(dev, buf_read, dev->page_size, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read, sizeof(buf_empty))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read, sizeof(buf_empty)));
TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read + sizeof(buf_empty), sizeof(buf))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf, buf_read + sizeof(buf_empty), sizeof(buf)));
@ -224,12 +224,12 @@ static void test_mtd_write_read(void)
ret = mtd_erase(dev, 0, dev->page_size * dev->pages_per_sector); ret = mtd_erase(dev, 0, dev->page_size * dev->pages_per_sector);
TEST_ASSERT_EQUAL_INT(0, ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_write(dev, buf_page, 0, dev->page_size); ret = mtd_write(dev, buf_page, 0, dev->page_size);
TEST_ASSERT_EQUAL_INT(dev->page_size, ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_write(dev, buf_page, dev->page_size, dev->page_size); ret = mtd_write(dev, buf_page, dev->page_size, dev->page_size);
TEST_ASSERT_EQUAL_INT(dev->page_size, ret); TEST_ASSERT_EQUAL_INT(0, ret);
memset(buf_page, 0, sizeof(buf_page)); memset(buf_page, 0, sizeof(buf_page));
ret = mtd_read(dev, buf_page, 0, sizeof(buf_page)); ret = mtd_read(dev, buf_page, 0, sizeof(buf_page));
TEST_ASSERT_EQUAL_INT(sizeof(buf_page), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(1, buf_page[0]); TEST_ASSERT_EQUAL_INT(1, buf_page[0]);
TEST_ASSERT_EQUAL_INT(1, buf_page[sizeof(buf_page) - 1]); TEST_ASSERT_EQUAL_INT(1, buf_page[sizeof(buf_page) - 1]);
@ -254,12 +254,12 @@ static void test_mtd_write_read_flash(void)
/* Basic write / read */ /* Basic write / read */
int ret = mtd_write(dev, buf1, 0, sizeof(buf1)); int ret = mtd_write(dev, buf1, 0, sizeof(buf1));
TEST_ASSERT_EQUAL_INT(sizeof(buf1), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_write(dev, buf2, 0, sizeof(buf2)); ret = mtd_write(dev, buf2, 0, sizeof(buf2));
TEST_ASSERT_EQUAL_INT(sizeof(buf2), ret); TEST_ASSERT_EQUAL_INT(0, ret);
ret = mtd_read(dev, buf_read, 0, sizeof(buf_read)); ret = mtd_read(dev, buf_read, 0, sizeof(buf_read));
TEST_ASSERT_EQUAL_INT(sizeof(buf_read), ret); TEST_ASSERT_EQUAL_INT(0, ret);
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_expected, buf_read, sizeof(buf_expected))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_expected, buf_read, sizeof(buf_expected)));
TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf_expected), sizeof(buf_empty))); TEST_ASSERT_EQUAL_INT(0, memcmp(buf_empty, buf_read + sizeof(buf_expected), sizeof(buf_empty)));
} }