RTT笔记-shell

RTT笔记-shell

模式切换

finsh同时支持c-c-style模式和msh模式,默认进入msh模式,在该模式下输入exit则进入c-style模式,在c-style模式下输入msh()则进入msh模式

c-style模式

C语言解释器模式,在程序中可以通过宏定义,对其添加函数或者变量

//函数宏
//name  函数指针,一般为函数名
//desc  针对这个函数命令的描述信息,desc一般为一段字符串,中间不可以有逗号,两边也没有引号

#include 
FINSH_FUNCTION_EXPORT(name, desc)
--------------------------------------
//变量宏
//name  变量名
//type  变量类型
//desc  变量描述
//类型列表
enum finsh_type{
    finsh_type_unknown = 0,            /**< unknown data type */
    finsh_type_void,                   /**< void */
    finsh_type_voidp,                  /**< void pointer */
    finsh_type_char,                   /**< char */
    finsh_type_uchar,                  /**< unsigned char */
    finsh_type_charp,                  /**< char pointer */
    finsh_type_short,                  /**< short */
    finsh_type_ushort,                 /**< unsigned short */
    finsh_type_shortp,                 /**< short pointer */
    finsh_type_int,                    /**< int */
    finsh_type_uint,                   /**< unsigned int */
    finsh_type_intp,                   /**< int pointer */
    finsh_type_long,                   /**< long */
    finsh_type_ulong,                  /**< unsigned long */
    finsh_type_longp,                  /**< long pointer */
};
FINSH_VAR_EXPORT(name, type, desc)  

举例

#include 

int var;

int hello_rtt(int a)
{
  rt_kprintf("hello, world! I am %d\n", a);
  return a;
}
FINSH_FUNCTION_EXPORT(hello_rtt, say hello to rtt)

FINSH_VAR_EXPORT(var, finsh_type_int, just a var for test)

msh模式

添加msh命令:

使用宏,参数一是函数名字,参数二是说明
MSH_CMD_EXPORT(hello , say hello to RT-Thread);
无参函数:void hello(void)
有参函数:static void hello(int argc, char**argv)

static void main_log(int argc, char**argv)
{
    
    rt_kprintf("argc :%d\n",argc);
    rt_kprintf("1  :%s\n", &argv[0][0]);
    rt_kprintf("2  :%s\n", &argv[1][0]);
     
}
MSH_CMD_EXPORT(main_log, ulog_test);

输出结果

发→◇main_log 1234
收←◆main_log 1234
argc :2
1  :main_log
2  :1234

使用举例,参数是一个字符串和数字

static void main_log(int argc, char**argv)
{
    char name[10];
    uint8_t level;
    if(argc!=3)
    {
        LOG_I("main_log arg size");
          return;
    }
    
    rt_kprintf("argc :%d\n",argc);
    rt_kprintf("1  :%s\n", &argv[0][0]);
    rt_kprintf("2  :%s\n", &argv[1][0]);
    rt_kprintf("3  :%s\n", &argv[2][0]);

    rt_memcpy(name,&argv[1][0],rt_strlen(&argv[1][0])+1);
    rt_kprintf("name :%s\n", name);
    level = atoi(&argv[2][0]);
    rt_kprintf("level :%d\n", level);
    if(ulog_tag_lvl_filter_set(name,level) ==0)
    {
         LOG_I("main_log set ok");
    }
    else
    {
       LOG_I("main_log arg error");
    }
    
}

MSH_CMD_EXPORT(main_log, ulog_test);

基本命令

官网文档

list_thread

返回结果:

msh />list_thread
thread   pri  status      sp     stack size max used left tick  error
-------- ---  ------- ---------- ----------  ------  ---------- ---
tshell    20  ready   0x00000118 0x00001000    29%   0x00000009 000
tidle     31  ready   0x0000005c 0x00000200    28%   0x00000005 000
timer      4  suspend 0x00000078 0x00000400    11%   0x00000009 000
字段 描述
thread 线程的名称
pri 线程的优先级
status 线程当前的状态
sp 线程当前的栈位置
stack size 线程的栈大小
max used 线程历史中使用的最大栈位置
left tick 线程剩余的运行节拍数
error 线程的错误码

显示信号量状态

使用 list_sem 命令来显示系统中所有信号量信息,包括信号量的名称、信号量的值和等待这个信号量的线程数目。

msh />list_sem
semaphore v   suspend thread
-------- --- --------------
shrx     000 0
e0       000 0
字段 描述
semaphore 信号量的名称
v 信号量当前的值
suspend thread 等待这个信号量的线程数目

显示动态内存状态

msh />free
total memory: 7669836
used memory : 15240
maximum allocated memory: 18520
字段 描述
total memory 内存总大小
used memory 已使用的内存大小
maximum allocated memory 最大分配内存

你可能感兴趣的:(RTT笔记-shell)