国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

為什么學習STM32時還要學習匯編

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2022-02-16 13:43 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

不同的平臺的匯編代碼是不一樣的,最早的匯編在50年代就發明了,比很多人的父母的年齡都大,老掉牙,不用學習怎么寫匯編。一個公司有一個人知道怎么寫匯編就夠了。但要學習讀匯編,為什么學習匯編?

1、性能

直接翻譯為機器語言,性能最高。優秀的C語言效率只能達到匯編的80%左右。其他高級語言跟匯編一比差得更遠。語言越高級性能越差。很多bootloader和BIOS用匯編寫,匯編操作的是電腦手機剛剛上電時,硬件和初始化的那些命令,它們的性能的要求比較高,效率高開機速度更快。

分析問題

個人認為,編程人與機器對話,我們寫C,寫JAVA,但是電腦并不認識這些語言,電腦只認識0和1;所以需要一個人來翻譯這些語言,這個翻譯官就是編譯器,但是編譯器不能百分之百準確的表達程序員的意思,也就是所謂的翻譯有反義。例如,編譯器為了性能好一點,可能會優化變量和語句,這個過程可能好心辦壞事,把有用的操作優化了。因此只有看懂一些匯編語句,才能分析程序真正執行的流程。在問題難以定位的情況下,匯編可能是分析問題的最后一根稻草。
幫助理解硬件

有些學校的單片機課程是以匯編進行教學的,主要原因就是匯編更貼近硬件。不過我不贊成這種做法,C語言能快速做出一點東西,有利于學生在放棄之前,增加成就感,好堅持下去。但是匯編確實更貼近硬件。

LDR指令

為了便于理解下文,先介紹下LDR指令,其格式如下:

LDR{條件} 目的寄存器 <存儲器地址>

作用:將 存儲器地址 所指地址處連續的4個字節(1個字)的數據傳送到目的寄存器中。LDR指令的尋址方式比較靈活,實例如下:

LDR R0,[R1] ;將存儲器地址為R1的字數據讀入寄存器R0。
LDR R0,[R1,R2] ;將存儲器地址為R1+R2的字數據讀入寄存器R0。
LDR R0,[R1,#8] ;將存儲器地址為R1+8的字數據讀入寄存器R0。
LDR R0,[R1],R2 ;將存儲器地址為R1的字數據讀入寄存器R0,并將R1+R2的值存入R1。
LDR R0,[R1],#8 ;將存儲器地址為R1的字數據讀入寄存器R0,并將R1+8的值存入R1。
LDR R0,[R1,R2]! ;將存儲器地址為R1+R2的字數據讀入寄存器R0,并將R1+R2的值存入R1。
LDR R0,[R1,LSL #3] ;將存儲器地址為R1*8的字數據讀入寄存器R0。
LDR R0,[R1,R2,LSL #2] ;將存儲器地址為R1+R2*4的字數據讀入寄存器R0。
LDR R0,[R1,,R2,LSL #2]!;將存儲器地址為R1+R2*4的字數據讀入寄存器R0,并將R1+R2*4的值存入R1。
LDR R0,[R1],R2,LSL #2 ;將存儲器地址為R1的字數據讀入寄存器R0,并將R1+R2*4的值存入R1。
LDR R0,Label ;Label為程序標號,Label必須是當前指令的-4~4KB范圍內。

要注意的是:

LDR Rd,[Rn],#0x04 ;這里Rd不允許是R15。

另外LDRB 的指令格式與LDR相似,只不過它是將存儲器地址中的8位(1個字節)讀到目的寄存器中。LDRH的指令格式也與LDR相似,它是將內存中的16位(半字)讀到目的寄存器中。

LDR R0,=0xff

這里的LDR不是arm指令,而是偽指令。這個時候與MOVE很相似,只不過MOV指令后的立即數是有限制的。這個立即數必須是0X00-OXFF范圍內的數經過偶數次右移得到的數,所以MOV用起來比較麻煩,因為有些數不那么容易看出來是否合法。

2、如何在KEIL下閱讀匯編

按d進入debug模式,在view下選擇disassembly window 。

100059172-113890-1.png

看光標,c文件下指向了main函數的第一行。

匯編窗口也指向了對應的語句。但是,在執行C語言的第一行之前,仍然有許多操作要做,比如變量放在哪?在哪里調用了main函數等,這些操作都被集成開發環境IDE給封裝起來了。我們必須知道,在執行main函數之前,有許多事情要做,只不過,初學的時候不必理會。以下是C語言源碼,功能是點亮LED

//main.c #include int main(void) { RCC->APB2ENR |= RCC_APB2ENR_IOPBEN; GPIOB->CRL &= ~(0xf<<(1*4)); GPIOB->CRL |= 0x2<<(1*4); GPIOB->ODR &= ~(1<<1); return 0; } //main.h #define RCC_APB2ENR (*(unsigned int *)0x40021018) #define GPIOB_CRL (*(unsigned int *)0x40010c00) #define GPIOB_ODR (*(unsigned int *)0x40010c0c)

匯編窗口往上翻,確實很多語句,先看這幾行代碼的匯編:

100059172-113891-2.jpg

先說最常用的兩句匯編:

LDR r0,[r1] r0 = *r1

STR r0,[r1] *r1 = r0

MOV r0,r1 r1->r0拷貝

100059172-113892-3.png

從內存0x0800 017c的32位數據拷貝到r0:

r0 = * 0x0800 017c

我們看到的 1000 4002其實 就是0x4002 1000。這里邊有個知識點叫做大小端模式,以下簡單講解,不能理解就記住。

100059172-113893-4.jpg

這個數據是在地址是這么存放的:

7C 7D 7E 7F
00 10 02 40

實際數據是0x4002 1000

* 0x0800 017c=0x4002 1000

然后r0的值+0x18也就是24 因為這個是第6號(第6號就是第7個的意思)元素

得到r0 = *0x4002 1018,r0的值由一個地址,變成了地址所存放的數據。

然后是或0x08操作,結果再復制給r0,*0x4002 1018 |=0x08

給r1分配地址,這個地址也是0x4002 1000, r1 = *0x4002 1000

把r0存放的值,(不是r0的地址,)存到r1+18的空間上

*(r1+0x18) = r0
*0x4002 1018 = (*0x4002 1018 |=0x08)
*0x4002 1018|=0x08

最終結果:地址4002 1018的數,執行了或0x08的操作。再分析下一句 :

100059172-113895-6.jpg

前兩句給r0分配空間,r0 = *0x4001 0c00

然后用BIC清除數據位,把4-7位清零,結果再賦值給r0。

*0x4001 0c00 &= ~(0xf0)
r1 = *0x4001 0c00
*0x4001 0c00 &= ~(0xf0)

剩下的不再詳細分析,直接給答案 :

100059172-113894-5.jpg

***0x4001 0c00 |= 0x20
0x4001 0c0c &= ~(0x02)*

最終,可以看到C語句被翻譯成了意料之中的匯編語句,自己的意圖被機器準確的理解了。

來源 | STM32嵌入式開發
整理文章為傳播相關技術,版權歸原作者所有,如有侵權,請聯系刪除
審核編輯:何安

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2309

    文章

    11162

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    強化學習會讓自動駕駛模型學習更快嗎?

    [首發于智駕最前沿微信公眾號]在談及自動駕駛大模型訓練時,有的技術方案會采用模仿學習,而有些會采用強化學習。同樣作為大模型的訓練方式,強化學習有何不同?又有什么特點呢? 什么是強化學習
    的頭像 發表于 01-31 09:34 ?643次閱讀
    強化<b class='flag-5'>學習</b>會讓自動駕駛模型<b class='flag-5'>學習</b>更快嗎?

    自動駕駛中常提的模仿學習是什么?

    當談及自動駕駛模型學習時,經常會提到模仿學習的概念。所謂模仿學習,就是模型先看別人怎么做,然后學著去做。自動駕駛中的模仿學習,就是把人類司機在各種路況下的行為做成范例,記錄下看到了什么
    的頭像 發表于 01-16 16:41 ?1994次閱讀

    學習單片機快速方法

    使用開發軟件,比如KEIL。建議大家用C言語編程,匯編語言有時間可以學習一下。 畢竟C語言一目了然,移植性較好。雖然匯編效率高,但是難懂。況且現在單片機集成度越來越高,不必要那么高效率的代碼。你想想,花
    發表于 01-14 07:42

    機器學習和深度學習中需避免的 7 個常見錯誤與局限性

    無論你是剛入門還是已經從事人工智能模型相關工作一段時間,機器學習和深度學習中都存在一些我們需要時刻關注并銘記的常見錯誤。如果對這些錯誤置之不理,日后可能會引發諸多麻煩!只要我們密切關注數據、模型架構
    的頭像 發表于 01-07 15:37 ?191次閱讀
    機器<b class='flag-5'>學習</b>和深度<b class='flag-5'>學習</b>中需避免的 7 個常見錯誤與局限性

    匯編語言還有必要學習

    1、嵌入式操作系統需要匯編語言 2、實時性要求非常高的地方,需要匯編語言,比如FFT算法。 3、匯編語言做運算那叫一個痛苦,下面是一段雙字節乘法,浮點數就更難搞
    的頭像 發表于 11-25 11:46 ?636次閱讀
    <b class='flag-5'>匯編</b>語言還有必要<b class='flag-5'>學習</b>嗎

    科普|通信射頻接頭學習

    科普|通信射頻接頭學習
    的頭像 發表于 08-19 17:09 ?925次閱讀
    科普|通信射頻接頭<b class='flag-5'>學習</b>

    PID控制算法學習筆記資料

    用于新手學習PID控制算法。
    發表于 08-12 16:22 ?7次下載

    ARM入門學習方法分享

    )架構。學習ARM的開始可以從學習RISC和CISC架構的基礎知識開始。 二、學習匯編語言:ARM架構的核心是匯編語言。
    發表于 07-23 10:21

    DeepSeeK學習資料

    104頁DeepSeeK學習資料(清華)
    發表于 06-08 09:57 ?2次下載

    電子硬件工程師如何從零開始學習?(文末免費分享從零開始學習資料)

    經常有用戶咨詢,如何學習和提升電子硬件能力,有沒有適合小白學習的資料等等;電子硬件工程師是一個結合理論、實踐和創新能力的職業,需要掌握電路設計、元器件選型、PCB設計、嵌入式系統、測試調試等多方面
    的頭像 發表于 06-04 07:36 ?2180次閱讀
    電子硬件工程師如何從零開始<b class='flag-5'>學習</b>?(文末免費分享從零開始<b class='flag-5'>學習</b>資料)

    STM32單片機學習進階路線】FreeRTOS嵌入式開發指南:從入門到智能循跡避障小車項目實戰(含文檔代碼)

    STM32學習路徑一般是先掌握裸機開發,再進階學習RTOS。簡單的功能可通過裸機實現,而復雜產品則需借助RTOS來完成。隨著RTOS應用場景日益增多,尤其在物聯網快速發展的推動下,越來越多企業在
    的頭像 發表于 05-29 11:46 ?1300次閱讀
    【<b class='flag-5'>STM32</b>單片機<b class='flag-5'>學習</b>進階路線】FreeRTOS嵌入式開發指南:從入門到智能循跡避障小車項目實戰(含文檔代碼)

    使用MATLAB進行無監督學習

    無監督學習是一種根據未標注數據進行推斷的機器學習方法。無監督學習旨在識別數據中隱藏的模式和關系,無需任何監督或關于結果的先驗知識。
    的頭像 發表于 05-16 14:48 ?1438次閱讀
    使用MATLAB進行無監督<b class='flag-5'>學習</b>

    請問STM32WBA65如何進行matter的學習

    STM32WBA65如何進行matter的學習?相關的支持都有哪些?有一個X-CUBE-MATTER,可是這個沒有集成在STM32CubeMX中
    發表于 04-24 07:22

    STM32Cube學習筆記 (十六篇全)

    資料介紹: STM32Cube學習筆記,一步一步手把手帶你進入STM32Cube的世界,包括點燈,按鍵,串口,ADC,DAC等等一共16篇。 純分享貼,有需要可以直接下載附件獲取完整資料! (如果內容有幫助可以關注、點贊、
    發表于 03-22 17:02

    請問STM32部署機器學習算法硬件至少要使用哪個系列的芯片?

    STM32部署機器學習算法硬件至少要使用哪個系列的芯片?
    發表于 03-13 07:34