[PATCH 1/3] phy: phy-sun4i-usb: add allwinner f1c100s configuration
Andre Przywara
andre.przywara at arm.com
Sat Jun 10 02:14:36 CEST 2023
On Fri, 9 Jun 2023 14:11:07 +0000
路辉 <luhux76 at gmail.com> wrote:
Hi,
> From 09a85536f92cfd22f2a6feba8ea91fae4bc41ed8 Mon Sep 17 00:00:00 2001
> From: Lu Hui <luhux76 at gmail.com>
> Date: Fri, 9 Jun 2023 22:04:56 +0800
> Subject: [PATCH 1/3] phy: phy-sun4i-usb: add allwinner f1c100s configuration
I sent a similar patch literally just a few hours ago:
https://lore.kernel.org/u-boot/20230609105621.1410483-1-andre.przywara@arm.com/T/
Can you please check whether this works for you as well? My series
missed the final MUSB enablement (because I wanted to test host mode
first), but at least the PHY part should work.
In the future, please add a commit message, describing your patch, and
also your Signed-off-by: line, otherwise the patch cannot be merged.
Cheers,
Andre
>
> ---
> drivers/phy/allwinner/phy-sun4i-usb.c | 14 +++++++++++++-
> 1 file changed, 13 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/phy/allwinner/phy-sun4i-usb.c
> b/drivers/phy/allwinner/phy-sun4i-usb.c
> index 6428163c18..8425a83c84 100644
> --- a/drivers/phy/allwinner/phy-sun4i-usb.c
> +++ b/drivers/phy/allwinner/phy-sun4i-usb.c
> @@ -4,6 +4,7 @@
> * Copyright (C) 2017 Jagan Teki <jagan at amarulasolutions.com>
> * Copyright (C) 2015 Hans de Goede <hdegoede at redhat.com>
> * Copyright (C) 2014 Roman Byshko <rbyshko at gmail.com>
> + * Copyright (C) 2023 Lu Hui <luhux76 at gmail.com>
> *
> * Modelled arch/arm/mach-sunxi/usb_phy.c to compatible with generic-phy.
> *
> @@ -83,6 +84,7 @@ enum sun4i_usb_phy_type {
> sun8i_v3s_phy,
> sun50i_a64_phy,
> sun50i_h6_phy,
> + suniv_f1c100s_phy,
> };
>
> struct sun4i_usb_phy_cfg {
> @@ -372,8 +374,9 @@ static int sun4i_usb_phy_xlate(struct phy *phy,
> {
> struct sun4i_usb_phy_data *data = dev_get_priv(phy->dev);
>
> - if (args->args_count >= data->cfg->num_phys)
> + if (args->args_count > data->cfg->num_phys) {
> return -EINVAL;
> + }
>
> if (data->cfg->missing_phys & BIT(args->args[0]))
> return -ENODEV;
> @@ -531,6 +534,14 @@ static int sun4i_usb_phy_probe(struct udevice *dev)
> return 0;
> }
>
> +static const struct sun4i_usb_phy_cfg suniv_f1c100s_cfg = {
> + .num_phys = 1,
> + .type = suniv_f1c100s_phy,
> + .disc_thresh = 3,
> + .phyctl_offset = REG_PHYCTL_A10,
> + .dedicated_clocks = true,
> +};
> +
> static const struct sun4i_usb_phy_cfg sun4i_a10_cfg = {
> .num_phys = 3,
> .type = sun4i_a10_phy,
> @@ -659,6 +670,7 @@ static const struct udevice_id sun4i_usb_phy_ids[] = {
> { .compatible = "allwinner,sun20i-d1-usb-phy", .data =
> (ulong)&sun20i_d1_cfg },
> { .compatible = "allwinner,sun50i-a64-usb-phy", .data =
> (ulong)&sun50i_a64_cfg},
> { .compatible = "allwinner,sun50i-h6-usb-phy", .data =
> (ulong)&sun50i_h6_cfg},
> + { .compatible = "allwinner,suniv-f1c100s-usb-phy", .data =
> (ulong)&suniv_f1c100s_cfg},
> { }
> };
>
More information about the U-Boot
mailing list