吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

解讀STM32位帶操作, 讓你快速了解并掌握它的用途

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-08 11:56 ? 次閱讀

今天重溫一下經典的位帶操作,主要結合Cortex-M3內核(STM32)來講述,相信許多朋友在初學的時候都被繞暈過。

關于位帶操作,它的難點其實在于需要理解或掌握較多基礎知識。當你掌握這些基礎知識,它其實就不難了。

接下來帶領大家掌握關于Cortex-M3的位帶操作,順便讓大家回顧一下這些基礎知識。

1初識位帶操作

Bit-banding簡稱位帶,有人也叫位段。支持位帶操作后,可以使用普通的加載/存儲指令來對單一的比特進行讀寫。

很多朋友是從學習51單片機過來的,都知道P1.1這個引腳可以單獨控制,我們操作的這個引腳就是一個Bit位。

我們都知道在STM32中不能直接操作寄存器的某一個Bit位,比如單獨控制PA端口輸出數據寄存器中的ODR1,如下圖:

STM32F1內核Cortex-M3早就考慮到了這個問題,為了能達到直接操作ODR1這類Bit位,就在內核中開辟了一塊地址區域(位帶別名):可以將ODR1這類Bit位(位帶區)映射到位帶別名區域對應的地址,只需要操作映射后的地址,就可以實現操作這個ODR1位了。

簡單來說就是映射操作,只是這個映射操作有許多約定要遵循。

2位帶操作中的映射關系

在Cortex-M3中有兩個區實現了位帶操作,其中一個是SRAM區的最低 1MB 范圍,第二個則是片內外設區的最低 1MB 范圍。

這兩個區域如下圖紅色標注的區域:

這兩個1MB將分別映射到另外兩個地址區域:

1.SRAM區的最低1MB(0x2000 0000 --- 0x200F FFFF) 映射到(0x2200 0000 --- 0x23FF FFFF)。

2.片內外設區的最低1MB(0x4000 0000 --- 0x400F FFFF)映射到(0x4200 0000 --- 0x43FF FFFF)。

其實就是映射到偏移(距離自身)0x0200 0000外的32MB空間(位帶別名區),如下圖SRAM區映射關系:

提示:看圖中的有顏色的8Bit,它是映射到偏移0x0200 0000外的32Bit(4Byte)空間上。我們讀寫0x2200 0000這個地址,其實就是操作0x2000 0000中的Bit0位。

這就是所謂的“比特的膨脹對應關系”,1Bit膨脹到32Bit(4字節)。4字節對應的就是那1Bit位的地址,而這個地址中的數據只有最低一位才有效(LSB)。

解釋上面多處出現的關鍵詞

位帶區: 支持位帶操作的地址區;

位帶別名: 對別名地址的訪問最終作用到位帶區的訪問上;

3位帶區->別名區計算公式

位帶操作的主要目的:通過Bit位地址(A)計算得到別名區地址(AliasAddr)。

1.SARM區計算公式

AliasAddr= 0x22000000 + ((A‐0x20000000)*8+n)*4 =0x22000000+(A-0x20000000)*32 + n*4

2.片上外設區計算公式

AliasAddr= 0x42000000 + ((A-0x40000000)*8+n)*4 =0x42000000+(A-0x40000000)*32 + n*4

由于映射關系一樣,所以公式原理也一樣,只是地址不一樣。計算公式需要結合上圖比特的膨脹對應關系來理解。

*8:1個字4個字節;

*4:1個字節8Bit;

4代碼實現

利用上面計算公式,代碼實現的過程就很簡單,我們的目的就是對“AliasAddr”這個地址進行讀寫操作。

1.RAM位帶操作宏定義

#define BITBAND_RAM(RAM, BIT) (*((uint32_t volatile*)(0x22000000u + (((uint32_t)&(RAM) - (uint32_t)0x20000000u)<<5) + (((uint32_t)(BIT))<<2))))


2.外設寄存器位帶宏定義

#define BITBAND_REG(REG, BIT) (*((uint32_t volatile*)(0x42000000u + (((uint32_t)&(REG) - (uint32_t)0x40000000u)<<5) + (((uint32_t)(BIT))<<2))))

方便大家對比,給一個截圖:

A.RAM地址0x20001000的Bit1位寫0

BITBAND_RAM(*(uint32_t *)0x20001000, 1) = 0;

B.讀取RAM地址0x20001000的Bit1位

uint8_t Val;

Val=BITBAND_RAM(*(uint32_t *)0x20001000, 1);

C.對PA1數據輸出寄存器輸出1

BITBAND_REG(GPIOA->ODR, 1) = 1;

D.讀取PA1數據輸出寄存器

uint8_t Val;

Val=BITBAND_REG(GPIOA->ODR, 1);

這里就是操作某一個地址,類似于操作指針一樣;

5位帶操作優缺點

1.優點

相比直接操作寄存器代碼更簡潔,運行效率更高。避免在多任務,或中斷時出現紊亂等。

2.缺點

操作不當(傳入地址參數不對),容易出現總線Fault。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2272

    文章

    10923

    瀏覽量

    357554
  • 51單片機
    +關注

    關注

    274

    文章

    5705

    瀏覽量

    124294
  • Cortex-M3
    +關注

    關注

    9

    文章

    270

    瀏覽量

    59589
收藏 人收藏

    評論

    相關推薦

    減速機的原理和用途知識了解多少?

    減速機的原理和用途 ?減速機是一種重要的機械傳動裝置,主要用于降低輸入軸的轉速,同時增加輸出軸的扭矩。? 其工作原理基于齒輪傳動,通過一對或多對齒輪的嚙合來實現減速和增矩的目的。減速機在工業生產、交通運輸、建筑機械、航空航天等多個領域都有廣泛的應用。?
    的頭像 發表于 12-16 14:24 ?289次閱讀
    減速機的原理和<b class='flag-5'>用途</b>知識<b class='flag-5'>你</b><b class='flag-5'>了解</b>多少?

    STM32 OLED多菜單操作

    stm32 ?oled多菜單操作
    發表于 10-09 11:01 ?2次下載

    【「倉頡編程快速上手」閱讀體驗】+壹讀后感

    清晰透徹,即使沒有任何編程經驗,也能輕松理解。 書中還配備了大量的實例和練習,這使得理論知識不再空洞抽象。通過實際操作這些例子,可以更好地掌握
    發表于 09-06 20:12

    STM32G4系列到底支不支持帶操作

    印象中不止一次有人詢問STM32G4系列到底支不支持帶操作
    的頭像 發表于 07-29 09:45 ?1653次閱讀
    <b class='flag-5'>STM32</b>G4系列到底支不支持<b class='flag-5'>位</b><b class='flag-5'>帶操作</b>

    STM32H743系列支持帶操作嗎?

    //IO口操作宏定義 define BITBAND(addr, bitnum) ((addr0xF0000000)+0x2000000+((addr0xFFFFF)<<5
    發表于 07-23 08:13

    ESP32 WIFI SOFTAP模式可以有多個STA連接到STA相互通信嗎?

    我不清楚SOFT AP是否可以像一個普通的 AP 那樣,可以有多個 STA 連接到 STA 相互通信?
    發表于 06-20 06:27

    關于帶操作的疑問求解

    大家都知道,帶有對應的帶別名區,操作帶別名區就可以寫帶區的BIT,讀取帶BIT值到內部
    發表于 05-17 07:33

    stm32單片機學習路線

    系統(RTOS)的基本概念:實時操作系統在一些復雜的應用中非常有用。了解RTOS的基本概念,如任務、信號量、消息隊列等,可以幫助你設計和開發更加復雜的應用。 2.學習配置和使用STM32的外設:
    發表于 05-10 15:34

    請問stm8s IO操作如何實現?

    請教各位了,stm8s IO操作如何實現像stm32類似的帶操作啊? #define LEDPAout(0), LED = 1; LED
    發表于 05-09 07:10

    如何快速入門FPGA

    和編程技巧。 參與FPGA相關的社區和論壇,與其他工程師交流學習經驗,解決遇到的問題。 通過以上步驟,可以逐步掌握FPGA的基礎知識,通過實踐項目不斷提升自己的技能。記住,持續學習和實踐是
    發表于 04-28 09:06

    如何快速入門FPGA?

    和編程技巧。 參與FPGA相關的社區和論壇,與其他工程師交流學習經驗,解決遇到的問題。 通過以上步驟,可以逐步掌握FPGA的基礎知識,通過實踐項目不斷提升自己的技能。記住,持續學習和實踐是
    發表于 04-28 08:54

    STM32F103RGT6帶操作不成功的原因?

    各位大神,我是一個入門級的超級菜鳥,遇到一個問題: 為啥子我同樣的帶操作STM32F103C8T6上操作成功,但是在STM32F103R
    發表于 04-19 06:32

    STM32G4XX不能夠像STM32F1XX STM32F4XX那樣對GPIO進行帶操作呢?

    請教下,在STM32G4XX系列里面,GPIO掛載在AHB2總線上面,地址在0x4800 0000. 是不是也就意味著,STM32G4XX不能夠在像STM32F1XX STM32F4X
    發表于 03-21 07:16

    嵌入式工程師需要掌握哪些技術?

    驅動程序、操作系統以及與硬件交互的代碼。對于嵌入式系統來說,效率和資源利用率是至關重要的,因此,掌握C/C++編程技巧是入行嵌入式的基礎。 2. 硬件基礎知識:了解基本的電子電路和數字邏輯是嵌入式
    發表于 03-04 16:38

    揭秘線路板上的孔的類型和作用,對電子產品有更深的了解

    揭秘線路板上的孔的類型和作用,對電子產品有更深的了解
    的頭像 發表于 02-29 17:10 ?1487次閱讀
    百家乐官网PK| 百家乐技巧-澳门百家乐官方网址| 威尼斯人娱乐城博彩投注平台| 真人百家乐官网来博| 百家乐官网具体怎么收费的| 大发888 游戏下载| 鑫鼎国际| 百家乐官网最长的闲| 澳门百家乐庄闲的玩法| 时时博娱乐城| 百家乐游戏合法吗| 明升备用地址| 子山午向的房子24山图| 皇博娱乐| 百家乐全程打庄| 金道博彩| 24山方向上| 娱乐城去澳门| 百家乐看不到视频| 上饶县| 百家乐博彩通博彩网皇冠网澳门赌场真人赌博| 灵山县| 赌百家乐容易的原| 百家乐官网越长的路| 威尼斯人娱乐城游戏平台| 网上百家乐官网是假还是真的| 大发888 打法888| 百家乐官网bp| 娱乐论坛| 百家乐筹码500| 百家乐官网必赢法软件| 百家乐网址官网| 百家乐官网国际赌场娱乐网规则| 元游棋牌游戏大厅| 网上百家乐解码器| 百家乐官网赢的方法| 三公百家乐在哪里可以玩| 怎样打百家乐官网的玩法技巧和规则 | 百家乐信用哪个好| 百家乐官网d博彩论坛| 威尼斯人娱乐开户送18|