-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathMakefile
37 lines (24 loc) · 872 Bytes
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# Build ghdl module for yosys
# Name or path to the ghdl executable.
GHDL=ghdl
YOSYS_CONFIG=yosys-config
SOEXT=so
LDFLAGS=
CFLAGS=-O
LIBGHDL_LIB:=$(shell $(GHDL) --libghdl-library-path)
LIBGHDL_INC:=$(shell $(GHDL) --libghdl-include-dir)
ALL_LDFLAGS=$(LIBGHDL_LIB) -Wl,-rpath,$(dir $(LIBGHDL_LIB)) $(LDFLAGS)
ALL_CFLAGS=-fPIC -DYOSYS_ENABLE_GHDL -I$(LIBGHDL_INC) $(CFLAGS)
all: ghdl.$(SOEXT)
ghdl.$(SOEXT): ghdl.o vhdl_backend.o
$(YOSYS_CONFIG) --build $@ $^ -shared $(ALL_LDFLAGS)
ghdl.o: src/ghdl.cc
$(YOSYS_CONFIG) --exec --cxx -c --cxxflags -o $@ $< $(ALL_CFLAGS)
vhdl_backend.o: src/vhdl_backend.cc
$(YOSYS_CONFIG) --exec --cxx -c --cxxflags -o $@ $< $(ALL_CFLAGS)
clean: force
$(RM) -f ghdl.$(SOEXT) ghdl.o vhdl_backend.o
install: ghdl.$(SOEXT)
$(YOSYS_CONFIG) --exec mkdir -p --datdir/plugins
$(YOSYS_CONFIG) --exec cp $< --datdir/plugins
force: