女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于多處理器系統的串行通信方式研究

電子設計 ? 來源:單片機及嵌入式系統應用 ? 作者:崔鳳新;廖明燕; ? 2021-06-17 15:41 ? 次閱讀

作者:崔鳳新;廖明燕;鄭金吾

單片機系統中,多處理器是指多個相同類型或者不同類型的單片機協作處理同一個系統的不同工作。它們之間必須具備一定的數據交換和協作處理能力,共同完成一個系統化的工作。不同處理器之間可以采用數據交換方式、并行總線方式、串行總線方式進行通信。其中,數據交換方式又可以稱為共享內存交換方式;串行總線方式又可以分為單總線方式、集成電路之間的通信方式和UART方式。

1 MSP430多處理器

MSP430是一款超低功耗的混合信號控制器,具有1 6位RISC結構,有著豐富的片內外設,主要包括有看門狗定時器比較器、硬件乘法器、液晶驅動器、ADC、I/0端口、串口(USART)等等,還集成有64 KB的Flas’E-ROM和2 KB的RAM。其功能強大,應用場合廣泛。但是在大型復雜的場合或者實時性要求較高的場合,使用一個處理器處理所有的業務,總是顯得有些不足。引入多個MsP430處理器協作工作的模式,可以提高系統的實時性、可靠性和適用性。

在多數場合,MSP430無須為每個處理器擴展FlashROM,也無須擴展RAM,采用共享內存的數據交換方式組成多處理器系統并非最佳選擇。此外,MSP430包括有兩個串口(USART),在MSP430的應用中,可以把兩組串行端口中的一個供外部通信使用,另一個串行端口供內部通信使用。采用串行總線中的串行通信方式組成多處理器系統是比較理想的選擇。

2 技術要點

2.1 MSP430多處理器組成

MSP430具有兩個串行端口(USART),可以使用其中的一個作為多處理器之間的通信端口。由于串行通信的架構限制,MSP430采用UART串行通信模式組成的多處理器系統,必須建立一個主處理器和若干從處理器。主處理器的TXD端與所有從處理器的RXD端相連,所有從處理器的TXD端與主處理器的RXD端相連。MSP43O多處理器拓撲結構如圖1所示。

在這個結構中,主處理器通過TXD端發送出指令報文,傳輸到從處理器的RXD接收端;從處理器對指令報文進行解包并且對這個指令報文進行響應。從處理器的響應報文通過TXD發送到主處理器的RXD接收端,主處理器獲取響應報文確認指令是否被正確執行。從這個結構上看,主處理器可以與任何從處理器進行通信,任何從處理器也可以和主處理器進行通信,但是從處理器與從處理器之間卻不可以進行直接的通信。

2.2 多處理器系統串行通信協議

在多處理器系統的串行通信方式中,可以有若干種通信協議進行選擇,如ModBus、Brooks、工業總線協議等等。在此,可以選擇業界通用的MocBus通信協議作為處理器與處理器之間的通信協議。

2.3 ModBus通信協議

Modbus協議支持傳統的RS232RS422RS485以太網設備。ModBus協議包括ASCII、RTU、TCP等報文格式,并沒有規定物理層。此協議定義了控制器能夠認識和使用的消息結構,而不管它們是經過何種網絡進行通信的。ModBtls的ASCII、RTU協議規定了消息和數據的結構、命令和就答的方式,數據通信采用Master/Slave方式。Master端發出數據請求消息,Slave端接收到正確消息后就可以發送數據到Mastez端,以響應請求;Master端也可以直接發消息修改Slave端的數據,實現雙向讀寫。

2.4 ModBus在多處理器系統中的報文格式

由于是一個主服務器對應多個從處理器的系統,處理器與處理器之間的報文傳輸必須明確標注目標地址和源地址,以免不相干的處理器之間進行誤導操作。除此以外,為了提高主處理器的處理能力,同時避免不同處理器存在報文相應速度差,以及不同指令任務之間存在處理量差異的問題,必須采用異步通信模式進行通信。要滿足異步通信模式,必須在報文中對每次的通信操作加注請求報文的16位標示(可以稱之為句柄),同時對這些句柄進行記錄。

2.4.1 數據讀取請求報文格式

源地址:主處理器地址。

目標地址:指令目的地地址(從處理器)。

句柄:指令請求標示號。

功能代碼:操作指令代碼。

起始地址:讀取從處理器數據寄存器的起始地址。

字節數:操作所涉及的寄存器字。

校驗碼:CRC校驗碼或者LRC校驗碼。

2.4.2 數據讀取應答報文格式

源地址:從處理器地址。

目標地址:主處理器地址。

句柄:指令請求標示號。

功能代碼:操作指令代碼。

數據字節數:操作所涉及的寄存器字節數。

數據1至數據n:數據。

校驗碼:CRC校驗碼或者LRC校驗碼。

其中,應答報文中的目標地址等價于請求報文中的源地址,應答報文中的源地址等價于請求報文中的目標地址。

2.5 校驗碼

在ModBus中,通用的校驗方式是ASCII協議方式采用LRC校驗方式,RTU協議方式采用CRC校驗方式。

2.5.1 LRC校驗

LRC校驗比較簡單。它在ASCII協議中使用,檢測了消息域中除開始的冒號及結束的回車換行號外的內容。它僅僅是把每一個需要傳輸的數據按字節疊加后取反加1即可。下面是它的C代碼:

BYTE GetCheckCode(const char*pSendBuf,Int nEnd)

{ //獲得校驗碼

BYTE byLrc=O。

char pBuf;

int nData=0

for(i=1;i {//每兩個需要發送的ASCII碼轉化為一個十六進制數

pBuf[O]=pSendBuf;

pBu=pSendBuf;

pBuf=、O’;

sscanf(pBuf,”%x”,& nData);

bvLrc+=nData;

byhc=~byLrc;

byLrc++

return byLrc;

}

2.5.2 CRC校驗

CRC是先調入一值是全“1”的16位寄存器,然后調用一過程將消息中連續的8位字節和當前寄存器中的值進行處理。僅每個字符中的8位數據對CRC有效,起始位和停止位以及奇偶校驗位均無效。

CRC產生過程中,每個8位字符都單獨和寄存器內容相或(OR),結果向最低有效位方向移動,最高有效位以0填充。LSB被提取出來檢測。如果LSB為1,寄存器單獨和預置的值“或”一下;如果LSB為O,則不進行。整個過程要重復8次。在最后一位(第8位)完成后,下一個8位字節又單獨和寄存器的當前值相“或”。最終寄存器中的值,是消息中所有字節都執行之后的CRC值。

CRC添加到消息中時,低字節先加入,然后高字節加入。下面是它的C代碼:

WORD GetCheckCode(const char*pSendBuf,int nEnd)

{ //獲得校驗碼

WORD wCrc=WORD(0xFFFF);

for(int i=O;i wCrc^=WoRD(BYTE(pSendBuf);

for(Intj=O;j《8;J++){

if(wCrc&1){

wCrc》》=l;

wCrc^一OxA00l:

}

else{

wCrc》》=1;

retIlrIl wCrc:

3 報文示范

ModBus包含ASCII和RTU兩種報文格式。RTU報文較短,但是沒有邊界定義;ASCII報文較長,但是邊界明了。在多處理器通信之中,由于通信距離很短,干擾較小,因此可以選擇較高的通信速率。通信速率提高了,報文長度較長對通信的影響不大,因此可以選擇ASCII報文格式進行通信。

ModBus的ASCII讀取請求報文格式如下:

假設主機地址01,要對從機地址02進行讀取247和248地址的兩個寄存器值的通信,并且本次通信為第1次通信,設定流水號為000l。

4 結 語

多處理器協作工作模式和通信協議,已經成功應于CNG加氣機,使系統信息交換更加迅速、可靠,整個系統的性能得到了提高。

責任編輯:gt

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 處理器
    +關注

    關注

    68

    文章

    19801

    瀏覽量

    233519
  • 單片機
    +關注

    關注

    6063

    文章

    44915

    瀏覽量

    646834
  • 定時器
    +關注

    關注

    23

    文章

    3287

    瀏覽量

    117199
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    請問有誰做過串口的多處理器通信嗎?

    原子哥,論壇上的大神們,有做過串口的多處理器通信么?如果有,大家是用空總線檢測還是用地址標記的方式啊?
    發表于 09-05 04:35

    什么是STM8多處理器通信

    STM8多處理器通信是什么
    發表于 11-12 06:27

    什么是MSP430多處理器?MSP430多處理器有哪些技術要點?

    什么是MSP430多處理器?MSP430多處理器有哪些技術要點?
    發表于 05-27 06:52

    多處理器通信和LIN模式區別是什么?

    多處理器通信和LIN模式區別是什么?
    發表于 12-08 07:32

    異構多處理器系統Cache一致性解決方案

    SoC技術的發展使多個異構的處理器集成到一個芯片成為可能,這種結構已成為提高微處理器性能的重要途徑。與傳統的多處理器系統一樣,Cache一致性問題也是片內異構
    發表于 09-26 15:02 ?11次下載

    多處理器分組實時調度算法

    多處理器實時調度理論是目前實時系統的關鍵技術。論文研究了PFair 調度算法在多處理器中的調度理論,在此基礎上,提出了一種基于PFair 調度算法的
    發表于 12-18 15:38 ?11次下載

    基于NiosII的SOPC多處理器系統設計方法

    基于NiosII的SOPC多處理器系統設計方法 兩個或多個微處理器一起工作來完成某個任務的系統稱為“多處理器
    發表于 10-17 09:28 ?1317次閱讀
    基于NiosII的SOPC<b class='flag-5'>多處理器</b><b class='flag-5'>系統</b>設計方法

    嵌入式異構多處理器系統中的通信實現

    摘要:提出一種嵌入式異構多處理器系統的結構模型,論述這種系統通信機制,并闡述在基于這種嵌入式異構多處理器
    發表于 03-01 01:34 ?47次下載

    什么是同步多處理器

    同步多處理器,英文為Synchronous Multi-Processors,縮寫為SMP。同步多處理器系統在工作的時候,每當一個任務完成后,空閑的處理器會立刻尋找下一個新的任務,對于
    發表于 06-02 09:16 ?1247次閱讀

    GPGPU流式多處理器架構剖析(上)

    具有較小結構的CPU,支持指令并行(多發射)。流式多處理器是線程塊的運行載體,但一般不支持亂序執行。每個流式多處理器上的單個Warp以SIMD方式執行相同指令。
    的頭像 發表于 04-03 14:28 ?2370次閱讀
    GPGPU流式<b class='flag-5'>多處理器</b>架構剖析(上)

    GPGPU流式多處理器架構剖析(下)

    具有較小結構的CPU,支持指令并行(多發射)。流式多處理器是線程塊的運行載體,但一般不支持亂序執行。每個流式多處理器上的單個Warp以SIMD方式執行相同指令。
    的頭像 發表于 04-03 14:28 ?2085次閱讀
    GPGPU流式<b class='flag-5'>多處理器</b>架構剖析(下)

    基于VPX6—460的多處理器通信設計

    電子發燒友網站提供《基于VPX6—460的多處理器通信設計.pdf》資料免費下載
    發表于 11-08 14:37 ?0次下載
    基于VPX6—460的<b class='flag-5'>多處理器</b><b class='flag-5'>通信</b>設計

    基于VPX6-460的多處理器通信設計

    電子發燒友網站提供《基于VPX6-460的多處理器通信設計.pdf》資料免費下載
    發表于 11-13 10:13 ?0次下載
    基于VPX6-460的<b class='flag-5'>多處理器</b><b class='flag-5'>通信</b>設計

    對稱多處理器和非對稱多處理器的區別

    隨著計算需求的日益增長,單處理器系統已經無法滿足高性能計算的需求。多處理器系統應運而生,它們通過將多個處理器集成到一個
    的頭像 發表于 10-10 15:58 ?2001次閱讀

    對稱多處理器的特點是什么

    對稱多處理器(Symmetric Multi-Processing,簡稱SMP)是一種多處理器系統,其中多個處理器共享相同的物理內存和其他資源,并且操作
    的頭像 發表于 10-10 16:36 ?823次閱讀