uart_stdio實(shí)驗(yàn)
大致內(nèi)容和uart實(shí)驗(yàn)類似,這里只分析兩個(gè)文件。目的:在串口0上實(shí)現(xiàn)printf、scanf等函數(shù),它使用scanf、sscanf、printf等函數(shù)從串口接收一個(gè)十進(jìn)制數(shù)字序列,然后將它轉(zhuǎn)化為十六進(jìn)制輸出。
stdio.lds
SECTIONS {
. = 0x00000000;
.init : AT(0){ head.o init.o nand.o}
/*將上面文件對(duì)應(yīng)的運(yùn)行地址設(shè)為0,加載地址(存在NAND Flash上的地址)設(shè)為0.
從NAND Flash啟動(dòng)時(shí),這些代碼被復(fù)制到Steppingstone后就可以直接運(yùn)行*/
. = 0x30000000;
.text : AT(4096) { *(.text) }/*加載地址設(shè)為4096*/
.rodata ALIGN(4) : AT((LOADADDR(.text)+SIZEOF(.text)+3)&~(0x03)) {*(.rodata*)}
.data ALIGN(4) : AT((LOADADDR(.rodata)+SIZEOF(.rodata)+3)&~(0x03)) { *(.data) }
/*因?yàn)榍懊媸褂?ALIGN(4)使得運(yùn)行地址為4字節(jié)對(duì)齊,所以后面各段之間的加載地址相對(duì)偏移值應(yīng)該等于
運(yùn)行地址的相對(duì)偏移值,需要將AT(...)中的值也設(shè)為4字節(jié)對(duì)齊:先加上3,然后&~(0x03),(將低2位設(shè)為0)*/
__bss_start = .;
.bss ALIGN(4) : { *(.bss) *(COMMON) }
__bss_end = .;
}
Makefile
CC = arm-linux-gcc
LD = arm-linux-ld
AR = arm-linux-ar
OBJCOPY = arm-linux-objcopy
OBJDUMP = arm-linux-objdump
INCLUDEDIR := $(shell pwd)/include #打印本文件夾路徑賦值給 INCDIR
CFLAGS := -Wall -O2 #-Wall:打開警告信息 -O2:2級(jí)優(yōu)化(常用)
CPPFLAGS := -nostdinc -I$(INCLUDEDIR) #-nostdinc:不在標(biāo)準(zhǔn)系統(tǒng)目錄中搜索頭文件,只在-I指定的目錄中搜索
export CC LD OBJCOPY OBJDUMP INCLUDEDIR CFLAGS CPPFLAGS #導(dǎo)出這些變量到全局,其實(shí)就是給子文件夾下面的Makefile使用
objs := head.o init.o nand.o serial.o main.o lib/libc.a #lib/libc.a 在子makefile中生成的目標(biāo)
stdio.bin: $(objs)
${LD} -Tstdio.lds -o stdio_elf $^
${OBJCOPY} -O binary -S stdio_elf $@
${OBJDUMP} -D -m arm stdio_elf > stdio.dis
.PHONY : lib/libc.a
#.PHONY是一個(gè)偽目標(biāo),可以防止在Makefile中定義的只執(zhí)行命令的目標(biāo)和工作目錄下的實(shí)際文件出現(xiàn)名字沖突,另一種是提高執(zhí)行makefile時(shí)的效率。
lib/libc.a:
cd lib; make; cd ..
#切換到lib文件夾,執(zhí)行make指令,然后返回到上一級(jí)目錄。
%.o:%.c
${CC} $(CPPFLAGS) $(CFLAGS) -c -o $@ $<
%.o:%.S
${CC} $(CPPFLAGS) $(CFLAGS) -c -o $@ $<
clean:
make clean -C lib
rm -f stdio.bin stdio_elf stdio.dis *.o
[剩余文件點(diǎn)我下載]