acd7aaf51b
Since commit bbc4d71d63549bc ("net: phy: realtek: fix rtl8211e rx/tx delay config"), the Realtek PHY driver will override any TX/RX delay set by hardware straps if the phy-mode device property does not match. This is causing problems on SynQuacer based platforms (the only SoC that incorporates the netsec hardware), since many were built with this Realtek PHY, and shipped with firmware that defines the phy-mode as 'rgmii', even though the PHY is configured for TX and RX delay using pull-ups. From the driver's perspective, we should not make any assumptions in the general case that the PHY hardware does not require any initial configuration. However, the situation is slightly different for ACPI boot, since it implies rich firmware with AML abstractions to handle hardware details that are not exposed to the OS. So in the ACPI case, it is reasonable to assume that the PHY comes up in the right mode, regardless of whether the mode is set by straps, by boot time firmware or by AML executed by the ACPI interpreter. So let's ignore the 'phy-mode' device property when probing the netsec driver in ACPI mode, and hardcode the mode to PHY_INTERFACE_MODE_NA, which should work with any PHY provided that it is configured by the time the driver attaches to it. While at it, document that omitting the mode is permitted for DT probing as well, by setting the phy-mode DT property to the empty string. Fixes: 533dd11a12f6 ("net: socionext: Add Synquacer NetSec driver") Signed-off-by: Ard Biesheuvel <ardb@kernel.org> Reviewed-by: Ilias Apalodimas <ilias.apalodimas@linaro.org> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Link: https://lore.kernel.org/r/20201018163625.2392-1-ardb@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
57 lines
1.9 KiB
Plaintext
57 lines
1.9 KiB
Plaintext
* Socionext NetSec Ethernet Controller IP
|
|
|
|
Required properties:
|
|
- compatible: Should be "socionext,synquacer-netsec"
|
|
- reg: Address and length of the control register area, followed by the
|
|
address and length of the EEPROM holding the MAC address and
|
|
microengine firmware
|
|
- interrupts: Should contain ethernet controller interrupt
|
|
- clocks: phandle to the PHY reference clock
|
|
- clock-names: Should be "phy_ref_clk"
|
|
- phy-mode: See ethernet.txt file in the same directory
|
|
- phy-handle: See ethernet.txt in the same directory.
|
|
|
|
- mdio device tree subnode: When the Netsec has a phy connected to its local
|
|
mdio, there must be device tree subnode with the following
|
|
required properties:
|
|
|
|
- #address-cells: Must be <1>.
|
|
- #size-cells: Must be <0>.
|
|
|
|
For each phy on the mdio bus, there must be a node with the following
|
|
fields:
|
|
- compatible: Refer to phy.txt
|
|
- reg: phy id used to communicate to phy.
|
|
|
|
Optional properties: (See ethernet.txt file in the same directory)
|
|
- dma-coherent: Boolean property, must only be present if memory
|
|
accesses performed by the device are cache coherent.
|
|
- max-speed: See ethernet.txt in the same directory.
|
|
- max-frame-size: See ethernet.txt in the same directory.
|
|
|
|
The MAC address will be determined using the optional properties
|
|
defined in ethernet.txt. The 'phy-mode' property is required, but may
|
|
be set to the empty string if the PHY configuration is programmed by
|
|
the firmware or set by hardware straps, and needs to be preserved.
|
|
|
|
Example:
|
|
eth0: ethernet@522d0000 {
|
|
compatible = "socionext,synquacer-netsec";
|
|
reg = <0 0x522d0000 0x0 0x10000>, <0 0x10000000 0x0 0x10000>;
|
|
interrupts = <GIC_SPI 176 IRQ_TYPE_LEVEL_HIGH>;
|
|
clocks = <&clk_netsec>;
|
|
clock-names = "phy_ref_clk";
|
|
phy-mode = "rgmii";
|
|
max-speed = <1000>;
|
|
max-frame-size = <9000>;
|
|
phy-handle = <&phy1>;
|
|
|
|
mdio {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
phy1: ethernet-phy@1 {
|
|
compatible = "ethernet-phy-ieee802.3-c22";
|
|
reg = <1>;
|
|
};
|
|
};
|