[PATCH v2 1/5] net: sun8i-emac: Add a structure for variant data
Andre Przywara
andre.przywara at arm.com
Mon Jan 23 18:21:25 CET 2023
On 22/01/2023 22:51, Samuel Holland wrote:
> Currently, EMAC variants are distinguished by their identity, but this
> gets unwieldy as more overlapping variants are added. Add a structure so
> we can describe the individual feature differences between the variants.
>
> Signed-off-by: Samuel Holland <samuel at sholland.org>
Looks alright, given that this is temporary/preparatory.
Reviewed-by: Andre Przywara <andre.przywara at arm.com>
Cheers,
Andre
> ---
>
> Changes in v2:
> - New patch for v2
>
> drivers/net/sun8i_emac.c | 65 +++++++++++++++++++++++++++-------------
> 1 file changed, 45 insertions(+), 20 deletions(-)
>
> diff --git a/drivers/net/sun8i_emac.c b/drivers/net/sun8i_emac.c
> index e800a326b8..986e565cd8 100644
> --- a/drivers/net/sun8i_emac.c
> +++ b/drivers/net/sun8i_emac.c
> @@ -127,7 +127,7 @@
>
> DECLARE_GLOBAL_DATA_PTR;
>
> -enum emac_variant {
> +enum emac_variant_id {
> A83T_EMAC = 1,
> H3_EMAC,
> A64_EMAC,
> @@ -135,6 +135,10 @@ enum emac_variant {
> H6_EMAC,
> };
>
> +struct emac_variant {
> + enum emac_variant_id variant;
> +};
> +
> struct emac_dma_desc {
> u32 status;
> u32 ctl_size;
> @@ -160,7 +164,7 @@ struct emac_eth_dev {
> u32 tx_slot;
> bool use_internal_phy;
>
> - enum emac_variant variant;
> + const struct emac_variant *variant;
> void *mac_reg;
> phys_addr_t sysctl_reg;
> struct phy_device *phydev;
> @@ -317,7 +321,7 @@ static int sun8i_emac_set_syscon(struct sun8i_eth_pdata *pdata,
> {
> u32 reg;
>
> - if (priv->variant == R40_GMAC) {
> + if (priv->variant->variant == R40_GMAC) {
> /* Select RGMII for R40 */
> reg = readl(priv->sysctl_reg + 0x164);
> reg |= SC_ETCS_INT_GMII |
> @@ -333,9 +337,9 @@ static int sun8i_emac_set_syscon(struct sun8i_eth_pdata *pdata,
> reg = sun8i_emac_set_syscon_ephy(priv, reg);
>
> reg &= ~(SC_ETCS_MASK | SC_EPIT);
> - if (priv->variant == H3_EMAC ||
> - priv->variant == A64_EMAC ||
> - priv->variant == H6_EMAC)
> + if (priv->variant->variant == H3_EMAC ||
> + priv->variant->variant == A64_EMAC ||
> + priv->variant->variant == H6_EMAC)
> reg &= ~SC_RMII_EN;
>
> switch (priv->interface) {
> @@ -349,9 +353,9 @@ static int sun8i_emac_set_syscon(struct sun8i_eth_pdata *pdata,
> reg |= SC_EPIT | SC_ETCS_INT_GMII;
> break;
> case PHY_INTERFACE_MODE_RMII:
> - if (priv->variant == H3_EMAC ||
> - priv->variant == A64_EMAC ||
> - priv->variant == H6_EMAC) {
> + if (priv->variant->variant == H3_EMAC ||
> + priv->variant->variant == A64_EMAC ||
> + priv->variant->variant == H6_EMAC) {
> reg |= SC_RMII_EN | SC_ETCS_EXT_GMII;
> break;
> }
> @@ -806,7 +810,7 @@ static int sun8i_emac_eth_of_to_plat(struct udevice *dev)
> return -EINVAL;
> }
>
> - priv->variant = dev_get_driver_data(dev);
> + priv->variant = (const void *)dev_get_driver_data(dev);
>
> if (!priv->variant) {
> printf("%s: Missing variant\n", __func__);
> @@ -860,7 +864,7 @@ static int sun8i_emac_eth_of_to_plat(struct udevice *dev)
> if (pdata->phy_interface == PHY_INTERFACE_MODE_NA)
> return -EINVAL;
>
> - if (priv->variant == H3_EMAC) {
> + if (priv->variant->variant == H3_EMAC) {
> ret = sun8i_handle_internal_phy(dev, priv);
> if (ret)
> return ret;
> @@ -900,16 +904,37 @@ static int sun8i_emac_eth_of_to_plat(struct udevice *dev)
> return 0;
> }
>
> +static const struct emac_variant emac_variant_a83t = {
> + .variant = A83T_EMAC,
> +};
> +
> +static const struct emac_variant emac_variant_h3 = {
> + .variant = H3_EMAC,
> +};
> +
> +static const struct emac_variant emac_variant_r40 = {
> + .variant = R40_GMAC,
> +};
> +
> +static const struct emac_variant emac_variant_a64 = {
> + .variant = A64_EMAC,
> +};
> +
> +static const struct emac_variant emac_variant_h6 = {
> + .variant = H6_EMAC,
> +};
> +
> static const struct udevice_id sun8i_emac_eth_ids[] = {
> - {.compatible = "allwinner,sun8i-h3-emac", .data = (uintptr_t)H3_EMAC },
> - {.compatible = "allwinner,sun50i-a64-emac",
> - .data = (uintptr_t)A64_EMAC },
> - {.compatible = "allwinner,sun8i-a83t-emac",
> - .data = (uintptr_t)A83T_EMAC },
> - {.compatible = "allwinner,sun8i-r40-gmac",
> - .data = (uintptr_t)R40_GMAC },
> - {.compatible = "allwinner,sun50i-h6-emac",
> - .data = (uintptr_t)H6_EMAC },
> + { .compatible = "allwinner,sun8i-a83t-emac",
> + .data = (ulong)&emac_variant_a83t },
> + { .compatible = "allwinner,sun8i-h3-emac",
> + .data = (ulong)&emac_variant_h3 },
> + { .compatible = "allwinner,sun8i-r40-gmac",
> + .data = (ulong)&emac_variant_r40 },
> + { .compatible = "allwinner,sun50i-a64-emac",
> + .data = (ulong)&emac_variant_a64 },
> + { .compatible = "allwinner,sun50i-h6-emac",
> + .data = (ulong)&emac_variant_h6 },
> { }
> };
>
More information about the U-Boot
mailing list