rtl_ameba_gcc_sample/Makefile

116 lines
3.8 KiB
Makefile
Raw Normal View History

2016-06-22 14:08:09 +00:00
.SUFFIXES: .o .a .c .s
DEV_NUL=/dev/null
CHIP=ameba
RM=rm -f
CROSS_COMPILE = arm-none-eabi-
AR = $(CROSS_COMPILE)ar
CC = $(CROSS_COMPILE)gcc
2016-07-02 21:54:53 +00:00
CPP = $(CROSS_COMPILE)g++
2016-06-22 14:08:09 +00:00
AS = $(CROSS_COMPILE)as
NM = $(CROSS_COMPILE)nm
SIZE = $(CROSS_COMPILE)size
SDK_SRC_BASE_PATH = sdk/src
vpath %.c ./src
vpath %.c $(SDK_SRC_BASE_PATH)/targets/hal/target_rtk/target_8195a
2016-06-22 14:08:09 +00:00
vpath %.c $(SDK_SRC_BASE_PATH)/targets/cmsis/target_rtk/target_8195a
2016-07-03 10:32:28 +00:00
vpath %.cc ./src
2016-06-22 14:08:09 +00:00
INCLUDES += -I$(SDK_SRC_BASE_PATH)/targets/cmsis
INCLUDES += -I$(SDK_SRC_BASE_PATH)/targets/cmsis/target_rtk/target_8195a
INCLUDES += -I$(SDK_SRC_BASE_PATH)/targets/hal/target_rtk/target_8195a
INCLUDES += -I$(SDK_SRC_BASE_PATH)/targets/hal/target_rtk/target_8195a/rtl8195a
INCLUDES += -I$(SDK_SRC_BASE_PATH)/sw/lib/sw_lib/mbed/hal
INCLUDES += -I$(SDK_SRC_BASE_PATH)/sw/lib/sw_lib/mbed/targets/hal/rtl8195a/
2016-06-22 14:08:09 +00:00
INCLUDES += -I$(SDK_SRC_BASE_PATH)/sw/os
OUTPUT_PATH=build
CFLAGS = -g -mcpu=cortex-m3
CFLAGS += -mthumb
CFLAGS += -c -nostartfiles -fno-short-enums
CFLAGS += -Wall -Wpointer-arith -Wstrict-prototypes -Wundef
CFLAGS += -Wno-write-strings
CFLAGS += -MMD -MP
CFLAGS += -fno-common -fmessage-length=0 -fno-exceptions
CFLAGS += -ffunction-sections -fdata-sections
CFLAGS += -fomit-frame-pointer
CFLAGS += -std=gnu99
CFLAGS += -O2 $(INCLUDES) -D$(CHIP)
2016-07-02 21:54:53 +00:00
CPPFLAGS = -g -mcpu=cortex-m3
CPPFLAGS += -mthumb
CPPFLAGS += -c -nostartfiles -fno-short-enums
CPPFLAGS += -Wall -Wpointer-arith -Wundef
CPPFLAGS += -Wno-write-strings
CPPFLAGS += -MMD -MP
CPPFLAGS += -fno-common -fmessage-length=0 -fno-exceptions
CPPFLAGS += -ffunction-sections -fdata-sections
CPPFLAGS += -fomit-frame-pointer
CPPFLAGS += -O2 $(INCLUDES) -D$(CHIP)
2016-06-22 14:08:09 +00:00
ASFLAGS = -mcpu=cortex-m3 -mthumb -Wall -a -g $(INCLUDES)
ifeq ($(SDRAM), true)
else
C_SRC+=$(wildcard $(SDK_SRC_BASE_PATH)/targets/hal/target_rtk/target_8195a/hal_sdr_controller.c)
endif
2016-06-22 14:08:09 +00:00
C_SRC+=$(wildcard $(SDK_SRC_BASE_PATH)/targets/cmsis/target_rtk/target_8195a/app_start.c)
C_SRC+=$(wildcard src/*.c)
2016-07-03 10:32:28 +00:00
CPP_SRC=$(wildcard src/*.cc)
2016-06-22 14:08:09 +00:00
C_OBJ_TEMP=$(patsubst %.c, %.o, $(notdir $(C_SRC)))
2016-07-03 10:32:28 +00:00
CPP_OBJ_TEMP=$(patsubst %.cc, %.o, $(notdir $(CPP_SRC)))
2016-06-22 14:08:09 +00:00
# during development, remove some files
C_OBJ_FILTER=
2016-07-02 21:54:53 +00:00
CPP_OBJ_FILTER=
2016-06-22 14:08:09 +00:00
C_OBJ=$(filter-out $(C_OBJ_FILTER), $(C_OBJ_TEMP))
2016-07-02 21:54:53 +00:00
CPP_OBJ=$(filter-out $(CPP_OBJ_FILTER), $(CPP_OBJ_TEMP))
2016-06-22 14:08:09 +00:00
ELF_FLAGS= -O2 -Wl,--gc-sections -mcpu=cortex-m3 -mthumb --specs=nano.specs
2016-06-24 02:45:22 +00:00
ELF_FLAGS+= -Lsdk/lib -Lsdk/scripts -Tsdk/scripts/rlx8195a.ld -Wl,-Map=$(OUTPUT_PATH)/target.map
2016-06-26 06:21:28 +00:00
ELF_FLAGS+= -Wl,--cref -Wl,--gc-sections -Wl,--entry=Reset_Handler -Wl,--unresolved-symbols=report-all -Wl,--warn-common -Wl,--no-enum-size-warning
2016-06-22 14:08:09 +00:00
ifeq ($(SDRAM), true)
ELF_LDLIBS= sdk/lib/startup.o sdk/lib/hal_sdr_controller.o -l_platform -lstdc++ -lsupc++ -lm -lc -lgcc -lnosys
else
2016-06-22 14:08:09 +00:00
ELF_LDLIBS= sdk/lib/startup.o -l_platform -lstdc++ -lsupc++ -lm -lc -lgcc -lnosys
endif
2016-06-22 14:08:09 +00:00
all: makebin/ram_all.bin
makebin/ram_all.bin: $(OUTPUT_PATH)/target.axf
cd ./makebin && /bin/bash ./makebin.sh
2016-07-02 21:54:53 +00:00
$(OUTPUT_PATH)/target.axf: $(addprefix $(OUTPUT_PATH)/,$(C_OBJ)) $(addprefix $(OUTPUT_PATH)/,$(CPP_OBJ))
2016-06-22 14:08:09 +00:00
echo build all objects
$(CC) $(ELF_FLAGS) -o $(OUTPUT_PATH)/target.axf -Wl,--start-group $^ -Wl,--end-group $(ELF_LDLIBS)
$(SIZE) $(OUTPUT_PATH)/target.axf
2016-06-22 14:08:09 +00:00
$(addprefix $(OUTPUT_PATH)/,$(C_OBJ)): $(OUTPUT_PATH)/%.o: %.c
@echo "$(CC) -c $(CFLAGS) $< -o $@"
@"$(CC)" -c $(CFLAGS) $< -o $@
2016-07-03 10:32:28 +00:00
$(addprefix $(OUTPUT_PATH)/,$(CPP_OBJ)): $(OUTPUT_PATH)/%.o: %.cc
2016-07-02 21:54:53 +00:00
@echo "$(CPP) -c $(CPPFLAGS) $< -o $@"
@"$(CPP)" -c $(CPPFLAGS) $< -o $@
2016-06-22 14:08:09 +00:00
clean:
@echo clean
2016-06-24 02:45:22 +00:00
-@$(RM) $(OUTPUT_PATH)/target.* 1>$(DEV_NUL) 2>&1
-@$(RM) $(OUTPUT_PATH)/*.d 1>$(DEV_NUL) 2>&1
-@$(RM) $(OUTPUT_PATH)/*.o 1>$(DEV_NUL) 2>&1
-@$(RM) $(OUTPUT_PATH)/*.i 1>$(DEV_NUL) 2>&1
-@$(RM) $(OUTPUT_PATH)/*.s 1>$(DEV_NUL) 2>&1
2016-06-22 14:08:09 +00:00
-@$(RM) ./makebin/target* 1>$(DEV_NUL) 2>&1
-@$(RM) ./makebin/*.bin 1>$(DEV_NUL) 2>&1