-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
113 lines (93 loc) · 3.01 KB
/
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
###############################################################################
#
# Lynsyn Makefile
#
# Compiles host software for all Lynsyn boards
#
# Usage:
# make Builds all host software
# make clean Cleans everything
#
# Make sure to adjust settings at the top of this file for your system
#
###############################################################################
###############################################################################
# Settings for the host tools
export QMAKE = qmake CONFIG+=release
###############################################################################
###############################################################################
# Everything below this should not need any changes
export HOSTDIR = $(shell pwd)
ifeq ($(OS),Windows_NT)
export CFLAGS = -I$(HOSTDIR)/../argp-standalone-1.3/ -I/mingw64/include/libusb-1.0/
export LDFLAGS = -largp -L$(HOSTDIR)/../argp-standalone-1.3/
endif
export CFLAGS += -g -O2 -Wall -I/usr/include/libusb-1.0/ -I$(HOSTDIR)/common/ -I$(HOSTDIR)/liblynsyn/
export LDFLAGS += -lusb-1.0
export CXXFLAGS = -std=gnu++11 $(CFLAGS)
export CC = gcc
export CPP = g++
export LD = g++
export AR = ar
export RANLIB = ranlib
###############################################################################
.PHONY: host_software
host_software: bin/lynsyn_tester bin/lynsyn_sampler bin/lynsyn_xvc bin/lynsyn_xsvf bin/lynsyn_viewer
@echo
@echo "Host software compilation successful"
@echo
.PHONY: bin/lynsyn_tester
bin/lynsyn_tester:
mkdir -p bin
cd lynsyn_tester && $(MAKE)
cp lynsyn_tester/lynsyn_tester bin
.PHONY: bin/lynsyn_sampler
bin/lynsyn_sampler:
cd lynsyn_sampler && $(MAKE)
cp lynsyn_sampler/lynsyn_sampler bin
.PHONY: bin/lynsyn_xvc
bin/lynsyn_xvc:
mkdir -p lynsyn_xvc/build
cd lynsyn_xvc/build && $(QMAKE) ..
cd lynsyn_xvc/build && $(MAKE)
ifeq ($(OS),Windows_NT)
cp lynsyn_xvc/build/release/lynsyn_xvc bin
else
cp lynsyn_xvc/build/lynsyn_xvc bin
endif
.PHONY: bin/lynsyn_xsvf
bin/lynsyn_xsvf:
cd libxsvf && $(MAKE) lynsyn_xsvf
cp libxsvf/lynsyn_xsvf bin
.PHONY: bin/lynsyn_viewer
bin/lynsyn_viewer:
mkdir -p lynsyn_viewer/build
cd lynsyn_viewer/build && $(QMAKE) ..
cd lynsyn_viewer/build && $(MAKE)
ifeq ($(OS),Windows_NT)
cp lynsyn_viewer/build/release/lynsyn_viewer bin
else
cp lynsyn_viewer/build/lynsyn_viewer bin
endif
###############################################################################
.PHONY: install
install: host_software install_hw
cp bin/* /usr/bin/
cp jtagdevices /etc/jtagdevices
@echo
@echo "Software and hardware installed"
@echo
###############################################################################
.PHONY: install_hw
install_hw:
cp udev/48-lynsyn.rules /etc/udev/rules.d
udevadm control --reload-rules
###############################################################################
.PHONY : clean
clean:
cd lynsyn_tester && $(MAKE) clean
cd lynsyn_sampler && $(MAKE) clean
cd libxsvf && $(MAKE) clean
rm -rf lynsyn_xvc/build
rm -rf lynsyn_viewer/build
rm -rf liblynsyn/*.o bin