Формат исходного кода дерева устройств (DTS) представляет собой текстовое представление дерева устройств (DT). Компилятор дерева устройств (DTC) обрабатывает этот формат, преобразуя его в двоичное дерево устройств, которое соответствует форме, ожидаемой ядром Linux.
Используйте ссылки
Проект DTC (компилятор дерева устройств + патчи наложения) описывает формат DTS в файлах dtc-format.txt и manual.txt . Формат и правила DTO описаны в файле dt-object-internal.txt . В этих документах описывается, как обновить основное дерево устройств, используя узел fragment@x и синтаксис __overlay__ в дереве устройств наложения. Например:
/ { fragment@0 { target = <&some_node>; __overlay__ { some_prop = "okay"; ... }; }; };
Однако Google настоятельно рекомендует не использовать fragment@x и синтаксис __overlay__ , а вместо этого использовать эталонный синтаксис. Например:
&some_node {
some_prop = "okay";
...
}; Синтаксис ссылок компилируется dtc в тот же объект, что и выше, с использованием синтаксиса __overlay__ . Этот синтаксис не требует нумерации фрагментов, что позволяет легко читать и записывать наложенные DTS-файлы. Если ваш dtc не поддерживает этот синтаксический сахар, используйте dtc из AOSP .
Используйте этикетки
Чтобы разрешить неопределенные ссылки на узлы, отсутствующие во время компиляции, файл DT .dts наложения должен содержать тег /plugin/ в своем заголовке. Например:
/dts-v1/; /plugin/;
Отсюда вы можете указать узлы для наложения, используя ссылку, которая представляет собой абсолютный путь к узлу с префиксом амперсанда (&). Например, для node@0 в основном дереве данных:
| Определите метки в основном файле DT... | ...а затем используйте этикетки. |
|---|---|
[my_main_dt.dts] /dts-v1/; / { my_node: node@0 { status = "disabled"; my_child: child@0 { value = <0xffffffff>; }; }; }; | [my_overlay_dt.dts] /dts-v1/; /plugin/; &my_node { status = "okay"; }; &my_child { value = <0x1>; }; |
Переопределение
Если свойство целевого объекта существует в основном объекте DTO, оно переопределяется после DTO; в противном случае оно добавляется. Например:
| main.dts | overlay.dts | Объединенный результат |
|---|---|---|
[my_main_dt.dts] /dts-v1/; / { compatible = "corp,foo"; my_node: node@0 { status = "disabled"; }; }; | [my_overlay_dt.dts] /dts-v1/; /plugin/; &my_node { status = "okay"; }; | /dts-v1/; / { compatible = "corp,foo"; ... node@0 { linux,phandle = <0x1>; phandle = <0x1>; status = "okay"; }; }; |
Добавить
Если свойство целевого объекта, на которое ссылается объект, отсутствует в основном DT, оно добавляется после DTO. Например:
| main.dts | overlay.dts | Объединенный результат |
|---|---|---|
[my_main_dt.dts] /dts-v1/; / { compatible = "corp,foo"; my_node: node@0 { status = "okay"; }; }; | [my_overlay_dt.dts] /dts-v1/; /plugin/; &my_node { new_prop = "bar"; }; | /dts-v1/; / { compatible = "corp,foo"; ... node@0 { linux,phandle = <0x1>; phandle = <0x1>; status = "okay"; new_prop = "bar"; }; }; |
Дочерние узлы
Примеры синтаксиса дочерних узлов:
| main.dts | overlay.dts | Объединенный результат |
|---|---|---|
[my_main_dt.dts] /dts-v1/; / { compatible = "corp,foo"; my_nodes: nodes { compatible = "corp,bar"; node@0 { status = "disabled"; }; }; }; | [my_overlay_dt.dts] /dts-v1/; /plugin/; &my_nodes { new_prop1 = "abc"; node@0 { status = "okay"; new_prop2 = "xyz"; }; }; | /dts-v1/; / { compatible = "corp,foo"; ... nodes { linux,phandle = <0x1>; phandle = <0x1>; compatible = "corp,bar"; new_prop1 = "abc"; node@0 { linux,phandle = <0x2>; phandle = <0x2>; status = "okay"; new_prop2 = "xyz"; }; }; }; |