九、C语言版LED试验工程治理

工程治理次要是在 Makefile 中会对一些源文件的地址援用和输入文件地址定位,依照学习指南的给出的公共构造如图,对于该目录构造的工程,编写Makefile如下。

CROSS_COMPILE             ?= arm-linux-gnueabihf-       # ?= 如果没有定义,则定义为TARGET                    ?= bspCC             := $(CROSS_COMPILE)gccLD            := $(CROSS_COMPILE)ldOBJCOPY         := $(CROSS_COMPILE)objcopyOBJDUMP         := $(CROSS_COMPILE)objdump# \ 是换行符,示意下一行与这一行为同一行。INCDIRS 是所有头文件的文件夹INCDIRS         := imx6ul \                                        bsp/clk \                   bsp/led \                   bsp/delay #  SRCDIRS 源代码所在的文件夹                                  SRCDIRS            := project \               bsp/clk \               bsp/led \               bsp/delay                    #  应用 patsubst 函数把    INCDIRS 中的每一个文件夹替换成 -I $(folder) 的格局,因为Makefile 指明头文件目录时 须要在后面加上 -I       INCLUDE            := $(patsubst %, -I %, $(INCDIRS))#  先应用 foreach 函数取出SRCDIRS每个文件,而后用wildcard 函数匹配出.S结尾的文件,匹配出的文件带目录门路SFILES            := $(foreach dir, $(SRCDIRS), $(wildcard $(dir)/*.S))CFILES            := $(foreach dir, $(SRCDIRS), $(wildcard $(dir)/*.c))#  先应用 notdir  函数去除门路SFILENDIR        := $(notdir  $(SFILES))CFILENDIR        := $(notdir  $(CFILES))#  先应用变量替换,把SFILENDIR外面的.S文件替换成.o文件,而后用patsubst 给这些文件带上门路 obj/SOBJS            := $(patsubst %, obj/%, $(SFILENDIR:.S=.o))COBJS            := $(patsubst %, obj/%, $(CFILENDIR:.c=.o))OBJS            := $(SOBJS) $(COBJS)# 指定搜寻目录VPATH,应用 VPATH 指明源文件门路,如果不指明,make只会在以后的目录中去找寻依赖文件和指标文件VPATH            := $(SRCDIRS).PHONY: clean# bsp.bin 依赖 obj/ 目录下的 .o 文件,因为以后obj/目录下还为空,会执行上面的依赖    $(TARGET).bin : $(OBJS)    $(LD) -Timx6ul.lds -o $(TARGET).elf $^    $(OBJCOPY) -O binary -S $(TARGET).elf $@    $(OBJDUMP) -D -m arm $(TARGET).elf > $(TARGET).dis# obj/ 目录上面的 .o 文件依赖于 .S 文件$(SOBJS) : obj/%.o : %.S    $(CC) -Wall -nostdlib -c -O2  $(INCLUDE) -o $@ $<$(COBJS) : obj/%.o : %.c    $(CC) -Wall -nostdlib -c -O2  $(INCLUDE) -o $@ $<    clean:    rm -rf $(TARGET).elf $(TARGET).dis $(TARGET).bin $(COBJS) $(SOBJS)

这里的链接脚本与之前的基本一致,就是要留神 .text 外面的 文件要加门路 obj/start.o

十、U-Boot 应用试验

(1)Linux 移植介绍

Linux 的移植较,在移植 Linux之前咱们须要先移植一个 bootloader 代码,这个 bootloader 代码用于启动 Linux 内核, bootloader有很多,罕用的就是 U-Boot。移植好 U-Boot 当前再移植 Linux 内核,移植完 Linux 内核当前Linux 还不能失常启动,还须要再移植一个根文件系统(rootfs),根文件系统外面蕴含了一些最罕用的命令和文件。所以 U-Boot、 Linux kernel 和 rootfs 这三者一起形成了一个残缺的 Linux 零碎,一个能够失常应用、功能完善的 Linux 零碎。

(2)编译U-boot

用晚点原子给出的Uboot,放到文件夹下后,先解压缩 tar -vxjf uboot-imx-2016.03-2.1.0-ge468cdc-v1.5.tar.bz2 。原本很简略,没想到在编译的过程中,呈现了 cp: write error: No space left on device,前面用命令 df -h 一查,原来是虚拟机的存储空间满了。删了一些货色后,转念一想不如间接建一个软连贯,间接能够在Linux虚拟机里不便的用Windows外面的文件,于是应用命令 ln -s /media/sf_Share ~/share.soft 建了一个软连贯。接着就是开始编译发现又失败了,这此的起因又是上面的提醒,再一看,应该是创立的软链接跨了磁盘,而后在mkae外面又尝试创立ln硬链接,留神到硬链接不能跨分区。试了试不在软连贯外面应用 ln,发现还是不行,应该是在加载的盘符中无奈创立硬链接吧,前面查到,建设硬链接时,链接文件和被链接文件必须位于同一个文件系统中,并且不能建设指向目录的硬链接,于是只能等今天再试试了。

ln -fsn $dest arch/arm/include/asm/archln: failed to create symbolic link 'arch/arm/include/asm/arch': Operation not permitted

果然第二次尝试,把整个目录拷贝到了home目录下,而后编译,就编译胜利了。用到的指令如下,因为我只有四个核,所以最初一行的 j12 改成了 j4

编译胜利后的提醒如下: