5 OBJCOPY = $(TOOLCHAIN)-objcopy
6 OBJDUMP = $(TOOLCHAIN)-objdump
7 SIZE = $(TOOLCHAIN)-size
13 CFLAGS += -Wall -Wextra
14 CFLAGS += -Wredundant-decls
15 #CFLAGS += -fno-common -ffunction-sections -fdata-sections
18 LDFLAGS += -Wl,--gc-sections
22 LDFLAGS += -T$(LDSCRIPT)
26 !cc = |> ^ CC %f^ $(CC) $(CFLAGS) $(CPPFLAGS) -c %f -o %o |> %B.o
27 !LINK = |> ^ LINK %o^ $(LD) $(CFLAGS) $(LDFLAGS) -Wl,-Map=%O.map %f $(LDLIBS) -o %o |> | %O.map
28 !OBJCOPY= |> ^ OBJCOPY %o^ $(OBJCOPY) -Oihex %f %o |>
29 !OBJDUMP= |> ^ OBJDUMP %o^ $(OBJDUMP) -h -S %f > %o |> %O.lss
30 !SIZE = |> ^ SIZE %f^ $(SIZE) %f |>
33 : foreach $(SRC) | $(PREDEP) |> !cc |> {objs}
34 : $(SRC_Z) |> !cc $(CPPFLAGS_Z) |> {objs}
36 : {objs} |> !LINK |> $(PROG).elf {elf}
37 : {elf} |> !OBJCOPY |> %B.hex {aux}
38 : {elf} |> !OBJDUMP |> %B.lss {aux}
39 : {elf} | {aux} |> !SIZE |>