OpenCores
URL https://opencores.org/ocsvn/w11/w11/trunk

Subversion Repositories w11

[/] [w11/] [tags/] [w11a_V0.61/] [tools/] [fx2/] [src/] [Makefile] - Diff between revs 17 and 26

Only display areas with differences | Details | Blame | View Log

Rev 17 Rev 26
# $Id: Makefile 461 2012-04-09 21:17:54Z mueller $
# $Id: Makefile 461 2012-04-09 21:17:54Z mueller $
#
#
# Copyright 2011-2012 by Walter F.J. Mueller 
# Copyright 2011-2012 by Walter F.J. Mueller 
# Code was forked from ixo-jtag.svn.sourceforge.net on 2011-07-17
# Code was forked from ixo-jtag.svn.sourceforge.net on 2011-07-17
#
#
# - original copyright and licence disclaimer --------------------------------
# - original copyright and licence disclaimer --------------------------------
# - Copyright 2007 Kolja Waschk, ixo.de
# - Copyright 2007 Kolja Waschk, ixo.de
# - This code is part of usbjtag. usbjtag is free software;
# - This code is part of usbjtag. usbjtag is free software;
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
#
#
# This program is free software; you may redistribute and/or modify it under
# This program is free software; you may redistribute and/or modify it under
# the terms of the GNU General Public License as published by the Free
# the terms of the GNU General Public License as published by the Free
# Software Foundation, either version 2, or at your option any later version.
# Software Foundation, either version 2, or at your option any later version.
#
#
# This program is distributed in the hope that it will be useful, but
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
# WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
# or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
# or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
# for complete details.
# for complete details.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
#
#
# Makefile for FX2 Firmware on Digilent Nexys2, Nexys3, and Atlys boards
# Makefile for FX2 Firmware on Digilent Nexys2, Nexys3, and Atlys boards
#
#
#  Revision History:
#  Revision History:
# Date         Rev Version  Comment
# Date         Rev Version  Comment
# 2012-04-09   461   1.5.1  fixed nexys3_jtag_3fifo_ic.ihx rule,used _2fifo code
# 2012-04-09   461   1.5.1  fixed nexys3_jtag_3fifo_ic.ihx rule,used _2fifo code
# 2012-02-11   457   1.5    re-organize VID/PID and descriptor handling
# 2012-02-11   457   1.5    re-organize VID/PID and descriptor handling
# 2012-01-02   448   1.4    add support for sync fifo w/ int. clock (_ic)
# 2012-01-02   448   1.4    add support for sync fifo w/ int. clock (_ic)
# 2011-12-29   446   1.3    add nexys3 support
# 2011-12-29   446   1.3    add nexys3 support
# 2011-07-23   397   1.2    add usb_fifo_init.c
# 2011-07-23   397   1.2    add usb_fifo_init.c
# 2011-07-17   395   1.1    reorganized to support multiple target/fifo configs
# 2011-07-17   395   1.1    reorganized to support multiple target/fifo configs
# 2011-07-17   394   1.0    Initial version (from ixo-jtag/usb_jtag Rev 204)
# 2011-07-17   394   1.0    Initial version (from ixo-jtag/usb_jtag Rev 204)
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
#
#
# handle USB VID/PID
# handle USB VID/PID
# - normaly given via the environment variables (as 4 digit hex number)
# - normaly given via the environment variables (as 4 digit hex number)
#     RETRO_FX2_VID
#     RETRO_FX2_VID
#     RETRO_FX2_PID
#     RETRO_FX2_PID
#
#
# - in the retro11 project the default is:
# - in the retro11 project the default is:
#     VID: 16c0  (VOTI)
#     VID: 16c0  (VOTI)
#     PID: 03ef  (VOTI free for internal lab use 1007)
#     PID: 03ef  (VOTI free for internal lab use 1007)
#
#
#   !! Important Note on Usage of this USB VID/PID !!
#   !! Important Note on Usage of this USB VID/PID !!
#   This VID/PID is owned by VOTI, a small dutch company. Usage is granted
#   This VID/PID is owned by VOTI, a small dutch company. Usage is granted
#   for 'internal lab use only' by VOTI under the conditions:
#   for 'internal lab use only' by VOTI under the conditions:
#     - the gadgets in which you use those PIDs do not leave your desk
#     - the gadgets in which you use those PIDs do not leave your desk
#     - you won't complain to VOTI if you get in trouble with duplicate PIDs
#     - you won't complain to VOTI if you get in trouble with duplicate PIDs
#       (for instance because someone else did not follow the previous rule).
#       (for instance because someone else did not follow the previous rule).
#   See also http://www.voti.nl/pids/pidfaq.html
#   See also http://www.voti.nl/pids/pidfaq.html
#
#
ifndef RETRO_FX2_VID
ifndef RETRO_FX2_VID
RETRO_FX2_VID = 16c0
RETRO_FX2_VID = 16c0
endif
endif
ifndef RETRO_FX2_PID
ifndef RETRO_FX2_PID
RETRO_FX2_PID = 03ef
RETRO_FX2_PID = 03ef
endif
endif
#
#
DEFVIDPID=-DUSE_VID=0x${RETRO_FX2_VID} -DUSE_PID=0x${RETRO_FX2_PID}
DEFVIDPID=-DUSE_VID=0x${RETRO_FX2_VID} -DUSE_PID=0x${RETRO_FX2_PID}
#
#
# compiler and assembler flags
# compiler and assembler flags
#
#
LIBDIR=lib
LIBDIR=lib
LIB=libfx2.lib
LIB=libfx2.lib
CC=sdcc
CC=sdcc
CFLAGS+=-mmcs51 --no-xinit-opt -I${LIBDIR}
CFLAGS+=-mmcs51 --no-xinit-opt -I${LIBDIR}
AS=asx8051
AS=asx8051
ASFLAGS+=-plosgff
ASFLAGS+=-plosgff
LDFLAGS=--code-loc 0x0000 --code-size 0x1800
LDFLAGS=--code-loc 0x0000 --code-size 0x1800
LDFLAGS+=--xram-loc 0x1800 --xram-size 0x0800
LDFLAGS+=--xram-loc 0x1800 --xram-size 0x0800
LDFLAGS+=-Wl '-b USBDESCSEG = 0xE100'
LDFLAGS+=-Wl '-b USBDESCSEG = 0xE100'
LDFLAGS+=-L ${LIBDIR}
LDFLAGS+=-L ${LIBDIR}
#
#
# compile rules
# compile rules
#
#
%.rel : %.a51
%.rel : %.a51
        $(AS) $(ASFLAGS) $<
        $(AS) $(ASFLAGS) $<
%.rel : %.c
%.rel : %.c
        $(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@
        $(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@
#
#
# link rule
# link rule
#
#
%.ihx :
%.ihx :
        $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $+
        $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $+
#
#
# primary target rules
# primary target rules
#
#
ALLIHX  =nexys2_jtag.ihx
ALLIHX  =nexys2_jtag.ihx
ALLIHX +=nexys2_jtag_2fifo_as.ihx
ALLIHX +=nexys2_jtag_2fifo_as.ihx
ALLIHX +=nexys2_jtag_3fifo_as.ihx
ALLIHX +=nexys2_jtag_3fifo_as.ihx
ALLIHX +=nexys2_jtag_2fifo_ic.ihx
ALLIHX +=nexys2_jtag_2fifo_ic.ihx
ALLIHX +=nexys2_jtag_3fifo_ic.ihx
ALLIHX +=nexys2_jtag_3fifo_ic.ihx
ALLIHX +=nexys3_jtag.ihx
ALLIHX +=nexys3_jtag.ihx
ALLIHX +=nexys3_jtag_2fifo_as.ihx
ALLIHX +=nexys3_jtag_2fifo_as.ihx
ALLIHX +=nexys3_jtag_3fifo_as.ihx
ALLIHX +=nexys3_jtag_3fifo_as.ihx
ALLIHX +=nexys3_jtag_2fifo_ic.ihx
ALLIHX +=nexys3_jtag_2fifo_ic.ihx
ALLIHX +=nexys3_jtag_3fifo_ic.ihx
ALLIHX +=nexys3_jtag_3fifo_ic.ihx
.PHONY: all install
.PHONY: all install
all: $(ALLIHX)
all: $(ALLIHX)
install: $(ALLIHX)
install: $(ALLIHX)
        cp -p $(ALLIHX) ../bin
        cp -p $(ALLIHX) ../bin
#
#
# rules to create USB descriptor sources
# rules to create USB descriptor sources
#
#
CPPA51=cpp -P -x assembler-with-cpp
CPPA51=cpp -P -x assembler-with-cpp
dscr_nexys2_jtag.a51 : dscr_gen.A51
dscr_nexys2_jtag.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 $< > $@
dscr_nexys2_jtag_2fifo_as.a51 : dscr_gen.A51
dscr_nexys2_jtag_2fifo_as.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_2FIFO -DUSE_AS $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_2FIFO -DUSE_AS $< > $@
dscr_nexys2_jtag_3fifo_as.a51 : dscr_gen.A51
dscr_nexys2_jtag_3fifo_as.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_3FIFO -DUSE_AS $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_3FIFO -DUSE_AS $< > $@
dscr_nexys2_jtag_2fifo_ic.a51 : dscr_gen.A51
dscr_nexys2_jtag_2fifo_ic.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_2FIFO -DUSE_IC $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_2FIFO -DUSE_IC $< > $@
dscr_nexys2_jtag_3fifo_ic.a51 : dscr_gen.A51
dscr_nexys2_jtag_3fifo_ic.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_3FIFO -DUSE_IC $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS2 -DUSE_3FIFO -DUSE_IC $< > $@
dscr_nexys3_jtag.a51 : dscr_gen.A51
dscr_nexys3_jtag.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 $< > $@
dscr_nexys3_jtag_2fifo_as.a51 : dscr_gen.A51
dscr_nexys3_jtag_2fifo_as.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_2FIFO -DUSE_AS $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_2FIFO -DUSE_AS $< > $@
dscr_nexys3_jtag_3fifo_as.a51 : dscr_gen.A51
dscr_nexys3_jtag_3fifo_as.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_3FIFO -DUSE_AS $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_3FIFO -DUSE_AS $< > $@
dscr_nexys3_jtag_2fifo_ic.a51 : dscr_gen.A51
dscr_nexys3_jtag_2fifo_ic.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_2FIFO -DUSE_IC $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_2FIFO -DUSE_IC $< > $@
dscr_nexys3_jtag_3fifo_ic.a51 : dscr_gen.A51
dscr_nexys3_jtag_3fifo_ic.a51 : dscr_gen.A51
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_3FIFO -DUSE_IC $< > $@
        $(CPPA51) $(DEFVIDPID) -DUSE_NEXYS3 -DUSE_3FIFO -DUSE_IC $< > $@
#
#
# rules to create usb_fifo_init variants
# rules to create usb_fifo_init variants
#
#
usb_fifo_init_jtag.rel : usb_fifo_init.c
usb_fifo_init_jtag.rel : usb_fifo_init.c
        $(CC) -c $(CFLAGS)  $< -o $@
        $(CC) -c $(CFLAGS)  $< -o $@
#
#
usb_fifo_init_jtag_2fifo_as.rel : usb_fifo_init.c
usb_fifo_init_jtag_2fifo_as.rel : usb_fifo_init.c
        $(CC) -c $(CFLAGS) -DUSE_2FIFO $< -o $@
        $(CC) -c $(CFLAGS) -DUSE_2FIFO $< -o $@
usb_fifo_init_jtag_3fifo_as.rel : usb_fifo_init.c
usb_fifo_init_jtag_3fifo_as.rel : usb_fifo_init.c
        $(CC) -c $(CFLAGS) -DUSE_3FIFO $< -o $@
        $(CC) -c $(CFLAGS) -DUSE_3FIFO $< -o $@
#
#
usb_fifo_init_jtag_2fifo_ic.rel : usb_fifo_init.c
usb_fifo_init_jtag_2fifo_ic.rel : usb_fifo_init.c
        $(CC) -c $(CFLAGS) -DUSE_2FIFO -DUSE_IC30 $< -o $@
        $(CC) -c $(CFLAGS) -DUSE_2FIFO -DUSE_IC30 $< -o $@
usb_fifo_init_jtag_3fifo_ic.rel : usb_fifo_init.c
usb_fifo_init_jtag_3fifo_ic.rel : usb_fifo_init.c
        $(CC) -c $(CFLAGS) -DUSE_3FIFO -DUSE_IC30 $< -o $@
        $(CC) -c $(CFLAGS) -DUSE_3FIFO -DUSE_IC30 $< -o $@
#
#
COM_REL=vectors.rel main.rel eeprom.rel startup.rel
COM_REL=vectors.rel main.rel eeprom.rel startup.rel
#
#
I0_REL=usb_fifo_init_jtag.rel
I0_REL=usb_fifo_init_jtag.rel
#
#
IAS2_REL=usb_fifo_init_jtag_2fifo_as.rel
IAS2_REL=usb_fifo_init_jtag_2fifo_as.rel
IAS3_REL=usb_fifo_init_jtag_3fifo_as.rel
IAS3_REL=usb_fifo_init_jtag_3fifo_as.rel
#
#
IIC2_REL=usb_fifo_init_jtag_2fifo_ic.rel
IIC2_REL=usb_fifo_init_jtag_2fifo_ic.rel
IIC3_REL=usb_fifo_init_jtag_3fifo_ic.rel
IIC3_REL=usb_fifo_init_jtag_3fifo_ic.rel
#
#
N2_REL=hw_nexys2.rel
N2_REL=hw_nexys2.rel
N3_REL=hw_nexys3.rel
N3_REL=hw_nexys3.rel
#
#
LIB_REL=$(LIBDIR)/$(LIB)
LIB_REL=$(LIBDIR)/$(LIB)
#
#
# rules to compile all code
# rules to compile all code
#
#
$(LIBDIR)/$(LIB) :
$(LIBDIR)/$(LIB) :
        make -C $(LIBDIR)
        make -C $(LIBDIR)
eeprom.rel : eeprom.c eeprom.h
eeprom.rel : eeprom.c eeprom.h
main.rel : main.c hardware.h eeprom.h
main.rel : main.c hardware.h eeprom.h
$(N2_REL) : hw_nexys2.c hardware.h
$(N2_REL) : hw_nexys2.c hardware.h
$(N3_REL) : hw_nexys3.c hardware.h
$(N3_REL) : hw_nexys3.c hardware.h
#
#
# rules to build Nexys2 firmware images
# rules to build Nexys2 firmware images
#
#
nexys2_jtag.ihx :          $(COM_REL) dscr_nexys2_jtag.rel \
nexys2_jtag.ihx :          $(COM_REL) dscr_nexys2_jtag.rel \
                                $(N2_REL) $(I0_REL)   $(LIB_REL)
                                $(N2_REL) $(I0_REL)   $(LIB_REL)
#
#
nexys2_jtag_2fifo_as.ihx : $(COM_REL) dscr_nexys2_jtag_2fifo_as.rel \
nexys2_jtag_2fifo_as.ihx : $(COM_REL) dscr_nexys2_jtag_2fifo_as.rel \
                                $(N2_REL) $(IAS2_REL) $(LIB_REL)
                                $(N2_REL) $(IAS2_REL) $(LIB_REL)
nexys2_jtag_3fifo_as.ihx : $(COM_REL) dscr_nexys2_jtag_3fifo_as.rel \
nexys2_jtag_3fifo_as.ihx : $(COM_REL) dscr_nexys2_jtag_3fifo_as.rel \
                                $(N2_REL) $(IAS3_REL) $(LIB_REL)
                                $(N2_REL) $(IAS3_REL) $(LIB_REL)
#
#
nexys2_jtag_2fifo_ic.ihx : $(COM_REL) dscr_nexys2_jtag_2fifo_ic.rel \
nexys2_jtag_2fifo_ic.ihx : $(COM_REL) dscr_nexys2_jtag_2fifo_ic.rel \
                                $(N2_REL) $(IIC2_REL) $(LIB_REL)
                                $(N2_REL) $(IIC2_REL) $(LIB_REL)
nexys2_jtag_3fifo_ic.ihx : $(COM_REL) dscr_nexys2_jtag_3fifo_ic.rel \
nexys2_jtag_3fifo_ic.ihx : $(COM_REL) dscr_nexys2_jtag_3fifo_ic.rel \
                                $(N2_REL) $(IIC3_REL) $(LIB_REL)
                                $(N2_REL) $(IIC3_REL) $(LIB_REL)
#
#
# rules to build Nexys3 firmware images
# rules to build Nexys3 firmware images
#
#
nexys3_jtag.ihx :          $(COM_REL) dscr_nexys3_jtag.rel \
nexys3_jtag.ihx :          $(COM_REL) dscr_nexys3_jtag.rel \
                                $(N3_REL) $(I0_REL)   $(LIB_REL)
                                $(N3_REL) $(I0_REL)   $(LIB_REL)
#
#
nexys3_jtag_2fifo_as.ihx : $(COM_REL) dscr_nexys3_jtag_2fifo_as.rel \
nexys3_jtag_2fifo_as.ihx : $(COM_REL) dscr_nexys3_jtag_2fifo_as.rel \
                                $(N3_REL) $(IAS2_REL) $(LIB_REL)
                                $(N3_REL) $(IAS2_REL) $(LIB_REL)
nexys3_jtag_3fifo_as.ihx : $(COM_REL) dscr_nexys3_jtag_3fifo_as.rel \
nexys3_jtag_3fifo_as.ihx : $(COM_REL) dscr_nexys3_jtag_3fifo_as.rel \
                                $(N3_REL) $(IAS3_REL) $(LIB_REL)
                                $(N3_REL) $(IAS3_REL) $(LIB_REL)
#
#
nexys3_jtag_2fifo_ic.ihx : $(COM_REL) dscr_nexys3_jtag_2fifo_ic.rel \
nexys3_jtag_2fifo_ic.ihx : $(COM_REL) dscr_nexys3_jtag_2fifo_ic.rel \
                                $(N3_REL) $(IIC2_REL) $(LIB_REL)
                                $(N3_REL) $(IIC2_REL) $(LIB_REL)
nexys3_jtag_3fifo_ic.ihx : $(COM_REL) dscr_nexys3_jtag_3fifo_ic.rel \
nexys3_jtag_3fifo_ic.ihx : $(COM_REL) dscr_nexys3_jtag_3fifo_ic.rel \
                                $(N3_REL) $(IIC3_REL) $(LIB_REL)
                                $(N3_REL) $(IIC3_REL) $(LIB_REL)
#
#
# cleanup phony's
# cleanup phony's
#
#
.PHONY : clean distclean
.PHONY : clean distclean
clean :
clean :
        make -C ${LIBDIR} clean
        make -C ${LIBDIR} clean
        rm -f *.lst *.asm *.lib *.sym *.rel *.mem *.map *.rst *.lnk
        rm -f *.lst *.asm *.lib *.sym *.rel *.mem *.map *.rst *.lnk
        rm -f dscr_*.a51
        rm -f dscr_*.a51
distclean : clean
distclean : clean
        rm -f *.ihx
        rm -f *.ihx
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.