标签:需要 export 修改文件 stop too roo .net 修改文件权限 PFS
Linux 最小系统制作
一、制作工具Busybox
在制作文件系统的时候,我们需要使用“Busybox 工具”,即为附件压缩包“busybox-1.21.1.tar.bz2”。“BusyBox 工具”是一个集成了一百多个最常用Linux 命令和工具的软件。 BusyBox 包含了一些简单的工具,例如 ls、cat 和 echo 命令等等,还包含了一些更大、更复杂的工具,例 grep、find、mount 以及 telnet 命令。有些人将 BusyBox 称为 Linux工具里的瑞士军刀。简单的说 BusyBox 就好像是个大工具箱,它集成压缩了 Linux 的许多工具和命令,也包含了 Android 系统自带的 shell。
“Busybox 工具”的官方网址是“http://www.busybox.net/”,这是一个开源的程序,并且一直在更新中,我们使用的版本是“busybox-1.21.1.tar.bz2”。
二、制作步骤
(1)首先拷贝“busybox-1.21.1.tar.bz2”到我们的虚拟机 Ubuntu 系统上,然后在Ubuntu 命令行,执行“#tar -xvf busybox-1.21.1.tar.bz2”解压命令
(2)如下图,使用“#cd busybox-1.21.1”命令进入到前面解压出来的“busybox-1.21.1”文件夹中
(3)输入make menuconfig 进行配置
(4)进入Busybox Settings ->Build Optiions-> Cross Compiler prefix
(5)输入交叉编译器arm-none-linux-gnueabi-
(6)返回busybox settings
(7)进入Installation Options ->BusyBox installation prefix
(8)删除./_install
(9)输入../system
(10)返回最上级,然后保存退出
(11)输入make,开始编译busybox
(12)把编译后的二进制文件安装到../system,输入命令make install
(13)Cd ../system 看里面的文件
(14)制作的文件系统还需要新建“dev,etc,lib,mnt,proc,sys,tmp,var”文件夹,使用命令“mkdir dev etc lib mnt proc sys tmp var”
(15) 进入ect文件夹cd etc,创建文件vi eth0-setting ,输入以下内容并保存:
IP=192.168.1.230
Mask=255.255.255.0
Gateway=192.168.1.1
DNS=192.168.1.1
MAC=08:90:90:90:90:90
(16) 修改文件权限chmod 755 eth0-setting
(17)在 etc 目录下用“mkdir init.d”命令建立“init.d”文件夹 ,进入init.d文件夹,cd init.d,创建文件vi ifconfig-eth0 ,输入以下内容
1. #!/bin/sh 2.echo -n Try to bring eth0 interface up......>/dev/ttySAC2 3.if [ -f /etc/eth0-setting ] ; then 4.source /etc/eth0-setting 5.if grep -q "/dev/root / nfs " /etc/mtab ; then 6.echo -n NFS root ... > /dev/ttySAC2 7.else 8.ifconfig eth0 down 9.ifconfig eth0 hw ether $MAC 10.ifconfig eth0 $IP netmask $Mask up 11.route add default gw $Gateway 12.fi 13.echo nameserver $DNS > /etc/resolv.conf 14.else 15.if grep -q "/dev/root / nfs " /etc/mtab ; then 16.echo -n NFS root ... > /dev/ttySAC2 17.else 18./sbin/ifconfig eth0 192.168.253.12 netmask 255.255.255.0 up 19.fi 20.fi 21.echo Done > /dev/ttySAC2
(18)修改文件权限chmod 755 ifconfig-eth0
(19)然后在“init.d”文件夹下使用“vi rcS”命令建立“rcS”文件 ,输入以下内容
1.#! /bin/sh 2.PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin: 3.runlevel=S 4.prevlevel=N 5.umask 022 6.export PATH runlevel prevlevel 7.# # 8.Trap CTRL-C &c only in this shell so we can interrupt subprocesses. 9.# 10.trap ":" INT QUIT TSTP 11./bin/hostname iTOP-4412 12.#/bin/mount -n -t proc none /proc 13.#/bin/mount -n -t sysfs none /sys 14.#/bin/mount -n -t usbfs none /proc/bus/usb 15.#/bin/mount -t ramfs none /dev 16.[ -e /proc/1 ] || /bin/mount -n -t proc none /proc 17.[ -e /sys/class ] || /bin/mount -n -t sysfs none /sys 18.[ -e /dev/tty ] || /bin/mount -t ramfs none /dev 19.echo /sbin/mdev > /proc/sys/kernel/hotplug 20./sbin/mdev -s 21.#/bin/hotplug 22.# mounting file system specified in /etc/fstab 23.mkdir -p /dev/pts 24.mkdir -p /dev/shm 25./bin/mount -n -t devpts none /dev/pts -o mode=0622 26./bin/mount -n -t tmpfs tmpfs /dev/shm 27.#/bin/mount -n -t ramfs none /tmp 28.#/bin/mount -n -t ramfs none /var 29.mkdir -p /var/empty 30.mkdir -p /var/log 31.mkdir -p /var/log/boa 32.mkdir -p /var/lock 33.mkdir -p /var/run 34.mkdir -p /var/tmp 35.ln -sf /dev/ttyS2 /dev/tty2 36.ln -sf /dev/ttyS2 /dev/tty3 37.ln -sf /dev/ttyS2 /dev/tty4 38.syslogd 39./etc/rc.d/init.d/netd start 40.echo " " > /dev/tty1 41.echo "Starting networking..." > /dev/tty1 42.#sleep 1 43.#/etc/rc.d/init.d/httpd start 44.#echo " " > /dev/tty1 45.#echo "Starting web server..." > /dev/tty1 46.#sleep 1 47.#/etc/rc.d/init.d/leds start 48.#echo " " > /dev/tty1 49.#echo "Starting leds service..." > /dev/tty1 50.#echo " " 51.#sleep 1 52.#echo "*************************************" > /dev/ttySAC2 53.#echo " http://www.topeet.com.cn " > /dev/ttySAC2 54.#echo "*************************************" > /dev/ttySAC2 55.#echo "*************************************" 56.#echo " http://www.topeet.com.cn " 57.#echo "*************************************" 58.mkdir /mnt/disk 59.sleep 1 60./sbin/ifconfig lo 127.0.0.1 61./etc/init.d/ifconfig-eth0
(20)然后保存并退出“rcS”文件,使用“chmod 755 rcS”命令修改“rcS”文件的权限
(21)返回上一级,cd ..进入etc文件夹
(22)接下来在“etc”目录下使用“vi passwd”命令建立文件“passwd” ,输入以下内容
root::0:0:root:/:/bin/sh
bin:*:1:1:bin:/bin:
daemon:*:2:2:daemon:/sbin:
nobody:*:99:99:Nobody:/:
(23)然后保存并退出“passwd”文件,使用“chmod 755 passwd”命令修改“passwd”文件的权限
(24)使用“vi profile”命令在“etc”目录建立“profile”文件 ,输入
1.# Ash profile 2.# vim: syntax=sh 3.# No core files by default 4.ulimit -S -c 0 > /dev/null 2>&1 5.USER="`id -un`" 6.LOGNAME=$USER 7.PS1=‘[$USER@$HOSTNAME]# ‘ 8.PATH=$PATH 9.HOSTNAME=`/bin/hostname` 10.export USER LOGNAME PS1 PATH
(25)然后保存并退出“profile”文件,使用“chmod 755 profile”命令修改“profile”文件的权限
(26)接下来使用“mkdir rc.d”命令在“etc”目录建立文件夹“rc.d”
(27)进入rc.d,使用“mkdir init.d”命令建立“init.d”文件夹 ,进入cd init.d文件夹
(28)接着在“init.d”文件夹,使用“vi netd”命令建立“netd”文件 ,输入
1.#!/bin/sh 2.base=inetd 3.# See how we were called. 4.case "$1" in 5.start) 6./usr/sbin/$base 7.;; 8.stop) 9.pid=`/bin/pidof $base` 10.if [ -n "$pid" ]; then 11.kill -9 $pid 12.fi 13.;; 14.esac 15.exit 0
(29)然后保存并退出“netd”文件,使用“chmod 755 netd”命令修改“netd”文件的权限
(30)使用“cd ../../../”命令返回到“system”目录 ,进入lib文件夹
(31)因为我们使用的交叉编译环境和编译内核是一样的,所以我们的编译器在文件夹“/usr/local/arm/arm-2009q3”中。Busybox 编译生成的二进制文件是以动态链接库的形式运行,所以我们需要拷贝编译器里面的库文件到“lib”目录,使用命令:cp/usr/local/arm/arm-2009q3/arm-none-Linux-gnueabi/libc/lib/* ./
(32)返回system,再进入var,然后使用“mkdir lib lock log run tmp”命令在“var”目录下建立“lib,lock,log,run,tmp”五个目录
(33)所有文件都创建好了,下面需要编译成映像文件
(34)拷贝“Linux_tools.tgz”到 Ubuntu 的“/”目录下,并使用命令“tar -vxf linux_tools.tgz”解压
(35)使用命令“make_ext4fs -s -l 314572800 -a root -L Linux system.img system”,执行该命令后,会生成“system.img”文件系统镜像
(36)然后把system.img烧录进开发板,烧录方式和android和QT的系统文件一样,其他的映像可以使用QT和android的映像
标签:需要 export 修改文件 stop too roo .net 修改文件权限 PFS
原文地址:https://www.cnblogs.com/jemylu/p/10744652.html