12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- TI SysCon Reset Controller
- =======================
- Almost all SoCs have hardware modules that require reset control in addition
- to clock and power control for their functionality. The reset control is
- typically provided by means of memory-mapped I/O registers. These registers are
- sometimes a part of a larger register space region implementing various
- functionalities. This register range is best represented as a syscon node to
- allow multiple entities to access their relevant registers in the common
- register space.
- A SysCon Reset Controller node defines a device that uses a syscon node
- and provides reset management functionality for various hardware modules
- present on the SoC.
- SysCon Reset Controller Node
- ============================
- Each of the reset provider/controller nodes should be a child of a syscon
- node and have the following properties.
- Required properties:
- --------------------
- - compatible : Should be,
- "ti,k2e-pscrst"
- "ti,k2l-pscrst"
- "ti,k2hk-pscrst"
- "ti,syscon-reset"
- - #reset-cells : Should be 1. Please see the reset consumer node below
- for usage details
- - ti,reset-bits : Contains the reset control register information
- Should contain 7 cells for each reset exposed to
- consumers, defined as:
- Cell #1 : offset of the reset assert control
- register from the syscon register base
- Cell #2 : bit position of the reset in the reset
- assert control register
- Cell #3 : offset of the reset deassert control
- register from the syscon register base
- Cell #4 : bit position of the reset in the reset
- deassert control register
- Cell #5 : offset of the reset status register
- from the syscon register base
- Cell #6 : bit position of the reset in the
- reset status register
- Cell #7 : Flags used to control reset behavior,
- availible flags defined in the DT include
- file <dt-bindings/reset/ti-syscon.h>
- SysCon Reset Consumer Nodes
- ===========================
- Each of the reset consumer nodes should have the following properties,
- in addition to their own properties.
- Required properties:
- --------------------
- - resets : A phandle to the reset controller node and an index number
- to a reset specifier as defined above.
- Please also refer to Documentation/devicetree/bindings/reset/reset.txt for
- common reset controller usage by consumers.
- Example:
- --------
- The following example demonstrates a syscon node, the reset controller node
- using the syscon node, and a consumer (a DSP device) on the TI Keystone 2
- 66AK2E SoC.
- / {
- soc {
- psc: power-sleep-controller@2350000 {
- compatible = "syscon", "simple-mfd";
- reg = <0x02350000 0x1000>;
- pscrst: reset-controller {
- compatible = "ti,k2e-pscrst", "ti,syscon-reset";
- #reset-cells = <1>;
- ti,reset-bits = <
- 0xa3c 8 0xa3c 8 0x83c 8 (ASSERT_CLEAR | DEASSERT_SET | STATUS_CLEAR) /* 0: dsp0 */
- 0xa40 5 0xa44 3 0 0 (ASSERT_SET | DEASSERT_CLEAR | STATUS_NONE) /* 1: example */
- >;
- };
- };
- dsp0: dsp0 {
- ...
- resets = <&pscrst 0>;
- ...
- };
- };
- };
|