Hi Andrew, Thank you for review the code and valuable comments.
On Thu, Sep 08, 2016 at 03:27:27PM +0200, Andrew Lunn wrote: > EXTERNAL EMAIL > > > On Thu, Sep 08, 2016 at 02:47:22PM +0530, Raju Lakkaraju wrote: > > From: Raju Lakkaraju <raju.lakkar...@microsemi.com> > > > > Used Device Tree to configure the MAC Interface as per review comments and > > re-sending code for review > > I don't see anything about device tree in this patch... > Ethernet driver (in my BBB environment, TI cpsw driver) read the device tree phy interface parameter and update in phydev structure. In device tree the following code holds the phy interface configuration. &cpsw_emac0 { phy_id = <&davinci_mdio>, <0>; phy-mode = "rgmii"; }; I tested with different modes by changing device tree parameter (i.e. rmii/rgmii/mii). I have used this parameter to configure the MAC interface. > > > > Signed-off-by: Raju Lakkaraju <raju.lakkar...@microsemi.com> > > --- > > drivers/net/phy/mscc.c | 60 > > ++++++++++++++++++++++++++++++++++++++++++++++++++ > > 1 file changed, 60 insertions(+) > > > > diff --git a/drivers/net/phy/mscc.c b/drivers/net/phy/mscc.c > > index f0a0e8d..dfbf4f3 100644 > > --- a/drivers/net/phy/mscc.c > > +++ b/drivers/net/phy/mscc.c > > @@ -24,6 +24,16 @@ enum rgmii_rx_clock_delay { > > RGMII_RX_CLK_DELAY_3_4_NS = 7 > > }; > > > > +/* Microsemi VSC85xx PHY registers */ > > +/* IEEE 802. Std Registers */ > > +#define MSCC_PHY_EXT_PHY_CNTL_1 23 > > +#define MAC_IF_SELECTION_MASK 0x1800 > > +#define MAC_IF_SELECTION_GMII 0 > > +#define MAC_IF_SELECTION_RMII 1 > > +#define MAC_IF_SELECTION_RGMII 2 > > +#define MAC_IF_SELECTION_POS 11 > > +#define FAR_END_LOOPBACK_MODE_MASK 0x0008 > > + > > #define MII_VSC85XX_INT_MASK 25 > > #define MII_VSC85XX_INT_MASK_MASK 0xa000 > > #define MII_VSC85XX_INT_STATUS 26 > > @@ -59,6 +69,52 @@ static int vsc85xx_phy_page_set(struct phy_device > > *phydev, u8 page) > > return rc; > > } > > > > +static int vsc85xx_soft_reset(struct phy_device *phydev) > > +{ > > + int rc; > > + u16 reg_val; > > + > > + reg_val = phy_read(phydev, MII_BMCR); > > + reg_val |= BMCR_RESET; > > + rc = phy_write(phydev, MII_BMCR, reg_val); > > + > > + return rc; > > +} > > Do you need to wait for the reset to complete? > > Does it make sense to call genphy_soft_reset() which will poll the phy > waiting for the BMCR_RESET bit to clear? > I accepted your review comment. I can use genphy_soft_reset( ) instead of creating another same function. > > + > > +static int vsc85xx_mac_if_set(struct phy_device *phydev, > > + phy_interface_t interface) > > +{ > > + int rc; > > + u16 reg_val; > > + > > + mutex_lock(&phydev->lock); > > + reg_val = phy_read(phydev, MSCC_PHY_EXT_PHY_CNTL_1); > > + reg_val &= ~(MAC_IF_SELECTION_MASK); > > + switch (interface) { > > + case PHY_INTERFACE_MODE_RGMII: > > + reg_val |= (MAC_IF_SELECTION_RGMII << MAC_IF_SELECTION_POS); > > + break; > > + case PHY_INTERFACE_MODE_RMII: > > + reg_val |= (MAC_IF_SELECTION_RMII << MAC_IF_SELECTION_POS); > > + break; > > + case PHY_INTERFACE_MODE_MII: > > + case PHY_INTERFACE_MODE_GMII: > > + default: > > So somebody asks you to configure the phy as PHY_INTERFACE_MODE_NA or > PHY_INTERFACE_MODE_TBI, you are going to use GMII. Maybe returning > -EINVAL would be better? > Microsemi PHY can support only 3 modes (RGMII/RMII/GMII). Default configuration should be GMII in PHY hardware. I accepted your review comment. In default switch case i will return -EINVAL. > Andrew Thanks, Raju.