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

掃碼添加小助手

加入工程師交流群

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

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

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

1初識(shí)位帶操作

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

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

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

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

簡單來說就是映射操作,只是這個(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ì)別名地址的訪問最終作用到位帶區(qū)的訪問上;

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

位帶操作的主要目的:通過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)系來理解。

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

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

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

利用上面計(jì)算公式,代碼實(shí)現(xià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)

相比直接操作寄存器代碼更簡潔,運(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)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • STM32
    +關(guān)注

    關(guān)注

    2301

    文章

    11073

    瀏覽量

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

    關(guān)注

    277

    文章

    5712

    瀏覽量

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

    關(guān)注

    9

    文章

    276

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

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

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

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

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

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

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

    盟通活動(dòng):2025 STM32研討會(huì),期待與您共會(huì)!

    2025年9月11日及9月17日,STM32研討會(huì)將走進(jìn)北京和上海,為大家深入解讀STM32的中國戰(zhàn)略,圍繞STM32在不同領(lǐng)域的最新產(chǎn)品
    的頭像 發(fā)表于 08-27 16:22 ?465次閱讀
    盟通活動(dòng):2025 <b class='flag-5'>STM32</b>研討會(huì),期待與您共會(huì)!

    華秋DFM軟件丨操作教程——菜單欄-編輯功能篇

    、右下角和中間 ,設(shè)置好位置點(diǎn)擊執(zhí)行即可(詳細(xì)操作步驟如下視頻所示)。 好啦,今天的“ 菜單欄-編輯 ”功能分享就到這里。掌握,就能 更系統(tǒng)、更高效地完成設(shè)計(jì)檢查和優(yōu)化 ,把潛在的制造問題扼殺在搖籃里
    發(fā)表于 08-20 17:27

    入行嵌入式應(yīng)該怎么準(zhǔn)備?

    想入行嵌入式該怎么準(zhǔn)備。很能理解大家對(duì)于嵌入式的關(guān)注,嵌入式系統(tǒng)是當(dāng)今科技領(lǐng)域中的重要組成部分,存在于我們生活的方方面面,各行各業(yè)。智能化時(shí)代的到來也嵌入式技術(shù)炙手可熱! SO,該學(xué)習(xí)這些
    發(fā)表于 08-06 10:34

    充電接口真的了解嗎?

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

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

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

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

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

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

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

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

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

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

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

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

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