chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

快速理解STM32位帶操作原理

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

掃碼添加小助手

加入工程師交流群

作者:strongerHuang

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

一、初識(shí)位帶操作

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

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

這兩個(gè)1MB將分別映射到另外兩個(gè)地址區(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)。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

四、代碼實(shí)現(xiàn)

利用上面計(jì)算公式,代碼實(shí)現(xiàn)的過(guò)程就很簡(jiǎn)單,我們的目的就是對(duì)“AliasAddr”這個(gè)地址進(jìn)行讀寫(xiě)操作。

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))))

方便大家對(duì)比,給一個(gè)截圖:

A.RAM地址0x20001000的Bit1位寫(xiě)0

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

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

uint8_t Val;

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

C.對(duì)PA1數(shù)據(jù)輸出寄存器輸出1

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

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

uint8_t Val;

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

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

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

1.優(yōu)點(diǎn)

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

2.缺點(diǎn)

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

六、說(shuō)明

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

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


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

    關(guān)注

    2307

    文章

    11150

    瀏覽量

    372410

原文標(biāo)題:快速理解STM32位帶操作原理和用途

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    零知STM32手勢(shì)控制風(fēng)扇系統(tǒng) - 隔空操作實(shí)測(cè)

    STM32
    PCB56242069
    發(fā)布于 :2026年01月06日 10:14:05

    用戶對(duì)變量或寄存器進(jìn)行操作的方法

    嵌入式系統(tǒng)總是要用戶對(duì)變量或寄存器進(jìn)行操作。給定一個(gè)整型變量a,寫(xiě)兩段代碼,第一個(gè)設(shè)置a的bit 3,第二個(gè)清除a 的bit 3。在以上兩個(gè)操作中,要保持其它不變。 考察點(diǎn):
    發(fā)表于 12-23 08:16

    arm單片機(jī)位帶操作的原理

    單片機(jī)單片機(jī)的帶操作(Bit-Banding)是一種特殊的內(nèi)存映射技術(shù),允許開(kāi)發(fā)者以原子操作的方式對(duì)特定的內(nèi)存進(jìn)行讀寫(xiě),從而提高了對(duì)GPIO端口、寄存器以及其他外設(shè)單個(gè)位的
    發(fā)表于 11-25 08:24

    操作的常見(jiàn)錯(cuò)誤與應(yīng)對(duì)策略

    的,可能會(huì)導(dǎo)致數(shù)據(jù)溢出或丟失。 (三)數(shù)據(jù)類型表示的理解要點(diǎn) 在嵌入式系統(tǒng)中,不同的數(shù)據(jù)類型有著不同的表示方式,這一點(diǎn)在進(jìn)行操作
    發(fā)表于 11-24 07:50

    使用操作精準(zhǔn)配置單片機(jī)寄存器

    項(xiàng)目對(duì)效率要求高,推薦使用掩碼操作;如果需要可讀性和維護(hù)性,推薦結(jié)構(gòu)體映射寄存器;如果使用Cortex-M架構(gòu),帶操作是個(gè)不錯(cuò)的選擇。 1、使用
    發(fā)表于 11-24 07:22

    C語(yǔ)言操作

    C 語(yǔ)言操作符包括按與( )、按或(|)、按異或(^)、按取反(~)、左移(<&
    發(fā)表于 11-21 07:52

    映射的操作

    Bit-banding 簡(jiǎn)稱帶、段 支持帶操作后,可以使用普通的加載/存儲(chǔ)指令來(lái)對(duì)單一的比特進(jìn)行讀寫(xiě) 對(duì)于硬件 I/O 密集型的底層程序最有用處 優(yōu)點(diǎn) 使代碼更簡(jiǎn)潔 在多任務(wù)
    發(fā)表于 11-18 07:03

    帶操作的分析

    8051單片機(jī)可以直接對(duì)某一IO進(jìn)行讀寫(xiě)操作,而Cortex-M3的帶操作是8051尋址區(qū)的加強(qiáng)版。使用
    發(fā)表于 11-18 07:01

    GPIO輸出操作的幾種方法分享

    權(quán)威指南》第五章,第5小節(jié) 帶操作(87頁(yè)~92頁(yè))。   為簡(jiǎn)化帶操作,可以定義一些宏。比如,我們可以建立一個(gè)把“帶地址+
    發(fā)表于 11-13 07:50

    RVB 操作指令集擴(kuò)展(一)

    一、B擴(kuò)展簡(jiǎn)介 B擴(kuò)展,即bit-manipulation (bitmanip) extension,主打增強(qiáng)操作的指令集。B擴(kuò)展定義了RV32-64下的操作指令。為了更精準(zhǔn)地在領(lǐng)
    發(fā)表于 10-22 08:11

    STM32C011開(kāi)發(fā)(3)----Flash操作

    STM32C011 系列微控制器內(nèi)置 Flash 存儲(chǔ)器,支持程序存儲(chǔ)與數(shù)據(jù)保存,具備頁(yè)面擦除、雙字寫(xiě)入、讀寫(xiě)保護(hù)等功能。本文將簡(jiǎn)要介紹 STM32C011 的 Flash 結(jié)構(gòu)與特性,并通過(guò)實(shí)際代碼示例,講解 Flash 的擦除、寫(xiě)入與讀取等基本
    的頭像 發(fā)表于 09-18 16:48 ?4046次閱讀
    <b class='flag-5'>STM32</b>C011開(kāi)發(fā)(3)----Flash<b class='flag-5'>操作</b>

    STM32N6 開(kāi)箱實(shí)驗(yàn):如何快速上手最強(qiáng)大的STM32系列?

    STM32N6是有史以來(lái)功能最強(qiáng)大的STM32系列STM32N6嵌入了意法半導(dǎo)體專有的Neural-ART加速器和運(yùn)行頻率為800MHz的ArmCortex-M55內(nèi)核,提供了迄今為止最高
    的頭像 發(fā)表于 09-17 10:37 ?4268次閱讀
    <b class='flag-5'>STM32</b>N6 開(kāi)箱實(shí)驗(yàn):如何<b class='flag-5'>快速</b>上手最強(qiáng)大的<b class='flag-5'>STM32</b>系列?

    基于stm32 nucleo_L476的智能燈(操作說(shuō)明+源碼)

    基于stm32 nucleo_L476的智能燈(操作說(shuō)明+源碼)推薦下載!
    發(fā)表于 05-28 21:29

    STM32G473 DRDY為什么不置?

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

    一文講清:PWMV2快速入門(mén)

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