STM32普通型芯片的CAN有14組過濾器組(互聯(lián)型有28組過濾器組),用以對接收到的幀進行過濾。每組過濾器包括了2個可配置的32位寄存器:CAN_FxR0和CAN_FxR1。對于過濾器組,可以將其配置成屏蔽位模式,這樣CAN_FxR0中保存的就是標識符匹配值,CAN_FxR1中保存的是屏蔽碼,即CAN_FxR1中如果某一位為1,則CAN_FxR0中相應的位必須與收到的幀的標志符中的相應位吻合才能通過過濾器;CAN_FxR1中為0的位表示CAN_FxR0中的相應位可不必與收到的幀進行匹配。過濾器組還可以被配置成標識符列表模式,此時CAN_FxR0和CAN_FxR1中的都是要匹配的標識符,收到的幀的標識符必須與其中的一個吻合才能通過過濾。
注意:CAN_FilterIdHigh是指高16位CAN_FilterIdLow是低16位應該將需要得到的幀的和過濾器的設置值左對齊起。
一般我們用的都是普通型的,所以在本文中可以說STM32有14組過濾器組。
根據(jù)配置,每1組過濾器組可以有1個,2個或4個過濾器。
這些過濾器相當于關卡,每當收到一條報文時,CAN要先將收到的報文從這些過濾器上"過"一下,能通過的報文是有效報文,收進FIFO,不能通過的是無效報文(不是發(fā)給"我"的報文),直接丟棄。
所有的過濾器是并聯(lián)的,即一個報文只要通過了一個過濾器,就是算是有效的。
每組過濾器組有兩種工作模式:標識符列表模式和標識符屏蔽位模式。
在標識符列表模式下,收到報文的標識符必須與過濾器的值完全相等才能通過。
在標識符屏蔽位模式下,可以指定標識符的哪些位為何值時就算通過。這其實就是限定了處于某一范圍的標識符能夠通過。
在一組過濾器中,整組的過濾器都使用同一種工作模式。
另外,每組過濾器中的過濾器寬度是可變的,可以是32位或16位。
按工作模式和寬度,一個過濾器組可以變成以下幾中形式之一:
(1) 1個32位的屏蔽位模式的過濾器。
(2) 2個32位的列表模式的過濾器。
(3) 2個16位的屏蔽位模式的過濾器。
(4) 4個16位的列表模式的過濾器。
所有的過濾器是并聯(lián)的,即一個報文只要通過了一個過濾器,就是算是有效的。
每組過濾器組有兩個32位的寄存器用于存儲過濾用的"標準值",分別是FxR1,F(xiàn)xR2。
在32位的屏蔽位模式下:
有1個過濾器。
FxR2用于指定需要關心哪些位,F(xiàn)xR1用于指定這些位的標準值。
在32位的列表模式下:
有兩個過濾器。
FxR1指定過濾器0的標準值,收到報文的標識符只有跟FxR1完全相同時,才算通過。
FxR2指定過濾器1的標準值。
在16位的屏蔽位模式下:
有2個過濾器。
FxR1配置過濾器0,其中,[31-16]位指定要關心的位,[15-0]位指定這些位的標準值。
FxR2配置過濾器1,其中,[31-16]位指定要關心的位,[15-0]位指定這些位的標準值。
在16位的列表模式下:
有4個過濾器。
FxR1的[15-0]位配置過濾器0,F(xiàn)xR1的[31-16]位配置過濾器1。
FxR2的[15-0]位配置過濾器2,F(xiàn)xR2的[31-16]位配置過濾器3。
STM32的CAN有兩個FIFO,分別是FIFO0和FIFO1。為了便于區(qū)分,下面FIFO0寫作FIFO_0,F(xiàn)IFO1寫作FIFO_1。
每組過濾器組必須關聯(lián)且只能關聯(lián)一個FIFO。復位默認都關聯(lián)到FIFO_0。
所謂“關聯(lián)”是指假如收到的報文從某個過濾器通過了,那么該報文會被存到該過濾器相連的FIFO。
從另一方面來說,每個FIFO都關聯(lián)了一串的過濾器組,兩個FIFO剛好瓜分了所有的過濾器組。
每當收到一個報文,CAN就將這個報文先與FIFO_0關聯(lián)的過濾器比較,如果被匹配,就將此報文放入FIFO_0中。
如果不匹配,再將報文與FIFO_1關聯(lián)的過濾器比較,如果被匹配,該報文就放入FIFO_1中。
如果還是不匹配,此報文就被丟棄。
每個FIFO的所有過濾器都是并聯(lián)的,只要通過了其中任何一個過濾器,該報文就有效。
如果一個報文既符合FIFO_0的規(guī)定,又符合FIFO_1的規(guī)定,顯然,根據(jù)操作順序,它只會放到FIFO_0中。
每個FIFO中只有激活了的過濾器才起作用,換句話說,如果一個FIFO有20個過濾器,但是只激話了5個,那么比較報文時,只拿這5個過濾器作比較。
一般要用到某個過濾器時,在初始化階段就直接將它激活。
需要注意的是,每個FIFO必須至少激活一個過濾器,它才有可能收到報文。如果一個過濾器都沒有激活,那么是所有報文都報廢的。
一般的,如果不想用復雜的過濾功能,F(xiàn)IFO可以只激活一組過濾器組,且將它設置成32位的屏蔽位模式,兩個標準值寄存器(FxR1,F(xiàn)xR2)都設置成0。這樣所有報文均能通過。(STM32提供的例程里就是這么做的!)
STM32 CAN中,另一個較難理解的就是過濾器編號。
過濾器編號用于加速CPU對收到報文的處理。
收到一個有效報文時, CAN會將收到的報文 以及它所通過的過濾器編號, 一起存入接收郵箱中。CPU在處理時,可以根據(jù)過濾器編號,快速的知道該報文的用途,從而作出相應處理。
不用過濾器編號其實也是可以的, 這時候CPU就要分析所收報文的標識符, 從而知道報文的用途。
由于標識符所含的信息較多,處理起來就慢一點了。
STM32使用以下規(guī)則對過濾器編號:
(1) FIFO_0和FIFO_1的過濾器分別獨立編號,均從0開始按順序編號。
(2) 所有關聯(lián)同一個FIFO的過濾器,不管有沒有被激活,均統(tǒng)一進行編號。
(3) 編號從0開始,按過濾器組的編號從小到大,按順序排列。
(4) 在同一過濾器組內,按寄存器從小到大編號。FxR1配置的過濾器編號小,F(xiàn)xR2配置的過濾器編號大。
(5) 同一個寄存器內,按位序從小到大編號。[15-0]位配置的過濾器編號小,[31-16]位配置的過濾器編號大。
(6) 過濾器編號是彈性的。 當更改了設置時,每個過濾器的編號都會改變。
但是在設置不變的情況下,各個過濾器的編號是相對穩(wěn)定的。
這樣,每個過濾器在自己在FIFO中都有編號。
在FIFO_0中,編號從0 -- (M-1), 其中M為它的過濾器總數(shù)。
在FIFO_1中,編號從0 -- (N-1),,其中N為它的過濾器總數(shù)。
一個FIFO如果有很多的過濾器,,可能會有一條報文, 在幾個過濾器上均能通過,這時候,,這條報文算是從哪兒過來的呢?
STM32在使用過濾器時,按以下順序進行過濾:
(1) 位寬為32位的過濾器,優(yōu)先級高于位寬為16位的過濾器。
(2) 對于位寬相同的過濾器,標識符列表模式的優(yōu)先級高于屏蔽位模式。
(3) 位寬和模式都相同的過濾器,優(yōu)先級由過濾器號決定,過濾器號小的優(yōu)先級高。
按這樣的順序,報文能通過的第一個過濾器,就是該報文的過濾器編號,被存入接收郵箱中。
上一篇:IAR錯誤之Error[Li005] no definition for "__program_start"
下一篇:stm32通過電調帶動電機(可按鍵調速)
推薦閱讀
史海拾趣
自成立以來,博流公司一直致力于物聯(lián)網、車聯(lián)網和智能穿戴領域集成電路芯片的研發(fā)。經過不斷的技術創(chuàng)新和突破,公司成功推出了多款具有競爭力的芯片產品,廣泛應用于智能家居、智慧城市、智能制造等領域。同時,博流還注重與物聯(lián)網生態(tài)合作伙伴的緊密合作,共同提供端到端、邊緣計算到云的整體解決方案,為客戶創(chuàng)造價值。
近年來,ETA Electric Industry Co Ltd積極響應全球環(huán)保倡議,致力于實現(xiàn)可持續(xù)發(fā)展。他們優(yōu)化了生產流程,減少了廢棄物和污染物的排放。同時,公司還加大了對環(huán)保型電子元器件的研發(fā)力度,推出了一系列節(jié)能、環(huán)保的新產品。這些舉措不僅提升了公司的社會形象,也為其在激烈的市場競爭中增添了新的優(yōu)勢。
上述五個故事,講述了ETA Electric Industry Co Ltd在電子行業(yè)的發(fā)展歷程。從起步之初的艱難,到技術創(chuàng)新的突破,再到市場拓展和質量管理的成功,最后到對環(huán)保和可持續(xù)發(fā)展的追求,每一步都體現(xiàn)了公司的成長和進步。
隨著第一款產品的成功,Electric Imp Inc.公司開始積極拓展市場。公司與多家知名廠商建立了合作關系,將物聯(lián)網設備管理平臺應用于智能家居、工業(yè)自動化、智慧城市等領域。同時,公司還加強了與高校、科研機構的合作,共同研發(fā)新技術、新產品。這些努力使得公司在物聯(lián)網領域的影響力逐漸擴大。
為了更好地拓展市場,D3 Semiconductor與全球知名的電子元件分銷商貿澤電子(Mouser Electronics)建立了合作伙伴關系。根據(jù)協(xié)議,貿澤電子儲備了D3 Semiconductor的完整650伏額定電壓超結MOSFET產品線,并將其推向全球市場。這一合作不僅加強了D3 Semiconductor在全球市場的競爭力,也為公司帶來了更多的商業(yè)機會。
DIALIGHT公司一直專注于工業(yè)LED照明領域的發(fā)展。他們深入了解工業(yè)空間照明的需求和挑戰(zhàn),設計了一系列專為工業(yè)應用而定制的LED照明產品。這些產品不僅易于安裝和維護,而且能在惡劣的環(huán)境下持續(xù)使用。此外,DIALIGHT還提供集成系統(tǒng)解決方案,幫助客戶降低能源成本、維護成本和碳足跡,同時提高設施的安全性和生產力。通過不斷創(chuàng)新和優(yōu)質服務,DIALIGHT在工業(yè)LED照明領域贏得了廣泛的認可和信賴。
上期回顧:【EEWORLD】救火車和你一起學ARM系列活動之一——發(fā)起活動和組建工作環(huán)境 http://bbs.eeworld.com.cn/thread-73857-1-1.html 最小系統(tǒng)電路和建立第一個軟件工程 在這次活動中,我們的學習目的主要有兩個: 第一、要了解L ...… 查看全部問答∨ |
本帖最后由 paulhyde 于 2014-9-15 09:01 編輯 只要你輸入漢字,就能得到相應的點陣數(shù)據(jù),漢字還可以改字形哦 … 查看全部問答∨ |
拜托各位了,小弟最近在高PID控制,自己用C語言寫的不準確,請高手賜教一下,最好是解釋的比較清楚的那種。我的郵箱:sishuiliunian902@163.com… 查看全部問答∨ |
燒完內核開機,出現(xiàn)錯誤代碼請大家?guī)兔Ψ治?/a> WinCE NAND Boot v1.00 (nboot1st) Jun 29 2007 16:33:48 In loadboot WinCE NAND Boot v1.00 (nboot2nd) Jun 29 2007 16:36:41 Total Sectors:0x0000e800 Sector addr on NAND: 0x000004a0 TotalSector: 0x0000e800 Reading Kernel Image ...… 查看全部問答∨ |
#include "msp430x14x.h" void main(void) { unsigned int i; WDTCTL=WDTPW+WDTHOLD; P5DIR|=0x10; P5SEL=0x10; BCSCTL1&=~XT2OFF; do ...… 查看全部問答∨ |
|
(LATTICE的CPLD器件)內部分頻信號如何約束到全局網絡上去? CPLD內部用的主時鐘為全局時鐘管腳輸入時鐘的異步分頻時鐘,如何將這個時鐘約束到全局時鐘網絡上去,或者在VHDL語言中怎樣調用BUFG原語?使用的是lattice器件… 查看全部問答∨ |
我司(合肥某IC設計公司)欲招聘以下人員: 一、高級硬件工程師: (人數(shù)5 人) 主要職責: 1. 原型機/驗證平臺的設計,集成,調試和維護 2. 參與系統(tǒng)聯(lián)調 職位要求: 1.& ...… 查看全部問答∨ |
設計資源 培訓 開發(fā)板 精華推薦
- 有獎直播 | 德州儀器基于 Arm 的 AM62 處理器簡介
- 最后一周:免費獲取Pasternack《RF產品選型指南》2018 印刷版!
- 有獎直播|如何借助Mentor Xpedition AMS對汽車CAN總線進行仿真優(yōu)化分析?
- 如何用3個關鍵步驟,來確保下一代設計安全性,深入解讀嵌入式設備DeepCover加密控制器,看視頻答題贏好禮!
- 好書共讀:《硬件設計指南:從器件認知到手機基帶設計》
- 【預約有禮】全球測量圈大咖直播:驗證5G核心網,確保最佳性能
- 中秋“國宴“ :拍攝板卡上的國產元器件,抽開心小禮品
- Keysight教你如何提高測試精度,答對問題還有禮品相送,速速參與!
- TI 培訓推薦有禮活動
- 【分享成長,10月有獎】EEWORLD優(yōu)秀主題/回復第15期活動開始啦!!!