Zephyr API Documentation 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
shell.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef SHELL_H__
8#define SHELL_H__
9
10#include <zephyr/kernel.h>
17#include <zephyr/logging/log.h>
19#include <zephyr/sys/util.h>
20
21#if defined CONFIG_SHELL_GETOPT
22#include <getopt.h>
23#endif
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
29#ifndef CONFIG_SHELL_PROMPT_BUFF_SIZE
30#define CONFIG_SHELL_PROMPT_BUFF_SIZE 0
31#endif
32
33#ifndef CONFIG_SHELL_CMD_BUFF_SIZE
34#define CONFIG_SHELL_CMD_BUFF_SIZE 0
35#endif
36
37#ifndef CONFIG_SHELL_PRINTF_BUFF_SIZE
38#define CONFIG_SHELL_PRINTF_BUFF_SIZE 0
39#endif
40
41#ifndef CONFIG_SHELL_HISTORY_BUFFER
42#define CONFIG_SHELL_HISTORY_BUFFER 0
43#endif
44
45#define Z_SHELL_CMD_ROOT_LVL (0u)
46
47#define SHELL_HEXDUMP_BYTES_IN_LINE 16
48
60#define SHELL_OPT_ARG_RAW (0xFE)
61
65#define SHELL_OPT_ARG_CHECK_SKIP (0xFF)
66
71#define SHELL_OPT_ARG_MAX (0xFD)
72
83
95typedef void (*shell_dynamic_get)(size_t idx,
96 struct shell_static_entry *entry);
97
108
109struct shell;
110
115
131const struct device *shell_device_lookup(size_t idx,
132 const char *prefix);
133
144typedef bool (*shell_device_filter_t)(const struct device *dev);
145
159const struct device *shell_device_filter(size_t idx,
160 shell_device_filter_t filter);
161
182const struct device *shell_device_get_binding(const char *name);
183
196typedef int (*shell_cmd_handler)(const struct shell *sh,
197 size_t argc, char **argv);
198
212typedef int (*shell_dict_cmd_handler)(const struct shell *sh, size_t argc,
213 char **argv, void *data);
214
215/* When entries are added to the memory section a padding is applied for
216 * the posix architecture with 64bits builds and x86_64 targets. Adding padding to allow handle data
217 * in the memory section as array.
218 */
219#if (defined(CONFIG_ARCH_POSIX) && defined(CONFIG_64BIT)) || defined(CONFIG_X86_64)
220#define Z_SHELL_STATIC_ENTRY_PADDING 24
221#else
222#define Z_SHELL_STATIC_ENTRY_PADDING 0
223#endif
224
225/*
226 * @brief Shell static command descriptor.
227 */
229 const char *syntax;
230 const char *help;
231 const union shell_cmd_entry *subcmd;
234 uint8_t padding[Z_SHELL_STATIC_ENTRY_PADDING];
235};
236
252#define SHELL_CMD_ARG_REGISTER(syntax, subcmd, help, handler, \
253 mandatory, optional) \
254 static const struct shell_static_entry UTIL_CAT(_shell_, syntax) = \
255 SHELL_CMD_ARG(syntax, subcmd, help, handler, mandatory, optional); \
256 static const TYPE_SECTION_ITERABLE(union shell_cmd_entry, \
257 UTIL_CAT(shell_cmd_, syntax), shell_root_cmds, \
258 UTIL_CAT(shell_cmd_, syntax) \
259 ) = { \
260 .entry = &UTIL_CAT(_shell_, syntax) \
261 }
262
283#define SHELL_COND_CMD_ARG_REGISTER(flag, syntax, subcmd, help, handler, \
284 mandatory, optional) \
285 COND_CODE_1(\
286 flag, \
287 (\
288 SHELL_CMD_ARG_REGISTER(syntax, subcmd, help, handler, \
289 mandatory, optional) \
290 ), \
291 (\
292 static shell_cmd_handler dummy_##syntax##_handler __unused = \
293 handler;\
294 static const union shell_cmd_entry *dummy_subcmd_##syntax \
295 __unused = subcmd\
296 ) \
297 )
309#define SHELL_CMD_REGISTER(syntax, subcmd, help, handler) \
310 SHELL_CMD_ARG_REGISTER(syntax, subcmd, help, handler, 0, 0)
311
325#define SHELL_COND_CMD_REGISTER(flag, syntax, subcmd, help, handler) \
326 SHELL_COND_CMD_ARG_REGISTER(flag, syntax, subcmd, help, handler, 0, 0)
327
346#define SHELL_STATIC_SUBCMD_SET_CREATE(name, ...) \
347 static const struct shell_static_entry shell_##name[] = { \
348 __VA_ARGS__ \
349 }; \
350 static const union shell_cmd_entry name = { \
351 .entry = shell_##name \
352 }
353
354#define Z_SHELL_UNDERSCORE(x) _##x
355#define Z_SHELL_SUBCMD_NAME(...) \
356 UTIL_CAT(shell_subcmds, MACRO_MAP_CAT(Z_SHELL_UNDERSCORE, __VA_ARGS__))
357#define Z_SHELL_SUBCMD_SECTION_TAG(...) MACRO_MAP_CAT(Z_SHELL_UNDERSCORE, __VA_ARGS__)
358#define Z_SHELL_SUBCMD_SET_SECTION_TAG(x) \
359 Z_SHELL_SUBCMD_SECTION_TAG(NUM_VA_ARGS_LESS_1 x, __DEBRACKET x)
360#define Z_SHELL_SUBCMD_ADD_SECTION_TAG(x, y) \
361 Z_SHELL_SUBCMD_SECTION_TAG(NUM_VA_ARGS_LESS_1 x, __DEBRACKET x, y)
362
375#define SHELL_SUBCMD_SET_CREATE(_name, _parent) \
376 static const TYPE_SECTION_ITERABLE(struct shell_static_entry, _name, shell_subcmds, \
377 Z_SHELL_SUBCMD_SET_SECTION_TAG(_parent))
378
379
399#define SHELL_SUBCMD_COND_ADD(_flag, _parent, _syntax, _subcmd, _help, _handler, \
400 _mand, _opt) \
401 COND_CODE_1(_flag, \
402 (static const TYPE_SECTION_ITERABLE(struct shell_static_entry, \
403 Z_SHELL_SUBCMD_NAME(__DEBRACKET _parent, _syntax), \
404 shell_subcmds, \
405 Z_SHELL_SUBCMD_ADD_SECTION_TAG(_parent, _syntax)) = \
406 SHELL_EXPR_CMD_ARG(1, _syntax, _subcmd, _help, \
407 _handler, _mand, _opt)\
408 ), \
409 (static shell_cmd_handler dummy_handler_##_syntax __unused = _handler;\
410 static const union shell_cmd_entry dummy_subcmd_##_syntax __unused = { \
411 .entry = (const struct shell_static_entry *)_subcmd\
412 } \
413 ) \
414 )
415
428#define SHELL_SUBCMD_ADD(_parent, _syntax, _subcmd, _help, _handler, _mand, _opt) \
429 SHELL_SUBCMD_COND_ADD(1, _parent, _syntax, _subcmd, _help, _handler, _mand, _opt)
430
435#define SHELL_SUBCMD_SET_END {NULL}
436
443#define SHELL_DYNAMIC_CMD_CREATE(name, get) \
444 static const TYPE_SECTION_ITERABLE(union shell_cmd_entry, name, \
445 shell_dynamic_subcmds, name) = \
446 { \
447 .dynamic_get = get \
448 }
449
463#define SHELL_CMD_ARG(syntax, subcmd, help, handler, mand, opt) \
464 SHELL_EXPR_CMD_ARG(1, syntax, subcmd, help, handler, mand, opt)
465
485#define SHELL_COND_CMD_ARG(flag, syntax, subcmd, help, handler, mand, opt) \
486 SHELL_EXPR_CMD_ARG(IS_ENABLED(flag), syntax, subcmd, help, \
487 handler, mand, opt)
488
508#define SHELL_EXPR_CMD_ARG(_expr, _syntax, _subcmd, _help, _handler, \
509 _mand, _opt) \
510 { \
511 .syntax = (_expr) ? (const char *)STRINGIFY(_syntax) : "", \
512 .help = (_expr) ? (const char *)_help : NULL, \
513 .subcmd = (const union shell_cmd_entry *)((_expr) ? \
514 _subcmd : NULL), \
515 .handler = (shell_cmd_handler)((_expr) ? _handler : NULL), \
516 .args = { .mandatory = _mand, .optional = _opt} \
517 }
518
527#define SHELL_CMD(_syntax, _subcmd, _help, _handler) \
528 SHELL_CMD_ARG(_syntax, _subcmd, _help, _handler, 0, 0)
529
542#define SHELL_COND_CMD(_flag, _syntax, _subcmd, _help, _handler) \
543 SHELL_COND_CMD_ARG(_flag, _syntax, _subcmd, _help, _handler, 0, 0)
544
558#define SHELL_EXPR_CMD(_expr, _syntax, _subcmd, _help, _handler) \
559 SHELL_EXPR_CMD_ARG(_expr, _syntax, _subcmd, _help, _handler, 0, 0)
560
561/* Internal macro used for creating handlers for dictionary commands. */
562#define Z_SHELL_CMD_DICT_HANDLER_CREATE(_data, _handler) \
563static int UTIL_CAT(UTIL_CAT(cmd_dict_, UTIL_CAT(_handler, _)), \
564 GET_ARG_N(1, __DEBRACKET _data))( \
565 const struct shell *sh, size_t argc, char **argv) \
566{ \
567 return _handler(sh, argc, argv, \
568 (void *)GET_ARG_N(2, __DEBRACKET _data)); \
569}
570
571/* Internal macro used for creating dictionary commands. */
572#define SHELL_CMD_DICT_CREATE(_data, _handler) \
573 SHELL_CMD_ARG(GET_ARG_N(1, __DEBRACKET _data), NULL, GET_ARG_N(3, __DEBRACKET _data), \
574 UTIL_CAT(UTIL_CAT(cmd_dict_, UTIL_CAT(_handler, _)), \
575 GET_ARG_N(1, __DEBRACKET _data)), 1, 0)
576
610#define SHELL_SUBCMD_DICT_SET_CREATE(_name, _handler, ...) \
611 FOR_EACH_FIXED_ARG(Z_SHELL_CMD_DICT_HANDLER_CREATE, (), \
612 _handler, __VA_ARGS__) \
613 SHELL_STATIC_SUBCMD_SET_CREATE(_name, \
614 FOR_EACH_FIXED_ARG(SHELL_CMD_DICT_CREATE, (,), _handler, __VA_ARGS__), \
615 SHELL_SUBCMD_SET_END \
616 )
617
628
639
645
647 void *context);
648
649
650typedef void (*shell_uninit_cb_t)(const struct shell *sh, int res);
651
658typedef void (*shell_bypass_cb_t)(const struct shell *sh,
659 uint8_t *data,
660 size_t len);
661
662struct shell_transport;
663
680 int (*init)(const struct shell_transport *transport,
681 const void *config,
682 shell_transport_handler_t evt_handler,
683 void *context);
684
692 int (*uninit)(const struct shell_transport *transport);
693
706 int (*enable)(const struct shell_transport *transport,
707 bool blocking_tx);
708
719 int (*write)(const struct shell_transport *transport,
720 const void *data, size_t length, size_t *cnt);
721
732 int (*read)(const struct shell_transport *transport,
733 void *data, size_t length, size_t *cnt);
734
742 void (*update)(const struct shell_transport *transport);
743
744};
745
748 void *ctx;
749};
750
757
758#ifdef CONFIG_SHELL_STATS
759#define Z_SHELL_STATS_DEFINE(_name) static struct shell_stats _name##_stats
760#define Z_SHELL_STATS_PTR(_name) (&(_name##_stats))
761#else
762#define Z_SHELL_STATS_DEFINE(_name)
763#define Z_SHELL_STATS_PTR(_name) NULL
764#endif /* CONFIG_SHELL_STATS */
765
777
778BUILD_ASSERT((sizeof(struct shell_backend_config_flags) == sizeof(uint32_t)),
779 "Structure must fit in 4 bytes");
780
784#define SHELL_DEFAULT_BACKEND_CONFIG_FLAGS \
785{ \
786 .insert_mode = 0, \
787 .echo = 1, \
788 .obscure = IS_ENABLED(CONFIG_SHELL_START_OBSCURED), \
789 .mode_delete = 1, \
790 .use_colors = 1, \
791 .use_vt100 = 1, \
792};
793
804
805BUILD_ASSERT((sizeof(struct shell_backend_ctx_flags) == sizeof(uint32_t)),
806 "Structure must fit in 4 bytes");
807
815
823
831
835struct shell_ctx {
836#if defined(CONFIG_SHELL_PROMPT_CHANGE) && CONFIG_SHELL_PROMPT_CHANGE
838#else
839 const char *prompt;
840#endif
841
847
850
853
858
861
864
865#if defined CONFIG_SHELL_GETOPT
867 struct getopt_state getopt;
868#endif
869
877
880
883
884 volatile union shell_backend_cfg cfg;
885 volatile union shell_backend_ctx ctx;
886
888
893
897};
898
899extern const struct log_backend_api log_backend_shell_api;
900
908
912struct shell {
913 const char *default_prompt;
915 const struct shell_transport *iface;
916 struct shell_ctx *ctx;
919
921
923
925
927
929
930 const char *name;
933};
934
935extern void z_shell_print_stream(const void *user_ctx, const char *data,
936 size_t data_len);
937
950#define Z_SHELL_DEFINE(_name, _prompt, _transport_iface, _out_buf, _log_backend, _shell_flag) \
951 static const struct shell _name; \
952 static struct shell_ctx UTIL_CAT(_name, _ctx); \
953 Z_SHELL_HISTORY_DEFINE(_name##_history, CONFIG_SHELL_HISTORY_BUFFER); \
954 Z_SHELL_FPRINTF_DEFINE(_name##_fprintf, &_name, _out_buf, CONFIG_SHELL_PRINTF_BUFF_SIZE, \
955 true, z_shell_print_stream); \
956 LOG_INSTANCE_REGISTER(shell, _name, CONFIG_SHELL_LOG_LEVEL); \
957 Z_SHELL_STATS_DEFINE(_name); \
958 static K_KERNEL_STACK_DEFINE(_name##_stack, CONFIG_SHELL_STACK_SIZE); \
959 static struct k_thread _name##_thread; \
960 static const STRUCT_SECTION_ITERABLE(shell, _name) = { \
961 .default_prompt = _prompt, \
962 .iface = _transport_iface, \
963 .ctx = &UTIL_CAT(_name, _ctx), \
964 .history = IS_ENABLED(CONFIG_SHELL_HISTORY) ? &_name##_history : NULL, \
965 .shell_flag = _shell_flag, \
966 .fprintf_ctx = &_name##_fprintf, \
967 .stats = Z_SHELL_STATS_PTR(_name), \
968 .log_backend = _log_backend, \
969 LOG_INSTANCE_PTR_INIT(log, shell, _name).name = \
970 STRINGIFY(_name), .thread = &_name##_thread, .stack = _name##_stack}
971
985#define SHELL_DEFINE(_name, _prompt, _transport_iface, _log_queue_size, _log_timeout, _shell_flag) \
986 static uint8_t _name##_out_buffer[CONFIG_SHELL_PRINTF_BUFF_SIZE]; \
987 Z_SHELL_LOG_BACKEND_DEFINE(_name, _name##_out_buffer, CONFIG_SHELL_PRINTF_BUFF_SIZE, \
988 _log_queue_size, _log_timeout); \
989 Z_SHELL_DEFINE(_name, _prompt, _transport_iface, _name##_out_buffer, \
990 Z_SHELL_LOG_BACKEND_PTR(_name), _shell_flag)
991
1005int shell_init(const struct shell *sh, const void *transport_config,
1006 struct shell_backend_config_flags cfg_flags,
1007 bool log_backend, uint32_t init_log_level);
1008
1015void shell_uninit(const struct shell *sh, shell_uninit_cb_t cb);
1016
1024int shell_start(const struct shell *sh);
1025
1033int shell_stop(const struct shell *sh);
1034
1038#define SHELL_NORMAL SHELL_VT100_COLOR_DEFAULT
1039
1043#define SHELL_INFO SHELL_VT100_COLOR_GREEN
1044
1048#define SHELL_OPTION SHELL_VT100_COLOR_CYAN
1049
1053#define SHELL_WARNING SHELL_VT100_COLOR_YELLOW
1054
1058#define SHELL_ERROR SHELL_VT100_COLOR_RED
1059
1071void __printf_like(3, 4) shell_fprintf_impl(const struct shell *sh, enum shell_vt100_color color,
1072 const char *fmt, ...);
1073
1074#define shell_fprintf(sh, color, fmt, ...) shell_fprintf_impl(sh, color, fmt, ##__VA_ARGS__)
1075
1088void shell_vfprintf(const struct shell *sh, enum shell_vt100_color color,
1089 const char *fmt, va_list args);
1090
1106void shell_hexdump_line(const struct shell *sh, unsigned int offset,
1107 const uint8_t *data, size_t len);
1108
1116void shell_hexdump(const struct shell *sh, const uint8_t *data, size_t len);
1117
1127#define shell_info(_sh, _ft, ...) \
1128 shell_fprintf_info(_sh, _ft "\n", ##__VA_ARGS__)
1129void __printf_like(2, 3) shell_fprintf_info(const struct shell *sh, const char *fmt, ...);
1130
1140#define shell_print(_sh, _ft, ...) \
1141 shell_fprintf_normal(_sh, _ft "\n", ##__VA_ARGS__)
1142void __printf_like(2, 3) shell_fprintf_normal(const struct shell *sh, const char *fmt, ...);
1143
1153#define shell_warn(_sh, _ft, ...) \
1154 shell_fprintf_warn(_sh, _ft "\n", ##__VA_ARGS__)
1155void __printf_like(2, 3) shell_fprintf_warn(const struct shell *sh, const char *fmt, ...);
1156
1166#define shell_error(_sh, _ft, ...) \
1167 shell_fprintf_error(_sh, _ft "\n", ##__VA_ARGS__)
1168void __printf_like(2, 3) shell_fprintf_error(const struct shell *sh, const char *fmt, ...);
1169
1176void shell_process(const struct shell *sh);
1177
1187int shell_prompt_change(const struct shell *sh, const char *prompt);
1188
1197void shell_help(const struct shell *sh);
1198
1200#define SHELL_CMD_HELP_PRINTED (1)
1201
1219int shell_execute_cmd(const struct shell *sh, const char *cmd);
1220
1232int shell_set_root_cmd(const char *cmd);
1233
1242void shell_set_bypass(const struct shell *sh, shell_bypass_cb_t bypass);
1243
1251bool shell_ready(const struct shell *sh);
1252
1263int shell_insert_mode_set(const struct shell *sh, bool val);
1264
1276int shell_use_colors_set(const struct shell *sh, bool val);
1277
1288int shell_use_vt100_set(const struct shell *sh, bool val);
1289
1300int shell_echo_set(const struct shell *sh, bool val);
1301
1313int shell_obscure_set(const struct shell *sh, bool obscure);
1314
1326int shell_mode_delete_set(const struct shell *sh, bool val);
1327
1335int shell_get_return_value(const struct shell *sh);
1336
1341#ifdef __cplusplus
1342}
1343#endif
1344
1345#ifdef CONFIG_SHELL_CUSTOM_HEADER
1346/* This include must always be at the end of shell.h */
1347#include <zephyr_custom_shell.h>
1348#endif
1349
1350#endif /* SHELL_H__ */
struct z_thread_stack_element k_thread_stack_t
Typedef of struct z_thread_stack_element.
Definition arch_interface.h:46
long atomic_t
Definition atomic_types.h:15
static void cmd(uint32_t command)
Execute a display list command by co-processor engine.
Definition ft8xx_reference_api.h:153
void shell_uninit(const struct shell *sh, shell_uninit_cb_t cb)
Uninitializes the transport layer and the internal shell state.
void(* shell_uninit_cb_t)(const struct shell *sh, int res)
Definition shell.h:650
void shell_hexdump_line(const struct shell *sh, unsigned int offset, const uint8_t *data, size_t len)
Print a line of data in hexadecimal format.
int(* shell_dict_cmd_handler)(const struct shell *sh, size_t argc, char **argv, void *data)
Shell dictionary command handler prototype.
Definition shell.h:212
int shell_prompt_change(const struct shell *sh, const char *prompt)
Change displayed shell prompt.
void(* shell_transport_handler_t)(enum shell_transport_evt evt, void *context)
Definition shell.h:646
int shell_mode_delete_set(const struct shell *sh, bool val)
Allow application to control whether the delete key backspaces or deletes.
void shell_fprintf_info(const struct shell *sh, const char *fmt,...)
int(* shell_cmd_handler)(const struct shell *sh, size_t argc, char **argv)
Shell command handler prototype.
Definition shell.h:196
void shell_fprintf_error(const struct shell *sh, const char *fmt,...)
int shell_get_return_value(const struct shell *sh)
Retrieve return value of most recently executed shell command.
shell_flag
Flags for setting shell output newline sequence.
Definition shell.h:904
const struct device * shell_device_lookup(size_t idx, const char *prefix)
Get by index a device that matches .
shell_signal
Definition shell.h:824
void shell_fprintf_normal(const struct shell *sh, const char *fmt,...)
void shell_vfprintf(const struct shell *sh, enum shell_vt100_color color, const char *fmt, va_list args)
vprintf-like function which sends formatted data stream to the shell.
void shell_set_bypass(const struct shell *sh, shell_bypass_cb_t bypass)
Set bypass callback.
int shell_set_root_cmd(const char *cmd)
Set root command for all shell instances.
bool shell_ready(const struct shell *sh)
Get shell readiness to execute commands.
int shell_use_colors_set(const struct shell *sh, bool val)
Allow application to control whether terminal output uses colored syntax.
void shell_process(const struct shell *sh)
Process function, which should be executed when data is ready in the transport interface.
const struct device * shell_device_get_binding(const char *name)
Get a device reference from its device::name field or label.
int shell_use_vt100_set(const struct shell *sh, bool val)
Allow application to control whether terminal is using vt100 commands.
void shell_fprintf_impl(const struct shell *sh, enum shell_vt100_color color, const char *fmt,...)
printf-like function which sends formatted data stream to the shell.
int shell_obscure_set(const struct shell *sh, bool obscure)
Allow application to control whether user input is obscured with asterisks – useful for implementing ...
int shell_init(const struct shell *sh, const void *transport_config, struct shell_backend_config_flags cfg_flags, bool log_backend, uint32_t init_log_level)
Function for initializing a transport layer and internal shell state.
shell_receive_state
Definition shell.h:622
void shell_fprintf_warn(const struct shell *sh, const char *fmt,...)
bool(* shell_device_filter_t)(const struct device *dev)
Filter callback type, for use with shell_device_lookup_filter.
Definition shell.h:144
void(* shell_bypass_cb_t)(const struct shell *sh, uint8_t *data, size_t len)
Bypass callback.
Definition shell.h:658
int shell_execute_cmd(const struct shell *sh, const char *cmd)
Execute command.
void shell_help(const struct shell *sh)
Prints the current command help.
int shell_stop(const struct shell *sh)
Function for stopping shell processing.
int shell_start(const struct shell *sh)
Function for starting shell processing.
int shell_echo_set(const struct shell *sh, bool val)
Allow application to control whether user input is echoed back.
const struct log_backend_api log_backend_shell_api
const struct device * shell_device_filter(size_t idx, shell_device_filter_t filter)
Get a device by index and filter.
shell_transport_evt
Shell transport event.
Definition shell.h:641
void shell_hexdump(const struct shell *sh, const uint8_t *data, size_t len)
Print data in hexadecimal format.
int shell_insert_mode_set(const struct shell *sh, bool val)
Allow application to control text insert mode.
shell_state
Definition shell.h:632
void(* shell_dynamic_get)(size_t idx, struct shell_static_entry *entry)
Shell dynamic command descriptor.
Definition shell.h:95
@ SHELL_FLAG_CRLF_DEFAULT
Do not map CR or LF.
Definition shell.h:905
@ SHELL_FLAG_OLF_CRLF
Map LF to CRLF on output.
Definition shell.h:906
@ SHELL_SIGNALS
Definition shell.h:829
@ SHELL_SIGNAL_TXDONE
Definition shell.h:828
@ SHELL_SIGNAL_RXRDY
Definition shell.h:825
@ SHELL_SIGNAL_LOG_MSG
Definition shell.h:826
@ SHELL_SIGNAL_KILL
Definition shell.h:827
@ SHELL_RECEIVE_DEFAULT
Definition shell.h:623
@ SHELL_RECEIVE_ESC_SEQ
Definition shell.h:625
@ SHELL_RECEIVE_ESC
Definition shell.h:624
@ SHELL_RECEIVE_TILDE_EXP
Definition shell.h:626
@ SHELL_TRANSPORT_EVT_TX_RDY
Definition shell.h:643
@ SHELL_TRANSPORT_EVT_RX_RDY
Definition shell.h:642
@ SHELL_STATE_UNINITIALIZED
Definition shell.h:633
@ SHELL_STATE_PANIC_MODE_INACTIVE
Panic requested, not supported.
Definition shell.h:637
@ SHELL_STATE_ACTIVE
Definition shell.h:635
@ SHELL_STATE_PANIC_MODE_ACTIVE
Panic activated.
Definition shell.h:636
@ SHELL_STATE_INITIALIZED
Definition shell.h:634
Public kernel APIs.
flags
Definition parser.h:97
#define CONFIG_SHELL_PROMPT_BUFF_SIZE
Definition shell.h:30
#define CONFIG_SHELL_CMD_BUFF_SIZE
Definition shell.h:34
#define CONFIG_SHELL_PRINTF_BUFF_SIZE
Definition shell.h:38
shell_vt100_color
Definition shell_types.h:14
#define bool
Definition stdbool.h:13
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:411
const char * name
Name of the device instance.
Definition device.h:413
Mutex Structure.
Definition kernel.h:3025
Poll Event.
Definition kernel.h:5987
Definition kernel.h:5963
Thread Structure.
Definition thread.h:259
Logger backend API.
Definition log_backend.h:63
Logger backend structure.
Definition log_backend.h:94
Definition shell.h:769
uint32_t use_vt100
Controls VT100 commands usage in shell.
Definition shell.h:775
uint32_t mode_delete
Operation mode of backspace key.
Definition shell.h:773
uint32_t echo
Controls shell echo.
Definition shell.h:771
uint32_t insert_mode
Controls insert mode for text introduction.
Definition shell.h:770
uint32_t obscure
If echo on, print asterisk instead.
Definition shell.h:772
uint32_t use_colors
Controls colored syntax.
Definition shell.h:774
Definition shell.h:794
uint32_t print_noinit
Print request from not initialized shell.
Definition shell.h:800
uint32_t sync_mode
Shell in synchronous mode.
Definition shell.h:801
uint32_t tx_rdy
Definition shell.h:796
uint32_t handle_log
Shell is handling logger backend.
Definition shell.h:802
uint32_t processing
Shell is executing process function.
Definition shell.h:795
uint32_t last_nl
Last received new line character.
Definition shell.h:798
uint32_t history_exit
Request to exit history mode.
Definition shell.h:797
uint32_t cmd_ctx
Shell is executing command.
Definition shell.h:799
Shell instance context.
Definition shell.h:835
const struct shell_static_entry * selected_cmd
New root command.
Definition shell.h:849
shell_uninit_cb_t uninit_cb
Callback called from shell thread context when unitialization is completed just before aborting shell...
Definition shell.h:857
struct shell_vt100_ctx vt100_ctx
VT100 color and cursor position, terminal width.
Definition shell.h:852
const char * prompt
Definition shell.h:839
k_tid_t tid
Definition shell.h:895
char temp_buff[0]
Command temporary buffer.
Definition shell.h:879
char cmd_buff[0]
Command input buffer.
Definition shell.h:876
struct shell_static_entry active_cmd
Currently executed command.
Definition shell.h:846
uint32_t log_level
Definition shell.h:863
volatile union shell_backend_cfg cfg
Definition shell.h:884
uint16_t cmd_tmp_buff_len
Command length in tmp buffer.
Definition shell.h:873
struct k_poll_signal signals[SHELL_SIGNALS]
Definition shell.h:887
enum shell_state state
Internal module state.
Definition shell.h:842
struct k_mutex wr_mtx
Definition shell.h:894
shell_bypass_cb_t bypass
When bypass is set, all incoming data is passed to the callback.
Definition shell.h:860
uint16_t cmd_buff_len
Command length.
Definition shell.h:870
uint16_t cmd_buff_pos
Command buffer cursor position.
Definition shell.h:871
int ret_val
Definition shell.h:896
char printf_buff[0]
Printf buffer size.
Definition shell.h:882
struct k_poll_event events[SHELL_SIGNALS]
Events that should be used only internally by shell thread.
Definition shell.h:892
enum shell_receive_state receive_state
Escape sequence indicator.
Definition shell.h:843
volatile union shell_backend_ctx ctx
Definition shell.h:885
fprintf context
Definition shell_fprintf.h:29
Definition shell_history.h:21
Shell log backend instance structure (RO data).
Definition shell_log_backend.h:36
Definition shell.h:111
uint8_t mandatory
Number of mandatory arguments.
Definition shell.h:112
uint8_t optional
Number of optional arguments.
Definition shell.h:113
Definition shell.h:228
const union shell_cmd_entry * subcmd
Pointer to subcommand.
Definition shell.h:231
uint8_t padding[0]
Definition shell.h:234
shell_cmd_handler handler
Command handler.
Definition shell.h:232
struct shell_static_args args
Command arguments.
Definition shell.h:233
const char * help
Command help string.
Definition shell.h:230
const char * syntax
Command syntax strings.
Definition shell.h:229
Shell statistics structure.
Definition shell.h:754
atomic_t log_lost_cnt
Lost log counter.
Definition shell.h:755
Unified shell transport interface.
Definition shell.h:668
void(* update)(const struct shell_transport *transport)
Function called in shell thread loop.
Definition shell.h:742
int(* init)(const struct shell_transport *transport, const void *config, shell_transport_handler_t evt_handler, void *context)
Function for initializing the shell transport interface.
Definition shell.h:680
int(* write)(const struct shell_transport *transport, const void *data, size_t length, size_t *cnt)
Function for writing data to the transport interface.
Definition shell.h:719
int(* uninit)(const struct shell_transport *transport)
Function for uninitializing the shell transport interface.
Definition shell.h:692
int(* enable)(const struct shell_transport *transport, bool blocking_tx)
Function for enabling transport in given TX mode.
Definition shell.h:706
int(* read)(const struct shell_transport *transport, void *data, size_t length, size_t *cnt)
Function for reading data from the transport interface.
Definition shell.h:732
Definition shell.h:746
void * ctx
Definition shell.h:748
const struct shell_transport_api * api
Definition shell.h:747
Definition shell_types.h:44
Shell instance internals.
Definition shell.h:912
struct k_thread * thread
Definition shell.h:931
LOG_INSTANCE_PTR_DECLARE(log)
enum shell_flag shell_flag
Definition shell.h:920
const struct shell_log_backend * log_backend
Definition shell.h:926
struct shell_history * history
Definition shell.h:918
struct shell_stats * stats
Definition shell.h:924
const char * name
Definition shell.h:930
const char * default_prompt
shell default prompt.
Definition shell.h:913
const struct shell_fprintf * fprintf_ctx
Definition shell.h:922
struct shell_ctx * ctx
Internal context.
Definition shell.h:916
const struct shell_transport * iface
Transport interface.
Definition shell.h:915
k_thread_stack_t * stack
Definition shell.h:932
Misc utilities.
Definition shell.h:811
atomic_t value
Definition shell.h:812
Definition shell.h:819
uint32_t value
Definition shell.h:820
Shell command descriptor.
Definition shell.h:101
const struct shell_static_entry * entry
Pointer to array of static commands.
Definition shell.h:106
shell_dynamic_get dynamic_get
Pointer to function returning dynamic commands.
Definition shell.h:103