ameba-gcc-sample-rtos/Makefile

149 lines
5.3 KiB
Makefile

.SUFFIXES: .o .a .c .s
DEV_NUL=/dev/null
RM=rm -f
CROSS_COMPILE = arm-none-eabi-
AR = $(CROSS_COMPILE)ar
CC = $(CROSS_COMPILE)gcc
AS = $(CROSS_COMPILE)as
NM = $(CROSS_COMPILE)nm
SIZE = $(CROSS_COMPILE)size
vpath %.c ./src
INCLUDES = -Isdk/component/soc/realtek/8195a/cmsis/device
INCLUDES += -Isdk/component/soc/realtek/8195a/fwlib/rtl8195a
INCLUDES += -Isdk/component/soc/realtek/8195a/fwlib
INCLUDES += -Isdk/component/soc/realtek/common/bsp
INCLUDES += -Isdk/component/soc/realtek/8195a/cmsis
INCLUDES += -Isdk/component/soc/realtek/8195a/cmsis/device
INCLUDES += -Isdk/component/os/freertos
INCLUDES += -Isdk/component/os/freertos/freertos_v8.1.2/Source/include
INCLUDES += -Isdk/component/os/freertos/freertos_v8.1.2/Source/portable/GCC/ARM_CM3
INCLUDES += -Isdk/component/common/api/wifi
INCLUDES += -Isdk/component/common/drivers/wlan/realtek/include
INCLUDES += -Isdk/component/common/drivers/wlan/realtek/src/osdep
INCLUDES += -Isdk/component/common/drivers/sdio/realtek/sdio_host/inc
INCLUDES += -Isdk/component/common/mbed/hal
INCLUDES += -Isdk/component/common/mbed/hal_ext
INCLUDES += -Isdk/component/common/mbed/targets/hal/rtl8195a
INCLUDES += -Isdk/project/realtek_ameba1_va0_example/inc
OUTPUT_PATH=build
CFLAGS = -c
CFLAGS += -g
CFLAGS += -w
CFLAGS += -mcpu=cortex-m3
CFLAGS += -mtune=cortex-m3
CFLAGS += -mthumb
CFLAGS += -O2
CFLAGS += -ansi
CFLAGS += -std=gnu99
CFLAGS += -fno-short-enums
CFLAGS += -fno-common
CFLAGS += -fmessage-length=0
CFLAGS += -Wall
CFLAGS += -fno-exceptions
CFLAGS += -ffunction-sections
CFLAGS += -fdata-sections
CFLAGS += -fomit-frame-pointer
CFLAGS += -fno-short-enums
CFLAGS += -nostdlib
CFLAGS += -Werror
CFLAGS += -Wundef
CFLAGS += -Wpointer-arith
CFLAGS += -Wstrict-prototypes
CFLAGS += -Wno-write-strings
CFLAGS += -fsingle-precision-constant
CFLAGS += -Wdouble-promotion
CFLAGS += -nostartfiles
CFLAGS += -DCONFIG_PLATFORM_8195A $(INCLUDES)
CFLAGS += $(CFLAGS_MOD)
ASFLAGS = -mcpu=cortex-m3 -mthumb -Wall -a -g $(INCLUDES)
C_SRC+=$(wildcard src/*.c)
C_OBJ_TEMP=$(patsubst %.c, %.o, $(notdir $(C_SRC)))
# during development, remove some files
C_OBJ_FILTER=
C_OBJ=$(filter-out $(C_OBJ_FILTER), $(C_OBJ_TEMP))
ELF_CFLAGS += -O2
ELF_CFLAGS += -Wl,--gc-sections
ELF_CFLAGS += -mcpu=cortex-m3
ELF_CFLAGS += -mthumb
ELF_CFLAGS += --specs=nano.specs
ELF_LDFLAGS += -Lsdk/lib -Lsdk/scripts -Tsdk/scripts/rlx8195A-symbol-v03-img2_arduino_arduino.ld
ELF_LDFLAGS += -Wl,-Map=$(OUTPUT_PATH)/target.map
ELF_LDFLAGS += -Wl,--cref
ELF_LDFLAGS += -Wl,--warn-common
ELF_LDFLAGS += -Wl,--gc-sections
ELF_LDFLAGS += -Wl,--no-enum-size-warning
ELF_LDFLAGS += -Wl,--no-wchar-size-warning
ELF_LDFLAGS += -Wl,--entry=InfraStart
ELF_LDFLAGS += -Wl,-nostdlib
ELF_ARLIST += ./sdk/lib/lib_platform.a
ELF_ARLIST += ./sdk/lib/lib_ameba.a
#ELF_ARLIST += ./sdk/lib/lib_wlan.a
#ELF_ARLIST += ./sdk/lib/lib_wlan_mp.a
#ELF_ARLIST += ./sdk/lib/lib_wps.a
#ELF_ARLIST += ./sdk/lib/lib_mdns.a
#ELF_ARLIST += ./sdk/lib/lib_rtlstd.a
#ELF_ARLIST += ./sdk/lib/lib_sdcard.a
#all: makebin/ram_all.bin
all: $(OUTPUT_PATH)/target.axf
#makebin/ram_all.bin: $(OUTPUT_PATH)/target.axf
# cd ./makebin && /bin/bash ./makebin.sh
makebin/ram_all.bin: makebin/target.map
$(eval RAM2_START_ADDR = 0x$(shell grep __ram_image2_text makebin/target.map | grep _start__ | awk '{print $$1}'))
$(eval RAM2_END_ADDR = 0x$(shell grep __ram_image2_text makebin/target.map | grep _end__ | awk '{print $$1}'))
$(eval RAM3_START_ADDR = 0x$(shell grep __sdram_data_ makebin/target.map | grep _start__ | awk '{print $$1}'))
$(eval RAM3_END_ADDR = 0x$(shell grep __sdram_data_ makebin/target.map | grep _end__ | awk '{print $$1}'))
arm-none-eabi-objcopy -j .image2.start.table -j .ram_image2.text -j .ram.data -Obinary build/target.axf makebin/ram_2.bin
arm-none-eabi-objcopy -j .image3 -j .ARM.exidx -j .sdr_data -Obinary build/target.axf makebin/sdram.bin
tools/pick $(RAM2_START_ADDR) $(RAM2_END_ADDR) makebin/ram_2.bin makebin/ram_2.p.bin body+reset_offset+sig
tools/pick $(RAM2_START_ADDR) $(RAM2_END_ADDR) makebin/ram_2.bin makebin/ram_2.ns.bin body+reset_offset
tools/pick $(RAM3_START_ADDR) $(RAM3_END_ADDR) makebin/sdram.bin makebin/ram_3.p.bin body+reset_offset
cp tools/ram_1.p.bin makebin/ram_1.p.bin
tools/padding 44k 0xFF makebin/ram_1.p.bin
cat makebin/ram_1.p.bin makebin/ram_2.p.bin makebin/ram_3.p.bin > makebin/ram_all.bin
cat makebin/ram_2.ns.bin makebin/ram_3.p.bin > makebin/ota.bin
tools/checksum makebin/ota.bin
makebin/target.map: $(OUTPUT_PATH)/target.axf
arm-none-eabi-nm $(OUTPUT_PATH)/target.axf | sort > makebin/target.map
arm-none-eabi-objdump -d $(OUTPUT_PATH)/target.axf | sort > makebin/target.asm
$(OUTPUT_PATH)/target.axf: $(addprefix $(OUTPUT_PATH)/,$(C_OBJ))
echo build all objects
$(CC) $(ELF_CFLAGS) $(ELF_LDFLAGS) -o $(OUTPUT_PATH)/target.axf -Wl,--start-group $^ -Wl,--end-group $(ELF_ARLIST) -lstdc++ -lsupc++ -lm -lc -lgcc -lnosys
$(SIZE) $(OUTPUT_PATH)/target.axf
$(addprefix $(OUTPUT_PATH)/,$(C_OBJ)): $(OUTPUT_PATH)/%.o: %.c
@echo "$(CC) -c $(CFLAGS) $< -o $@"
@"$(CC)" -c $(CFLAGS) $< -o $@
clean:
@echo clean
-@$(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
-@$(RM) ./makebin/target* 1>$(DEV_NUL) 2>&1
-@$(RM) ./makebin/*.bin 1>$(DEV_NUL) 2>&1