RK356X/RK3588构建Ubuntu20.04根文件系统

一给  金牌会员 | 2024-6-27 03:47:50 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 785|帖子 785|积分 2355


前言

很多厂商没有吧文件系统的构建方法开源出来,只是提供了一个rootfs.img的固件包,这不利于我们做二次开发,本文章实现一个本身构建的文件系统,并移植到RK的平台上使用

一、官网下载ubuntu-base

http://cdimage.ubuntu.com/ubuntu-base/releases/
本文章使用的是:buntu-base-20.04.5-base-arm64.tar.gz
解压:
  1. mkdir ubuntu_rootfs
  2. tar -zxvf ubuntu-base-20.04.5-base-arm64.tar.gz -C ubuntu_rootfs
复制代码
二、挂载并构建文件系统

2.1、配置构建文件系统环境

配置网络配置
  1. cp /etc/resolv.conf  ubuntu_rootfs/etc/
复制代码
配置仿真开发环境
  1. sudo apt install qemu-user-static
复制代码
  1. sudo cp /usr/bin/qemu-aarch64-static ubuntu_rootfs/usr/bin/
复制代码
更换软件源
  1. sudo vim ubuntu_rootfs/etc/apt/sources.list
复制代码
  1. deb http://mirrors.aliyun.com/ubuntu-ports/ focal main restricted
  2. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-updates main restricted
  3. deb http://mirrors.aliyun.com/ubuntu-ports/ focal universe
  4. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-updates universe
  5. deb http://mirrors.aliyun.com/ubuntu-ports/ focal multiverse
  6. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-updates multiverse
  7. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-backports main restricted universe multiverse
  8. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-security main restricted
  9. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-security universe
  10. deb http://mirrors.aliyun.com/ubuntu-ports/ focal-security multiverse
复制代码
2.2、编写挂载脚本mount.sh并安装相关工具

挂载根文件系统运行需要的装备和目次
  1. #!/bin/bash
  2. function mnt() {
  3.     echo "MOUNTING"
  4.     sudo mount -t proc /proc ${2}proc
  5.     sudo mount -t sysfs /sys ${2}sys
  6.     sudo mount -o bind /dev ${2}dev
  7.     #sudo mount -t devpts -o gid=5,mode=620 devpts ${2}dev/pts
  8.     sudo mount -o bind /dev/pts ${2}dev/pts
  9.     sudo chroot ${2}
  10. }
  11. function umnt() {
  12.     echo "UNMOUNTING"
  13.     sudo umount ${2}proc
  14.     sudo umount ${2}sys
  15.     sudo umount ${2}dev/pts
  16.     sudo umount ${2}dev
  17. }
  18. if [ "$1" == "-m" ] && [ -n "$2" ];
  19. then
  20.         mnt $1 $2
  21. elif [ "$1" == "-u" ] && [ -n "$2" ];
  22. then
  23.         umnt $1 $2
  24. else
  25.         echo ""
  26.         echo "Either 1'st, 2'nd or both parameters were missing"
  27.         echo ""
  28.         echo "1'st parameter can be one of these: -m(mount) OR -u(umount)"
  29.         echo "2'nd parameter is the full path of rootfs directory(with tralling '/')"
  30.         echo ""
  31.         echo "For example: ch-mount -m /media/sdcard"
  32.         echo ""
  33.         echo 1st parameter : ${1}
  34.         echo 2nd parameter : $[2]
  35. fi
复制代码
添加执行权限并挂载文件系统
  1. sudo chmod +x mount.sh
  2. ./mount.sh -m ubuntu_rootfs/
复制代码
挂载之后,开始安装文件系统中须要的一些软件
  1. apt update
复制代码
  1. apt upgrade
复制代码
  1. apt install sudo vim udev net-tools ethtool udhcpc netplan.io language-pack-en-base language-pack-zh-han* iputils-ping openssh-sftp-server  ntp usbutils alsa-utils libmtp9   
复制代码
安装的过程中会让你选择地区和时区

亚洲地区选择:6,Asia
中国时区选择:70,Shanghai
等待编译完成即可

2.3、轻量级的桌面环境 lubuntu-desktop

嵌入式平台选择轻量级的桌面环境lubuntu-desktop安装
  1. apt install lubuntu-desktop
复制代码
2.4、卸载一些不须要的软件

  1. apt-get remove --purge lubuntu-update-notifier
复制代码
  1. apt-get remove --purge libreoffice*
复制代码
2.5、添加用户

舔加用户
  1. adduser ubuntu   
复制代码
增加管理员权限
  1. adduser ubuntu sudo  
复制代码
2.6 、允许root用户登录桌面

设置允许root用户登录桌面
  1. vim /etc/gdm3/custom.conf
复制代码
添加
  1. AutomaticLoginEnable = true
  2. AutomaticLogin = ubuntu
  3. AllowRoot=true
复制代码
如图

  1. vim /etc/pam.d/gdm-password
复制代码
表明:#auth required pam_succeed_if.so user != root quiet_success
  1. #%PAM-1.0
  2. auth    requisite       pam_nologin.so
  3. #auth   required        pam_succeed_if.so user != root quiet_success
  4. @include common-auth
  5. auth    optional   
复制代码
  1. vim /etc/lightdm/lightdm.conf.d/20-autologin.conf
复制代码
在autologin-user中修改成本身的用户名
  1. [Seat:*]
  2. #autologin-guest=false
  3. #autologin-user=magiclen
  4. #autologin-user-timeout=0
  5. user-session=Lubuntu
  6. autologin-user=ubuntu
  7. greeter-show-manual-login=true
复制代码
2.7、串口主动登录

  1. vim /lib/systemd/system/serial-getty\@.service
复制代码
表明:ExecStart=-/sbin/agetty -o ‘-p – \u’ --keep-baud 115200,38400,9600 %I $TERM
修改:ExecStart=-/sbin/agetty --autologin root --noclear %I $TERM
  1. [Service]
  2. # The '-o' option value tells agetty to replace 'login' arguments with an
  3. # option to preserve environment (-p), followed by '--' for safety, and then
  4. # the entered username.
  5. #ExecStart=-/sbin/agetty -o '-p -- \\u' --keep-baud 115200,38400,9600 %I $TERM
  6. ExecStart=-/sbin/agetty --autologin root --noclear %I $TERM
  7. Type=idle
  8. Restart=always
  9. UtmpIdentifier=%I
  10. TTYPath=/dev/%I
  11. TTYReset=yes
  12. TTYVHangup=yes
  13. KillMode=process
  14. IgnoreSIGPIPE=no
  15. SendSIGHUP=yes
复制代码
末了关闭主动休眠
  1. sudo systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target
复制代码
2.8、开机卡“A start job is running for wait for network to be Configured”的解决方法

打开:
  1. vim  /etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service
复制代码
修改:
  1. - ExecStart=/usr/bin/nm-online -s -q --timeout=30
  2. + ExecStart=/usr/bin/nm-online -s -q --timeout=0
复制代码
2.9、添加分区开释的系统服务(重要)

通过实行,rootfs分区烧录后,只有固件本身巨细,需要做分区开释
  1. vim etc/init.d/resize2fs.sh
复制代码
  1. #!/bin/bash -e
  2. # resize filesystem mmcblk0p6
  3. if [ ! -e "/usr/local/boot_flag" ] ;
  4. then
  5.   echo "Resizing /dev/mmcblk0p6..."
  6.   resize2fs /dev/mmcblk0p6
  7.   touch /usr/local/boot_flag
  8. fi
复制代码
添加执行权限
  1. chmod +x etc/init.d/resize2fs.sh
复制代码
创建服务去运行脚本
  1. vim lib/systemd/system/resize2fs.service
复制代码
  1. #start
  2. [Unit]
  3. Description=Setup rockchip platform environment
  4. Before=lightdm.service
  5. After=resize-helper.service
  6. [Service]
  7. Type=simple
  8. ExecStart=/etc/init.d/resize2fs.sh
  9. [Install]
  10. WantedBy=multi-user.target
  11. #end
复制代码
#退出根文件系统
  1. exit
复制代码
#卸载挂载的根文件系统
  1. ./mount.sh -u ubuntu_rootfs/
复制代码
三、制作文件系统rootfs分区固件

3.1、创建一个空镜像文件

  1. dd if=/dev/zero of=ubuntu_rootfs.img bs=1M count=8192‬
复制代码
将该文件格式化为ext4文件系统
  1. mkfs.ext4 ubuntu_rootfs.img
复制代码
3.2、将镜像文件挂载到空文件

  1. mkdir ubuntu_base_rootfs
复制代码
  1. chmod 777 ubuntu_base_rootfs
复制代码
  1. mount ubuntu_rootfs.img ubuntu_base_rootfs
复制代码
  1. cp -rfp ubuntu_rootfs/* ubuntu_base_rootfs/
复制代码
  1. umount ubuntu_base_rootfs/
复制代码
3.3、修复及检测镜像文件系统

修复及检测镜像文件系统
  1. e2fsck -p -f ubuntu_rootfs.img
复制代码
resize2fs减小镜像文件的巨细,上述的2.8小节中的开释rootfs分区巨细与这里减少文件巨细相关。
  1. resize2fs -M ubuntu_rootfs.img
复制代码
检察巨细
  1. du -sh ubuntu_rootfs.img
复制代码
  1. rootfs# du -sh ubuntu_rootfs.img
  2. 5.0G        ubuntu_rootfs.img
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

一给

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表