2000-10-09 00:36:55 +02: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)
|
2002-12-08 04:06:30 +01:00
|
|
|
# any later version.
|
2000-10-09 00:36:55 +02:00
|
|
|
#
|
|
|
|
|
# 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
|
2012-08-29 03:41:23 +02:00
|
|
|
# Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
|
# Boston, MA 02110-1301, USA.
|
2000-10-09 00:36:55 +02:00
|
|
|
#
|
|
|
|
|
SHELL = /bin/sh
|
|
|
|
|
|
2008-11-17 16:22:46 +01:00
|
|
|
suffix = @install_suffix@
|
|
|
|
|
|
2000-10-09 00:36:55 +02:00
|
|
|
prefix = @prefix@
|
|
|
|
|
exec_prefix = @exec_prefix@
|
|
|
|
|
srcdir = @srcdir@
|
2008-01-24 21:10:31 +01:00
|
|
|
datarootdir = @datarootdir@
|
2000-10-09 00:36:55 +02:00
|
|
|
|
|
|
|
|
VPATH = $(srcdir)
|
|
|
|
|
|
|
|
|
|
bindir = $(exec_prefix)/bin
|
|
|
|
|
libdir = $(exec_prefix)/lib
|
|
|
|
|
includedir = $(prefix)/include
|
|
|
|
|
mandir = @mandir@
|
|
|
|
|
|
|
|
|
|
dllib=@DLLIB@
|
|
|
|
|
|
|
|
|
|
CC = @CC@
|
|
|
|
|
INSTALL = @INSTALL@
|
|
|
|
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
|
|
|
|
INSTALL_DATA = @INSTALL_DATA@
|
2011-04-07 21:03:16 +02:00
|
|
|
LEX = @LEX@
|
|
|
|
|
YACC = @YACC@
|
2008-05-23 01:31:09 +02:00
|
|
|
MAN = @MAN@
|
|
|
|
|
PS2PDF = @PS2PDF@
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2010-10-10 06:30:18 +02:00
|
|
|
ifeq (@srcdir@,.)
|
|
|
|
|
INCLUDE_PATH = -I. -I..
|
|
|
|
|
else
|
|
|
|
|
INCLUDE_PATH = -I. -I.. -I$(srcdir) -I$(srcdir)/..
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
CPPFLAGS = $(INCLUDE_PATH) @CPPFLAGS@ @DEFS@
|
2014-07-09 03:45:39 +02:00
|
|
|
CFLAGS = @WARNING_FLAGS@ @WARNING_FLAGS_CC@ @CFLAGS@
|
2000-10-09 00:36:55 +02:00
|
|
|
LDFLAGS = @LDFLAGS@
|
|
|
|
|
|
2010-10-10 06:30:18 +02:00
|
|
|
O = main.o substit.o cflexor.o cfparse.o
|
|
|
|
|
|
2009-11-27 18:25:50 +01:00
|
|
|
all: dep iverilog@EXEEXT@ iverilog.man
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2008-12-17 01:54:28 +01:00
|
|
|
check: all
|
|
|
|
|
|
2000-10-09 00:36:55 +02:00
|
|
|
clean:
|
2009-10-29 03:20:36 +01:00
|
|
|
rm -f *.o cflexor.c cfparse.c cfparse.h cfparse.output
|
2009-11-27 18:25:50 +01:00
|
|
|
rm -f iverilog@EXEEXT@ iverilog.man iverilog.pdf iverilog.ps
|
2008-12-17 01:24:09 +01:00
|
|
|
rm -rf dep
|
2003-02-27 23:13:22 +01:00
|
|
|
|
|
|
|
|
distclean: clean
|
2008-12-17 01:24:09 +01:00
|
|
|
rm -f Makefile config.log
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2010-10-10 06:30:18 +02:00
|
|
|
cppcheck: $(O:.o=.c)
|
2014-06-30 05:38:23 +02:00
|
|
|
cppcheck --enable=all -f \
|
|
|
|
|
-UYY_USER_INIT \
|
|
|
|
|
-UYYPARSE_PARAM -UYYPRINT -Ushort -Uyyoverflow \
|
|
|
|
|
-UYYTYPE_INT8 -UYYTYPE_INT16 -UYYTYPE_UINT8 -UYYTYPE_UINT16 \
|
|
|
|
|
$(INCLUDE_PATH) $^
|
2010-10-10 06:30:18 +02:00
|
|
|
|
2008-12-13 00:30:15 +01:00
|
|
|
Makefile: $(srcdir)/Makefile.in ../config.status
|
2009-10-20 07:58:54 +02:00
|
|
|
cd ..; ./config.status --file=driver/$@
|
2008-12-13 00:30:15 +01:00
|
|
|
|
2010-10-10 06:30:18 +02:00
|
|
|
dep:
|
|
|
|
|
mkdir dep
|
2000-10-09 00:36:55 +02:00
|
|
|
|
|
|
|
|
iverilog@EXEEXT@: $O
|
2001-05-20 17:09:39 +02:00
|
|
|
$(CC) $(LDFLAGS) $O -o iverilog@EXEEXT@ @EXTRALIBS@
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2012-01-05 02:59:41 +01:00
|
|
|
cflexor.c: $(srcdir)/cflexor.lex
|
|
|
|
|
$(LEX) -s -t $< > $@
|
2001-11-12 02:26:36 +01:00
|
|
|
|
2020-07-30 17:27:01 +02:00
|
|
|
# Use pattern rules to avoid parallel build issues (see pr3462585)
|
|
|
|
|
cfparse%c cfparse%h: $(srcdir)/cfparse%y
|
|
|
|
|
$(YACC) --verbose -t -p cf -d -o cfparse.c $<
|
2001-11-12 02:26:36 +01:00
|
|
|
|
2008-12-16 18:05:17 +01:00
|
|
|
%.o: %.c
|
2010-05-13 01:46:22 +02:00
|
|
|
$(CC) $(CPPFLAGS) $(CFLAGS) @DEPENDENCY_FLAG@ -c $< -o $*.o
|
2008-12-16 18:05:17 +01:00
|
|
|
mv $*.d dep
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2009-12-28 18:49:35 +01:00
|
|
|
main.o: main.c globals.h $(srcdir)/../version_base.h ../version_tag.h Makefile
|
2010-05-13 01:46:22 +02:00
|
|
|
$(CC) $(CPPFLAGS) $(CFLAGS) @DEPENDENCY_FLAG@ -c -DIVL_ROOT='"@libdir@/ivl$(suffix)"' -DIVL_SUFFIX='"$(suffix)"' -DIVL_INC='"@includedir@"' -DIVL_LIB='"@libdir@"' -DDLLIB='"@DLLIB@"' $(srcdir)/main.c
|
2008-12-16 23:13:29 +01:00
|
|
|
mv $*.d dep
|
2008-12-16 18:05:17 +01:00
|
|
|
|
|
|
|
|
cflexor.o: cflexor.c cfparse.h
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2009-11-27 18:25:50 +01:00
|
|
|
iverilog.man: $(srcdir)/iverilog.man.in ../version.exe
|
|
|
|
|
../version.exe `head -1 $(srcdir)/iverilog.man.in`'\n' > $@
|
2009-12-04 23:57:36 +01:00
|
|
|
tail -n +2 $(srcdir)/iverilog.man.in >> $@
|
2009-11-27 18:25:50 +01:00
|
|
|
|
|
|
|
|
iverilog.ps: iverilog.man
|
2010-10-02 20:02:27 +02:00
|
|
|
$(MAN) -t ./iverilog.man > iverilog.ps
|
2002-05-24 03:13:00 +02:00
|
|
|
|
|
|
|
|
iverilog.pdf: iverilog.ps
|
2008-05-23 01:31:09 +02:00
|
|
|
$(PS2PDF) iverilog.ps iverilog.pdf
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2008-05-23 01:31:09 +02:00
|
|
|
ifeq (@MINGW32@,yes)
|
|
|
|
|
ifeq ($(MAN),none)
|
2008-11-17 16:22:46 +01:00
|
|
|
INSTALL_DOC = $(mandir)/man1/iverilog$(suffix).1
|
2008-05-23 01:31:09 +02:00
|
|
|
else
|
|
|
|
|
ifeq ($(PS2PDF),none)
|
2008-11-17 16:22:46 +01:00
|
|
|
INSTALL_DOC = $(mandir)/man1/iverilog$(suffix).1
|
2008-05-23 01:31:09 +02:00
|
|
|
else
|
2008-11-17 16:22:46 +01:00
|
|
|
INSTALL_DOC = $(prefix)/iverilog$(suffix).pdf $(mandir)/man1/iverilog$(suffix).1
|
2001-10-21 23:59:49 +02:00
|
|
|
all: iverilog.pdf
|
2008-05-23 01:31:09 +02:00
|
|
|
endif
|
|
|
|
|
endif
|
|
|
|
|
INSTALL_DOCDIR = $(mandir)/man1
|
2001-10-21 23:59:49 +02:00
|
|
|
else
|
2008-11-17 16:22:46 +01:00
|
|
|
INSTALL_DOC = $(mandir)/man1/iverilog$(suffix).1
|
2001-10-21 23:59:49 +02:00
|
|
|
INSTALL_DOCDIR = $(mandir)/man1
|
|
|
|
|
endif
|
|
|
|
|
|
2008-11-17 16:22:46 +01:00
|
|
|
install: all installdirs $(bindir)/iverilog$(suffix)@EXEEXT@ $(INSTALL_DOC)
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2008-11-17 16:22:46 +01:00
|
|
|
$(bindir)/iverilog$(suffix)@EXEEXT@: ./iverilog@EXEEXT@
|
2009-02-04 17:44:22 +01:00
|
|
|
$(INSTALL_PROGRAM) ./iverilog@EXEEXT@ "$(DESTDIR)$(bindir)/iverilog$(suffix)@EXEEXT@"
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2009-11-27 18:25:50 +01:00
|
|
|
$(mandir)/man1/iverilog$(suffix).1: iverilog.man
|
|
|
|
|
$(INSTALL_DATA) iverilog.man "$(DESTDIR)$(mandir)/man1/iverilog$(suffix).1"
|
2000-10-09 00:36:55 +02:00
|
|
|
|
2008-11-17 16:22:46 +01:00
|
|
|
$(prefix)/iverilog$(suffix).pdf: iverilog.pdf
|
2009-02-04 17:44:22 +01:00
|
|
|
$(INSTALL_DATA) iverilog.pdf "$(DESTDIR)$(prefix)/iverilog$(suffix).pdf"
|
2001-10-21 23:59:49 +02:00
|
|
|
|
2009-02-04 17:44:22 +01:00
|
|
|
installdirs: $(srcdir)/../mkinstalldirs
|
|
|
|
|
$(srcdir)/../mkinstalldirs "$(DESTDIR)$(bindir)" "$(DESTDIR)$(INSTALL_DOCDIR)"
|
2000-10-09 00:36:55 +02:00
|
|
|
|
|
|
|
|
uninstall:
|
2009-02-04 17:44:22 +01:00
|
|
|
rm -f "$(DESTDIR)$(bindir)/iverilog$(suffix)@EXEEXT@"
|
|
|
|
|
rm -f "$(DESTDIR)$(mandir)/man1/iverilog$(suffix).1" "$(DESTDIR)$(prefix)/iverilog$(suffix).pdf"
|
2008-12-16 18:05:17 +01:00
|
|
|
|
|
|
|
|
-include $(patsubst %.o, dep/%.d, $O)
|