一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

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

黃工的嵌入式技術(shù)圈 ? 來源:黃工的嵌入式技術(shù)圈 ? 2020-03-08 11:56 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

關(guān)于位帶操作,它的難點其實在于需要理解或掌握較多基礎(chǔ)知識。當(dāng)你掌握這些基礎(chǔ)知識,它其實就不難了。

接下來帶領(lǐng)大家掌握關(guān)于Cortex-M3的位帶操作,順便讓大家回顧一下這些基礎(chǔ)知識。

1初識位帶操作

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

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

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

STM32F1內(nèi)核Cortex-M3早就考慮到了這個問題,為了能達(dá)到直接操作ODR1這類Bit位,就在內(nèi)核中開辟了一塊地址區(qū)域(位帶別名):可以將ODR1這類Bit位(位帶區(qū))映射到位帶別名區(qū)域?qū)?yīng)的地址,只需要操作映射后的地址,就可以實現(xiàn)操作這個ODR1位了。

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

2位帶操作中的映射關(guān)系

在Cortex-M3中有兩個區(qū)實現(xiàn)了位帶操作,其中一個是SRAM區(qū)的最低 1MB 范圍,第二個則是片內(nèi)外設(shè)區(qū)的最低 1MB 范圍。

這兩個區(qū)域如下圖紅色標(biāo)注的區(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ū)的訪問上;

3位帶區(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;

4代碼實現(xiàn)

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

1.RAM位帶操作宏定義

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


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

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

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

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

uint8_t Val;

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

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

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

1.優(yōu)點

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

2.缺點

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

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

    關(guān)注

    2293

    文章

    11032

    瀏覽量

    365128
  • 51單片機(jī)
    +關(guān)注

    關(guān)注

    277

    文章

    5711

    瀏覽量

    127422
  • Cortex-M3
    +關(guān)注

    關(guān)注

    9

    文章

    276

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    充電接口真的了解嗎?

    USB(Universal Serial Bus,通用串行總線)自1994年誕生以來,已成為我們?nèi)粘I钪胁豢苫蛉钡慕涌跇?biāo)準(zhǔn)。從鍵盤、鼠標(biāo)到手機(jī)、充電寶,USB接口無處不在。但知道USB接口也有
    的頭像 發(fā)表于 05-18 17:39 ?753次閱讀

    帶您了解觀測水尺的主要用途和意義

    觀測水尺是一種用于測量和記錄水位變化的工具,主要應(yīng)用于水文監(jiān)測、水利工程、航運、防洪抗旱等領(lǐng)域。以下是的主要用途和意義:1.水文監(jiān)測與數(shù)據(jù)采集記錄水位變化:通過定期觀測水尺刻度,獲取河流、湖泊
    的頭像 發(fā)表于 04-14 10:59 ?446次閱讀
    帶您<b class='flag-5'>了解</b>觀測水尺的主要<b class='flag-5'>用途</b>和意義

    國產(chǎn) ARM 平臺硬核實測!RK3568 賦能人工智能機(jī)械臂手部檢測案例演示

    一、產(chǎn)品簡介TL3568-PlusTEB人工智能實驗箱國產(chǎn)高性能處理器644核低功耗2.0GHz超高主頻1T超高算力NPU兼容鴻蒙等國產(chǎn)操作系統(tǒng)二、實驗?zāi)康?、了解MediaPipe開發(fā)框架的
    的頭像 發(fā)表于 02-10 07:57 ?663次閱讀
    國產(chǎn) ARM 平臺硬核實測!RK3568 賦能人工智能機(jī)械臂手部檢測案例演示

    什么是YOLO?RK3568+YOLOv5是如何實現(xiàn)物體識別的?一起來了解一下!

    一、產(chǎn)品簡介TL3568-PlusTEB人工智能實驗箱國產(chǎn)高性能處理器644核低功耗2.0GHz超高主頻1T超高算力NPU兼容鴻蒙等國產(chǎn)操作系統(tǒng)二、實驗?zāi)康?、了解YOLOv5模型的用途
    的頭像 發(fā)表于 12-19 19:04 ?1004次閱讀
    什么是YOLO?RK3568+YOLOv5是如何實現(xiàn)物體識別的?一起來<b class='flag-5'>了解</b>一下!

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

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

    絕緣電阻測試的基礎(chǔ)以及為什么如此重要

    絕緣電阻測試的八個技巧 絕緣材料是一種能抵抗試圖通過的電流的材料。絕緣體有助于抵抗沖擊和短路,使電絕緣成為任何建筑或系統(tǒng)中最重要的部件之一。這也意味著測量電阻特別重要,必須清楚地了解電阻水平,以
    發(fā)表于 12-09 10:24

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

    如何快速入門HAL庫編程 要快速入門HAL庫編程,可以遵循以下步驟: 了解基礎(chǔ)知識 : 掌握C語言編程基礎(chǔ),包括變量、數(shù)據(jù)類型、函數(shù)、指針等。 了解
    的頭像 發(fā)表于 12-02 11:39 ?1140次閱讀

    STM32 OLED多菜單操作

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

    實時顯示和拍照存儲,IFD-x實時掌握溫度信息 非接觸式熱成像儀器紅外線成像

    實時顯示和拍照存儲,IFD-x實時掌握溫度信息 非接觸式熱成像儀器紅外線成像 非接觸式熱成像儀器,IFD-x采用紅外陣列高精度溫度傳感器和先進(jìn)的軟件算法。它能夠?qū)σ晥龇秶鷥?nèi)的任何物體進(jìn)行紅外成像
    的頭像 發(fā)表于 09-26 10:00 ?477次閱讀

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

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

    【免費分享】易上手的STM32多核心開發(fā)板資料包一網(wǎng)打盡,教程+課件+視頻+項目+源碼

    ?想要深入學(xué)習(xí)STM32開發(fā)嗎?現(xiàn)在機(jī)會來了!我們?yōu)槌鯇W(xué)者們準(zhǔn)備了一份全面的資料包,包括原理圖、教程、課件、視頻、項目、源碼等,所有資料全部免費領(lǐng)取,課程視頻可試看(購買后看完整版),從零開始,
    的頭像 發(fā)表于 09-03 10:09 ?809次閱讀
    【免費分享】易上手的<b class='flag-5'>STM32</b>多核心開發(fā)板資料包一網(wǎng)打盡,教程+課件+視頻+項目+源碼

    認(rèn)識貼片電阻嗎,對他了解多少?

    認(rèn)識貼片電阻嗎,對他了解多少?
    的頭像 發(fā)表于 08-27 15:49 ?1244次閱讀
    <b class='flag-5'>你</b>認(rèn)識貼片電阻嗎,<b class='flag-5'>你</b>對他<b class='flag-5'>了解</b>多少?

    第一篇:V1.5-STM32f103c8t6智能小車筆記 標(biāo)準(zhǔn)庫開發(fā) 6612電機(jī)驅(qū)動新手入門項目

    這是全網(wǎng)最詳細(xì)、性價比最高的STM32實戰(zhàn)項目入門教程,通過合理的硬件設(shè)計和詳細(xì)的視頻筆記介紹,硬件使用STM32F103主控資料多方便學(xué)習(xí),通過3萬字筆記、12多個小時視頻、20多章節(jié)代碼手把手教會如何開發(fā)和調(diào)試。
    的頭像 發(fā)表于 08-12 18:25 ?2583次閱讀
    第一篇:V1.5-<b class='flag-5'>STM32</b>f103c8t6智能小車筆記 標(biāo)準(zhǔn)庫開發(fā) 6612電機(jī)驅(qū)動新手入門項目

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

    印象中不止一次有人詢問STM32G4系列到底支不支持帶操作。
    的頭像 發(fā)表于 07-29 09:45 ?2262次閱讀
    <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
    發(fā)表于 07-23 08:13