On Tue, Apr 21, 2020 at 07:45:47PM -0600, Robert Hancock wrote:
Hi Andre/Russell,
Just wondering where things got to with the changes for SGMII on Xilinx
axienet that you were discussing (below)? I am looking into our Xilinx setup
using 1000BaseX SFP and trying to get it working "properly" with newer
kernels. My understanding is that the requirements for 1000BaseX and SGMII
are somewhat similar. I gathered that SGMII was working somewhat already,
but that not all link modes had been tested. However, it appears 1000BaseX
is not yet working in the stock kernel.
The way I had this working before with a 4.19-based kernel was basically a
hack to phylink to allow the Xilinx PCS/PMA PHY to be configured
sufficiently as a PHY for it to work, and mostly ignored the link status of
the SFP PHY itself, even though we were using in-band signalling mode with
an SFP module. That was using this patch:
https://patchwork.ozlabs.org/project/netdev/patch/1559330285-30246-5-git-send-email-hancock@xxxxxxxxxxxxx/
Of course, that's basically just a hack which I suspect mostly worked by
luck. I see that there are some helpers that were added to phylink to allow
setting PHY advertisements and reading PHY status from clause 22 PHY
devices, so I'm guessing that is the way to go in this case? Something like:
axienet_mac_config: if using in-band mode, use
phylink_mii_c22_pcs_set_advertisement to configure the Xilinx PHY.
axienet_mac_pcs_get_state: use phylink_mii_c22_pcs_get_state to get the MAC
PCS state from the Xilinx PHY
axienet_mac_an_restart: if using in-band mode, use
phylink_mii_c22_pcs_an_restart to restart autonegotiation on Xilinx PHY
To use those c22 functions, we need to find the mdio_device that's
referenced by the phy-handle in the device tree - I guess we can just use
some of the guts of of_phy_find_device to do that?
Please see the code for DPAA2 - it's changed slightly since I sent a
copy to the netdev mailing list, and it still isn't clear whether this
is the final approach (DPAA2 has some fun stuff such as several
different PHYs at address 0.) NXP basically didn't like the approach
I had in the patches I sent to netdev, we had a call, they presented
an alternative appraoch, I implemented it, then they decided my
original approach was the better solution for their situation.
See http://git.armlinux.org.uk/cgit/linux-arm.git/log/?h=cex7
specifically the patches from:
"dpaa2-mac: add 1000BASE-X/SGMII PCS support"
through to:
"net: phylink: add interface to configure clause 22 PCS PHY"
You may also need some of the patches further down in the net-queue
branch:
"net: phylink: avoid mac_config calls"
through to:
"net: phylink: rejig link state tracking"