產(chǎn)品很多配置信息需要后期進行配置,配置交互最好的方式之一是上位機通過串口與開發(fā)板進行交互來完配置。這里我準(zhǔn)備引入AT指令來進行配置。
我采用串口中斷+定時器中斷來實現(xiàn)了串口的接收,下面進行AT指令框架的創(chuàng)建。
- 首先定義了指令結(jié)構(gòu):
typedef enum{
AT_CMD_TEST = 0,
AT_CMD_SETRTC,
AT_END
}AT_Cmd;
typedef unsigned char (*pFunc)(unsigned char *ptr, unsigned char len);
typedef struct
{
AT_Cmd cmd; /* 指令序號 */
unsigned char *str; /* 指令內(nèi)容 */
pFunc cb; /* 指令執(zhí)行 */
}AT_cmd_func;
/* AT指令表 */
const AT_cmd_func at_cmd_func[] = {
{AT_CMD_TEST, "AT", at_cmd_test},
{AT_CMD_SETRTC, "AT+SETRTC=", at_cmd_setrtc},
{AT_END, NULL, NULL}
};
- 我定義了執(zhí)行指令的函數(shù)1個是AT測試,再有一條是設(shè)置RTC的指令(具體還沒有實現(xiàn),只是定義了一條打印指令);
/* 指令執(zhí)行函數(shù) */
unsigned char at_cmd_test(unsigned char *p, unsigned char len){
AT_DEBUG_INFO("AT+OKrn");
return 0;
}
unsigned char at_cmd_setrtc(unsigned char *p, unsigned char len){
AT_DEBUG_INFO("setrtcrn");
return 0;
}
- 最后我們進行指令解析,主要有兩個函數(shù),一個是檢索指令表里是否存在指令,二個是解析指令,如果成果測執(zhí)行相應(yīng)的指令。
/* 查找指令表中對應(yīng)的指令 */
unsigned char AT_cmd_search(unsigned char *p, unsigned char len)
{
unsigned char ret = 0;
unsigned char *pstr;
unsigned char i, n;
for(i=1; at_cmd_func[i].cmd != AT_END; i++)
{
n = mstrlen(at_cmd_func[i].str);
if(!mstrncmp(p, at_cmd_func[i].str, n)){
ret = i;
break;
}
}
return ret;
}
/* AT指令解析 */
unsigned char at_cmd_parse(unsigned char *p, unsigned char len){
unsigned char ret = AT_SUCCESS;
unsigned char index = 0;
unsigned char n;
if(len < 4) {
return AT_ERR;
}
if((p[0] == 'A') && (p[1] == 'T') && (p[len-2] == 0x0D) && (p[len-1] == 0x0A)) {
if(len == 4) { /* 測試指令 */
if(at_cmd_func[AT_CMD_TEST].cb != NULL) {
at_cmd_func[AT_CMD_TEST].cb(NULL, 0); /* 執(zhí)行測試指令 */
}
}else if(p[2] == '+') { /* 執(zhí)行指令解析 */
index = AT_cmd_search(p, len); /* 查找匹配的執(zhí)行指令, 0-已匹配, !0-未匹配*/
if(index) {
if(at_cmd_func[index].cb != NULL) {
n = mstrlen(at_cmd_func[index].str);
ret = at_cmd_func[index].cb(p+n, len-n); /* 執(zhí)行對應(yīng)的指令函數(shù), p+n:將指令參數(shù)傳輸執(zhí)行函數(shù),len-n-2:指令參數(shù)有效長度 */
}else {
ret = AT_ERR_FUN_UNUSED; /* 沒有可執(zhí)行函數(shù) */
}
}else {
ret = AT_ERR_UNINVAL; /* 未找到匹配的指令 */
}
}else { /* 格式不匹配 */
return AT_ERR;
}
return ret;
}
}
【測試】
我在接收到指令后執(zhí)行at_cmd_parse 發(fā)送AT、AT+SETRTC=成功的返回需要的信息。

審核編輯:湯梓紅
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
指令
+關(guān)注
關(guān)注
1文章
623瀏覽量
37529 -
串口
+關(guān)注
關(guān)注
15文章
1619瀏覽量
82811 -
開發(fā)板
+關(guān)注
關(guān)注
26文章
6289瀏覽量
118063 -
上位機
+關(guān)注
關(guān)注
27文章
1002瀏覽量
57049 -
CW32
+關(guān)注
關(guān)注
1文章
299瀏覽量
1846
發(fā)布評論請先 登錄
相關(guān)推薦
熱點推薦
基于CW32L083的AT指令框架的創(chuàng)建
框架的創(chuàng)建。
首先定義了指令結(jié)構(gòu):
typedefenum{
AT_CMD_TEST=0, /* 測試指令 */
AT_CMD_SETRTC,/* 設(shè)置RTC指令 */
發(fā)表于 01-06 06:17
請問如何解決CW32L083系列微控制器在通信過程中可能出現(xiàn)的數(shù)據(jù)錯誤問題?
如何解決CW32L083系列微控制器在通信過程中可能出現(xiàn)的數(shù)據(jù)錯誤問題?
發(fā)表于 12-16 08:01
在進行低功耗設(shè)計時如何優(yōu)化CW32L083系列微控制器的功耗?
在進行低功耗設(shè)計時,如何優(yōu)化CW32L083系列微控制器的功耗?
發(fā)表于 12-16 06:03
請問CW32L083如何實現(xiàn)AUTOTRIM時鐘校準(zhǔn)?
如題,CW32L083如何實現(xiàn)AUTOTRIM時鐘校準(zhǔn)?有沒有HSIOSC時鐘校準(zhǔn)編程示例?
發(fā)表于 12-16 06:02
請問如何利用CW32L083系列微控制器的內(nèi)部Flash存儲器進行程序升級和數(shù)據(jù)存儲?
如何利用CW32L083系列微控制器的內(nèi)部Flash存儲器進行程序升級和數(shù)據(jù)存儲?
發(fā)表于 12-15 07:39
在開發(fā)過程中如何利用CW32L083系列微控制器的官方固件庫進行程序編寫和調(diào)試?
在開發(fā)過程中,如何利用CW32L083系列微控制器的官方固件庫進行程序編寫和調(diào)試?
發(fā)表于 12-15 07:23
CW32L083的基本定時器
CW32L083 內(nèi)部集成 3 個基本定時器 (BTIM),每個 BTIM 完全獨立且功能完全相同,各包含一個 16bit 自動重裝 載計數(shù)器并由一個可編程預(yù)分頻器驅(qū)動。BTIM 支持定時器模式
發(fā)表于 12-15 06:23
在使用CW32L083系列微控制器時如何進行系統(tǒng)復(fù)位和看門狗定時器配置?
在使用CW32L083系列微控制器時,如何進行系統(tǒng)復(fù)位和看門狗定時器配置?
發(fā)表于 12-10 06:46
基于CW32L083的AT指令框架
評論