作者@new_bee
Part.0
目錄
芯片介紹
開(kāi)發(fā)板介紹
RT-Smart用戶態(tài)系統(tǒng)編譯使用
感想
引用
Part.1
芯片介紹
RISC-V架構(gòu)由于其精簡(jiǎn)和開(kāi)源的特性,得到業(yè)界的認(rèn)可,近幾年可謂相當(dāng)熱門。操作系統(tǒng)方面有RT-Thread,Linux等支持。在今年早些時(shí)候,Google希望RISC-V成為Android支持的“一級(jí)”架構(gòu)。
D1s 是22nm 64bit RISC-V 架構(gòu)的處理器,主頻720MHz。內(nèi)置64M DDR2。支持RGB,MIPI等視頻輸出接口,ADC、DAC、I2S、PCM、DMIC、OWA 等多種音頻接口。音視頻編解碼支持如下:
Video decoding H.265 up to 1080p@60fps H.264 up to 1080p@60fps MPEG-1/2/4, JPEG, VC1 up to 1080p@60fps Video encoding JPEG/MJPEG up to 1080p@60fps Supports input picture scaler up/down
Part.2
開(kāi)發(fā)板介紹
RDC2022 紀(jì)念版開(kāi)發(fā)板是基于D1s芯片的小尺寸開(kāi)發(fā)板,尺寸為5.5cm*4cm。正面包含一塊D1s核心板,外圍電路采用ME3116作為DCDC降壓芯片,CH340N作為USB-TTL芯片,PT4103作為背光驅(qū)動(dòng),并包含一塊LM4890音頻功放。總體電路比較簡(jiǎn)潔。
開(kāi)發(fā)板背面為SD卡插槽,一個(gè)RGB888接口接顯示屏,和一個(gè)觸摸屏接口。該開(kāi)發(fā)板還包含兩組12腳的PMOD接口用于接插外設(shè)。
RGB接口按引腳定義可以接入通用RGB屏幕,我這里接的是480*272的屏幕,引腳定義如下:
Part.3
RT-Smart用戶態(tài)系統(tǒng)編譯使用
首先用typec數(shù)據(jù)線一端插入燒錄口,按住FEL按鈕同時(shí)另一端插入電腦,此時(shí)設(shè)備進(jìn)入FEL模式。第一次插入設(shè)備管理器會(huì)發(fā)現(xiàn)未知設(shè)備。運(yùn)行Zadig安裝驅(qū)動(dòng),如下圖:
之后就可以在FEL模式下刷機(jī)。
用typec數(shù)據(jù)線一端插入調(diào)試口,另一端插入電腦。電腦打開(kāi)串口軟件,選擇對(duì)應(yīng)串口,波特率設(shè)為500000,則可以通過(guò)串口進(jìn)行調(diào)試。
開(kāi)發(fā)編譯環(huán)境準(zhǔn)備
下載用戶態(tài)代碼:
git clone https://github.com/RT-Thread/userapps.git
下載內(nèi)核態(tài)代碼(注:位置可以與用戶態(tài)代碼分開(kāi),只要設(shè)置RISCV64的工具鏈環(huán)境變量即可):
git clone https://github.com/RT-Thread/rt-thread.git
下載RISC-V 64工具鏈:
cd userapps python3 tools/get_toolchain.py riscv64
配置RISC-V 64工具鏈環(huán)境變量(注意:按官方腳本需要執(zhí)行):
source smart-env.sh riscv64
這個(gè)腳本完成兩個(gè)工作:
設(shè)置RTT_CC等環(huán)境變量
copy riscv的config到.config
但是某些shell下獲取當(dāng)前腳本目錄錯(cuò)誤,導(dǎo)致無(wú)法完成copy,第一次使用的話會(huì)繼續(xù)用默認(rèn)的arm工具鏈編譯。
比較簡(jiǎn)單的解決辦法是執(zhí)行兩步:
source smart-env.sh riscv64 cp configs/def_config_riscv64 .config
編譯rt-thread內(nèi)核
進(jìn)入bsp目錄
cd rt-thread/bsp/allwinner/d1s
修改編譯配置
scons --menuconfig
首先打開(kāi)UART3串口,選中UART3,并修改TX引腳為GPIOG08,RX引腳為GPIOG09,路徑為:
General Deivers Configuration->General Purpose UARTs
設(shè)置終端使用UART3,修改為uart3,路徑為:
RT-Thread Kernel->Kernel Device Object,
這回目標(biāo)是點(diǎn)屏,所以要打開(kāi)LCD驅(qū)動(dòng),路徑為:
General Deivers Configuration->Enable LCD
以上完成內(nèi)核配置,保存退出。編譯成功后會(huì)生成內(nèi)核文件:
將sd.bin拷貝到windows下xfel工具目錄下。按住開(kāi)發(fā)板FEL按鈕同時(shí)另一端插入電腦。執(zhí)行命令完成燒錄:
xfel.exe sd write 57344 sd.bin
編譯rt-smart用戶態(tài)應(yīng)用點(diǎn)屏
首先將D1s bsp目錄下 mksdcard.sh 腳本拷貝到userapps目錄下,下載修改代碼:
https://github.com/Rbb666/RT-Smart-UserAPP.git
拷貝項(xiàng)目下的lvgl到userapps/apps目錄下。
由于一些宏定義缺失,需要將lvgl-nes/lv_rtt_port下的lv_conf.h和lv_port.h拷到對(duì)應(yīng)目錄下:
同時(shí),由于我沒(méi)有觸摸屏設(shè)備,所以注釋掉lv_demo.c中的觸摸屏初始化代碼。
在用戶態(tài)代碼根目錄下,編譯用戶態(tài)應(yīng)用,執(zhí)行腳本制作root文件系統(tǒng),生成sdroot.bin,最后燒錄文件系統(tǒng)。
scons ./mksdcard.sh xfel.exe sd write 8388608 sdroot.bin
燒錄完成后重啟,就可以用調(diào)試口看到目錄下有l(wèi)vgl.elf。執(zhí)行點(diǎn)亮屏幕
./lvgl.elf
Part.4
感想
總體而言,RISC-V的生態(tài)在廠商和開(kāi)源社區(qū)的努力下逐步完善起來(lái)。芯片,開(kāi)發(fā)板,操作系統(tǒng)都有諸多選擇,工具鏈也可以較透明的無(wú)縫移植。
但是感觸比較深的還是缺少更多的文檔和入門教程,對(duì)于新人不會(huì)像樹(shù)莓派等有開(kāi)箱即用的效果(當(dāng)然樹(shù)莓派現(xiàn)在的性價(jià)比就不說(shuō)了)。
另外,scons編譯確實(shí)較方便,不過(guò)針對(duì)一些復(fù)雜的基于makefile的開(kāi)源項(xiàng)目,移植到scons較為繁復(fù)。在用RISCV工具鏈編譯一些基于makefile的開(kāi)源項(xiàng)目時(shí),也遇到了一些坑,之后會(huì)寫文章分享。當(dāng)然RISCV的發(fā)展不是一蹴而就的事,仍需業(yè)界和開(kāi)源社區(qū)大力支持。
-
處理器
+關(guān)注
關(guān)注
68文章
19051瀏覽量
228556 -
芯片
+關(guān)注
關(guān)注
452文章
50033瀏覽量
419880 -
Linux
+關(guān)注
關(guān)注
87文章
11182瀏覽量
208540 -
開(kāi)發(fā)板
+關(guān)注
關(guān)注
25文章
4846瀏覽量
96899 -
RISC-V
+關(guān)注
關(guān)注
44文章
2182瀏覽量
45907
原文標(biāo)題:D1s RDC2022紀(jì)念版開(kāi)發(fā)板開(kāi)箱評(píng)測(cè)及點(diǎn)屏教程
文章出處:【微信號(hào):gh_79acfa3aa3e3,微信公眾號(hào):全志在線】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論