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

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

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

采用標(biāo)準(zhǔn)C的強(qiáng)制轉(zhuǎn)換和指針的概念來實(shí)現(xiàn)訪問MCU的寄存器

GReq_mcu168 ? 來源:玩轉(zhuǎn)單片機(jī) ? 2020-08-04 16:44 ? 次閱讀

單片機(jī)的特殊功能寄存器SFR,是SRAM地址已經(jīng)確定的SRAM單元,在C語言環(huán)境下對其訪問歸納起來有兩種方法。

1

采用標(biāo)準(zhǔn)C的強(qiáng)制類型轉(zhuǎn)換和指針來實(shí)現(xiàn)

采用標(biāo)準(zhǔn)C的強(qiáng)制轉(zhuǎn)換和指針的概念來實(shí)現(xiàn)訪問MCU寄存器,例如:

#define DDRB (*(volatile unsigned char *)0x25)

分析如下:

這樣讀/寫以0x25為地址的SRAM單元,直接書寫DDRB即可,即DDRB為變量,只不過變量的地址固定為0x25。例如:

DDRB = 0xff;

這樣比直接采用指針變量的方法直觀和方便的多,例如:

unsigned char *p, i;

p = 0x25;

i = *p; //把地址為0x25單元中的數(shù)據(jù)讀出送入i變量

*p = 0; //向地址為0x25的單元中寫入0

總結(jié)一下,就是(*(volatile unsigned char *)0x25)可以看作是一個(gè)普通變量,這個(gè)變量喲固定的地址,指向0x25。而0x25只是個(gè)常量,不是指針,更不是變量。

2

對C編譯器進(jìn)行語法擴(kuò)充

對C編譯器進(jìn)行語法擴(kuò)充。例如MCS51系列KeilC中擴(kuò)充sfr關(guān)鍵字,舉例如下:

sfr P0 = 0x80;

這樣操作0x80單元直接寫P0即可。

下面對AVR的歌C編譯器對訪問MCU寄存器的方法進(jìn)行簡介。

A:采用標(biāo)準(zhǔn)C的強(qiáng)制類型轉(zhuǎn)換和指針來實(shí)現(xiàn)訪問MCU的寄存器,每一個(gè)C編譯器都支持,原因很簡單,這是標(biāo)準(zhǔn)C。

B:ICCAVR和GCCAVR沒有定義新的數(shù)據(jù)類型,只能采用標(biāo)準(zhǔn)C的強(qiáng)制類型轉(zhuǎn)換和指針來實(shí)現(xiàn)訪問MCU的寄存器。而IAR和CodeVisionAVR編譯器對ANSI C進(jìn)行了擴(kuò)充,都定義了新的數(shù)據(jù)類型,是C語言可以直接訪問MCU的有關(guān)寄存器,例如,IAR中:

SFR_B(DDRB, 0x28)

CodeVisionAVR中:

sfrb DDRB = 0x28

這樣,PORTB=0xff;等同于(*(volatile unsigned char *)0x05) = 0xff;而0x25正好是寄存器PORTB在器件ATmega48/88/168中的地址。

GCCAVR每個(gè)AVR器件在頭文件不采用直接定義特殊功能寄存器宏,例如在iomx8.h文件中一個(gè)定義如下:

#define PORTB _SFR_IO8(0x25)

而在sfr_defs.h中可以找到如下兩個(gè)宏定義:

#define _SFR_IO8(io_addr) _MMIO_BYTE((io_addr)+0x20)

#define _MMIO_BYTE(mem_addr) (*(volatile unit8_t *)(mem_addr))

實(shí)質(zhì)上與直接的強(qiáng)制類型轉(zhuǎn)換和指針定義是一樣的。

另外,GCCAVR中宏_BV(bit)是操作I/O寄存器是頻繁用到的,avr-libc建議使用這一宏進(jìn)行寄存器的位操作,他在文件sfr_defs.h中定義如下:

#define _BV(bit)

以下是他的使用示例:

DDRB = _BV(PB0) | _BV(PB1); //器件頭文件中已經(jīng)定義PB0代表0,PB1代表1

他等同于“DDRB=0x03;”,這樣寫的目的是為了提供程序的可讀性。不要擔(dān)心它會(huì)生成比“DDRB=0x03;”更大的代碼,編譯器會(huì)處理這種事情,最終會(huì)輸出與“DDRB=0x03;”同樣的結(jié)果。

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

    關(guān)注

    31

    文章

    5253

    瀏覽量

    119201
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7575

    瀏覽量

    134053
  • 變量
    +關(guān)注

    關(guān)注

    0

    文章

    607

    瀏覽量

    28257

原文標(biāo)題:兩種方式實(shí)現(xiàn)C語言訪問MCU寄存器

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    寄存器的類型和作用

    在計(jì)算機(jī)科學(xué)中,寄存器(Register)是一種高速存儲(chǔ)單元,它位于CPU內(nèi)部,與CPU的運(yùn)算單元和邏輯控制單元緊密相連。寄存器的主要作用是暫時(shí)存儲(chǔ)指令、操作數(shù)和地址等臨時(shí)數(shù)據(jù),以便CPU快速訪問和處理。由于
    的頭像 發(fā)表于 09-05 14:11 ?252次閱讀

    寄存器尋址的實(shí)現(xiàn)方式

    在計(jì)算機(jī)體系結(jié)構(gòu)中,寄存器尋址是一種常見的尋址方式,它允許程序直接訪問CPU內(nèi)部的寄存器寄存器尋址可以提高程序的執(zhí)行效率,因?yàn)樗苊饬藢?nèi)存的訪問
    的頭像 發(fā)表于 07-12 10:36 ?359次閱讀

    寄存器分為基本寄存器和什么兩種

    ,它們用于存儲(chǔ)指令、數(shù)據(jù)和地址等信息。基本寄存器的容量通常較小,但訪問速度非??欤?yàn)樗鼈兣cCPU的執(zhí)行單元緊密相連。 基本寄存器的分類 基本寄存器可以分為以下幾類: (1)通用
    的頭像 發(fā)表于 07-12 10:31 ?634次閱讀

    移位寄存器右移是怎么移位的

    移位寄存器是一種在數(shù)字電路和計(jì)算機(jī)科學(xué)中廣泛使用的存儲(chǔ)設(shè)備,它可以用來存儲(chǔ)和傳輸數(shù)據(jù)。在移位寄存器中,數(shù)據(jù)可以通過移位操作實(shí)現(xiàn)數(shù)據(jù)的傳輸和處理。移位
    的頭像 發(fā)表于 07-12 10:14 ?397次閱讀

    干貨滿滿:ARM的內(nèi)核寄存器講解

    內(nèi)核寄存器與外設(shè)寄存器: 內(nèi)核寄存器與外設(shè)寄存器是完全不同的概念。內(nèi)核寄存器是指 CPU 內(nèi)部的
    發(fā)表于 04-17 11:47 ?1903次閱讀
    干貨滿滿:ARM的內(nèi)核<b class='flag-5'>寄存器</b>講解

    CYPD3120上是否有允許從外部MCU訪問讀/寫寄存器的可訪問接口?

    TUSB564),MCU 需要知道 USB-C 電纜何時(shí)翻轉(zhuǎn),才能直接翻轉(zhuǎn) DP 接收端的通道極性。 CYPD3120 上是否有允許從外部 MCU 訪問讀/寫
    發(fā)表于 02-23 06:18

    移位寄存器的功能是什么 移位寄存器的工作原理

    、并行-串行轉(zhuǎn)換、數(shù)字時(shí)鐘分頻等功能。在計(jì)算機(jī)和通信系統(tǒng)中,移位寄存器具有重要的應(yīng)用,常常用于數(shù)據(jù)傳輸、數(shù)據(jù)緩存、數(shù)字信號(hào)處理等領(lǐng)域。 移位寄存器由若干個(gè)觸發(fā)(Flip-flop)組
    的頭像 發(fā)表于 02-03 16:43 ?5102次閱讀

    移位寄存器的工作原理 移位寄存器左移和右移怎么算

    移位寄存器是一種用于在數(shù)字電路中實(shí)現(xiàn)數(shù)據(jù)移位操作的基本電路元件。它由多個(gè)觸發(fā)以及相關(guān)控制電路組成,具有存儲(chǔ)、接受和移動(dòng)數(shù)據(jù)的功能。移位寄存器可以分為兩種類型:串行移位
    的頭像 發(fā)表于 01-18 10:52 ?6004次閱讀

    UVM寄存器模型的常規(guī)方法有哪些呢?

    在應(yīng)用寄存器模型時(shí), 除了利用它的寄存器信息, 還可以利用它跟蹤寄存器的值。
    的頭像 發(fā)表于 11-25 09:27 ?1439次閱讀
    UVM<b class='flag-5'>寄存器</b>模型的常規(guī)方法有哪些呢?

    寄存器開發(fā),HAL開發(fā)和LL開發(fā)的區(qū)別和參考代碼

    1,寄存器開發(fā)【難度值:難】寄存器開發(fā)是一種直接訪問微控制寄存器的編程方法,它提供了對硬件的極大靈活性和直接控制。在
    的頭像 發(fā)表于 11-17 08:00 ?1015次閱讀
    <b class='flag-5'>寄存器</b>開發(fā),HAL開發(fā)和LL開發(fā)的區(qū)別和參考代碼

    gic的寄存器 gicv3的LPI中斷

    0x100-0x17C — 》 GICD_ISENABLERn 這個(gè)地址范圍內(nèi)一共可以表示32個(gè)32bit的寄存器(n=0x7c/4+1) 所以n的值為0-31,共可以表示32*32=1024個(gè)中斷 提供了2種
    的頭像 發(fā)表于 11-08 16:09 ?561次閱讀

    芯片DFX:Coresight的寄存器一覽

    coresight對于每個(gè)coresight組件,規(guī)定了一些寄存器,這些寄存器的偏移是固定的,這些寄存器,是必須存在的。但是有的,可以不實(shí)現(xiàn)寄存器
    的頭像 發(fā)表于 11-02 11:45 ?893次閱讀
    芯片DFX:Coresight的<b class='flag-5'>寄存器</b>一覽

    8位MCU 32.768kHz晶振相關(guān)控制寄存器和代碼選項(xiàng)說明

    中穎8位MCU 32.768kHz晶振相關(guān)控制寄存器和代碼選項(xiàng)說明
    的頭像 發(fā)表于 10-27 15:07 ?454次閱讀

    CPSR寄存器和APSR寄存器的組成

    程序狀態(tài)寄存器的作用就是反映處理的狀態(tài)信息。在程序運(yùn)行期間我們可以通過查看程序狀態(tài)寄存器的狀態(tài)位進(jìn)行程序的分支跳轉(zhuǎn)處理,或者我們可以設(shè)置程序狀態(tài)
    的頭像 發(fā)表于 10-20 11:38 ?3729次閱讀
    CPSR<b class='flag-5'>寄存器</b>和APSR<b class='flag-5'>寄存器</b>的組成

    Linux程序狀態(tài)寄存器訪問指令

    轉(zhuǎn)移指令 【跳轉(zhuǎn)指令】 B 跳轉(zhuǎn)指令BL 帶返回的跳轉(zhuǎn)指令BLX 帶返回和狀態(tài)切換的跳轉(zhuǎn)指令BX 帶狀態(tài)切換的跳轉(zhuǎn)指令 程序狀態(tài)寄存器訪問指令 1、【MRS指令】 MRS 通用寄存器,程序狀態(tài)
    的頭像 發(fā)表于 10-07 14:22 ?822次閱讀