Samsung_tiny4412(驱动笔记01)----linux 3.5,U-Boot,Busybox,SD卡启动环境搭建

/***********************************************************************************
 *                    
 *                      linux 3.5,U-Boot,Busybox,SD卡启动环境搭建
 *
 *  声明:
 *      1. 本系列文档是在vim下编辑,请尽量是用vim来阅读,在其它编辑器下可能会
 *          不对齐,从而影响阅读.
 *      2. 以下所有的shell命令都是在root权限下运行的;
 *      3. minicom(U-Boot)指的是用minicom连接开发板做为U-Boot的终端;
 *      4. 文中在需要往文件中写入内容的时候使用了如下2方式:
 *          1.如果文件不存在,创建文件;如果存在,以覆盖的方式往文件中添加内容:
 *              cat > 文件名 << EOF (结束符)
 *              ...
 *              文件内容...
 *              ...
 *              EOF (输入遇到EOF,cat指令结束,内容将保存在前面指定的文件名中)
 *          2.如果文件不存在,创建文件;如果存在,将内容追加到文件尾:
 *              cat >> 文件名 << EOF (结束符)
 *              ...
 *              文件内容...
 *              ...
 *              EOF 
 *
 *                                          2015-3-7 阴 深圳 尚观 Sbin 曾剑锋
 **********************************************************************************/

                        \\\\\\\--*目录*--/////////////
                        |   一. 预热文章;                   
                        |   二. 内核源码树介绍;             
                        |   三. 配置交叉编译器;             
                        |   四. 内核编译流程以及原理;       
                        |   五. 安装并配置minicom程序;      
                        |   六. U-Boot编译;                 
                        |   七. U-Boot SD卡启动;            
                        |   八. Android fast_boot SD卡启动; 
                        |   九. 使用Busybox制作文件系统;    
                        |   十. NFS配置;                    
                        \\\\\\\\\//////////////////


一. 预热文章:
    1. 计算机是如何启动:
        http://www.ruanyifeng.com/blog/2013/02/booting.html
    2. Linux 的启动流程:
        http://www.ruanyifeng.com/blog/2013/08/linux_boot_process.html
    3. Unix目录结构的来历:
        http://lists.busybox.net/pipermail/busybox/2010-December/074114.html
        http://www.ruanyifeng.com/blog/2012/02/a_history_of_unix_directory_structure.html

二. 内核源码树介绍:
    1. arch(architecture):  与平台架构相关的文件
    2. block:               块设备IO调度策略实现
    3. COPYING:             版权声明
    4. crypto:              常用加密,校验方法实现
    5. Documentation:       内核官方文档
        zh_CN:              中文翻译文档
    6. drivers:             设备驱动程序
    7. fs(file system):     文件系统实现
    8. include:             内核头文件
    9. init:                内核启动代码
    10. ipc(inter process communication): 进程间通信实现
        1. signal           信号
        2. pipe             无名管道
        3. named pipe(FIFO) 命名管道
        4. message queue    消息队列
        5. shared memory    共享内存
        6. semaphore        信号量
        7. socket           套接字
    11. kernel:             内核核心代码
    12. lib(library):       通用库实现
    13. mm(memory manage):  内存管理方法实现
    14. net:                网络协议栈实现
    15. samples:            内核示例代码
    16. scripts:            内核编译工具
    17. sound:              与音频相关代码
        1. oss(open sound system)
        2. alsa(advance linux sound 

三. 配置交叉编译器:
    1. tar xf arm-linux-gcc-4.5.1-v6-vfp-20120301.tgz
    2. cp opt/* /opt -r
    3. cat >> ~/.bashrc << EOF (配置环境变量,以方便使用交叉编译器)
        PATH=$PATH:opt/FriendlyARM/toolschain/4.5.1/bin
        EOF
    4. source ~/.bashrc (使前面的配置的PATH生效)
    5. 检查是否已配置好:
        在终端输入: arm后按两下tab出现如下表示正常
            arm-linux-addr2line               arm-none-linux-gnueabi-addr2line
            arm-linux-ar                      arm-none-linux-gnueabi-ar
            arm-linux-as                      arm-none-linux-gnueabi-as
            arm-linux-c++                     arm-none-linux-gnueabi-c++
            arm-linux-cc                      arm-none-linux-gnueabi-cc
            arm-linux-c++filt                 arm-none-linux-gnueabi-c++filt
            arm-linux-cpp                     arm-none-linux-gnueabi-cpp
            arm-linux-g++                     arm-none-linux-gnueabi-g++
            arm-linux-gcc                     arm-none-linux-gnueabi-gcc
            arm-linux-gcc-4.5.1               arm-none-linux-gnueabi-gcc-4.5.1

四. 内核编译流程以及原理:
    1. make menuconfig
        1. 程序会运行: scripts/kconfig/mconf Kconfig
        2. 配置完保存后,在内核树的根目录下生成: .config文件,是隐藏文件;
        3. Kconfig的语法请参考: Documentation/kbuild/kconfig-language.txt
    2. make -j2 zImage
        1. 参数-j2是开启2个线程来编译内核,zImage编译目标;
        2. 程序会运行: scripts/kconfig/conf .config,生成如下文件:
            1. include/config/auto.conf: 用于Makefile中的的模块编译选择;
                CONFIG_MENU3=y
                CONFIG_M2=y
            2. include/generated/autoconf.h: 用于内核源代码的#ifdef/#ifndef;
                #define CONFIG_MENU3 1
                #define CONFIG_M2 1
        3. 根据上面的auto.conf和autoconf.h,将内核中的.c文件编译成.o文件;
        4. 再把每个目录下的.o通过ar命令打包在built-in.o放到上一级目录中,
           所以每个目录都有一个built-in.o
        5. 以此类推,在源码目录的顶级目录会得到一个built-in.o文件并转换为vmlinux.o
        6. vmlinux.o经过链接器链接(ld)得到vmlinux
        7. 因为内核是运行在裸板上的,所以需要去掉elf文件头,得到了二进制Image文件;
        8. Image经过gzip压缩以后得到了最终的zImage文件;
        9. 可以通过nm vmlinux内核符号,查看需要的驱动没有编译进内核,当然也可以通过
           查看内核根目录下的System.map中的地址符号表,这跟U-Boot一样.

五. 安装并配置minicom程序:
    1. 安装minicom: yum install minicom
    2. 通过USB转串口线连接开发板与电脑,运行命令: ls /dev/
        找到对应的设备节点,本文假设开发板对应的设备节点是:/dev/ttyUSB0
    3. 配置minicom:
        1. 在终端: minicom -s
        2. 进入界面后: 选Serial port setup     
        3. 当使用usb转串口时,Serial Deveice: /dev/ttyUSB0
            +-------------------------------------------+
            | A -    Serial Device      : /dev/ttyUSB0  |
            | B - Lockfile Location     : /var/lock     |
            | C -   Callin Program      :               |
            | D -  Callout Program      :               |
            | E -    Bps/Par/Bits       : 115200 8N1    |
            | F - Hardware Flow Control : No            |
            | G - Software Flow Control : No            |
            |                                           |
            |    Change which setting?                  |

        4. 照上面设好后,选 Save setup as dfl保存为默认配置 

六. U-Boot编译:
    1. make tiny4412_config //(对应的内容可在boards.cfg里查询)
    2. make //编译完成后u-boot.bin就是所要的文件,u-boot.bin是把u-boot文件
            //的elf文件信息去除后得来的

七. U-Boot SD卡启动(假设SD卡挂载在/dev/sdb,并且进入U-Boot根目录):
    1. 往SD卡中烧写U-Boot: uboot_tiny4412/sd_fuse/tiny4412/sd_fusing.sh /dev/sdb 
        运行结果会自动分如下2个区:
            1. /dev/sdb1
            2. /dev/sdb4
    2. 采用vfat格式格式化/dev/sdb1分区,用于放zImage:   mkfs.vfat /dev/sdb1 
    3. 采用ext4格式格式化/dev/sdb4分区,用于放文件系统: mkfs.ext4 /dev/sdb4 
    4. 重新拔插SD卡,把生成上面生成的zImage放入/dev/sdb1分区中,文件系统放在/dev/sdb4分区中;
    5. 将SD卡插入开发板,选择SD卡启动,打开minicom;
    5. 安装dnw: tar xf dnw-linux.tar.gz && cd dnw-linux && make && make install
    6. dnw测试zImage是否可行:
        1. minicom(U-Boot)里面: dnw 0x40008000
        2. PC侧命令:            dnw arch/arm/boot/zImage (在内核根目录下运行命令)
        3. minicom(U-Boot)里面: bootm 0x40008000
    7. minicom(U-Boot)命令查看SD卡中的zImage是否存在: fatls mmc 0:1
    8. minicom(U-Boot)加载zImage到内存0x40008000: fatload mmc 0:1 0x40008000 zImage
    9. minicom(U-Boot)启动内核: bootm 0x40008000
    10. minicom(U-Boot)修改bootcmd: set bootcmd "fatload mmc 0:1 0x40008000 zImage;bootm 0x40008000"
    11. minicom(U-Boot)保存: save
    12. minicom(U-Boot)重启: reset

八. Android fast_boot SD卡启动(需要在前面U-Boot SD卡启动的基础上操作):
    1. minicom输入U-Boot命令即可对SD卡进行分区: fdisk -c 0 320 806 518
    2. 重新分区后,可重新格式化FAT分区,minicom输入U-Boot命令: fatformat mmc 0:1
    3. 使用USB线连接Tiny4412的MICRO_USB口到PC,然后minicom输入U-Boot命令: fastboot
    4. 在PC端将fastboot脚本拷贝到$PATH目录下,当然你也许会没有fastboot,问度娘要吧;
    5. 在PC端输入以下命令进行烧写: fastboot flash kernel zImage(烧写kernel)
    6. zImage传输完的时候minicom会出现假死状态,按ctrl+c退出fastboot命令状态;
    7. minicom(U-Boot)加载zImage到内存0x40008000: movi read kernel 0 40008000
    8. minicom(U-Boot)启动内核: bootm 0x40008000
    9.  minicom(U-Boot)修改bootcmd: set bootcmd "movi read kernel 0 40008000;bootm 0x40008000"
    10. minicom(U-Boot)保存: save
    11. minicom(U-Boot)重启: reset

九. 使用Busybox制作文件系统(本文假设nfs文件系统在PC端的/disk/A9/filesystem文件加下):
    1. make menucofig,在弹出来的对话框中选择一下内容:
        1. Busybox Settings --> Build Options --> [*] Build BusyBox as a static binary (no shared libs) 
        2. Busybox Settings --> Build Options --> (arm-linux-) Cross Compiler prefix
    2. mkdir /disk/A9/filesystem -p (假设/disk/A9/filesystem为nfs提供的目录)
    3. make && make install CONFIG_PREFIX=/disk/A9/filesystem
    4. cd /disk/A9/filesystem && mkdir dev etc sys proc mnt tmp
    5. cat > etc/init.d/rcS << EOF  (rcS:run command Start)
        mount -t ramfs none /dev
        mount -t sysfs none /sys
        mount -t proc  none /proc
        mount -t tmpfs none /tmp
        #采用设备模型进行创建设备节点的必须加上,热插拔处理,为后面的是用驱动模型作准备
        echo "/sbin/mdev" > /proc/sys/kernel/hotplug
        /sbin/mdev  -s
        EOF
    6. mknod dev/console c 5 1
    7. cat > etc/inittab << EOF
        ::sysinit:/etc/init.d/rcS
        ttySAC0::askfirst:-/bin/sh #/bin/sh前面的-表示sh会默认加载/etc/profile
        EOF
    8. cat > etc/profile << EOF
        export PS1="[^_^ W]# " #设置命令提示前面的那段文字
        EOF
    9. mkdir lib && cp /opt/FriendlyARM/toolschain/4.5.1/arm-none-linux-gnueabi/lib/* lib
    10. chmod 777 /disk/A9/filesystem -R --> 给nfs访问所有的权限
    11. 文件系统制作完毕,如果想要将文件系统保存到SD卡中,请保存在第四个分区中;
    12. minicom(U-Boot)里面查看到文件系统的文件夹: ext2ls mmc 0:4 /
    13. SD卡文件系统bootargs设置: set bootargs "root=/dev/mmcblk0p4 console=ttySAC0,115200 lcd=S70"

十. NFS配置(本文假设PC机的IP在局域网100段):
    1. 关闭防火墙(iptables),关闭selinux
    2. PC侧设置:
        1. 设置PC的IP: ifconfig eth0 192.168.100.22
        2. cat >> /etc/exports << EOF
            /disk/A9/filesystem *(rw)
            EOF
        3. service nfs restart
        4. showmount -e 192.168.100.22   --> 查看该目录是否已经发布出去
    3. U-Boot设置(通过minicom设置)
        1. 开发板IP: 192.168.100.111
        2. NFS服务器IP: 192.168.100.22
        3. 网关: 192.168.100.1
        4. 子网掩码: 225.225.225.0
        5. NFS文件系统启动,U-Boot bootargs设置: set bootargs "root=/dev/nfs nfsroot=192.168.100.22:/disk/A9/filesystem ip=192.168.100.111 console=ttySAC0,115200 lcd=S70"
原文地址:https://www.cnblogs.com/zengjfgit/p/4320880.html