forked from stm32-rs/stm32-rs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
171 lines (124 loc) · 4.59 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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
all: patch svd2rust
.PHONY: extract patch crates svd2rust svdconv form check clean_mmaps clean-rs clean-patch clean-html clean-svd clean_svdconv clean lint mmaps
.PRECIOUS: svd/%.svd .deps/%.d
SHELL := /usr/bin/env bash
# Path to `svd`/`svdtools`
SVDTOOLS ?= svdtools
CRATES ?= stm32c0 stm32f0 stm32f1 stm32f2 stm32f3 stm32f4 stm32f7 \
stm32h5 stm32h7 stm32l0 stm32l1 stm32l4 stm32l5 stm32g0 stm32g4 \
stm32mp1 stm32wl stm32wb stm32u5
# All yaml files in devices/ will be used to patch an SVD
YAMLS := $(foreach crate, $(CRATES), \
$(wildcard devices/$(crate)*.yaml))
# Each yaml file in devices/ exactly name-matches an SVD file in svd/
EXTRACTED_SVDS := $(patsubst devices/%.yaml, svd/%.svd, $(YAMLS))
PATCHED_SVDS := $(patsubst devices/%.yaml, svd/%.svd.patched, $(YAMLS))
FORMATTED_SVDS := $(patsubst devices/%.yaml, svd/%.svd.formatted, $(YAMLS))
# Each yaml file also corresponds to a mmap in mmaps/
MMAPS := $(patsubst devices/%.yaml, mmaps/%.mmap, $(YAMLS))
# Each yaml file also corresponds to svdconv report in svdconv/
SVDCONV_REPORTS := $(patsubst devices/%.yaml, svdconv/%.txt, $(YAMLS))
# Each device will lead to a crate/src/device/mod.rs file
RUST_SRCS := $(foreach crate, $(CRATES), \
$(patsubst devices/$(crate)%.yaml, \
$(crate)/src/$(crate)%/mod.rs, \
$(wildcard devices/$(crate)*.yaml)))
RUST_DIRS := $(foreach crate, $(CRATES), \
$(patsubst devices/$(crate)%.yaml, \
$(crate)/src/$(crate)%/, \
$(wildcard devices/$(crate)*.yaml)))
FORM_SRCS := $(foreach crate, $(CRATES), \
$(patsubst devices/$(crate)%.yaml, \
$(crate)/src/$(crate)%/.form, \
$(wildcard devices/$(crate)*.yaml)))
CHECK_SRCS := $(foreach crate, $(CRATES), \
$(patsubst devices/$(crate)%.yaml, \
$(crate)/src/$(crate)%/.check, \
$(wildcard devices/$(crate)*.yaml)))
# Turn a devices/device.yaml and svd/device.svd into svd/device.svd.patched
svd/%.svd.patched: devices/%.yaml svd/%.svd .deps/%.d
$(SVDTOOLS) patch $<
svd/%.svd.formatted: svd/%.svd.patched
xmllint $< --format -o $@
# Generate mmap from patched SVD
mmaps/%.mmap: svd/%.svd.patched
@mkdir -p mmaps
$(SVDTOOLS) mmap $< > $@
# Generate svdconv reports from patched SVD
svdconv/%.txt: svd/%.svd.patched
@mkdir -p svdconv
svdconv --suppress-warnings $< > $@ | true
# Generates the common crate files: Cargo.toml, build.rs, src/lib.rs, README.md
crates:
python3 scripts/makecrates.py devices/ -y --families $(CRATES)
define crate_template
$(1)/src/%/mod.rs: svd/%.svd.patched $(1)/Cargo.toml
mkdir -p $$(@D)
cd $$(@D); svd2rust -c ../../../svd2rust.toml -i ../../../$$<
rustfmt --config-path="rustfmt.toml" $$@
rm $$(@D)/build.rs
mv -f $$(@D)/generic.rs $$(@D)/../
$(1)/src/%/.form: $(1)/src/%/mod.rs
form -i $$< -o $$(@D)
rm $$<
mv $$(@D)/lib.rs $$<
rustfmt --config-path="rustfmt.toml" $$<
touch $$@
$(1)/src/%/.check: $(1)/src/%/mod.rs
cd $(1) && cargo check --target-dir ../target/check/ --features rt,atomics,$$*
touch $$@
$(1)/Cargo.toml: crates
endef
$(foreach crate,$(CRATES),$(eval $(call crate_template, $(crate))))
svd/%.svd: svd/.extracted ;
svd/.extracted:
cd svd && ./extract.sh && touch .extracted
extract: $(EXTRACTED_SVDS)
patch: $(PATCHED_SVDS)
svd2rust: $(RUST_SRCS) crates
form: $(FORM_SRCS) crates
svdformat: $(FORMATTED_SVDS)
check: $(CHECK_SRCS)
html/index.html: $(PATCHED_SVDS)
@mkdir -p html
svdtools html html/ $(PATCHED_SVDS)
html/comparisons.html: $(PATCHED_SVDS) scripts/htmlcomparesvdall.sh
scripts/htmlcomparesvdall.sh
html: html/index.html html/comparisons.html
lint: $(PATCHED_SVDS)
xmllint --schema svd/cmsis-svd.xsd --noout $(PATCHED_SVDS)
mmaps: $(MMAPS)
svdconv: $(SVDCONV_REPORTS)
clean-rs:
rm -rf $(RUST_DIRS)
rm -f */src/generic.rs
clean-patch:
rm -f $(PATCHED_SVDS)
rm -f $(FORMATTED_SVDS)
clean-html:
rm -rf html
clean-mmaps:
rm -rf mmaps
clean-svdconv:
rm -rf svdconv
clean-crates:
rm -rf $(CRATES)
clean-svd:
rm -f svd/*.svd
rm -f svd/.extracted
clean: clean-rs clean-patch clean-html clean-svd clean-mmaps clean-svdconv
rm -rf .deps
# As alternative to `pip install --user svdtools`:
# run `make venv update-venv` and `source venv/bin/activate'
venv:
python3 -m venv venv
update-venv:
venv/bin/pip install -U pip
venv/bin/pip install -U -r requirements.txt
install:
scripts/tool_install.sh
# Generate dependencies for each device YAML
.deps/%.d: devices/%.yaml
@mkdir -p .deps
$(SVDTOOLS) makedeps $< $@
-include .deps/*