openEuler
openEuler-risc-v学习笔记
QEMU安装
参考
.md
qemu下载链接
/
wget .0.0.tar.xz
tar xvJf qemu-5.0.0.tar.xz
cd qemu-5.0.0
./qemu-5.0.0/configure --target-list=riscv64-softmmu,riscv64-linux-user --prefix=/home/username/path
make
make install
注意–prefix=/home/username/path中的username应当被$(whoami)解析实现。
配置
执行下面三条语句
echo 'export PATH=/home/$(whoami)/path/bin:$PATH' >> ~/.bashrc
source ~/.bashrc
qemu-system-riscv64 --version
命令qemu-system-riscv64 --version能正确显示安装的QEMU版本则表示安装成功。
如果出问题可以卸载
源码编译安装的qemu需要手动卸载:
可执行文件默认放在/usr/local/bin
库文件默认存放在/usr/local/libexec
配置文件默认存放在/usr/local/etc
共享文件默认存放在/usr/local/share
# rm -rf /usr/local/bin/qemu-*
# rm -rf /usr/local/libexec/qemu-bridge-helper
# rm -rf /usr/local/etc/qemu
# rm -rf /usr/local/share/qemu
在删除解压包即可
运行openEuler RISC-V
下载
=https%3A%2F%2Frepo.openeuler.org%2FopenEuler-preview%2FRISC-V%2FImage
在此链接下下载这两个文件,如果需要使用docker,第一个文件下载以docker结尾的
fw_payload_oe.elf
openEuler-preview.riscv64.qcow2
在有这两个文件的文件夹下执行启动脚本
启动
qemu-system-riscv64 \-nographic -machine virt \-smp 8 -m 2G \-kernel fw_payload_oe.elf \-drive file=openEuler-preview.riscv64.qcow2,format=qcow2,id=hd0 \-object rng-random,filename=/dev/urandom,id=rng0 \-device virtio-rng-device,rng=rng0 \-device virtio-blk-device,drive=hd0 \-device virtio-net-device,netdev=usernet \-netdev user,id=usernet,hostfwd=tcp::12055-:22 \-append 'root=/dev/vda1 rw console=ttyS0 systemd.default_timeout_start_sec=600 selinux=0 highres=off mem=4096M earlycon'
启动命令可做成Shell脚本,其中fw_payload_oe.elf与openEuler-preview.riscv64.qcow2需修改为实际下载的文件名, 并注意相对和绝对路径,如做成启动脚本则可与脚本放在同一目录下。 为ssh转发的12055端口也可改为自己需要的端口号。
配置
密码
root 默认密码为 openEuler12#$
为 root 设置密码
passwd root
Password:
Retype:
用户
添加用户euler并设置密码
adduser -d /home/euler -s /bin/bash euler
passwd euler
Password:
Retype:
su 是 Switch User 的命令,用于切换用户。
从用户root切换到用户euler执行 su euler,连环境变量一并切换到euler的主目录则执行 su - euler
从用户euler切换到用户root执行 su ,连环境变量一并切换到root的主目录则执行 su -
时间
chrony在oE上暂时不可用,使用timesyncd:
echo “NTP=ntp.aliyun.com” >> /etc/systemd/timesyncd.conf
systemctl restart systemd-timesyncd.service
查看timesyncd运行状态:
systemctl status systemd-timesyncd.service
如果正确则crtl+c退出
亦可手动设置当前正确的时间,以下时间仅供参考,按实际时间替换
date -s “2020-07-15 23:00:01”
date命令可查看当前系统时间。
作为测试,此时执行 yum update 应当成功。
时间务必正确设置,错误的时间会影响诸如https的TLS认证等过程。
配置DNS
/etc/resolv.conf
nameserver 119.29.29.29
配置软件包源
位于 /etc/yum.repos.d/ 下
vim /etc/yum.repos.d/
增加
[base]
name=base
baseurl=/
enabled=1
gpgcheck=0
[everything]
name=everything
baseurl=/
enabled=1
gpgcheck=0
按需安装软件包
yum update
yum install osc sudo
执行dnf或yum需要root用户权限
sudo 添加用户
首先利用whereis 命令查找sudoers配置文件的目录(默认会在/etc/sudoers)
[root@localhost xiaofei]# whereis sudoers
sudoers: /etc/sudoers /etc/sudoers.bak /usr/share/man/man5/sudoers.5.gz
然后需要切换到root用户,更改/etc/sudoers的权限
[root@localhost xiaofei]# chmod u+w /etc/sudoers
然后就可以利用vi编辑器来把用户添加到sudoers之中
[root@localhost xiaofei]# vi /etc/sudoers
然后找到root ALL=(ALL) ALL所在的位置,把所要添加的用户添加到文件之中,保存退出即可
osc命令工具的安装与~/.oscrc配置文件
安装osc
osc 命令工具
通过yum或dnf安装osc命令工具
sudo yum install osc
缺什么安什么
~/.oscrc配置文件
须在欲使用的OBS上注册账号,如=https%3A%2F%2Fbuild.openeuler.org
[general]
apiurl = /
no_verify = 1 # 未配置证书情况下不验证
[/]
user=username # 用户名
pass=password # 明文密码
trusted_prj=openEuler:selfbuild:function # 此项目为openEuler:Mailine:RISC-V项目的依赖库
使用 osc build 直接构建 OBS 服务端的内容
执行osc命令的用户应当为拥有sudo权限但非root的普通用户。
#切换到某个工作目录下开始本地构建的操作
cd ~/devel #选定某个项目中需要进行本地的某个包(此处为openEuler:Mainline:RISC-V项目的xz包)
osc co openEuler:Mainline:RISC-V/xz#切换到该包的目录
cd openEuler:Mainline:RISC-V/xz#openEuler的OBS在线服务器根据_service文件中的描述从gitee下载需要的源码包、补丁和spec文件等,将它们下载到本地
osc up -S#重命名由service下载的文件,使其能被本地 osc build 正确识别
rm -f _service;for file in `ls | grep -v .osc`;do new_file=${file##*:};mv $file $new_file;done#开始进行本地构建
osc build#构建目标仓会自动选择,一般为standard仓
#若存在多个目标仓,可指定仓名
osc build BaseOS#输入sudo密码
Password:#可能需要交互选择信任网站证书或添加信任依赖仓
#网站证书信任问题可能是系统时间导致的,用`date -s`设置正确的时间#构建成功会显示产物位置,失败则会显示错误信息。
对既有项目进行分支修改并本地构建测试
#对不属于自己的在线公开既有项目的包,分支到自己的工在线程,此处为 zlib
osc branch openEuler:Mainline:RISC-V /zlib#切换到某个工作目录下开始本地构建操作
cd ~/devel #切换下载分支后的包
osc co home:usename:branches:openEuler:Mainline:RISC-V/zlib#切换到该包的目录
cd home:usename:branches:openEuler:Mainline:RISC-V/zlib#目录中应只有一个_service文件,描述了从gitee下载的文件
#可fork对应的gitee项目,并在gitee中进行代码修改
#同时在OBS的WebUI中编辑_service文件,主要修改gitee仓路径和revision号#亦可在本地编辑_service文件,编辑后提交到OBS服务器
osc ci -m "commit log"#对_service文件修改完成后,将所有内容下载到本地
osc up -S#然后重命名由service下载的文件
实操上手
使用 osc build 直接构建 OBS 服务端的内容
执行osc命令的用户应当为拥有sudo权限但非root的普通用户。
#切换到某个工作目录下开始本地构建的操作
cd ~/devel #选定某个项目中需要进行本地的某个包(此处为openEuler:Mainline:RISC-V项目的xz包)
osc co openEuler:Mainline:RISC-V/xz#切换到该包的目录
cd openEuler:Mainline:RISC-V/xz#openEuler的OBS在线服务器根据_service文件中的描述从gitee下载需要的源码包、补丁和spec文件等,将它们下载到本地
osc up -S#重命名由service下载的文件,使其能被本地 osc build 正确识别
rm -f _service;for file in `ls | grep -v .osc`;do new_file=${file##*:};mv $file $new_file;done#开始进行本地构建
osc build#构建目标仓会自动选择,一般为standard仓
#若存在多个目标仓,可指定仓名
osc build BaseOS#输入sudo密码
Password:#可能需要交互选择信任网站证书或添加信任依赖仓
#网站证书信任问题可能是系统时间导致的,用`date -s`设置正确的时间#构建成功会显示产物位置,失败则会显示错误信息。
对既有项目进行分支修改并本地构建测试
#对不属于自己的在线公开既有项目的包,分支到自己的工在线程,此处为 zlib
osc branch openEuler:Mainline:RISC-V zlib#切换到某个工作目录下开始本地构建操作
cd ~/devel #切换下载分支后的包
osc co home:usename:branches:openEuler:Mainline:RISC-V/zlib#切换到该包的目录
cd home:usename:branches:openEuler:Mainline:RISC-V/zlib#目录中应只有一个_service文件,描述了从gitee下载的文件
#可fork对应的gitee项目,并在gitee中进行代码修改
#同时在OBS的WebUI中编辑_service文件,主要修改gitee仓路径和revision号#亦可在本地编辑_service文件,编辑后提交到OBS服务器
osc ci -m "commit log"#对_service文件修改完成后,将所有内容下载到本地
osc up -S#然后重命名由service下载的文件
后续操作与使用 osc build 直接构建 OBS 服务端的内容相同
开发流程
在腾讯文档查看没人认领的package,然后在此处搜索查看package构建状态
:Mainline
如果是successful则换一个package,否则开展修复
在这个gitee仓库查看,是否存在需要的package
如果没有,进入configuration修改riscv_fork_list.yaml里的内容,按照格式与排序增加需要修复package的name。进行pr,几分钟后,再次搜索,仓库会出现该package,将需要修复的package进行fork到自己仓库,即可按照上述流程,在osc开展修复