99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

三種常見(jiàn)嵌入式設(shè)備通信協(xié)議

Q4MP_gh_c472c21 ? 2018-03-06 10:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

嵌入式設(shè)備與PC通訊的通信協(xié)議設(shè)計(jì)經(jīng)驗(yàn)

嵌入式設(shè)備在運(yùn)行中需要設(shè)置參數(shù),這個(gè)工作經(jīng)常由PC機(jī)來(lái)實(shí)現(xiàn),需要為雙方通信設(shè)計(jì)協(xié)議,有代表性協(xié)議是如下三種:

表1 三種常見(jiàn)通信協(xié)議

從上表可以看到,一般嵌入式設(shè)備內(nèi)存和運(yùn)算性能都有限,因此固定二進(jìn)制是首選通信協(xié)議。

一. 簡(jiǎn)單性

保證協(xié)議是一個(gè)簡(jiǎn)單的方案,晦澀難懂往往意味著實(shí)現(xiàn)困難和容易出錯(cuò)。協(xié)議的結(jié)構(gòu)宜采用平面方式,每個(gè)域作用明確,數(shù)據(jù)域盡可能設(shè)計(jì)得長(zhǎng)度和位置固定,注釋詳盡,文檔清晰,實(shí)例豐富,讓人盡快上手和理解。

協(xié)議一般都需要以下域:幀頭,長(zhǎng)度,幀類(lèi)型,目標(biāo)地址,源地址,數(shù)據(jù),校驗(yàn),幀尾。

二. 可擴(kuò)展

必須保證將來(lái)增加功能和更改硬件后協(xié)議仍能勝任工作,這往往是通過(guò)預(yù)留空間來(lái)實(shí)現(xiàn),協(xié)議的變更應(yīng)該只是量的增加,不至于引起協(xié)議結(jié)構(gòu)的變化。

三. 低耦合

理想情況下每個(gè)協(xié)議包是原子信息,即本協(xié)議包不與其他協(xié)議包牽連,以防止通訊丟幀和設(shè)置牽連帶來(lái)的錯(cuò)誤。

四. 穩(wěn)定性

協(xié)議包長(zhǎng)度適宜:太小包含的信息過(guò)少,協(xié)議包的種類(lèi)繁多,容易引起通訊混亂和牽連錯(cuò)誤;太大包含的信息過(guò)多,可讀性較差,組幀和解幀的工作困難,還會(huì)帶來(lái)通訊易受干擾的缺陷,一般協(xié)議長(zhǎng)度以最小原子性信息為標(biāo)尺。

協(xié)議必須包括校驗(yàn)機(jī)制,以便于接收方判別協(xié)議包正確完整接收,如果出錯(cuò)需要較好的機(jī)制來(lái)確保通訊成功(如重傳)。

五. 高效率

按信息類(lèi)型區(qū)分協(xié)議包類(lèi)別,如:設(shè)置網(wǎng)絡(luò)信息參數(shù),設(shè)置當(dāng)前運(yùn)行參數(shù),可以區(qū)分開(kāi)來(lái),方便程序處理。

將同種操作編碼為一個(gè)子集是一種高效手段,如Read操作,編碼為0x0010,Write操作,編碼為0x0020。

數(shù)據(jù)盡可能設(shè)計(jì)成同構(gòu)模式,如果實(shí)在有差異,至少將同類(lèi)型數(shù)據(jù)放置在一起,這樣程序可以充分利用指針和線(xiàn)性尋址加速處理。

六. 易實(shí)現(xiàn)

盡量減少?gòu)?fù)雜算法的使用,如,通訊鏈路穩(wěn)定,數(shù)據(jù)幀的校驗(yàn)碼可以由CheckSum代替CRC。除非資源非常緊張,否則不要將過(guò)多的信息擠壓在一個(gè)數(shù)據(jù)里,因?yàn)樗鼤?huì)帶來(lái)可讀性差和實(shí)現(xiàn)困難。

七.軟件開(kāi)發(fā)

盡可能地讓硬件ISR完成驅(qū)動(dòng)工作,不要讓“進(jìn)程”參與復(fù)雜的時(shí)序邏輯,否則處理器將步履蹣跚且邏輯復(fù)雜!如:

接收固定長(zhǎng)度的數(shù)據(jù)幀,可以使用DMA,每接收完一幀DMA_ISR向進(jìn)程發(fā)消息。小心處理DMA斷層異常(接收的數(shù)據(jù)幀長(zhǎng)度正常但數(shù)據(jù)錯(cuò)誤,數(shù)據(jù)為上幀的后半部分+本幀的前半部分)。

接收不定長(zhǎng)的數(shù)據(jù)幀,可以使用狀態(tài)機(jī),當(dāng)接收到“幀尾數(shù)據(jù)”時(shí)向進(jìn)程發(fā)消息。小心數(shù)據(jù)紊亂和超時(shí)異常(數(shù)據(jù)紊亂時(shí)需要將狀態(tài)機(jī)及時(shí)復(fù)位,超時(shí)一般使用定時(shí)器監(jiān)控)。

八. 考慮硬件

如果通信鏈路是高速總線(xiàn)(如SPORT可達(dá)100Mbps),一般設(shè)計(jì)成一幀產(chǎn)生一次中斷,它通過(guò)長(zhǎng)度觸發(fā)的DMA來(lái)實(shí)現(xiàn),需要將協(xié)議設(shè)計(jì)成固定長(zhǎng)度,如附錄A。它具備高效率,但靈活性較差。

如果通信鏈路是低速總線(xiàn)(如UART一般100kbps),一般接收一字節(jié)產(chǎn)生一次中斷,可以將協(xié)議設(shè)計(jì)成變長(zhǎng)幀,如附錄B。它具備高靈活性,但效率較低。

附錄A 一個(gè)基于DMA傳輸固定長(zhǎng)度的協(xié)議實(shí)例。

圖1顯示了PC發(fā)送數(shù)據(jù)幀的格式,總長(zhǎng)為64字節(jié),是4字節(jié)的整倍數(shù),符合絕大部分32位處理器結(jié)構(gòu)體對(duì)齊的特性。

0x3C:INT8U,幀頭,可見(jiàn)字符’<’

Len:INT8U,本幀的總數(shù)據(jù)長(zhǎng)度,在圖4即為64

Dst:INT8U,標(biāo)識(shí)目標(biāo)設(shè)備的ID號(hào)

Src:INT8U,標(biāo)識(shí)源設(shè)備的ID號(hào)

Data:56字節(jié)的存儲(chǔ)區(qū),內(nèi)容依賴(lài)于具體的通信幀(實(shí)例見(jiàn)表2)

Cmd:INT16U,數(shù)據(jù)幀的類(lèi)別

CS:INT8U, 對(duì)它前面所有數(shù)據(jù)(62字節(jié))進(jìn)行8位累加和校驗(yàn)

0x7D:INT8U, 幀尾,可見(jiàn)字符’}’

圖1 PC發(fā)送數(shù)據(jù)幀

表2 Data域數(shù)據(jù)結(jié)構(gòu)實(shí)例

附錄B 一個(gè)基于變長(zhǎng)格式的UART通信協(xié)議實(shí)例。

PC與iWL880A(一種無(wú)線(xiàn)通信產(chǎn)品,詳見(jiàn)www.rimelink.com)通信幀采用變長(zhǎng)格式,如下圖所示。大部分設(shè)備(常見(jiàn)為PC機(jī))對(duì)于接收以“回車(chē)符”的機(jī)制很好處理,協(xié)議中的Tail就等于0x0D(換行符)。

聲明:本文內(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)注

    5152

    文章

    19676

    瀏覽量

    317729
  • 通信協(xié)議
    +關(guān)注

    關(guān)注

    28

    文章

    1038

    瀏覽量

    41192

原文標(biāo)題:嵌入式設(shè)備與PC通訊的通信協(xié)議設(shè)計(jì)經(jīng)驗(yàn)

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    ElfBoard嵌入式教育科普|CAN接口全面解析

    CAN的全稱(chēng)是Controller Area Network,譯為控制器區(qū)域網(wǎng)絡(luò),是一用于車(chē)輛、電力系統(tǒng)、工業(yè)設(shè)備嵌入式系統(tǒng)的半雙工異步串行通信協(xié)議和物理接口。
    的頭像 發(fā)表于 05-28 16:30 ?1009次閱讀
    ElfBoard<b class='flag-5'>嵌入式</b>教育科普|CAN接口全面解析

    嵌入式教育科普|GPIO接口全面解析

    在現(xiàn)代科技領(lǐng)域,嵌入式系統(tǒng)接口作為信息交互的核心載體,發(fā)揮著至關(guān)重要的作用,各類(lèi)接口通過(guò)預(yù)定義的通信協(xié)議與標(biāo)準(zhǔn)化規(guī)范,可以實(shí)現(xiàn)設(shè)備間的精準(zhǔn)數(shù)據(jù)傳輸與智能控制。 作為嵌入式開(kāi)發(fā)的技
    的頭像 發(fā)表于 03-05 11:11 ?1840次閱讀
    <b class='flag-5'>嵌入式</b>教育科普|GPIO接口全面解析

    Modbus 轉(zhuǎn) Profinet:工業(yè)通信協(xié)議的橋梁

    1. 引言 在工業(yè)自動(dòng)化領(lǐng)域,Modbus 和 Profinet 是兩廣泛使用的通信協(xié)議。Modbus 是一串行通信協(xié)議,常用于連接工業(yè)電子設(shè)備
    的頭像 發(fā)表于 02-24 11:11 ?358次閱讀
    Modbus 轉(zhuǎn) Profinet:工業(yè)<b class='flag-5'>通信協(xié)議</b>的橋梁

    搞懂TTL、RS232、485通信協(xié)議

    本文介紹了TTL、RS232和RS485這三種常見(jiàn)通信協(xié)議的傳輸距離、應(yīng)用場(chǎng)景以及影響通信距離的各種因素。TTL是一短距離
    的頭像 發(fā)表于 01-16 10:59 ?7586次閱讀
    搞懂TTL、RS232、485<b class='flag-5'>通信協(xié)議</b>!

    總線(xiàn)通信協(xié)議解析及應(yīng)用

    在現(xiàn)代計(jì)算機(jī)系統(tǒng)中,總線(xiàn)通信協(xié)議扮演著至關(guān)重要的角色。它們定義了數(shù)據(jù)如何在處理器、內(nèi)存、輸入/輸出設(shè)備等組件之間傳輸。 總線(xiàn)通信協(xié)議的基本概念 總線(xiàn)通信協(xié)議是一組規(guī)則,它規(guī)定了數(shù)據(jù)在系
    的頭像 發(fā)表于 12-31 10:07 ?1072次閱讀

    ARM嵌入式通信協(xié)議及應(yīng)用

    隨著科技的飛速發(fā)展,嵌入式系統(tǒng)在各個(gè)領(lǐng)域扮演著越來(lái)越重要的角色。ARM處理器因其高性能、低功耗的特點(diǎn),在嵌入式系統(tǒng)中得到了廣泛應(yīng)用。通信協(xié)議作為嵌入式系統(tǒng)的重要組成部分,對(duì)于實(shí)現(xiàn)
    的頭像 發(fā)表于 12-28 09:18 ?962次閱讀

    常見(jiàn)串口通信協(xié)議 如何設(shè)置串口參數(shù)

    串口通信是一常見(jiàn)通信方式,廣泛應(yīng)用于計(jì)算機(jī)、嵌入式系統(tǒng)和各種電子設(shè)備之間。串口
    的頭像 發(fā)表于 12-27 09:51 ?3443次閱讀

    上位機(jī)通信協(xié)議詳解 嵌入式上位機(jī)設(shè)計(jì)流程

    上位機(jī)通信協(xié)議詳解 上位機(jī)通信協(xié)議是指上位機(jī)(通常是指具有強(qiáng)大計(jì)算能力和數(shù)據(jù)處理能力的計(jì)算機(jī)系統(tǒng))與下位機(jī)(如傳感器、執(zhí)行器等)之間進(jìn)行數(shù)據(jù)交換和通信所遵循的規(guī)則和標(biāo)準(zhǔn)。以下是對(duì)幾種常見(jiàn)
    的頭像 發(fā)表于 12-04 10:21 ?2994次閱讀

    串口通信協(xié)議解析 串口通信應(yīng)用實(shí)例

    串口通信協(xié)議解析 串口通信協(xié)議是指規(guī)定了數(shù)據(jù)包的內(nèi)容,內(nèi)容包含了起始位、主體數(shù)據(jù)、校驗(yàn)位及停止位,雙方需要約定一致的數(shù)據(jù)包格式才能正常收發(fā)數(shù)據(jù)的有關(guān)規(guī)范。以下是串口通信協(xié)議的介紹: 基本概念
    的頭像 發(fā)表于 11-21 17:03 ?2148次閱讀

    PLC控制系統(tǒng)的通信協(xié)議解析

    的基本概念 通信協(xié)議是一組規(guī)則,定義了數(shù)據(jù)如何在不同的設(shè)備之間傳輸。在PLC控制系統(tǒng)中,這些協(xié)議包括物理層、數(shù)據(jù)鏈路層、網(wǎng)絡(luò)層、傳輸層和應(yīng)用層等多個(gè)層次。 常見(jiàn)的PLC
    的頭像 發(fā)表于 11-08 09:46 ?2620次閱讀

    PROFINET通信協(xié)議是什么

    PROFINET通信協(xié)議是一專(zhuān)為工業(yè)自動(dòng)化領(lǐng)域設(shè)計(jì)的基于以太網(wǎng)的實(shí)時(shí)通信協(xié)議。以下是對(duì)PROFINET通信協(xié)議的詳細(xì)解析,包括其定義、特點(diǎn)、體系結(jié)構(gòu)、工作原理、
    的頭像 發(fā)表于 09-25 18:13 ?5145次閱讀

    SPI通信協(xié)議的基本概念和工作模式

    接口設(shè)計(jì),在嵌入式系統(tǒng)、微控制器與各種外圍設(shè)備之間的通信中占據(jù)重要地位。以下是對(duì)SPI通信協(xié)議的詳細(xì)解析,內(nèi)容涵蓋其基本概念、通信原理、信號(hào)
    的頭像 發(fā)表于 09-09 17:04 ?3208次閱讀

    嵌入式常見(jiàn)模擬電路

    嵌入式系統(tǒng)設(shè)計(jì)中,模擬電路是不可或缺的一部分。它們負(fù)責(zé)處理真實(shí)世界中的信號(hào),如聲音、溫度、壓力等,并將這些信號(hào)轉(zhuǎn)換成數(shù)字信號(hào),或者對(duì)這些信號(hào)進(jìn)行放大、濾波等處理。以下是五常見(jiàn)的模擬電路及其
    發(fā)表于 08-28 15:31

    嵌入式QT常見(jiàn)開(kāi)發(fā)方式有哪些?

    功能。 3.Qt Quick/QML開(kāi)發(fā): 利用QML語(yǔ)言和Qt Quick框架來(lái)創(chuàng)建流暢且動(dòng)畫(huà)豐富的用戶(hù)界面,QML是一聲明性語(yǔ)言,適合于快速原型開(kāi)發(fā)和移動(dòng)設(shè)備嵌入式系統(tǒng)的現(xiàn)代界面設(shè)計(jì)。同時(shí)可以結(jié)合
    發(fā)表于 08-12 10:05

    簡(jiǎn)單認(rèn)識(shí)UART通信協(xié)議

    UART(Universal Asynchronous Receiver/Transmitter,通用異步收發(fā)傳輸器)通信協(xié)議是一常見(jiàn)的串行通信協(xié)議,廣泛應(yīng)用于計(jì)算機(jī)、
    的頭像 發(fā)表于 07-25 18:07 ?2152次閱讀