色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

riscv如何實現自定義指令并用qemu運行詳解

嵌入式IoT ? 來源:嵌入式IoT ? 作者:嵌入式IoT ? 2021-05-02 10:24 ? 次閱讀

1.說明

riscv支持指令集自定義擴展,這大大增加了riscv的可玩性,同時對于一些實際應用中,自己通過一條指令來實現特定的功能,效率非常高,當然,前提是硬件平臺需要對該指令的支持。

本文主要利用qemu模擬硬件平臺,實現特定指令解析,同時寫裸機代碼來測試該指令的運行情況。當然,如果實現的很好,是需要修改riscv的gcc的,讓自己的擴展指令加入。這里不做修改,后面會詳細描述細節。

自定義指令實現完成后,用qemu對功能進行仿真,然后通過fgpa驗證具體的行為,最后流片,一個完整的riscv,并支持自定義指令的芯片就可以完成了。

這里可以實現一個cube指令,并定義該指令的含義是將傳入的值進行三次冪,得到最后的結果。

qemu模擬的硬件平臺是sifive_u。

2.riscv擴展指令的添加

目的

實現cube指令,傳入一個數,比如2,那么該指令返回的結果是8,如果是3,則返回3^3=27。

riscv指令的類型:

對于riscv,其指令按照特定的類型分為一下幾種。

781de90c-9fec-11eb-8b86-12bb97331649.png

目前的實現只基于R-type。

其擴展指令集的格式如下

.insn r opcode, func3, func7, rd, rs1, rs2

按照其語法規則opcode表示操作碼,目前是7位,對于非壓縮指令來說,最后兩位是1。所以自己可以定義一個操作碼,當然有一些操作碼已經使用了,具體可以查看下面的倉庫。

https://github.com/riscv/riscv-opcodes

也可以在riscv官網上

的第Chapter 24 RV32/64G Instryction Set Listings查看目前riscv定義的指令碼。

比如關于算數的指令集定義如下:

785b3e24-9fec-11eb-8b86-12bb97331649.png

自己設計一條指令要在這些標準指令之外的,比如操作碼為0x7b。

內聯匯編格式如下:

asm volatile(“.insn r 0x7b, 6, 6, %0, %1, x0” : “=r”(cube) : “r”(addr));

于是,按照語法解析如下:

* func7 rs2 rs1 func3 rd opcode

* 31---------25--------19------15------12----------------6----------0

* | 000110 | 00000 | ***** | 110 | ***** | 1111011 |

* |------------------------------------------------------|----------|

上圖中,*表示的是任意值,所以該指令在翻譯的時候,實際上就是取出rs1表示的是寄存器地址,然后返回的是rd,也是寄存器地址。最后,從寄存器中存放的地址取數據則得到相應的值。

3.裸機代碼編譯

下面一段非常簡單的針對sifive_u的裸機代碼,并在進入main函數后,直接調用custom_cube計算得到結果。

#include 《stdio.h》

static int custom_cube(int addr)

{

int cube;

asm volatile (

“.insn r 0x7b, 6, 6, %0, %1, x0”

:“=r”(cube)

:“r”(addr)

);

return cube;

}

void main()

{

int a = 3;

int ret = 0;

ret = custom_cube((int)&a);

if(ret == a*a*a)

{

putchar(‘o’);

putchar(‘k’);

}

else

{

putchar(‘e’);

putchar(‘r’);

putchar(‘r’);

}

while(1);

}

程序非常簡單,就是判斷custom_cube得到計算結果是否與a*a*a的值相等。

代碼可以在下面的地址中找到

https://github.com/bigmagic123/riscv-hello-c

下載sifive的交叉編譯工具鏈即可,不需要自己編譯工具鏈,添加到系統環境變量,即可編譯。

通過反匯編查看

riscv64-unknown-elf-objdump -D build/bin/rv64imac/qemu-sifive_u/hello 》 1.txt

可以看到如下的信息

7868b46e-9fec-11eb-8b86-12bb97331649.png

可以看到gcc并不認識這條指令,沒法翻譯成偽代碼,所以直接變成機器碼了。

手動分析一下這個機器碼

* func7 rs2 rs1 func3 rd opcode

* 31---------25--------19------15------12----------------6----------0

* | 0000110 | 00000 | 01111 | 110 | 01111 | 1111011 |

* |------------------------------------------------------|----------|

通過上述分析,主要關注傳遞的參數rs1與rd。其值都是01111,因為寄存器一共是32位,所以用五位來表示,此時使用了x15寄存器傳遞參數同時作為返回值。

4.qemu編譯和指令的擴展

本機測試環境是Ubuntu20.04,首先需要從官方網站上下載最新的代碼。

執行下面的命令,安裝編譯環境。

sudo apt-get install -y git build-essential pkg-config zlib1g-dev libglib2.0-0 libglib2.0-dev libsdl1.2-dev libpixman-1-dev libfdt-dev autoconf automake libtool librbd-dev libaio-dev flex bison make

sudo apt-get install ninja-build

并進入qemu目錄并創建build目錄,進入build,輸入下面語句開始編譯。

。./configure --prefix=your_path/linux_qemu --target-list=riscv32-softmmu,riscv64-softmmu && make -j8 && make install

其中your_path/linux_qemu是自己存在的目錄。編譯完成后,qemu在該目錄下。

4.1 添加擴展指令的decodetree

由于riscv指令格式具有一定的規律,所以有人根據語法規則寫了一個通用的python腳本來生產對應指令解析函數,這也是非常值得學習。qemu是通過指令集解析的,目前只需在decodetree中增加一條cube指令的實現即可。

在target/riscv/insn32.decode中。

只需要按照規定的格式排版即可

78a4844e-9fec-11eb-8b86-12bb97331649.png

定義其格式

78e483d2-9fec-11eb-8b86-12bb97331649.png

4.2 添加擴展函數

在擴展函數實現上可以在target/riscv/insn_trans/trans_rvi.c.inc中添加

static bool trans_cube(DisasContext *ctx, arg_cube *a)

{

gen_helper_cube(cpu_gpr[a-》rd], cpu_gpr[a-》rs1]);

return true;

}

當指令集解析時,匹配上操作碼后,可以執行該函數。

另外也需要在target/riscv/helper.h函數中添加函數定義

DEF_HELPER_1(cube, tl, tl)

其中第一個參數為名稱,第二個是返回值,第三個是參數傳遞值。

4.3 解析函數實現

可以在target/riscv/op_helper.c中添加具體指令的實現。

target_ulong helper_cube(target_ulong rs1)

{

target_ulong val;

cpu_physical_memory_rw(rs1, &val, 4, 0);

return val*val*val;

}

由于該指令是實現立方乘法,所以返回乘法值即可。

5.功能測試與驗證

qemu重新編譯后,執行第二章節的代碼。

78f5eece-9fec-11eb-8b86-12bb97331649.png

當指令執行正確會輸出ok。

qemu-system-riscv64 -nographic -machine sifive_u -bios none -kernel build/bin/rv64imac/qemu-sifive_u/hello

實際執行效果如下:

791b9cdc-9fec-11eb-8b86-12bb97331649.png

此時,可以正常的執行成功。
編輯:lyn

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

    關注

    0

    文章

    10

    瀏覽量

    9427
  • RISC-V
    +關注

    關注

    45

    文章

    2320

    瀏覽量

    46373
  • qemu
    +關注

    關注

    0

    文章

    57

    瀏覽量

    5371

原文標題:riscv實現自定義指令并用qemu運行

文章出處:【微信號:Embeded_IoT,微信公眾號:嵌入式IoT】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Altium Designer 15.0自定義元件設計

    電子發燒友網站提供《Altium Designer 15.0自定義元件設計.pdf》資料免費下載
    發表于 01-21 15:04 ?0次下載
    Altium Designer 15.0<b class='flag-5'>自定義</b>元件設計

    自定義Modbus通信塊指令的搭建教程

    和歐姆龍E5EZ的智能溫控儀表作為從站為例,為大家分享如何使用自定義的Modbus RTU的通信程序塊,來實現快速高效的Modbus通信程序設計。同時在本文的結尾會為大家提供參考程序和打包好的Modbus RTU通信塊的庫指令
    的頭像 發表于 01-20 10:37 ?304次閱讀
    <b class='flag-5'>自定義</b>Modbus通信塊<b class='flag-5'>指令</b>的搭建教程

    think-cell:自定義think-cell(四)

    C.5 設置默認議程幻燈片布局 think-cell 議程可以在演示文稿中使用特定的自定義布局來定義議程、位置和議程幻燈片上的其他形狀,例如標題或圖片。通過將此自定義布局添加到模板,您可以為整個組織
    的頭像 發表于 01-13 10:37 ?79次閱讀
    think-cell:<b class='flag-5'>自定義</b>think-cell(四)

    think-cell;自定義think-cell(一)

    本章介紹如何自定義 think-cell,即如何更改默認顏色和其他默認屬性;這是通過 think-cell 的樣式文件完成的,這些文件將在前四個部分中進行討論。 第五部分 C.5 設置默認議程幻燈片
    的頭像 發表于 01-08 11:31 ?120次閱讀
    think-cell;<b class='flag-5'>自定義</b>think-cell(一)

    創建自定義的基于閃存的引導加載程序(BSL)

    電子發燒友網站提供《創建自定義的基于閃存的引導加載程序(BSL).pdf》資料免費下載
    發表于 09-19 10:50 ?0次下載
    創建<b class='flag-5'>自定義</b>的基于閃存的引導加載程序(BSL)

    EtherCAT運動控制器PT/PVT實現用戶自定義軌跡規劃

    EtherCAT運動控制器PT/PVT實現用戶自定義軌跡規劃。
    的頭像 發表于 08-15 11:49 ?692次閱讀
    EtherCAT運動控制器PT/PVT<b class='flag-5'>實現</b>用戶<b class='flag-5'>自定義</b>軌跡規劃

    ESP32如何使用庫中的HF相關函數發送自定義AT指令

    請問如何使用庫中的HF相關函數發送自定義AT指令
    發表于 06-17 07:43

    e203自定義指令硬件模塊設計,在vivado硬件里自定義指令識別為非法指令怎么解決?

    e203自定義指令硬件模塊設計,修改內核,綜合沒錯誤,軟件也修改工具鏈通過并產生verilog文件,但在vivado硬件里自定義指令識別為非法指令
    發表于 05-28 06:40

    e203自定義指令硬件模塊設計不工作的原因?

    設計了自定義指令,用軟件跑了verilog二進制文件,激勵進去。但自定義的硬件模塊不工作,都是零,是我指令沒給進去嗎?還是邏輯有問題?有遇到過類似問題的小伙伴嗎?求解答
    發表于 05-27 07:29

    HarmonyOS開發案例:【 自定義彈窗】

    基于ArkTS的聲明式開發范式實現了三種不同的彈窗,第一種直接使用公共組件,后兩種使用CustomDialogController實現自定義彈窗
    的頭像 發表于 05-16 18:18 ?1425次閱讀
    HarmonyOS開發案例:【 <b class='flag-5'>自定義</b>彈窗】

    TSMaster 自定義 LIN 調度表編程指導

    LIN(LocalInterconnectNetwork)協議調度表是用于LIN總線通信中的消息調度的一種機制,我們收到越來越多來自不同用戶希望能夠通過接口實現自定義LIN調度表的需求。所以在
    的頭像 發表于 05-11 08:21 ?730次閱讀
    TSMaster <b class='flag-5'>自定義</b> LIN 調度表編程指導

    HarmonyOS開發案例:【UIAbility和自定義組件生命周期】

    本文檔主要描述了應用運行過程中UIAbility和自定義組件的生命周期。對于UIAbility,描述了Create、Foreground、Background、Destroy四種生命周期。對于頁面
    的頭像 發表于 05-10 15:31 ?1318次閱讀
    HarmonyOS開發案例:【UIAbility和<b class='flag-5'>自定義</b>組件生命周期】

    HarmonyOS開發實例:【自定義Emitter】

    使用[Emitter]實現事件的訂閱和發布,使用[自定義彈窗]設置廣告信息。
    的頭像 發表于 04-14 11:37 ?1035次閱讀
    HarmonyOS開發實例:【<b class='flag-5'>自定義</b>Emitter】

    鴻蒙ArkUI實例:【自定義組件】

    組件是 OpenHarmony 頁面最小顯示單元,一個頁面可由多個組件組合而成,也可只由一個組件組合而成,這些組件可以是ArkUI開發框架自帶系統組件,比如?`Text`?、?`Button`?等,也可以是自定義組件,本節筆者簡單介紹一下自定義組件的語法規范。
    的頭像 發表于 04-08 10:17 ?683次閱讀

    RK3568驅動指南|驅動基礎進階篇-進階5 自定義實現insmod命令實驗

    RK3568驅動指南|驅動基礎進階篇-進階5 自定義實現insmod命令實驗
    的頭像 發表于 02-20 14:10 ?756次閱讀
    RK3568驅動指南|驅動基礎進階篇-進階5 <b class='flag-5'>自定義</b><b class='flag-5'>實現</b>insmod命令實驗
    主站蜘蛛池模板: 老阿姨才是最有V味的直播| 亚洲 欧美 国产 综合 播放| 538prom国产在线视频一区| 酒色.com| YELLOW高清视频免费观看| 日韩视频在线观看| 国产亚洲视频中文字幕| 综合久久伊人| 日本亚洲精品色婷婷在线影院| 国产精品日本不卡一区二区| 二级毛片在线观看| 午夜福利小视频400| 99久久亚洲综合精品| 色婷婷综合久久久中文字幕| 黄色三级网站| bt成人种子| 亚洲第一色网| 男女床上黄色| 国产成人女人在线视频观看| 诱人的秘书BD在线观看| 日韩中文无线码在线视频| 黑丝女仆恋上我| 超碰视频97av| 在线观看成人免费| 桃花在线视频观看免费| 美女视频秀色福利视频| 国产东北男同志videos网站| 123成人站| 亚洲2017天堂色无码| 男人插女人动态| 果冻传媒在线观看视频| 超大BBWWW| 制服的微热| 亚州三级久久电影| 欧美日韩视频高清一区| 九九免费的视频| 国产精品久久婷婷五月色 | 日本阿v在线资源无码免费| 久久99精品国产麻豆婷婷| 国产成人精品午夜福麻豆报告| 91蜜桃视频|