123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335 |
- /*
- * @file hv_comm_shell.h
- * @brief Header file of shell.
- *
- * @verbatim
- * ==============================================================================
- * ##### How to use #####
- * ==============================================================================
- * (+)
- * @endverbatim
- * @author HiView SoC Software Team
- * @version 1.0.0
- * @date 2022-08-18
- */
- #ifndef __HV_COMM_SHELL_H__
- #define __HV_COMM_SHELL_H__
- #include "hv_vos_Comm.h"
- #include "hv_comm_shell_getopt.h"
- #include "hv_comm_shell_cfg.h"
- #include "hv_comm_shell_port.h"
- #include "hv_comm_Log.h"
- #if SHELL_USING_AUTH == 1
- #if !defined(SHELL_USER_PASSWORD)
- #error "please config shell user password (int shell_cfg.h) "
- #endif
- #endif
- #define SHELL_VERSION "2.0.8" /**< 版本号 */
- /**
- * @brief shell变量类型定义
- *
- */
- #define SHELL_VAR_INT 0
- #define SHELL_VAR_SHORT 1
- #define SHELL_VAR_CHAR 2
- #define SHELL_VAR_POINTER 3
- #define SHELL_VAL 4
- #if defined(__CC_ARM) || (defined(__ARMCC_VERSION) && __ARMCC_VERSION >= 6000000)
- #define SECTION(x) __attribute__((section(x)))
- #elif defined(__ICCARM__)
- #define SECTION(x) @ x
- #elif defined(__GNUC__)
- #define SECTION(x) __attribute__((section(x)))
- #else
- #define SECTION(x)
- #endif
- /**
- * @brief shell命令导出
- *
- * @attention 命令导出方式支持keil,iar的编译器以及gcc,具体参考readme
- */
- #if SHELL_USING_CMD_EXPORT == 1
- #if SHELL_LONG_HELP == 1
- #define SHELL_EXPORT_CMD(cmd, func, desc) \
- const char shellCmd##cmd[] = #cmd; \
- const char shellDesc##cmd[] = #desc; \
- const SHELL_CommandTypeDef \
- shellCommand##cmd SECTION("shellCommand") = \
- { \
- shellCmd##cmd, \
- (int (*)())func, \
- shellDesc##cmd, \
- (void *)0 \
- }
- #define SHELL_EXPORT_CMD_EX(cmd, func, desc, help) \
- const char shellCmd##cmd[] = #cmd; \
- const char shellDesc##cmd[] = #desc; \
- const char shellHelp##cmd[] = #help; \
- const SHELL_CommandTypeDef \
- shellCommand##cmd SECTION("shellCommand") = \
- { \
- shellCmd##cmd, \
- (int (*)())func, \
- shellDesc##cmd, \
- shellHelp##cmd \
- }
- #else /** SHELL_LONG_HELP == 1 */
- #define SHELL_EXPORT_CMD(cmd, func, desc) \
- const char shellCmd##cmd[] = #cmd; \
- const char shellDesc##cmd[] = #desc; \
- const SHELL_CommandTypeDef \
- shellCommand##cmd SECTION("shellCommand") = \
- { \
- shellCmd##cmd, \
- (int (*)())func, \
- shellDesc##cmd \
- }
- #define SHELL_EXPORT_CMD_EX(cmd, func, desc, help) \
- const char shellCmd##cmd[] = #cmd; \
- const char shellDesc##cmd[] = #desc; \
- const SHELL_CommandTypeDef \
- shellCommand##cmd SECTION("shellCommand") = \
- { \
- shellCmd##cmd, \
- (int (*)())func, \
- shellDesc##cmd \
- }
- #endif /** SHELL_LONG_HELP == 1 */
- #if SHELL_USING_VAR == 1
- #define SHELL_EXPORT_VAR(var, variable, desc, type) \
- const char shellVar##var[] = #var; \
- const char shellDesc##var[] = #desc; \
- const SHELL_VaribaleTypeDef \
- shellVariable##var SECTION("shellVariable") = \
- { \
- shellVar##var, \
- (void *)(variable), \
- shellDesc##var, \
- type \
- }
- #else
- #define SHELL_EXPORT_VAR(var, variable, desc, type)
- #endif /** SHELL_USING_VAR == 1 */
- #else
- #define SHELL_EXPORT_CMD(cmd, func, desc)
- #define SHELL_EXPORT_CMD_EX(cmd, func, desc, help)
- #define SHELL_EXPORT_VAR(var, variable, desc, type)
- #endif /** SHELL_USING_CMD_EXPORT == 1 */
- #define SHELL_EXPORT_VAR_INT(var, variable, desc) \
- SHELL_EXPORT_VAR(var, &variable, desc, SHELL_VAR_INT)
- #define SHELL_EXPORT_VAR_SHORT(var, variable, desc) \
- SHELL_EXPORT_VAR(var, &variable, desc, SHELL_VAR_SHORT)
- #define SHELL_EXPORT_VAR_CHAR(var, variable, desc) \
- SHELL_EXPORT_VAR(var, &variable, desc, SHELL_VAR_CHAR)
- #define SHELL_EXPORT_VAR_POINTER(var, variable, desc) \
- SHELL_EXPORT_VAR(var, variable, desc, SHELL_VAR_POINTER)
- #define SHELL_EXPORT_VAL(val, value, desc) \
- SHELL_EXPORT_VAR(val, value, desc, SHELL_VAL)
- /**
- * @brief shell命令条目
- *
- * @note 用于shell命令通过命令表的方式定义
- */
- #if SHELL_USING_CMD_EXPORT == 0
- #if SHELL_LONG_HELP == 1
- #define SHELL_CMD_ITEM(cmd, func, desc) \
- { \
- #cmd, \
- (int (*)())func, \
- #desc, \
- (void *)0 \
- }
- #define SHELL_CMD_ITEM_EX(cmd, func, desc, help) \
- { \
- #cmd, \
- (int (*)())func, \
- #desc, \
- #help \
- }
- #else /** SHELL_LONG_HELP == 1 */
- #define SHELL_CMD_ITEM(cmd, func, desc) \
- { \
- #cmd, \
- (int (*)())func, \
- #desc \
- }
- #define SHELL_CMD_ITEM_EX(cmd, func, desc, help) \
- { \
- #cmd, \
- (int (*)())func, \
- #desc, \
- }
- #endif /** SHELL_LONG_HELP == 1 */
- #define SHELL_VAR_ITEM(var, variable, desc, type) \
- { \
- #var, \
- varialbe, \
- #desc, \
- type, \
- }
- #define SHELL_VAR_ITEM_INT(var, variable, desc) \
- SHELL_VAR_ITEM(var, &variable, desc, SHELL_VAR_INT)
- #define SHELL_VAR_ITEM_SHORT(var, variable, desc) \
- SHELL_VAR_ITEM(var, &variable, desc, SHELL_VAR_SHORT)
- #define SHELL_VAR_ITEM_CHAR(var, variable, desc) \
- SHELL_VAR_ITEM(var, &variable, desc, SHELL_VAR_CHAR)
- #define SHELL_VAR_ITEM_POINTER(var, variable, desc) \
- SHELL_VAR_ITEM(var, variable, desc, SHELL_VAR_POINTER)
- #endif /** SHELL_USING_CMD_EXPORT == 0 */
- /**
- * @brief shell读取数据函数原型
- *
- * @param char shell读取的字符
- *
- * @return char 0 读取数据成功
- * @return char -1 读取数据失败
- */
- typedef signed char (*shellRead)(char *);
- /**
- * @brief shell写数据函数原型
- *
- * @param const char 需写的字符
- */
- typedef void (*shellWrite)(const char);
- /**
- * @brief shell指令执行函数原型
- *
- */
- typedef int (*shellFunction)();
- /**
- * @brief shell输入状态
- *
- */
- typedef enum
- {
- SHELL_IN_NORMAL = 0,
- SHELL_ANSI_ESC,
- SHELL_ANSI_CSI,
- }SHELL_InputMode;
- /**
- * @brief shell 命令定义
- *
- */
- typedef struct
- {
- const char *name; /**< shell命令名称 */
- shellFunction function; /**< shell命令函数 */
- const char *desc; /**< shell命令描述 */
- #if SHELL_LONG_HELP == 1
- const char *help; /**< shell长帮助信息 */
- #endif
- }SHELL_CommandTypeDef;
- #if SHELL_USING_VAR == 1
- /**
- * @brief shell 变量定义
- *
- */
- typedef struct
- {
- const char *name; /**< shell变量名称 */
- const void *value; /**< shell变量值 */
- const char *desc; /**< shell变量描述 */
- const int type; /**< shell变量类型 */
- } SHELL_VaribaleTypeDef;
- #endif /** SHELL_USING_VAR == 1 */
- /**
- * @brief shell对象定义
- *
- */
- typedef struct
- {
- char *command; /**< shell命令提示符 */
- char buffer[SHELL_COMMAND_MAX_LENGTH]; /**< shell命令缓冲 */
- unsigned short length; /**< shell命令长度 */
- unsigned short cursor; /**< shell光标位置 */
- char *param[SHELL_PARAMETER_MAX_NUMBER]; /**< shell参数 */
- char history[SHELL_HISTORY_MAX_NUMBER][SHELL_COMMAND_MAX_LENGTH]; /**< 历史记录 */
- unsigned short historyCount; /**< 历史记录数量 */
- short historyFlag; /**< 当前记录位置 */
- short historyOffset; /**< 历史记录偏移 */
- SHELL_CommandTypeDef *commandBase; /**< 命令表基址 */
- unsigned short commandNumber; /**< 命令数量 */
- #if SHELL_USING_VAR == 1
- SHELL_VaribaleTypeDef *variableBase; /**< 变量表基址 */
- unsigned short variableNumber; /**< 变量数量 */
- #endif
- int keyFuncBase; /**< 按键响应表基址 */
- unsigned short keyFuncNumber; /**< 按键响应数量 */
- struct
- {
- unsigned char inputMode : 2; /**< 输入模式 */
- unsigned char isActive: 1; /**< 是否是当前活动shell */
- unsigned char tabFlag : 1; /**< tab标志 */
- unsigned char authFlag : 1; /**< 密码标志 */
- } status; /**< shell状态 */
- shellRead read; /**< shell读字符 */
- shellWrite write; /**< shell写字符 */
- #if SHELL_LONG_HELP == 1 || (SHELL_USING_AUTH && SHELL_LOCK_TIMEOUT > 0)
- int activeTime; /**< shell激活时间戳 */
- #endif
- }SHELL_TypeDef;
- /**
- * @brief shell按键功能定义
- *
- */
- typedef struct
- {
- unsigned char keyCode; /**< shell按键键值 */
- void (*keyFunction)(SHELL_TypeDef *); /**< 按键响应函数 */
- } SHELL_KeyFunctionDef;
- void shellInit(SHELL_TypeDef *shell);
- void shellSetCommandList(SHELL_TypeDef *shell, SHELL_CommandTypeDef *base, unsigned short size);
- #if SHELL_USING_VAR == 1
- void shellSetVariableList(SHELL_TypeDef *shell, SHELL_VaribaleTypeDef *base, unsigned short size);
- int shellGetVariable(SHELL_TypeDef *shell, char *var);
- #endif /** SHELL_USING_VAR == 1 */
- void shellSetKeyFuncList(SHELL_TypeDef *shell, SHELL_KeyFunctionDef *base, unsigned short size);
- SHELL_TypeDef *shellGetCurrent(void);
- void shellPrint(SHELL_TypeDef *shell, char *fmt, ...);
- unsigned short shellDisplay(SHELL_TypeDef *shell, const char *string);
- void shellHandler(SHELL_TypeDef *shell, char data);
- #define shellInput shellHandler
- void shellHelp(int argc, char *argv[]);
- void shellClear(void);
- SHELL_TypeDef* GetShellObject();
- #if SHELL_USING_TASK == 1
- void Hv_Debug_ShellTaskHandle(void *param);
- #endif
- #endif
|