基于MSGQ模塊的DSP的應(yīng)用簡(jiǎn)化方案
main()
if processor 0: 打開雇主消息隊(duì)列并
創(chuàng)建雇主線程。
if processor 1: 打開雇員消息隊(duì)列并
創(chuàng)建雇員線程。
打開錯(cuò)誤消息隊(duì)列并創(chuàng)建錯(cuò)誤線程。
srio_init to initialize peripheral
workerThread()
Loop
MSGQ_get message from the worker queue
確定發(fā)送器
向發(fā)送器發(fā)送特定數(shù)量的消息
bossThread()
MSGQ_locate to locate worker queue
Loop
MSGQ_alloc message
使用要接收的多個(gè)消息來(lái)填充消息。
MSGQ_setSrcQueue to embedded boss’s message queue
MSGQ_put message to reader
Loop
MSGQ_get message from the boss queue
errorThread()
Loop
MSGQ_get message from the error queue
Log MQT error via LOG_printf
在單個(gè)處理器上發(fā)送消息
下面將介紹在單個(gè)處理器上發(fā)送和接收消息的幕后情況,這個(gè)過程分為任務(wù)一和任務(wù)二。任務(wù)二由操作系統(tǒng)進(jìn)行調(diào)用,打開MSGQ隊(duì)列,并為該消息隊(duì)列指定 “pend”與“post”函數(shù)。如果沒有消息,則使用“pend”函數(shù),在而向消息隊(duì)列發(fā)送消息時(shí)則調(diào)用“post”函數(shù)。
如果MSGQ模塊獲得了沒有待決消息的信息,那么就可運(yùn)行任務(wù)一,但必須讀取隊(duì)列標(biāo)識(shí)符,并定位適當(dāng)?shù)年?duì)列,以免其位于不同的處理器上。通常在啟動(dòng)時(shí)定位隊(duì)列對(duì)性能幾乎沒有什么影響。此外,任務(wù)一在向任務(wù)二發(fā)送消息之前還必須為消息傳輸分配存儲(chǔ)器。
一旦任務(wù)一發(fā)送消息,就不能再對(duì)消息進(jìn)行處理,因?yàn)檫@時(shí)MSGQ已擁有該消息,MSGQ會(huì)將該消息分配給適當(dāng)?shù)年?duì)列。任務(wù)二獲得了有消息的信息,并準(zhǔn)備接收消息。一旦任務(wù)二獲得消息,就能夠?qū)ο⑦M(jìn)行重復(fù)使用,并將其發(fā)送回任務(wù)一。例如,如果兩個(gè)任務(wù)要將消息來(lái)回傳輸,那么就僅需分配開始的消息。若讀取器接收到消息,就能相應(yīng)地更新內(nèi)容,然后將其發(fā)回。這樣,任務(wù)二就能夠處理消息,一旦處理完成,消息就返回到存儲(chǔ)器管理,任務(wù)二也就不能再對(duì)該消息進(jìn)行處理。消息傳輸至此完成。消息傳遞可通過為數(shù)據(jù)移動(dòng)提供虛擬接口來(lái)顯著簡(jiǎn)化復(fù)雜處理器通信的開發(fā)與維護(hù)。
評(píng)論