數據校驗是為保證數據的完整性進行的一種驗證操作。CAN通信採用CRC校驗作為一種重要的錯誤檢測手段,是節點判斷CAN幀信息的完整性並產生確認應答的依據。
在現場總線通信和控制的實際應用中,工業應用環境往往是極端的溫度以及電磁噪聲或是其他的惡劣環境,系統在這種條件下能否正常工作至關重要,試想一下倘若生產線設備發送的位置信息在傳輸過程出現了錯誤,輕則可能造成生產癱瘓,重則可能導致設備損壞甚至人員傷害。
在CAN總線通信過程中CAN控制器具備完整的錯誤檢測能力,其中包含:位錯誤檢測、格式錯誤檢測、填充錯誤檢測、應答錯誤檢測和CRC錯誤檢測。作為一種重要的錯誤檢測手段,CRC錯誤檢測是接收節點判斷CAN幀信息的完整性並向總線確認應答的依據。
常見的校驗方法
1、最簡單的校驗是數據發送後進行主動回讀,結果一致才確認傳輸成功,很顯然這種傳輸溝通的方式很直觀並非常精準,但是由於回讀的操作使得數據傳輸量翻倍,也就是傳輸對帶寬要求高且效率低下。
2、奇偶校驗,就是傳輸中使用額外1個位來記錄傳輸數據二進位數中1的個數是奇數還是偶數,這個方案適合絕大多數硬體,傳輸開銷適中,因此被廣泛使用,例如常見的串口通信。
3、累加和校驗,該算法原理是對數據逐一進行累加後得到一個數值,接收方在接收數據同時也進行數據的累加並最終與發送過來的累加和進行比較,該算法計算簡單,無論在硬體或是軟體實現都能保證較高的效率,常用於低速串行數據通信校驗和晶片代碼的完整性判斷。
4、CRC檢驗,該算法是基於一個多項式除法取餘的結果,其根據位數需求和多項式變化有數十種版本,憑藉其硬體實現簡單,位反轉偵錯能力較強及運算開銷適中的優點被廣泛應用與數字網絡傳輸以及數據存儲領域,如磁碟數據校驗、USB、GSM/CDMA通信,在計算機應用中經常接觸到的RAR和ZIP文件的壓縮/解壓數據完整性檢查也採用了該算法。
5、MD5、SHA為代表的信息摘要校驗,數據摘要算法也被稱為哈希(Hash)算法、散列算法,摘要算法用於數據量比較大的場合。它通過對所有數據提取指紋信息以實現數據籤名、數據完整性校驗等功能,由於其不可逆性,有時候會被用做敏感信息的加密,如軟體註冊授權文件的內容保護,還有經常遇到的網際網路下載大文件(例如大小到GB級別的ISO鏡像)通常會帶有MD5、SHA1等信息方便用戶檢查傳輸數據的完整性。
CAN幀中的CRC檢驗
1、CRC域在CAN幀中的位置
圖1
如圖1橙色塊方框所示,一個傳統CAN幀結構中,CRC域放置在數據結束後應答檢測之前,對於CAN FD也是相同的位置,該信息對於用戶應用界面來說是不可見的,可以通過CANscope總線分析儀解碼窗口或者帶有CAN協議解碼能力的示波器從總線模擬波形上得到對應的CRC數據展示,見圖2。
圖2
2、CRC的在CAN幀中的生成
在經典CAN中,使用15位CRC,在硬體可使用移位和異或運算完成CRC的計算,而CAN FD規範中對幀數據長度進行了擴展,對於數據長度小於等於16位元組的CAN FD幀,採用17位CRC,對於數據長度大於16位元組的CAN FD幀採用21位CRC。CAN總線中使用的若干版本CRC生成多項式g整理如表1所示。
表1
3、CRC是如何完成校驗工作的
CAN幀基於CRC多項式的安全校驗是發送器根據發送的比特計算校驗值,並在CAN幀結構CRC欄位中提供該結果。接收器使用相同的多項式來計算總線上所見位的校驗值,將自我計算的校驗值與接收的校準值進行比較,如果匹配,則認為幀被正確接收,接收節點在ACK時隙位中發送顯性狀態,從而覆蓋發送器的隱性狀態。在不匹配的情況下,接收節點在ACK定界符之後發送錯誤幀。
目前CAN FD的控制器CRC校驗實現過程會相對複雜一點,在一個CAN總線網絡中,幀起始被檢測到後所有的節點開始使用三組多項式g15、g17和g21同步計算CRC序列,其中也包含發送節點,由於CRC的計算受CAN幀類型和DLC長度影響,直到CAN幀的控制域以及DLC確認後才選擇採用對應的CRC生成序列,確定的CRC序列會在幀結構中CRC欄位被採納用於發送或者用於接收比較。
4、有關CRC的ISO CAN FD、non-ISO CAN FD兼容性問題
當前CAN FD協議有兩個版本,為提高故障(錯誤)檢測能力,新版本特別引入了一個3位填充位計數器和一個額外的奇偶校驗位。此外,CRC計算方法也發生了變化。這些改進使最新的CAN FD協議與博世(BOSCH)開發的原始CAN FD協議不兼容。負責ISO的工作組已完成其文件,並已將其提交給DIS(國際標準草案)在進行投票程序。
為了避免誤解,CiA建議使用術語「ISO CAN FD」和「non-ISO CAN FD」。所有符合ISO 11898-2:2015的產品都應稱為「ISO CAN FD」。執行博世(BOSCH)原始CAN FD協議的產品應命名為「non-ISO CAN FD」,在這個過度階段的產品主要目的是用於前期評估和開發,將來所有產品都將符合ISO標準。
請注意,早前一些供應商提供的組件或者工具是針對non-ISO CAN FD協議的,包括目前在售的部分CAN FD產品,CiA建議僅使用ISO CAN FD產品進行設計和開發,不過你可繼續使用non-ISO CAN FD做評估和前期開發,因為協議的改變對於用戶界面是不可見,但注意的是不能同一個網絡混用non-ISO CAN FD和ISO CAN FD接口設備,這樣會造成CAN總線錯誤無法完成發送和接收,如果僅僅是發送或接收傳統的CAN幀將不會受到任何影響,幸運的是部分設備供應商提供的組件或者工具允許用戶選擇支持ISO或者non-ISO模式,這樣能很好地在過渡時期幫助你完成工作。
傳統CAN以及目前CAN FD採取的校驗機制,保證傳輸過程中遭受破壞的幀數據幾乎不會被接收以及應答成功,能有效防止物理層傳輸錯誤,讓用戶界面不需要額外關注幀傳輸數據的正確性。
如有任何疑問,可以:
添加小Z微信號:zlgmcu-888
撥打ZLG立功科技·致遠電子官方技術熱線:400-888-4005.