Adding phy_on in opposition to phy_off.
+static inline void
+jme_phy_on(struct jme_adapter *jme)
+{
+ u32 bmcr;
+
+ bmcr = jme_mdio_read(jme->dev, jme->mii_if.phy_id, MII_BMCR);
+ bmcr &= ~BMCR_PDOWN;
+ jme_mdio_write(jme->dev, jme->mii_if.phy_id, MII_BMCR, bmcr);
+}
+
static int
jme_open(struct net_device *netdev)
{
static int
jme_open(struct net_device *netdev)
{
- if (test_bit(JME_FLAG_SSET, &jme->flags))
+ if (test_bit(JME_FLAG_SSET, &jme->flags)) {
+ jme_phy_on(jme);
jme_set_settings(netdev, &jme->old_ecmd);
jme_set_settings(netdev, &jme->old_ecmd);
jme_reset_phy_processor(jme);
jme_reset_phy_processor(jme);
jme_clear_pm(jme);
pci_restore_state(pdev);
jme_clear_pm(jme);
pci_restore_state(pdev);
- if (test_bit(JME_FLAG_SSET, &jme->flags))
+ if (test_bit(JME_FLAG_SSET, &jme->flags)) {
+ jme_phy_on(jme);
jme_set_settings(netdev, &jme->old_ecmd);
jme_set_settings(netdev, &jme->old_ecmd);
jme_reset_phy_processor(jme);
jme_reset_phy_processor(jme);
jme_start_irq(jme);
netif_device_attach(netdev);
jme_start_irq(jme);
netif_device_attach(netdev);