完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
下载ubuntu基本裸系统
http://cdimage.ubuntu.com/ubuntu-base/releases/16.04/release/ http://cdimage.ubuntu.com/ubuntu-base/releases/16.04/release/ubuntu-base-16.04-core-armhf.tar.gz 下载ubuntu-base-16.04-core-armhf.tar.gz之后,建立一个ubuntufs文件,然后进行文件的解压,复制到ubuntufs文件夹里面: ---/rk3288$ mkdir ubuntufs ---/rk3288$ sudo tar -xpf ubuntu-base-16.04-core-armhf.tar.gz -C ubuntufs 接下来就是修改我们的根文件系统 在修改之前我们要做一些准备工作 由于我们要chroot,所以需要能够在chroot环境执行arm64版本的binary,所以我们要接触linux的binfmt机制和qemu static解释器。qemu是纯软件实现的虚拟化模拟器,几乎可以模拟任何硬件设备,有了它就可以通过chroot命令进入不同平台架构的根文件系统进行相关操作。 安装qemu ---/rk3288$ sudo apt-get install qemu-user-static 然后复制到 ---/rk3288$ sudo cp /usr/bin/qemu-arm-static ubuntufs/usr/bin/ 准备网络 将本机的dns配置复制到目标rootfs ---/rk3288$ sudo cp -b /etc/resolv.conf ubuntufs/etc/resolv.conf 把所有的# deb替换成deb,即取消注释,然后将所有链接换成阿里云的源。另外需要注意的是,其中的xenial代表ubuntu16.04版本,如果是ubuntu18.04则对应bionic。 ---/rk3288$ sudo vi ubuntufs/etc/apt/sources.list # See http://help.ubuntu.com/community/UpgradeNotes for how to upgrade to # newer versions of the distribution. deb http://mirrors.aliyun.com/ubuntu-ports/ xenial main restricted deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial main restricted ## Major bug fix updates produced after the final release of the ## distribution. deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-updates main restricted deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-updates main restricted ## Uncomment the following two lines to add software from the ‘universe’ ## repository. ## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu ## team. Also, please note that software in universe WILL NOT receive any ## review or updates from the Ubuntu security team. deb http://mirrors.aliyun.com/ubuntu-ports/ xenial universe deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial universe deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-updates universe deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-updates universe ## N.B. software from this repository may not have been tested as ## extensively as that contained in the main release, although it includes ## newer versions of some applications which may provide useful features. ## Also, please note that software in backports WILL NOT receive any review ## or updates from the Ubuntu security team. deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-backports main restricted deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-backports main restricted deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-security main restricted deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-security main restricted deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-security universe deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-security universe deb http://mirrors.aliyun.com/ubuntu-ports/ xenial-security multiverse deb-src http://mirrors.aliyun.com/ubuntu-ports/ xenial-security multiverse 使用chroot命令进入根文件系统进行操作 ---/rk3288$ sudo chroot ubuntufs chroot,即 change root directory,更改root目录的意思,命令详情自查。 root@chry-PC:/# ls bin boot dev etc home lib media mnt opt proc root run ***in srv sys tmp usr var root@chry-PC:/# pwd 然后更新和安装软件 最新的软件包列表,使用apt update命令,然后酌情使用apt upgrade命令更新已安装的软件。 root@*****:/# apt update root@*****:/# apt upgrade 然后是使用apt-get install命令安装需要用到的软件,这一步自行发挥。可以在最后面增加–no-install-recommends参数来避免安装非必须的文件,从而减小镜像的体积。 root@*****:/# apt-get install vim net-tools iputils-ping ssh udhcpc sudo rsync --no-install-recommends 添加用户及设置密码 root@*****:/# useradd -s ‘/bin/bash’ -m -G adm,sudo chry root@*****:/# passwd chry Enter new UNIX password: Retype new UNIX password: passwd: password updated successfully root@*****:/# passwd root Enter new UNIX password: Retype new UNIX password: passwd: password updated successfully root@*****:/# 设置可使用root用户登录ssh 安装ssh后,默认情况下不允许使用root用户登录,需作以下修改: root@*****:/# vi /etc/ssh/sshd_config 设置串口 因为没有安装桌面,所以这里的配置要具体和内核中登录的串口的设备对应起来,不然对导致无法通过串口登录的问题。 vi /lib/systemd/system/serial-getty@.service 修改BindsTo选项: dev-%i.device改成dev-%i如果不执行这一步,烧录文件系统后启动,串口可能会卡死。 串口自动登录root用户(可选) 修改ExecStart选项: -/***in/agetty --keep-baud 115200,38400,9600 %I $TERM改成 -/***in/agetty -a root --keep-baud 115200,38400,9600 %I $TERM 设置主机名(可选) 默认主机名为localhost.localdomain root@*****:/# echo ‘ubuntu.ubuntu’ 》 /etc/hostname 添加主机入口 root@*****:/# vi /etc/hosts 127.0.0.1 localhost 127.0.0.1 ubuntu.ubuntu 如果不修改/etc/hosts,该系统每次运行sudo命令都会有错误提示,但不影响使用。 制作根文件系统 在修改完跟文件系统后,使用exit退出来,开始制作镜像文件。 root@****:/# exit 使用du命令查看一下修改后根文件系统的大小 ubuntu@ubuntu-PC:~/code/rk3288$ sudo du -h --max-depth=0 ubuntufs/ 410M ubuntufs/ 用dd工具创建镜像文件,注意6G是分区大小: ubuntu@ubuntu-PC:~/code/rk3288$ dd if=/dev/zero of=linuxroot.img bs=1M count=6144 记录了6144+0 的读入 记录了6144+0 的写出 6442450944 bytes (6.4 GB, 6.0 GiB) copied, 48.2686 s, 133 MB/s 格式化镜像文件,并加入linuxroot卷标: ubuntu@ubuntu:~/code/rk3288$ mkfs.ext4 -F -L linuxroot linuxroot.img mke2fs 1.43.4 (31-Jan-2017) 丢弃设备块: 完成 创建含有 1572864 个块(每块 4k)和 393216 个inode的文件系统 文件系统UUID:b9207194-30bc-4f8c-9476-70ccf7c83794 超级块的备份存储于下列块: 32768, 98304, 163840, 229376, 294912, 819200, 884736 正在分配组表: 完成 正在写入inode表: 完成 创建日志(16384 个块)完成 写入超级块和文件系统账户统计信息: 已完成 挂载镜像并往里面拷入修改后的文件系统 ubuntu@ubuntu-PC:~/code/rk3288$ mkdir rootfs ubuntu@ubuntu-PC:~/code/rk3288$ sudo mount linuxroot.img rootfs/ ubuntu@ubuntu-PC:~/code/rk3288$ sudo cp -rfp ubuntufs/* rootfs/ ubuntu@ubuntu-PC:~/code/rk3288$ sudo umount rootfs/ linuxroot.img里就已经有刚才制作的根目录内容了,但linuxroot.img文件大小却是定义的分区大小,不是文件系统的实际大小,所以还要经过一些处理才能发布。检查并修复linuxroot.img镜像的文件系统,不熟悉的朋友可以通过网络了解此工具: ubuntu@ubuntu-PC:~/code/rk3288$ e2fsck -p -f linuxroot.img linuxroot:正在修复日志 linuxroot:16382/393216 文件(0.0% 为非连续的), 75104/1572864 块 减小ubuntu.img镜像文件的大小 ubuntu@ubuntu-PC:~/code/rk3288$ resize2fs -M linuxroot.img resize2fs 1.43.4 (31-Jan-2017) 将 linuxroot.img 上的文件系统调整为 206153 个块(每块 4k)。 linuxroot.img 上的文件系统现在为 206153 个块(每块 4k)。 ubuntu@ubuntu-PC:~/code/rk3288$ ls -lh linuxroot.img -rw-r--r-- 1 ubuntu ubuntu 806M 9月 4 09:48 linuxroot.img 配置ubuntu文件系统 源码中默认的Linux rootfs是buildroot,如果rootfs使用buildroot,跳过此步,需要使用用ubuntu文件系统。需要通过以下步骤来配置 在device/rockchip/rk3288/BoardConfig_8846.mk中, 将“# rootfs image path”修改为: Export RK_ROOTFS_IMG=rootfs/linuxroot.img 编译配置文件 在工程目录下执行: 。/build.sh BoardConfig_8846.mk 模块化编译 编译u-boot: 。/build.sh uboot 编译kernel 。/build.sh kernel 打包固件(工程目录下执行) 。/mkfirmware.sh 整理分区镜像到rockdev/目录下,每次打包固件前,需要运行mkfirmware.sh脚本更新rockdev/下的分区镜像。 整合统一固件 。/uild.sh updateimg 注意:每次打包固件前,需要运行mkfirmware.sh脚本更新rockdev/下的分区镜像。 测试根文件系统 烧录 测试___给rootfs分区扩展磁盘空间 `sudo l***lk` sudo df -h 检查根文件系统大小是否一致,如果,不一致,运行一下命令解决sudo resize2fs /dev/mmcblk2p*上面的*换成l***lk下根文件系统对应的编号。重新运行sudo df -h问题解决。网络测试ifconfig发现只有127.0.0.1,运行sudo udhcpc自动获取ip,测试ping命令,测试电脑上通过ssh使用root用户登录到板子上。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
基于米尔瑞芯微RK3576核心板/开发板的人脸疲劳检测应用方案
2420 浏览 0 评论
2778 浏览 1 评论
2268 浏览 1 评论
3597 浏览 1 评论
4355 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-23 13:57 , Processed in 0.620438 second(s), Total 72, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号