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

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

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

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

1初識(shí)位帶操作

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

很多朋友是從學(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)核中開辟了一塊地址區(qū)域(位帶別名):可以將ODR1這類Bit位(位帶區(qū))映射到位帶別名區(qū)域?qū)?yīng)的地址,只需要操作映射后的地址,就可以實(shí)現(xiàn)操作這個(gè)ODR1位了。

簡(jiǎn)單來(lái)說(shuō)就是映射操作,只是這個(gè)映射操作有許多約定要遵循。

2位帶操作中的映射關(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)空間上。我們讀寫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)上;

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

4代碼實(shí)現(xiàn)

利用上面計(jì)算公式,代碼實(shí)現(xiàn)的過(guò)程就很簡(jiǎn)單,我們的目的就是對(duì)“AliasAddr”這個(gè)地址進(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))))

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

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.對(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è)地址,類似于操作指針一樣;

5位帶操作優(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。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)注

    2305

    文章

    11118

    瀏覽量

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

    關(guān)注

    277

    文章

    5714

    瀏覽量

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

    關(guān)注

    9

    文章

    276

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

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

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

    映射的操作

    共享資源在任務(wù)間的“互鎖”訪問(wèn) 多任務(wù)的共享資源必須滿足一次只有一個(gè)任務(wù)訪問(wèn),即“原子操作”,帶操作可以滿足這個(gè)條件 以前的”讀-改-寫“需要 3 條指令,導(dǎo)致這中間留有兩個(gè)能被中
    發(fā)表于 11-18 07:03

    帶操作的分析

    址某一帶操作的宏*/ 2、舉個(gè)例子 下面以 GPIOA-&gt;ODR寄存器(地址為0x40020014)為例,通過(guò)位帶操作進(jìn)行讀寫,并與傳統(tǒng)方式讀寫比較,
    發(fā)表于 11-18 07:01

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

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

    最新MCP規(guī)范解讀,看這篇就夠了!

    一、MCP是什么? 為什么需要? 想象一下,正在開發(fā)一個(gè) AI 編程助手,需要: 讀取和修改項(xiàng)目文件 查詢數(shù)據(jù)庫(kù)Schema 搜索代碼倉(cāng)庫(kù) 執(zhí)行Git操作 傳統(tǒng)做法是為每個(gè)數(shù)據(jù)源
    的頭像 發(fā)表于 11-12 16:29 ?920次閱讀
    最新MCP規(guī)范<b class='flag-5'>解讀</b>,看這篇就夠了!

    嵌入式需要掌握哪些核心技能?

    嵌入式需要掌握哪些核心技能? 若想通過(guò)學(xué)習(xí)嵌入式技術(shù)提升就業(yè)競(jìng)爭(zhēng)力,需重點(diǎn)掌握C語(yǔ)言、嵌入式硬件架構(gòu)、RTOS/Linux開發(fā)、通信協(xié)議四大核心技能,結(jié)合行業(yè)需求積累項(xiàng)目經(jīng)驗(yàn)。 以下為具體分析
    發(fā)表于 10-21 16:25

    燒錄工具操作教程:新手也能快速掌握~

    燒錄工具看似復(fù)雜,其實(shí)操作很簡(jiǎn)單!現(xiàn)在就為奉上清晰明了的使用說(shuō)明,即使是新手也能迅速掌握。 本文就以 Air780EPM 開發(fā)板為例,演示燒錄工具的使用步驟。 ? 一、生成量產(chǎn)文件 1.
    的頭像 發(fā)表于 09-26 19:20 ?404次閱讀
    燒錄工具<b class='flag-5'>操作</b>教程:新手也能<b class='flag-5'>快速</b><b class='flag-5'>掌握</b>~

    新手如何快速掌握電磁閥氣密性檢測(cè)設(shè)備的操作?

    對(duì)于剛接觸工業(yè)檢測(cè)的新手來(lái)說(shuō),面對(duì)一臺(tái)電磁閥氣密性檢測(cè)設(shè)備可能會(huì)感到無(wú)從下手。但其實(shí),只要掌握正確的學(xué)習(xí)方法和操作流程,快速上手并非難事。今天就為大家?guī)?lái)一份實(shí)用的入門指南。首先,做好充分的準(zhǔn)備工作
    的頭像 發(fā)表于 09-25 15:02 ?269次閱讀
    新手如何<b class='flag-5'>快速</b><b class='flag-5'>掌握</b>電磁閥氣密性檢測(cè)設(shè)備的<b class='flag-5'>操作</b>?

    【留言有獎(jiǎng)】2025 STM32研討會(huì),RT-Thread在現(xiàn)場(chǎng)期待與共會(huì)!| 活動(dòng)預(yù)告

    2025年9月11日及9月17日,STM32研討會(huì)將走進(jìn)北京和上海,為大家深入解讀STM32的中國(guó)戰(zhàn)略,圍繞STM32在不同領(lǐng)域的最新產(chǎn)品
    的頭像 發(fā)表于 09-07 11:10 ?321次閱讀
    【留言有獎(jiǎng)】2025 <b class='flag-5'>STM32</b>研討會(huì),RT-Thread在現(xiàn)場(chǎng)期待與<b class='flag-5'>你</b>共會(huì)!| 活動(dòng)預(yù)告

    留言領(lǐng)獎(jiǎng)!2025 STM32研討會(huì)即將啟幕,米爾期待與共會(huì)

    2025年9月11日及9月17日,STM32研討會(huì)將走進(jìn)北京和上海,為大家深入解讀STM32的中國(guó)戰(zhàn)略,圍繞STM32在不同領(lǐng)域的最新產(chǎn)品
    的頭像 發(fā)表于 08-28 08:05 ?538次閱讀
    留言領(lǐng)獎(jiǎng)!2025 <b class='flag-5'>STM32</b>研討會(huì)即將啟幕,米爾期待與<b class='flag-5'>你</b>共會(huì)

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

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

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

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

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

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

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

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