Files
2024-09-28 14:24:04 +08:00

65 lines
1.6 KiB
Makefile
Executable File

# OUTPUT type
# 1 - .out
# 2 - .a
# 3 - .so
OUTPUT_TYPE = 1
OUTPUT_NAME = rawdata
SUB_DIRS = $(TOPDIR)/common/os_shim/dtestos
ADD_INCLUDE += $(TOPDIR)/inc/io_lib $(TOPDIR)/plc/inc $(TOPDIR)/plc/halphy/inc $(TOPDIR)/inc/os_shim \
$(TOPDIR)/common/compiler/gcc/inc $(TOPDIR)/plc/halmac/inc $(TOPDIR)/inc/utils $(TOPDIR)/plc/halmac/hw/inc/desc \
$(TOPDIR)/plc/halmac/hw/inc/reg $(TOPDIR)/plc/halmac/hw/inc $(TOPDIR)/plc/halphy/hw/inc $(TOPDIR)/inc/driver \
$(TOPDIR)/driver/inc
# predefined macro
PRE_MARCO +=
ADD_LIBDIR += $(TOPDIR)/common/utils $(TOPDIR)/plc/halphy \
$(TOPDIR)/plc/halmac/hw $(TOPDIR)/startup/riscv \
$(TOPDIR)/startup/cm3 $(TOPDIR)/plc/halmac
# becareful the seq of LIBs
ADD_LIB += halphy halmac
LD_SCRIPT = link_rawdata.lds
ifeq ($(gcc),arm)
OBJDUMP = arm-none-eabi-objdump
ADD_INCLUDE += $(TOPDIR)/os/inc/cm3
ADD_LIB += cm3
else
OBJDUMP = riscv32-unknown-elf-objdump
ADD_INCLUDE += $(TOPDIR)/os/inc/riscv
ADD_LIB += riscv
endif
# iot_printf
ADD_LIBDIR += $(TOPDIR)/driver $(TOPDIR)/common/io_lib $(TOPDIR)/common $(TOPDIR)/os
ADD_LIB += driver io_lib
#####################################################
ifdef TOPDIR
include $(TOPDIR)/build/makefile.cfg
else
include $(CURDIR)/build/makefile.cfg
TOPDIR = $(CURDIR)
export TOPDIR
endif
dump:
$(OBJDUMP) -D -S -l $(OUTPUT_FULL_NAME) > $(OUTPUT_FULL_NAME).dump
# display the obj files and output name
debug:
@echo TOPDIR=$(TOPDIR)
@echo OUTPUT_LIB=$(OUTPUT_FULL_NAME)
@echo DEPS=$(DEPS)
@echo OBJECTS=$(OBJECTS)
@echo SRCS=$(SRCS)
@echo OBJECTS folder=$(foreach dirname, $(SUB_DIRS), $(addprefix $(BIN_DIR)/, $(dirname)))
@echo output_name=$(OUTPUT_FULL_NAME)