主頁 > 前端設計 > 談談CANopen協議的機制

談談CANopen協議的機制

2020-10-03 06:32:02 前端設計

CANopen是基于CAN協議的高級通信協議和設備組態檔規范,該協議是為嵌入式網路應用(如車載網路)開發的,CANopen涵蓋了網路編程框架,設備描述,介面定義和應用程式組態檔,CANopen使來自不同制造商的設備和應用程式之間實作通信標準化,它已被廣泛用于各個行業,并在自動化和運動應用中具有突出的表現,

就OSI通信系統模型而言,CAN覆寫前兩個級別:物理層和資料鏈路層,物理層定義了所使用的線路,電壓,高速特性等,標準的CAN協議實作資料鏈路層,它是基于幀的(訊息)協議,CANopen涵蓋了上面五層:網路(尋址,路由),傳輸(端到端可靠性),會話(同步),表示(以標準方式編碼的資料,資料表示)和應用,應用層描述了如何配置,傳輸和同步CANopen設備,

許多處理器都實作了CAN 總線介面和驅動程式,我們假設讀者已經了解CANBUS 總線的基本知識,重點介紹應用程CANopen 協議,

CANopen 的基本概念

每個新技術的出現,都會伴隨著一大堆的技術術語和英文縮寫,使初學者難以理解,一位日本人稱為是“術語的洪流“,使用簡單的語言將一個復雜的事情的基本框架講明白,要比開頭就劈頭蓋腦地拋術語,講細節好的多,我寫這篇博文也就是這種嘗試,

  • CANBUS 是一種總線型通信網路,所有的節點都并聯在兩根通信線上,

  • CANBUS 和以太網類似,是基于幀傳輸方式,只是以太網一個幀可以是1500個位元組,而CANBUS 的幀最多只能傳輸8個位元組

以太網的幀結構

CANopen 的幀結構

不要以為資料幀短不好,短有短的優點,它將更可靠,實時性好,

  • 11 位 進一步分成位 4個功能碼和7位 ID,7位大小限制CANopen網路上的設備數量限制為127個節點,
  • 在一個控制系統中,設備的ID 和 資料的格式都是由系統廠商規定的,例如筆者曾經開發過一個汽車上的方向盤角度傳感器,就是由汽車廠提供的幀資料格式和ID 資料表,來設計的,與博世的同類產品不相同,

我們一直在講,底層通信協議只是解決語法的問題,沒有解決語法的問題-資料代表上面含義?

CANOpen 是建立在CANBUS鏈路層基礎上的應用協議,解決語意的問題(8個位元組什么代表意思?),讓不同廠商的產品能夠真正的互聯互通,

基于物件的通信

每個設備都有各種資料要和外界交換,例如方向傳感器的角度,速度和加速度,這些引數具有名稱,型別,長度等特征,訪問這些引數的方式最簡單的方式就是定義地址和長度,然后讀取,PLC 中modbus 協議就是這么簡單粗暴的方法,這種低級的方式顯然比較容易出錯,設定復雜,

控制協議越來越多地采納了面向物件程式設計的思想,將每個引數定義成為一個資料物件,并且可以采樣人類可讀方式撰寫,例如采樣XML 語言來描述,

CANopen 采用了類似的思想,它將引數定義為物件,每個設備中都有一個物件字典,物件字典可以一個檔案描述,它叫做EDS(Electronic data sheet),它采用了INI 檔案格式,

為了簡化協議中的資料交換,CANopen 協議中只是自定物件的索引(index)和子索引(sub index)并不傳遞物件的所有資訊,這就好比只交換字典中的的頁碼和行,列,通信雙方各自去查字典,了解具體的含義,

于是,CANBUS 可憐的8個位元組又分成了三個部分,一個位元組用于說明符,三個位元組用于節點索引和子索引,四個位元組用于傳輸中的實際資料,真正的資料只有4個位元組了,

當所有需要傳輸的資料都不能放入一條訊息中時,將選擇分段傳輸,因此必須使用多個訊息或“段”來傳輸資料,說明符的第7 為1 表示有后續資料,

物件字典

CANopen的中心主題之一是物件字典(OD),它實質上是一個存盤配置和程序資料的表格,所有CANopen設備都必須實作物件字典,

CANopen標準定義了16位的位索引和8位的子索引,也就是說,允許每個索引最多包含65536個索引和256個子條目,

該標準定義某些索引和索引范圍必須包含特定引數,例如,標準定義索引1008h(子索引00h)必須包含設備名稱,這樣,任何CANopen主站都可以從CANopen從站網路讀取此索引,

有些物件字典索引(例如設備型別(1000h))是強制性的,而另一些則是可選的,例如制造商軟體版本(100Ah),強制性索引的集合表示最小物件字典,這是標記符合CANopen的設備所必需的,

訪問物件字典的兩種通信機制是服務資料物件(SDO)和程序資料物件(PDO),

物件字典中包含的基本資料型別為:布林值,void(占位符),無符號整數,有符號整數,浮點數和字符,可以從基本資料型別構造更復雜的資料型別,例如字串,日期和時間,

EDS 檔案

前面提過,每個CANopen 兼容的設備,都需要提供一個EDS 檔案,以便讓其它訪問該節點的設備形成物件字典,主站程式需要匯入EDS檔案,EDS 是采用了INI 檔案格式,它最早是windows 組態檔的格式,也有廠家開發了EDS 的編輯工具,

服務資料物件(SDO)

在CANopen協議的網路上,每個節點必須實作一個服務器,該服務器處理對其物件字典的讀/寫請求,CANopen主站充當該服務器的客戶端,直接訪問(讀/寫)服務器物件字典的機制是服務資料物件(SDO),訪問了物件字典的節點稱為SDO服務器,獲取資料的節點稱為SDO客戶端,傳輸始終由SDO客戶端啟動,

通常,主CANopen節點將向網路發送請求,感興趣的節點將以請求的資料進行回應,當SDO客戶端要從服務器請求資訊時,它將使用600h +節點ID的CAN-ID發送SDO請求, 然后,服務器將使用580h的CAN-ID +節點ID進行回應,節點ID指定訊息來自哪個從節點,下面所示的示例,主節點(SDO客戶端)將訊息發送到網路的CAN-ID為603h,盡管所有節點都可以看到此訊息,但目標節點以外的所有節點都將忽略該訊息,目標節點知道ID為603h的訊息意味著該訊息是針對該節點的,這是SDO請求,訊息的資料欄位將指定主節點要訪問資料的物件的索引和子索引,然后,目標節點以訊息ID 583h進行回應,

程序資料物件(PDO)

程序資料表示可以隨時間變化的資料,例如節點控制器的輸入(即傳感器)和輸出(即電動機驅動器),程序資料也存盤在物件字典中,但是,由于SDO通信一次僅允許訪問一個物件字典索引,因此訪問不斷變化的資料可能會有很多開銷,此外,CANopen協議要求節點必須能夠發送自己的資料,而無需由CANopen主站輪詢,因此,使用一種稱為“程序資料物件”(PDO)的通信方法來傳輸程序資料的方法也有所不同

PDO有兩種型別:傳輸PDO(TPDO)和接收PDO(RPDO),TPDO是來自節點(產生的)的資料,而RPDO是到達節點(消耗的)的資料,另外,PDO有兩種型別的引數:配置引數和映射引數,物件詞典中保留給PDO配置和映射資訊的部分是索引1400h-1BFFh,

配置引數指定COB-ID,傳輸型別,禁止時間(僅TPDO)和事件計時器,這將在本節中進行說明,有多種方法可以啟動PDO傳輸,這些方法包括事件驅動,時間驅動,單獨輪詢和同步輪詢,傳輸型別在PDO的配置引數中指定,在事件驅動的傳輸中,當其中的程序資料發生更改時,將啟動PDO傳輸,在時間驅動的傳輸中,PDO傳輸以固定的時間間隔發生,在單獨的輪詢中,PDO傳輸是使用不常用的稱為遠程請求的機制啟動的,在同步輪詢中,使用SYNC信號啟動PDO傳輸,同步信號經常用作全域計時器,例如,如果CANopen主站發出SYNC訊息,則可以配置多個節點以查看并回應該SYNC,通過這種方式,主站可以同時獲取多個程序物件的“快照”,

網路管理(NMT)概述

網路管理服務包括在初始化,運行前,運行和停止之間更改從站狀態的能力,NMT協議允許CANopen網路控制各個節點的通信狀態,操作前狀態主要用于配置CANopen設備,因此,在預操作狀態下不允許進行PDO通信,在操作狀態下可以進行PDO通信,在停止狀態下,節點只能執行節點保護或心跳,而不能接識訓傳輸訊息,某些型別的CANopen通信允許處于不同狀態,例如,在操作前狀態下允許SDO,但不允許PDO,這是因為SDO通常用于初始化物件字典引數,

守護與心跳

CANopen規范要求節點必須使用某種方法來檢查節點是否“活動”,可用的兩種方法是:節點保護和心跳,后者是首選方法,

在心跳協議中,CANopen節點定期發送心跳訊息,該訊息使CANopen主設備或心跳使用者知道該節點仍處于活動狀態,如果心跳訊息在一定時間內未到達,則主機可以采取特定措施,此類操作可能是重置節點或向操作員報告錯誤,心跳訊息由CAN-ID 0x700 +節點ID標識,其中第一個資料位元組等于1110,

在節點保護協議中,CANopen主站輪詢從站節點的當前狀態資訊,如果節點在特定時間段內未回應,則主服務器將認為該節點已死,并將采取措施,

心跳協議是首選方法,因為它的開銷比節點保護少,

緊急訊息

CANopen網路中的??每個節點都分配有一條緊急訊息(EMCY),用于傳達節點狀態,請注意,心跳和節點保護協議旨在用于傳達通信故障,而緊急訊息則用于傳達節點內的錯誤(即傳感器故障),EMCY訊息由80h的COB-ID +節點ID標識,EMCY訊息的資料部分包含有關發生的錯誤的資訊,

下面我會來談談 CANopen 與IEC61499 相結合,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/150542.html

標籤:其他

上一篇:串口通信協議概述

下一篇:快速入門msp430g2553

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more