# ----------------------------------------------------------------------------
# Hyper Operating System V4 Advance
#
# Copyright (C) 1998-2008 by Project HOS
# http://sourceforge.jp/projects/hos/
# ----------------------------------------------------------------------------


# %jp{^[Qbg}
TARGET ?= sample

# %jp{c[`}
GCC_ARCH     ?= mips-elf-
CMD_CC       ?= $(GCC_ARCH)gcc
CMD_ASM      ?= $(GCC_ARCH)gcc
CMD_LINK     ?= $(GCC_ARCH)gcc
CMD_OBJCNV   ?= $(GCC_ARCH)objcopy


# %jp{fBNg}
OS_DIR            = ../../../../..
KERNEL_DIR        = $(OS_DIR)/kernel
KERNEL_CFGRTR_DIR = $(OS_DIR)/cfgrtr/build/gcc
KERNEL_MAKINC_DIR = $(KERNEL_DIR)/build/common/gmake
KERNEL_BUILD_DIR  = $(KERNEL_DIR)/build/mips/jelly/gcc
APLFW_DIR         = $(OS_DIR)/aplfw
APLFW_INC_DIR     = $(APLFW_DIR)
APLFW_BUILD_DIR   = $(APLFW_DIR)/build/mips/jelly/gcc
OBJS_DIR          = objs_$(TARGET)


# %jp{J[lݒ}
KERNEL_HOK_TSK = Yes
KERNEL_HOK_ISR = Yes


# %jp{ʒ`Ǎ}
include $(KERNEL_MAKINC_DIR)/common.inc


# %jp{RtBM[^`}
KERNEL_CFGRTR = $(KERNEL_CFGRTR_DIR)/h4acfg-jelly


# %jp{Cu`}
APLFW_LIB = $(APLFW_BUILD_DIR)/hosaplfw.a


# %jp{fobOł̒`ύX}
ifeq ($(DEBUG),Yes)
TARGET := $(TARGET)dbg
APLFW_LIB = $(APLFW_BUILD_DIR)/hosaplfwdbg.a
endif


# %jp{}bv}
ifeq ($(MEMMAP),ram)
# %jp{RAM}
TARGET       := $(TARGET)_ram
LINK_SCRIPT = ram.lds
else
# %jp{ROM}
LINK_SCRIPT = rom.lds
endif


# %jp{tOݒ}
CFLAGS  = -march=mips1 -msoft-float -G 0
AFLAGS  = -march=mips1 -msoft-float -G 0
LNFLAGS = -march=mips1 -msoft-float -G 0 -nostartfiles -Wl,-Map,$(TARGET).map,-T$(LINK_SCRIPT)


# %jp{o̓t@C}
TARGET_EXE = $(TARGET).elf
TARGET_MOT = $(TARGET).mot
TARGET_HEX = $(TARGET).hex
TARGET_BIN = $(TARGET).bin


# %jp{gccp̐ݒǍ}
include $(KERNEL_MAKINC_DIR)/gcc_d.inc


# %jp{CN[hfBNg}
INC_DIRS += $(APLFW_INC_DIR)

# %jp{\[XfBNg}
SRC_DIRS += . ..


# %jp{AZut@C̒ǉ}
ASRCS += ./crt0.S


# %jp{Ct@C̒ǉ}
CSRCS += ../kernel_cfg.c
CSRCS += ../main.c
CSRCS += ../boot.c
CSRCS += ../ostimer.c
CSRCS += memcpy.c
CSRCS += strlen.c


# %jp{Cut@C̒ǉ}
LIBS += $(APLFW_LIB) -lc



# --------------------------------------
#  %jp{[}
# --------------------------------------

.PHONY : all
all: kernel_make make_subprj makeexe_all $(TARGET_EXE) $(TARGET_MOT) $(TARGET_HEX) $(TARGET_BIN)

.PHONY : run
run: $(TARGET_BIN)
	jelly_loader -r $(TARGET_BIN)


.PHONY : make_subprj
make_subprj:
	$(MAKE) -C $(APLFW_BUILD_DIR)

.PHONY : clean
clean: makeexe_clean
	rm -f $(TARGET_EXE) $(TARGET_EXE) $(OBJS) ../kernel_cfg.c ../kernel_id.h

.PHONY : depend
depend: makeexe_depend

.PHONY : mostlyclean
mostlyclean: clean kernel_clean
	$(MAKE) -C $(APLFW_BUILD_DIR) clean

.PHONY : mostlydepend
mostlydepend: depend
	$(MAKE) -C $(APLFW_BUILD_DIR) depend


../kernel_cfg.c ../kernel_id.h: ../system.cfg
	cpp -E ../system.cfg ../system.i
	$(KERNEL_CFGRTR) ../system.i -c ../kernel_cfg.c -i ../kernel_id.h


$(TARGET_EXE): $(LINK_SCRIPT)


# %jp{CupݒǍ}
include $(KERNEL_MAKINC_DIR)/makeexe.inc

# %jp{gccp̃[`Ǎ}
include $(KERNEL_MAKINC_DIR)/gcc_r.inc



# --------------------------------------
#  %jp{ˑ֌W}
# --------------------------------------

$(OBJS_DIR)/sample.obj: ../sample.c ../kernel_id.h


# end of file
