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