Jeff,

Thanks a lot for feedback.

We are working on incorporating the feedback. And we will upload the entire 
single patch soon.

Thanks,
pradeep

On Wednesday 05 July 2006 21:04, Jeff Garzik wrote:
> Linsys Contractor Amit S. Kale wrote:
> > +static int
> > +netxen_nic_set_settings(struct net_device *dev, struct ethtool_cmd
> > *ecmd) +{
> > +    struct netxen_port *port = netdev_priv(dev);
> > +    struct netxen_adapter *adapter = port->adapter;
> > +    struct netxen_niu_phy_status status;
> > +
> > +    /* read which mode */
> > +    if (adapter->ahw.board_type == NETXEN_NIC_GBE) {
> > +        /* autonegotiation */
> > +        if (netxen_nic_phy_write(port->adapter, port->portnum,
> > +                     NETXEN_NIU_GB_MII_MGMT_ADDR_AUTONEG,
> > +                     (netxen_crbword_t) ecmd->autoneg) != 0)
> > +            return -EIO;
> > +        else
> > +            port->link_autoneg = ecmd->autoneg;
> > +
> > +        if (netxen_nic_phy_read(port->adapter, port->portnum,
> > +                    NETXEN_NIU_GB_MII_MGMT_ADDR_PHY_STATUS,
> > +                    (netxen_crbword_t *) & status) != 0)
> > +            return -EIO;
> > +
> > +        /* speed */
> > +        switch (ecmd->speed) {
> > +        case SPEED_10:
> > +            status.speed = 0;
> > +            break;
> > +        case SPEED_100:
> > +            status.speed = 1;
> > +            break;
> > +        case SPEED_1000:
> > +            status.speed = 2;
> > +            break;
> > +        }
> > +        /* set duplex mode */
> > +        if (ecmd->duplex == DUPLEX_HALF)
> > +            status.duplex = 0;
> > +        if (ecmd->duplex == DUPLEX_FULL)
> > +            status.duplex = 1;
> > +
> > +        if (netxen_nic_phy_write(port->adapter, port->portnum,
> > +                     NETXEN_NIU_GB_MII_MGMT_ADDR_PHY_STATUS,
> > +                     *((int *)&status)) != 0)
> > +            return -EIO;
> > +        else {
> > +            port->link_speed = ecmd->speed;
> > +            port->link_duplex = ecmd->duplex;
> > +        }
> > +    }
> > +    if (netif_running(dev)) {
> > +        dev->stop(dev);
> > +        dev->open(dev);
> > +    }
> > +    return 0;
> > +}
> > +
> >
> > +/* Restart Link Process */
> > +static int netxen_nic_nway_reset(struct net_device *dev)
> > +{
> > +    if (netif_running(dev)) {
> > +        dev->stop(dev);    /* verify */
> > +        dev->open(dev);
> > +    }
> > +    return 0;
> > +}
>
> Direct calls to dev->stop() and dev->open() are likely buggy, because
> the locking/context differs between the above quoted calls and the calls
> from inside the net stack.
>
> > +struct ethtool_ops netxen_nic_ethtool_ops = {
> > +    .get_settings = netxen_nic_get_settings,
> > +    .set_settings = netxen_nic_set_settings,
> > +    .get_drvinfo = netxen_nic_get_drvinfo,
> > +    .get_regs_len = netxen_nic_get_regs_len,
> > +    .get_regs = netxen_nic_get_regs,
> > +    .get_wol = netxen_nic_get_wol,
> > +    .nway_reset = netxen_nic_nway_reset,
> > +    .get_link = netxen_nic_get_link,
> > +    .get_eeprom_len = netxen_nic_get_eeprom_len,
> > +    .get_eeprom = netxen_nic_get_eeprom,
> > +    .get_ringparam = netxen_nic_get_ringparam,
> > +    .get_pauseparam = netxen_nic_get_pauseparam,
> > +    .set_pauseparam = netxen_nic_set_pauseparam,
> > +    .get_tx_csum = ethtool_op_get_tx_csum,
> > +    .set_tx_csum = ethtool_op_set_tx_csum,
> > +    .get_sg = ethtool_op_get_sg,
> > +    .set_sg = ethtool_op_set_sg,
> > +#ifdef NETIF_F_TSO
> > +    .get_tso = ethtool_op_get_tso,
> > +    .set_tso = ethtool_op_set_tso,
> > +#endif
>
> kill this #ifdef
>
>       Jeff
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to