日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

3天內不再提示

CAN總線及相關寄存器配置分析

智能汽車電子與軟件 ? 來源:電控知識搬運工 ? 作者:電控知識搬運工 ? 2022-11-28 15:07 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

嵌入式工程師一般都知道CAN總線廣泛應用到汽車中,其實船艦電子設備通信也廣泛使用CAN,隨著國家對海防的越來越重視,對CAN的需求也會越來越大。

概述

CAN(Controller Area Network)即控制器局域網,是一種能夠實現分布式實時控制的串行通信網絡 想到CAN就要想到德國的Bosch公司,因為CAN就是這個公司開發(fā)的(和Intel)。 CAN有很多優(yōu)秀的特點,使得它能夠被廣泛地應用。比如:傳輸速度最高到1Mbps,通信距離最遠到10km,無損位仲裁機制,多主結構。 近些年來,CAN控制器價格越來越低,很多MCU也集成了CAN控制器?,F在每一輛汽車上都裝有CAN總線。 一個典型的CAN應用場景:9a9d9572-6e21-11ed-8abf-dac502259ad0.png

CAN總線標準

CAN總線標準只規(guī)定了物理層和數據鏈路層,需要用戶自定義應用層。不同的CAN標準僅物理層不同。9ab19f0e-6e21-11ed-8abf-dac502259ad0.png ?CAN收發(fā)器負責邏輯電平和物理信號之間的轉換。9ac46a4e-6e21-11ed-8abf-dac502259ad0.png ?將邏輯信號轉換成物理信號(差分電平),或者將物理信號轉換成邏輯電平。 CAN標準有兩個,即IOS11898和IOS11519,兩者差分電平特性不同。9ad67c3e-6e21-11ed-8abf-dac502259ad0.png高低電平幅度低,對應的傳輸速度快;9ae7a658-6e21-11ed-8abf-dac502259ad0.png*雙絞線共模消除干擾,是因為電平同時變化,電壓差不變。

物理層

CAN有三種接口器件:9af9e96c-6e21-11ed-8abf-dac502259ad0.png ?9b09d94e-6e21-11ed-8abf-dac502259ad0.png多個節(jié)點連接,只要有一個為低電平,總線就為低電平,只有所有節(jié)點輸出高電平時,才為高電平。所謂"線與"。 CAN總線有5個連續(xù)相同位后,就插入一個相反位,產生跳變沿,用于同步。從而消除累積誤差。 和485、232一樣,CAN的傳輸速度與距離成反比。9b198ad8-6e21-11ed-8abf-dac502259ad0.png ?CAN總線,終端電阻的接法:9b2b252c-6e21-11ed-8abf-dac502259ad0.png ?為什么是120Ω,因為電纜的特性阻抗為120Ω,為了模擬無限遠的傳輸線。 數據鏈路層CAN總線傳輸的是CAN幀,CAN的通信幀分成五種,分別為數據幀、遠程幀、錯誤幀、過載幀和幀間隔。 數據幀用來節(jié)點之間收發(fā)數據,是使用最多的幀類型;遠程幀用來接收節(jié)點向發(fā)送節(jié)點接收數據;錯誤幀是某節(jié)點發(fā)現幀錯誤時用來向其他節(jié)點通知的幀;過載幀是接收節(jié)點用來向發(fā)送節(jié)點告知自身接收能力的幀;用于將數據幀、遠程幀與前面幀隔離的幀。 數據幀根據仲裁段長度不同分為標準幀(2.0A)和擴展幀(2.0B) 幀起始9b3fc3ec-6e21-11ed-8abf-dac502259ad0.png幀起始由一個顯性位(低電平)組成,發(fā)送節(jié)點發(fā)送幀起始,其他節(jié)點同步于幀起始; 幀結束由7個隱形位(高電平)組成。 仲裁段CAN總線是如何解決多點競爭的問題? 由仲裁段給出答案。 CAN總線控制器在發(fā)送數據的同時監(jiān)控總線電平,如果電平不同,則停止發(fā)送并做其他處理。如果該位位于仲裁段,則退出總線競爭;如果位于其他段,則產生錯誤事件。9b50b67a-6e21-11ed-8abf-dac502259ad0.png ?幀ID越小,優(yōu)先級越高。由于數據幀的RTR位為顯性電平,遠程幀為隱性電平,所以幀格式和幀ID相同的情況下,數據幀優(yōu)先于遠程幀;由于標準幀的IDE位為顯性電平,擴展幀的IDE位為隱形電平,對于前11位ID相同的標準幀和擴展幀,標準幀優(yōu)先級比擴展幀高。 控制段共6位,標準幀的控制段由擴展幀標志位IDE、保留位r0和數據長度代碼DLC組成;擴展幀控制段則由IDE、r1、r0和DLC組成。9b7f4512-6e21-11ed-8abf-dac502259ad0.png ?數據段為0-8字節(jié),短幀結構,實時性好,適合汽車和工控領域;9b9f78dc-6e21-11ed-8abf-dac502259ad0.png ?CRC段CRC校驗段由15位CRC值和CRC界定符組成。9bb1a930-6e21-11ed-8abf-dac502259ad0.pngACK段當接收節(jié)點接收到的幀起始到CRC段都沒錯誤時,它將在ACK段發(fā)送一個顯性電平,發(fā)送節(jié)點發(fā)送隱性電平,線與結果為顯性電平。 遠程幀遠程幀分為6個段,也分為標準幀和擴展幀,且RTR位為1(隱性電平)9bc53bf8-6e21-11ed-8abf-dac502259ad0.pngCAN是可靠性很高的總線,但是它也有五種錯誤:
CRC錯誤:發(fā)送與接收的CRC值不同發(fā)生該錯誤;格式錯誤:幀格式不合法發(fā)生該錯誤;應答錯誤:發(fā)送節(jié)點在ACK階段沒有收到應答信息發(fā)生該錯誤;位發(fā)送錯誤:發(fā)送節(jié)點在發(fā)送信息時發(fā)現總線電平與發(fā)送電平不符發(fā)生該錯誤;位填充錯誤:通信線纜上違反通信規(guī)則時發(fā)生該錯誤。
當發(fā)生這五種錯誤之一時,發(fā)送節(jié)點或接受節(jié)點將發(fā)送錯誤幀。 為防止某些節(jié)點自身出錯而一直發(fā)送錯誤幀,干擾其他節(jié)點通信,CAN協(xié)議規(guī)定了節(jié)點的3種狀態(tài)及行為。9bd2f1e4-6e21-11ed-8abf-dac502259ad0.png ?過載幀當某節(jié)點沒有做好接收的"準備"時,將發(fā)送過載幀,以通知發(fā)送節(jié)點。9be705e4-6e21-11ed-8abf-dac502259ad0.png ?幀間隔用來隔離數據幀、遠程幀與他們前面的幀,錯誤幀和過載幀前面不加幀間隔。9c03f136-6e21-11ed-8abf-dac502259ad0.png構建CAN節(jié)點構建節(jié)點,實現相應控制,由底向上分為四個部分:CAN節(jié)點電路、CAN控制器驅動、CAN應用層協(xié)議、CAN節(jié)點應用程序。 雖然不同節(jié)點完成的功能不同,但是都有相同的硬件和軟件結構。9c185ebe-6e21-11ed-8abf-dac502259ad0.png ?CAN收發(fā)器和控制器分別對應CAN的物理層和數據鏈路層,完成CAN報文的收發(fā);功能電路,完成特定的功能,如信號采集或控制外設等;主控制器與應用軟件按照CAN報文格式解析報文,完成相應控制。 CAN硬件驅動是運行在主控制器(如P89V51)上的程序,它主要完成以下工作:基于寄存器的操作,初始化CAN控制器、發(fā)送CAN報文、接收CAN報文; 如果直接使用CAN硬件驅動,當更換控制器時,需要修改上層應用程序,移植性差。在應用層和硬件驅動層加入虛擬驅動層,能夠屏蔽不同CAN控制器的差異。 一個CAN節(jié)點除了完成通信的功能,還包括一些特定的硬件功能電路,功能電路驅動向下直接控制功能電路,向上為應用層提供控制功能電路函數接口。特定功能包括信號采集、人機顯示等。9c2941a2-6e21-11ed-8abf-dac502259ad0.png ?CAN收發(fā)器是實現CAN控制器邏輯電平與CAN總線上差分電平的互換。實現CAN收發(fā)器的方案有兩種,一是使用CAN收發(fā)IC(需要加電源隔離和電氣隔離),另一種是使用CAN隔離收發(fā)模塊。推薦使用第二種。 CAN控制器是CAN的核心元件,它實現了CAN協(xié)議中數據鏈路層的全部功能,能夠自動完成CAN協(xié)議的解析。CAN控制器一般有兩種,一種是控制器IC(SJA1000),另一種是集成CAN控制器的MCU(LPC11C00)。 MCU負責實現對功能電路和CAN控制器的控制:在節(jié)點啟動時,初始化CAN控制器參數;通過CAN控制器讀取和發(fā)送CAN幀;在CAN控制器發(fā)生中斷時,處理CAN控制器的中斷異常;根據接收到的數據輸出控制信號;9c3cfcc4-6e21-11ed-8abf-dac502259ad0.png ?接口管理邏輯:解釋MCU指令,尋址CAN控制器中的各功能模塊的寄存器單元,向主控制器提供中斷信息和狀態(tài)信息。 發(fā)送緩沖區(qū)和接收緩沖區(qū)能夠存儲CAN總線網絡上的完整信息。 驗收濾波是將存儲的驗證碼與CAN報文識別碼進行比較,跟驗證碼匹配的CAN幀才會存儲到接收緩沖區(qū)。 CAN內核實現了數據鏈路的全部協(xié)議。

CAN協(xié)議應用層概述

CAN總線只提供可靠的傳輸服務,所以節(jié)點接收報文時,要通過應用層協(xié)議來判斷是誰發(fā)來的數據、數據代表了什么含義。常見的CAN應用層協(xié)議有:CANOpen、DeviceNet、J1939、iCAN等。 CAN應用層協(xié)議驅動是運行在主控制器(如P89V51)上的程序,它按照應用層協(xié)議來對CAN報文進行定義、完成CAN報文的解析與拼裝。例如,我們將幀ID用來表示節(jié)點地址,當接收到的幀ID與自身節(jié)點ID不通過時,就直接丟棄,否則交給上層處理;發(fā)送時,將幀ID設置為接收節(jié)點的地址。 CAN收發(fā)器SJA1000的輸出模式有很多,使用最多的是正常輸出模式,輸入模式通常不選擇比較器模式,可以增大通信距離,并且減少休眠下的電流。9c55162e-6e21-11ed-8abf-dac502259ad0.png ?收發(fā)器按照通信速度分為高速CAN收發(fā)器和容錯CAN收發(fā)器。 同一網絡中要使用相同的CAN收發(fā)器。 CAN連接線上會有很多干擾信號,需要在硬件上添加濾波器和抗干擾電路:9c67c062-6e21-11ed-8abf-dac502259ad0.png ?也可以使用CAN隔離收發(fā)器(集成濾波器和抗干擾電路)。9c819762-6e21-11ed-8abf-dac502259ad0.png ?9c91141c-6e21-11ed-8abf-dac502259ad0.png ?CAN控制器與MCU的連接方式:9ca31d1a-6e21-11ed-8abf-dac502259ad0.pngSJA1000可被視為外擴RAM,地址寬度8位,最多支持256個寄存器9cb4e108-6e21-11ed-8abf-dac502259ad0.png9cc8c0ce-6e21-11ed-8abf-dac502259ad0.png ?

														#defineREG_BASE_ADDR0xA000//寄存器基址  unsignedchar*SJA_CS_Point=(unsignedchar*)REG_BASE_ADDR;  //寫SJA1000寄存器 voidWriteSJAReg(unsignedcharRegAddr,unsignedcharValue) { *(SJA_CS_Point+RegAddr)=Value; return; }  //讀SJA1000寄存器 unsignedcharReadSJAReg(unsignedcharRegAddr) { return(*(SJA_CS_Point+RegAddr)); }
															9cdbdca4-6e21-11ed-8abf-dac502259ad0.png
															?9cf12550-6e21-11ed-8abf-dac502259ad0.png
															?將緩存區(qū)的數據連續(xù)寫入寄存器:

														…… for(i=0;i
															將連續(xù)多個寄存器連續(xù)讀入緩存區(qū):

														…… for(i=0;i
															9d00aa0c-6e21-11ed-8abf-dac502259ad0.png
															?頭文件包含方案:1. 每個程序包含用到的頭文件2. 每個程序包含一個公用頭文件,公用頭文件包含所有其他頭文件

														#ifndef__CONFIG_H__//防止頭文件被重復包含 #define__CONFIG_H__ #include<8051.h>//包含80C51寄存器定義頭文件 #include"SJA1000REG.h"//包含SJA1000寄存器定義頭文件 //定義取字節(jié)運算 #defineLOW_BYTE(x)(unsignedchar)(x) #defineHIGH_BYTE(x)(unsignedchar)((unsignedint)(x)>>8) //定義振蕩器時鐘處理器時鐘頻率(用戶可以根據實際情況作出調整) #defineOSCCLK11059200UL //宏定義MCU的時鐘頻率 #defineCPUCLK(OSCCLK/12) #endif//__CONFIG_H__
															SJA1000上電后處于復位狀態(tài),必須初始化后才能工作:(1)置位模式寄存器Bit0位進入復位模式;(2)設置時鐘分頻寄存器選擇時鐘頻率、CAN模式;(3)設置驗收濾波,設定驗證碼和屏蔽碼;(4)設置總線定時器寄存器0、1設定CAN波特率;(5)設置輸出模式;(6)清零模式寄存器Bit0位退出復位模式;
															模式寄存器9d173b28-6e21-11ed-8abf-dac502259ad0.png
															?只檢測模式:SJA1000發(fā)送CAN幀時不檢查應答位;
															只聽模式:此模式下SJA1000不會發(fā)送錯誤幀,用于自動檢測波特率;SJA1000以不同的波特率接收CAN幀,當收到CAN幀時,表明當前波特率與總線波特率相同。
															波特率設置CAN總線無時鐘,使用異步串行傳輸;波特率是1秒發(fā)送的數據位;9d314e14-6e21-11ed-8abf-dac502259ad0.png
															?CAN幀發(fā)送:發(fā)送CAN幀的步驟:1.檢測狀態(tài)寄存器,等待發(fā)送緩沖區(qū)可用;2.填充報文到發(fā)送緩沖區(qū);3.啟動發(fā)送。9d48bf22-6e21-11ed-8abf-dac502259ad0.png
															?SJA1000具有一個12字節(jié)的緩沖區(qū),要發(fā)送的報文可以通過寄存器16-28寫入,也可通過寄存器96-108寫入或讀出:9d5c0aa0-6e21-11ed-8abf-dac502259ad0.png9d70529e-6e21-11ed-8abf-dac502259ad0.png設置發(fā)送模式:

														charSetSJASendCmd(unsignedcharcmd) { unsignedcharret; switch(cmd) { default: case0: ret=SetBitMask(REG_CAN_CMR,TR_BIT);//正常發(fā)送 break; case1: ret=SetBitMask(REG_CAN_CMR,TR_BIT|AT_BIT);//單次發(fā)送 break; case2: ret=SetBitMask(REG_CAN_CMR,TR_BIT|SRR_BIT);//自收自發(fā) break; case0xff: ret=SetBitMask(REG_CAN_CMR,AT_BIT);//終止發(fā)送 break; } returnret; }
															發(fā)送函數: 

														unsignedcharSJA_CAN_Filter[8]= { //定義驗收濾波器的參數,接收所有幀 0x00,0x00,0x00,0x00, //ACR0~ACR3 0xff,0xff,0xff,0xff //AMR0~AMR3 };  unsignedcharSTD_SEND_BUFFER[11]= { //CAN發(fā)送報文緩沖區(qū) 0x08,//幀信息,標準數據幀,數據長度=8 0xEA,0x60,//幀ID=0x753 0x55,0x55,0x55,0x55,0xaa,0xaa,0xaa,0xaa//幀數據 };  voidmain(void)//主函數,程序入口 { timerInit();//初始化 D1=0; SJA1000_RST=1;//硬件復位SJA1000 timerDelay(50);//延時500ms SJA1000_RST=0; SJA1000_Init(0x00,0x14,SJA_CAN_Filter);//初始化SJA1000,設置波特率為1Mbps //無限循環(huán),main()函數不允許返回 for(;;) { SJASendData(STD_SEND_BUFFER,0x0); timerDelay(100);//延時1000ms } }
															為什么幀ID是0x753,這與CAN幀在緩沖區(qū)的存儲格式有關。9d8c93dc-6e21-11ed-8abf-dac502259ad0.png
															?9d9d4150-6e21-11ed-8abf-dac502259ad0.png
															?終端電阻非常重要,當波特率較高而且沒加終端電阻時,信號過沖非常嚴重。9db41a42-6e21-11ed-8abf-dac502259ad0.pngSJA1000有64個字節(jié)的接收緩沖區(qū)(FIFO),這可以降低對MCU的要求。MCU可以通過查詢或中斷的方式確定SJA1000接收到報文后讀取報文。審核編輯:郭婷

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

    關注

    114

    文章

    17890

    瀏覽量

    195336
  • CAN總線
    +關注

    關注

    146

    文章

    2051

    瀏覽量

    135539
  • 寄存器
    +關注

    關注

    31

    文章

    5621

    瀏覽量

    130459

原文標題:詳解CAN 總線及其相關寄存器配置

文章出處:【微信號:智能汽車電子與軟件,微信公眾號:智能汽車電子與軟件】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    深入解析SN74SSTU32864D:25位可配置寄存器緩沖

    深入解析SN74SSTU32864D:25位可配置寄存器緩沖 在電子設計領域,高性能、可配置寄存器緩沖
    的頭像 發(fā)表于 04-23 13:40 ?144次閱讀

    Texas Instruments SN74SSTU32864C:25位可配置寄存器緩沖深度剖析

    我們要深入分析的就是德州儀器(Texas Instruments)推出的SN74SSTU32864C——一款25位可配置寄存器緩沖。 文件下載: SN74SSTU32864CGKER
    的頭像 發(fā)表于 04-23 13:40 ?140次閱讀

    深入解析SN74SSTU32864E:25位可配置寄存器緩沖

    深入解析SN74SSTU32864E:25位可配置寄存器緩沖 概述 在電子設計領域,選擇合適的緩沖對于系統(tǒng)的性能和穩(wěn)定性至關重要。德州儀器(Texas Instruments
    的頭像 發(fā)表于 04-23 11:30 ?259次閱讀

    74SSTUB32864A:25位可配置寄存器緩沖的深度解析

    74SSTUB32864A:25位可配置寄存器緩沖的深度解析 在DDR2 DIMM設計領域,74SSTUB32864A這款25位可配置寄存器
    的頭像 發(fā)表于 04-18 14:30 ?117次閱讀

    ICSSSTUB32866B:DDR2可配置寄存器緩沖的技術解析

    ICSSSTUB32866B:DDR2可配置寄存器緩沖的技術解析 在DDR2內存模塊的設計中,選擇合適的寄存器緩沖至關重要。ICSSST
    的頭像 發(fā)表于 04-14 09:40 ?436次閱讀

    解讀 IDT74SSTUBF32868A:DDR2 應用的 28 位可配置寄存器緩沖

    解讀 IDT74SSTUBF32868A:DDR2 應用的 28 位可配置寄存器緩沖 在當今的電子設備中,內存系統(tǒng)的高效運行對于整體性能起著至關重要的作用。DDR2 內存模塊作為一種常見的內存
    的頭像 發(fā)表于 04-12 09:50 ?424次閱讀

    SN74SSTUB32866:25位可配置寄存器緩沖的設計與應用

    SN74SSTUB32866:25位可配置寄存器緩沖的設計與應用 在電子設計領域,對于高速數據傳輸和處理的需求日益增長,可配置寄存器緩沖
    的頭像 發(fā)表于 02-09 17:45 ?1197次閱讀

    探索SN74SSTEB32866:25位可配置寄存器緩沖的卓越性能

    探索SN74SSTEB32866:25位可配置寄存器緩沖的卓越性能 在硬件設計的廣闊領域中,一款優(yōu)秀的寄存器緩沖能為整個系統(tǒng)帶來顯著的性
    的頭像 發(fā)表于 02-09 16:05 ?268次閱讀

    解析 SN74SSTUB32864:高性能 25 位可配置寄存器緩沖

    解析 SN74SSTUB32864:高性能 25 位可配置寄存器緩沖 在電子設計領域,一個性能卓越的寄存器緩沖對于提升系統(tǒng)的穩(wěn)定性和效率
    的頭像 發(fā)表于 02-08 09:25 ?304次閱讀

    SN74SSTU32864:25位可配置寄存器緩沖的全面剖析

    Instruments)的SN74SSTU32864這款25位可配置寄存器緩沖,了解它的特性、功能及相關設計要點。 文件下載: sn74sstu32864.pdf 產品概述 SN7
    的頭像 發(fā)表于 02-08 09:25 ?313次閱讀

    探索IDT74SSTUBF32866B:DDR2的25位可配置寄存器緩沖

    探索IDT74SSTUBF32866B:DDR2的25位可配置寄存器緩沖 在DDR2內存模塊的設計中,合適的寄存器緩沖至關重要,它能確保
    的頭像 發(fā)表于 01-08 16:30 ?412次閱讀

    探索IDT74SSTUBF32866B:DDR2的25位可配置寄存器緩沖

    探索IDT74SSTUBF32866B:DDR2的25位可配置寄存器緩沖 在DDR2內存模塊的設計中,擁有高性能且穩(wěn)定的寄存器緩沖至關重
    的頭像 發(fā)表于 12-24 16:30 ?561次閱讀

    【NCS隨筆】nRF54L15使用UICR寄存器保存數據

    nRF54L15使用UICR寄存器保存數據 本文章主要是講解如何使用nRF54L15的UICR寄存器保存一些基礎數據 一、UICR寄存器的說明 UICR(用戶信息配置
    的頭像 發(fā)表于 11-27 17:09 ?1758次閱讀

    蜂鳥內核中DMA的硬件實現——寄存器配置

    :DMA寄存器配置、讀寫模塊和fifo。 這里主要分享對DMA寄存器配置分析討論。 寄存器
    發(fā)表于 10-24 08:46

    工控通信精練,CAN轉profinet網關的通信技術應用經驗必備分享

    CAN2.OA 協(xié)議構建 CAN 總線控制網絡, 對 SJAI 的初始化主要完成控制寄存器 CR、驗收 代碼寄存器 ACR、驗收屏蔽
    的頭像 發(fā)表于 06-05 17:02 ?517次閱讀
    工控通信精練,<b class='flag-5'>CAN</b>轉profinet網關的通信技術應用經驗必備分享
    九龙县| 翁牛特旗| 襄樊市| 新民市| 汉阴县| 卓资县| 广德县| 祁连县| 铜山县| 南澳县| 同仁县| 吉首市| 樟树市| 东兴市| 西盟| 珲春市| 神农架林区| 德化县| 陈巴尔虎旗| 兰西县| 西城区| 五家渠市| 从化市| 洪洞县| 太湖县| 武陟县| 缙云县| 南通市| 扎兰屯市| 拉孜县| 新泰市| 永福县| 会昌县| 塔城市| 青阳县| 温州市| 安丘市| 永康市| 旅游| 汨罗市| 榆社县|