/* * Copyright (c) 2019 Vestas Wind Systems A/S * * SPDX-License-Identifier: Apache-2.0 */ /** * @file * @brief EEPROM shell commands. */ #include #include #include struct args_index { uint8_t device; uint8_t offset; uint8_t length; uint8_t data; uint8_t pattern; }; static const struct args_index args_indx = { .device = 1, .offset = 2, .length = 3, .data = 3, .pattern = 4, }; static int cmd_read(const struct shell *shell, size_t argc, char **argv) { uint8_t buf[CONFIG_EEPROM_SHELL_BUFFER_SIZE]; const struct device *eeprom; off_t offset; size_t len; int err; offset = strtoul(argv[args_indx.offset], NULL, 0); len = strtoul(argv[args_indx.length], NULL, 0); if (len > sizeof(buf)) { shell_error(shell, "Read buffer size (%d bytes) exceeded", sizeof(buf)); return -EINVAL; } eeprom = device_get_binding(argv[args_indx.device]); if (!eeprom) { shell_error(shell, "EEPROM device not found"); return -EINVAL; } shell_print(shell, "Reading %d bytes from EEPROM, offset %d...", len, offset); err = eeprom_read(eeprom, offset, buf, len); if (err) { shell_error(shell, "EEPROM read failed (err %d)", err); return err; } shell_hexdump(shell, buf, len); return 0; } static int cmd_write(const struct shell *shell, size_t argc, char **argv) { uint8_t wr_buf[CONFIG_EEPROM_SHELL_BUFFER_SIZE]; uint8_t rd_buf[CONFIG_EEPROM_SHELL_BUFFER_SIZE]; const struct device *eeprom; unsigned long byte; off_t offset; size_t len; int err; int i; offset = strtoul(argv[args_indx.offset], NULL, 0); len = argc - args_indx.data; if (len > sizeof(wr_buf)) { shell_error(shell, "Write buffer size (%d bytes) exceeded", sizeof(wr_buf)); return -EINVAL; } for (i = 0; i < len; i++) { byte = strtoul(argv[args_indx.data + i], NULL, 0); if (byte > UINT8_MAX) { shell_error(shell, "Error parsing data byte %d", i); return -EINVAL; } wr_buf[i] = byte; } eeprom = device_get_binding(argv[args_indx.device]); if (!eeprom) { shell_error(shell, "EEPROM device not found"); return -EINVAL; } shell_print(shell, "Writing %d bytes to EEPROM...", len); err = eeprom_write(eeprom, offset, wr_buf, len); if (err) { shell_error(shell, "EEPROM write failed (err %d)", err); return err; } shell_print(shell, "Verifying..."); err = eeprom_read(eeprom, offset, rd_buf, len); if (err) { shell_error(shell, "EEPROM read failed (err %d)", err); return err; } if (memcmp(wr_buf, rd_buf, len) != 0) { shell_error(shell, "Verify failed"); return -EIO; } shell_print(shell, "Verify OK"); return 0; } static int cmd_size(const struct shell *shell, size_t argc, char **argv) { const struct device *eeprom; eeprom = device_get_binding(argv[args_indx.device]); if (!eeprom) { shell_error(shell, "EEPROM device not found"); return -EINVAL; } shell_print(shell, "%d bytes", eeprom_get_size(eeprom)); return 0; } static int cmd_fill(const struct shell *shell, size_t argc, char **argv) { uint8_t wr_buf[CONFIG_EEPROM_SHELL_BUFFER_SIZE]; uint8_t rd_buf[CONFIG_EEPROM_SHELL_BUFFER_SIZE]; const struct device *eeprom; unsigned long pattern; off_t offset; size_t len; int err; offset = strtoul(argv[args_indx.offset], NULL, 0); len = strtoul(argv[args_indx.length], NULL, 0); if (len > sizeof(wr_buf)) { shell_error(shell, "Write buffer size (%d bytes) exceeded", sizeof(wr_buf)); return -EINVAL; } pattern = strtoul(argv[args_indx.pattern], NULL, 0); if (pattern > UINT8_MAX) { shell_error(shell, "Error parsing pattern byte"); return -EINVAL; } memset(wr_buf, pattern, len); eeprom = device_get_binding(argv[args_indx.device]); if (!eeprom) { shell_error(shell, "EEPROM device not found"); return -EINVAL; } shell_print(shell, "Writing %d bytes of 0x%02x to EEPROM...", len, pattern); err = eeprom_write(eeprom, offset, wr_buf, len); if (err) { shell_error(shell, "EEPROM write failed (err %d)", err); return err; } shell_print(shell, "Verifying..."); err = eeprom_read(eeprom, offset, rd_buf, len); if (err) { shell_error(shell, "EEPROM read failed (err %d)", err); return err; } if (memcmp(wr_buf, rd_buf, len) != 0) { shell_error(shell, "Verify failed"); return -EIO; } shell_print(shell, "Verify OK"); return 0; } SHELL_STATIC_SUBCMD_SET_CREATE(eeprom_cmds, SHELL_CMD_ARG(read, NULL, " ", cmd_read, 4, 0), SHELL_CMD_ARG(write, NULL, " [byte0] .. ", cmd_write, 4, CONFIG_EEPROM_SHELL_BUFFER_SIZE - 1), SHELL_CMD_ARG(size, NULL, "", cmd_size, 2, 0), SHELL_CMD_ARG(fill, NULL, " ", cmd_fill, 5, 0), SHELL_SUBCMD_SET_END ); SHELL_CMD_REGISTER(eeprom, &eeprom_cmds, "EEPROM shell commands", NULL);