【平頭哥Sipeed LicheeRV 86開發(fā)板試用】Docker搭建 D1 BSP SDK Tina系統(tǒng)開發(fā)環(huán)境,用的是官方Docker+ubuntu20物理機(jī)
準(zhǔn)備
- LicheeRV 86 Panel
- 數(shù)據(jù)線
- 具有32GB以上剩余空間的Linux系統(tǒng)PC一臺
docker安裝
命令如下:
sudo apt-get install docker.io
sudo docker pull ubuntu
安裝完成后,使用docker images 或 docker image ls杳看是ubuntu的鏡像。
sun@sun-ubuntu:~/licheepiRV$?sudo?docker?image?ls
REPOSITORY????????????TAG???????IMAGE?ID???????CREATED???????????SIZE
ubuntu????????????????latest????2b4cba85892a???7?days?ago???????????72.8MB
Docker鏡像獲取
為了方便用戶自行開發(fā),矽速整理發(fā)布了 LicheeRV 的bsp開發(fā)docker鏡像,大家使用該鏡像可以快速開始D1的系統(tǒng)級開發(fā)。
docker鏡像可以從百度網(wǎng)盤下載:
鏈接:https://pan.baidu.com/s/1QJTaDw6kkTM4c_GAlmG0hg
提取碼:wbef
在網(wǎng)盤中下載對應(yīng)的docker文件后,下了一周,10G多,這個方法不可取,
解壓到tar文件(我用開始在ubuntu里命令,全解壓的,后面發(fā)現(xiàn)dockor沒有導(dǎo)入目錄的命令)在windows用7z半解壓成tar包,docker才能導(dǎo)入,命令:
docker importdocker import licheerv_d1_compile.tar licheerv_d1_compile:latest
注不要用官方的docker importdocker import licheerv_d1_compile.tar licheerv_d1_compile:lastest, 不合規(guī)
查看鏡像
sun@sun-ubuntu:~/licheepiRV$ sudo docker image ls
REPOSITORY????????????TAG???????IMAGE ID???????CREATED??????????????SIZE
licheerv_d1_compile???latest???536eae684749???About a minute ago???16.1GB
ubuntu????????????????latest????2b4cba85892a???7 days ago???????????72.8MB
我這樣運(yùn)行,不用密碼,是root
sudo docker run -it ubuntu-docker /bin/bash
傳文件加-v 掛載本地目錄
官方都這樣說:然后即可run該容器,用戶名為nihao,密碼為sipeed123, 一般用戶看了也不會用.也沒說方法怎么運(yùn)行的用這個用戶密碼
建議用這個方法,應(yīng)該會快(可以開始不知道,開始就看md的文檔,說下載,我就下載了)直接從dockerhub拉?。?/p>
docker pull zepan/d1compile
Tina SDK編譯
Docker導(dǎo)入的鏡像里有源碼,編譯器及依賴編譯前先把
SDKtargetallwinnerd1-nazhedefconfig
(3590行)#CONFIG_PACKAGE_alsa-plugins=y 關(guān)閉
然后依次運(yùn)行
cd ~/sdk/tina-d1-open_new/
source build/envsetup.sh
lunch???#選1
make?-j4(#按實(shí)際核數(shù)編譯,我第1次未通過,后加參數(shù))
出錯信息:
........
make[1]: *** [tools/Makefile:133:
/home/nihao/sdk/tina-d1-open_new/out/d1-nezha/staging_dir/target/stamp/.tools_install_yyyynyyynyyyyyyynnnyyyyyyyyyyynnyyyyyyyynyyynyyyyy]
Error 2
............
用下面命令才編譯通過的,依據(jù)提示:
make j4 FORCE_UNSAFE_CONFIGURE=1
編譯花費(fèi)了,很長時間,我的還是物理機(jī),具體多久,不知道,編譯后,我不沒管它,很久才看它有沒編譯。
打包
編譯完會,打包pack:
root@fe6633ddc2b8:/home/nihao/sdk/tina-d1-open_new# pack
--==========--
......PACK_TOPDIR /home/nihao/sdk/tina-d1-open_new
--==========--
No kernel param, parse it from d1
copying tools file
copying configs file
storage_type value is 5
rm /home/nihao/sdk/tina-d1-open_new/out/d1-nezha/image/sys_partition_nor.fex
..........
make user resource for : /home/nihao/sdk/tina-d1-open_new/out/d1-nezha/image/sys_partition.fex
handle partition user-res
no user resource partitions
APP_PART_DOWNLOAD_FILE = /home/nihao/sdk/tina-d1-open_new/out/d1-nezha/image/app.fex
Need size of filesystem
no data resource partitions
don't build dtbo ...
update_chip
pack boot package
GetPrivateProfileSection read to end
content_count=3
LICHEE_REDUNDANT_ENV_SIZE config in BoardConfig.mk
--mkenvimage create redundant env data!--
---redundant env data size 0x20000---
packing for tina linux
normal
this is not a partition key
gpt_head->header_crc32 = 0xf45be3b4
GPT----part num 8---
gpt_entry: 128
gpt_header: 92
GPT:boot-resource: 1f8 2177
GPT:env : 2178 236f
GPT:env-redund : 2370 2567
GPT:boot : 2568 761f
GPT:dsp0 : 7620 7a0f
GPT:recovery : 7a10 e84f
GPT:rootfs : e850 100e84f
GPT:UDISK : 100e850 100e85f
update gpt file ok
update mbr file ok
====================================
show "sys_partition_for_dragon.fex" message
------------------------------------
[mbr]
mbr_size : 252 Kbyte
------------------------------------
partition_name : boot-resource
partition_size : 8064
downloadfile : boot-resource.fex
boot-resource.fex size : 718K byte
------------------------------------
partition_name : env
partition_size : 504
downloadfile : env.fex
env.fex size : 128K byte
------------------------------------
partition_name : env-redund
partition_size : 504
downloadfile : env.fex
env.fex size : 128K byte
------------------------------------
partition_name : boot
partition_size : 20664
downloadfile : boot.fex
boot.fex -> /home/nihao/sdk/tina-d1-open_new/out/d1-nezha/boot.img
boot.img size : 9.3M byte
------------------------------------
partition_name : dsp0
partition_size : 1008
downloadfile : dsp0.fex
dsp0.fex size : 258K byte
------------------------------------
partition_name : recovery
partition_size : 28224
------------------------------------
partition_name : rootfs
partition_size : 0x1000000
downloadfile : rootfs.fex
rootfs.fex -> /home/nihao/sdk/tina-d1-open_new/out/d1-nezha/rootfs.img
rootfs.img size : 100M byte
------------------------------------
partition_name : UDISK
------------------------------------
/home/nihao/sdk/tina-d1-open_new/out/host/bin/
/home/nihao/sdk/tina-d1-open_new/out/d1-nezha/image
Begin Parse sys_partion.fex
Add partion boot-resource.fex BOOT-RESOURCE_FEX
Add partion very boot-resource.fex BOOT-RESOURCE_FEX
FilePath: boot-resource.fex
FileLength=b3800Add partion env.fex ENV_FEX000000000
Add partion very env.fex ENV_FEX000000000
FilePath: env.fex
FileLength=20000Add partion env.fex ENV_FEX000000000
Add partion very env.fex ENV_FEX000000000
FilePath: env.fex
FileLength=20000Add partion boot.fex BOOT_FEX00000000
Add partion very boot.fex BOOT_FEX00000000
FilePath: boot.fex
FileLength=94c800Add partion dsp0.fex DSP0_FEX00000000
Add partion very dsp0.fex DSP0_FEX00000000
FilePath: dsp0.fex
FileLength=4059cAdd partion rootfs.fex ROOTFS_FEX000000
Add partion very rootfs.fex ROOTFS_FEX000000
FilePath: rootfs.fex
FileLength=6400000sys_config.fex Len: 0x4ec3
config.fex Len: 0x6c00
board.fex Len: 0x400
split_xxxx.fex Len: 0x200
sys_partition.fex Len: 0xc2b
sunxi.fex Len: 0xd600
boot0_nand.fex Len: 0x10000
boot0_sdcard.fex Len: 0x10000
u-boot.fex Len: 0xa0000
u-boot-crash.fex Len: 0x25
toc1.fex Len: 0x8
toc0.fex Len: 0x8
fes1.fex Len: 0xa560
boot_package.fex Len: 0xc0000
usbtool.fex Len: 0x24e00
usbtool_crash.fex Len: 0x1ec00
aultools.fex Len: 0x28a73
aultls32.fex Len: 0x25205
cardtool.fex Len: 0x11e00
cardscript.fex Len: 0x6de
sunxi_gpt.fex Len: 0x2000
sunxi_mbr.fex Len: 0x10000
dlinfo.fex Len: 0x4000
arisc.fex Len: 0xf
vmlinux.fex Len: 0x8
tinaconf.fex Len: 0xe18e
boot-resource.fex Len: 0xb3800
Vboot-resource.fex Len: 0x4
env.fex Len: 0x20000
Venv.fex Len: 0x4
env.fex Len: 0x20000
Venv.fex Len: 0x4
boot.fex Len: 0x94c800
Vboot.fex Len: 0x4
dsp0.fex Len: 0x4059c
Vdsp0.fex Len: 0x4
rootfs.fex Len: 0x6400000
Vrootfs.fex Len: 0x4
BuildImg 0
Dragon execute image.cfg SUCCESS !
----------image is for nand/emmc----------
----------image is at----------
/home/nihao/sdk/tina-d1-open_new/out/d1-nezha/tina_d1-nezha_uart0.img
pack finish
拿出文件
開始文檔拿不出來,第二次用-v
sudo docker run -itv /home/tina:/home/tina licheerv-d1_compile /bin/bash
查看是否掛載成功:
root@4ba9051a0ab9:/# ls /home/tina/camera tinyhttpd-0.1.0 wav2c
yeah,成功了,
進(jìn)SDK目錄發(fā)現(xiàn),原來編譯的東西沒的了,(請教大神,可以有方法讓編譯文件,保存下來嗎?)
root@4ba9051a0ab9:/home/nihao/sdk/tina-d1-open_new# ls
1.txt Makefile device myfiles package
scripts tmpConfig.in build dl
myfiles_default prebuilt target toolchain
LicheeRV_data config lichee myfiles_waft rules.mk test.sh tools
所以在docker 編譯后,馬上拿出來
再次編譯一下吧
這樣就能把編譯出來的文件, 燒錄到開發(fā)板。