1、stdio : standard input output 标准输入输出
2、printf函数调用到的2个关键函数:
vsprintf : 格式化打印信息,最终得到纯字符串的打印信息等待输出
putc : 操控标准输出的硬件,将信息发送出去
3、移植步骤:
(1)解压printf.rar到uart_stdio目录,解压后会有include、lib两个目录,其中include放的是相关头文件,lib放的是printf、scanf相关的代码;
(2)修改uart_stdio目录下的makefile,将lib目录下的代码编译链接成lib.a,然后将lib.a编译进bin中;
CC = arm-linux-gcc
LD = arm-linux-ld
OBJCOPY = arm-linux-objcopy
OBJDUMP = arm-linux-objdump
AR = arm-linux-ar INCDIR := $(shell pwd)
# C预处理器的flag,flag就是编译器可选的选项
CPPFLAGS := -nostdlib -nostdinc -I$(INCDIR)/include
# C编译器的flag
CFLAGS := -Wall -O2 -fno-builtin #导出这些变量到全局,其实就是给子文件夹下面的Makefile使用
export CC LD OBJCOPY OBJDUMP AR CPPFLAGS CFLAGS objs := start.o led.o clock.o uart.o main.o
objs += lib/libc.a uart.bin: $(objs)
$(LD) -Tlink.lds -o uart.elf $^
$(OBJCOPY) -O binary uart.elf uart.bin
$(OBJDUMP) -D uart.elf > uart_elf.dis
gcc mkv210_image.c -o mkx210
./mkx210 uart.bin .bin lib/libc.a:
cd lib; make; cd .. %.o : %.S
$(CC) $(CPPFLAGS) $(CFLAGS) -o $@ $< -c %.o : %.c
$(CC) $(CPPFLAGS) $(CFLAGS) -o $@ $< -c clean:
rm *.o *.elf *.bin *.dis mkx210 -f
cd lib; make clean; cd ..
(3)编写main函数进行测试
void puts(const char *p);
char *gets(char *p);
void uart_init(void); void memset(char *p, int val, int length)
{
int i; for(i=; i<length; i++)
{
p[i]=val;
}
} int main(void)
{
char buf[] = {}; uart_init(); puts("x210 Simple shell:\n"); while()
{
puts("Please input your code:"); memset(buf, , sizeof(buf)); gets(buf); puts("Your input code is:"); puts(buf); puts("\n"); } return ;
}