0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

分享一個(gè)開(kāi)源輕量級(jí)單片機(jī)命令行交互組件

嵌入式情報(bào)局 ? 來(lái)源:gitee.com ? 2023-01-29 10:43 ? 次閱讀

1、介紹

在進(jìn)行調(diào)試和維護(hù)時(shí),常常需要與單片機(jī)進(jìn)行交互,獲取、設(shè)置某些參數(shù)或執(zhí)行某些操作,nr_micro_shell正是為滿足這一需求,針對(duì)資源較少的MCU編寫(xiě)的基本命令行工具。

雖然RT_Thread組件中已經(jīng)提供了強(qiáng)大的finsh命令行交互工具,但對(duì)于ROMRAM資源較少的單片機(jī),finsh還是略顯的龐大,在這些平臺(tái)上,若仍想保留基本的命令行交互功能,nr_micro_shell是一個(gè)不錯(cuò)的選擇。

項(xiàng)目地址:github.com/Nrusher/nr_micro_shell

nr_micro_shell具有以下優(yōu)點(diǎn)

1.占用資源少,使用簡(jiǎn)單,靈活方便。使用過(guò)程只涉及兩個(gè)shell_init()和shell()兩個(gè)函數(shù),無(wú)論是使用RTOS還是裸機(jī)都可以方便的應(yīng)用該工具,不需要額外的編碼工作。

2.交互體驗(yàn)好。完全類似于linux shell命令行,當(dāng)串口終端支持ANSI(如Hypertrm終端)時(shí),其不僅支持基本的命令行交互,還提供Tab鍵命令補(bǔ)全,查詢歷史命令,方向鍵移動(dòng)光標(biāo)修改功能。

3.擴(kuò)展性好。nr_micro_shell為用戶提供自定義命令的標(biāo)準(zhǔn)函數(shù)原型,只需要按照命令編寫(xiě)命令函數(shù),并注冊(cè)命令函數(shù),即可使用命令。

nr_micro_shell和相同配置下的finsh (finsh不使用msh)占用資源對(duì)比

原始工程 添加nr_micro_shell增加量 添加finsh增加量
ROM 63660 +3832 +26908
RAM 4696 +1104 +1304

兩者配置都為

最多3條歷史命令。

支持Tab補(bǔ)全 。

命令行最大長(zhǎng)度為100。

最多10個(gè)命令參數(shù)。

命令行線程堆棧為512字節(jié)。

nr_micro_shell演示效果如下

52d11bf2-9f08-11ed-bfe3-dac502259ad0.gif

52e28e28-9f08-11ed-bfe3-dac502259ad0.gif

1.1 目錄結(jié)構(gòu)

名稱 說(shuō)明
docs 文檔目錄,包含演示的GIF圖片等
examples 例子目錄,包括命令函數(shù)示例:nr_micro_shell_commands.c 和RT_Thread下使用示例 nr_micro_shell_thread.c
inc 頭文件目錄
src 源代碼目錄

1.2 許可證

nr_micro_shell package 遵循 MIT 許可,詳見(jiàn) LICENSE 文件。

1.3 依賴

無(wú)依賴

2、RT_Thread 下 ENV 工具使用

RT_Thread 使用 nr_micro_shell package package 需要在 RT-Thread 的包管理器中選擇它,具體路徑如下:

RT-Threadonlinepackages
toolspackages--->
[*]nr_micro_shell:Lightweightcommandlineinteractiontool.--->

相關(guān)的設(shè)置在按下sapce鍵選中后,按enter可進(jìn)行相關(guān)參數(shù)配置。然后讓 RT-Thread 的包管理器自動(dòng)更新,或者使用 pkgs --update 命令更新包到 BSP 中。

若您需要運(yùn)行示例,請(qǐng)保證RT_Thread配置中的Using console for kt_printf.選項(xiàng)是被打開(kāi)的,kt_printf可以正常工作,且Use components automatically initialization.選項(xiàng)打開(kāi)。編譯直接下載仿真便可以使用nr_micro_shell。命令行空白時(shí)按Tab,可顯示所有支持的命令,測(cè)試示例命令可見(jiàn)doc/pic下的使用示例動(dòng)圖。自定義命令過(guò)程,參照下文3. 裸機(jī)下使用nr_micro_shell package中的方法。

3、裸機(jī)下使用

3.1 配置:

所有配置工作都可以在 nr_micro_shell_config.h 中完成。有關(guān)詳細(xì)信息,請(qǐng)參見(jiàn)文件中的注釋。

3.2 用法:

確保所有文件都已添加到項(xiàng)目中。

確保 nr_micro_shell_config.h 中的宏函數(shù)"shell_printf(),ansi_show_char()"可以在項(xiàng)目中正常使用。

使用示例如下

#include"nr_micro_shell.h"

intmain(void)
{
/*初始化*/
shell_init();

while(1)
{
if(USARTGETACHAR'c')
{
/*nr_micro_shell接收字符*/
shell(c);
}
}
}

建議直接使用硬件輸入前,建議使用如下代碼(確??梢哉4蛴⌒畔?,驗(yàn)證nr_micro_shell是否可以正常運(yùn)行

#include"nr_micro_shell.h"

intmain(void)
{
unsignedinti=0;
//匹配好結(jié)束符配置NR_SHELL_END_OF_LINE0
chartest_line[]="test123
"
/*初始化*/
shell_init();

/*初步測(cè)試代碼*/
for(i=0;i

3.3 添加自己的命令

STEP1:

您需要在nr_micro_shell_commands.c*中實(shí)現(xiàn)一個(gè)命令函數(shù)。命令函數(shù)的原型如下

voidyour_command_funtion(charargc,char*argv)
{
.....
}

argc是參數(shù)的數(shù)目。argv存儲(chǔ)每個(gè)參數(shù)的起始地址和內(nèi)容。如果輸入字符串是

test-a1

argc為3,argv的內(nèi)容為

-------------------------------------------------------------
0x03|0x08|0x0b|'t'|'e'|'s'|'t'|'?'|'-'|'a'|'?'|'1'|'?'|
-------------------------------------------------------------

如果想知道第一個(gè)或第二個(gè)參數(shù)的內(nèi)容,應(yīng)該使用

/*"-a"*/
printf(argv[argv[1]])
/*"1"*/
printf(argv[argv[2]])

STEP2:在使用命令前需要注冊(cè)命令,共有兩種方法注冊(cè)命令

1.當(dāng)配置文件中NR_SHELL_USING_EXPORT_CMD未被定義,在static_cmd[]表中寫(xiě)入

conststatic_cmd_ststatic_cmd[]=
{
.....
{"your_command_name",your_command_funtion},
.....
{"?",NULL}
};

注意:不要?jiǎng)h除{"?",NULL}!

2.當(dāng)配置文件中NR_SHELL_USING_EXPORT_CMD被定義,且NR_SHELL_CMD_EXPORT()支持使用的編譯器時(shí),可以使用以下方式注冊(cè)命令

NR_SHELL_CMD_EXPORT(your_command_name,your_command_funtion);

4、linux下使用nr_micro_shell仿真

在工程./examples/simulator/目錄下存放著nr_micro_shell仿真代碼,仍在./examples/nr_micro_shell_commands.c文件中按上述方式添加自定義命令,添加完成后可以使用make命令編譯源碼,生產(chǎn)的可執(zhí)行文件為./examples/simulator/out/nr_micro_shell或./examples/simulator/out/nr_micro_shell_db??墒褂玫膍ake命令如下

#編譯可執(zhí)行文件
make
#編譯可仿真執(zhí)行文件
makedebug
#清除編譯生成文件
makeclean

5、注意事項(xiàng)

根據(jù)你的使用習(xí)慣使用NR_SHELL_USING_EXPORT_CMD選擇命令注冊(cè)方式。

使用注冊(cè)表注冊(cè)命令時(shí),確保您的工程中存在注冊(cè)表

conststatic_cmd_ststatic_cmd[]=
{
.....
{"?",NULL}
};

使用NR_SHELL_CMD_EXPORT()時(shí)確保,NR_SHELL_CMD_EXPORT()支持使用的編譯器,否則會(huì)報(bào)錯(cuò)。

nr_micro_shell 不支持ESC鍵等控制鍵(控制符)。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 單片機(jī)
    +關(guān)注

    關(guān)注

    6030

    文章

    44489

    瀏覽量

    631996
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    16885

    瀏覽量

    349926
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11207

    瀏覽量

    208721
  • 開(kāi)源
    +關(guān)注

    關(guān)注

    3

    文章

    3215

    瀏覽量

    42329
  • 命令行
    +關(guān)注

    關(guān)注

    0

    文章

    77

    瀏覽量

    10377

原文標(biāo)題:分享一個(gè)開(kāi)源輕量級(jí)單片機(jī)命令行交互組件

文章出處:【微信號(hào):嵌入式情報(bào)局,微信公眾號(hào):嵌入式情報(bào)局】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    在STM32實(shí)現(xiàn)命令行

    工作中的開(kāi)發(fā)環(huán)境都是基于linux命令行交互,作為命令行的重度使用者,玩單片機(jī)也要使用命令行工具,百度了
    發(fā)表于 12-09 11:32 ?2236次閱讀

    單片機(jī)上實(shí)現(xiàn)shell命令行交互的方法

    文章發(fā)表于我的個(gè)人微信公眾號(hào):嵌入式軟件那些事公眾號(hào)會(huì)定期分享些嵌入式軟件開(kāi)發(fā)相關(guān)的技術(shù)經(jīng)驗(yàn),涉及嵌入式Linux、STM32、RTOS等,希望對(duì)大家有所幫助!如何在單片機(jī)上實(shí)現(xiàn)shell命令行
    發(fā)表于 01-12 07:33

    caxa命令行中的應(yīng)用

    caxa命令行中的應(yīng)用 命令行對(duì)于大多用戶來(lái)說(shuō)往往只是輸入數(shù)據(jù)的作用,但是其中的奧妙還有很多,下面就給大家
    發(fā)表于 10-18 18:18 ?2276次閱讀

    CMD的命令行高級(jí)教程

    CMD的命令行高級(jí)教程
    發(fā)表于 10-24 08:31 ?30次下載
    CMD的<b class='flag-5'>命令行</b>高級(jí)教程

    mini shell命令行調(diào)試工具(單片機(jī)、c語(yǔ)言)

    @mini shell命令行調(diào)試工具介紹Mini shell 命令行調(diào)試工具(單片機(jī)、c語(yǔ)言)Mini shell是個(gè)特別適合低內(nèi)存的
    發(fā)表于 11-29 10:21 ?9次下載
    mini shell<b class='flag-5'>命令行</b>調(diào)試工具(<b class='flag-5'>單片機(jī)</b>、c語(yǔ)言)

    Shell命令行解釋器簡(jiǎn)介

    Shell 是個(gè)命令行解釋器,Shell 為用戶提供了與設(shè)備進(jìn)行命令行交互的方式,用戶通過(guò)串口、以太網(wǎng)、無(wú)線等方式將
    的頭像 發(fā)表于 08-19 17:20 ?3157次閱讀

    Golang基于flag庫(kù)實(shí)現(xiàn)個(gè)命令行工具

    Golang 標(biāo)準(zhǔn)庫(kù)中的 flag 庫(kù)提供了解析命令行選項(xiàng)的能力,我們可以基于此來(lái)開(kāi)發(fā)命令行工具。
    的頭像 發(fā)表于 10-28 09:26 ?1249次閱讀

    新的開(kāi)源命令行工具west

    電子發(fā)燒友網(wǎng)站提供《新的開(kāi)源命令行工具west.zip》資料免費(fèi)下載
    發(fā)表于 11-11 09:25 ?0次下載
    新的<b class='flag-5'>開(kāi)源</b><b class='flag-5'>命令行</b>工具west

    針對(duì)單片機(jī)開(kāi)發(fā)的輕量級(jí)OTA組件

    今天為大家分享開(kāi)源的,專為單片機(jī)開(kāi)發(fā)的輕量級(jí) OTA 組件:mOTA。
    的頭像 發(fā)表于 12-26 09:36 ?1338次閱讀

    基于Go語(yǔ)言、輕量級(jí)開(kāi)源的可視化路由追蹤命令行工具——NextTrace

    它基于 nexttrace 命令通過(guò)命令行顯示類似于 traceroute 清晰的路由信息。當(dāng)執(zhí)行完條追蹤的路由信息時(shí),會(huì)自動(dòng)生成 MapTrace URL 也就是
    的頭像 發(fā)表于 04-17 14:16 ?3299次閱讀

    個(gè)開(kāi)源MCU級(jí)的命令行交互組件

    個(gè)開(kāi)源MCU級(jí)命令行交互組件~
    的頭像 發(fā)表于 10-17 16:26 ?394次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個(gè)</b><b class='flag-5'>開(kāi)源</b>MCU級(jí)的<b class='flag-5'>命令行</b><b class='flag-5'>交互</b><b class='flag-5'>組件</b>

    如何在單片機(jī)中實(shí)現(xiàn)命令交互

    在進(jìn)行調(diào)試和維護(hù)時(shí),常常需要與單片機(jī)進(jìn)行交互,獲取、設(shè)置某些參數(shù)或執(zhí)行某些操作,nr_micro_shell正是為滿足這需求,針對(duì)資源較少的MCU編寫(xiě)的基本命令行工具。
    發(fā)表于 09-27 09:31 ?1071次閱讀
    如何在<b class='flag-5'>單片機(jī)</b>中實(shí)現(xiàn)<b class='flag-5'>命令</b><b class='flag-5'>交互</b>

    單片機(jī)上如何做shell命令行交互

    做個(gè)shell命令行交互?答案當(dāng)然是可以的,在網(wǎng)上類似的文章和代碼籮筐, 基本原理: 監(jiān)測(cè)用戶的輸入,然后到
    的頭像 發(fā)表于 11-01 15:16 ?1267次閱讀

    linux虛擬機(jī)怎么調(diào)出命令行

    在Linux虛擬機(jī)中調(diào)出命令行界面,可以通過(guò)以下步驟實(shí)現(xiàn): 打開(kāi)虛擬機(jī),進(jìn)入到Linux系統(tǒng)。 在桌面或應(yīng)用菜單中找到終端或命令行圖標(biāo),點(diǎn)擊打開(kāi)。 輸入
    的頭像 發(fā)表于 11-08 11:28 ?2939次閱讀

    linux虛擬機(jī)怎么調(diào)出命令行

    命令行的方式可以因不同的虛擬機(jī)軟件而異,下面將介紹幾種常用的虛擬機(jī)軟件以及它們調(diào)出命令行的方法。 VMware虛擬機(jī) VMware是
    的頭像 發(fā)表于 11-17 09:55 ?3610次閱讀