MIPS: OCTEON: add fixed-link nodes to in-kernel device tree

Currently OCTEON ethernet falls back to phyless operation on
boards where we have no known PHY address or a fixed-link node.
Add fixed-link support for boards that need it, so we can clean up
the platform code and ethernet driver from some legacy code.

Signed-off-by: Aaro Koskinen <aaro.koskinen@iki.fi>
Signed-off-by: Paul Burton <paul.burton@mips.com>
Cc: linux-mips@vger.kernel.org
This commit is contained in:
Aaro Koskinen 2019-02-05 00:41:45 +02:00 committed by Paul Burton
parent 3315b6b336
commit 565485b8b5
No known key found for this signature in database
GPG Key ID: 3EA79FACB57500DD
2 changed files with 32 additions and 0 deletions

View File

@ -180,10 +180,18 @@
ethernet@0 { ethernet@0 {
phy-handle = <&phy2>; phy-handle = <&phy2>;
cavium,alt-phy-handle = <&phy100>; cavium,alt-phy-handle = <&phy100>;
fixed-link {
speed = <1000>;
full-duplex;
};
}; };
ethernet@1 { ethernet@1 {
phy-handle = <&phy3>; phy-handle = <&phy3>;
cavium,alt-phy-handle = <&phy101>; cavium,alt-phy-handle = <&phy101>;
fixed-link {
speed = <1000>;
full-duplex;
};
}; };
ethernet@2 { ethernet@2 {
phy-handle = <&phy4>; phy-handle = <&phy4>;

View File

@ -458,6 +458,23 @@ static bool __init octeon_has_88e1145(void)
!OCTEON_IS_MODEL(OCTEON_CN56XX); !OCTEON_IS_MODEL(OCTEON_CN56XX);
} }
static bool __init octeon_has_fixed_link(int ipd_port)
{
switch (cvmx_sysinfo_get()->board_type) {
case CVMX_BOARD_TYPE_CN3005_EVB_HS5:
case CVMX_BOARD_TYPE_CN3010_EVB_HS5:
case CVMX_BOARD_TYPE_CN3020_EVB_HS5:
case CVMX_BOARD_TYPE_CUST_NB5:
case CVMX_BOARD_TYPE_EBH3100:
/* Port 1 on these boards is always gigabit. */
return ipd_port == 1;
case CVMX_BOARD_TYPE_BBGW_REF:
/* Ports 0 and 1 connect to the switch. */
return ipd_port == 0 || ipd_port == 1;
}
return false;
}
static void __init octeon_fdt_set_phy(int eth, int phy_addr) static void __init octeon_fdt_set_phy(int eth, int phy_addr)
{ {
const __be32 *phy_handle; const __be32 *phy_handle;
@ -592,6 +609,7 @@ static void __init octeon_fdt_pip_port(int iface, int i, int p, int max)
int eth; int eth;
int phy_addr; int phy_addr;
int ipd_port; int ipd_port;
int fixed_link;
snprintf(name_buffer, sizeof(name_buffer), "ethernet@%x", p); snprintf(name_buffer, sizeof(name_buffer), "ethernet@%x", p);
eth = fdt_subnode_offset(initial_boot_params, iface, name_buffer); eth = fdt_subnode_offset(initial_boot_params, iface, name_buffer);
@ -609,6 +627,12 @@ static void __init octeon_fdt_pip_port(int iface, int i, int p, int max)
phy_addr = cvmx_helper_board_get_mii_address(ipd_port); phy_addr = cvmx_helper_board_get_mii_address(ipd_port);
octeon_fdt_set_phy(eth, phy_addr); octeon_fdt_set_phy(eth, phy_addr);
fixed_link = fdt_subnode_offset(initial_boot_params, eth, "fixed-link");
if (fixed_link < 0)
WARN_ON(octeon_has_fixed_link(ipd_port));
else if (!octeon_has_fixed_link(ipd_port))
fdt_nop_node(initial_boot_params, fixed_link);
} }
static void __init octeon_fdt_pip_iface(int pip, int idx) static void __init octeon_fdt_pip_iface(int pip, int idx)