99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內(nèi)不再提示

快速理解STM32位帶操作原理

strongerHuang ? 來源:strongerHuang ? 作者:strongerHuang ? 2020-09-03 15:40 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

作者:strongerHuang

說到位帶操作,可能很多人比較陌生,但說到控制IO,你肯定不會陌生。有的項目為了最大效率控制IO,使用位帶操作。下面就來簡單說說未帶操作的內(nèi)容。

一、初識位帶操作

Bit-banding簡稱位帶,有人也叫位段。支持位帶操作后,可以使用普通的加載/存儲指令來對單一的比特進行讀寫。很多朋友是從學習51單片機過來的,都知道P1.1這個引腳可以單獨控制,我們操作的這個引腳就是一個Bit位。我們都知道在STM32中不能直接操作寄存器的某一個Bit位,比如單獨控制PA端口輸出數(shù)據(jù)寄存器中的ODR1,如下圖:

STM32F1內(nèi)核Cortex-M3早就考慮到了這個問題,為了能達到直接操作ODR1這類Bit位,就在內(nèi)核中開辟了一塊地址區(qū)域(位帶別名):可以將ODR1這類Bit位(位帶區(qū))映射到位帶別名區(qū)域?qū)?yīng)的地址,只需要操作映射后的地址,就可以實現(xiàn)操作這個ODR1位了。簡單來說就是映射操作,只是這個映射操作有許多約定要遵循。二、位帶操作中的映射關(guān)系在Cortex-M3中有兩個區(qū)實現(xiàn)了位帶操作,其中一個是SRAM區(qū)的最低 1MB 范圍,第二個則是片內(nèi)外設(shè)區(qū)的最低 1MB 范圍。這兩個區(qū)域如下圖紅色標注的區(qū)域:

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

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

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

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

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

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

解釋上面多處出現(xiàn)的關(guān)鍵詞

位帶區(qū):支持位帶操作的地址區(qū);

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

三、位帶區(qū)->別名區(qū)計算公式

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

1.SARM區(qū)計算公式

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

2.片上外設(shè)區(qū)計算公式

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

由于映射關(guān)系一樣,所以公式原理也一樣,只是地址不一樣。計算公式需要結(jié)合上圖比特的膨脹對應(yīng)關(guān)系來理解。

*8:1個字4個字節(jié);

*4:1個字節(jié)8Bit;

四、代碼實現(xiàn)

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

1.RAM位帶操作宏定義

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

2.外設(shè)寄存器位帶宏定義

#defineBITBAND_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數(shù)據(jù)輸出寄存器輸出1

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

D.讀取PA1數(shù)據(jù)輸出寄存器

uint8_t Val;

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

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

五、位帶操作優(yōu)缺點

1.優(yōu)點

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

2.缺點

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

六、說明

關(guān)于Cortex-M3的位帶操作,詳情可以參看Cortex-M3技術(shù)參考手冊(權(quán)威指南)。 我了解Cortex-M處理器中,Cortex-M3、Cortex-M4都具有位帶操作,Cortex-M0,Cortex-M+好像不支持。具體可以下載相關(guān)的技術(shù)參考手冊查看。 原文標題:快速理解STM32位帶操作原理和用途

文章出處:【微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


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

    關(guān)注

    2293

    文章

    11032

    瀏覽量

    364873

原文標題:快速理解STM32位帶操作原理和用途

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    STM32G473 DRDY為什么不置

    STM32G473 RNG使能,系統(tǒng)主頻155MHz,Q時鐘輸出配置38.75Mhz。RNG模塊DRDY不置,狀態(tài)寄存器顯示時鐘錯誤。該芯片RNG具有兩個時鐘源,配置時是否需要在RCC中進行選擇配置?
    發(fā)表于 03-12 07:27

    一文講清:PWMV2快速入門

    引言本指南旨在幫助開發(fā)者快速掌握如何使用PWMV2外設(shè)進行編程和應(yīng)用開發(fā)。本文內(nèi)容注重簡潔明了,旨在讓讀者輕松理解關(guān)鍵概念和基本操作。對于更高級的功能和詳細配置,請參閱后續(xù)的系列文檔以獲取深入指導。
    的頭像 發(fā)表于 02-08 13:39 ?697次閱讀
    一文講清:PWMV2<b class='flag-5'>快速</b>入門

    變送器工作原理解

    變送器的類型 液變送器有多種類型,包括浮球式、電容式、超聲波式、雷達式等。每種類型的工作原理和應(yīng)用場景有所不同,但它們的基本功能都是將液變化轉(zhuǎn)換為電信號。 1. 浮球式液變送
    的頭像 發(fā)表于 01-06 15:24 ?1117次閱讀

    STM32WB55RG開發(fā)(2)----STM32CubeProgrammer燒錄

    STM32CubeProgrammer (STM32CubeProg) 是一款用于編程STM32產(chǎn)品的全功能多操作系統(tǒng)軟件工具。 它提供了一個易用高效的環(huán)境,通過調(diào)試接口(JTAG和
    的頭像 發(fā)表于 12-16 15:52 ?1949次閱讀
    <b class='flag-5'>STM32</b>WB55RG開發(fā)(2)----<b class='flag-5'>STM32</b>CubeProgrammer燒錄

    如何快速入門HAL庫編程 HAL庫與裸機編程的比較

    。 選擇開發(fā)環(huán)境和工具 : 下載并安裝適用于目標微控制器的IDE(如STM32CubeIDE)。 配置開發(fā)環(huán)境,包括編譯器、調(diào)試器等。 學習HAL庫文檔和教程 : 閱讀官方HAL庫文檔,了解HAL庫的結(jié)構(gòu)、函數(shù)和用法。 觀看在線教程或參加培訓課程,加深對HAL庫的理解
    的頭像 發(fā)表于 12-02 11:39 ?1130次閱讀

    STM32H503開發(fā)(2)----STM32CubeProgrammer燒錄

    STM32CubeProgrammer (STM32CubeProg) 是一款用于編程STM32產(chǎn)品的全功能多操作系統(tǒng)軟件工具。 它提供了一個易用高效的環(huán)境,通過調(diào)試接口(JTAG和
    的頭像 發(fā)表于 11-28 09:25 ?2564次閱讀
    <b class='flag-5'>STM32</b>H503開發(fā)(2)----<b class='flag-5'>STM32</b>CubeProgrammer燒錄

    stm32 GPIO中斷配置教程

    在嵌入式開發(fā)中,STM32微控制器因其高性能和豐富的外設(shè)而廣受歡迎。GPIO(通用輸入/輸出)中斷是STM32微控制器中常用的功能之一,它允許開發(fā)者在特定引腳上檢測到外部信號變化時快速響應(yīng)。 1.
    的頭像 發(fā)表于 11-19 15:53 ?3456次閱讀

    工業(yè)智能網(wǎng)關(guān)快速接入移動OneNET平臺配置操作

    新基建。 在實際應(yīng)用中,很多用戶都需要將生產(chǎn)設(shè)備數(shù)據(jù)對接到移動OneNET平臺中,享受便捷快速的配置操作體驗,同時也不需要付出購買運維硬件的成本精力,快速實現(xiàn)工業(yè)物聯(lián)網(wǎng)場景應(yīng)用。以下介紹通過物通博聯(lián)工業(yè)智能網(wǎng)關(guān)
    的頭像 發(fā)表于 11-06 17:24 ?953次閱讀
    工業(yè)智能網(wǎng)關(guān)<b class='flag-5'>快速</b>接入移動OneNET平臺配置<b class='flag-5'>操作</b>

    STM32 OLED多菜單操作

    stm32 ?oled多菜單操作
    發(fā)表于 10-09 11:01 ?3次下載

    氧化鋅避雷器直流參數(shù)測試儀的使用方法——每日了解電力知識

    武漢摩恩推出MEYB-30氧化鋅避雷器直流參數(shù)測試儀,專測10kV及以下電力系統(tǒng)避雷器缺陷,集直流高壓電源、測量控制于一體,具備無線通訊、快速取樣等功能,適用于多種場所,便于攜帶操作。
    的頭像 發(fā)表于 08-15 08:48 ?510次閱讀
    氧化鋅避雷器直流參數(shù)測試儀的使用方法——每日了解電力知識

    THS6212 Input offset voltage matching如何理解?

    THS6212的datasheet里面只看到有關(guān)于偏置電流的描述,Inverting input bias current matching能否理解輸入失調(diào)電流?不是話應(yīng)該怎樣理解? 另外
    發(fā)表于 08-09 06:48

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

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

    LM98725高性能1681 MSPS信號處理解決方案

    電子發(fā)燒友網(wǎng)站提供《LM98725高性能1681 MSPS信號處理解決方案.pdf》資料免費下載
    發(fā)表于 07-26 10:51 ?0次下載
    LM98725高性能16<b class='flag-5'>位</b>81 MSPS信號處<b class='flag-5'>理解</b>決方案

    STM32H743系列支持帶操作嗎?

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

    請問一下ESP8266有沒有操作或者帶的功能?

    請問一下ESP8266有沒有操作或者帶的功能,我們需要對一塊連續(xù)內(nèi)存區(qū)域(相當于顯存)進行操作,如果不用
    發(fā)表于 07-22 06:42