|  | * Generic PM domains | 
|  |  | 
|  | System on chip designs are often divided into multiple PM domains that can be | 
|  | used for power gating of selected IP blocks for power saving by reduced leakage | 
|  | current. | 
|  |  | 
|  | This device tree binding can be used to bind PM domain consumer devices with | 
|  | their PM domains provided by PM domain providers. A PM domain provider can be | 
|  | represented by any node in the device tree and can provide one or more PM | 
|  | domains. A consumer node can refer to the provider by a phandle and a set of | 
|  | phandle arguments (so called PM domain specifiers) of length specified by the | 
|  | #power-domain-cells property in the PM domain provider node. | 
|  |  | 
|  | ==PM domain providers== | 
|  |  | 
|  | Required properties: | 
|  | - #power-domain-cells : Number of cells in a PM domain specifier; | 
|  | Typically 0 for nodes representing a single PM domain and 1 for nodes | 
|  | providing multiple PM domains (e.g. power controllers), but can be any value | 
|  | as specified by device tree binding documentation of particular provider. | 
|  |  | 
|  | Optional properties: | 
|  | - power-domains : A phandle and PM domain specifier as defined by bindings of | 
|  | the power controller specified by phandle. | 
|  | Some power domains might be powered from another power domain (or have | 
|  | other hardware specific dependencies). For representing such dependency | 
|  | a standard PM domain consumer binding is used. When provided, all domains | 
|  | created by the given provider should be subdomains of the domain | 
|  | specified by this binding. More details about power domain specifier are | 
|  | available in the next section. | 
|  |  | 
|  | Example: | 
|  |  | 
|  | power: power-controller@12340000 { | 
|  | compatible = "foo,power-controller"; | 
|  | reg = <0x12340000 0x1000>; | 
|  | #power-domain-cells = <1>; | 
|  | }; | 
|  |  | 
|  | The node above defines a power controller that is a PM domain provider and | 
|  | expects one cell as its phandle argument. | 
|  |  | 
|  | Example 2: | 
|  |  | 
|  | parent: power-controller@12340000 { | 
|  | compatible = "foo,power-controller"; | 
|  | reg = <0x12340000 0x1000>; | 
|  | #power-domain-cells = <1>; | 
|  | }; | 
|  |  | 
|  | child: power-controller@12340000 { | 
|  | compatible = "foo,power-controller"; | 
|  | reg = <0x12341000 0x1000>; | 
|  | power-domains = <&parent 0>; | 
|  | #power-domain-cells = <1>; | 
|  | }; | 
|  |  | 
|  | The nodes above define two power controllers: 'parent' and 'child'. | 
|  | Domains created by the 'child' power controller are subdomains of '0' power | 
|  | domain provided by the 'parent' power controller. | 
|  |  | 
|  | ==PM domain consumers== | 
|  |  | 
|  | Required properties: | 
|  | - power-domains : A phandle and PM domain specifier as defined by bindings of | 
|  | the power controller specified by phandle. | 
|  |  | 
|  | Example: | 
|  |  | 
|  | leaky-device@12350000 { | 
|  | compatible = "foo,i-leak-current"; | 
|  | reg = <0x12350000 0x1000>; | 
|  | power-domains = <&power 0>; | 
|  | }; | 
|  |  | 
|  | The node above defines a typical PM domain consumer device, which is located | 
|  | inside a PM domain with index 0 of a power controller represented by a node | 
|  | with the label "power". |