STM32中操作暫存器GPIOB CRL0x

時間 2021-08-30 10:29:12

1樓:牛排稀飯

沒有區別,在這個**中用到4*0的作用是因為是用的是作用於pb0,而4是對應gpio設定的最小位數,將4*0中的0改為1後就可以對pb1進行操作,這種寫法是為了後續操作的快捷。所以對於只用到pb0的程式~(0x0f<<(4*0))和~0x0f是沒有區別的,而若是使程式以後的修改更加的便利,還是推薦書上的那種寫法,希望採納。

2樓:煙夢山

本人小白,對於=0xf0,暫存器與0xf0,低四位正好至0

3樓:匿名使用者

#include "stm32f10x.h"

#include "gpio_config.h"

/***gpio_config***/

void gpio_config(void)

/***gpio_port_enable***/

void gpio_port_mode(gpio_typedef *gpio_numtemp,unsigned char gpio_portnum,unsigned char gpio_portmode)

stm32中{gpiob->crl&=0x0fffffff;gpiob->crl|=8<<28;}為什麼會報錯

4樓:匿名使用者

由於編譯器預設signed int即32位有符號整數型別,而1<<31實際為0x80000000,

這樣就有可能改寫了符號位(最高位)

依此類推,(2<<30),(3<<29)...等都會出現編譯警告問題.

解決辦法為: ((unsigned int)1<<31),((unsigned int)2<<30),...

你的問題和上述問題類似

stm32中的一句話,gpioa->crl&=0xffffff0f

5樓:

gpioa->crl原來是有初始值的 比如說0xffffffffgpioa->crl&=0xffffff0f則表示:

gpioa->crl=gpioa->crl&0xffffff0f 即

gpioa->crl=0xffffffff&0xffffff0f

6樓:匿名使用者

意思就是將該32位暫存器的bit4~bit7清零,其他位值不改變。

gpiob->crl|=0x00300000 後面的數值怎麼來的啊,什麼意思額?隨便再解釋下這個結構的意思?求大神解難!

7樓:

gpiob->crl |= 0x00300000;

等價於gpiob->crl = gpiob->crl | 0x00300000;

其功能是將gpiob的crl暫存器的第20位、第21位置1。

8樓:

crl對應的是低8位資料,0x00300000對應的是第6個(從0位開始計數,從右往左數過去,第幾位就是對應pb0 -pb7的哪個引腳)gpio引腳,也就是要操作的是pb5口,數值為3,那麼轉換成二進位制就是:0011,檢視資料手冊上的crl暫存器相關資料,可以找到對應的數值含義11:就是配置:

輸出模式,速度50mhz,00:就對應:通用推輓輸出模式,一句話概括:

配置pb5為:推輓輸出模式,速度為50mhz

9樓:白羊

如果你想知道這個數值該怎麼來的話,那麼我建議你問一問你的老師或者是學霸同學。

stm32 用庫函式操作和暫存器操作

首先,兩個都是c語言。從51過渡過來的話,就先說暫存器操作。每個mcu都有自己的暫存器,51是功能比較簡單的一種,相應的暫存器也比較少,我們常用的就那麼幾個,像p0 p1 smod tmod之類的,這些存在於標準標頭檔案reg.h裡面,因為少,所以大家就直接這麼去操作了,每一位對應的意義隨便翻一下手...

如何區分觸發stm32外部中斷的gpio引腳

arm coetex m3核心共支援256箇中斷,其中16個內部中斷,240個外部中斷和可程式設計的256級中斷優先順序的設定。stm32目前支援的中斷共84個 16個內部 68個外部 還有16級可程式設計的中斷優先順序的設定,僅使用中斷優先順序設定8bit中的高4位。stm32可支援68箇中斷通道...

求教高手STM32中SDIO DMA模式的中斷設定問題

愛來聚海的風暴 不是4個埠,而是用4位元的方式來傳輸資料。其實sd都支援spi方式,這種方式下,只有1個bit來傳輸,會很慢,因此4bit就快了。具體提現在stm32因為有內部sd控制器,因此他可以支援這種4bits模式。就是你說的diskio.c檔案中的read write會利用這個 stm32 ...