// SPDX-License-Identifier: GPL-2.0+ /* * (C) Copyright 2019 * Alex Marginean, NXP */ #include #include #include #define SANDBOX_PHY_ADDR 5 #define SANDBOX_PHY_REG 0 struct mdio_sandbox_priv { int enabled; u16 reg; }; static int mdio_sandbox_read(struct udevice *dev, int addr, int devad, int reg) { struct mdio_sandbox_priv *priv = dev_get_priv(dev); if (!priv->enabled) return -ENODEV; if (addr != SANDBOX_PHY_ADDR) return -ENODEV; if (devad != MDIO_DEVAD_NONE) return -ENODEV; if (reg != SANDBOX_PHY_REG) return -ENODEV; return priv->reg; } static int mdio_sandbox_write(struct udevice *dev, int addr, int devad, int reg, u16 val) { struct mdio_sandbox_priv *priv = dev_get_priv(dev); if (!priv->enabled) return -ENODEV; if (addr != SANDBOX_PHY_ADDR) return -ENODEV; if (devad != MDIO_DEVAD_NONE) return -ENODEV; if (reg != SANDBOX_PHY_REG) return -ENODEV; priv->reg = val; return 0; } static int mdio_sandbox_reset(struct udevice *dev) { struct mdio_sandbox_priv *priv = dev_get_priv(dev); priv->reg = 0; return 0; } static const struct mdio_ops mdio_sandbox_ops = { .read = mdio_sandbox_read, .write = mdio_sandbox_write, .reset = mdio_sandbox_reset, }; static int mdio_sandbox_probe(struct udevice *dev) { struct mdio_sandbox_priv *priv = dev_get_priv(dev); priv->enabled = 1; return 0; } static const struct udevice_id mdio_sandbox_ids[] = { { .compatible = "sandbox,mdio" }, { } }; U_BOOT_DRIVER(mdio_sandbox) = { .name = "mdio_sandbox", .id = UCLASS_MDIO, .of_match = mdio_sandbox_ids, .probe = mdio_sandbox_probe, .ops = &mdio_sandbox_ops, .priv_auto_alloc_size = sizeof(struct mdio_sandbox_priv), };