-
Notifications
You must be signed in to change notification settings - Fork 78
/
Kconfig
316 lines (257 loc) · 9.18 KB
/
Kconfig
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
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
#
# Copyright (c) Siemens AG, 2021-2023
#
# Authors:
# Jan Kiszka <[email protected]>
# Li Hua Qian <[email protected]>
#
# This file is subject to the terms and conditions of the MIT License. See
# COPYING.MIT file in the top-level directory.
#
mainmenu "IOT2050 Image Configuration"
config KAS_BUILD_SYSTEM
string
default "isar"
choice
prompt "Image type"
default IMAGE_EXAMPLE
config IMAGE_EXAMPLE
bool "Example image"
help
This is the official example image with several tools as well as
Node-RED preinstalled. It comes without a graphical user interface.
config IMAGE_SWUPDATE
bool "Example image with SWUpdate support"
help
Based on the example image, this adds SWUpdate and changes the
partition layout to an A/B rootfs.
config IMAGE_BOOT
bool "Firmware images"
help
Build firmware images that are responsible for booting IOT2050
devices. Two artifacts are generated: iot2050-pg1-image-boot.bin
for Product Generation 1 devices and iot2050-pg2-image-boot.bin for
Product Generation 2 devices, including M.2 and SM variants.
WARNING: Do not flash this image onto your device unless you know
that it fits AND you have an external flash programmer at hand that
allows to recover. Otherwise you risk to BRICK THE IOT2050!
config IMAGE_FWU_PKG
bool "Firmware update package for all devices"
help
This is the official firmware update package in
IOT2050-FW-Update-PKG-Vx.x.x.tar.xz format, which includes firmware bins,
and update criteria, and builtin env, and it is for all IOT2050 devices.
endchoice
config KAS_INCLUDE_MAIN
string
default "kas-iot2050-example.yml" if IMAGE_EXAMPLE
default "kas-iot2050-swupdate.yml" if IMAGE_SWUPDATE
default "kas-iot2050-boot.yml" if IMAGE_BOOT
default "kas-iot2050-fwu-package.yml" if IMAGE_FWU_PKG
comment "Image features"
if IMAGE_EXAMPLE || IMAGE_SWUPDATE
config PREEMPT_RT
bool "Preempt-RT kernel"
help
Build the image with a Preempt-RT kernel, rather than the default
non-preemptive one. This can help achieving better real-time
latencies with the device.
config KAS_INCLUDE_RT
string
default "kas/opt/preempt-rt.yml"
depends on PREEMPT_RT
config NODE_RED
bool "Node-RED support"
default y
help
Building image with Node-RED support.
config KAS_INCLUDE_NO_NODE_RED
string
default "kas/opt/no-node-red.yml"
depends on !NODE_RED
config DOCKER
bool "Docker support"
help
Building image with docker support.
config KAS_INCLUDE_DOCKER
string
default "kas/opt/docker.yml"
depends on DOCKER
config LXDE
bool "LXDE graphical user interface"
help
This adds an LXDE-based graphical user interface.
config KAS_INCLUDE_LXDE
string
default "kas/opt/lxde.yml"
depends on LXDE
config EIO
bool "EIO subsystem support"
help
Building image with EIO subsystem support.
NOTE: The EIO firmware and library need be downloaded before building. See
the README.md for more information.
config KAS_INCLUDE_EIO
string
default "kas/opt/eio.yml"
depends on EIO
endif
# Provide two entries so that the help text can be adjusted to the image.
config SECURE_BOOT
bool "Secure boot & Data encryption"
depends on IMAGE_SWUPDATE && !IMAGE_QEMU
help
Enable signing of boot artifacts (boot loader, unified kernel image).
Furthermore activate dm-verity integrity protection for the read-only
root filesystem.
This uses the public custMpk.key and certificate by default. Do not
use this key in production, it is for demonstration purposes only.
The writable persistent /var and /home partitions are encrypted as
LUKS2 partitions.
The reason of coupling the data encryption with the secure boot is to
have a proper integrity chain rooted in hardware (OTP, RPMB, etc.)
config SECURE_BOOT
bool "Secure boot"
depends on IMAGE_BOOT
help
Enable signing of all customizable firmware artifacts, enforce UEFI
Secure Boot mode, protect sensitive U-Boot environment variables and
prevent interactive access to U-Boot during boot and also on boot
failures.
This uses the public custMpk.key and certificate by default. Do not
use this key in production, it is for demonstration purposes only.
NOTE: Only PG2 and M.2 devices are officially supported regarding
secure boot.
config OTP_PROVISIONING
bool "OTP Provisioning"
depends on IMAGE_BOOT
help
Integrate OTP provisioning data into the firmware artifacts. Various
options are avaiable. By default, this will integrate the OTP command
data for provision two public key hashes and enable secure boot in
OTP.
WARNING: This uses the dummy keys by default. Do not use these keys
in production, they are for demonstration purposes only.
config RPMB_SETUP
bool "OPTEE RPMB setup for OTP key write"
depends on IMAGE_BOOT && !SECURE_BOOT
help
Enable one-time pairing between processor and secure storage
(RPMB on eMMC). Do not sign and distribute this version. Run it
only in a secure environment on the target device, then replace it
with signed production firmware and enable secure boot.
config IMAGE_QEMU
bool "QEMU Image"
depends on IMAGE_EXAMPLE || IMAGE_SWUPDATE
help
QEMU image to boot image without real hardware. The device emulated
by QEMU is not identical to a physical IOT2050. This leads to missing
or limited features such as Arduino I/Os, only one ethernet port,
virtual debug serial port, qemu version of u-boot, no watchdog, only
virtual drives, performance issues etc.
WARNING: Please be aware of potential problems when using the image
for testing purposes.
config KAS_INCLUDE_QEMU_IMAGE
string
default "kas-iot2050-qemu.yml"
depends on IMAGE_QEMU
config KAS_INCLUDE_SECURE_BOOT
string
default "kas/opt/secure-boot.yml"
depends on SECURE_BOOT
config KAS_INCLUDE_OTP_PROVISIONING
string
default "kas/opt/otpcmd/key-provision.yml" if OTP_PROVISIONING_2KEYS_ENABLE
default "kas/opt/otpcmd/key-provision-keys-only.yml" if OTP_PROVISIONING_2KEYS
default "kas/opt/otpcmd/key-provision-3keys.yml" if OTP_PROVISIONING_3KEYS_ENABLE
default "kas/opt/otpcmd/key-provision-enabling-only.yml" if OTP_PROVISIONING_ENABLING_ONLY
default "kas/opt/otpcmd/key-switch.yml" if OTP_PROVISIONING_KEY_SWITCHING_1TO2
default "kas/opt/otpcmd/key-switch-2to3.yml" if OTP_PROVISIONING_KEY_SWITCHING_2TO3
depends on OTP_PROVISIONING
config KAS_INCLUDE_RPMB_SETUP
string
default "kas/opt/rpmb-setup.yml"
depends on RPMB_SETUP
comment "Build options"
config SDK
bool "Build SDK"
depends on IMAGE_EXAMPLE || IMAGE_SWUPDATE
help
Generate an SDK consisting of a cross-compiler and library headers
needed to build applications for the device.
Note: This will not generate the image for the device itself.
config KAS_INCLUDE_SDK
string
default "kas/opt/sdk.yml"
depends on SDK
config PACKAGE_LOCK
bool "Use Debian packages from release"
help
Use the same Debian packages that were selected for building the
released image or firmware version.
config KAS_INCLUDE_PACKAGE_LOCK
string
default "kas/opt/package-lock.yml"
depends on PACKAGE_LOCK
config DEBIAN_MIRROR
bool "Use specific debian mirror"
depends on !PACKAGE_LOCK
help
Rather than relying on deb.debian.org to select the best local
mirror, specify a specific one.
config DEBIAN_MIRROR_URL
string "URL of Debian mirror"
default "http://ftp.de.debian.org"
depends on DEBIAN_MIRROR
config KAS_INCLUDE_DEBIAN_MIRROR
string
default "kas/opt/debian-mirror.yml"
depends on DEBIAN_MIRROR
config FIRMWARE_SECURE_VER
string "Use specific firmware secure version"
default "0"
depends on SECURE_BOOT && IMAGE_BOOT
help
Use specific anti-rollback secure version rather than the default 0.
Range 0 - 127.
choice
prompt "*** OTP provisioning command type ***"
depends on OTP_PROVISIONING
default OTP_PROVISIONING_2KEYS_ENABLE
config OTP_PROVISIONING_2KEYS_ENABLE
bool "2 keys & enabling secure boot"
help
OTP provisioning command data contains the public key hashes of
below keys and enabling secure boot:
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custMpk.pem
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custSmpk.pem
config OTP_PROVISIONING_2KEYS
bool "2 keys only"
help
OTP provisioning command data contains the public key hashes of
below keys but without enabling secure boot:
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custMpk.pem
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custSmpk.pem
config OTP_PROVISIONING_3KEYS_ENABLE
bool "3 keys & enabling secure boot"
help
OTP provisioning command data contains the public key hashes of
below keys and enabling secure boot:
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custMpk.pem
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custSmpk.pem
* recipes-bsp/secure-boot-otp-provisioning/files/keys/custBmpk.pem
config OTP_PROVISIONING_ENABLING_ONLY
bool "Enabling secure boot only"
help
OTP provisioning command data only contains enabling secure boot.
config OTP_PROVISIONING_KEY_SWITCHING_1TO2
bool "Key switching from key 1 to key 2"
help
OTP provisioning command data contains key switching from key 1
to key 2.
config OTP_PROVISIONING_KEY_SWITCHING_2TO3
bool "Key switching from key 2 to key 3"
help
OTP provisioning command data contains key switching from key 2
to key 3.
endchoice