基於UART以狀態機的形式實現LIN通信

2021-01-07 電子產品世界

隨著汽車智能化程度的提高和迅速升級換代的需要,汽車電子網絡正在由集中式控制向分布式控制發展。LIN總線作為CAN總線的有效補充,以低速率和低成本的實現有效解決了分布式控制帶來的成本增加問題。車身分布式控制系統中,採用CAN總線和LIN總線連接各個控制單元,完成單元之間的數據交換,系統結構如圖1所示。

圖1 車身控制系統結構圖

該車身控制系統包括車燈模塊、車門模塊、車內模塊、控制面板模塊和儀錶盤模塊,分別完成對相應負載的控制和監測,同時通過CAN總線完成數據交換。其中車燈模塊和車門模塊基於CAN/LIN總線以分布式的形式實現。本文重點論述的是LIN協議的實現。

LIN協議分析和狀態機的設計

有限狀態機是由一組狀態、一個起始狀態、輸入以及將輸入與當前狀態轉換為下一個狀態的轉換函數所組成,它是一個特殊的有向圖,包括一些狀態節點和連接這些狀態的有向弧。對特定的狀態機而言,首先要建立一些有效的狀態,然後設計相應的算法完成狀態的轉換。

一個完整的LIN幀由間隔場、同步場、PID、數據場以及校驗和場組成,LIN協議驅動器要實現的便是依序完成間隔場和同步場的檢測、ID的發送和接收、數據場字節的發送和接收,最後完成校驗。狀態機形式與LIN協議數據鏈路層規範的定義相吻合,可以通過建立相應的狀態來描述相應的場從而描述整個 LIN幀,且可以通過監控當前狀態,按照當前接收到的字節切換其狀態,從而以狀態轉換的方式依序完成各個場的發送和接收。設計以下幾個狀態:IDLE、BREAK、SYNBYTE、IDENTIFY、TRANCEIVE和 CHECKS UM,設置標誌位state反映LINdriver的狀態,idle,pendin g,succe ss,當處於LIN正確通訊的中間狀態時,state=pending,當LIN通訊失敗,state=idle,當完成一次完整的LIN通訊,state=success。

狀態的監控和轉換是在UART接收中斷服務程序中實現的。因為LIN總線採用單根線通信,UART外接LIN物理層收發器,所以當UART發送的總線數據和接收到的總線數據一樣時,UART接收到的數據便是UART發送的數據,在接收中斷服務程序中完成狀態轉換算法,如圖2。通過判斷當前狀態和接收到的數據切換LINdriver的狀態,同時更新標誌位。


圖2 LIN協議狀態機

軟體設計

軟體設計流程如圖3所示。首先進行初始化,主要包括UART模塊的初始化和I/O腳初始化,設置波特率,使能接收中斷,設置LIN物理層收發器相應I/O腳方向及電平,然後在UART接收中斷服務程序中以狀態機的形式完成LIN通訊。下面結合LIN幀結構和LINdriver的狀態轉換對該狀態機算法進行闡述。


圖3 軟體流程圖

LIN幀以間隔場起始的,LIN- driver的起始狀態為IDLE,此時state=idle。間隔場是一個13位0的場,引起接收中斷同時置位UART模塊的frameerror位,在UART接收中斷服務程序中,判斷接收到的數據為0x00且frameerror標誌位為1時,便認為接收到了間隔場,這時LINdriver從IDLE切換到BREAK,state=pending。

同步場是一個0x55的字節,當前狀態為BREAK時,如果接收到的數據為0x55,LINdriver切換為SYNBYTE,state=pending保持不變,否則切換為IDLE,state=idle;

PID是帶奇偶校驗的ID,它以低6 位 ID0-ID5表示ID,高兩位P0、P1是對 該ID的奇偶校驗,當前狀態為SY NBYTE時,收到的數據便為PID。首先按照奇偶校驗算法對PID進行校驗,校驗通過再按照應用層協議對該PID進行過濾,過濾成功則LINdriver切換為TRANCEIVE,校驗失敗或者過濾失敗則LINdriver返回IDLE,state=idle;

當前狀態為TRANCEIVE時,接收到的數據便是數據場中字節,當數據接收完畢,LINdriver切換為CHECKSUM。當前狀態為CHECKSUM時,接收到的數據便為校驗和場,校驗成功,便置state=success,表示成功地完成了一次LIN通訊,這時數據場中的數據是有效的,可以用於應用程式;校驗失敗表示LIN通訊失敗,數據場中數據無效。

結語

本文針對普通單片機,藉助於其片上UART,以狀態機的形式實現了LIN協議驅動,降低了LIN的實現成本,運行可靠穩定,符合LIN總線以低成本作為CAN總線有效補充的初衷。

pid控制相關文章:pid控制原理

通信相關文章:通信原理


相關焦點

  • 如何在FPGA中實現狀態機
    FPGA常常用於執行基於序列和控制的行動,比如實現一個簡單的通信協議。對於設計人員來說,滿足這些行動和序列要求的最佳方法則是使用狀態機。狀 態機是在數量有限的狀態之間進行轉換的邏輯結構。一個狀態機在某個特定的時間點只處於一種狀態。
  • 狀態機重新優化業務流程
    轉門狀態機可以用狀態轉換表表示,顯示每個可能的狀態、它們之間的轉換(基於給機器的輸入)和每個輸入產生的輸出:轉門狀態機也可以用一個稱為狀態圖的有向圖來表示。每個狀態都由一個節點(圓)表示。邊(箭頭)顯示從一種狀態到另一種狀態的轉換。每個箭頭都標有觸發轉換的輸入。不引起狀態變化的輸入(如處於解鎖狀態的硬幣輸入)由返回原始狀態的圓形箭頭表示。
  • 利用74LS161實現複雜狀態機
    打開APP 利用74LS161實現複雜狀態機 發表於 2018-01-18 09:00:02 狀態機的寫法
  • LabVIEW設計模型——狀態機
    狀態機是在工程應用中使用最多的設計模型。使用狀態機,我們可以很容易的實現程序流程圖中的判斷、分支。 狀態機是由一系列的狀態構成的,其中包括一個「初始化」狀態,和一個「停止」狀態。
  • 由淺入深,讓你全面了解狀態機模式的應用原理
    本文首先簡單介紹狀態機的基本知識(建議找專門專業的介紹狀態機的書籍進行學習),然後基於十字轉門的例子,以遷移表的方式來實現有限狀態機的功能,接著再介紹經典的狀態機模式,最後重點介紹boost startchart的相關知識點,boost startchart是boost實現的狀態機庫,它幾乎支持了所有的UML中狀態機的特性,主要學習的途徑就是官網提供的指南,該指南信息量很大,但是學習起來有點費勁
  • 單片機之狀態機淺談
    說到單片機編程,不得不說到狀態機,狀態機做為軟體編程的主要架構已經在各種語言中應用,當然包括C語言,在一個思路清晰而且高效的程序中,必然有狀態機的身影浮現。靈活的應用狀態機不僅是程序更高效,而且可讀性和擴展性也很好。狀態無處不在,狀態中有狀態,只要掌握了這種思維,讓它成為您編程中的一種習慣,相信您會受益匪淺。
  • 基於MFC串口連續通信的簡易實現
    摘要 設計了一種在MFC中實現與串口連續通信的簡易方法,利用微軟提供的MSComm控制項,仿照MODBUS-RTU協議,並根據數據包
  • 不懂狀態機怎麼能讀懂中間件的LifeCycle?
    要搞清楚LifeCycle模式首先需要能看懂狀態機。事實上,狀態機就是當滿足某種條件時,改變為指定狀態,也是很好理解的。這裡,我假設有如下的狀態機視圖上圖中,我假設是一個組件的狀態機圖。當組件啟動時,首先進入WAITING狀態,如果發送完成SYN包,則進入SYN_SEND狀態;如果調用了setStoped()方法,則改變為STOPED狀態。
  • Profibus-DP主站通信平臺的設計方案
    目前國內業界對於Profibus-DP的研究和相關產品的開發都是基於國外提供的專用協議晶片(主站多數採用西門子推出的ASPC2,從站多採用SPC3等智能通信晶片),而沒有協議晶片樣機開發的相關報導。對於主站的開發,國內一些科研院所(北航706教研室、中科院、浙大等)也曾利用可編程邏輯器件配合MCU設計出簡單主站的試驗產品,但是這些產品僅能實現單主站的功能,對於組成強大的Profibu-DP網絡還望塵莫及。為了打破國外晶片的壟斷,推動國內相關晶片及產品的開發,本文提出了一種FPGA與ARM相結合的方式解決Profibu-DP 1類主站的主主通信及主從通信問題,實現了比較完整的主站研製方案。
  • 硬體描述語言Verilog HDL設計進階之: 典型實例-狀態機應用
    在本實例狀態機的設計過程中,讀者需要著重注意狀態機設計的一些特性。·FSM設計方法(米勒型和摩爾型)。·狀態機的編碼(Binary、gray-code、one-hot等)。·狀態機的初始化狀態和默認狀態(完整狀態機設計)。·狀態機的狀態定義風格(使用parameter參數定義狀態)。
  • 零基礎學FPGA(七)淺談狀態機
    今天我們來寫狀態機。本文引用地址:http://www.eepw.com.cn/article/267960.htm  關於狀態機呢,想必大家應該都接觸過,通俗的講就是數電裡我們學的狀態轉換圖。
  • 運用狀態機提高嵌入式軟體效率
    有限狀態機中有許多變量,例如,與動作(actions)轉換(Mealy機)或狀態(摩爾機)關聯的動作,多重起始狀態,基於沒有輸入符號的轉換或指定符號和狀態(非定有限狀態機)的多個轉換、指派給接收狀態(識別者)的一個或多個狀態。有限狀態機多應用於硬體時序電路設計。 有限狀態機也可以應用到嵌入式軟體設計中。在進行嵌入式軟體設計時,通常的做法是按照信息流程進行順序編程。
  • 電動汽車動力總成解讀|狀態機
    導語:狀態機,代表了電驅動系統運行的不同狀態或者工作模式,電驅動系統控制器(Inverter)與整車控制器(VCU)狀態機的匹配就好比找對象,既要性格、三觀相匹配,也要有相似的生活方式和行為邏輯。文本從電驅動系統的多種工作模式角度,對電動汽車點火啟動、運轉、熄火停車背後的故事做了簡要介紹。本文分為以下三部分展開:1. 什麼是狀態機?2.
  • 如何設計一個穩定可靠的狀態機
    隨著大規模和超大規模FPGA/CPLD器件的誕生和發展,以HDL(硬體描述語言)為工具、FPGA/CPLD器件為載體的EDA技術的應用越來越廣泛.從小型電子系統到大規模SOC(Systemonachip)設計,已經無處不在.在FPGA/CPLD設計中,狀態機是最典型、應用最廣泛的時序電路模塊,如何設計一個穩定可靠的狀態機是我們必須面對的問題.
  • 基於FINS協議的OMRON PLC與上位機乙太網通信的實現
    FINS(factory interface network service)通信協議是歐姆龍公司開發的用於工業自動化控制網絡的指令/響應系統。使用FINS指令可實現各種網絡間的無縫通信,包括用於信息網絡的Etherne(乙太網),用於控制網絡的Controller Link和SYSMAC LINK。
  • 基於Xilinx FPGA 實現FFT算法的電力諧波檢測的設計方案詳解
    基於Xilinx FPGA 實現FFT算法的電力諧波檢測的設計方案詳解 工程師青青 發表於 2018-07-16 18:22:00 基於FFT算法的電力系統諧波檢測裝置
  • FPGA工程師:如何在FPGA中實現狀態機?
    FPGA常常用於執行基於序列和控制的行動,比如實現一個簡單的通信協議。對於設計人員來說,滿足這些行動和序列要求的最佳方法則是使用狀態機。狀態機是在數量有限的狀態之間進行轉換的邏輯結構。一個狀態機在某個特定的時間點只處於一種狀態。但在一系列觸發器的觸發下,將在不同狀態間進行轉換。
  • 「墨子號」實現基於糾纏的無中繼千公裡量子保密通信
    中國科學院院士、中國科學技術大學教授潘建偉及其同事彭承志、印娟等組成的研究團隊,聯合牛津大學Artur Ekert、中科院上海技術物理研究所王建宇團隊以及微小衛星創新研究院、光電技術研究所等相關團隊,利用「墨子號」量子科學實驗衛星,在國際上首次實現千公裡級基於糾纏的量子密鑰分發。
  • 基於ZYNQ系列 SoC和AD9361實現的簡易頻譜分析儀
    摘要:頻譜分析儀是用來檢測電信號頻譜特徵的儀器,在通信、雷達以及電子產品研發等領域有著廣泛的應用。本文設計了基於ZYNQ系列SoC(System on chip)和AD9361實現的簡易頻譜分析儀,頻譜數據可以通過串口發送給上位機,並在上位機中通過MATLAB進行數據處理和分析。相比普通頻譜分析儀,該簡易頻譜分析儀使用便捷,體積小,且十分便於功能擴展。
  • 基於搭建一種具有優秀可移植性的高性能通用軟體無線電平臺的目的
    軟體無線電的概念最早由美國MITRE 公司的Joe.Mitola 於1992 年5 月在美國國家遠程會議上提出,其基本思想是以硬體平臺作為無線電通信的基礎,通過軟體編程的方式在此硬體平臺上實現可定製的無線電功能。