1 # Adding new devices to a device tree
5 ACPI exposes a platform-independent interface for operating systems to perform
6 power management and other platform-level functions. Some operating systems
7 also use ACPI to enumerate devices that are not immediately discoverable, such
8 as those behind I2C or SPI buses (in contrast to PCI). This document discusses
9 the way that coreboot uses the concept of a "device tree" to generate ACPI
10 tables for usage by the operating system.
12 ## Devicetree and overridetree (if applicable)
14 For mainboards that are organized around a "reference board" or "baseboard"
15 model (see ``src/mainboard/google/octopus`` or ``hatch`` for examples), there is
16 typically a devicetree.cb file that all boards share, and any differences for a
17 specific board ("variant") are captured in the overridetree.cb file. Any
18 settings changed in the overridetree take precedence over those in the main
19 devicetree. Note, not all mainboards will have the devicetree/overridetree
20 distinction, and may only have a devicetree.cb file. Or you can always just
21 write the ASL (ACPI Source Language) code yourself.
23 ### Naming and referencing devices
25 When declaring a device, it can optionally be given an alias that can be
26 referred to elsewhere. This is particularly useful to declare a device in one
27 device tree while allowing its configuration to be more easily changed in an
28 overlay. For instance, the AMD Picasso SoC definition
29 (`soc/amd/picasso/chipset.cb`) declares an IOMMU on a PCI bus that is disabled
36 device pci 00.2 alias iommu off end
42 A device based on this SoC can override the configuration for the IOMMU without
43 duplicating addresses, as in
44 `mainboard/google/zork/variants/baseboard/devicetree_trembyle.cb`:
50 device ref iommu on end
56 In this example the override simply enables the IOMMU, but it could also
57 set additional properties (or even add child devices) inside the IOMMU `device`
62 It is important to note that devices that use `device ref` syntax to override
63 previous definitions of a device by alias must be placed at **exactly the same
64 location in the device tree** as the original declaration. If not, this will
65 actually create another device rather than overriding the properties of the
66 existing one. For instance, if the above snippet from `devicetree_trembyle.cb`
67 were written as follows:
71 # NOTE: not inside domain 0!
72 device ref iommu on end
76 Then this would leave the SoC's IOMMU disabled, and instead create a new device
77 with no properties as a direct child of the SoC.
81 Platform independent device drivers are hooked up via entries in a devicetree.
82 See [Driver Devicetree Entries](drivers/dt_entries.md) for more info.
86 - **All fields that are left unspecified in the devicetree are initialized to