#
# (C) Copyright 2000-2006
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
#
# See file CREDITS for list of people who contributed to this
# project.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; either version 2 of
# the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
# MA 02111-1307 USA
#

include $(TOPDIR)/config.mk

ELF-$(ARCH)  :=
ELF-$(BOARD) :=
ELF-$(CPU)   :=

#isp_calib
ELF-y		 += isp_calib

ELF-$(CONFIG_SMC91111)           += smc91111_eeprom
ELF-$(CONFIG_SMC911X)            += smc911x_eeprom
ELF-$(CONFIG_SPI_FLASH_ATMEL)    += atmel_df_pow2
ELF-i386                         += 82559_eeprom
ELF-mpc5xxx                      += interrupt
ELF-mpc8xx                       += test_burst timer
ELF-mpc8260                      += mem_to_mem_idma2intr
ELF-ppc                          += sched
ELF-oxc                          += eepro100_eeprom

#
# Some versions of make do not handle trailing white spaces properly;
# leading to build failures. The problem was found with GNU Make 3.80.
# Using 'strip' as a workaround for the problem.
#
ELF := $(strip $(ELF-y) $(ELF-$(ARCH)) $(ELF-$(BOARD)) $(ELF-$(CPU)))

SREC = $(addsuffix .srec,$(ELF))
BIN  = $(addsuffix .bin,$(ELF))

COBJS	:= $(ELF:=.o)

LIB	= $(obj)libstubs.a

LIBAOBJS-$(ARCH)     :=
LIBAOBJS-$(CPU)      :=
LIBAOBJS-ppc         += $(ARCH)_longjmp.o $(ARCH)_setjmp.o
LIBAOBJS-mpc8xx      += test_burst_lib.o
LIBAOBJS := $(LIBAOBJS-$(ARCH)) $(LIBAOBJS-$(CPU))

LIBCOBJS += ../stubs.o

#######################################
#isp_calib
#######################################
pxHAL := ./sdk/hal
pxMDW := ./sdk/middleware
pxAPI := ./sdk/api
pxAPP := ./app
pxLIB := ./lib
pxINC := ./inc
pxAPPINC := ./app

include ./scripts/flist_sdk.inc
include ./scripts/flist_app.inc
include ./scripts/flist_lib.inc

######################################
#isp_calib source file
######################################
ISPC_SRCS =
ISPC_SRCS += ./calib_main.c
ISPC_SRCS += $(SDK_SRCS)
ISPC_SRCS += $(APP_SRCS)
ISPC_SRCS += $(LIB_SRCS)

LIBCOBJS += $(ISPC_SRCS:.c=.o)

LIBOBJS	= $(addprefix $(obj),$(LIBAOBJS) $(LIBCOBJS))

SRCS	:= $(COBJS:.o=.c) $(LIBCOBJS:.o=.c) $(LIBAOBJS:.o=.S)
OBJS	:= $(addprefix $(obj),$(COBJS))
ELF	:= $(addprefix $(obj),$(ELF))
BIN	:= $(addprefix $(obj),$(BIN))
SREC	:= $(addprefix $(obj),$(SREC))

gcclibdir := $(shell dirname `$(CC) -print-libgcc-file-name`)

CPPFLAGS += -I..
#isp_uboot_calib
EXTRA_CFLAGS += -I./
EXTRA_CFLAGS += -I$(pxINC)
EXTRA_CFLAGS += -I$(pxINC)/app
EXTRA_CFLAGS += -I$(pxINC)/lib
EXTRA_CFLAGS += -I$(pxINC)/sdk
EXTRA_CFLAGS += -I$(pxAPPINC)/include
EXTRA_CFLAGS += -I$(pxAPPINC)/applens/include

#--- Release Version 
EXTRA_CFLAGS += -DFORMAL_RELEASE
EXTRA_CFLAGS += -DR_VER_AA=$(FWVER_AA)
EXTRA_CFLAGS += -DR_VER_B=$(FWVER_B)
EXTRA_CFLAGS += -DR_VER_C=$(FWVER_C)
EXTRA_CFLAGS += -DR_VER_XX=$(FWVER_XX)
EXTRA_CFLAGS += -DR_VER_YY=$(FWVER_YY)

EXTRA_CFLAGS += -DP_VER_C=$(PROFVER_C)
EXTRA_CFLAGS += -DP_VER_XX=$(PROFVER_XX)
EXTRA_CFLAGS += -DP_VER_YY=$(PROFVER_YY)

#--- Code/Date Version 
EXTRA_CFLAGS	+= -DMK_YEAR=$(shell echo `date +'%-Y'`)
EXTRA_CFLAGS	+= -DMK_MONTH=$(shell echo `date +'%-m'`)
EXTRA_CFLAGS	+= -DMK_DAY=$(shell echo `date +'%-d'`)
EXTRA_CFLAGS	+= -DMK_HH=$(shell echo `date +'%-H'`)
EXTRA_CFLAGS	+= -DMK_MM=$(shell echo `date +'%-M'`)
EXTRA_CFLAGS	+= -DMK_SS=$(shell echo `date +'%-S'`)
EXTRA_CFLAGS	+= -DVER_MAJOR=$(B_VER_MAJOR)
EXTRA_CFLAGS	+= -DVER_MINOR=$(B_VER_MINOR)

CFLAGS += $(EXTRA_CFLAGS)
HOSTCFLAGS += $(EXTRA_CFLAGS)
CPPFLAGS += $(EXTRA_CFLAGS)


# For PowerPC there's no need to compile standalone applications as a
# relocatable executable.  The relocation data is not needed, and
# also causes the entry point of the standalone application to be
# inconsistent.
ifeq ($(ARCH),powerpc)
AFLAGS := $(filter-out $(RELFLAGS),$(AFLAGS))
CFLAGS := $(filter-out $(RELFLAGS),$(CFLAGS))
CPPFLAGS := $(filter-out $(RELFLAGS),$(CPPFLAGS))
endif

all:	$(obj).depend $(OBJS) $(LIB) $(SREC) $(BIN) $(ELF)

clean:
	rm -f $(OBJS) $(SREC) $(BIN) $(ELF)


#########################################################################
$(LIB):	$(obj).depend $(LIBOBJS)
		$(AR) $(ARFLAGS) $@ $(LIBOBJS)

$(ELF):
$(obj)%:	$(obj)%.o $(LIB)
		$(LD) -g -Ttext $(STANDALONE_LOAD_ADDR) \
			-o $@ -e $(SYM_PREFIX)$(notdir $(<:.o=)) $< $(LIB) \
			-L$(gcclibdir) -lgcc

$(SREC):
$(obj)%.srec:	$(obj)%
		$(OBJCOPY) -O srec $< $@ 2>/dev/null

$(BIN):
$(obj)%.bin:	$(obj)%
		$(OBJCOPY) -O binary $< $@ 2>/dev/null

#########################################################################

# defines $(obj).depend target
include $(SRCTREE)/rules.mk

sinclude $(obj).depend

#########################################################################
