1# 2# This source code is free software; you can redistribute it 3# and/or modify it in source code form under the terms of the GNU 4# Library General Public License as published by the Free Software 5# Foundation; either version 2 of the License, or (at your option) 6# any later version. 7# 8# This program is distributed in the hope that it will be useful, 9# but WITHOUT ANY WARRANTY; without even the implied warranty of 10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11# GNU Library General Public License for more details. 12# 13# You should have received a copy of the GNU Library General Public 14# License along with this program; if not, write to the Free 15# Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 16# Boston, MA 02110-1301, USA. 17# 18SHELL = /bin/sh 19 20suffix = @install_suffix@ 21 22prefix = @prefix@ 23exec_prefix = @exec_prefix@ 24srcdir = @srcdir@ 25datarootdir = @datarootdir@ 26 27VPATH = $(srcdir) 28 29bindir = @bindir@ 30libdir = @libdir@ 31mandir = @mandir@ 32includedir = @includedir@ 33 34# For a cross compile these defines will need to be set accordingly. 35HOSTCC = @CC@ 36HOSTCFLAGS = @WARNING_FLAGS@ @WARNING_FLAGS_CC@ @CFLAGS@ 37 38BUILDCC = @CC_FOR_BUILD@ 39BUILDEXT = @BUILD_EXEEXT@ 40CXX = @CXX@ 41INSTALL = @INSTALL@ 42INSTALL_SCRIPT = @INSTALL_SCRIPT@ 43INSTALL_PROGRAM = @INSTALL_PROGRAM@ 44INSTALL_DATA = @INSTALL_DATA@ 45LEX = @LEX@ 46YACC = @YACC@ 47MAN = @MAN@ 48PS2PDF = @PS2PDF@ 49 50ifeq (@srcdir@,.) 51INCLUDE_PATH = -I. -I.. 52else 53INCLUDE_PATH = -I. -I.. -I$(srcdir) -I$(srcdir)/.. 54endif 55 56CPPFLAGS = $(INCLUDE_PATH) @CPPFLAGS@ @DEFS@ -DICARUS_VPI_CONST=const 57CFLAGS = @WARNING_FLAGS@ @WARNING_FLAGS_CC@ @CFLAGS@ 58CXXFLAGS = @WARNING_FLAGS@ @WARNING_FLAGS_CXX@ @CXXFLAGS@ 59LDFLAGS = @rdynamic@ @LDFLAGS@ 60LIBS = @LIBS@ @EXTRALIBS@ 61 62dllib=@DLLIB@ 63 64MDIR1 = -DMODULE_DIR1='"$(libdir)/ivl$(suffix)"' 65 66VPI = vpi_modules.o vpi_bit.o vpi_callback.o vpi_cobject.o vpi_const.o vpi_darray.o \ 67 vpi_event.o vpi_iter.o vpi_mcd.o \ 68 vpi_priv.o vpi_scope.o vpi_real.o vpi_signal.o vpi_string.o vpi_tasks.o vpi_time.o \ 69 vpi_vthr_vector.o vpip_bin.o vpip_hex.o vpip_oct.o \ 70 vpip_to_dec.o vpip_format.o vvp_vpi.o 71 72O = main.o parse.o parse_misc.o lexor.o arith.o array_common.o array.o bufif.o compile.o \ 73 concat.o dff.o class_type.o enum_type.o extend.o file_line.o latch.o npmos.o part.o \ 74 permaheap.o reduce.o resolv.o \ 75 sfunc.o stop.o \ 76 substitute.o \ 77 symbols.o ufunc.o codes.o vthread.o schedule.o \ 78 statistics.o tables.o udp.o vvp_island.o vvp_net.o vvp_net_sig.o \ 79 vvp_object.o vvp_cobject.o vvp_darray.o event.o logic.o delay.o \ 80 words.o island_tran.o $(VPI) 81 82all: dep vvp@EXEEXT@ vvp.man 83 84check: all 85ifeq (@WIN32@,yes) 86ifeq (@install_suffix@,) 87 ./vvp -M../vpi $(srcdir)/examples/hello.vvp | grep 'Hello, World.' 88else 89 # On Windows if we have a suffix we must run the vvp test with 90 # a suffix since it was built/linked that way. 91 ln vvp.exe vvp$(suffix).exe 92 ./vvp$(suffix) -M../vpi $(srcdir)/examples/hello.vvp | grep 'Hello, World.' 93 rm -f vvp$(suffix).exe 94endif 95else 96 ./vvp -M../vpi $(srcdir)/examples/hello.vvp | grep 'Hello, World.' 97endif 98 99clean: 100 rm -f *.o *~ parse.cc parse.h lexor.cc tables.cc 101 rm -rf dep vvp@EXEEXT@ parse.output vvp.man vvp.ps vvp.pdf vvp.exp 102 103distclean: clean 104 rm -f Makefile config.log 105 rm -f stamp-config-h config.h 106 107cppcheck: $(O:.o=.cc) draw_tt.c 108 cppcheck --enable=all --std=posix --std=c99 --std=c++03 -f \ 109 --suppressions-list=$(srcdir)/cppcheck.sup \ 110 -UMODULE_DIR1 -UMODULE_DIR2 -UYY_USER_INIT \ 111 -UYYPARSE_PARAM -UYYPRINT -Ushort -Usize_t -Uyyoverflow \ 112 -UYYTYPE_INT8 -UYYTYPE_INT16 -UYYTYPE_UINT8 -UYYTYPE_UINT16 \ 113 --relative-paths=$(srcdir) $(INCLUDE_PATH) $^ 114 115Makefile: $(srcdir)/Makefile.in 116 cd ..; ./config.status --file=vvp/$@ 117 118dep: 119 mkdir dep 120 121vvp@EXEEXT@: $O 122 $(CXX) $(LDFLAGS) -o vvp@EXEEXT@ $O $(LIBS) $(dllib) 123 124%.o: %.cc config.h 125 $(CXX) $(CPPFLAGS) -DIVL_SUFFIX='"$(suffix)"' $(MDIR1) $(MDIR2) $(CXXFLAGS) @DEPENDENCY_FLAG@ -c $< -o $*.o 126 mv $*.d dep/$*.d 127 128%.o: %.c config.h 129 $(CC) $(CPPFLAGS) $(MDIR1) $(MDIR2) $(CFLAGS) @DEPENDENCY_FLAG@ -c $< -o $*.o 130 mv $*.d dep/$*.d 131 132tables.cc: $(srcdir)/draw_tt.c 133 $(CC) $(CFLAGS) -o draw_tt$(BUILDEXT) $(srcdir)/draw_tt.c 134 ./draw_tt$(BUILDEXT) > tables.cc 135 rm draw_tt$(BUILDEXT) 136 137lexor.o: lexor.cc parse.h 138 139parse.o: parse.cc 140 141tables.o: tables.cc 142 143# Use pattern rules to avoid parallel build issues (see pr3462585) 144parse%cc parse%h: $(srcdir)/parse%y 145 $(YACC) --verbose -t --defines=parse.h -o parse.cc $< 146 147lexor.cc: $(srcdir)/lexor.lex 148 $(LEX) -s -olexor.cc $(srcdir)/lexor.lex 149 150vvp.man: $(srcdir)/vvp.man.in ../version.exe 151 ../version.exe `head -1 $(srcdir)/vvp.man.in`'\n' > $@ 152 tail -n +2 $(srcdir)/vvp.man.in >> $@ 153 154vvp.ps: vvp.man 155 $(MAN) -t ./vvp.man > vvp.ps 156 157vvp.pdf: vvp.ps 158 $(PS2PDF) vvp.ps vvp.pdf 159 160ifeq (@MINGW32@,yes) 161ifeq ($(MAN),none) 162INSTALL_DOC = installman 163else 164ifeq ($(PS2PDF),none) 165INSTALL_DOC = installman 166else 167INSTALL_DOC = installpdf installman 168all: vvp.pdf 169endif 170endif 171INSTALL_DOCDIR = $(mandir)/man1 172else 173INSTALL_DOC = installman 174INSTALL_DOCDIR = $(mandir)/man1 175endif 176 177stamp-config-h: $(srcdir)/config.h.in ../config.status 178 @rm -f $@ 179 cd ..; ./config.status --header=vvp/config.h 180config.h: stamp-config-h 181 182install: all installdirs installfiles 183 184F = ./vvp@EXEEXT@ $(INSTALL_DOC) 185 186installman: vvp.man installdirs 187 $(INSTALL_DATA) vvp.man "$(DESTDIR)$(mandir)/man1/vvp$(suffix).1" 188 189installpdf: vvp.pdf installdirs 190 $(INSTALL_DATA) vvp.pdf "$(DESTDIR)$(prefix)/vvp$(suffix).pdf" 191 192installfiles: $(F) | installdirs 193 $(INSTALL_PROGRAM) ./vvp@EXEEXT@ "$(DESTDIR)$(bindir)/vvp$(suffix)@EXEEXT@" 194 195installdirs: $(srcdir)/../mkinstalldirs 196 $(srcdir)/../mkinstalldirs "$(DESTDIR)$(bindir)" "$(DESTDIR)$(libdir)" "$(DESTDIR)$(INSTALL_DOCDIR)" 197 198 199uninstall: $(UNINSTALL32) 200 rm -f "$(DESTDIR)$(bindir)/vvp$(suffix)@EXEEXT@" 201 rm -f "$(DESTDIR)$(mandir)/man1/vvp$(suffix).1" "$(DESTDIR)$(prefix)/vvp$(suffix).pdf" 202 203-include $(patsubst %.o, dep/%.d, $O) 204