We need to initialize the notifer before use it.
So lets initialize it when add a new phy device to
reduce the code redundancy.
Signed-off-by: Neil Zhang <zhangwm@marvell.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
 
        platform_set_drvdata(pdev, ab);
 
-       ATOMIC_INIT_NOTIFIER_HEAD(&ab->phy.notifier);
-
        /* all: Disable phy when called from set_host and set_peripheral */
        INIT_WORK(&ab->phy_dis_work, ab8500_usb_phy_disable_work);
 
 
        nop->phy.otg->set_host          = nop_set_host;
        nop->phy.otg->set_peripheral    = nop_set_peripheral;
 
-       ATOMIC_INIT_NOTIFIER_HEAD(&nop->phy.notifier);
        return 0;
 }
 EXPORT_SYMBOL_GPL(usb_phy_gen_create_phy);
 
                goto err_irq;
        }
 
-       ATOMIC_INIT_NOTIFIER_HEAD(&gpio_vbus->phy.notifier);
-
        INIT_DELAYED_WORK(&gpio_vbus->work, gpio_vbus_work);
 
        gpio_vbus->vbus_draw = regulator_get(&pdev->dev, "vbus_draw");
 
        mxs_phy->phy.notify_disconnect  = mxs_phy_on_disconnect;
        mxs_phy->phy.type               = USB_PHY_TYPE_USB2;
 
-       ATOMIC_INIT_NOTIFIER_HEAD(&mxs_phy->phy.notifier);
-
        mxs_phy->clk = clk;
 
        platform_set_drvdata(pdev, &mxs_phy->phy);
 
                return -EINVAL;
        }
 
+       ATOMIC_INIT_NOTIFIER_HEAD(&x->notifier);
+
        spin_lock_irqsave(&phy_lock, flags);
 
        list_for_each_entry(phy, &phy_list, head) {
                return -EINVAL;
        }
 
+       ATOMIC_INIT_NOTIFIER_HEAD(&x->notifier);
+
        spin_lock_irqsave(&phy_lock, flags);
        list_for_each_entry(phy_bind, &phy_bind_list, list)
                if (!(strcmp(phy_bind->phy_dev_name, dev_name(x->dev))))