Компиляция C ++ и C в одном Makefile - PullRequest
0 голосов
/ 13 июня 2018

У меня есть проект, который был написан и разработан на C для устройства ARM с использованием набора инструментов arm-none-eabi-gcc.Он использует собственный make-файл, который работал только для компиляции C.Мы пытаемся перейти на проект C ++, сохраняя исходные файлы C, но у меня возникают проблемы с обновлением make-файла.Я знаю, что об этом спрашивали пару раз, но ни один из них не смог полностью решить нашу проблему.Как мне включить исходные и заголовочные файлы C для компиляции с файлами g ++ и cpp?

Я очень ценю любого, кто хочет и может просмотреть наш make-файл, чтобы помочь решить проблемы компиляции.Makefile длинный, поэтому вот несколько сокращенная версия, в которую должно включать все критическое.

Имейте в виду, я включил сюда только make-файл, а не platform_id.mk или $ (PLATFORM_MCU).но я вполне уверен в этих файлах.

BIN_NAME = $(PLATFORM)_firmware.bin
ifdef PLATFORM
include $(PROJECT_ROOT)build/platform_id.mk
include $(PROJECT_ROOT)hal/$(PLATFORM_MCU)/$(PLATFORM_MCU).mk
include $(PROJECT_ROOT)build/$(PLATFORM_MCU_CORE)/$(PLATFORM_MCU_CORE).mk
else
$(error "Platform not defined. Used the -e flag to define the platform in the environment
endif
$(info $(msg))

# C compiler flags
CFLAGS +=\
    -std=c99\
    -Og\
    -g3\
    -Wall\
    -fdata-sections\
    -ffunction-sections\
    -MMD\
    -DHAVE_MMAP=0\
    -Dmalloc_getpagesize=8\
    -DMORECORE_CLEARS=0\
    -DDEFAULT_TRIM_THRESHOLD=8

# C++ compiler flags
CXXFLAGS +=\
    -Wall\
    -D__STDC_LIMIT_MACROS

# C Pre Processor flags
CPPFLAGS +=\

# Undefine WIN32 variable if building on Windows host
ifdef WIN32
CFLAGS += -UWIN32
msg = You're on a windows host.
else
msg = You're not on a windows host.
endif

ifdef TOOLCHAIN
AR = $(TOOLCHAIN)-ar
CC = $(TOOLCHAIN)-gcc
CXX = $(TOOLCHAIN)-g++
endif

# Binary make targets
TARGET = out/$(PLATFORM_MCU)/$(BIN_NAME)


# Binary Sources
VPATH += $(wildcard */src/)
# extract all *.c filenames, don't pull the filepath with it
C_SRCS += $(notdir $(wildcard */src/*.c))
# extract all *.cpp filesnames, don't pull the filepath with it
CXX_SRCS += $(notdir $(wildcard */src/*.cpp))
# extract all *.s filenames, don't pull the filepath with it
S_SRCS += $(notdir $(wildcard */src/*.s))

# Objects
OBJECTS_C += $(patsubst %.c,out/$(PLATFORM_MCU)/obj/%.o,$(C_SRCS))
OBJECTS_CXX += $(patsubst %.cpp,out/$(PLATFORM_MCU)/obj/%.o,$(CXX_SRCS))

# Dependencies
DEP_C := $(OBJECTS_C:.o=.d)
DEP_CXX := $(OBJECTS_CXX:.o=.d)


# Includes
NULL =
SPACE = $(NULL) $(NULL)
INCLUDE_SRC = $(subst $(SPACE),$(SPACE)-I,$(VPATH))
PATH_INC = $(wildcard */inc/)
INCLUDE_INC = $(subst $(SPACE),$(SPACE)-I,$(PATH_INC))

C_INC +=\
    -I$(INCLUDE_INC) \
    -I$(INCLUDE_SRC)



# Clean and precious
PRECIOUS += out/$(PLATFORM_MCU)/obj/%.o
CLEAN += out/$(PLATFORM_MCU)/

# all
all: $(TARGET)

# Create binary
$(TARGET): $(OBJECTS_C) $(OBJECTS_CXX) $(S_SRCS)
    @mkdir -p $(dir $@)
    $(CXX) $(CXXFLAGS) $(C_INC) -T$(LDFILE) $(LFLAGS) -o $@
    $(TOOLCHAIN)-objcopy -O binary $@ $(basename $@).bin

# Compile from cpp files. Compilation works when this is removed (and toolchain and files are tweaked to represent that)
out/$(PLATFORM_MCU)/obj/%.o: %.cpp
    @mkdir -p $(dir $@)
    $(CXX) $(CXXFLAGS) $(C_INC) -o $@ -c $<

-include $(DEP_CXX)

# Create binary from c files
out/$(PLATFORM_MCU)/obj/%.o: %.c
    @mkdir -p $(dir $@)
    $(CC) $(CFLAGS) $(C_INC) -o $@ -c $<

-include $(DEP_C)

.PRECIOUS: $(PRECIOUS)


.PHONY: all clean


clean:
    rm -rf $(CLEAN)

После запуска make -e PLATFORM=test ошибок много, и в первую очередь утверждается, что различные функции в исходном коде c не определены.Сейчас main.cpp не намного больше, чем int main() и включает в заголовочный файл, который включает большинство других заголовочных файлов C.

Вот пример одной из ошибок компилятора:

hal/atsamg55/sam/drivers/usart/usart.h:333:47: error: 'p_usart' was not declared in this scope
 uint32_t usart_get_writeprotect_status(Usart *p_usart);

Вот main.cpp

#include "headers.h"

int main(){   

  while(1)
  {

  }

  return 0;
}

Еще раз, спасибо за любую помощь, которую вы можете предоставить.

1 Ответ

0 голосов
/ 13 июня 2018

Спасибо за помощь, я думаю, что смог решить проблему и хочу опубликовать ее здесь на случай, если она кому-нибудь поможет в будущем.Ошибки в отношении всех файлов C произошли из-за моей неправильной передачи определений из CFLAGS в флаги CXX.После того как я добавил флаги, связанные с -DBOARD = TEST, мои заголовочные файлы смогли распознать используемую мной доску, что позволило ей проходить через цепочку «включений».

...