4.9. Kconfig Diffs¶
For packages using Kconfig as their configuration system, PTXdist can generate their config file from another reference config file and a Kconfig diff on the fly. This mechanism can be used to build configuration variants of a kernel or barebox package. For example, a “debug” kernel package can refer to the config file of the “production” kernel as its reference config file, and its Kconfig diff then only contains the Kconfig symbols that were changed in the “debug” variant:
|release config symbol||debug kconfig diff||resulting debug config symbol|
|# CONFIG_ARCH_MULTI_V6 is not set||# CONFIG_ARCH_MULTI_V6 is not set|
|# CONFIG_CGROUP_DEBUG is not set||CONFIG_CGROUP_DEBUG=y||CONFIG_CGROUP_DEBUG=y|
|# CONFIG_DEBUG_PREEMPT is not set||CONFIG_DEBUG_PREEMPT=y||CONFIG_DEBUG_PREEMPT=y|
|CONFIG_WATCHDOG=y||# CONFIG_WATCHDOG is not set||# CONFIG_WATCHDOG is not set|
|CONFIG_WATCHDOG_CORE=y||# CONFIG_WATCHDOG_CORE is undefined|
|CONFIG_BCM2835_WDT=y||# CONFIG_BCM2835_WDT is undefined|
Kconfig does not write symbols to the config file that have unfulfilled dependencies (e.g., in the
CONFIG_BCM2835_WDT depend on
Those symbols that are not present in the resulting debug config file are represented as
undefined in the diff.
The first line of the Kconfig diff file contains the MD5 sum of the reference config file. PTXdist uses this checksum to detect when the reference config has changed, in which case the diff needs to be regenerated from the package’s config file, and to make sure that the diff is applicable to the reference config.
Using Kconfig diffs¶
The main part is setting the
<PKG>_REF_CONFIG variable of a package to the reference config
file, for example:
# rules/kernel.make: KERNEL_CONFIG := $(call ptx/in-platformconfigdir, kernelconfig-release)
# rules/kernel-debug.make: KERNEL_DEBUG_CONFIG := $(call ptx/in-platformconfigdir, kernelconfig-debug) KERNEL_DEBUG_REF_CONFIG := $(call ptx/in-platformconfigdir, kernelconfig-release)
PTXdist will now automatically generate
kernelconfig-debug.diff whenever doing and oldconfig or menuconfig on the kernel-debug
If any symbols were changed by that operation, both the
kernelconfig-debug.diff and the
kernelconfig-debug are updated afterwards.
Kconfig diffs and layers¶
PTXdist uses the same diff mechanism whenever the config file of a Kconfig-style package is changed in an inherited layer (see Layers in PTXdist). In that case, the diff is calculated between the package’s config file in the base layer and the package’s (adapted) config file in the current layer.
When using both
<PKG>_REF_CONFIG and inter-layer Kconfig diffs, the inter-layer diff takes
precedence, and the reference config file in the inherited layer is ignored.
In the following example, arrows represent the config diff relation: