{
        struct b53_device *dev = ds->priv;
        unsigned int cpu_port = ds->ports[port].cpu_dp->index;
+       int ret = 0;
        u16 pvlan;
 
+       if (dev->ops->irq_enable)
+               ret = dev->ops->irq_enable(dev, port);
+       if (ret)
+               return ret;
+
        /* Clear the Rx and Tx disable bits and set to no spanning tree */
        b53_write8(dev, B53_CTRL_PAGE, B53_PORT_CTRL(port), 0);
 
        b53_read8(dev, B53_CTRL_PAGE, B53_PORT_CTRL(port), ®);
        reg |= PORT_CTRL_RX_DISABLE | PORT_CTRL_TX_DISABLE;
        b53_write8(dev, B53_CTRL_PAGE, B53_PORT_CTRL(port), reg);
+
+       if (dev->ops->irq_disable)
+               dev->ops->irq_disable(dev, port);
 }
 EXPORT_SYMBOL(b53_disable_port);
 
 
        int (*write64)(struct b53_device *dev, u8 page, u8 reg, u64 value);
        int (*phy_read16)(struct b53_device *dev, int addr, int reg, u16 *value);
        int (*phy_write16)(struct b53_device *dev, int addr, int reg, u16 value);
+       int (*irq_enable)(struct b53_device *dev, int port);
+       void (*irq_disable)(struct b53_device *dev, int port);
 };
 
 enum {