About DT binding of reset control
From: Masahiro Yamada
Date: Fri Dec 06 2019 - 03:05:02 EST
Hello, Rob, DT folks,
I am trying to add the reset control into
the Denali NAND controller driver:
Documentation/devicetree/bindings/mtd/denali-nand.txt
drivers/mtd/nand/raw/denali_dt.c
I'd like to get some advice about the DT binding
before the detailed implementation.
The IP datasheet clearly says
two separate reset lines, like this:
rst_n : controller core reset
reg_rst_n: register flip-flop reset
But, in actual SoC integration,
the two reset signals are often tied up together, and
the reset controller only provides 1-bit control.
(The upstream platforms, SoCFPGA, UniPhier,
both are this case.)
In this case, which is more preferred for the
DT binding?
[1] Define two resets explicitly according to the IP spec
Optional properties:
reset-names : contain "nand", "reg"
resets: phandles to the controller core reset, the register reset
Example:
nand {
....
reset-names = "nand", "reg";
resets = <&nand_rst>, <&nand_rst>;
...
};
[2] Allow arbitrary number of reset lines
Optional properties:
resets: phandle(s) to reset(s)
The number of reset lines is SoC-dependent.
Examples:
nand {
resets = <&nand>;
...
};
I guess [1] is more precise as the hardware specification.
But, DT files will end up with giving the same phandle
to both of the two resets.
I think it is OK, but anyway better to ask
before proceeding.
Thanks.
--
Best Regards
Masahiro Yamada