[PATCH v2 5/5] Documentation: Add documentation for APM X-Gene SATA DTS binding
Arnd Bergmann
arnd at arndb.de
Sun Nov 10 15:39:09 EST 2013
On Saturday 09 November 2013, Loc Ho wrote:
> Documentation: Add documentation for APM X-Gene SATA DTS binding
>
> Signed-off-by: Loc Ho <lho at apm.com>
> Signed-off-by: Tuan Phan <tphan at apm.com>
> Signed-off-by: Suman Tripathi <stripathi at apm.com>
> ---
> .../devicetree/bindings/ata/apm-xgene.txt | 84 ++++++++++++++++++++
Please Cc the devicetree-discuss mailing list for the binding submission.
> +SATA nodes are defined to describe on-chip Serial ATA controllers.
> +Each SATA controller (pair of ports) have its own node.
> +
> +Required properties:
> +- compatible : Shall be "apm,xgene-ahci"
> +- reg : First memory resource shall be the AHCI memory resource
> + Second memory resource shall be the Serdes memory resource
> + Third memory resource shall be the optional Serdes
> + memory resource if mux'ed with another IP
> +- interrupt-parent : Interrupt controller
> +- interrupts : Interrupt mapping for SATA IRQ
> +- #clock-cells : Shall be value of 1
Why is there a #clock-cells entry here?
> +- clocks : Reference to the clock entry
> +- clock-names : Shall be "eth01clk", "eth23clk", or "eth45clk".
This makes no sense. The clock-names property needs to have a fixed
string according to the name of the clock input signal of the hardware,
not a name of the clock provider.
> +- serdes-diff-clk : Shall be 0 for external, 1 internal differential,
> + or 2 internal single ended clock. Default is 0.
> +- gen-sel : Shall be 1 (force Gen1), 2 (Force Gen2, or 3 Gen3).
> + Default is 3.
> +- EQA1 : Serdes EQ parameter for A1 chip. Default is 9.
> +- EQ : Serdes EQ parameter for non-A1 chip. Default is 2.
> +- GENAVG : Enable averaging Serdes calculation. Default is 0 for
> + A1 chip and 1 for non-A1 chip.
> +- LBA1 : Serdes loopback buffer for A1 chip. Default is 1;
> +- LB : Serdes loopback buffer for non-A1 chip. Default is 0;
> +- LCA1 : Serdes loopback enable control for A1 chip. Default
> + is 1;
> +- LC : Serdes loopback enable control for non-A1 chip.
> + Default is 0;
> +- CDRA1 : Serdes SPD select CDR for A1 chip. Default is 5.
> +- CDR : Serdes SPD select CDR for non-A1 chip. Default is 5.
> +- PQA1 : Serdes PQ for A1 chip. Default is 8.
> +- PQ : Serdes PQ for non-A1 chip. Default is 0xA.
> +- coherent : Enable coherent (1 = enable, 0 = disable).
> + Default is 1.
This looks like a really bad binding. I would suggest that instead of having
individual register values in here, you hardwire the settings in the driver
based on the compatible string. It's pretty crazy to put register-level configuration
in the DT like this.
Further, you should probably use the generic PHY binding to create a separate driver
for the serdes PHY,
Arnd
More information about the linux-arm-kernel
mailing list