lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20170922175918.GD3470@lunn.ch>
Date:   Fri, 22 Sep 2017 19:59:18 +0200
From:   Andrew Lunn <andrew@...n.ch>
To:     Bernd Edlinger <bernd.edlinger@...mail.de>
Cc:     "netdev@...r.kernel.org" <netdev@...r.kernel.org>,
        Florian Fainelli <f.fainelli@...il.com>
Subject: Re: [PATCH] Add a driver for Renesas uPD60620 and uPD60620A PHYs

On Fri, Sep 22, 2017 at 05:08:45PM +0000, Bernd Edlinger wrote:
> Signed-off-by: Bernd Edlinger <bernd.edlinger@...mail.de>
> ---
>   drivers/net/phy/Kconfig    |   5 +
>   drivers/net/phy/Makefile   |   1 +
>   drivers/net/phy/uPD60620.c | 226 
> +++++++++++++++++++++++++++++++++++++++++++++
>   3 files changed, 232 insertions(+)
>   create mode 100644 drivers/net/phy/uPD60620.c
> 
> diff --git a/drivers/net/phy/Kconfig b/drivers/net/phy/Kconfig
> index a9d16a3..25089f0 100644
> --- a/drivers/net/phy/Kconfig
> +++ b/drivers/net/phy/Kconfig
> @@ -287,6 +287,11 @@ config DP83867_PHY
>   	---help---
>   	  Currently supports the DP83867 PHY.
> 
> +config RENESAS_PHY
> +	tristate "Driver for Renesas PHYs"
> +	---help---
> +	  Supports the uPD60620 and uPD60620A PHYs.
> +

Hi Bernd

Please call this "Reneseas PHYs" and place in it alphabetical order.

>   config FIXED_PHY
>   	tristate "MDIO Bus/PHY emulation with fixed speed/link PHYs"
>   	depends on PHYLIB
> diff --git a/drivers/net/phy/Makefile b/drivers/net/phy/Makefile
> index 416df92..1404ad3 100644
> --- a/drivers/net/phy/Makefile
> +++ b/drivers/net/phy/Makefile
> @@ -72,6 +72,7 @@ obj-$(CONFIG_MICROSEMI_PHY)	+= mscc.o
>   obj-$(CONFIG_NATIONAL_PHY)	+= national.o
>   obj-$(CONFIG_QSEMI_PHY)		+= qsemi.o
>   obj-$(CONFIG_REALTEK_PHY)	+= realtek.o
> +obj-$(CONFIG_RENESAS_PHY)	+= uPD60620.o
>   obj-$(CONFIG_ROCKCHIP_PHY)	+= rockchip.o
>   obj-$(CONFIG_SMSC_PHY)		+= smsc.o
>   obj-$(CONFIG_STE10XP)		+= ste10Xp.o
> diff --git a/drivers/net/phy/uPD60620.c b/drivers/net/phy/uPD60620.c
> new file mode 100644
> index 0000000..b3d900c
> --- /dev/null
> +++ b/drivers/net/phy/uPD60620.c
> @@ -0,0 +1,226 @@
> +/*
> + * Driver for the Renesas PHY uPD60620.
> + *
> + * Copyright (C) 2015 Softing Industrial Automation GmbH
> + *
> + *  This program is free software; you can redistribute it and/or modify
> + *  it under the terms of the GNU General Public License as published by
> + *  the Free Software Foundation; either version 2 of the License, or
> + *  (at your option) any later version.
> + *
> + */
> +
> +#include <linux/kernel.h>
> +#include <linux/module.h>
> +#include <linux/phy.h>
> +
> +#define UPD60620_PHY_ID    0xb8242824
> +
> +/* Extended Registers and values */
> +/* PHY Special Control/Status    */
> +#define PHY_PHYSCR         0x1F      /* PHY.31 */
> +#define PHY_PHYSCR_10MB    0x0004    /* PHY speed = 10mb */
> +#define PHY_PHYSCR_100MB   0x0008    /* PHY speed = 100mb */
> +#define PHY_PHYSCR_DUPLEX  0x0010    /* PHY Duplex */
> +#define PHY_PHYSCR_RSVD5   0x0020    /* Reserved Bit 5 */
> +#define PHY_PHYSCR_MIIMOD  0x0040    /* Enable 4B5B MII mode */

Are any of these comments actually useful. It seems like the defines
are pretty obvious.

> +#define PHY_PHYSCR_RSVD7   0x0080    /* Reserved Bit 7 */
> +#define PHY_PHYSCR_RSVD8   0x0100    /* Reserved Bit 8 */
> +#define PHY_PHYSCR_RSVD9   0x0200    /* Reserved Bit 9 */
> +#define PHY_PHYSCR_RSVD10  0x0400    /* Reserved Bit 10 */
> +#define PHY_PHYSCR_RSVD11  0x0800    /* Reserved Bit 11 */
> +#define PHY_PHYSCR_ANDONE  0x1000    /* Auto negotiation done */
> +#define PHY_PHYSCR_RSVD13  0x2000    /* Reserved Bit 13 */
> +#define PHY_PHYSCR_RSVD14  0x4000    /* Reserved Bit 14 */
> +#define PHY_PHYSCR_RSVD15  0x8000    /* Reserved Bit 15 */

It looks like the only register you use is SCR and SPM. Maybe delete
all the rest? Or do you plan to add more features making use of these
registers?

> +/* Init PHY */
> +
> +static int upd60620_config_init(struct phy_device *phydev)
> +{
> +	/* Enable support for passive HUBs (could be a strap option) */
> +	/* PHYMODE: All speeds, HD in parallel detect */
> +	return phy_write(phydev, PHY_SPM, 0x0180 | phydev->mdio.addr);
> +}
> +
> +/* Get PHY status from common registers */
> +
> +static int upd60620_read_status(struct phy_device *phydev)
> +{
> +	int phy_state;
> +
> +	/* Read negotiated state */
> +	phy_state = phy_read(phydev, MII_BMSR);
> +	if (phy_state < 0)
> +		return phy_state;
> +
> +	phydev->link = 0;
> +	phydev->lp_advertising = 0;
> +	phydev->pause = 0;
> +	phydev->asym_pause = 0;
> +
> +	if (phy_state & BMSR_ANEGCOMPLETE) {

It is worth comparing this against genphy_read_status() which is the
reference implementation. You would normally check if auto negotiation
is enabled, not if it has completed. If it is enabled you read the
current negotiated state, even if it is not completed.

> +		phy_state = phy_read(phydev, PHY_PHYSCR);
> +		if (phy_state < 0)
> +			return phy_state;
> +
> +		if (phy_state & (PHY_PHYSCR_10MB | PHY_PHYSCR_100MB)) {
> +			phydev->link = 1;
> +			phydev->speed = SPEED_10;
> +			phydev->duplex = DUPLEX_HALF;
> +
> +			if (phy_state & PHY_PHYSCR_100MB)
> +				phydev->speed = SPEED_100;
> +			if (phy_state & PHY_PHYSCR_DUPLEX)
> +				phydev->duplex = DUPLEX_FULL;
> +
> +			phy_state = phy_read(phydev, MII_LPA);
> +			if (phy_state < 0)
> +				return phy_state;
> +
> +			phydev->lp_advertising
> +				= mii_lpa_to_ethtool_lpa_t(phy_state);
> +
> +			if (phydev->duplex == DUPLEX_FULL) {
> +				if (phy_state & LPA_PAUSE_CAP)
> +					phydev->pause = 1;
> +				if (phy_state & LPA_PAUSE_ASYM)
> +					phydev->asym_pause = 1;
> +			}
> +		}
> +	} else if (phy_state & BMSR_LSTATUS) {

The else clause is then for a fixed configuration. Since all you are
looking at is BMCR, you can probably just cut/paste from
genphy_read_status().

> +		phy_state = phy_read(phydev, MII_BMCR);
> +		if (phy_state < 0)
> +			return phy_state;
> +
> +		if (!(phy_state & BMCR_ANENABLE)) {
> +			phydev->link = 1;
> +			phydev->speed = SPEED_10;
> +			phydev->duplex = DUPLEX_HALF;
> +
> +			if (phy_state & BMCR_SPEED100)
> +				phydev->speed = SPEED_100;
> +			if (phy_state & BMCR_FULLDPLX)
> +				phydev->duplex = DUPLEX_FULL;
> +		}
> +	}
> +	return 0;
> +}

  Andrew

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ