printf()
, putchar()
and puts()
. It’s
time to bundle them as a library. This will give me more flexibility as I will
not have to give a full list of the modules to link, the linker will handle
the missing dependencies by looking into the libraries.
printf()
and putchar()
in
stand alone modules. As I have removed my previous implementation of
puts()
from the system, I need to create puts.c.
/* puts.c -- write a string to stdout */ #include <stdio.h> #include "system.h" /* kputc(), kputs() */ int puts( const char *s) { kputs( s) ; kputc( '\n') ; return 0 ; }
What’s the name, the content and the rule to maintain the library:
AR = $(BINPFX)ar LIBOBJS = printf.o putchar.o puts.o LIBSTEM = stm32 lib$(LIBSTEM).a: $(LIBOBJS) $(AR) rc $@ $?Where to look for and which libraries to use in the link phase:
LIBS = -l$(LIBSTEM) -lgcc LIB_PATHS = -L. -L$(LIBDIR) $(PROJECT).elf: $(OBJS) lib$(LIBSTEM).a @echo $@ from $(OBJS) $(LD) -T$(LD_SCRIPT) $(LIB_PATHS) -Map=$(PROJECT).map -cref -o $@ $(OBJS) $(LIBS) $(SIZE) $@ $(OBJDUMP) -hS $@ > $(PROJECT).lstLibrary modules are implicitly part of the composition, so it’s not necessary to list them anymore.
#SRCS = startup.c uplow.2.c uptime.c printf.c putchar.c SRCS = startup.c uplow.2.c uptime.cI include libraries in the list of files to delete when doing a make clean.
clean: @echo CLEAN @rm -f *.o *.elf *.map *.lst *.bin *.hex *.a
$ make f030f4.elf from startup.o uplow.2.o uptime.o text data bss dec hex filename 1317 0 8 1325 52d f030f4.elf f030f4.hex f030f4.binChecking the map produced by the linker I can see that it fetched the necessary modules for
printf()
and putchar()
from the
newly created library.
Archive member included to satisfy reference by file (symbol) libstm32.a(printf.o) uptime.o (printf) libstm32.a(putchar.o) uptime.o (putchar) D:/Program Files (x86)/GNU Arm Embedded Toolchain/arm-gnu-toolchain-14.2.rel1-mi ngw-w64-i686-arm-none-eabi/lib/gcc/arm-none-eabi/14.2.1/thumb/v6-m/nofp\libgcc.a (_thumb1_case_sqi.o) libstm32.a(printf.o) (__gnu_thumb1_case_sqi) D:/Program Files (x86)/GNU Arm Embedded Toolchain/arm-gnu-toolchain-14.2.rel1-mi ngw-w64-i686-arm-none-eabi/lib/gcc/arm-none-eabi/14.2.1/thumb/v6-m/nofp\libgcc.a (_udivsi3.o) uptime.o (__aeabi_uidiv) D:/Program Files (x86)/GNU Arm Embedded Toolchain/arm-gnu-toolchain-14.2.rel1-mi ngw-w64-i686-arm-none-eabi/lib/gcc/arm-none-eabi/14.2.1/thumb/v6-m/nofp\libgcc.a (_dvmd_tls.o) D:/Program Files (x86)/GNU Arm Embedded Toolchain/ arm-gnu-toolchain-14.2.rel1-mingw-w64-i686-arm-none-eabi/lib/gcc/arm-none-eabi/1 4.2.1/thumb/v6-m/nofp\libgcc.a(_udivsi3.o) (__aeabi_idiv0)
SRCS = startup.c uplow.2.c hello.cBuild terminates successfully, the changes in size are due to the difference in the system implementation.
$ make f030f4.elf from startup.o uplow.2.o hello.o text data bss dec hex filename 445 0 8 453 1c5 f030f4.elf f030f4.hex f030f4.binChecking the map file produced in the link phase, I can see that only puts.o has been fetched from my local library.
Archive member included to satisfy reference by file (symbol) libstm32.a(puts.o) hello.o (puts)
Next, I will continue on the topic of asynchronous serial transmission and look into baud rate and clock configuration.