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
|
# Copyright 2020 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Registry of known Zephyr modules."""
import zmake.build_config as build_config
import zmake.util as util
def third_party_module(name, checkout):
"""Common callback in registry for all third_party/zephyr modules.
Args:
name: The name of the module.
checkout: The path to the chromiumos source.
Return:
The path to the module module.
"""
return checkout / "src" / "third_party" / "zephyr" / name
known_modules = {
"hal_stm32": third_party_module,
"cmsis": third_party_module,
"ec": lambda name, checkout: (checkout / "src" / "platform" / "ec"),
"nanopb": third_party_module,
}
def locate_from_checkout(checkout_dir):
"""Find modules from a Chrome OS checkout.
Important: this function should only conditionally be called if a
checkout exists. Zmake *can* be used without a Chrome OS source
tree. You should call locate_from_directory if outside of a
Chrome OS source tree.
Args:
checkout_dir: The path to the chromiumos source.
Returns:
A dictionary mapping module names to paths.
"""
result = {}
for name, locator in known_modules.items():
result[name] = locator(name, checkout_dir)
return result
def locate_from_directory(directory):
"""Create a modules dictionary from a directory.
This takes a directory, and searches for the known module names
located in it.
Args:
directory: the directory to search in.
Returns:
A dictionary mapping module names to paths.
"""
result = {}
for name in known_modules:
modpath = (directory / name).resolve()
if (modpath / "zephyr" / "module.yml").is_file():
result[name] = modpath
return result
def setup_module_symlinks(output_dir, modules):
"""Setup a directory with symlinks to modules.
Args:
output_dir: The directory to place the symlinks in.
modules: A dictionary of module names mapping to paths.
Returns:
The resultant BuildConfig that should be applied to use each
of these modules.
"""
if not output_dir.exists():
output_dir.mkdir(parents=True)
module_links = []
for name, path in modules.items():
link_path = output_dir.resolve() / name
util.update_symlink(path, link_path)
module_links.append(link_path)
if module_links:
return build_config.BuildConfig(
cmake_defs={"ZEPHYR_MODULES": ";".join(map(str, module_links))}
)
return build_config.BuildConfig()
|