Re: [PATCH v2 1/6] phy: rockchip-typec: deprecate some DT properties for various register fields.

From: Heiko Stuebner
Date: Thu Feb 15 2018 - 11:06:47 EST


Hi Enric,

Am Mittwoch, 14. Februar 2018, 17:54:42 CET schrieb Enric Balletbo i Serra:
> Adding properties for various register fields in the DT doesn't scale and
> this information should be in the driver instead.
>
> Before this patch these registers (description below) were specified in
> the DT, every register node contained 3 sections: offset, enable bit,
> write mask bit.
>
> - rockchip,typec-conn-dir : the register of type-c connector direction,
> for type-c phy0, it must be <0xe580 0 16>;
> for type-c phy1, it must be <0xe58c 0 16>;
> - rockchip,usb3tousb2-en : the register of type-c force usb3 to usb2 enable
> control.
> for type-c phy0, it must be <0xe580 3 19>;
> for type-c phy1, it must be <0xe58c 3 19>;
> - rockchip,external-psm : the register of type-c phy external psm clock
> selection.
> for type-c phy0, it must be <0xe588 14 30>;
> for type-c phy1, it must be <0xe594 14 30>;
> - rockchip,pipe-status : the register of type-c phy pipe status.
> for type-c phy0, it must be <0xe5c0 0 0>;
> for type-c phy1, it must be <0xe5c0 16 16>;
>
> After this patch these register definitions are in the driver. So can be
> removed from the DT. Note that there are 2 type-c phys for RK3399 with
> different offsets, the driver checks the phy base address of the running
> instance and applies the right offsets.
>
> Signed-off-by: Enric Balletbo i Serra <enric.balletbo@xxxxxxxxxxxxx>

Generally I really support moving that stuff back into the driver and
judging by the recent mail conversations with Rob and Brian, this also
seems to be a consensus of sorts.

The one but I see here is, that the newly added things represent
rk3399-specific values and should be prefixed accordingly and also
already be flexible enough for the next soc using it.

Examples below.


> @@ -349,6 +349,9 @@
> #define MODE_DFP_USB BIT(1)
> #define MODE_DFP_DP BIT(2)
>
> +#define TYPEC_PHY0_BASE_ADDRESS 0xff7c0000
> +#define TYPEC_PHY1_BASE_ADDRESS 0xff800000

RK3399_TYPEC_PHY0_ADDRESS etc ?

> @@ -362,6 +365,20 @@ struct rockchip_usb3phy_port_cfg {
> struct usb3phy_reg pipe_status;
> };
>
> +static const struct rockchip_usb3phy_port_cfg tcphy0_port_cfg = {
> + .typec_conn_dir = { 0xe580, 0, 16 },
> + .usb3tousb2_en = { 0xe580, 3, 19 },
> + .external_psm = { 0xe588, 14, 30 },
> + .pipe_status = { 0xe5c0, 0, 0 },
> +};
> +
> +static const struct rockchip_usb3phy_port_cfg tcphy1_port_cfg = {
> + .typec_conn_dir = { 0xe58c, 0, 16 },
> + .usb3tousb2_en = { 0xe58c, 3, 19 },
> + .external_psm = { 0xe594, 14, 30 },
> + .pipe_status = { 0xe5c0, 16, 16 },
> +};

rk3399_tcphy1_port_cfg. Especially important as these are GRF-registers
(general register files = a dumping ground for random settings bits)
and nothing ever stays the same in the GRF between chips.


> @@ -1103,6 +1078,13 @@ static int rockchip_typec_phy_probe(struct platform_device *pdev)
> if (IS_ERR(tcphy->base))
> return PTR_ERR(tcphy->base);
>
> + if (res->start == TYPEC_PHY0_BASE_ADDRESS)
> + tcphy->port_cfgs = &tcphy0_port_cfg;
> + else if (res->start == TYPEC_PHY1_BASE_ADDRESS)
> + tcphy->port_cfgs = &tcphy1_port_cfg;
> + else
> + return -EINVAL;

should be selected according to the compatible.
Like just create a struct similar to things like the inno-usb2-phy.
That way you can also just write down the address itself in a reg
property and do not need specific constants like the ones at the top.


Heiko