array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 ARM架构安装ubuntu系统 - 爱码网
jzcn

一、简介

arm开发板制作系统是比较麻烦,不论使用busybox还是yocto制作根文件系统对新手都比太友好,除非深度定制,否则使用ubuntu系统既可以满足,把更多的精力放在应用开发上。

二、准备材料

我使用的芯片是RK3288,小伙伴可以根据自己的情况选择开发版。
开发环境:VMware
操作系统:ubuntu
开发版:RK3288

三、ubuntu的下载与配置

  1. 下载ubuntu系统
    ubuntu官网根文件系统下载地址 http://cdimage.ubuntu.com ,根据需要下载自己所需的版本,我使用的是ubuntu20.04.2。打开链接后选择ubuntu-base → releases → 版本号 → release → ubuntu-base-20.04.1-base-armhf.tar.gz 下载完成后将ubuntu-base-20.04.1-base-armhf.tar.gz拷贝到ubuntu下,并解压。
mkdir ubuntu20.04.2
sudo tar zxf ubuntu-base-20.04.1-base-armhf.tar.gz -C ubuntu20.04.2
  1. 安装qemu-user-static工具
    安装完成后拷贝“/usr/bin/qemu-arm-static”到刚刚解压文件的“/usr/bin”路径下。
sudo apt-get install qemu-user-static
sudo cp /usr/bin/qemu-arm-static ubuntu20.04.2/usr/bin/
  1. 网络配置
    我在上一篇文章中uboot通过NFS挂载ubuntu根文件系统,介绍在ubuntu20.04.2/etc/apt/sources.list文件中更改ubuntu的软件源,不知道为啥这次配置后反而下载不了,所以这里我就没有配置,各位小伙伴视情况而定。为了制作成功的根文件系统能够联网,可以直接拷贝本机的dns配置文件到根文件系统的相应位置。
sudo cp /etc/resolv.conf ubuntu20.04.2/etc/resolv.conf
  1. 使用chroot工具挂载文件系统
    挂载成功后会进入到我们下来的系统中,注意里面的操作都是对我们挂载的系统进行操作的,无法在对开发系统进行操作,除非使用exit命令退出。
sudo chroot ubuntu20.04.2

  1. 安装软件
    首先更新源,更新完成,安装必要软件,如有需要根据自己需求安装所需的软件即可,以下是我使用时需要的软件。
apt-get update
apt-get upgrade
# 需要安装的软件
apt-get install sudo
apt-get install openssh-server
apt-get install vim
apt-get install net-tools
apt-get install iproute2
apt-get install udhcpc
apt-get install iputils-ping
  1. 用户配置
    设置root密码
passwd root

创建用户

adduser rk3288

设置主机名称和本机IP

echo "rk3288" > /etc/hostname
echo "127.0.0.1 localhost" >> /etc/hosts
echo "127.0.1.1 rk3288" >> /etc/hosts
  1. 设置串口和网络dhcp
    因为没有安装桌面,所以这里的配置要和内核中登录的串口的设备对应,否则串口会卡死,无法登陆。
sudo vim /lib/systemd/system/serial-getty\@.service

修改BindsTo选项将‘dev-%i.device’改成‘dev-%i’,修改ExecStart选项将‘-/sbin/agetty --keep-baud 115200,38400,9600 %I $TERM’改成‘-/sbin/agetty -a root --keep-baud 115200,38400,9600 %I $TERM’

  1. 退出挂载
exit

四、打包跟文件系统

不同的开发板需要的文件格式不一样,有的只需要将根文件系统压缩即可,是情况而定。RK3288需要的是.img格式,所以需要将根文件系统打包成.img文件,具体的操作方法我就不在介绍了,可以了解我之前文章linux下制作img文件

五、烧写文件

  1. 打开瑞芯的烧写软件,文件结构如图所示

  2. 拷贝文件系统到
    \rockdev\Image路径下

  3. 打开AndroidTool_Release/AndroidTool.exe烧写工具,并将rootfs替换成要烧写的软件

  4. 通过ota连接设备,进入烧写模式,这里烧写的是linux系统,所以和andriod系统的烧写有所不同,具体如下


  5. 完成烧写

五、网络测试

  1. 通过sudo udhcpc自动获取网络
ifconfig

sudo udhcpc

  1. 打开ssh登录
    修改/etc/ssh/sshd_config文件,
vim /etc/ssh/sshd_config

打开PermitRootLogin和PasswordAuthentication。


重启ssh服务

systemctl restart ssh

完成后就可以打开ssh服务了

六、磁盘空间

  • df(英文全称:disk full):列出文件系统的整体磁盘使用量
  • du(英文全称:disk used):检查磁盘空间使用量
  • fdisk:用于磁盘分区
  1. 查看文件系统的整体磁盘使用量
df -h

  1. 查看磁盘分区
fdisk -l

  1. 用于列出所有可用块设备的信息
sudo lsblk


从上面信息可以看出来我整个空间有14G左右,但是文件系统使用的空间只有4G左右,还有10G的空间未使用,所以现在需要将系统空间重新分配一下。

  1. 重新分配空间
    从下图中可以明显看出来我整个空间有14G左右,而空间/dev/mmcblk2p5挂载的是根文件系统,并且空间有14.3G,但是通过df -h查看时只使用了4G左右,还有一部分空间未使用,所以只需要使用命令resize2fs将/dev/mmcblk2p5空间重新分配一下即可。

    重新分配根文件空间
sudo resize2fs /dev/mmcblk2p5


到此在ARM架构中安装ubuntu系统已经完成了,有写得不好的地方望小伙伴们指出,我将努力学习并改进。

参考文献

RK3288的ubuntu根文件系统制作与配置:https://www.it610.com/article/1291557055815032832.htm
Linux平台查看、格式化、(开机自动)挂载未使用的磁盘空间https:<blog.csdn.net/rainforest_c/article/details/104986078>
resize2fs命令 – 调整文件系统大小:https://www.linuxcool.com/resize2fs
Linux 磁盘管理:https://www.runoob.com/linux/linux-filesystem.html

分类:

技术点:

相关文章: