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

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

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

如何實(shí)現(xiàn)RISC-V架構(gòu)的交叉調(diào)試系統(tǒng)設(shè)計(jì)

麥克泰技術(shù) ? 來(lái)源:嵌入式系統(tǒng)專家之聲 ? 2023-12-19 11:07 ? 次閱讀

0 引言

國(guó)內(nèi)外各類構(gòu)的嵌入式芯片在競(jìng)爭(zhēng)激烈的市場(chǎng)環(huán)境不斷突破技術(shù)壁壘,飛速提升性能。芯片配套的集成開(kāi)發(fā)環(huán)境(IDE,Integrated Development Environment)作為開(kāi)發(fā)中的關(guān)鍵工具,其提供的交叉編譯和交叉調(diào)試功能解決了嵌入式開(kāi)發(fā)中目標(biāo)機(jī)的運(yùn)算能力和存儲(chǔ)空間有限的缺陷,對(duì)芯片嵌入式開(kāi)發(fā)的重要性不言而喻。

近年來(lái),各芯片廠商都在大力研發(fā)自己芯片的配套IDE,力圖打破 KEIL和IAR兩個(gè)行業(yè)標(biāo)桿的壟斷局面。這些免費(fèi)IDE(如ST的 CubeIDE和TI的CCS)大部分是基于Eclipse深度定制的,包含 Eclipse、SDK插件、代碼生成插件、編譯工具鏈,以及調(diào)試工具鏈的開(kāi)發(fā)環(huán)境。目前,這些IDE存在僅針對(duì)各自產(chǎn)品的定制化開(kāi)發(fā)、源碼封閉導(dǎo)致二次開(kāi)發(fā)困難等問(wèn)題。基于上述原因,新上市的硬件產(chǎn)品移植適配工作量巨大,不利于IDE的推廣使用。

本文主要由Eclipse、GDB、OpenOCD(采用JTAG標(biāo)準(zhǔn))組成的自主方案實(shí)現(xiàn)了IDE。鑒于交叉調(diào)試的重要性,本文重點(diǎn)介紹基于GDB和OpenOCD的技術(shù)選型,實(shí)現(xiàn)了目標(biāo)機(jī)(芯片型號(hào)為基于RISC架構(gòu)的RAC102)的交叉調(diào)試方案。在該方案中,對(duì)GDB和OpenOCD源碼進(jìn)行自主編譯移植后,兩者采用遠(yuǎn)程通信協(xié)議(RSP,Remote SerialProtocol)進(jìn)行通信,完成可執(zhí)行程序的調(diào)試操作。通過(guò)此案例驗(yàn)證了IDE設(shè)計(jì)方案中交叉調(diào)試的可行性,為后續(xù)其余架構(gòu)的IDE適配提供了指導(dǎo)思路。在此技術(shù)基礎(chǔ)上,提供支持多架構(gòu)芯的通用且開(kāi)放的嵌入式開(kāi)發(fā)集成環(huán)境。

1 設(shè)計(jì)思路

1.1 器件選型

1.1.1 編輯器選型

Eclipse平臺(tái)為更好地為C/C++開(kāi)發(fā)人員服務(wù),衍生出了Eclipse CDT 擴(kuò)展套件。該套件可以為嵌入式開(kāi)發(fā)者提供C/C+ +程序的編輯、編 譯、運(yùn)行及本地調(diào)試等功能[1]作為利用機(jī)器接口(MI,Machine Interface)支持C/C++源碼調(diào)試最好的開(kāi)源工具,采用CDT套件作 為交叉調(diào)試的前端,通過(guò)MI接口使CDT和GDB相互通信,構(gòu)建了可視化的嵌入式遠(yuǎn)程調(diào)試軟件,提高了開(kāi)發(fā)效率。

1.1.2 調(diào)試器選型

GDB是GNU工具集中的開(kāi)源且高適配性的調(diào)試器,根據(jù)可執(zhí)行程序的運(yùn)行位置分為本地調(diào)試和遠(yuǎn)程調(diào)試兩種模式。在遠(yuǎn)程調(diào)試模式下,GDB與調(diào)試代理(OpenOCD、GDBServer等)通過(guò)RSP協(xié)議進(jìn)行信息交互,完成目標(biāo)機(jī)上可執(zhí)行文件的調(diào)試控制。注意,若目標(biāo)機(jī)架構(gòu)與宿主機(jī)架構(gòu)不同,則稱為交叉調(diào)試。此外,GDB支持兩種外部調(diào)試工具接口:MI和CLI(CommandLineInterface),其多樣化的接口、完善的目標(biāo)處理機(jī)制等特點(diǎn)為后續(xù)IDE的架構(gòu)適配打下了基礎(chǔ)。

1.1.3 調(diào)試代理選型

OpenOCD(Open On Chip Debugger)是一個(gè)開(kāi)源、通用的片上調(diào)試器,并且可作為支持JTAG標(biāo)準(zhǔn)的調(diào)試代理。目前,可與GDB聯(lián)合為RISC V、ARM、MIPS等架構(gòu)的芯片提供在線調(diào)試工具[2]。OpenOCD開(kāi)源的好處在于,可自主改寫(xiě)函數(shù)源碼進(jìn)而適配目標(biāo)芯片的特性。因此,基于GDB和OpenOCD搭建的調(diào)試系統(tǒng)具備功能拓展簡(jiǎn)單靈活、架構(gòu)兼容性強(qiáng)的優(yōu)勢(shì)。此外,OpenOCD支持各種商用JTAG仿真器、直接讀寫(xiě)物理地址和核內(nèi)部寄存器等特點(diǎn)也是技術(shù)選型時(shí)考慮的因素。

1.1.4 調(diào)試標(biāo)準(zhǔn)選型

JTAG(JointTest Action Group)邊界掃描調(diào)試標(biāo)準(zhǔn)主要提供微處理器電氣特性測(cè)試和目標(biāo)機(jī)可執(zhí)行程序調(diào)試兩大功能,適用于配置了JTAG接口的芯片電路。基于JTAG標(biāo)準(zhǔn)的微處理器在調(diào)試模式下中斷可執(zhí)行程序,上層的GDB和OpenOCD發(fā)送調(diào)試命令到調(diào)試模塊,完成后續(xù)程序調(diào)試工作。采用JTAG標(biāo)準(zhǔn)的主要原因是:①基于ARM、RISCV、Intel等主流架構(gòu)的微處理器實(shí)現(xiàn)了JTAG調(diào)試接口,該標(biāo)準(zhǔn)適配性高。②基于該標(biāo)準(zhǔn)的調(diào)試具備程序無(wú)侵入、依賴簡(jiǎn)單、高穩(wěn)定性的特點(diǎn)。

1.2 整體框架

本文自主設(shè)計(jì)的IDE以主流嵌入式開(kāi)發(fā)類似的宿主機(jī)目標(biāo)機(jī)通用結(jié)構(gòu)為基礎(chǔ)進(jìn)行整體框架設(shè)計(jì),如圖1所示??紤]到目標(biāo)機(jī)存儲(chǔ)資源的局限性,目標(biāo)機(jī)端放置調(diào)試代理(GDB Server或GDB STUB)的傳統(tǒng)方案被摒棄。本框架方案中,目標(biāo)機(jī)端僅運(yùn)行可執(zhí)行程序,宿主機(jī)端由Eclipse、GDB和OpenOCD組成,其中OpenOCD完成了傳統(tǒng)方案下目標(biāo)機(jī)端的調(diào)試代理工作。在框架中,首先CDT圖形界面通過(guò)UI操作來(lái)調(diào)用MI接口與GDB,進(jìn)行調(diào)試命令發(fā)送和調(diào)試信息獲取。GDB通過(guò)MI接口獲取調(diào)試命令后,在RSP序列包封裝和解析機(jī)制下與Open-OCD進(jìn)行調(diào)試命令傳遞和調(diào)試信息反饋。

最后,JTAG仿真器通過(guò)宿主機(jī)通信端口接收到OpenOCD的指令,將其轉(zhuǎn)換為標(biāo)準(zhǔn)的JTAG信號(hào)并通過(guò)調(diào)試訪問(wèn)端口(DAP,Debug Access Port)發(fā)送給目標(biāo)機(jī)端。JTAG進(jìn)入調(diào)試模式讀取內(nèi)存和寄存器,按照需求進(jìn)行可執(zhí)行程序調(diào)試,目標(biāo)機(jī)完成調(diào)試后再將調(diào)試結(jié)果反饋給宿主機(jī)。通過(guò)上述流程,IDE完成目標(biāo)機(jī)可執(zhí)行程序的交叉調(diào)試。

5193db2c-9e1b-11ee-8b88-92fbcf53809c.png

圖1 IDE設(shè)計(jì)框圖

2實(shí)現(xiàn)方式

2.1 驅(qū)動(dòng)適配

為了目標(biāo)機(jī)的可執(zhí)行程序被順利調(diào)試,首先要保證目標(biāo)機(jī)和宿主機(jī)之間的傳輸正常。由于使用默認(rèn)驅(qū)動(dòng)時(shí),通過(guò)USB端口與仿真器 通信會(huì)發(fā)生異常錯(cuò)誤,因此,采用Zadig工具更新宿主機(jī)的USB驅(qū)動(dòng),從而保證目標(biāo)機(jī)可以與宿主機(jī)進(jìn)行正常通信。其驅(qū)動(dòng)安裝步驟如下:

①在菜單欄中選擇“Options”->“List All Devices”,查看當(dāng)前連接到計(jì)算機(jī)上的所有USB設(shè)備。

②在接口復(fù)合框中分別選中目標(biāo)機(jī)對(duì)應(yīng)的“Dual RS232-HS (Interface 0)”接口,并在驅(qū)動(dòng)復(fù)合框選擇“WinUSB”驅(qū)動(dòng)。

③選擇“Replace Driver”進(jìn)行驅(qū)動(dòng)更新即可。

④重復(fù)上述3個(gè)步驟,步驟②中接口選擇“Dual RS232-HS (Interface 1)”,完成該接口的驅(qū)動(dòng)安裝。

2.2 操作系統(tǒng)適配

由于IDE設(shè)計(jì)方案中交叉調(diào)試的調(diào)試器選用了GDB,因此運(yùn)行在 Unix/Linux系統(tǒng)下的GDB適配宿主機(jī)系統(tǒng)(Windows系統(tǒng))是需要完成的目標(biāo)。為了實(shí)現(xiàn)上述目的,可以采用Cygwin工具,其功能就是 在Windows上仿真Linux操作系統(tǒng),使得GNU工具鏈可以運(yùn)行在Linux模擬環(huán)境。在運(yùn)行Windows的同時(shí),僅依賴Cygwin核心的動(dòng)態(tài) 庫(kù)(如cygwin1.dll)也可以使用VIM、GCC、make、GDB等Linux工具。注意,安裝Cygwin時(shí)并沒(méi)有缺省安裝GNU工具鏈,應(yīng)根據(jù)需求安裝 相應(yīng)的工具。本文根據(jù)操作系統(tǒng)的配置需要安裝了binutils、gcc-core、gcc-g++、gdb、make等工具。

2.3 源碼編譯調(diào)試

2.3.1 GDB工作目錄建立

首先通過(guò)Cygwin進(jìn)入GDB源碼根目錄,新建文件夾build,用來(lái)存儲(chǔ) 源碼編譯后的可執(zhí)行文件。注意,Win- dows目錄在Cygwin進(jìn)行了掛 載,如D盤(pán)路徑變成/cyg- drive/d等。因此,進(jìn)入GDB源碼根目錄時(shí)要注意目錄路徑的變換。命令行操作如下:

//查看磁盤(pán)掛載情況,識(shí)別掛載后磁盤(pán)路徑

#df-h

//進(jìn)入 GDB源碼根目錄

#cd/cygdrive/d/gdb-source/gdb-10. 2

//創(chuàng)建 build工作目錄

#mkdirbuild

2.3.2 GDB源碼編譯

編譯源碼的主要流程由./configure(腳本文件配置)、make(工具編譯)、make install(工具安裝)3個(gè)步驟構(gòu)成。具體而言,首先,運(yùn)行configure腳本檢查當(dāng)前的配置選項(xiàng)和系統(tǒng)環(huán)境設(shè)置,檢查正確 后根據(jù)源碼中Makefile.in模版文件的引導(dǎo)生 成 Makefile文件;然后,make工具根據(jù)Makefile文件的進(jìn)行預(yù)處理、編譯、鏈接等項(xiàng)目構(gòu)建工作,生成二進(jìn)制文件;最后,make install命令根據(jù)執(zhí)行con-figure腳本時(shí)傳遞的prefix等參數(shù)將生成的二進(jìn)制文件安裝到指定路徑。

執(zhí)行./configure需要進(jìn)行各種參數(shù)配置,GDB交叉編譯中使用的參數(shù)配置如表1所列。

表1 configure腳本參數(shù)說(shuō)明

51a378ca-9e1b-11ee-8b88-92fbcf53809c.png

GDB源碼編譯的操作如下:

//建立交叉調(diào)試環(huán)境之前檢查 config. sub腳本是否支持目標(biāo)機(jī)架構(gòu)的編譯 。若支持 ,則返回相應(yīng)的架構(gòu)類型 ,否則會(huì)報(bào)錯(cuò)

# sh config. sub riscv64 unknown elf gcc

//執(zhí)行 configure腳本 ,其中 CFLAGS= " g"的作用為后續(xù)調(diào)試 GDB源碼顯示調(diào)試信息。build和 host參數(shù)默認(rèn)均為

本機(jī)架構(gòu),不再顯性指定

#./configureCFLAGS=" g"

target=riscv64 unknown elf

prefix=/cygdrive/d/gdb source/gdb 10.2/build

//make編譯與安裝

#make

#makeinstall

2.3.3 GDB源碼調(diào)試

前面的工作已經(jīng)編譯生成了基于RISC V架構(gòu)的GDB可執(zhí)行程序,可以進(jìn)行目標(biāo)機(jī)上被調(diào)試程序的交叉調(diào)試工作。若GDB調(diào)試過(guò)程中出現(xiàn)了BUG或者需要進(jìn)一步理解內(nèi)部運(yùn)行機(jī)制,則需要進(jìn)入GDB源碼調(diào)試模式。為了方便閱讀調(diào)試源碼,選擇VSCode進(jìn)行GDB源碼調(diào)試,需配置launch.json文件,該配置文件主要作用是添加GDB調(diào)試任務(wù)并運(yùn)行可執(zhí)行文件。launch.json文件配置流程主要分為以下幾個(gè)步驟:

①生成launch.json文件。菜單欄選擇“運(yùn)行”->“添加配置”->“C++(GDB/LLDB)”,即可生成一個(gè)配置為空的launch.json文件。

②添加默認(rèn)配置模版。在"configurations"字段域中輸入“GDB”可以自動(dòng)生成默認(rèn)配置。

③修改默認(rèn)配置。"program"字段代表調(diào)試器的路徑,該字段設(shè)置為Cygwin的GDB路徑;"miDebuggerPath"字段代表被調(diào)試的可執(zhí)行文件路徑,該字段設(shè)置為前面編譯生成的GDB程序。

完成launch.json文件配置后,在VSCode中選擇“gdb啟動(dòng)”就可以在調(diào)試模式下運(yùn)行GDB調(diào)試器。

此外,調(diào)試代理OpenOCD的編譯和調(diào)試與GDB源碼編譯和調(diào)試工作步驟基本一致,在此不再重復(fù)說(shuō)明。目標(biāo)機(jī)的被調(diào)試的可執(zhí)行程序?yàn)镽AC102芯片自帶示例程序。

2.4 交叉調(diào)試

首先,運(yùn)行OpenOCD程序后,會(huì)彈出運(yùn)行終端窗口,顯示JATG標(biāo)準(zhǔn)選擇、芯片架構(gòu)信息、監(jiān)聽(tīng)端口等第一階段信息,表示OpenOCD運(yùn)行正常,與目標(biāo)機(jī)的RAC102芯片連接成功。

之后,以調(diào)試模式或者運(yùn)行模式打開(kāi)GDB程序,彈出運(yùn)行終端窗口,在終端中依次設(shè)置指定RAC102芯片的架構(gòu)、遠(yuǎn)程調(diào)試的連接端口以及加載調(diào)試信息文件,命令執(zhí)行如下:

(gdb) set architecture riscv:rv32

The target architecture is assumed to be riscv:rv32

(gdb)target extended-remote localhost:3333

Remote debugging using localhost:3333

(gdb)file D:\led\led_debug.elf

Reading symbols from D:\led\led_debug.elf…

完成上述操作后,OpenOCD運(yùn)行終端會(huì)輸出端口連接成功、中斷地址等第二階段信息,表示OpenOCD與GDB連接成功。此時(shí)可以在GDB調(diào)試終端中輸入continue、step、break等常用的調(diào)試命令進(jìn)行交叉調(diào)試。

3 功能驗(yàn)證與協(xié)議分析

在交叉調(diào)試中,GDB所有的調(diào)試命令和調(diào)試信息反饋均通過(guò)RSP協(xié)議來(lái)實(shí)現(xiàn)。該協(xié)議通過(guò)串口或網(wǎng)口等媒介傳輸ASCII消息。RSP包的基本格式為:$數(shù)據(jù)包#校驗(yàn)和[3-4]。其中,數(shù)據(jù)包由若干ASCII數(shù)據(jù)組成,該校驗(yàn)和是數(shù)據(jù)包所有字符的ASCII碼之和取256的模后得到的值,用兩位十六進(jìn)制ASCII表示。若OpenOCD正確接收數(shù)據(jù),則會(huì)返回‘+’,否則返回‘-’表示發(fā)生錯(cuò)誤,要求重新發(fā)送消息[5]。

由GDB和OpenOCD源碼調(diào)試分析可知,GDB作為RSP客戶端,在remote.c源文件中完成了讀寫(xiě)、運(yùn)行控制、查詢及設(shè)置、追蹤點(diǎn)以及停止通知等RSP常用類型通信包的接口實(shí)現(xiàn);OpenOCD作為RSP服務(wù)端,在server.cc源文件完成了GDB發(fā)送的通信包的解析與處理。在此基礎(chǔ)上,通過(guò)RSP通信包的組合實(shí)現(xiàn)常用的GDB調(diào)試命令。

在上述前提下,通過(guò)調(diào)試命令對(duì)應(yīng)的RSP協(xié)議分析來(lái)驗(yàn)證在GDB+OpenOCD的方案中基于RISC-V架構(gòu)的RAC102芯片交叉調(diào)試的功能正確性。參照第2.4小節(jié)的交叉調(diào)試流程,區(qū)別在于在執(zhí)行target extended-remote localhost:port命令之前,需要使用set remotelogfile filename命令配置好遠(yuǎn)程串行通信記錄日志,日志文件名為filename,GDB會(huì)將與OpenOCD的交互數(shù)據(jù)寫(xiě)入該日志文件中。通過(guò)表2給出了驗(yàn)證后常用的調(diào)試命令以及對(duì)應(yīng)RSP協(xié)議指令集,證明了交叉調(diào)試方案設(shè)計(jì)的正確性與可行性。

表2 GDB命令與RSP協(xié)議對(duì)照指令集

G D B 命 令 RSP請(qǐng)求序列 RSP應(yīng)答序列
target extended-
remotelocalhost:
port

①qSupported
②vMustReplyEmpty
③QStartNoAckMode
④!
⑤Hg thread-id
⑥qXferread
⑦qTStatus
⑧?
⑨qXferread
⑩Hc thread-id

?qC
?qAttached
?qOffsets
?g
?qXferread
?qSymbol
①qSymbol::Size;
qXferread;
QStartNoAckMode;
vContSupported
②空
③OK
④OK
⑤OK
⑥m data
⑦空
⑧S signal-id
⑨1 data
⑩OK
?QC thread-id

?1(注:數(shù)字1)
?Text =xx;Data=yy;
Bss=zz
?XX..(注:寄存
器數(shù)據(jù)內(nèi)容)
?1 data
?OK
file filename ①qSymbol
②g
①OK
②XX..
run
①vKill;pid
②k和?組合包
vRun
④qC
⑤qAttached
⑥qOffsets
⑦Hg thread-id
⑧qXferread
⑨g
⑩vCont;c
?x03
?g
?qXferread
①空
②W00
③S signal-id
④QC thread-id
⑤1(注:數(shù)字1)
⑥Text=xx;Data=yy;
Bss=zz
⑦OK
⑧m data
⑨XX..
onds>
?T siganal-id
?XX..
?1 data
continue ①m
②ZO
③vCont?
④yCont;c
⑤g
⑥qXferread
⑦z0
①XX..
②OK
③vCont;c;C;s:S
④T signal-id
⑤XX..
⑥1 data
⑦OK
next ①m
②ZO
③vCont;s:thread -
id;c
④g
⑤qXferread
⑥z0
①XX..
②OK
③T thread-id
④XX..
⑤1 data
⑥OK
step
break lineNo ①m(若干包) ①XX..(若干包)
watchval
print yal
backtrace
diassemble
quit ①D
②?
①OK
②S siganal-id

4 結(jié)語(yǔ)

本文自主設(shè)計(jì)了一套集成開(kāi)發(fā)環(huán)境方案,該方案中基于自行編譯的GDB和OpenOCD實(shí)現(xiàn)了基于RSIC-V架構(gòu)的RAC102芯片的交叉調(diào)試,并且通過(guò)RSP協(xié)議分析進(jìn)行了調(diào)試功能的驗(yàn)證。交叉調(diào)試方案的實(shí)現(xiàn)為后續(xù)其余架構(gòu)芯片的集成開(kāi)發(fā)環(huán)境設(shè)計(jì)與實(shí)現(xiàn)提供了指導(dǎo)思路。進(jìn)一步,為自研架構(gòu)芯片設(shè)計(jì)開(kāi)發(fā)的自主可控提供了保障。







審核編輯:劉清

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

    關(guān)注

    31

    文章

    5355

    瀏覽量

    120532
  • 仿真器
    +關(guān)注

    關(guān)注

    14

    文章

    1018

    瀏覽量

    83781
  • 嵌入式開(kāi)發(fā)

    關(guān)注

    18

    文章

    1031

    瀏覽量

    47597
  • GDB調(diào)試
    +關(guān)注

    關(guān)注

    0

    文章

    24

    瀏覽量

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

    關(guān)注

    45

    文章

    2292

    瀏覽量

    46205

原文標(biāo)題:RISC-V架構(gòu)的交叉調(diào)試系統(tǒng)設(shè)計(jì)

文章出處:【微信號(hào):麥克泰技術(shù),微信公眾號(hào):麥克泰技術(shù)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    正式的RISC-V基礎(chǔ)指令集架構(gòu)與特權(quán)架構(gòu)規(guī)范來(lái)了,RISC-V基金會(huì)已正式批準(zhǔn)

    根據(jù)RISC-V基金會(huì)官網(wǎng)發(fā)布的公告,RISC-V 基金會(huì)宣布了批準(zhǔn)RISC-V 基礎(chǔ)指令集架構(gòu)與特權(quán)架構(gòu)規(guī)范,為
    的頭像 發(fā)表于 07-11 10:46 ?9873次閱讀

    RISC-V PMP調(diào)試

    RISC-V PMP調(diào)試
    的頭像 發(fā)表于 06-08 11:52 ?1938次閱讀
    <b class='flag-5'>RISC-V</b> PMP<b class='flag-5'>調(diào)試</b>

    rIsc-v的缺的是什么?

    通過(guò)軟件模擬或復(fù)雜的指令序列來(lái)實(shí)現(xiàn)一些高級(jí)功能,這可能會(huì)增加執(zhí)行時(shí)間和功耗。 2. 生態(tài)系統(tǒng)支持不足 軟件和工具鏈的可用性:盡管RISC-V社區(qū)在快速發(fā)展,但與成熟的ARM等架構(gòu)相比,
    發(fā)表于 07-29 17:18

    基于risc-v架構(gòu)的芯片與linux系統(tǒng)兼容性討論

    一定的兼容性挑戰(zhàn),但并非不可克服。通過(guò)針對(duì)RISC-V架構(gòu)進(jìn)行編譯和優(yōu)化Linux內(nèi)核、確保硬件接口兼容、支持平臺(tái)特性、提供適用的編譯工具鏈和二進(jìn)制格式以及構(gòu)建完整的生態(tài)系統(tǒng)等措施,可以實(shí)現(xiàn)
    發(fā)表于 11-30 17:20

    RISC-V架構(gòu)及MRS開(kāi)發(fā)環(huán)境回顧

    ,華為海思轉(zhuǎn)向了開(kāi)源指令集架構(gòu)RISC-V,針對(duì)鴻蒙操作系統(tǒng)的開(kāi)發(fā)者發(fā)布了首款RISC-V開(kāi)發(fā)板Hi3861。Hi3861針對(duì)的是物聯(lián)網(wǎng)市場(chǎng),突破ARM限制。(5)
    發(fā)表于 12-16 23:08

    RISC-V 生態(tài)架構(gòu)淺析

    模式。通過(guò)不同的模式組合可以實(shí)現(xiàn)不同的系統(tǒng)。2.5 自定制指令擴(kuò)展除了上述闡述的模塊化指令子集的可擴(kuò)展、可選擇,RISC-V架構(gòu)還有一個(gè)非常重要的特性,那就是支持第三方的擴(kuò)展。用戶可以
    發(fā)表于 06-22 16:51

    學(xué)習(xí)RISC-V入門 基于RISC-V架構(gòu)的開(kāi)源處理器及SoC研究

    系統(tǒng)調(diào)用指令:實(shí)現(xiàn)系統(tǒng)調(diào)用、調(diào)試等功能。1.2 RISC-V的優(yōu)勢(shì)1.2.1 與開(kāi)源指令集架構(gòu)
    發(fā)表于 07-27 18:09

    科普RISC-V生態(tài)架構(gòu)(認(rèn)識(shí)RISC-V)

    模式。通過(guò)不同的模式組合可以實(shí)現(xiàn)不同的系統(tǒng)。2.5 自定制指令擴(kuò)展除了上述闡述的模塊化指令子集的可擴(kuò)展、可選擇,RISC-V架構(gòu)還有一個(gè)非常重要的特性,那就是支持第三方的擴(kuò)展。用戶可以
    發(fā)表于 08-02 11:50

    ARM與RISC-V架構(gòu)的區(qū)別是什么?

    2019年開(kāi)始,RISC-V得到了越來(lái)越多的重視,原因有很多,ARM授權(quán)費(fèi)高是關(guān)鍵的因素,下面就來(lái)說(shuō)說(shuō)關(guān)于ARM和RISC-V架構(gòu),以及相關(guān)的內(nèi)容。 關(guān)于ARM 1991 年ARM 公司成立于英國(guó)
    發(fā)表于 04-25 09:13

    RISC-V 生態(tài)架構(gòu)淺析

    的應(yīng)用,參與度之高,覆蓋面之廣,盛況空前;指令集架構(gòu)的生態(tài)鏈正在成長(zhǎng)和完善,工具鏈、RTOS/Linux操作系統(tǒng)的移植等工作都取得關(guān)鍵突破;2018年11月,RISC-V基金會(huì)宣布了與Linux基金會(huì)
    發(fā)表于 06-18 19:59

    分析RISC-V架構(gòu)的不同之處

    0 RISC-V和其他開(kāi)放架構(gòu)有何不同如果僅從“免費(fèi)”或“開(kāi)放”這兩點(diǎn)來(lái)評(píng)判,RISC-V架構(gòu)并不是第一個(gè)做到免費(fèi)或開(kāi)放的處理器架構(gòu)。在開(kāi)始
    發(fā)表于 07-26 06:58

    RISC-V架構(gòu)簡(jiǎn)介

    【摘要】 本文首先對(duì)RISC-V架構(gòu)做了簡(jiǎn)要的介紹,在此基礎(chǔ)上實(shí)現(xiàn)了LiteOS在RISC-V架構(gòu)上的適配過(guò)程的具體步驟,希望對(duì)你有所幫助
    發(fā)表于 07-28 07:46

    RISC-V架構(gòu)

      RISC-V架構(gòu)  RISC-V(發(fā)音為“risk-five”)是一個(gè)基于精簡(jiǎn)指令集(RISC)原則的開(kāi)源指令集架構(gòu)(ISA)?! ∨c大
    發(fā)表于 04-03 15:29

    談一談RISC-V架構(gòu)的優(yōu)勢(shì)和特點(diǎn)

    得中國(guó)的芯片設(shè)計(jì)者能夠更加靈活地進(jìn)行設(shè)計(jì),降低生產(chǎn)成本,提高市場(chǎng)競(jìng)爭(zhēng)力。 2、可移植性好、可擴(kuò)展性強(qiáng):開(kāi)發(fā)者能方便地移植Linux和Unix系統(tǒng)RISC-V平臺(tái)上,這樣就可以在RISC-V
    發(fā)表于 05-14 09:05

    兩大架構(gòu)RISC-V 和 ARM 的各種關(guān)系

    一、RISC-V 和 ARM 的相似之處 RISC-V 和 ARM 基本上都是 RISC(精簡(jiǎn)指令集計(jì)算機(jī))。RISC-V 和 ARM 都使用加載-存儲(chǔ)
    發(fā)表于 06-21 20:31