-
Notifications
You must be signed in to change notification settings - Fork 106
/
Copy pathMakefile
132 lines (109 loc) · 4.02 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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
help:
@echo 'Make options:'
@echo 'firsttime -- for the first time you run make'
@echo 'update -- to update the install'
@echo 'format -- to format all files'
@echo 'checkformat -- to format all files with checking enabled'
@echo ' # Build a single board'
@echo ' make VENDOR/BOARD'
@echo ' # This is equivalent to'
@echo ' cd src/mainboard/VENDOR/BOARD && make'
@echo ' # Build all mainboards'
@echo ' make mainboards'
@echo ' # Build everything in parallel'
@echo ' make -j mainboards'
@echo ' # Build debug mode'
@echo ' MODE=debug make mainboards'
# Turn them all off. We'll turn them back on to try to get to working tests.
MAINBOARDS := $(wildcard src/mainboard/*/*/Makefile)
# NOTE: These are the host utilities, requiring their own recent Rust version.
RUST_VER := 1.78
BINUTILS_VER := 0.3.6
TARPAULIN_VER := 0.27.1
DPRINT_VER := 0.41.0
CARGOINST := rustup run --install $(RUST_VER) cargo install
.PHONY: $(MAINBOARDS)
mainboards: $(MAINBOARDS)
$(MAINBOARDS):
make --no-print-directory -C $(dir $@) cibuild
firsttime:
$(CARGOINST) $(if $(BINUTILS_VER),--version $(BINUTILS_VER),) cargo-binutils
$(CARGOINST) $(if $(TARPAULIN_VER),--version $(TARPAULIN_VER),) cargo-tarpaulin
$(CARGOINST) $(if $(DPRINT_VER),--version $(DPRINT_VER),) dprint
nexttime:
$(CARGOINST) --force $(if $(BINUTILS_VER),--version $(BINUTILS_VER),) cargo-binutils
$(CARGOINST) --force $(if $(TARPAULIN_VER),--version $(TARPAULIN_VER),) cargo-tarpaulin
$(CARGOINST) --force $(if $(DPRINT_VER),--version $(DPRINT_VER),) dprint
debiansysprepare:
sudo apt-get install \
device-tree-compiler \
pkg-config \
libssl-dev \
llvm-dev \
libclang-dev \
clang \
qemu-system-x86 \
binutils-riscv64-unknown-elf \
libudev-dev \
# -y makes it non-interactive.
curl https://sh.rustup.rs -sSf | sh -s -- -y
.PHONY: ciprepare debiansysprepare firsttime
ciprepare: debiansysprepare firsttime
update:
rustup update
# NOTE: do NOT use the cargo command in targets below.
# ALWAYS USE MAKE!
ALLMAKEFILE := \
$(wildcard payloads/Makefile) \
$(wildcard payloads/*/Makefile) \
$(wildcard payloads/*/*/Makefile) \
$(wildcard payloads/*/*/*/Makefile) \
$(wildcard payloads/*/*/*/*/Makefile) \
$(wildcard src/Makefile) \
$(wildcard src/*/Makefile) \
$(wildcard src/*/*/Makefile) \
$(wildcard src/*/*/*/Makefile) \
$(wildcard src/*/*/*/*/Makefile)
# Ron still doesn't understand this
TEST_ALL_MAKE_DEFAULT := $(patsubst %/Makefile,%/Makefile.default,$(ALLMAKEFILE))
$(TEST_ALL_MAKE_DEFAULT):
make --no-print-directory -C $(dir $@) default
.PHONY: testdefault $(TEST_ALL_MAKE_DEFAULT)
testdefault: $(TEST_ALL_MAKE_DEFAULT)
.PHONY: format
format:
dprint fmt
.PHONY: checkformat
checkformat:
dprint check
# There are a number of targets which can not test.
# Once those are fixed, we can just use a test target.
CRATES_TO_TEST := $(patsubst %/Makefile,%/Makefile.test,$(ALLMAKEFILE))
$(CRATES_TO_TEST):
make --no-print-directory -C $(dir $@) test
.PHONY: test $(CRATES_TO_TEST)
# NOTE: In CI, we run tests with coverage report.
# The individual crates' Makefiles use the `citest` target.
# However, there are a number of crates which can not test.
# Hence, `citest` either points to `coverage` or `skiptest`.
# We use the LCOV format so that we can simply concatenate
# the multiple reports. See ./Makefile.inc for details.
CRATES_TO_CITEST := $(patsubst %/Makefile,%/Makefile.citest,$(ALLMAKEFILE))
$(CRATES_TO_CITEST):
make --no-print-directory -C $(dir $@) citest
.PHONY: test $(CRATES_TO_CITEST)
citest: $(CRATES_TO_CITEST)
# concatenate all the results from the indidividual directories
mkdir -p coverall
find . -name "lcov.info" -exec cat > coverall/lcov.txt {} +
# TODO: Remove write_with_newline
CRATES_TO_CLIPPY := $(patsubst %/Makefile,%/Makefile.clippy,$(ALLMAKEFILE))
$(CRATES_TO_CLIPPY):
make --no-print-directory -C $(dir $@) ciclippy
.PHONY: clippy $(CRATES_TO_CLIPPY)
clippy: $(CRATES_TO_CLIPPY)
# convenience target: this should be the full ci flow
checkandbuildall: ciprepare clippy checkformat test mainboards
echo "Done CI!"
clean:
rm -rf $(TOP)/target