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

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

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

  1 前言

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

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

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

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

  2 RISC-V知識圖譜

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

640 (5).png

  3 RISC-V匯編基礎三大塊

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

  3.1 尋址方式

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

 微信截圖_20230616155328.png

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

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

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

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

  3.2 寄存器的用途

  3.2.1 RISC-V的寄存器列表

  微信截圖_20230616155406.png

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

  微信截圖_20230616155424.png

  3.3 匯編指令

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

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

  3.3.1 其他

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

微信截圖_20230616155503.png

  4 更多分享

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

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

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

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

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

  【GCC專欄】[10]

  【信息安全專欄】[11]

  【RT-Thread開發(fā)筆記】[12]

  【freeRTOS開發(fā)筆記】[13]

  【BLE藍牙開發(fā)筆記】[14]

  【ARM開發(fā)筆記】[15]

  【RISC-V開發(fā)筆記】[16]

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

  5 參考鏈接

  RISC-V 生態(tài)架構淺析[17]

  RISC-V寄存器[18]

  RISC-V指令[19]

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

  

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權者。如涉及作品內(nèi)容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久热精品视频在线观看一区| 国产精品久久久久久av下载红粉 | 久久乐国产精品| 亚洲视频导航| 最新精品在线| 亚洲电影免费| 欧美中在线观看| 欧美在线欧美在线| 午夜精品一区二区在线观看| 一区二区日本视频| 亚洲最新中文字幕| 日韩视频免费看| 亚洲乱码国产乱码精品精98午夜| 亚洲国产乱码最新视频| 亚洲国产成人高清精品| 樱桃国产成人精品视频| 激情成人av在线| 黄色成人在线| 亚洲电影免费观看高清完整版在线| 狠狠综合久久av一区二区小说| 国产一区二区在线免费观看 | 性欧美在线看片a免费观看| 亚洲午夜小视频| 亚洲一区二区在线| 亚洲欧美高清| 欧美一区国产二区| 欧美专区在线观看| 久久久亚洲高清| 另类酷文…触手系列精品集v1小说| 久久久夜夜夜| 老妇喷水一区二区三区| 免费毛片一区二区三区久久久| 免费不卡在线观看av| 欧美va亚洲va日韩∨a综合色| 欧美成人一二三| 欧美日韩视频不卡| 国产精品高潮呻吟久久av黑人| 欧美午夜精品一区| 国产欧美日韩一区二区三区| 国产亚洲毛片| 亚洲第一免费播放区| 亚洲精品一区二区网址| 9l国产精品久久久久麻豆| 亚洲午夜黄色| 欧美专区亚洲专区| 亚洲欧洲精品成人久久奇米网 | 亚洲电影欧美电影有声小说| 亚洲国产毛片完整版| 91久久久亚洲精品| 亚洲午夜一二三区视频| 欧美在线影院| 亚洲精品视频免费观看| 亚洲一区二区精品视频| 欧美一区二区三区在线播放| 久久一综合视频| 欧美日韩1区2区3区| 国产精品久久久久久户外露出| 国产精品一区亚洲| 亚洲福利视频专区| 一区二区三区高清在线| 欧美一区二区三区四区在线观看地址| 亚洲国产精品激情在线观看| 一二三四社区欧美黄| 欧美亚洲一区二区在线| 久久综合激情| 欧美日韩情趣电影| 国产偷国产偷亚洲高清97cao| 亚洲第一福利在线观看| 亚洲午夜黄色| 亚洲人久久久| 先锋影院在线亚洲| 欧美激情视频一区二区三区在线播放 | 国产精品久久久久久久久久久久久| 国产日韩综合一区二区性色av| 亚洲盗摄视频| 性欧美激情精品| 一本久道久久综合狠狠爱| 久久精品女人天堂| 欧美日韩一区在线观看视频| 国产一区欧美日韩| 一本久久综合亚洲鲁鲁五月天| 久久电影一区| 亚洲欧美国产高清va在线播| 欧美成人影音| 国产日韩亚洲欧美精品| 99精品热视频| 亚洲麻豆av| 久久香蕉国产线看观看av| 欧美性猛交99久久久久99按摩| 尤物九九久久国产精品的分类| 亚洲亚洲精品在线观看 | 亚洲国产欧美在线人成| 午夜精品视频在线观看一区二区| 欧美大片在线观看一区二区| 国产一区91| 亚洲一区二区三区成人在线视频精品| 99re这里只有精品6| 久久久久久久久伊人| 国产精品人人做人人爽人人添| 亚洲精品午夜精品| 亚洲精品久久7777| 久久综合久久综合这里只有精品| 国产精品一区二区三区成人| 夜夜嗨av一区二区三区网站四季av | 亚洲高清不卡在线观看| 久久成人国产| 国产精品卡一卡二卡三| 日韩一级黄色av| 日韩亚洲在线| 欧美大学生性色视频| 尤物九九久久国产精品的特点| 欧美在线观看你懂的| 欧美一区二区黄色| 国产精品久久久久久av福利软件| 99国产精品| 99在线|亚洲一区二区| 欧美国产综合视频| 一区二区三区在线观看国产| 欧美一区二区在线| 久久精品一区二区三区四区| 国产精品视频yy9299一区| 在线亚洲+欧美+日本专区| 亚洲午夜电影网| 欧美日韩亚洲三区| 日韩亚洲欧美综合| 亚洲视频导航| 欧美视频在线免费看| 亚洲最新合集| 亚洲欧美成人| 国产精品伦一区| 亚洲私人影院| 午夜亚洲性色视频| 国产美女精品视频免费观看| 亚洲影视在线| 欧美一级专区| 国产色综合天天综合网| 欧美一区二区性| 麻豆成人小视频| 亚洲国产精品视频| 99精品视频免费全部在线| 欧美区一区二区三区| 日韩午夜中文字幕| 亚洲一区二区三区在线看| 国产精品久在线观看| 欧美一区二区三区免费视频| 久久精品亚洲乱码伦伦中文| 国产一区二区三区四区三区四| 久久精品人人做人人综合| 噜噜噜在线观看免费视频日韩| 亚洲国产精品一区二区尤物区| 一区二区三区四区精品| 国产精品每日更新| 欧美在线观看网站| 免费成人小视频| 亚洲人成网站777色婷婷| 亚洲图片欧洲图片日韩av| 国产精品久久久久久久久久直播| 欧美亚洲综合在线| 欧美电影在线观看| 一区二区三区精品国产| 欧美一区二区三区在线免费观看 | 另类图片综合电影| 亚洲人线精品午夜| 亚洲欧美国产一区二区三区| 国产欧美日韩精品专区| 亚洲国产精品成人精品| 欧美绝品在线观看成人午夜影视 | 欧美精品一区二区视频| 亚洲一区一卡| 久久一区二区视频| 99热免费精品| 久久精品电影| 日韩一区二区精品在线观看| 欧美一区二区三区四区在线观看地址 | 欧美日韩亚洲三区| 欧美一区二区三区免费大片| 欧美成人免费全部| 亚洲天堂成人在线视频| 久久一区二区三区国产精品 | 蜜臀久久99精品久久久久久9| 亚洲精品中文字| 久久国产欧美| 亚洲精品久久久久久下一站| 欧美专区日韩视频| 亚洲美女中文字幕| 久久九九免费视频| 亚洲精品国产系列| 久久爱www久久做| 亚洲伦理在线观看| 久久精品成人欧美大片古装| 日韩天堂在线视频| 久久久午夜电影| 亚洲小说欧美另类社区| 欧美国产日韩精品| 香蕉久久国产| 欧美日韩在线另类| 亚洲精品偷拍| 国产一区视频观看| 亚洲午夜电影网| 91久久国产精品91久久性色|