diff mbox series

usb: host: xhci-mtk: Simplify supplies handling with regulator_bulk

Message ID 20220118133348.111860-1-angelogioacchino.delregno@collabora.com (mailing list archive)
State New, archived
Headers show
Series usb: host: xhci-mtk: Simplify supplies handling with regulator_bulk | expand

Commit Message

AngeloGioacchino Del Regno Jan. 18, 2022, 1:33 p.m. UTC
Remove the custom functions xhci_mtk_ldos_{enable,disable}() by
switching to using regulator_bulk to perform the very same thing,
as the regulators are always either both enabled or both disabled.

Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
---
 drivers/usb/host/xhci-mtk.c | 56 ++++++++++++-------------------------
 drivers/usb/host/xhci-mtk.h |  4 +--
 2 files changed, 20 insertions(+), 40 deletions(-)

Comments

Chunfeng Yun (云春峰) Jan. 20, 2022, 6:50 a.m. UTC | #1
On Tue, 2022-01-18 at 14:33 +0100, AngeloGioacchino Del Regno wrote:
> Remove the custom functions xhci_mtk_ldos_{enable,disable}() by
> switching to using regulator_bulk to perform the very same thing,
> as the regulators are always either both enabled or both disabled.
> 
> Signed-off-by: AngeloGioacchino Del Regno <
> angelogioacchino.delregno@collabora.com>
> ---
>  drivers/usb/host/xhci-mtk.c | 56 ++++++++++++-----------------------
> --
>  drivers/usb/host/xhci-mtk.h |  4 +--
>  2 files changed, 20 insertions(+), 40 deletions(-)
> 
> diff --git a/drivers/usb/host/xhci-mtk.c b/drivers/usb/host/xhci-
> mtk.c
> index 62c835d446be..3b81931e5b77 100644
> --- a/drivers/usb/host/xhci-mtk.c
> +++ b/drivers/usb/host/xhci-mtk.c
> @@ -395,31 +395,6 @@ static int xhci_mtk_clks_get(struct xhci_hcd_mtk
> *mtk)
>  	return devm_clk_bulk_get_optional(mtk->dev, BULK_CLKS_NUM,
> clks);
>  }
>  
> -static int xhci_mtk_ldos_enable(struct xhci_hcd_mtk *mtk)
> -{
> -	int ret;
> -
> -	ret = regulator_enable(mtk->vbus);
> -	if (ret) {
> -		dev_err(mtk->dev, "failed to enable vbus\n");
> -		return ret;
> -	}
> -
> -	ret = regulator_enable(mtk->vusb33);
> -	if (ret) {
> -		dev_err(mtk->dev, "failed to enable vusb33\n");
> -		regulator_disable(mtk->vbus);
> -		return ret;
> -	}
> -	return 0;
> -}
> -
> -static void xhci_mtk_ldos_disable(struct xhci_hcd_mtk *mtk)
> -{
> -	regulator_disable(mtk->vbus);
> -	regulator_disable(mtk->vusb33);
> -}
> -
>  static void xhci_mtk_quirks(struct device *dev, struct xhci_hcd
> *xhci)
>  {
>  	struct usb_hcd *hcd = xhci_to_hcd(xhci);
> @@ -475,6 +450,10 @@ static int xhci_mtk_setup(struct usb_hcd *hcd)
>  	return ret;
>  }
>  
> +static const char * const xhci_mtk_supply_names[] = {
> +	"vusb33", "vbus",
> +};
> +
>  static const struct xhci_driver_overrides xhci_mtk_overrides
> __initconst = {
>  	.reset = xhci_mtk_setup,
>  	.add_endpoint = xhci_mtk_add_ep,
> @@ -507,17 +486,18 @@ static int xhci_mtk_probe(struct
> platform_device *pdev)
>  		return -ENOMEM;
>  
>  	mtk->dev = dev;
> -	mtk->vbus = devm_regulator_get(dev, "vbus");
> -	if (IS_ERR(mtk->vbus)) {
> -		dev_err(dev, "fail to get vbus\n");
> -		return PTR_ERR(mtk->vbus);
> -	}
> +	mtk->num_supplies = ARRAY_SIZE(xhci_mtk_supply_names);
> +	mtk->supplies = devm_kcalloc(dev, mtk->num_supplies,
> +				     sizeof(*mtk->supplies),
> GFP_KERNEL);
> +	if (!mtk->supplies)
> +		return -ENOMEM;
>  
> -	mtk->vusb33 = devm_regulator_get(dev, "vusb33");
> -	if (IS_ERR(mtk->vusb33)) {
> -		dev_err(dev, "fail to get vusb33\n");
> -		return PTR_ERR(mtk->vusb33);
> -	}
> +	regulator_bulk_set_supply_names(mtk->supplies,
> xhci_mtk_supply_names,
> +					mtk->num_supplies);
> +
> +	ret = devm_regulator_bulk_get(dev, mtk->num_supplies, mtk-
> >supplies);
> +	if (ret)
> +		return dev_err_probe(dev, ret, "Failed to get
> regulators\n");
>  
>  	ret = xhci_mtk_clks_get(mtk);
>  	if (ret)
> @@ -558,7 +538,7 @@ static int xhci_mtk_probe(struct platform_device
> *pdev)
>  	pm_runtime_enable(dev);
>  	pm_runtime_get_sync(dev);
>  
> -	ret = xhci_mtk_ldos_enable(mtk);
> +	ret = regulator_bulk_enable(mtk->num_supplies, mtk->supplies);
>  	if (ret)
>  		goto disable_pm;
>  
> @@ -667,7 +647,7 @@ static int xhci_mtk_probe(struct platform_device
> *pdev)
>  	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
>  
>  disable_ldos:
> -	xhci_mtk_ldos_disable(mtk);
> +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
>  
>  disable_pm:
>  	pm_runtime_put_noidle(dev);
> @@ -695,7 +675,7 @@ static int xhci_mtk_remove(struct platform_device
> *pdev)
>  	usb_put_hcd(hcd);
>  	xhci_mtk_sch_exit(mtk);
>  	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
> -	xhci_mtk_ldos_disable(mtk);
> +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
>  
>  	pm_runtime_disable(dev);
>  	pm_runtime_put_noidle(dev);
> diff --git a/drivers/usb/host/xhci-mtk.h b/drivers/usb/host/xhci-
> mtk.h
> index 4b1ea89f959a..9b78cd2ba0ac 100644
> --- a/drivers/usb/host/xhci-mtk.h
> +++ b/drivers/usb/host/xhci-mtk.h
> @@ -150,9 +150,9 @@ struct xhci_hcd_mtk {
>  	int num_u3_ports;
>  	int u2p_dis_msk;
>  	int u3p_dis_msk;
> -	struct regulator *vusb33;
> -	struct regulator *vbus;
>  	struct clk_bulk_data clks[BULK_CLKS_NUM];
> +	struct regulator_bulk_data *supplies;
> +	u8 num_supplies;
Could you please help to change it like as clock bulk?

1. #define BULK_REGULATORS_NUM 2; then define @supplies array,

        struct regulator_bulk_data supplies[BULK_REGULATORS_NUM];

2. also add a helper to get regulator bulk; e.g.

static int xhci_mtk_regulators_get(struct xhci_hcd_mtk *mtk)
{
    struct regulator_bulk_data *supplies = mtk->supplies;

    supplies[0].supply = "vusb33";
    supplies[1].supply = "vbus";

    return devm_regulator_bulk_get(mtk->dev, BUL
K_REGULATORS_NUM, supplies);
}

Thanks a lot


>  	unsigned int has_ippc:1;
>  	unsigned int lpm_support:1;
>  	unsigned int u2_lpm_disable:1;
AngeloGioacchino Del Regno Feb. 7, 2022, 10 a.m. UTC | #2
Il 20/01/22 07:50, Chunfeng Yun ha scritto:
> On Tue, 2022-01-18 at 14:33 +0100, AngeloGioacchino Del Regno wrote:
>> Remove the custom functions xhci_mtk_ldos_{enable,disable}() by
>> switching to using regulator_bulk to perform the very same thing,
>> as the regulators are always either both enabled or both disabled.
>>
>> Signed-off-by: AngeloGioacchino Del Regno <
>> angelogioacchino.delregno@collabora.com>
>> ---
>>   drivers/usb/host/xhci-mtk.c | 56 ++++++++++++-----------------------
>> --
>>   drivers/usb/host/xhci-mtk.h |  4 +--
>>   2 files changed, 20 insertions(+), 40 deletions(-)
>>
>> diff --git a/drivers/usb/host/xhci-mtk.c b/drivers/usb/host/xhci-
>> mtk.c
>> index 62c835d446be..3b81931e5b77 100644
>> --- a/drivers/usb/host/xhci-mtk.c
>> +++ b/drivers/usb/host/xhci-mtk.c
>> @@ -395,31 +395,6 @@ static int xhci_mtk_clks_get(struct xhci_hcd_mtk
>> *mtk)
>>   	return devm_clk_bulk_get_optional(mtk->dev, BULK_CLKS_NUM,
>> clks);
>>   }
>>   
>> -static int xhci_mtk_ldos_enable(struct xhci_hcd_mtk *mtk)
>> -{
>> -	int ret;
>> -
>> -	ret = regulator_enable(mtk->vbus);
>> -	if (ret) {
>> -		dev_err(mtk->dev, "failed to enable vbus\n");
>> -		return ret;
>> -	}
>> -
>> -	ret = regulator_enable(mtk->vusb33);
>> -	if (ret) {
>> -		dev_err(mtk->dev, "failed to enable vusb33\n");
>> -		regulator_disable(mtk->vbus);
>> -		return ret;
>> -	}
>> -	return 0;
>> -}
>> -
>> -static void xhci_mtk_ldos_disable(struct xhci_hcd_mtk *mtk)
>> -{
>> -	regulator_disable(mtk->vbus);
>> -	regulator_disable(mtk->vusb33);
>> -}
>> -
>>   static void xhci_mtk_quirks(struct device *dev, struct xhci_hcd
>> *xhci)
>>   {
>>   	struct usb_hcd *hcd = xhci_to_hcd(xhci);
>> @@ -475,6 +450,10 @@ static int xhci_mtk_setup(struct usb_hcd *hcd)
>>   	return ret;
>>   }
>>   
>> +static const char * const xhci_mtk_supply_names[] = {
>> +	"vusb33", "vbus",
>> +};
>> +
>>   static const struct xhci_driver_overrides xhci_mtk_overrides
>> __initconst = {
>>   	.reset = xhci_mtk_setup,
>>   	.add_endpoint = xhci_mtk_add_ep,
>> @@ -507,17 +486,18 @@ static int xhci_mtk_probe(struct
>> platform_device *pdev)
>>   		return -ENOMEM;
>>   
>>   	mtk->dev = dev;
>> -	mtk->vbus = devm_regulator_get(dev, "vbus");
>> -	if (IS_ERR(mtk->vbus)) {
>> -		dev_err(dev, "fail to get vbus\n");
>> -		return PTR_ERR(mtk->vbus);
>> -	}
>> +	mtk->num_supplies = ARRAY_SIZE(xhci_mtk_supply_names);
>> +	mtk->supplies = devm_kcalloc(dev, mtk->num_supplies,
>> +				     sizeof(*mtk->supplies),
>> GFP_KERNEL);
>> +	if (!mtk->supplies)
>> +		return -ENOMEM;
>>   
>> -	mtk->vusb33 = devm_regulator_get(dev, "vusb33");
>> -	if (IS_ERR(mtk->vusb33)) {
>> -		dev_err(dev, "fail to get vusb33\n");
>> -		return PTR_ERR(mtk->vusb33);
>> -	}
>> +	regulator_bulk_set_supply_names(mtk->supplies,
>> xhci_mtk_supply_names,
>> +					mtk->num_supplies);
>> +
>> +	ret = devm_regulator_bulk_get(dev, mtk->num_supplies, mtk-
>>> supplies);
>> +	if (ret)
>> +		return dev_err_probe(dev, ret, "Failed to get
>> regulators\n");
>>   
>>   	ret = xhci_mtk_clks_get(mtk);
>>   	if (ret)
>> @@ -558,7 +538,7 @@ static int xhci_mtk_probe(struct platform_device
>> *pdev)
>>   	pm_runtime_enable(dev);
>>   	pm_runtime_get_sync(dev);
>>   
>> -	ret = xhci_mtk_ldos_enable(mtk);
>> +	ret = regulator_bulk_enable(mtk->num_supplies, mtk->supplies);
>>   	if (ret)
>>   		goto disable_pm;
>>   
>> @@ -667,7 +647,7 @@ static int xhci_mtk_probe(struct platform_device
>> *pdev)
>>   	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
>>   
>>   disable_ldos:
>> -	xhci_mtk_ldos_disable(mtk);
>> +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
>>   
>>   disable_pm:
>>   	pm_runtime_put_noidle(dev);
>> @@ -695,7 +675,7 @@ static int xhci_mtk_remove(struct platform_device
>> *pdev)
>>   	usb_put_hcd(hcd);
>>   	xhci_mtk_sch_exit(mtk);
>>   	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
>> -	xhci_mtk_ldos_disable(mtk);
>> +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
>>   
>>   	pm_runtime_disable(dev);
>>   	pm_runtime_put_noidle(dev);
>> diff --git a/drivers/usb/host/xhci-mtk.h b/drivers/usb/host/xhci-
>> mtk.h
>> index 4b1ea89f959a..9b78cd2ba0ac 100644
>> --- a/drivers/usb/host/xhci-mtk.h
>> +++ b/drivers/usb/host/xhci-mtk.h
>> @@ -150,9 +150,9 @@ struct xhci_hcd_mtk {
>>   	int num_u3_ports;
>>   	int u2p_dis_msk;
>>   	int u3p_dis_msk;
>> -	struct regulator *vusb33;
>> -	struct regulator *vbus;
>>   	struct clk_bulk_data clks[BULK_CLKS_NUM];
>> +	struct regulator_bulk_data *supplies;
>> +	u8 num_supplies;
> Could you please help to change it like as clock bulk?
> 
> 1. #define BULK_REGULATORS_NUM 2; then define @supplies array,
> 
>          struct regulator_bulk_data supplies[BULK_REGULATORS_NUM];
> 
> 2. also add a helper to get regulator bulk; e.g.
> 
> static int xhci_mtk_regulators_get(struct xhci_hcd_mtk *mtk)
> {
>      struct regulator_bulk_data *supplies = mtk->supplies;
> 
>      supplies[0].supply = "vusb33";
>      supplies[1].supply = "vbus";
> 
>      return devm_regulator_bulk_get(mtk->dev, BUL
> K_REGULATORS_NUM, supplies);
> }

Hello Chunfeng,
I chose to go for this way to enhance the implementation flexibility: like that,
any future SoC that needs different regulators (more vregs, less, different names)
will simply need a new array of vreg names, like:

static const char * const xhci_mtk_mtxxxx_supply_names[] = {
	"vusb33", "vbus", "another-supply", "and-another-one",
};

Other than enhancing flexibility, this will also make sure that we don't allocate
more regulator_bulk_data entries than needed, enhancing memory usage.

Your proposal, though, is valid if you are sure that future SoCs will have only
and always these two power supplies and nothing else...

Regards,
Angelo

> 
> Thanks a lot
> 
> 
>>   	unsigned int has_ippc:1;
>>   	unsigned int lpm_support:1;
>>   	unsigned int u2_lpm_disable:1;
>
Chunfeng Yun (云春峰) Feb. 14, 2022, 7:44 a.m. UTC | #3
On Mon, 2022-02-07 at 11:00 +0100, AngeloGioacchino Del Regno wrote:
> Il 20/01/22 07:50, Chunfeng Yun ha scritto:
> > On Tue, 2022-01-18 at 14:33 +0100, AngeloGioacchino Del Regno
> > wrote:
> > > Remove the custom functions xhci_mtk_ldos_{enable,disable}() by
> > > switching to using regulator_bulk to perform the very same thing,
> > > as the regulators are always either both enabled or both
> > > disabled.
> > > 
> > > Signed-off-by: AngeloGioacchino Del Regno <
> > > angelogioacchino.delregno@collabora.com>
> > > ---
> > >   drivers/usb/host/xhci-mtk.c | 56 ++++++++++++----------------
> > > -------
> > > --
> > >   drivers/usb/host/xhci-mtk.h |  4 +--
> > >   2 files changed, 20 insertions(+), 40 deletions(-)
> > > 
> > > diff --git a/drivers/usb/host/xhci-mtk.c b/drivers/usb/host/xhci-
> > > mtk.c
> > > index 62c835d446be..3b81931e5b77 100644
> > > --- a/drivers/usb/host/xhci-mtk.c
> > > +++ b/drivers/usb/host/xhci-mtk.c
> > > @@ -395,31 +395,6 @@ static int xhci_mtk_clks_get(struct
> > > xhci_hcd_mtk
> > > *mtk)
> > >   	return devm_clk_bulk_get_optional(mtk->dev,
> > > BULK_CLKS_NUM,
> > > clks);
> > >   }
> > >   
> > > -static int xhci_mtk_ldos_enable(struct xhci_hcd_mtk *mtk)
> > > -{
> > > -	int ret;
> > > -
> > > -	ret = regulator_enable(mtk->vbus);
> > > -	if (ret) {
> > > -		dev_err(mtk->dev, "failed to enable vbus\n");
> > > -		return ret;
> > > -	}
> > > -
> > > -	ret = regulator_enable(mtk->vusb33);
> > > -	if (ret) {
> > > -		dev_err(mtk->dev, "failed to enable vusb33\n");
> > > -		regulator_disable(mtk->vbus);
> > > -		return ret;
> > > -	}
> > > -	return 0;
> > > -}
> > > -
> > > -static void xhci_mtk_ldos_disable(struct xhci_hcd_mtk *mtk)
> > > -{
> > > -	regulator_disable(mtk->vbus);
> > > -	regulator_disable(mtk->vusb33);
> > > -}
> > > -
> > >   static void xhci_mtk_quirks(struct device *dev, struct xhci_hcd
> > > *xhci)
> > >   {
> > >   	struct usb_hcd *hcd = xhci_to_hcd(xhci);
> > > @@ -475,6 +450,10 @@ static int xhci_mtk_setup(struct usb_hcd
> > > *hcd)
> > >   	return ret;
> > >   }
> > >   
> > > +static const char * const xhci_mtk_supply_names[] = {
> > > +	"vusb33", "vbus",
> > > +};
> > > +
> > >   static const struct xhci_driver_overrides xhci_mtk_overrides
> > > __initconst = {
> > >   	.reset = xhci_mtk_setup,
> > >   	.add_endpoint = xhci_mtk_add_ep,
> > > @@ -507,17 +486,18 @@ static int xhci_mtk_probe(struct
> > > platform_device *pdev)
> > >   		return -ENOMEM;
> > >   
> > >   	mtk->dev = dev;
> > > -	mtk->vbus = devm_regulator_get(dev, "vbus");
> > > -	if (IS_ERR(mtk->vbus)) {
> > > -		dev_err(dev, "fail to get vbus\n");
> > > -		return PTR_ERR(mtk->vbus);
> > > -	}
> > > +	mtk->num_supplies = ARRAY_SIZE(xhci_mtk_supply_names);
> > > +	mtk->supplies = devm_kcalloc(dev, mtk->num_supplies,
> > > +				     sizeof(*mtk->supplies),
> > > GFP_KERNEL);
> > > +	if (!mtk->supplies)
> > > +		return -ENOMEM;
> > >   
> > > -	mtk->vusb33 = devm_regulator_get(dev, "vusb33");
> > > -	if (IS_ERR(mtk->vusb33)) {
> > > -		dev_err(dev, "fail to get vusb33\n");
> > > -		return PTR_ERR(mtk->vusb33);
> > > -	}
> > > +	regulator_bulk_set_supply_names(mtk->supplies,
> > > xhci_mtk_supply_names,
> > > +					mtk->num_supplies);
> > > +
> > > +	ret = devm_regulator_bulk_get(dev, mtk->num_supplies, mtk-
> > > > supplies);
> > > 
> > > +	if (ret)
> > > +		return dev_err_probe(dev, ret, "Failed to get
> > > regulators\n");
> > >   
> > >   	ret = xhci_mtk_clks_get(mtk);
> > >   	if (ret)
> > > @@ -558,7 +538,7 @@ static int xhci_mtk_probe(struct
> > > platform_device
> > > *pdev)
> > >   	pm_runtime_enable(dev);
> > >   	pm_runtime_get_sync(dev);
> > >   
> > > -	ret = xhci_mtk_ldos_enable(mtk);
> > > +	ret = regulator_bulk_enable(mtk->num_supplies, mtk->supplies);
> > >   	if (ret)
> > >   		goto disable_pm;
> > >   
> > > @@ -667,7 +647,7 @@ static int xhci_mtk_probe(struct
> > > platform_device
> > > *pdev)
> > >   	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
> > >   
> > >   disable_ldos:
> > > -	xhci_mtk_ldos_disable(mtk);
> > > +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
> > >   
> > >   disable_pm:
> > >   	pm_runtime_put_noidle(dev);
> > > @@ -695,7 +675,7 @@ static int xhci_mtk_remove(struct
> > > platform_device
> > > *pdev)
> > >   	usb_put_hcd(hcd);
> > >   	xhci_mtk_sch_exit(mtk);
> > >   	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
> > > -	xhci_mtk_ldos_disable(mtk);
> > > +	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
> > >   
> > >   	pm_runtime_disable(dev);
> > >   	pm_runtime_put_noidle(dev);
> > > diff --git a/drivers/usb/host/xhci-mtk.h b/drivers/usb/host/xhci-
> > > mtk.h
> > > index 4b1ea89f959a..9b78cd2ba0ac 100644
> > > --- a/drivers/usb/host/xhci-mtk.h
> > > +++ b/drivers/usb/host/xhci-mtk.h
> > > @@ -150,9 +150,9 @@ struct xhci_hcd_mtk {
> > >   	int num_u3_ports;
> > >   	int u2p_dis_msk;
> > >   	int u3p_dis_msk;
> > > -	struct regulator *vusb33;
> > > -	struct regulator *vbus;
> > >   	struct clk_bulk_data clks[BULK_CLKS_NUM];
> > > +	struct regulator_bulk_data *supplies;
> > > +	u8 num_supplies;
> > 
> > Could you please help to change it like as clock bulk?
> > 
> > 1. #define BULK_REGULATORS_NUM 2; then define @supplies array,
> > 
> >          struct regulator_bulk_data supplies[BULK_REGULATORS_NUM];
> > 
> > 2. also add a helper to get regulator bulk; e.g.
> > 
> > static int xhci_mtk_regulators_get(struct xhci_hcd_mtk *mtk)
> > {
> >      struct regulator_bulk_data *supplies = mtk->supplies;
> > 
> >      supplies[0].supply = "vusb33";
> >      supplies[1].supply = "vbus";
> > 
> >      return devm_regulator_bulk_get(mtk->dev, BUL
> > K_REGULATORS_NUM, supplies);
> > }
> 
> Hello Chunfeng,
> I chose to go for this way to enhance the implementation flexibility:
> like that,
> any future SoC that needs different regulators (more vregs, less,
> different names)
> will simply need a new array of vreg names, like:
> 
> static const char * const xhci_mtk_mtxxxx_supply_names[] = {
> 	"vusb33", "vbus", "another-supply", "and-another-one",
> };
> 
> Other than enhancing flexibility, this will also make sure that we
> don't allocate
> more regulator_bulk_data entries than needed, enhancing memory usage.
> 
> Your proposal, though, is valid if you are sure that future SoCs will
> have only
> and always these two power supplies and nothing else...
As I know, vbus is usually always on (fixed regulator) and is used to
provide 5v for the connected device, vusb33 is rarely used now (it's
used to provide v3.3 for the controller). I think no need pay more
attention to flexibility here.

Thanks a lot


> 
> Regards,
> Angelo
> 
> > 
> > Thanks a lot
> > 
> > 
> > >   	unsigned int has_ippc:1;
> > >   	unsigned int lpm_support:1;
> > >   	unsigned int u2_lpm_disable:1;
diff mbox series

Patch

diff --git a/drivers/usb/host/xhci-mtk.c b/drivers/usb/host/xhci-mtk.c
index 62c835d446be..3b81931e5b77 100644
--- a/drivers/usb/host/xhci-mtk.c
+++ b/drivers/usb/host/xhci-mtk.c
@@ -395,31 +395,6 @@  static int xhci_mtk_clks_get(struct xhci_hcd_mtk *mtk)
 	return devm_clk_bulk_get_optional(mtk->dev, BULK_CLKS_NUM, clks);
 }
 
-static int xhci_mtk_ldos_enable(struct xhci_hcd_mtk *mtk)
-{
-	int ret;
-
-	ret = regulator_enable(mtk->vbus);
-	if (ret) {
-		dev_err(mtk->dev, "failed to enable vbus\n");
-		return ret;
-	}
-
-	ret = regulator_enable(mtk->vusb33);
-	if (ret) {
-		dev_err(mtk->dev, "failed to enable vusb33\n");
-		regulator_disable(mtk->vbus);
-		return ret;
-	}
-	return 0;
-}
-
-static void xhci_mtk_ldos_disable(struct xhci_hcd_mtk *mtk)
-{
-	regulator_disable(mtk->vbus);
-	regulator_disable(mtk->vusb33);
-}
-
 static void xhci_mtk_quirks(struct device *dev, struct xhci_hcd *xhci)
 {
 	struct usb_hcd *hcd = xhci_to_hcd(xhci);
@@ -475,6 +450,10 @@  static int xhci_mtk_setup(struct usb_hcd *hcd)
 	return ret;
 }
 
+static const char * const xhci_mtk_supply_names[] = {
+	"vusb33", "vbus",
+};
+
 static const struct xhci_driver_overrides xhci_mtk_overrides __initconst = {
 	.reset = xhci_mtk_setup,
 	.add_endpoint = xhci_mtk_add_ep,
@@ -507,17 +486,18 @@  static int xhci_mtk_probe(struct platform_device *pdev)
 		return -ENOMEM;
 
 	mtk->dev = dev;
-	mtk->vbus = devm_regulator_get(dev, "vbus");
-	if (IS_ERR(mtk->vbus)) {
-		dev_err(dev, "fail to get vbus\n");
-		return PTR_ERR(mtk->vbus);
-	}
+	mtk->num_supplies = ARRAY_SIZE(xhci_mtk_supply_names);
+	mtk->supplies = devm_kcalloc(dev, mtk->num_supplies,
+				     sizeof(*mtk->supplies), GFP_KERNEL);
+	if (!mtk->supplies)
+		return -ENOMEM;
 
-	mtk->vusb33 = devm_regulator_get(dev, "vusb33");
-	if (IS_ERR(mtk->vusb33)) {
-		dev_err(dev, "fail to get vusb33\n");
-		return PTR_ERR(mtk->vusb33);
-	}
+	regulator_bulk_set_supply_names(mtk->supplies, xhci_mtk_supply_names,
+					mtk->num_supplies);
+
+	ret = devm_regulator_bulk_get(dev, mtk->num_supplies, mtk->supplies);
+	if (ret)
+		return dev_err_probe(dev, ret, "Failed to get regulators\n");
 
 	ret = xhci_mtk_clks_get(mtk);
 	if (ret)
@@ -558,7 +538,7 @@  static int xhci_mtk_probe(struct platform_device *pdev)
 	pm_runtime_enable(dev);
 	pm_runtime_get_sync(dev);
 
-	ret = xhci_mtk_ldos_enable(mtk);
+	ret = regulator_bulk_enable(mtk->num_supplies, mtk->supplies);
 	if (ret)
 		goto disable_pm;
 
@@ -667,7 +647,7 @@  static int xhci_mtk_probe(struct platform_device *pdev)
 	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
 
 disable_ldos:
-	xhci_mtk_ldos_disable(mtk);
+	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
 
 disable_pm:
 	pm_runtime_put_noidle(dev);
@@ -695,7 +675,7 @@  static int xhci_mtk_remove(struct platform_device *pdev)
 	usb_put_hcd(hcd);
 	xhci_mtk_sch_exit(mtk);
 	clk_bulk_disable_unprepare(BULK_CLKS_NUM, mtk->clks);
-	xhci_mtk_ldos_disable(mtk);
+	regulator_bulk_disable(mtk->num_supplies, mtk->supplies);
 
 	pm_runtime_disable(dev);
 	pm_runtime_put_noidle(dev);
diff --git a/drivers/usb/host/xhci-mtk.h b/drivers/usb/host/xhci-mtk.h
index 4b1ea89f959a..9b78cd2ba0ac 100644
--- a/drivers/usb/host/xhci-mtk.h
+++ b/drivers/usb/host/xhci-mtk.h
@@ -150,9 +150,9 @@  struct xhci_hcd_mtk {
 	int num_u3_ports;
 	int u2p_dis_msk;
 	int u3p_dis_msk;
-	struct regulator *vusb33;
-	struct regulator *vbus;
 	struct clk_bulk_data clks[BULK_CLKS_NUM];
+	struct regulator_bulk_data *supplies;
+	u8 num_supplies;
 	unsigned int has_ippc:1;
 	unsigned int lpm_support:1;
 	unsigned int u2_lpm_disable:1;