hc
2023-11-20 2e7bd41e4e8ab3d1efdabd9e263a2f7fe79bff8c
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
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
menu "System configuration"
 
# Note: usually, it is not possible to select a provider of a virtual
# package. But here we have an exception: there are only four providers
# and they only get selected by separate entries in this choice and
# under different, exclusive conditions. So this is a safe situation.
choice
   prompt "Root FS skeleton"
 
config BR2_ROOTFS_SKELETON_DEFAULT
   bool "default target skeleton"
   select BR2_PACKAGE_SKELETON_INIT_SYSV if BR2_INIT_SYSV
   select BR2_PACKAGE_SKELETON_INIT_SYSV if BR2_INIT_BUSYBOX
   select BR2_PACKAGE_SKELETON_INIT_SYSTEMD if BR2_INIT_SYSTEMD
   select BR2_PACKAGE_SKELETON_INIT_NONE if BR2_INIT_NONE
   help
     Use default target skeleton
 
config BR2_ROOTFS_SKELETON_CUSTOM
   bool "custom target skeleton"
   select BR2_PACKAGE_SKELETON_CUSTOM
   help
     Use custom target skeleton.
 
endchoice
 
if BR2_ROOTFS_SKELETON_CUSTOM
 
config BR2_ROOTFS_SKELETON_CUSTOM_PATH
   string "custom target skeleton path"
   help
     Path to custom target skeleton.
 
# dummy config so merged /usr workarounds can also be activated for
# custom rootfs skeleton
config BR2_ROOTFS_MERGED_USR
 
endif
 
if BR2_ROOTFS_SKELETON_DEFAULT
 
config BR2_TARGET_GENERIC_HOSTNAME
   string "System hostname"
   default "buildroot"
   help
     Select system hostname to be stored in /etc/hostname.
 
     Leave empty to not create /etc/hostname, or to keep the
     one from a custom skeleton.
 
config BR2_TARGET_GENERIC_ISSUE
   string "System banner"
   default "Welcome to Buildroot"
   help
     Select system banner (/etc/issue) to be displayed at login.
 
     Leave empty to not create /etc/issue, or to keep the
     one from a custom skeleton.
 
endif
 
choice
   bool "Passwords encoding"
   default BR2_TARGET_GENERIC_PASSWD_MD5
   help
     Choose the password encoding scheme to use when Buildroot
     needs to encode a password (eg. the root password, below).
 
     Note: this is used at build-time, and *not* at runtime.
 
config BR2_TARGET_GENERIC_PASSWD_MD5
   bool "md5"
   help
     Use MD5 to encode passwords.
 
     The default. Wildly available, and pretty good.
     Although pretty strong, MD5 is now an old hash function, and
     suffers from some weaknesses, which makes it susceptible to
     brute-force attacks.
 
config BR2_TARGET_GENERIC_PASSWD_SHA256
   bool "sha-256"
   help
     Use SHA256 to encode passwords.
 
     Very strong, but not ubiquitous, although available in glibc
     for some time now. Choose only if you are sure your C library
     understands SHA256 passwords.
 
config BR2_TARGET_GENERIC_PASSWD_SHA512
   bool "sha-512"
   help
     Use SHA512 to encode passwords.
 
     Extremely strong, but not ubiquitous, although available in glibc
     for some time now. Choose only if you are sure your C library
     understands SHA512 passwords.
 
endchoice # Passwd encoding
 
config BR2_TARGET_GENERIC_PASSWD_METHOD
   string
   default "md5"       if BR2_TARGET_GENERIC_PASSWD_MD5
   default "sha-256"   if BR2_TARGET_GENERIC_PASSWD_SHA256
   default "sha-512"   if BR2_TARGET_GENERIC_PASSWD_SHA512
 
choice
   prompt "Init system"
   default BR2_INIT_BUSYBOX
 
config BR2_INIT_BUSYBOX
   bool "BusyBox"
   select BR2_PACKAGE_BUSYBOX
   select BR2_PACKAGE_INITSCRIPTS
 
config BR2_INIT_SYSV
   bool "systemV"
   depends on BR2_USE_MMU # sysvinit
   select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # sysvinit
   select BR2_PACKAGE_INITSCRIPTS
   select BR2_PACKAGE_SYSVINIT
 
# In Buildroot, we decided not to support a split-usr when systemd is
# used as an init system. This is a design decision, not a systemd
# issue. Thus the select is with BR2_INIT_SYSTEMD (below) rather than
# with BR2_PACKAGE_SYSTEMD.
config BR2_INIT_SYSTEMD
   bool "systemd"
   depends on BR2_PACKAGE_SYSTEMD_ARCH_SUPPORTS
   depends on BR2_TOOLCHAIN_USES_GLIBC
   depends on BR2_USE_WCHAR
   depends on BR2_TOOLCHAIN_HAS_THREADS
   depends on BR2_TOOLCHAIN_HAS_SSP
   depends on BR2_USE_MMU
   depends on !BR2_STATIC_LIBS
   depends on BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_10
   select BR2_ROOTFS_MERGED_USR
   select BR2_PACKAGE_SYSTEMD
 
comment "systemd needs a glibc toolchain, headers >= 3.10"
   depends on !(BR2_TOOLCHAIN_USES_GLIBC \
       && BR2_TOOLCHAIN_HEADERS_AT_LEAST_3_10)
 
config BR2_INIT_NONE
   bool "None"
   help
     Buildroot will not install any init system. You will
     have to provide your own, either with a new package
     or with a rootfs-overlay.
 
endchoice
 
choice
   prompt "/dev management" if !BR2_INIT_SYSTEMD
   default BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_EUDEV if BR2_PACKAGE_THUNDERBOOT_USE_EUDEV
   default BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
 
config BR2_ROOTFS_DEVICE_CREATION_STATIC
   bool "Static using device table"
 
config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_DEVTMPFS
   bool "Dynamic using devtmpfs only"
 
config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_MDEV
   bool "Dynamic using devtmpfs + mdev"
   select BR2_PACKAGE_BUSYBOX
 
config BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_EUDEV
   bool "Dynamic using devtmpfs + eudev"
   depends on BR2_USE_WCHAR # eudev
   depends on !BR2_STATIC_LIBS
   depends on BR2_USE_MMU # eudev
   select BR2_PACKAGE_EUDEV
 
comment "eudev needs a toolchain w/ wchar, dynamic library"
   depends on BR2_USE_MMU
   depends on !BR2_USE_WCHAR || BR2_STATIC_LIBS
 
endchoice
 
comment "/dev management using udev (from systemd)"
   depends on BR2_INIT_SYSTEMD
 
config BR2_ROOTFS_DEVICE_TABLE
   string "Path to the permission tables"
   default "system/device_table.txt"
   help
     Specify a space-separated list of permission table locations,
     that will be passed to the makedevs utility to assign
     correct owners and permissions on various files in the
     target filesystem.
 
     See package/makedevs/README for details on the usage and
     syntax of these files.
 
config BR2_ROOTFS_STATIC_DEVICE_TABLE
   string "Path to the device tables"
   default "system/device_table_dev.txt"
   depends on BR2_ROOTFS_DEVICE_CREATION_STATIC
   help
     Specify a space-separated list of device table locations,
     that will be passed to the makedevs utility to create all
     the special device files under /dev.
 
     See package/makedevs/README for details on the usage and
     syntax of these files.
 
config BR2_ROOTFS_DEVICE_TABLE_SUPPORTS_EXTENDED_ATTRIBUTES
   bool "support extended attributes in device tables"
   help
     Support extended attributes handling in device tables
 
if BR2_ROOTFS_SKELETON_DEFAULT
 
config BR2_ROOTFS_MERGED_USR
   bool "Use symlinks to /usr for /bin, /sbin and /lib"
   help
     If you say 'n' here, then /bin, /sbin and /lib and their
     counterparts in /usr will be separate directories. This
     is the historical UNIX way. In this case, /usr can be a
     filesystem on a partition separate from / .
 
     If you say 'y' here, then /bin, /sbin and /lib will be symlinks
     to their counterparts in /usr. In this case, /usr can not be a
     separate filesystem.
 
config BR2_TARGET_ENABLE_ROOT_LOGIN
   bool "Enable root login with password"
   default y
   select BR2_PACKAGE_HOST_MKPASSWD if BR2_TARGET_GENERIC_ROOT_PASSWD != ""
   help
     Allow root to log in with a password.
 
     If not enabled, root will not be able to log in with a password.
     However, if you have an ssh server and you add an ssh key, you
     can still allow root to log in. Alternatively, you can use sudo
     to become root.
 
config BR2_TARGET_GENERIC_ROOT_PASSWD
   string "Root password"
   default ""
   depends on BR2_TARGET_ENABLE_ROOT_LOGIN
   help
     Set the initial root password.
 
     If set to empty (the default), then no root password will be set,
     and root will need no password to log in.
 
     If the password starts with any of $1$, $5$ or $6$, it is considered
     to be already crypt-encoded with respectively md5, sha256 or sha512.
     Any other value is taken to be a clear-text value, and is crypt-encoded
     as per the "Passwords encoding" scheme, above.
 
     Note: "$" signs in the hashed password must be doubled. For example,
     if the hashed password is "$1$longsalt$v35DIIeMo4yUfI23yditq0",
     then you must enter it as "$$1$$longsalt$$v35DIIeMo4yUfI23yditq0"
     (this is necessary otherwise make would attempt to interpret the $
     as a variable expansion).
 
     WARNING! WARNING!
     The password appears as-is in the .config file, and may appear
     in the build log! Avoid using a valuable password if either the
     .config file or the build log may be distributed, or at the
     very least use a strong cryptographic hash for your password!
 
choice
   bool "/bin/sh"
   default BR2_SYSTEM_BIN_SH_DASH if !BR2_PACKAGE_BUSYBOX
   help
     Select which shell will provide /bin/sh.
 
config BR2_SYSTEM_BIN_SH_BASH
   bool "bash"
   depends on BR2_USE_MMU # bash
   depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
   select BR2_PACKAGE_BASH
 
# busybox has shells that work on noMMU
config BR2_SYSTEM_BIN_SH_BUSYBOX
   bool "busybox' default shell"
   depends on BR2_PACKAGE_BUSYBOX
 
config BR2_SYSTEM_BIN_SH_DASH
   bool "dash"
   depends on BR2_USE_MMU # dash
   depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
   select BR2_PACKAGE_DASH
 
config BR2_SYSTEM_BIN_SH_MKSH
   bool "mksh"
   depends on BR2_USE_MMU # mksh
   depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
   select BR2_PACKAGE_MKSH
 
config BR2_SYSTEM_BIN_SH_ZSH
   bool "zsh"
   depends on BR2_USE_MMU # zsh
   depends on BR2_PACKAGE_BUSYBOX_SHOW_OTHERS
   select BR2_PACKAGE_ZSH
 
comment "bash, dash, mksh, zsh need BR2_PACKAGE_BUSYBOX_SHOW_OTHERS"
   depends on !BR2_PACKAGE_BUSYBOX_SHOW_OTHERS && BR2_PACKAGE_BUSYBOX
 
config BR2_SYSTEM_BIN_SH_NONE
   bool "none"
 
endchoice # /bin/sh
 
config BR2_SYSTEM_BIN_SH
   string
   default "bash"    if BR2_SYSTEM_BIN_SH_BASH
   default "dash"    if BR2_SYSTEM_BIN_SH_DASH
   default "mksh"    if BR2_SYSTEM_BIN_SH_MKSH
   default "zsh"     if BR2_SYSTEM_BIN_SH_ZSH
 
choice
   prompt "Run a shell on serial console after boot"
   default BR2_TARGET_SERIAL_SHELL_SH if BR2_PACKAGE_ROCKCHIP
   help
     Select a shell to use.
 
config BR2_TARGET_SERIAL_SHELL_GETTY
   bool "/sbin/getty (login prompt)"
   select BR2_TARGET_GENERIC_GETTY
 
config BR2_TARGET_SERIAL_SHELL_SH
   bool "/bin/sh"
 
config BR2_TARGET_SERIAL_SHELL_LOGIN
   bool "/bin/login"
 
config BR2_TARGET_SERIAL_SHELL_NONE
   bool "none"
 
endchoice
 
menuconfig BR2_TARGET_GENERIC_GETTY
   bool "Run a getty (login prompt) after boot"
   depends on BR2_TARGET_SERIAL_SHELL_GETTY
 
if BR2_TARGET_GENERIC_GETTY
config BR2_TARGET_GENERIC_GETTY_PORT
   string "TTY port"
   default "console"
   help
     Specify a port to run a getty on.
 
choice
   prompt "Baudrate"
   default BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
   help
     Select a baudrate to use.
 
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
   bool "keep kernel default"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
   bool "9600"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
   bool "19200"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
   bool "38400"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
   bool "57600"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
   bool "115200"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_1500000
   bool "1500000"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_2000000
   bool "2000000"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_2500000
   bool "2500000"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_3000000
   bool "3000000"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_3500000
   bool "3500000"
config BR2_TARGET_GENERIC_GETTY_BAUDRATE_4000000
   bool "4000000"
endchoice
 
config BR2_TARGET_GENERIC_GETTY_BAUDRATE
   string
   default "0"        if BR2_TARGET_GENERIC_GETTY_BAUDRATE_KEEP
   default "9600"        if BR2_TARGET_GENERIC_GETTY_BAUDRATE_9600
   default "19200"        if BR2_TARGET_GENERIC_GETTY_BAUDRATE_19200
   default "38400"        if BR2_TARGET_GENERIC_GETTY_BAUDRATE_38400
   default "57600"        if BR2_TARGET_GENERIC_GETTY_BAUDRATE_57600
   default "115200"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_115200
   default "1500000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_1500000
   default "2000000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_2000000
   default "2500000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_2500000
   default "3000000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_3000000
   default "3500000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_3500000
   default "4000000"    if BR2_TARGET_GENERIC_GETTY_BAUDRATE_4000000
 
config BR2_TARGET_GENERIC_GETTY_TERM
   string "TERM environment variable"
   default "vt100"
   # currently observed only by busybox and sysvinit
   depends on BR2_INIT_BUSYBOX || BR2_INIT_SYSV
   help
     Specify a TERM type.
 
config BR2_TARGET_GENERIC_GETTY_OPTIONS
   string "other options to pass to getty"
   default ""
   # currently observed only by busybox and sysvinit
   depends on BR2_INIT_BUSYBOX || BR2_INIT_SYSV
   help
     Any other flags you want to pass to getty,
     Refer to getty --help for details.
endif
 
config BR2_TARGET_GENERIC_REMOUNT_ROOTFS_RW
   bool "remount root filesystem read-write during boot"
   default y
   help
     The root filesystem is typically mounted read-only at boot.
     By default, buildroot remounts it in read-write mode early during the
     boot process.
     Say no here if you would rather like your root filesystem to remain
     read-only.
     If unsure, say Y.
 
config BR2_SYSTEM_DHCP
   string "Network interface to configure through DHCP"
   default ""
   depends on BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN || BR2_PACKAGE_SYSTEMD_NETWORKD
   help
     Enter here the name of the network interface (E.G. eth0) to
     automatically configure through DHCP at bootup.
 
     If left empty, no automatic DHCP requests will take place.
 
     For more complicated network setups use an overlay to overwrite
     /etc/network/interfaces or add a networkd configuration file.
 
comment "automatic network configuration via DHCP needs ifupdown or busybox or networkd"
   depends on !(BR2_PACKAGE_BUSYBOX || BR2_PACKAGE_IFUPDOWN || BR2_PACKAGE_SYSTEMD_NETWORKD)
 
endif # BR2_ROOTFS_SKELETON_DEFAULT
 
config BR2_SYSTEM_DEFAULT_PATH
   string "Set the system's default PATH"
   default "/bin:/sbin:/usr/bin:/usr/sbin"
   help
     Sets the system's default PATH. It is being used in
     /etc/profile in the skeleton-init-common package and by some
     daemons.
 
     The default should work in most cases.
 
config BR2_ENABLE_LOCALE_PURGE
   bool "Purge unwanted locales"
   default y
   help
     Explicitly specify what locales to install on target. If N
     then all locales supported by packages are installed.
 
config BR2_ENABLE_LOCALE_WHITELIST
   string "Locales to keep"
   default "C en_US"
   depends on BR2_ENABLE_LOCALE_PURGE
   help
     Whitespace seperated list of locales to allow on target.
     Locales not listed here will be removed from the target.
     See 'locale -a' on your host for a list of locales available
     on your build host, or have a look in /usr/share/locale in
     the target file system for available locales.
 
     Notice that listing a locale here doesn't guarantee that it
     will be available on the target - That purely depends on the
     support for that locale in the selected packages.
 
config BR2_GENERATE_LOCALE
   string "Generate locale data"
   default ""
   depends on \
       (BR2_TOOLCHAIN_BUILDROOT_UCLIBC && BR2_ENABLE_LOCALE) || \
       BR2_TOOLCHAIN_USES_GLIBC
   help
     Generate support for a list of locales. Locales can be
     specified with or without encoding, when no encoding is
     specified, UTF-8 is assumed. Examples of locales: en_US,
     fr_FR.UTF-8.
 
config BR2_SYSTEM_ENABLE_NLS
   bool "Enable Native Language Support (NLS)"
   depends on BR2_USE_WCHAR
   #  - glibc has built-in NLS support, but anyway doesn't
   #    support static linking
   #  - musl and uclibc support static linking, but they don't
   #    have built-in NLS support, which is provided by the
   #    libintl library from gettext. The fact that it is a
   #    separate library causes too many problems for static
   #    linking.
   depends on !BR2_STATIC_LIBS
   select BR2_PACKAGE_GETTEXT if !BR2_TOOLCHAIN_HAS_FULL_GETTEXT
   help
     This option will enable Native Language Support, which will
     allow software packages to support translations.
 
comment "NLS support needs a toolchain w/ wchar, dynamic library"
   depends on !BR2_USE_WCHAR || BR2_STATIC_LIBS
 
config BR2_TARGET_TZ_INFO
   bool "Install timezone info"
   select BR2_PACKAGE_TZDATA if BR2_TOOLCHAIN_USES_GLIBC
   select BR2_PACKAGE_TZDATA if BR2_TOOLCHAIN_USES_MUSL
   select BR2_PACKAGE_TZ if BR2_TOOLCHAIN_USES_UCLIBC
   help
     Say 'y' here to install timezone info.
 
if BR2_TARGET_TZ_INFO
 
config BR2_TARGET_TZ_ZONELIST
   string "timezone list"
   default "default"
   help
     Space-separated list of time zones to compile.
 
     The value "default" includes all commonly used time zones. Note
     that this set consumes around 5.5M for glibc and 2.1M for uClibc.
 
     The full list is the list of files in the time zone database source,
     not including the build and .tab files.
 
config BR2_TARGET_LOCALTIME
   string "default local time"
   default "Etc/UTC"
   help
     The time zone to install as the default local time, expressed as a
     tzdata location, such as:
       Etc/UTC             (the default)
       GMT
       Europe/Paris
       America/New_York
       Pacific/Wallis
       ...
 
endif # BR2_TARGET_TZ_INFO
 
config BR2_ROOTFS_USERS_TABLES
   string "Path to the users tables"
   help
     Specify a space-separated list of users table locations,
     that will be passed to the mkusers utility to create
     users on the system, with home directory, password, etc.
 
     See manual for details on the usage and syntax of these files.
 
config BR2_ROOTFS_OVERLAY
   string "Root filesystem overlay directories"
   default ""
   help
     Specify a list of directories that are copied over the target
     root filesystem after the build has finished and before it is
     packed into the selected filesystem images.
 
     They are copied as-is into the rootfs, excluding files ending with
     ~ and .git, .svn and .hg directories.
 
config BR2_ROOTFS_POST_BUILD_SCRIPT
   string "Custom scripts to run before creating filesystem images"
   default ""
   help
     Specify a space-separated list of scripts to be run after the build
     has finished and before Buildroot starts packing the files into
     selected filesystem images.
 
     This gives users the opportunity to do board-specific cleanups,
     add-ons and the like, so the generated files can be used directly
     without further processing.
 
     These scripts are called with the target directory name as first
     argument. Make sure the exit code of those scripts are 0, otherwise
     make will stop after calling them.
 
config BR2_ROOTFS_POST_FAKEROOT_SCRIPT
   string "Custom scripts to run inside the fakeroot environment"
   default ""
   help
     Specify a space-separated list of scripts to be run at the end
     of the fakeroot script right before the image(s) are actually
     generated.
 
     This gives users the opportunity to do customisations of the
     content of the rootfs, which would otherwise require root
     rights.
 
     These scripts are called with the target directory name as
     first argument. The build will fail on the first scripts that
     exits with a non-zero exit code.
 
     Note that Buildroot already provides mechanisms to customise
     the content of the rootfs:
 
       - BR2_ROOTFS_STATIC_DEVICE_TABLE
           to create arbitrary entries statically in /dev
 
       - BR2_ROOTFS_DEVICE_TABLE
           to set arbitrary permissions as well as extended attributes
           (such as capabilities) on files and directories,
 
       - BR2_ROOTFS_USERS_TABLES:
           to create arbitrary users and their home directories
 
     It is highly recommended to use those mechanisms if possible,
     rather than using custom fakeroot scripts.
 
config BR2_ROOTFS_POST_IMAGE_SCRIPT
   string "Custom scripts to run after creating filesystem images"
   default ""
   help
     Specify a space-separated list of scripts to be run after
     the build has finished and after Buildroot has packed the
     files into selected filesystem images.
 
     This can for example be used to call a tool building a
     firmware image from different images generated by Buildroot,
     or automatically extract the tarball root filesystem image
     into some location exported by NFS, or any other custom
     action.
 
     These scripts are called with the images directory name as
     first argument. The script is executed from the main Buildroot
     source directory as the current directory.
 
config BR2_ROOTFS_POST_SCRIPT_ARGS
   string "Extra arguments passed to custom scripts"
   depends on BR2_ROOTFS_POST_BUILD_SCRIPT != "" \
       || BR2_ROOTFS_POST_FAKEROOT_SCRIPT != "" \
       || BR2_ROOTFS_POST_IMAGE_SCRIPT != ""
   help
     Pass these additional arguments to each post-build or post-image
     scripts.
 
     Note that all the post-build and post-image scripts will be passed
     the same set of arguments, you can not pass different arguments to
     each script.
 
     Note also, as stated in their respective help text, that the first
     argument to each post-build or post-image script is the target
     directory / images directory. The arguments in this option will be
     passed *after* those.
 
endmenu