Makefile не работает для нескольких файлов c, но работает для одного файла c
Этот make-файл предназначен для создания шестнадцатеричного файла для микроконтроллера ARM. Мой make-файл берет все файлы c, хранящиеся в папке, и генерирует шестнадцатеричный файл. Шестнадцатеричный файл, файлы.obj и т. Д. Помещаются в папку bin.
Мои make-файлы работают нормально (т.е. я могу видеть шестнадцатеричный файл, файлы.obj и т. Д.), Когда внутри папки находится только один файл c. Но если я поместил в папку более одного файла c, сборка не удалась. Ниже приведена ошибка, которую я получаю, когда у меня более одного файла c.
arm-none-eabi-gcc: error: main.o: No such file or directory
make: *** [32bitTimer.elf] Error 1
Я прилагаю мой make-файл для справки.
Не могли бы вы сообщить мне, почему это не работает для нескольких файлов c?
## makefile
BINARY = 32bitTimer
LDSCRIPT = stm32f4-discovery.ld
SRCS = $(wildcard *.c)
OBJDIR = bin
PREFIX = arm-none-eabi
CC = $(PREFIX)-gcc
LD = $(PREFIX)-gcc
OBJCOPY = $(PREFIX)-objcopy
OBJDUMP = $(PREFIX)-objdump
GDB = $(PREFIX)-gdb
TOOLCHAIN_DIR ?= ../libopencm3
CFLAGS += -Os -g \
-Wall -Wextra -Wimplicit-function-declaration \
-Wredundant-decls -Wmissing-prototypes -Wstrict-prototypes \
-Wundef -Wshadow \
-I$(TOOLCHAIN_DIR)/include \
-fno-common -mcpu=cortex-m4 -mthumb \
-mfloat-abi=hard -mfpu=fpv4-sp-d16 -MD -DSTM32F4
LDFLAGS += --static -lc -lnosys -L$(TOOLCHAIN_DIR)/lib \
-L$(TOOLCHAIN_DIR)/lib/stm32/f4 \
-T$(LDSCRIPT) -nostartfiles -Wl,--gc-sections \
-mthumb -mcpu=cortex-m4 -mthumb -mfloat-abi=hard -mfpu=fpv4-sp-d16
OBJS = $(SRCS:.c=.o)
# Be silent per default, but 'make V=1' will show all compiler calls.
ifneq ($(V),1)
Q := @
endif
all: $(OBJDIR) $(BINARY).images
%.images: %.elf
$(Q)$(OBJCOPY) -Obinary $(OBJDIR)/$(*).elf $(OBJDIR)/$(*).bin
$(Q)$(OBJCOPY) -Oihex $(OBJDIR)/$(*).elf $(OBJDIR)/$(*).hex
$(Q)$(OBJCOPY) -Osrec $(OBJDIR)/$(*).elf $(OBJDIR)/$(*).srec
$(Q)$(OBJDUMP) -S $(OBJDIR)/$(*).elf > $(OBJDIR)/$(*).list
$(BINARY).elf: $(OBJS) $(LDSCRIPT) $(TOOLCHAIN_DIR)/lib/libopencm3_stm32f4.a
$(Q)$(LD) -o $(OBJDIR)/$(BINARY).elf $(OBJDIR)/$(OBJS) -lopencm3_stm32f4 $(LDFLAGS)
%.o:%.c
$(Q)$(CC) $(CFLAGS) -o $(OBJDIR)/$@ -c $<
$(OBJDIR):
$(Q)mkdir $(OBJDIR)
clean:
$(Q)rm -rf $(OBJDIR)
.PHONY: images clean
1 ответ
Это, вероятно, самая прямая проблема: на линии, которая начинается $(Q)$(LD) -o $(OBJDIR)
у вас есть текст:
$(OBJDIR)/$(OBJS)
Это не делает то, что вы (кажется) ожидаете. Это просто добавляет строковое значение $(OBJDIR)
на строковое значение $(OBJS)
, На самом деле это не префикс каждого слова в последнем. Вы, вероятно, хотите вместо этого сказать следующее:
$(patsubst %,$(OBJDIR)/%,$(OBJS))
который будет префикс каждого слова в $(OBJS)
со значением $(OBJDIR)
сопровождается косой чертой.