syscon-reset.txt 3.65 KB
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 "syscon-reset"
 - #reset-cells		: Should be 1. Please see the reset consumer node below
			  for usage details
 - #address-cells	: Should be 1
 - #size-cells		: Should be 0

SysCon Reset Child Node
============================
Each reset provider/controller node should have a child node for each reset
it would like to expose to consumers.

Required properties:
--------------------
 - reg			: Reset's logical number, this value will be used by
			  consumers of this reset as their reset specifier value
 - reset-control	: Contains the reset control register information,
			  Should contain 3 cells defined as:
			    Cell #1 : register offset of the reset
			              control/status register from the syscon
			              register base
			    Cell #2 : bit shift value for the reset in the
			              respective reset control/status register
			    Cell #3 : polarity of the reset bit, should use the
				      definitions defined in the DT include file
					include/dt-bindings/reset/syscon.h
				      Should be RESET_ASSERT_SET for resets
				      that are asserted when the bit is set,
				      and RESET_ASSERT_CLEAR for resets that
				      are asserted when the bit is cleared.

Optional properties:
--------------------
 - reset-status		: Contains the reset status register information. The
			  contents of this property are the equivalent to
			  reset-control as defined above. If this property is
			  not present and the toggle flag is not set, the
			  reset register is assumed to be the same as the
			  control register
 - toggle		: Mark this reset as a toggle only reset, this is used
			  when no status register is available.

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 and a reset specifier, the reset specifier should
		  be a numerical address matching the desired reset as set
		  by the reg property 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
Edison SoC.

/ {
	soc {
		psc: power-sleep-controller@02350000 {
			compatible = "syscon", "simple-mfd";
			reg = <0x02350000 0x1000>;

			pscrst: psc-reset {
				compatible = "syscon-reset";
				#reset-cells = <1>;
				#address-cells = <1>;
				#size-cells = <0>;

				dsp@0 {
					reg = <0>;
					reset-control = <0xa3c 8 RESET_ASSERT_CLEAR>;
					reset-status = <0x83c 8 RESET_ASSERT_CLEAR>;
				};
			};
		};

		dsp0: dsp0 {
			...
			resets = <&pscrst 0>;
			...
		};
	};
};