lk2nd uses control DT to store the per-device configuration. Often the initial bootloader on the device doesn't allow to pick unique DT for each device, so lk2nd relies on a special DT model to allow multiple devices share the same DT file.
Note
lk2nd DT format is custom and is not compatible with industry-standard DT bindings used by Linux. lk2nd, however, tries to keep it's custom bindings similar to industry-standard where it makes sense.
Generally an lk2nd file contains two parts:
- Root node. This node contains information needed by the previous bootloader.
- lk2nd node. This node contains all device-specific information used by lk2nd.
This section would generally only contain msm-id and board-id. For lk2nd this node should only contain the properties or nodes that the stock bootloader wants to see to boot the image. lk2nd generally doesn't use this data.
/ {
qcom,msm-id = <QCOM_ID_MSM8916 0>;
qcom,board-id = <0xCE08FF01 1>, <0xCE08FF01 3>, <0xCE08FF01 7>;
};
This section would contain information about all the devices supported by this specific dt file. Each supported device is listed there in a dedicated subnode. If it's well-known that the dt file will only be matched by a single device, then the device-specific information may be placed into the top level lk2nd node.
&lk2nd {
a3lte {
model = "Samsung Galaxy A3 (SM-A300F)";
/* ... */
};
gt58lte { /* ... */ };
};
&lk2nd {
model = "Huawei Y635-L01";
/* ... */
};
Device node contains all the information needed by lk2nd.
Every device should list it's model
and list of compatible
values.
Note that model
should contain the marketing name of the device (what
was written on the box) and not whatever can be found in the downsteam DT.
Additionally lk2nd,dtb-files
property can be present with a list of possible
device-tree names for this device. Don't add qcom/
or qcom-
prefix and .dtb
suffix to the values since lk2nd will add them as necessary.
gt58lte {
model = "Samsung Galaxy Tab A 8.0 (LTE, SM-T355)";
compatible = "samsung,gt58lte", "samsung,gt58";
lk2nd,dtb-files = "msm8916-samsung-gt58";
};
When the DT file contains multiple devices, lk2nd needs a way to know, on which of them it has booted. There are multple match properties to help that.
lk2nd can check the cmdline from the previous bootloader and match the
android.bootloader=
argument with an expression:
lk2nd,match-bootloader = "A300F*";
Like with match-bootloader, but check the whole cmdline for a match:
lk2nd,match-cmdline = "*lenok*";
lk2nd can check the cmdline from the previous bootloader and match the
android.device=
argument with an expression:
lk2nd,match-device = "victara";
In some cases there is no useful cmdline param to match against, so it's possible to use a list of possible display panels and match if one of them is present. See [Panel selection](#Panel selection)
lk2nd,match-panel;
panel { /* ... */ };
Many devices ship with one of multiple possible display modules. lk2nd can patch the device-tree of the OS to insert a compatible value for the detected display. Please list all possible panels when you add a new device, if you are planning to make use of this.
panel {
compatible = "wingtech,wt88047-panel";
qcom,mdss_dsi_r69431_720p_video {
compatible = "wingtech,sharp-r69431";
};
qcom,mdss_dsi_nt35521_720p_video {
compatible = "wingtech,auo-nt35521";
};
/* ... */
};
For some devices it may be needed to let lk2nd know what msm- and board-id to use when booting the downstream kernel. You can specify them in the device node and lk2nd will use them instead of autodetecting.
qcom,msm-id = <QCOM_ID_MSM8916 0>;
qcom,board-id = <0xCE08FF01 1>;
lk2nd provides a set of optional nodes, following a simple driver model.
If a device has non-default keymap for volume and power keys, it
can be overriden by the gpio-keys
node. This node follows upstream
binding with an exception of the new lk2nd,code
property.
gpio-keys {
compatible = "gpio-keys";
volume-down {
lk2nd,code = <KEY_VOLUMEDOWN>;
gpios = <&tlmm 81 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
};
home {
lk2nd,code = <KEY_HOME>;
gpios = <&pmic 3 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
};
};