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)不再提示

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

GReq_mcu168 ? 來(lái)源:玩轉(zhuǎn)單片機(jī) ? 2020-08-04 16:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

1

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

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

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

分析如下:

這樣讀/寫以0x25為地址的SRAM單元,直接書寫DDRB即可,即DDRB為變量,只不過(guò)變量的地址固定為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

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

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

sfr P0 = 0x80;

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

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

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

B:ICCAVR和GCCAVR沒有定義新的數(shù)據(jù)類型,只能采用標(biāo)準(zhǔn)C的強(qiáng)制類型轉(zhuǎn)換和指針來(lái)實(shí)現(xiàn)訪問(wèn)MCU的寄存器。而IAR和CodeVisionAVR編譯器對(duì)ANSI C進(jìn)行了擴(kuò)充,都定義了新的數(shù)據(jù)類型,是C語(yǔ)言可以直接訪問(wèn)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)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5604

    瀏覽量

    129678
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    183

    文章

    7643

    瀏覽量

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

    關(guān)注

    0

    文章

    615

    瀏覽量

    29450

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    請(qǐng)問(wèn)如何實(shí)現(xiàn)C語(yǔ)言訪問(wèn)MCU寄存器?

    單片機(jī)的特殊功能寄存器SFR,是SRAM地址已經(jīng)確定的SRAM單元,在C語(yǔ)言環(huán)境下對(duì)其訪問(wèn)歸納起來(lái)有兩種方法。 采用標(biāo)準(zhǔn)
    發(fā)表于 12-26 07:00

    C語(yǔ)言強(qiáng)制類型轉(zhuǎn)換

    強(qiáng)制類型轉(zhuǎn)換是通過(guò)定義類型轉(zhuǎn)換運(yùn)算來(lái)實(shí)現(xiàn)的。其一般形式為: (數(shù)據(jù)類型) (表達(dá)式) 其作用是把表達(dá)式的運(yùn)算結(jié)果強(qiáng)制
    發(fā)表于 11-24 06:32

    嵌入式系統(tǒng)必懂的 20 個(gè)寄存器

    嵌入式開發(fā)看起來(lái)很復(fù)雜,但很多操作其實(shí)都離不開寄存器寄存器就是MCU內(nèi)部的存儲(chǔ)單元,它們控制著處理和外設(shè)的行為。熟悉這些寄存器,你就能更
    的頭像 發(fā)表于 11-14 10:28 ?993次閱讀
    嵌入式系統(tǒng)必懂的 20 個(gè)<b class='flag-5'>寄存器</b>

    蜂鳥內(nèi)核中DMA的硬件實(shí)現(xiàn)——寄存器配置

    DMA,Direct Memory Access,直接內(nèi)存訪問(wèn),是一種不經(jīng)過(guò)CPU而直接從內(nèi)存存取數(shù)據(jù)的數(shù)據(jù)交換模式。在DMA模式下,CPU只需要向DMA控制下達(dá)指令(配置DMA寄存器),傳輸數(shù)據(jù)
    發(fā)表于 10-24 08:46

    mcu200t配置OV5640寄存器

    OV5640介紹 OV5640 的寄存器配置是通過(guò) FPGA 的 I2C(也稱為 SCCB 接口)接口來(lái)配置,需要配置正確的寄存器值讓 OV5640 輸出我們需要的圖像格式 OV56
    發(fā)表于 10-23 06:01

    SN74LV594A:2-5.5V帶輸出寄存器的8位移位寄存器技術(shù)解析

    AEC-Q100標(biāo)準(zhǔn),采用可濕性側(cè)翼QFN (WBQB) 封裝。TI SN74LV594A/-Q1可在移位寄存器和存儲(chǔ)寄存器上進(jìn)行獨(dú)立直接覆蓋清零
    的頭像 發(fā)表于 09-02 09:42 ?803次閱讀
    SN74LV594A:2-5.5V帶輸出<b class='flag-5'>寄存器</b>的8位移位<b class='flag-5'>寄存器</b>技術(shù)解析

    TLC6C598 8位移位寄存器LED驅(qū)動(dòng)技術(shù)手冊(cè)

    TLC6C598器件是單片、中壓、低電流功率 8 位移位 寄存器設(shè)計(jì)用于需要相對(duì)中等負(fù)載功率的系統(tǒng),例如 LED。 該器件包含一個(gè) 8 位串行輸入并行輸出移位寄存器,可為 8 位饋電 D型存儲(chǔ)
    的頭像 發(fā)表于 08-26 14:31 ?998次閱讀
    TLC6<b class='flag-5'>C</b>598 8位移位<b class='flag-5'>寄存器</b>LED驅(qū)動(dòng)<b class='flag-5'>器</b>技術(shù)手冊(cè)

    ?TLC6C5912 12通道移位寄存器LED驅(qū)動(dòng)技術(shù)文檔總結(jié)

    該TLC6C5912是一款單片、中壓、低電流功率 12 位移位寄存器 設(shè)計(jì)用于需要相對(duì)中等負(fù)載功率的系統(tǒng),例如 LED。 該器件包含一個(gè) 12 位串行輸入并行輸出移位寄存器,可為 12 位饋電
    的頭像 發(fā)表于 08-26 14:16 ?936次閱讀
    ?TLC6<b class='flag-5'>C</b>5912 12通道移位<b class='flag-5'>寄存器</b>LED驅(qū)動(dòng)<b class='flag-5'>器</b>技術(shù)文檔總結(jié)

    ?TLC6C5816-Q1 16位移位寄存器LED驅(qū)動(dòng)技術(shù)文檔總結(jié)

    TLC6C5816-Q1 器件是一款 16 位移位寄存器 LED 驅(qū)動(dòng),旨在支持汽車 LED 應(yīng)用。內(nèi)置LED開路和LED短路診斷機(jī)制,提供增強(qiáng)的安全保護(hù)。該器件包含 16 個(gè)通道,帶有
    的頭像 發(fā)表于 08-25 18:13 ?890次閱讀
    ?TLC6<b class='flag-5'>C</b>5816-Q1 16位移位<b class='flag-5'>寄存器</b>LED驅(qū)動(dòng)<b class='flag-5'>器</b>技術(shù)文檔總結(jié)

    SN74LV595B-EP低噪聲8位移位寄存器技術(shù)解析與應(yīng)用指南

    Texas Instruments SN74LV595B-EP低噪聲8位移位寄存器包含一個(gè)8位串行輸入、并行輸出移位寄存器,可為8位D類存儲(chǔ)寄存器饋送信號(hào)。存儲(chǔ)寄存器具有并行 3 狀態(tài)
    的頭像 發(fā)表于 08-15 09:28 ?1097次閱讀
    SN74LV595B-EP低噪聲8位移位<b class='flag-5'>寄存器</b>技術(shù)解析與應(yīng)用指南

    使用寄存器點(diǎn)亮LED燈

    學(xué)習(xí)本章時(shí),配合以上芯片手冊(cè)中的“19. I/O Ports”章節(jié)一起閱讀,效果會(huì)更佳,特別是涉及到寄存器說(shuō)明的部分。本章內(nèi)容涉及到較多寄存器方面的深入內(nèi)容,對(duì)于初學(xué)者而言這些內(nèi)容豐富也較難理解,但非常有必要細(xì)讀研究、夯實(shí)基礎(chǔ)。
    的頭像 發(fā)表于 05-28 17:37 ?1228次閱讀
    使用<b class='flag-5'>寄存器</b>點(diǎn)亮LED燈

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

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

    第四章 什么是寄存器

    本篇文章我們講解了寄存器概念、地址映射和寄存器操作等內(nèi)容,內(nèi)容比較干,大家有個(gè)概念即可,不要求全部熟記掌握,有需要時(shí)可重復(fù)查閱觀看。下一篇我們將開始進(jìn)行實(shí)操內(nèi)容,通過(guò)控制單片機(jī)的GP
    的頭像 發(fā)表于 05-21 14:23 ?1346次閱讀
    第四章 什么是<b class='flag-5'>寄存器</b>

    如何用C語(yǔ)言操作寄存器——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(10)

    由于寄存器的數(shù)量是非常之多的,如果每個(gè)寄存器都用像*((uint32_t*)(0x40080000+0x0020*1))這樣的方式去訪問(wèn)的話,會(huì)顯得很繁瑣、很麻煩。為了更方便地訪問(wèn)
    的頭像 發(fā)表于 04-22 15:30 ?1898次閱讀
    如何用<b class='flag-5'>C</b>語(yǔ)言操作<b class='flag-5'>寄存器</b>——瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南(10)

    AG32 MCU中CPLD使用基礎(chǔ)(二)

    讀寫數(shù)據(jù)到cpld; 在地址設(shè)計(jì)中,cpld的地址區(qū)間是:0x60000000 ~ 0x7FFFFFFF 當(dāng)mcu對(duì)這個(gè)區(qū)間內(nèi)的地址訪問(wèn)時(shí),相當(dāng)于訪問(wèn)了cpld的“寄存器”。
    發(fā)表于 04-07 09:25