女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

3天內不再提示

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

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2022-02-16 13:43 ? 次閱讀

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

1、性能

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

分析問題

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

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

LDR指令

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

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

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

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

要注意的是:

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

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

LDR R0,=0xff

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

2、如何在KEIL下閱讀匯編

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

100059172-113890-1.png

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

匯編窗口也指向了對應的語句。但是,在執(zhí)行C語言的第一行之前,仍然有許多操作要做,比如變量放在哪?在哪里調用了main函數(shù)等,這些操作都被集成開發(fā)環(huán)境IDE給封裝起來了。我們必須知道,在執(zhí)行main函數(shù)之前,有許多事情要做,只不過,初學的時候不必理會。以下是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位數(shù)據(jù)拷貝到r0:

r0 = * 0x0800 017c

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

100059172-113893-4.jpg

這個數(shù)據(jù)是在地址是這么存放的:

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

實際數(shù)據(jù)是0x4002 1000

* 0x0800 017c=0x4002 1000

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

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

然后是或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的數(shù),執(zhí)行了或0x08的操作。再分析下一句 :

100059172-113895-6.jpg

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

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

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

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

100059172-113894-5.jpg

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

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

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

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

    關注

    2289

    文章

    11011

    瀏覽量

    362273
收藏 人收藏

    評論

    相關推薦
    熱點推薦

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

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

    請問STM32WBA65如何進行matter的學習

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

    STM32Cube學習筆記 (十六篇全)

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

    【「嵌入式系統(tǒng)設計與實現(xiàn)」閱讀體驗】+ 學習一個STM32的案例

    說明意法半導體在高校中推廣是很成功的,很多學生一談到嵌入式就想到STM32。今天學習的案例是“基于STM32的水果無損檢測及分揀系統(tǒng)”。這個作品的技術難點其實不大,很容易想到它就是用視覺做檢測,再加上
    發(fā)表于 12-06 22:22

    關于RISC-V學習路線圖推薦

    的編程方法。 學習RISC-V匯編語言 : 了解RISC-V匯編語言的語法和指令格式,編寫簡單的匯編程序。 調試與優(yōu)化 : 使用調試工具(如GDB)對RISC-V程序進行調試和優(yōu)化,提
    發(fā)表于 11-30 15:21

    什么是機器學習?通過機器學習方法能解決哪些問題?

    來源:Master編程樹“機器學習”最初的研究動機是讓計算機系統(tǒng)具有人的學習能力以便實現(xiàn)人工智能。因為沒有學習能力的系統(tǒng)很難被認為是具有智能的。目前被廣泛采用的機器學習的定義是“利用經(jīng)
    的頭像 發(fā)表于 11-16 01:07 ?827次閱讀
    什么是機器<b class='flag-5'>學習</b>?通過機器<b class='flag-5'>學習</b>方法能解決哪些問題?

    NPU在深度學習中的應用

    隨著人工智能技術的飛速發(fā)展,深度學習作為其核心驅動力之一,已經(jīng)在眾多領域展現(xiàn)出了巨大的潛力和價值。NPU(Neural Processing Unit,神經(jīng)網(wǎng)絡處理單元)是專門為深度學習
    的頭像 發(fā)表于 11-14 15:17 ?1676次閱讀

    GPU深度學習應用案例

    GPU在深度學習中的應用廣泛且重要,以下是一些GPU深度學習應用案例: 一、圖像識別 圖像識別是深度學習的核心應用領域之一,GPU在加速圖像識別模型訓練方面發(fā)揮著關鍵作用。通過利用GPU的并行計算
    的頭像 發(fā)表于 10-27 11:13 ?1083次閱讀

    人工智能、機器學習和深度學習存在什么區(qū)別

    人工智能指的是在某種程度上顯示出類似人類智能的設備。AI有很多技術,但其中一個很大的子集是機器學習——讓算法從數(shù)據(jù)中學習
    發(fā)表于 10-24 17:22 ?2753次閱讀
    人工智能、機器<b class='flag-5'>學習</b>和深度<b class='flag-5'>學習</b>存在什么區(qū)別

    AI大模型與深度學習的關系

    AI大模型與深度學習之間存在著密不可分的關系,它們互為促進,相輔相成。以下是對兩者關系的介紹: 一、深度學習是AI大模型的基礎 技術支撐 :深度學習是一種機器學習的方法,通過多層神經(jīng)網(wǎng)
    的頭像 發(fā)表于 10-23 15:25 ?2655次閱讀

    嵌入式學習建議

    原理的嵌入式操作系統(tǒng)進行學習。不要一開始就學習幾種操作系統(tǒng),理解了基本原理,實踐中確有實際需要再學習也不遲。人總是要不斷學習的。 ⑨關于匯編
    發(fā)表于 10-22 11:41

    入門?畢設?競賽?項目練手?STM32/嵌入式/物聯(lián)網(wǎng)學習,有這幾款開發(fā)板就夠了!

    針對STM32單片機、嵌入式Linux、物聯(lián)網(wǎng)初學者,我們精心梳理了從“入門到項目進階”完整學習路徑,并配有詳細的教程、視頻講解、源代碼以及豐富的實戰(zhàn)案例資料。可廣泛用于高校教學、學生畢設、個人學習
    的頭像 發(fā)表于 10-10 16:31 ?901次閱讀
    入門?畢設?競賽?項目練手?<b class='flag-5'>STM32</b>/嵌入式/物聯(lián)網(wǎng)<b class='flag-5'>學習</b>,有這幾款開發(fā)板就夠了!

    深度學習中的無監(jiān)督學習方法綜述

    深度學習作為機器學習領域的一個重要分支,近年來在多個領域取得了顯著的成果,特別是在圖像識別、語音識別、自然語言處理等領域。然而,深度學習模型的強大性能往往依賴于大量有標簽的數(shù)據(jù)進行訓練,這在實際
    的頭像 發(fā)表于 07-09 10:50 ?1533次閱讀

    人工智能、機器學習和深度學習是什么

    在科技日新月異的今天,人工智能(Artificial Intelligence, AI)、機器學習(Machine Learning, ML)和深度學習(Deep Learning, DL)已成為
    的頭像 發(fā)表于 07-03 18:22 ?2523次閱讀

    深度學習與傳統(tǒng)機器學習的對比

    在人工智能的浪潮中,機器學習和深度學習無疑是兩大核心驅動力。它們各自以其獨特的方式推動著技術的進步,為眾多領域帶來了革命性的變化。然而,盡管它們都屬于機器學習的范疇,但深度學習和傳統(tǒng)機
    的頭像 發(fā)表于 07-01 11:40 ?2200次閱讀