Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 | /*
* Copyright (c) 2017 Linaro Limited.
* Copyright (c) 2018 Nordic Semiconductor.
*
* SPDX-License-Identifier: Apache-2.0
*/
#include <stdlib.h>
#include <zephyr/kernel.h>
#include <zephyr/device.h>
#include <zephyr/devicetree.h>
#include <zephyr/drivers/flash.h>
#include <zephyr/shell/shell.h>
#define PR_SHELL(sh, fmt, ...) \
shell_fprintf(sh, SHELL_NORMAL, fmt, ##__VA_ARGS__)
#define PR_ERROR(sh, fmt, ...) \
shell_fprintf(sh, SHELL_ERROR, fmt, ##__VA_ARGS__)
/* Assumption: our devices have less than 64MB of memory */
#define RESERVED_MEM_MAP (CONFIG_SRAM_BASE_ADDRESS + 0x4000000)
#define FLASH_MEM CONFIG_FLASH_BASE_ADDRESS
#define RAM_MEM CONFIG_SRAM_BASE_ADDRESS
/* MPU test command help texts */
#define READ_CMD_HELP "Read from a reserved address in the memory map"
#define WRITE_CMD_HELP "Write in to boot FLASH/ROM"
#define RUN_CMD_HELP "Run code located in RAM"
#define MTEST_CMD_HELP "Memory Test writes or reads a memory location.\n" \
"Command accepts 1 (Read) or 2 (Write) parameters."
#if defined(CONFIG_SOC_FLASH_MCUX) || defined(CONFIG_SOC_FLASH_LPC) || \
defined(CONFIG_SOC_FLASH_STM32)
static const struct device *const flash_dev = DEVICE_DT_GET(DT_CHOSEN(zephyr_flash_controller));
#endif
static int cmd_read(const struct shell *sh, size_t argc, char *argv[])
{
ARG_UNUSED(argc);
ARG_UNUSED(argv);
uint32_t *p_mem = (uint32_t *) RESERVED_MEM_MAP;
/* Reads from an address that is reserved in the memory map */
PR_SHELL(sh, "The value is: %d\n", *p_mem);
return 0;
}
#if defined(CONFIG_SOC_FLASH_MCUX) || defined(CONFIG_SOC_FLASH_LPC)
static int cmd_write_mcux(const struct shell *sh, size_t argc, char *argv[])
{
ARG_UNUSED(argc);
ARG_UNUSED(argv);
uint32_t value[2];
uint32_t offset;
/* 128K reserved to the application */
offset = FLASH_MEM + 0x20000;
value[0] = 0xBADC0DE;
value[1] = 0xBADC0DE;
PR_SHELL(sh, "write address: 0x%x\n", offset);
if (flash_write(flash_dev, offset, value,
sizeof(value)) != 0) {
PR_ERROR(sh, "Flash write failed!\n");
return 1;
}
return 0;
}
#elif defined(CONFIG_SOC_FLASH_STM32)
static int cmd_write_stm32(const struct shell *sh, size_t argc, char *argv[])
{
ARG_UNUSED(argc);
ARG_UNUSED(argv);
/* 16K reserved to the application */
uint32_t offset = FLASH_MEM + 0x4000;
uint32_t value = 0xBADC0DE;
PR_SHELL(sh, "write address: 0x%x\n", offset);
if (flash_write(flash_dev, offset, &value, sizeof(value)) != 0) {
PR_ERROR(sh, "Flash write failed!\n");
return 1;
}
return 0;
}
#else
static int cmd_write(const struct shell *sh, size_t argc, char *argv[])
{
ARG_UNUSED(argc);
ARG_UNUSED(argv);
/* 16K reserved to the application */
uint32_t *p_mem = (uint32_t *) (FLASH_MEM + 0x4000);
PR_SHELL(sh, "write address: 0x%x\n", FLASH_MEM + 0x4000);
/* Write in to boot FLASH/ROM */
*p_mem = 0xBADC0DE;
return 0;
}
#endif /* SOC_FLASH_MCUX || SOC_FLASH_LPC */
static int cmd_run(const struct shell *sh, size_t argc, char *argv[])
{
ARG_UNUSED(argc);
ARG_UNUSED(argv);
void (*func_ptr)(void) = (void (*)(void)) RAM_MEM;
/* Run code located in RAM */
func_ptr();
return 0;
}
static int cmd_mtest(const struct shell *sh, size_t argc, char *argv[])
{
uint32_t *mem;
uint32_t val;
val = (uint32_t)strtol(argv[1], NULL, 16);
mem = (uint32_t *) val;
if (argc == 2) {
PR_SHELL(sh, "The value is: 0x%x\n", *mem);
} else {
*mem = (uint32_t) strtol(argv[2], NULL, 16);
}
return 0;
}
int main(void)
{
#if defined(CONFIG_SOC_FLASH_MCUX) || defined(CONFIG_SOC_FLASH_LPC) || \
defined(CONFIG_SOC_FLASH_STM32)
if (!device_is_ready(flash_dev)) {
printk("Flash device not ready\n");
return 0;
}
#endif
return 0;
}
SHELL_STATIC_SUBCMD_SET_CREATE(sub_mpu,
SHELL_CMD_ARG(mtest, NULL, MTEST_CMD_HELP, cmd_mtest, 2, 1),
SHELL_CMD(read, NULL, READ_CMD_HELP, cmd_read),
SHELL_CMD(run, NULL, RUN_CMD_HELP, cmd_run),
#if defined(CONFIG_SOC_FLASH_MCUX) || defined(CONFIG_SOC_FLASH_LPC)
SHELL_CMD(write, NULL, WRITE_CMD_HELP, cmd_write_mcux),
#elif defined(CONFIG_SOC_FLASH_STM32)
SHELL_CMD(write, NULL, WRITE_CMD_HELP, cmd_write_stm32),
#else
SHELL_CMD(write, NULL, WRITE_CMD_HELP, cmd_write),
#endif /* SOC_FLASH_MCUX*/
SHELL_SUBCMD_SET_END /* Array terminated. */
);
SHELL_CMD_REGISTER(mpu, &sub_mpu, "MPU related commands.", NULL);
|