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

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

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

ToolKit是一套應(yīng)用于嵌入式系統(tǒng)的通用工具包

技術(shù)讓夢(mèng)想更偉大 ? 來(lái)源:技術(shù)讓夢(mèng)想更偉大 ? 2023-04-17 10:04 ? 次閱讀

1、介紹

ToolKit是一套應(yīng)用于嵌入式系統(tǒng)的通用工具包,可靈活應(yīng)用到有無(wú)RTOS的程序中,采用C語(yǔ)言面向?qū)ο蟮乃悸穼?shí)現(xiàn)各個(gè)功能,盡可能最大化的復(fù)用代碼,目前為止工具包包含:循環(huán)隊(duì)列、軟件定時(shí)器、事件集。

  • ?Queue循環(huán)隊(duì)列

  1. 1. 支持動(dòng)態(tài)、靜態(tài)方式進(jìn)行隊(duì)列的創(chuàng)建與刪除。

  2. 2. 可獨(dú)立配置緩沖區(qū)大小。

  3. 3.支持?jǐn)?shù)據(jù)最新保持功能,當(dāng)配置此模式并且緩沖區(qū)已滿,若有新的數(shù)據(jù)存入,將會(huì)移除最早數(shù)據(jù),并保持緩沖區(qū)已滿。

  • ?Timer軟件定時(shí)器

  1. 1. 支持動(dòng)態(tài)、靜態(tài)方式進(jìn)行定時(shí)器的創(chuàng)建與刪除。

  2. 2.支持循環(huán)單次模式。

  3. 3. 可配置有無(wú)超時(shí)回調(diào)函數(shù)。

  4. 4.可配置定時(shí)器工作在周期間隔模式。

  5. 5. 使用雙向鏈表,超時(shí)統(tǒng)一管理,不會(huì)因?yàn)樵黾佣〞r(shí)器而增加超時(shí)判斷代碼。

  • ?Event事件集

  1. 1. 支持動(dòng)態(tài)、靜態(tài)方式進(jìn)行事件集的創(chuàng)建與刪除。

  2. 2.每個(gè)事件最大支持32個(gè)標(biāo)志位。

  3. 3.事件的觸發(fā)可配置為“標(biāo)志與”“標(biāo)志或”。

2 、文件目錄

toolkit
├──include//包含文件目錄
|├──toolkit.h//toolkit頭文件
|└──toolkit_cfg.h//toolkit配置文件
├──src//toolkit源碼目錄
|├──tk_queue.c//循環(huán)隊(duì)列源碼
|├──tk_timer.c//軟件定時(shí)器源碼
|└──tk_event.c//事件集源碼
├──samples//例子
|├──tk_queue_samples.c//循環(huán)隊(duì)列使用例程源碼
|├──tk_timer_samples.c//軟件定時(shí)器使用例程源碼
|└──tk_event_samples.c//事件集使用例程源碼
└──README.md//說(shuō)明文檔

3 、函數(shù)定義

3.1 配置文件


  • ?ToolKit配置項(xiàng)

    宏定義 描述
    TOOLKIT_USING_ASSERT ToolKit使用斷言功能
    TOOLKIT_USING_QUEUE ToolKit使用循環(huán)隊(duì)列功能
    TOOLKIT_USING_TIMER ToolKit使用軟件定時(shí)器功能
    TOOLKIT_USING_EVENT ToolKit使用事件集功能
  • ?Queue 循環(huán)隊(duì)列配置項(xiàng)

    宏定義 描述
    TK_QUEUE_USING_CREATE Queue 循環(huán)隊(duì)列使用動(dòng)態(tài)創(chuàng)建和刪除
  • ?Timer 軟件定時(shí)器配置項(xiàng)

    宏定義 描述
    TK_TIMER_USING_CREATE Timer 軟件定時(shí)器使用動(dòng)態(tài)創(chuàng)建和刪除
    TK_TIMER_USING_INTERVAL Timer 軟件定時(shí)器使用間隔模式
    TK_TIMER_USING_TIMEOUT_CALLBACK Timer 軟件定時(shí)器使用超時(shí)回調(diào)函數(shù)
  • ?Event 事件集配置項(xiàng)

    宏定義 描述
    TK_EVENT_USING_CREATE Event 事件集使用動(dòng)態(tài)創(chuàng)建和刪除

說(shuō)明:當(dāng)配置TOOLKIT_USING_ASSERT后,所有功能都將會(huì)啟動(dòng)參數(shù)檢查。

3.2 Queue 循環(huán)隊(duì)列API函數(shù)


以下為詳細(xì)API說(shuō)明及簡(jiǎn)要示例程序,綜合demo可查看tk_queue_samples.c示例。

3.2.1 動(dòng)態(tài)創(chuàng)建隊(duì)列

注意:當(dāng)配置TOOLKIT_USING_QUEUE后,才能使用此函數(shù)。此函數(shù)需要用到malloc

structtk_queue*tk_queue_create(uint16_tqueue_size,uint16_tmax_queues,boolkeep_fresh);
參數(shù) 描述
queue_size 緩存區(qū)大小(單位字節(jié))
max_queues 最大隊(duì)列個(gè)數(shù)
keep_fresh 是否為保持最新模式,true:保持最新;false:默認(rèn)(存滿不能再存)
返回值 創(chuàng)建的隊(duì)列對(duì)象(NULL為創(chuàng)建失?。?/td>

隊(duì)列創(chuàng)建示例:

intmain(intargc,char*argv[])
{
/*動(dòng)態(tài)方式創(chuàng)建一個(gè)循環(huán)隊(duì)"queue",緩沖區(qū)大小50字節(jié),不保持最新*/
structtk_queue*queue=tk_queue_create(50,1,false);
if(queue==NULL){
printf("隊(duì)列創(chuàng)建失敗!
");
}
/*...*/
/*Youcanaddyourcodeunderhere.*/
return0;
}

3.2.2動(dòng)態(tài)刪除隊(duì)列

注意:當(dāng)配置TOOLKIT_USING_QUEUE后,才能使用此函數(shù)。此函數(shù)需要用到free。必須為動(dòng)態(tài)方式創(chuàng)建的隊(duì)列對(duì)象。

booltk_queue_delete(structtk_queue*queue);
參數(shù) 描述
queue 要?jiǎng)h除的隊(duì)列對(duì)象
返回值 true:刪除成功;false:刪除失敗

3.2.3靜態(tài)初始化隊(duì)列

booltk_queue_init(structtk_queue*queue,void*queuepool,uint16_tpool_size,uint16_tqueue_size,boolkeep_fresh);
參數(shù) 描述
queue 要初始化的隊(duì)列對(duì)象
*queuepool 隊(duì)列緩存區(qū)
pool_size 緩存區(qū)大小(單位字節(jié))
queue_size 隊(duì)列元素大小(單位字節(jié))
keep_fresh 是否為保持最新模式,true:保持最新;false:默認(rèn)(存滿不能再存)
返回值 true:初始化成功;false:初始化失敗

隊(duì)列創(chuàng)建示例:

intmain(intargc,char*argv[])
{
/*定義一個(gè)循環(huán)隊(duì)列*/
structtk_queuequeue;
/*定義循環(huán)隊(duì)列緩沖區(qū)*/
uint8_tqueue_pool[100];
/*靜態(tài)方式創(chuàng)建一個(gè)循環(huán)隊(duì)列"queue",緩存區(qū)為queue_pool,大小為queue_pool的大小,模式為保持最新*/
if(tk_queue_init(&queue,queue_pool,sizeof(queue_pool),
sizeof(queue_pool[0]),true)==false){
printf("隊(duì)列創(chuàng)建失敗!
");
}
/*...*/
/*Youcanaddyourcodeunderhere.*/
}

3.2.4 靜態(tài)脫離隊(duì)列

注意: 會(huì)使緩存區(qū)脫離與隊(duì)列的關(guān)聯(lián)。必須為靜態(tài)方式創(chuàng)建的隊(duì)列對(duì)象。

booltk_queue_detach(structtk_queue*queue);
參數(shù) 描述
queue 要脫離的隊(duì)列對(duì)象
返回值 true:脫離成功;false:脫離失敗

3.2.5 清空隊(duì)列

booltk_queue_clean(structtk_queue*queue);
參數(shù) 描述
queue 要清空的隊(duì)列對(duì)象
返回值 true:清除成功;false:清除失敗

3.2.6 判斷隊(duì)列是否為空

booltk_queue_empty(structtk_queue*queue);
參數(shù) 描述
queue 要查詢的隊(duì)列對(duì)象
返回值 true:空;false:不為空

3.2.7 判斷隊(duì)列是否已滿

booltk_queue_full(structtk_queue*queue);
參數(shù) 描述
queue 要查詢的隊(duì)列對(duì)象
返回值 true:滿;false:不為滿

3.2.8 從隊(duì)列中讀取一個(gè)元素(不從隊(duì)列中刪除)

booltk_queue_peep(structtk_queue*queue,void*pval);
參數(shù) 描述
queue 隊(duì)列對(duì)象
*pval 讀取值地址
返回值 true:讀取成功;false:讀取失敗

3.2.9 移除一個(gè)元素

booltk_queue_remove(structtk_queue*queue);
參數(shù) 描述
queue 要移除元素的對(duì)象
返回值 true:移除成功;false:移除失敗

3.2.10 向隊(duì)列壓入(入隊(duì))1個(gè)元素?cái)?shù)據(jù)

booltk_queue_push(structtk_queue*queue,void*val);
參數(shù) 描述
queue 要壓入的隊(duì)列對(duì)象
*val 壓入值
返回值 true:成功;false:失敗

3.2.11 從隊(duì)列彈出(出隊(duì))1個(gè)元素?cái)?shù)據(jù)

booltk_queue_pop(structtk_queue*queue,void*pval);
參數(shù) 描述
queue 要彈出的隊(duì)列對(duì)象
*pval 彈出值
返回值 true:成功;false:失敗

3.2.12 查詢隊(duì)列當(dāng)前數(shù)據(jù)長(zhǎng)度

uint16_ttk_queue_curr_len(structtk_queue*queue);
參數(shù) 描述
queue 要查詢的隊(duì)列對(duì)象
返回值 隊(duì)列數(shù)據(jù)當(dāng)前長(zhǎng)度

3.2.13 向隊(duì)列壓入(入隊(duì))多個(gè)元素?cái)?shù)據(jù)

uint16_ttk_queue_push_multi(structtk_queue*queue,void*pval,uint16_tlen);
參數(shù) 描述
queue 要壓入的隊(duì)列對(duì)象
*pval 壓入數(shù)據(jù)首地址
len 壓入元素個(gè)數(shù)
返回值 實(shí)際壓入個(gè)數(shù)

3.2.14 從隊(duì)列彈出(出隊(duì))多個(gè)元素?cái)?shù)據(jù)

uint16_ttk_queue_pop_multi(structtk_queue*queue,void*pval,uint16_tlen);
參數(shù) 描述
queue 要彈出的隊(duì)列對(duì)象
*pval 存放彈出數(shù)據(jù)的首地址
len 希望彈出的數(shù)據(jù)個(gè)數(shù)
返回值 實(shí)際彈出個(gè)數(shù)

3.3 Timer 軟件定時(shí)器API函數(shù)


以下為詳細(xì)API說(shuō)明及簡(jiǎn)要示例程序,綜合demo可查看tk_timer_samples.c示例。

3.3.1 軟件定時(shí)器功能初始化

注意:此函數(shù)在使用定時(shí)器功能最初調(diào)用,目的是創(chuàng)建定時(shí)器列表頭結(jié)點(diǎn),和配置tick獲取回調(diào)函數(shù)。

booltk_timer_func_init(uint32_t(*get_tick_func)(void));
參數(shù) 描述
get_tick_func 獲取系統(tǒng)tick回調(diào)函數(shù)
返回值 true:初始化成功;false:初始化失敗

3.3.2 動(dòng)態(tài)創(chuàng)建定時(shí)器

注意:當(dāng)配置TOOLKIT_USING_TIMER后,才能使用此函數(shù)。此函數(shù)需要用到malloc

structtk_timer*tk_timer_create(void(*timeout_callback)(structtk_timer*timer));
參數(shù) 描述
timeout_callback 定時(shí)器超時(shí)回調(diào)函數(shù),不使用可配置為NULL
返回值 創(chuàng)建的定時(shí)器對(duì)象(NULL為創(chuàng)建失敗)

定時(shí)器創(chuàng)建示例:

/*定義獲取系統(tǒng)tick回調(diào)函數(shù)*/
uint32_tget_sys_tick(void)
{
returntick;
}

/*定時(shí)器超時(shí)回調(diào)函數(shù)*/
voidtimer_timeout_callback(structtk_timer*timer)
{
printf("timeout_callback:timertimeout:%ld
",get_sys_tick());
}

intmain(intargc,char*argv[])
{
/*初始化軟件定時(shí)器功能,并配置tick獲取回調(diào)函數(shù)*/
tk_timer_func_init(get_sys_tick);

/*定義定時(shí)器指針*/
tk_timer_ttimer=NULL;
/*動(dòng)態(tài)方式創(chuàng)建timer,并配置定時(shí)器超時(shí)回調(diào)函數(shù)*/
timer=tk_timer_create((tk_timer_timeout_callback*)timer_timeout_callback);
if(timer==NULL)
{
printf("定時(shí)器創(chuàng)建失敗!
");
return0;
}
/*...*/
/*Youcanaddyourcodeunderhere.*/
return0;
}

3.3.3 動(dòng)態(tài)刪除定時(shí)器

當(dāng)配置TOOLKIT_USING_TIMER后,才能使用此函數(shù)。此函數(shù)需要用到free。必須為動(dòng)態(tài)方式創(chuàng)建的定時(shí)器對(duì)象。

booltk_timer_delete(structtk_timer*timer);
參數(shù) 描述
timer 要?jiǎng)h除的定時(shí)器對(duì)象
返回值 true:刪除成功;false:刪除失敗

3.3.4 靜態(tài)初始化定時(shí)器

booltk_timer_init(structtk_timer*timer,void(*timeout_callback)(structtk_timer*timer));
參數(shù) 描述
timer 要初始化的定時(shí)器對(duì)象
timeout_callback 定時(shí)器超時(shí)回調(diào)函數(shù),不使用可配置為NULL
返回值 true:創(chuàng)建成功;false:創(chuàng)建失敗

隊(duì)列創(chuàng)建示例:

/*定義獲取系統(tǒng)tick回調(diào)函數(shù)*/
uint32_tget_sys_tick(void)
{
returntick;
}

/*定時(shí)器超時(shí)回調(diào)函數(shù)*/
voidtimer_timeout_callback(structtk_timer*timer)
{
printf("timeout_callback:timertimeout:%ld
",get_sys_tick());
}

intmain(intargc,char*argv[])
{
/*定義定時(shí)器timer*/
structtk_timertimer;
boolresult=tk_timer_init(&timer,(tk_timer_timeout_callback*)timer_timeout_callback);
if(result==NULL)
{
printf("定時(shí)器創(chuàng)建失敗!
");
return0;
}
/*...*/
/*Youcanaddyourcodeunderhere.*/
return0;
}

3.3.5 靜態(tài)脫離定時(shí)器

注意: 會(huì)將timer從定時(shí)器鏈表中移除。必須為靜態(tài)方式創(chuàng)建的定時(shí)器對(duì)象。

booltk_timer_detach(structtk_timer*timer);
參數(shù) 描述
timer 要脫離的定時(shí)器對(duì)象
返回值 true:脫離成功;false:脫離失敗

3.3.6 定時(shí)器啟動(dòng)

booltk_timer_start(structtk_timer*timer,tk_timer_modemode,uint32_tdelay_tick);
參數(shù) 描述
timer 要啟動(dòng)的定時(shí)器對(duì)象
mode 工作模式,單次:TIMER_MODE_SINGLE;循環(huán):TIMER_MODE_LOOP
delay_tick 定時(shí)器時(shí)長(zhǎng)(單位tick)
返回值 true:?jiǎn)?dòng)成功;false:?jiǎn)?dòng)失敗

3.3.7 定時(shí)器停止

booltk_timer_stop(structtk_timer*timer);
參數(shù) 描述
timer 要停止的定時(shí)器對(duì)象
返回值 true:停止成功;false:停止失敗

3.3.8 定時(shí)器繼續(xù)

booltk_timer_continue(structtk_timer*timer);
參數(shù) 描述
timer 要繼續(xù)的定時(shí)器對(duì)象
返回值 true:繼續(xù)成功;false:繼續(xù)失敗

3.3.9 定時(shí)器重啟

注意:重啟時(shí)長(zhǎng)為最后一次啟動(dòng)定時(shí)器時(shí)配置的時(shí)長(zhǎng)。

booltk_timer_restart(structtk_timer*timer);
參數(shù) 描述
timer 要重啟的定時(shí)器對(duì)象
返回值 true:重啟成功;false:重啟失敗

3.3.10 獲取定時(shí)器模式

tk_timer_modetk_timer_get_mode(structtk_timer*timer);
參數(shù) 描述
timer 要獲取的定時(shí)器對(duì)象
返回值 定時(shí)器模式
定時(shí)器模式 描述
TIMER_MODE_SINGLE 單次模式
TIMER_MODE_LOOP 循環(huán)模式

3.3.11 獲取定時(shí)器狀態(tài)

tk_timer_statetk_timer_get_state(structtk_timer*timer);
參數(shù) 描述
timer 要獲取的定時(shí)器對(duì)象
返回值 定時(shí)器狀態(tài)
定時(shí)器模式 描述
TIMER_STATE_RUNNING 運(yùn)行狀態(tài)
TIMER_STATE_STOP 停止?fàn)顟B(tài)
TIMER_STATE_TIMEOUT 超時(shí)狀態(tài)

3.3.12 定時(shí)器處理

booltk_timer_loop_handler(void);
參數(shù) 描述
返回值 true:正常;false:異常,在調(diào)用此函數(shù)前,未初始化定時(shí)器功能“tk_timer_func_init

注意:tk_timer_loop_handler函數(shù)要不斷的循環(huán)調(diào)用。

3.3.13 超時(shí)回調(diào)函數(shù)

函數(shù)原型

typedefvoid(*timeout_callback)(structtk_timer*timer);

說(shuō)明:超時(shí)回調(diào)函數(shù)可定義多個(gè),即一個(gè)定時(shí)器對(duì)應(yīng)一個(gè)回調(diào)函數(shù),也可多個(gè)定時(shí)器對(duì)應(yīng)一個(gè)回調(diào)函數(shù)。

一對(duì)一

/*定義兩個(gè)回調(diào)函數(shù),對(duì)應(yīng)定時(shí)器timer1和timer2*/
voidtimer1_timeout_callback(structtk_timer*timer){
printf("定時(shí)器1超時(shí)!
");
}
voidtimer2_timeout_callback(structtk_timer*timer){
printf("定時(shí)器2超時(shí)!
");
}
/*創(chuàng)建兩個(gè)定時(shí)器,配置單獨(dú)超時(shí)回調(diào)函數(shù)*/
timer1=tk_timer_create((timeout_callback*)timer1_timeout_callback);
timer2=tk_timer_create((timeout_callback*)timer2_timeout_callback);

多對(duì)一

/*定時(shí)器timer1和timer2共用一個(gè)回調(diào)函數(shù),在回調(diào)函數(shù)做區(qū)分*/
voidtimer_timeout_callback(structtk_timer*timer){
if(timer==timer1)
printf("定時(shí)器1超時(shí)!
");
elseif(timer==timer2)
printf("定時(shí)器2超時(shí)!
");
}
/*創(chuàng)建兩個(gè)定時(shí)器,使用相同的超時(shí)回調(diào)函數(shù)*/
timer1=tk_timer_create((timeout_callback*)timer_timeout_callback);
timer2=tk_timer_create((timeout_callback*)timer_timeout_callback);

3.4 Event 事件集API函數(shù)


以下為詳細(xì)API說(shuō)明及簡(jiǎn)要示例程序,綜合demo可查看tk_event_samples.c示例。

3.4.1 動(dòng)態(tài)創(chuàng)建一個(gè)事件

注意:當(dāng)配置TOOLKIT_USING_EVENT后,才能使用此函數(shù)。此函數(shù)需要用到malloc。

structtk_event*tk_event_create(void);
參數(shù) 描述
返回值 創(chuàng)建的事件對(duì)象(NULL為創(chuàng)建失敗)

3.4.2 動(dòng)態(tài)刪除一個(gè)事件

當(dāng)配置TOOLKIT_USING_TIMER后,才能使用此函數(shù)。此函數(shù)需要用到free。必須為動(dòng)態(tài)方式創(chuàng)建的事件對(duì)象。

booltk_event_delete(structtk_event*event);
參數(shù) 描述
event 要?jiǎng)h除的事件對(duì)象
返回值 true:刪除成功;false:刪除失敗

3.4.3 靜態(tài)初始化一個(gè)事件

booltk_event_init(structtk_event*event);
參數(shù) 描述
event 要初始化的事件對(duì)象
返回值 true:創(chuàng)建成功;false:創(chuàng)建失敗

3.4.4 發(fā)送事件標(biāo)志

booltk_event_send(structtk_event*event,uint32_tevent_set);
參數(shù) 描述
event 發(fā)送目標(biāo)事件對(duì)象
event_set 事件標(biāo)志,每個(gè)標(biāo)志占1Bit,發(fā)送多個(gè)標(biāo)志可“|”
返回值 true:發(fā)送成功;false:發(fā)送失敗

3.4.5 接收事件

booltk_event_recv(structtk_event*event,uint32_tevent_set,uint8_toption,uint32_t*recved);
參數(shù) 描述
event 接收目標(biāo)事件對(duì)象
event_set 感興趣的標(biāo)志,每個(gè)標(biāo)志占1Bit,多個(gè)標(biāo)志可“|”
option 操作,標(biāo)志與:TK_EVENT_OPTION_AND;標(biāo)志或:TK_EVENT_OPTION_OR;清除標(biāo)志:TK_EVENT_OPTION_CLEAR
返回值 true:發(fā)送成功;false:發(fā)送失敗
審核編輯 :李倩


聲明:本文內(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)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5087

    文章

    19153

    瀏覽量

    306426
  • 嵌入式系統(tǒng)
    +關(guān)注

    關(guān)注

    41

    文章

    3607

    瀏覽量

    129603
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    180

    文章

    7613

    瀏覽量

    137247

原文標(biāo)題:一個(gè)應(yīng)用于嵌入式的通用工具包!

文章出處:【微信號(hào):技術(shù)讓夢(mèng)想更偉大,微信公眾號(hào):技術(shù)讓夢(mèng)想更偉大】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    LabVIEW 2011模塊和工具包嵌入式設(shè)計(jì))

    `借助NI LabVIEW,將嵌入式應(yīng)用程序設(shè)計(jì)、建模并部署到各類處理目標(biāo)(包括:現(xiàn)成的實(shí)時(shí)系統(tǒng)和基于FPGA的系統(tǒng),以及自定義微處理器與微控制器設(shè)備)。包括LabVIEW RT模塊、LabVIEW FPGA 模塊、FPGA編譯
    發(fā)表于 08-02 15:32

    促進(jìn)ARM嵌入式發(fā)展的工具包簡(jiǎn)介

    促進(jìn)ARM嵌入式發(fā)展的工具包簡(jiǎn)介
    發(fā)表于 07-31 21:55

    求NI Modulation Toolkit工具包

    哪位大大有NI Modulation Toolkit工具包,可以分享下嗎,網(wǎng)上找不到下載資源。做調(diào)制信號(hào)可能要用到,感激不盡!
    發(fā)表于 03-15 22:35

    如何設(shè)計(jì)一套基于ARM和DSP的嵌入式數(shù)控機(jī)床控制系統(tǒng)?

    本文結(jié)合DNC技術(shù)的發(fā)展趨勢(shì),設(shè)計(jì)了一套基于ARM和DSP的嵌入式數(shù)控機(jī)床控制系統(tǒng)。
    發(fā)表于 04-25 09:18

    分享一套通用的開(kāi)發(fā)環(huán)境搭建教程

    針對(duì)嵌入式的開(kāi)發(fā),不同的開(kāi)發(fā)者使用不同的操作系統(tǒng),可能是Windows 或者 Linux,隨之而來(lái)所搭建的開(kāi)發(fā)環(huán)境亦不同。所以在這里希望分享一套通用的開(kāi)發(fā)環(huán)境搭建教程,主要是圍繞VS
    發(fā)表于 11-05 06:23

    介紹一套完整的針對(duì)嵌入式系統(tǒng)的自動(dòng)化動(dòng)態(tài)確認(rèn)測(cè)試平臺(tái)

    系統(tǒng)進(jìn)行實(shí)時(shí)、閉環(huán)、非侵入測(cè)試的自動(dòng)化測(cè)試平臺(tái),適用于嵌入式系統(tǒng)在設(shè)計(jì)、仿真、開(kāi)發(fā)、調(diào)試、測(cè)試、集成驗(yàn)證和維護(hù)等各階段配置項(xiàng)級(jí)別和
    發(fā)表于 12-17 06:58

    一套科學(xué)的嵌入式系統(tǒng)學(xué)習(xí)方法

    原因是沒(méi)有掌握科學(xué),有效的學(xué)習(xí)方法,所以本章主要將從學(xué)習(xí)人群、待學(xué)知識(shí)點(diǎn)、學(xué)習(xí)順序等幾個(gè)方面來(lái)闡述一套科學(xué)的嵌入式系統(tǒng)學(xué)習(xí)方法。1.1.1 學(xué)習(xí)人群從事嵌入式開(kāi)發(fā)的工程...
    發(fā)表于 12-22 07:12

    分享用于Arduino的嵌入式編程設(shè)計(jì)的工具包

    工具包用于Arduino的嵌入式編程設(shè)計(jì)。This file exchange submission is an Embedded Coder custom target for Arduino.
    發(fā)表于 12-22 08:16

    SCADE為嵌入式軟件提供了一套基于模型的開(kāi)發(fā)方式

    嵌入式技術(shù)是計(jì)算機(jī)發(fā)展的趨勢(shì)之,被廣泛應(yīng)用于工業(yè)和軍事領(lǐng)域。SCADE(高安全性的應(yīng)用程序開(kāi)發(fā)環(huán)境)為嵌入式軟件提供了一套基于模型的開(kāi)發(fā)方
    發(fā)表于 10-17 10:09 ?5次下載
    SCADE為<b class='flag-5'>嵌入式</b>軟件提供了<b class='flag-5'>一套</b>基于模型的開(kāi)發(fā)方式

    用于IAR嵌入式Workbench的Stellaris開(kāi)發(fā)評(píng)估工具包的詳細(xì)資料概述

    Stellaris開(kāi)發(fā)和評(píng)估工具包提供了個(gè)低成本的方式開(kāi)始使用Stellaris微控制器使用IAR系統(tǒng)嵌入式Workbench工具設(shè)計(jì)。
    發(fā)表于 05-09 15:49 ?6次下載
    <b class='flag-5'>用于</b>IAR<b class='flag-5'>嵌入式</b>Workbench的Stellaris開(kāi)發(fā)評(píng)估<b class='flag-5'>工具包</b>的詳細(xì)資料概述

    如何使用PIC32MZ嵌入式連接(EC)入門(mén)工具包的詳細(xì)使用說(shuō)明

    本文檔介紹了如何使用PIC32MZ嵌入式連接(EC)入門(mén)工具包(也稱為“入門(mén)工具包”)開(kāi)發(fā)工具在目標(biāo)板上仿真和調(diào)試固件。
    發(fā)表于 06-07 11:28 ?25次下載

    Arm?ML處理器 嵌入式評(píng)估工具包介紹

    Arm Ethos-U55是世界上第款microNPU。這是種新型的ML處理器,旨在加速嵌入式和物聯(lián)網(wǎng)設(shè)備上的ML推理。 評(píng)估工具包概述 此評(píng)估
    的頭像 發(fā)表于 03-30 14:39 ?8185次閱讀

    個(gè)嵌入式通用軟件包ToolKit

    ToolKit一套應(yīng)用于嵌入式系統(tǒng)通用工具包,可靈活應(yīng)用到有無(wú)RTOS的程序中,采用C語(yǔ)言面
    的頭像 發(fā)表于 04-17 09:32 ?1140次閱讀

    搭建一套優(yōu)秀的嵌入式軟件框架必備的通用工具包

    ToolKit一套應(yīng)用于嵌入式系統(tǒng)通用工具包,可靈活應(yīng)用到有無(wú)RTOS的程序中,采用C語(yǔ)言面
    的頭像 發(fā)表于 04-18 09:34 ?1021次閱讀

    基于Toolkit嵌入式軟件框架搭建方法

    ToolKit一套應(yīng)用于嵌入式系統(tǒng)通用工具包,可靈活應(yīng)用到有無(wú)RTOS的程序中,采用C語(yǔ)言面
    發(fā)表于 04-25 14:29 ?394次閱讀