zephyr/subsys/net/lib/openthread/platform/flash.c
Tomasz Bursztyka e18fcbba5a device: Const-ify all device driver instance pointers
Now that device_api attribute is unmodified at runtime, as well as all
the other attributes, it is possible to switch all device driver
instance to be constant.

A coccinelle rule is used for this:

@r_const_dev_1
  disable optional_qualifier
@
@@
-struct device *
+const struct device *

@r_const_dev_2
 disable optional_qualifier
@
@@
-struct device * const
+const struct device *

Fixes #27399

Signed-off-by: Tomasz Bursztyka <tomasz.bursztyka@linux.intel.com>
2020-09-02 13:48:13 +02:00

116 lines
2.2 KiB
C

/*
* Copyright (c) 2018 Nordic Semiconductor ASA
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <kernel.h>
#include <drivers/flash.h>
#include "platform-zephyr.h"
static const struct device *flash_dev;
static size_t ot_flash_size;
static size_t ot_flash_offset;
static inline uint32_t mapAddress(uint32_t aAddress)
{
return aAddress + ot_flash_offset;
}
otError utilsFlashInit(void)
{
int i;
struct flash_pages_info info;
size_t pages_count;
flash_dev =
device_get_binding(DT_CHOSEN_ZEPHYR_FLASH_CONTROLLER_LABEL);
if (!flash_dev) {
return OT_ERROR_NOT_IMPLEMENTED;
}
pages_count = flash_get_page_count(flash_dev);
if (flash_get_page_info_by_idx(flash_dev,
pages_count - CONFIG_OT_PLAT_FLASH_PAGES_COUNT, &info)) {
return OT_ERROR_FAILED;
}
ot_flash_offset = info.start_offset;
ot_flash_size = 0;
for (i = 0; i < CONFIG_OT_PLAT_FLASH_PAGES_COUNT; i++) {
if (flash_get_page_info_by_idx(flash_dev,
pages_count - i - 1, &info)) {
return OT_ERROR_FAILED;
}
ot_flash_size += info.size;
}
return OT_ERROR_NONE;
}
uint32_t utilsFlashGetSize(void)
{
return ot_flash_size;
}
otError utilsFlashErasePage(uint32_t aAddress)
{
otError err = OT_ERROR_NONE;
struct flash_pages_info info;
uint32_t address;
address = mapAddress(aAddress);
if (flash_get_page_info_by_offs(flash_dev, address, &info)) {
return OT_ERROR_FAILED;
}
if (flash_write_protection_set(flash_dev, false) < 0) {
return OT_ERROR_FAILED;
}
if (flash_erase(flash_dev, address, info.size) < 0) {
err = OT_ERROR_FAILED;
}
(void)flash_write_protection_set(flash_dev, true);
return err;
}
otError utilsFlashStatusWait(uint32_t aTimeout)
{
ARG_UNUSED(aTimeout);
return OT_ERROR_NONE;
}
uint32_t utilsFlashWrite(uint32_t aAddress, uint8_t *aData, uint32_t aSize)
{
uint32_t index = 0U;
flash_write_protection_set(flash_dev, false);
if (!flash_write(flash_dev, mapAddress(aAddress), aData, aSize)) {
index = aSize;
}
flash_write_protection_set(flash_dev, true);
return index;
}
uint32_t utilsFlashRead(uint32_t aAddress, uint8_t *aData, uint32_t aSize)
{
uint32_t index = 0U;
if (!flash_read(flash_dev, mapAddress(aAddress), aData, aSize)) {
index = aSize;
}
return index;
}