chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

riscv如何實(shí)現(xiàn)自定義指令并用qemu運(yùn)行詳解

嵌入式IoT ? 來源:嵌入式IoT ? 作者:嵌入式IoT ? 2021-05-02 10:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1.說明

riscv支持指令集自定義擴(kuò)展,這大大增加了riscv的可玩性,同時(shí)對(duì)于一些實(shí)際應(yīng)用中,自己通過一條指令來實(shí)現(xiàn)特定的功能,效率非常高,當(dāng)然,前提是硬件平臺(tái)需要對(duì)該指令的支持。

本文主要利用qemu模擬硬件平臺(tái),實(shí)現(xiàn)特定指令解析,同時(shí)寫裸機(jī)代碼來測(cè)試該指令的運(yùn)行情況。當(dāng)然,如果實(shí)現(xiàn)的很好,是需要修改riscv的gcc的,讓自己的擴(kuò)展指令加入。這里不做修改,后面會(huì)詳細(xì)描述細(xì)節(jié)。

自定義指令實(shí)現(xiàn)完成后,用qemu對(duì)功能進(jìn)行仿真,然后通過fgpa驗(yàn)證具體的行為,最后流片,一個(gè)完整的riscv,并支持自定義指令的芯片就可以完成了。

這里可以實(shí)現(xiàn)一個(gè)cube指令,并定義該指令的含義是將傳入的值進(jìn)行三次冪,得到最后的結(jié)果。

qemu模擬的硬件平臺(tái)是sifive_u。

2.riscv擴(kuò)展指令的添加

目的

實(shí)現(xiàn)cube指令,傳入一個(gè)數(shù),比如2,那么該指令返回的結(jié)果是8,如果是3,則返回3^3=27。

riscv指令的類型:

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

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

目前的實(shí)現(xiàn)只基于R-type。

其擴(kuò)展指令集的格式如下

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

按照其語(yǔ)法規(guī)則opcode表示操作碼,目前是7位,對(duì)于非壓縮指令來說,最后兩位是1。所以自己可以定義一個(gè)操作碼,當(dāng)然有一些操作碼已經(jīng)使用了,具體可以查看下面的倉(cāng)庫(kù)。

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

也可以在riscv官網(wǎng)上

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

比如關(guān)于算數(shù)的指令集定義如下:

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

自己設(shè)計(jì)一條指令要在這些標(biāo)準(zhǔn)指令之外的,比如操作碼為0x7b。

內(nèi)聯(lián)匯編格式如下:

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

于是,按照語(yǔ)法解析如下:

* func7 rs2 rs1 func3 rd opcode

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

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

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

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

3.裸機(jī)代碼編譯

下面一段非常簡(jiǎn)單的針對(duì)sifive_u的裸機(jī)代碼,并在進(jìn)入main函數(shù)后,直接調(diào)用custom_cube計(jì)算得到結(jié)果。

#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);

}

程序非常簡(jiǎn)單,就是判斷custom_cube得到計(jì)算結(jié)果是否與a*a*a的值相等。

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

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

下載sifive的交叉編譯工具鏈即可,不需要自己編譯工具鏈,添加到系統(tǒng)環(huán)境變量,即可編譯。

通過反匯編查看

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

可以看到如下的信息:

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

可以看到gcc并不認(rèn)識(shí)這條指令,沒法翻譯成偽代碼,所以直接變成機(jī)器碼了。

手動(dòng)分析一下這個(gè)機(jī)器碼

* func7 rs2 rs1 func3 rd opcode

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

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

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

通過上述分析,主要關(guān)注傳遞的參數(shù)rs1與rd。其值都是01111,因?yàn)榧拇嫫饕还彩?2位,所以用五位來表示,此時(shí)使用了x15寄存器傳遞參數(shù)同時(shí)作為返回值。

4.qemu編譯和指令的擴(kuò)展

本機(jī)測(cè)試環(huán)境是Ubuntu20.04,首先需要從官方網(wǎng)站上下載最新的代碼。

執(zhí)行下面的命令,安裝編譯環(huán)境。

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

并進(jìn)入qemu目錄并創(chuàng)建build目錄,進(jìn)入build,輸入下面語(yǔ)句開始編譯。

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

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

4.1 添加擴(kuò)展指令的decodetree

由于riscv指令格式具有一定的規(guī)律,所以有人根據(jù)語(yǔ)法規(guī)則寫了一個(gè)通用的python腳本來生產(chǎn)對(duì)應(yīng)指令解析函數(shù),這也是非常值得學(xué)習(xí)。qemu是通過指令集解析的,目前只需在decodetree中增加一條cube指令的實(shí)現(xiàn)即可。

在target/riscv/insn32.decode中。

只需要按照規(guī)定的格式排版即可

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

定義其格式

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

4.2 添加擴(kuò)展函數(shù)

在擴(kuò)展函數(shù)實(shí)現(xiàn)上可以在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;

}

當(dāng)指令集解析時(shí),匹配上操作碼后,可以執(zhí)行該函數(shù)。

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

DEF_HELPER_1(cube, tl, tl)

其中第一個(gè)參數(shù)為名稱,第二個(gè)是返回值,第三個(gè)是參數(shù)傳遞值。

4.3 解析函數(shù)實(shí)現(xiàn)

可以在target/riscv/op_helper.c中添加具體指令的實(shí)現(xiàn)。

target_ulong helper_cube(target_ulong rs1)

{

target_ulong val;

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

return val*val*val;

}

由于該指令是實(shí)現(xiàn)立方乘法,所以返回乘法值即可。

5.功能測(cè)試與驗(yàn)證

qemu重新編譯后,執(zhí)行第二章節(jié)的代碼。

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

當(dāng)指令執(zhí)行正確會(huì)輸出ok。

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

實(shí)際執(zhí)行效果如下:

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

此時(shí),可以正常的執(zhí)行成功。
編輯:lyn

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

    關(guān)注

    0

    文章

    11

    瀏覽量

    9892
  • RISC-V
    +關(guān)注

    關(guān)注

    48

    文章

    2772

    瀏覽量

    51757
  • qemu
    +關(guān)注

    關(guān)注

    0

    文章

    57

    瀏覽量

    5866

原文標(biāo)題:riscv實(shí)現(xiàn)自定義指令并用qemu運(yùn)行

文章出處:【微信號(hào):Embeded_IoT,微信公眾號(hào):嵌入式IoT】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    易靈思FPGA RISC-V自定義指令的使用方法

    功耗設(shè)備到高性能計(jì)算。易靈思提供完整的RISC-V 解決方案,致力于讓開發(fā)者和硬件設(shè)計(jì)人員可以根據(jù)需要自定義和擴(kuò)展指令集,且無需擔(dān)心專有技術(shù)的限制。
    的頭像 發(fā)表于 11-24 11:36 ?3231次閱讀
    易靈思FPGA RISC-V<b class='flag-5'>自定義</b><b class='flag-5'>指令</b>的使用方法

    riscv實(shí)現(xiàn)自定義指令并用qemu運(yùn)行

    利用qemu模擬硬件平臺(tái),實(shí)現(xiàn)特定指令解析,同時(shí)寫裸機(jī)代碼來測(cè)試該指令運(yùn)行情況。當(dāng)然,如果實(shí)現(xiàn)
    發(fā)表于 10-31 07:37

    關(guān)于協(xié)處理器自定義指令實(shí)現(xiàn)

    位置1,在上述鏈接的指令格式中也可見其對(duì)應(yīng)關(guān)系: 后面一個(gè)6就是對(duì)應(yīng)指令編號(hào)了,在31位到25位的地方,不同的指令編號(hào)即表示不同的指令,所以每種custom類型都可以
    發(fā)表于 10-31 06:36

    軟硬件協(xié)同技術(shù)分享 - 任務(wù)劃分 + 自定義指令

    利用定時(shí)器中斷,率先判斷該FIFO的值不為空,并且保證一次讀取一個(gè)幀長(zhǎng)(即10個(gè)周期)的數(shù)據(jù),能夠實(shí)現(xiàn)該FIFO內(nèi)數(shù)據(jù)即寫即讀,數(shù)據(jù)寫入不久便能取走的效果。 自定義指令集設(shè)計(jì) E203
    發(fā)表于 10-28 08:03

    采用匯編指示符來使用自定義指令

    具體實(shí)現(xiàn) 1、采用.word .half .dword等匯編指示符直接插入自定義指令,這種方法需要自己指定寄存器。其中.word為插入一個(gè)字的數(shù)據(jù)即32位,.half為插入半字即16位
    發(fā)表于 10-28 06:02

    NucleiStudio如何生成.verilog文件和.dasm文件,以及對(duì).dasm文件中自定義指令反匯編結(jié)果分析

    硬件設(shè)計(jì)需要.verilog文件來運(yùn)行加NICE后的tb仿真、軟件組需要.dasm來確定自定義指令有無被正確編譯。今天,我們來分享一下NucleiStudio如何生成.verilog文件和.dasm
    發(fā)表于 10-24 06:33

    e203自定義指令硬件模塊設(shè)計(jì)不工作是怎么回事?

    設(shè)計(jì)了自定義指令,用軟件跑了verilog二進(jìn)制文件,激勵(lì)進(jìn)去。但自定義的硬件模塊不工作,都是零,是我指令沒給進(jìn)去嗎?還是邏輯有問題?有遇到過類似問題的小伙伴嗎?求解答
    發(fā)表于 10-20 06:50

    HarmonyOS應(yīng)用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統(tǒng)默認(rèn)鍵盤的解決方案,可實(shí)現(xiàn)鍵盤個(gè)性化交互。允許用戶結(jié)合業(yè)務(wù)需求與操作習(xí)慣,對(duì)按鍵布局進(jìn)行可視化重構(gòu)、設(shè)置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護(hù)層面,自定義鍵盤可以
    的頭像 發(fā)表于 06-05 14:19 ?1539次閱讀

    LabVIEW運(yùn)動(dòng)控制(三):EtherCAT運(yùn)動(dòng)控制器的高效加工指令自定義封裝

    LabVIEW高效加工指令自定義封裝
    的頭像 發(fā)表于 04-08 13:49 ?3246次閱讀
    LabVIEW運(yùn)動(dòng)控制(三):EtherCAT運(yùn)動(dòng)控制器的高效加工<b class='flag-5'>指令</b><b class='flag-5'>自定義</b>封裝

    如何添加自定義單板

    在開發(fā)過程中,用戶有時(shí)需要?jiǎng)?chuàng)建自定義板配置。本節(jié)將通過一個(gè)實(shí)例講解用戶如何創(chuàng)建屬于自己的machine,下面以g2l-test.conf為例進(jìn)行說明。
    的頭像 發(fā)表于 03-12 14:43 ?1065次閱讀

    e203在vivado硬件里自定義指令識(shí)別為非法指令怎么解決?

    e203自定義指令硬件模塊設(shè)計(jì),修改內(nèi)核,綜合沒錯(cuò)誤,軟件也修改工具鏈通過并產(chǎn)生verilog文件,但在vivado硬件里自定義指令識(shí)別為非法指令
    發(fā)表于 03-07 07:34

    Altium Designer 15.0自定義元件設(shè)計(jì)

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

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

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

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

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

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

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