summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/flash/str9xpec.c119
1 files changed, 81 insertions, 38 deletions
diff --git a/src/flash/str9xpec.c b/src/flash/str9xpec.c
index 7519413c..7f6a29ae 100644
--- a/src/flash/str9xpec.c
+++ b/src/flash/str9xpec.c
@@ -1163,48 +1163,91 @@ COMMAND_HANDLER(str9xpec_handle_flash_disable_turbo_command)
return ERROR_OK;
}
+static const struct command_registration str9xpec_config_command_handlers[] = {
+ {
+ .name = "enable_turbo",
+ .handler = str9xpec_handle_flash_enable_turbo_command,
+ .mode = COMMAND_EXEC,
+ .help = "enable str9xpec turbo mode",
+ },
+ {
+ .name = "disable_turbo",
+ .handler = str9xpec_handle_flash_disable_turbo_command,
+ .mode = COMMAND_EXEC,
+ .help = "disable str9xpec turbo mode",
+ },
+ {
+ .name = "options_cmap",
+ .handler = str9xpec_handle_flash_options_cmap_command,
+ .mode = COMMAND_EXEC,
+ .help = "configure str9xpec boot sector",
+ },
+ {
+ .name = "options_lvdthd",
+ .handler = str9xpec_handle_flash_options_lvdthd_command,
+ .mode = COMMAND_EXEC,
+ .help = "configure str9xpec lvd threshold",
+ },
+ {
+ .name = "options_lvdsel",
+ .handler = str9xpec_handle_flash_options_lvdsel_command,
+ .mode = COMMAND_EXEC,
+ .help = "configure str9xpec lvd selection",
+ },
+ {
+ .name = "options_lvdwarn",
+ .handler = str9xpec_handle_flash_options_lvdwarn_command,
+ .mode = COMMAND_EXEC,
+ .help = "configure str9xpec lvd warning",
+ },
+ {
+ .name = "options_read",
+ .handler = str9xpec_handle_flash_options_read_command,
+ .mode = COMMAND_EXEC,
+ .help = "read str9xpec options",
+ },
+ {
+ .name = "options_write",
+ .handler = str9xpec_handle_flash_options_write_command,
+ .mode = COMMAND_EXEC,
+ .help = "write str9xpec options",
+ },
+ {
+ .name = "lock",
+ .handler = str9xpec_handle_flash_lock_command,
+ .mode = COMMAND_EXEC,
+ .help = "lock str9xpec device",
+ },
+ {
+ .name = "unlock",
+ .handler = str9xpec_handle_flash_unlock_command,
+ .mode = COMMAND_EXEC,
+ .help = "unlock str9xpec device",
+ },
+ {
+ .name = "part_id",
+ .handler = str9xpec_handle_part_id_command,
+ .mode = COMMAND_EXEC,
+ .help = "print part id of str9xpec flash bank <num>",
+ },
+ COMMAND_REGISTRATION_DONE
+};
+static const struct command_registration str9xpec_command_handlers[] = {
+ {
+ .name = "str9xpec",
+ .mode = COMMAND_ANY,
+ .help = "str9xpec flash command group",
+ .chain = str9xpec_config_command_handlers,
+ },
+ COMMAND_REGISTRATION_DONE
+};
+
static int str9xpec_register_commands(struct command_context *cmd_ctx)
{
- struct command *str9xpec_cmd = COMMAND_REGISTER(cmd_ctx, NULL, "str9xpec",
- NULL, COMMAND_ANY, "str9xpec flash specific commands");
-
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "enable_turbo",
- str9xpec_handle_flash_enable_turbo_command,
- COMMAND_EXEC, "enable str9xpec turbo mode");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "disable_turbo",
- str9xpec_handle_flash_disable_turbo_command,
- COMMAND_EXEC, "disable str9xpec turbo mode");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_cmap",
- str9xpec_handle_flash_options_cmap_command,
- COMMAND_EXEC, "configure str9xpec boot sector");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_lvdthd",
- str9xpec_handle_flash_options_lvdthd_command,
- COMMAND_EXEC, "configure str9xpec lvd threshold");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_lvdsel",
- str9xpec_handle_flash_options_lvdsel_command,
- COMMAND_EXEC, "configure str9xpec lvd selection");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_lvdwarn",
- str9xpec_handle_flash_options_lvdwarn_command,
- COMMAND_EXEC, "configure str9xpec lvd warning");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_read",
- str9xpec_handle_flash_options_read_command,
- COMMAND_EXEC, "read str9xpec options");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "options_write",
- str9xpec_handle_flash_options_write_command,
- COMMAND_EXEC, "write str9xpec options");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "lock",
- str9xpec_handle_flash_lock_command,
- COMMAND_EXEC, "lock str9xpec device");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "unlock",
- str9xpec_handle_flash_unlock_command,
- COMMAND_EXEC, "unlock str9xpec device");
- COMMAND_REGISTER(cmd_ctx, str9xpec_cmd, "part_id",
- str9xpec_handle_part_id_command,
- COMMAND_EXEC, "print part id of str9xpec flash bank <num>");
-
- return ERROR_OK;
+ return register_commands(cmd_ctx, NULL, str9xpec_command_handlers);
}
+
struct flash_driver str9xpec_flash = {
.name = "str9xpec",
.register_commands = &str9xpec_register_commands,