iverilog/vvp/Makefile.in

190 lines
5.4 KiB
Makefile
Raw Normal View History

2001-03-11 01:29:38 +01:00
#
# This source code is free software; you can redistribute it
# and/or modify it in source code form under the terms of the GNU
# Library 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 Library General Public License for more details.
#
# You should have received a copy of the GNU Library 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
#
SHELL = /bin/sh
suffix = @install_suffix@
2001-03-11 01:29:38 +01:00
prefix = @prefix@
exec_prefix = @exec_prefix@
srcdir = @srcdir@
datarootdir = @datarootdir@
2001-03-11 01:29:38 +01:00
VPATH = $(srcdir)
bindir = @bindir@
libdir = @libdir@
2001-07-21 06:34:25 +02:00
mandir = @mandir@
2001-03-11 01:29:38 +01:00
includedir = @includedir@
CC = @CC@
2003-09-05 20:04:16 +02:00
HOSTCC = @CC@
2004-02-10 20:25:00 +01:00
CXX = @CXX@
2001-03-11 01:29:38 +01:00
INSTALL = @INSTALL@
INSTALL_SCRIPT = @INSTALL_SCRIPT@
INSTALL_PROGRAM = @INSTALL_PROGRAM@
INSTALL_DATA = @INSTALL_DATA@
2003-02-22 05:39:32 +01:00
RANLIB = @RANLIB@
2001-12-30 18:20:33 +01:00
LEX = @LEX@
YACC = @YACC@
MAN = @MAN@
PS2PDF = @PS2PDF@
2001-03-11 01:29:38 +01:00
CPPFLAGS = -I. -I.. -I $(srcdir) -I$(srcdir)/.. @CPPFLAGS@ @DEFS@
CXXFLAGS = -Wall @CXXFLAGS@
2004-02-10 20:25:00 +01:00
LDFLAGS = @rdynamic@ @LDFLAGS@
2001-05-20 17:09:39 +02:00
LIBS = @LIBS@ @EXTRALIBS@
2001-03-11 01:29:38 +01:00
dllib=@DLLIB@
MDIR1 = -DMODULE_DIR1=\"$(libdir)/ivl$(suffix)/.\"
all: dep vvp@EXEEXT@ libvpi.a vvp.man
2001-03-11 01:29:38 +01:00
clean:
rm -f *.o *~ parse.cc parse.h lexor.cc tables.cc
rm -rf dep vvp@EXEEXT@ libvpi.a parse.output vvp.man vvp.pdf vvp.exp
2001-03-11 01:29:38 +01:00
distclean: clean
rm -f Makefile config.log
rm -f stamp-config-h config.h
2001-03-11 01:29:38 +01:00
2001-03-25 07:59:46 +02:00
check: all
./vvp -M../vpi $(srcdir)/examples/hello.vvp | grep 'Hello, World.'
V = vpi_modules.o vpi_callback.o vpi_const.o vpi_event.o vpi_iter.o vpi_mcd.o \
vpi_priv.o vpi_scope.o vpi_real.o vpi_signal.o vpi_tasks.o vpi_time.o \
vpi_vthr_vector.o vpip_bin.o vpip_hex.o vpip_oct.o \
2003-04-20 04:49:07 +02:00
vpip_to_dec.o vpip_format.o vvp_vpi.o
O = main.o parse.o parse_misc.o lexor.o arith.o array.o bufif.o compile.o \
concat.o \
dff.o extend.o npmos.o part.o permaheap.o reduce.o resolv.o sfunc.o stop.o \
symbols.o ufunc.o codes.o \
vthread.o schedule.o statistics.o tables.o udp.o vvp_island.o vvp_net.o \
vvp_net_sig.o event.o logic.o delay.o words.o island_tran.o $V
2001-03-11 01:29:38 +01:00
ifeq (@WIN32@,yes)
# Under Windows (mingw) I need to make the ivl.exe in two steps.
# The first step makes an ivl.exe that dlltool can use to make an
# export and import library, and the last link makes a, ivl.exe
# that really exports the things that the import library imports.
vvp@EXEEXT@ libvpi.a: $O $(srcdir)/vvp.def
2003-03-08 21:59:23 +01:00
$(CXX) -o vvp@EXEEXT@ $(LDFLAGS) $O $(dllib) $(LIBS)
dlltool --dllname vvp@EXEEXT@ --def $(srcdir)/vvp.def \
--output-lib libvpi.a --output-exp vvp.exp
$(CXX) $(LDFLAGS) -o vvp@EXEEXT@ vvp.exp $(LDFLAGS) $O $(dllib) $(LIBS)
else
libvpi.a: libvpi.c
$(CC) -c $(srcdir)/libvpi.c
rm -f libvpi.a
ar cqv libvpi.a libvpi.o
2003-02-22 05:39:32 +01:00
$(RANLIB) libvpi.a
vvp@EXEEXT@: $O
$(CXX) $(LDFLAGS) -o vvp@EXEEXT@ $O $(LIBS) $(dllib)
endif
2001-03-11 01:29:38 +01:00
dep:
mkdir dep
2001-03-11 01:29:38 +01:00
%.o: %.cc
2004-02-10 20:25:00 +01:00
$(CXX) $(CPPFLAGS) $(MDIR1) $(MDIR2) $(CXXFLAGS) -MD -c $< -o $*.o
2003-10-09 01:09:09 +02:00
mv $*.d dep/$*.d
%.o: %.c
2004-02-10 20:25:00 +01:00
$(CC) $(CPPFLAGS) $(MDIR1) $(MDIR2) $(CFLAGS) -MD -c $< -o $*.o
2001-03-11 01:29:38 +01:00
mv $*.d dep/$*.d
tables.cc: $(srcdir)/draw_tt.c
2003-09-05 20:04:16 +02:00
$(HOSTCC) -o draw_tt $(srcdir)/draw_tt.c
2001-03-11 23:42:11 +01:00
./draw_tt > tables.cc
2001-05-20 17:09:39 +02:00
rm draw_tt@EXEEXT@
2001-03-11 01:29:38 +01:00
lexor.o: lexor.cc parse.h
parse.o: parse.cc
2001-04-01 23:31:46 +02:00
tables.o: tables.cc
parse.cc: $(srcdir)/parse.y
2001-12-30 18:20:33 +01:00
$(YACC) --verbose -t -d -o parse.cc $(srcdir)/parse.y
parse.h: parse.cc
mv parse.cc.h parse.h 2>/dev/null || mv parse.hh parse.h
2001-03-11 01:29:38 +01:00
lexor.cc: $(srcdir)/lexor.lex
2001-12-30 18:20:33 +01:00
$(LEX) -s -olexor.cc $(srcdir)/lexor.lex
2001-03-11 01:29:38 +01:00
vvp.man: $(srcdir)/vvp.man.in ../version.exe
../version.exe `head -1 $(srcdir)/vvp.man.in`'\n' > $@
tail -n +2 $(srcdir)/vvp.man.in >> $@
vvp.pdf: vvp.man
$(MAN) -t $(srcdir)/vvp.man | $(PS2PDF) - vvp.pdf
2001-10-21 23:59:49 +02:00
ifeq (@MINGW32@,yes)
ifeq ($(MAN),none)
INSTALL_DOC = $(mandir)/man1/vvp$(suffix).1
else
ifeq ($(PS2PDF),none)
INSTALL_DOC = $(mandir)/man1/vvp$(suffix).1
else
INSTALL_DOC = $(prefix)/vvp$(suffix).pdf $(mandir)/man1/vvp$(suffix).1
2001-10-21 23:59:49 +02:00
all: vvp.pdf
endif
endif
INSTALL_DOCDIR = $(mandir)/man1
2001-10-21 23:59:49 +02:00
else
INSTALL_DOC = $(mandir)/man1/vvp$(suffix).1
2001-10-21 23:59:49 +02:00
INSTALL_DOCDIR = $(mandir)/man1
endif
Makefile: $(srcdir)/Makefile.in
cd ..; ./config.status --file=vvp/$@
2001-03-25 07:59:46 +02:00
stamp-config-h: $(srcdir)/config.h.in ../config.status
@rm -f $@
cd ..; ./config.status --header=vvp/config.h
config.h: stamp-config-h
2001-03-11 01:29:38 +01:00
install: all installdirs $(bindir)/vvp$(suffix)@EXEEXT@ $(libdir)/libvpi$(suffix).a $(INSTALL_DOC)
$(bindir)/vvp$(suffix)@EXEEXT@: ./vvp@EXEEXT@
$(INSTALL_PROGRAM) ./vvp@EXEEXT@ "$(DESTDIR)$(bindir)/vvp$(suffix)@EXEEXT@"
2001-03-22 23:37:36 +01:00
$(libdir)/libvpi$(suffix).a : ./libvpi.a
$(INSTALL_DATA) libvpi.a "$(DESTDIR)$(libdir)/libvpi$(suffix).a"
2001-03-22 23:37:36 +01:00
$(mandir)/man1/vvp$(suffix).1: vvp.man
$(INSTALL_DATA) vvp.man "$(DESTDIR)$(mandir)/man1/vvp$(suffix).1"
2001-07-21 06:34:25 +02:00
$(prefix)/vvp$(suffix).pdf: vvp.pdf
$(INSTALL_DATA) vvp.pdf "$(DESTDIR)$(prefix)/vvp$(suffix).pdf"
2001-10-21 23:59:49 +02:00
installdirs: $(srcdir)/../mkinstalldirs
$(srcdir)/../mkinstalldirs "$(DESTDIR)$(bindir)" "$(DESTDIR)$(libdir)" "$(DESTDIR)$(INSTALL_DOCDIR)"
2003-10-09 01:09:09 +02:00
uninstall: $(UNINSTALL32)
rm -f "$(DESTDIR)$(bindir)/vvp$(suffix)@EXEEXT@"
rm -f "$(DESTDIR)$(libdir)/libvpi$(suffix).a"
rm -f "$(DESTDIR)$(mandir)/man1/vvp$(suffix).1" "$(DESTDIR)$(prefix)/vvp$(suffix).pdf"
2001-03-14 20:26:01 +01:00
2001-03-11 01:29:38 +01:00
-include $(patsubst %.o, dep/%.d, $O)