Ⅰ STM32 CAN 過濾器設置
看手冊里有關該模式過濾寄存器的每位含義,最低三位是IDE RTR和 0,前面高位是標識符
Ⅱ STM32 CAN 通信 濾波設置問題
首先這個配置使用的是 32位的標識符屏蔽位模式
CAN_FilterIdHigh和CAN_FilterIdLow組合成一個32位寄存器,用來存儲將要過濾的ID
CAN_FilterMaskIdHigh和CAN_FilterMaskIdLow組合成一個32位寄存器,用來表示這個ID的哪些位
必須符合(置1),哪些位不care(置0).
使用標示符屏蔽模式可以實現接收包含特定位的幀,即一系列的幀。
CAN的接收郵箱標示符寄存器中,31~3位存儲29位的擴展標示符。
所以通過濾波器要接收ID為0x0A的幀,
CAN_FilterIdLow = 0x000A << 3; CAN_FilterIdHigh = 0;
CAN_FilterMaskIdLow = 0x00FF << 3; CAN_FilterMaskIdHigh = 0;
純手打,若正確請給辛苦費
Ⅲ ESP32 如何配置 CAN 雙濾波器模式
在互聯型產品中,CAN1和CAN2分享28個過濾器組,其它STM32F103xx系列產品中有14個過濾器組,用以對接收到的幀進行過濾。
每組過濾器包括了2個可配置的32位寄存器:CAN_FxR0和CAN_FxR1。這些過濾器相當於關卡,每當收到一條報文時,CAN要先將收到的報文從這些過濾器上"過"一下,能通過的報文是有效報文,收進相關聯FIFO(FIFO1或FIFO2),不能通過的是無效報文(不是發給"我"的報文),直接丟棄。
(標准CAN的標志長度是11位。擴展格式CAN的標志長度是29。CAN2.0A協議規定CAN控制器必須有一個11位的標識符。CAN2.0B協議中規定CAN控制器的標示符長度可以是11位或29位。STM32同時支持CAN2.0A/CAN2.0B協議。)
每組過濾器組有兩種工作模式:標識符列表模式和標識符屏蔽位模式。
標識符屏蔽位模式:可過濾出一組標識符。此時,這樣CAN_FxR0中保存的就是標識符匹配值,CAN_FxR1中保存的是屏蔽碼,即CAN_FxR1中如果某一位為1,則CAN_FxR0中相應的位必須與收到的幀的標志符中的相應位吻合才能通過過濾器;CAN_FxR1中為0的位表示CAN_FxR0中的相應位可不必與收到的幀進行匹配。
標識符列表模式:可過濾出一個標識。此時CAN_FxR0和CAN_FxR1中的都是要匹配的標識符,收到的幀的標識符必須與其中的一個吻合才能通過過濾。
注意:CAN_FilterIdHigh是指高16位CAN_FilterIdLow是低16位應該將需要得到的幀的和過濾器的設置值左對齊起。
所有的過濾器是並聯的,即一個報文只要通過了一個過濾器,就是算是有效的。
按工作模式和寬度,一個過濾器組可以變成以下幾中形式之一:
(1) 1個32位的屏蔽位模式的過濾器。
(2) 2個32位的列表模式的過濾器。
(3) 2個16位的屏蔽位模式的過濾器。
(4) 4個16位的列表模式的過濾器。
每組過濾器組有兩個32位的寄存器用於存儲過濾用的"標准值",分別是FxR1,FxR2。
在32位的屏蔽位模式下:
有1個過濾器。
FxR2用於指定需要關心哪些位,FxR1用於指定這些位的標准值。
在32位的列表模式下:
有兩個過濾器。
FxR1指定過濾器0的標准值FxR2指定過濾器1的標准值。
收到報文的標識符只有跟FxR1與FxR1其中的一個完全相同時,才算通過。
在16位的屏蔽位模式下:
有2個過濾器。
FxR1配置過濾器0,其中,[31-16]位指定要關心的位,[15-0]位指定這些位的標准值。
FxR2配置過濾器1,其中,[31-16]位指定要關心的位,[15-0]位指定這些位的標准值。
在16位的列表模式下:
有4個過濾器。
FxR1的[15-0]位配置過濾器0,FxR1的[31-16]位配置過濾器1。
FxR2的[15-0]位配置過濾器2,FxR2的[31-16]位配置過濾器3。
STM32的CAN有兩個FIFO,分別是FIFO0和FIFO1。為了便於區分,下面FIFO0寫作FIFO_0,FIFO1寫作FIFO_1。
每組過濾器組必須關聯且只能關聯一個FIFO。復位默認都關聯到FIFO_0。
所謂「關聯」是指假如收到的報文從某個過濾器通過了,那麼該報文會被存到該過濾器相連的FIFO。
從另一方面來說,每個FIFO都關聯了一串的過濾器組,兩個FIFO剛好瓜分了所有的過濾器組。
每當收到一個報文,CAN就將這個報文先與FIFO_0關聯的過濾器比較,如果被匹配,就將此報文放入FIFO_0中。
如果不匹配,再將報文與FIFO_1關聯的過濾器比較,如果被匹配,該報文就放入FIFO_1中。
如果還是不匹配,此報文就被丟棄。
每個FIFO的所有過濾器都是並聯的,只要通過了其中任何一個過濾器,該報文就有效。
如果一個報文既符合FIFO_0的規定,又符合FIFO_1的規定,顯然,根據操作順序,它只會放到FIFO_0中。
每個FIFO中只有激活了的過濾器才起作用,換句話說,如果一個FIFO有20個過濾器,但是只激話了5個,那麼比較報文時,只拿這5個過濾器作比較。
一般要用到某個過濾器時,在初始化階段就直接將它激活。
需要注意的是,每個FIFO必須至少激活一個過濾器,它才有可能收到報文。如果一個過濾器都沒有激活,那麼是所有報文都報廢的。
一般的,如果不想用復雜的過濾功能,FIFO可以只激活一組過濾器組,且將它設置成32位的屏蔽位模式,兩個標准值寄存器(FxR1,FxR2)都設置成0。這樣所有報文均能通過。(STM32提供的常式里就是這么做的!)
STM32 CAN中,另一個較難理解的就是過濾器編號。
過濾器編號用於加速CPU對收到報文的處理。
收到一個有效報文時, CAN會將收到的報文 以及它所通過的過濾器編號, 一起存入接收郵箱中。CPU在處理時,可以根據過濾器編號,快速的知道該報文的用途,從而作出相應處理。
不用過濾器編號其實也是可以的, 這時候CPU就要分析所收報文的標識符, 從而知道報文的用途。
由於標識符所含的信息較多,處理起來就慢一點了。
STM32使用以下規則對過濾器編號:
(1) FIFO_0和FIFO_1的過濾器分別獨立編號,均從0開始按順序編號。
(2) 所有關聯同一個FIFO的過濾器,不管有沒有被激活,均統一進行編號。
(3) 編號從0開始,按過濾器組的編號從小到大,按順序排列。
(4) 在同一過濾器組內,按寄存器從小到大編號。FxR1配置的過濾器編號小,FxR2配置的過濾器編號大。
(5) 同一個寄存器內,按位序從小到大編號。[15-0]位配置的過濾器編號小,[31-16]位配置的過濾器編號大。
(6) 過濾器編號是彈性的。 當更改了設置時,每個過濾器的編號都會改變。
但是在設置不變的情況下,各個過濾器的編號是相對穩定的。
這樣,每個過濾器在自己在FIFO中都有編號。
在FIFO_0中,編號從0 -- (M-1), 其中M為它的過濾器總數。
在FIFO_1中,編號從0 -- (N-1),,其中N為它的過濾器總數。
一個FIFO如果有很多的過濾器,,可能會有一條報文, 在幾個過濾器上均能通過,這時候,,這條報文算是從哪兒過來的呢?
STM32在使用過濾器時,按以下順序進行過濾:
(1) 位寬為32位的過濾器,優先順序高於位寬為16位的過濾器。
(2) 對於位寬相同的過濾器,標識符列表模式的優先順序高於屏蔽位模式。
(3) 位寬和模式都相同的過濾器,優先順序由過濾器號決定,過濾器號小的優先順序高。
按這樣的順序,報文能通過的第一個過濾器,就是該報文的過濾器編號,被存入接收郵箱中。
Ⅳ stm32 can 報文過濾器編號的用法
濾波器就是過濾地址和報文的,比如你可以對郵箱0設置濾波器讓它只接受數據幀和指定地址為xxx的。如果讓某個郵箱具有多個地址,比如需要設置地址和廣播地址,那就需要設置2個濾波器。
Ⅳ 各位大俠,幫我看一下程序,stm32 CAN過濾器功能,過濾器組大於4就沒有作用了,為什麼
uint32_t、uint16_t應該是定義的32位和16位數據類型,你找找宏定義應該能找到,*(__IOuint16_t*)(Bank1_LCD_C)意思是把Bank1_LCD_C轉為uint16_t*型的指針,再把index賦給這個指針所指的地址,((uint32_t)0x60000000)就比較簡單了,就是把數據0x60000000轉換為uint32_t類型。至於_IO就是這個了:#define__IOvolatile/*!