aboutsummaryrefslogtreecommitdiff
path: root/Makefile
blob: f22fbd06d1e1bd281e21cd163ae69fb1b5ad3a0a (plain) (blame)
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
export CC  = clang
export CXX = clang++

export SYSTEMC_HOME := $(PWD)/INSTALL

SRCS = $(wildcard *.cc)
BINS = $(SRCS:%.cc=BUILD/UTIL/%)

# -- SYSTEMC UTILS -------------------------------------------------------------

run: build
	@for B in $(BINS); do \
		echo "==> $$B"; \
		$$B; \
	done

build: INSTALL/lib/libsystemc.a BUILD/UTIL $(SRCS)
	ninja -C BUILD/UTIL

BUILD/UTIL: CMakeLists.txt
	cmake -B $@ -S . \
	      -G Ninja \
	      -DCMAKE_EXPORT_COMPILE_COMMANDS=1 \
	      -DCMAKE_BUILD_TYPE=DEBUG \
	      #-DCMAKE_FIND_DEBUG_MODE=ON
	#ninja -C $@ -t compdb > compile_commands.json

# -- SYSTEMC -------------------------------------------------------------------

INSTALL/lib/libsystemc.a: BUILD/SYSC
	ninja -C BUILD/SYSC install

BUILD/SYSC: systemc
	cmake -B $@ -S systemc \
	      -G Ninja \
	      -DCMAKE_EXPORT_COMPILE_COMMANDS=1 \
	      -DCMAKE_BUILD_TYPE=DEBUG \
	      -DCMAKE_INSTALL_PREFIX=$(PWD)/INSTALL \
	      -DBUILD_SHARED_LIBS=OFF \
	      -DCMAKE_CXX_STANDARD=14

systemc:
	git clone --depth=1 https://github.com/accellera-official/systemc.git

# -- UTIL ----------------------------------------------------------------------

fmt:
	clang-format -i *.cc *.h

# -- CLEAN ---------------------------------------------------------------------

clean:
	$(RM) -r BUILD/UTIL compile_commands.json

distclean: clean
	$(RM) -r BUILD INSTALL systemc