/* * Copyright (c) 2017 Codecoup * * SPDX-License-Identifier: Apache-2.0 */ #include #include #include #include #include #include #include #define TEST_PARTITION storage_partition #define TEST_PARTITION_ID FIXED_PARTITION_ID(TEST_PARTITION) #define TEST_PARTITION_SIZE FIXED_PARTITION_SIZE(TEST_PARTITION) static uint8_t rambuf[TEST_PARTITION_SIZE]; static int test_flash_ram_erase(const struct device *dev, off_t offset, size_t len) { struct flash_pages_info info; off_t end_offset = offset + len; zassert_true(offset >= 0, "invalid offset"); zassert_true(offset + len <= TEST_PARTITION_SIZE, "flash address out of bounds"); while (offset < end_offset) { flash_get_page_info_by_offs(dev, offset, &info); (void)memset(rambuf + info.start_offset, 0xff, info.size); offset = info.start_offset + info.size; } return 0; } static int test_flash_ram_write(const struct device *dev, off_t offset, const void *data, size_t len) { zassert_true(offset >= 0, "invalid offset"); zassert_true(offset + len <= TEST_PARTITION_SIZE, "flash address out of bounds"); memcpy(rambuf + offset, data, len); return 0; } static int test_flash_ram_read(const struct device *dev, off_t offset, void *data, size_t len) { zassert_true(offset >= 0, "invalid offset"); zassert_true(offset + len <= TEST_PARTITION_SIZE, "flash address out of bounds"); memcpy(data, rambuf + offset, len); return 0; } static void test_flash_ram_pages_layout(const struct device *dev, const struct flash_pages_layout **layout, size_t *layout_size) { /* Same as used in Mynewt native "flash" backend */ static struct flash_pages_layout dev_layout[] = { { 4, 16 * 1024 }, { 1, 64 * 1024 }, { 7, 128 * 1024 }, }; *layout = dev_layout; *layout_size = ARRAY_SIZE(dev_layout); } static DEVICE_API(flash, flash_ram_api) = { .erase = test_flash_ram_erase, .write = test_flash_ram_write, .read = test_flash_ram_read, .page_layout = test_flash_ram_pages_layout, }; DEVICE_DEFINE(flash_ram_test, "ram_flash_test_drv", NULL, NULL, NULL, NULL, POST_KERNEL, CONFIG_KERNEL_INIT_PRIORITY_DEVICE, &flash_ram_api);