《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > RISC-V匯編基礎的三大塊知識

RISC-V匯編基礎的三大塊知識

2023-06-16
作者: 李肯
來源:架構師李肯
關鍵詞: RISC-V 匯編基礎

  1 前言

  玩嵌入式的,或多或少都接觸ARM。

  但是近些年隨著科技的發展,CPU的架構家族中,新增了一個叫RISC-V的家伙。

  RISC-V(讀作“RISC-FIVE”)是基于精簡指令集計算(RISC)原理建立的開放指令集架構[1](ISA),V表示為第五代RISC(精簡指令集計算機[2]),表示此前已經四代RISC處理器原型芯片。每一代RISC處理器都是在同一人帶領下完成,那就是加州大學伯克利分校的David A. Patterson教授。與大多數ISA相反,「RISC-V ISA可以免費地用于所有希望的設備中,允許任何人設計、制造和銷售RISC-V芯片和軟件」。它雖然**不是第一個開源的的指令集(ISA)**,但它很重要,因為它第一個被設計成可以根據具體場景可以選擇適合的指令集的指令集架構。基于RISC-V指令集架構可以設計服務器CPU[3],家用電器cpu,工控cpu和用在比指頭小的傳感器中的cpu。

  更多詳細介紹,請參考百度百科[4],RISC-V簡介[5].

  2 RISC-V知識圖譜

  本文先列個大綱,后續有時間再補充。

640 (5).png

  3 RISC-V匯編基礎三大塊

  這里整理了RISC-V匯編中非常基礎的三大塊知識,了解了這三大塊內容基本可以看懂甚至編譯一些簡單的匯編程序。

  3.1 尋址方式

  RISC-V分支指令尋址,在之前的B類型指令就是其中之一。這種格式可以表示從-4096到4094的分支地址,以2的倍數表示。B型格式包括一個7位操作碼、一個3位功能碼、兩個5位的寄存器操作數( rs1和 rs2)和一個12位地址立即數。該地址使用特殊的編碼方式,簡化了數據通路設計,但使組裝變得復雜。下面這條指令

 微信截圖_20230616155328.png

  其中條件分支的操作碼是11001112,而bne 的funct3碼是0012 RISC-V的無條件跳轉–鏈接指令(jal),是分支尋址的另一種方法,也是唯一使用J型格式的指令。該指令由一個7位操作碼、一個5位目標寄存器操作數(rd)和一個20位地址立即數組成。鏈接地址,即jal之后的指令的地址,被寫入rd 中。

  如果程序的地址必須適合這個20位字段,則意味著沒有程序可能大于220,所以另一種方法是指定一個與分支地址偏移量相加的寄存器,這樣就允許程序大到264,并且仍然能夠使用條件分支指令,以便分支指令可以按如下來計算:

  程序計數器=寄存器內容+分支地址偏移量 這樣就允許程序大到2^64,并且仍然能夠使用條件分支指令

  立即數尋址,操作數是指令本身的常量。寄存器尋址,操作數在寄存器中。基址或偏移尋址,操作數于內存中,其地址是寄存器和指令中的常量之和。PC相對尋址,分支地址是PC和指令中常量之和。注: 「加載和存儲對字節、半字、字或雙字的訪問有不同的版本」。

  3.2 寄存器的用途

  3.2.1 RISC-V的寄存器列表

  微信截圖_20230616155406.png

  3.2.2 RISC-V寄存器在匯編代碼中使用

  微信截圖_20230616155424.png

  3.3 匯編指令

  RISC-V有六種基本指令格式:

  R 類型指令,用于寄存器-寄存器操作I 型指令,用于短立即數和訪存 load 操作S 型指令,用于訪存 store 操作B 類型指令,用于條件跳轉操作U 型指令,用于長立即數J 型指令,用于無條件跳轉

  3.3.1 其他

  本人有RISC-V相關的學習資料若干份,這些都是非常經典使用的學習材料,感興趣的可以掃碼VX聯系我。

微信截圖_20230616155503.png

  4 更多分享

  歡迎關注我的github倉庫01workstation[6],日常分享一些開發筆記和項目實戰,歡迎指正問題。

  同時也非常歡迎關注我的CSDN主頁和專欄:

  【CSDN主頁:架構師李肯】[7]

  【RT-Thread主頁:架構師李肯】[8]

  【C/C++語言編程專欄】[9]

  【GCC專欄】[10]

  【信息安全專欄】[11]

  【RT-Thread開發筆記】[12]

  【freeRTOS開發筆記】[13]

  【BLE藍牙開發筆記】[14]

  【ARM開發筆記】[15]

  【RISC-V開發筆記】[16]

  有問題的話,可以跟我討論,知無不答,謝謝大家。

  5 參考鏈接

  RISC-V 生態架構淺析[17]

  RISC-V寄存器[18]

  RISC-V指令[19]

  以上參考資料,由本人整理,但來源于網絡,侵刪!

  

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: a级毛片免费全部播放| 国产免费人人看大香伊| 久久午夜免费鲁丝片| 欧美最猛性xxxxx69交| 国产二区在线播放| 777色淫网站女女| 成人福利小视频| 亚洲av永久无码精品水牛影视 | 中文织田真子中文字幕| 日韩日韩日韩日韩日韩| 人人妻人人澡人人爽人人精品浪潮 | 97久久精品人人澡人人爽| 女网址www女大全小| 久久精品国产一区二区三区不卡| 特黄特色大片免费播放器999| 国产亚洲综合久久| 8av国产精品爽爽ⅴa在线观看| 天天干天天操天天干| 久久人人做人人玩人精品| 最新中文字幕一区二区乱码| 亚洲午夜久久久影院伊人| 福利所第一导航| 国产人妖在线播放| 黄色一级片在线看| 国产无遮挡又黄又爽免费网站| japanese国产在线观看| 少妇被躁爽到高潮无码文| 中国成人在线视频| 成年美女黄网站18禁免费| 五月婷婷在线视频| 八戒八戒神马影院在线观看4| 美女被暴羞羞免费视频| 国产一国产一级毛片视频在线| 永久黄色免费网站| 天天综合色天天综合网| zooslook欧美另类dogs| 日本三级视频网站| 亚洲一区二区三区在线播放| 波多野结衣69xx| 亚洲精品福利视频| 毛片免费视频在线观看|