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.h>
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 <finsh.h>

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 最大分配内存
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容