Lines Matching +full:ethernet +full:- +full:phy +full:- +full:package
1 // SPDX-License-Identifier: GPL-2.0+
28 #include <linux/phy.h>
40 #include "mdio-boardinfo.h"
45 mdiodev->reset_gpio = gpiod_get_optional(&mdiodev->dev, in mdiobus_register_gpiod()
47 if (IS_ERR(mdiodev->reset_gpio)) in mdiobus_register_gpiod()
48 return PTR_ERR(mdiodev->reset_gpio); in mdiobus_register_gpiod()
50 if (mdiodev->reset_gpio) in mdiobus_register_gpiod()
51 gpiod_set_consumer_name(mdiodev->reset_gpio, "PHY reset"); in mdiobus_register_gpiod()
60 reset = reset_control_get_optional_exclusive(&mdiodev->dev, "phy"); in mdiobus_register_reset()
64 mdiodev->reset_ctrl = reset; in mdiobus_register_reset()
73 if (mdiodev->bus->mdio_map[mdiodev->addr]) in mdiobus_register_device()
74 return -EBUSY; in mdiobus_register_device()
76 if (mdiodev->flags & MDIO_DEVICE_FLAG_PHY) { in mdiobus_register_device()
89 mdiodev->bus->mdio_map[mdiodev->addr] = mdiodev; in mdiobus_register_device()
97 if (mdiodev->bus->mdio_map[mdiodev->addr] != mdiodev) in mdiobus_unregister_device()
98 return -EINVAL; in mdiobus_unregister_device()
100 reset_control_put(mdiodev->reset_ctrl); in mdiobus_unregister_device()
102 mdiodev->bus->mdio_map[mdiodev->addr] = NULL; in mdiobus_unregister_device()
110 bool addr_valid = addr >= 0 && addr < ARRAY_SIZE(bus->mdio_map); in mdiobus_find_device()
115 return bus->mdio_map[addr]; in mdiobus_find_device()
126 if (!(mdiodev->flags & MDIO_DEVICE_FLAG_PHY)) in mdiobus_get_phy()
140 * mdiobus_alloc_size - allocate a mii_bus structure
142 * If non-zero, then bus->priv is points to that memory.
164 bus->state = MDIOBUS_ALLOCATED; in mdiobus_alloc_size()
166 bus->priv = (void *)bus + aligned_size; in mdiobus_alloc_size()
168 /* Initialise the interrupts to polling and 64-bit seqcounts */ in mdiobus_alloc_size()
170 bus->irq[i] = PHY_POLL; in mdiobus_alloc_size()
171 u64_stats_init(&bus->stats[i].syncp); in mdiobus_alloc_size()
179 * mdiobus_release - mii_bus device release callback
189 WARN(bus->state != MDIOBUS_RELEASED && in mdiobus_release()
191 bus->state != MDIOBUS_ALLOCATED, in mdiobus_release()
193 bus->id); in mdiobus_release()
195 if (bus->state == MDIOBUS_RELEASED) in mdiobus_release()
213 start = u64_stats_fetch_begin(&s->syncp); in mdio_bus_get_stat()
215 } while (u64_stats_fetch_retry(&s->syncp, start)); in mdio_bus_get_stat()
226 val += mdio_bus_get_stat(&bus->stats[i], offset); in mdio_bus_get_global_stat()
241 sattr = eattr->var; in mdio_bus_stat_field_show()
243 if (sattr->addr < 0) in mdio_bus_stat_field_show()
244 val = mdio_bus_get_global_stat(bus, sattr->field_offset); in mdio_bus_stat_field_show()
246 val = mdio_bus_get_stat(&bus->stats[sattr->addr], in mdio_bus_stat_field_show()
247 sattr->field_offset); in mdio_bus_stat_field_show()
257 struct mii_bus *bus = mdiodev->bus; in mdio_bus_device_stat_field_show()
260 int addr = mdiodev->addr; in mdio_bus_device_stat_field_show()
264 sattr = eattr->var; in mdio_bus_device_stat_field_show()
266 val = mdio_bus_get_stat(&bus->stats[addr], sattr->field_offset); in mdio_bus_device_stat_field_show()
277 -1, offsetof(struct mdio_bus_stats, field) \
285 -1, offsetof(struct mdio_bus_stats, field) \
413 * mdio_find_bus - Given the name of a mdiobus, find the mii_bus.
431 * of_mdio_find_bus - Given an mii_bus node, find the mii_bus.
458 * auto-probed phy devices to be supplied with information passed in
460 * If a PHY package is found, PHY is searched also there.
470 if (of_node_name_eq(child, "ethernet-phy-package")) { in of_mdiobus_find_phy()
471 /* Validate PHY package reg presence */ in of_mdiobus_find_phy()
474 return -EINVAL; in of_mdiobus_find_phy()
478 /* The refcount for the PHY package will be in of_mdiobus_find_phy()
479 * incremented later when PHY join the Package. in of_mdiobus_find_phy()
492 if (addr == mdiodev->addr) { in of_mdiobus_find_phy()
501 return -ENODEV; in of_mdiobus_find_phy()
507 struct device *dev = &mdiodev->dev; in of_mdiobus_link_mdiodev()
509 if (dev->of_node || !bus->dev.of_node) in of_mdiobus_link_mdiodev()
512 of_mdiobus_find_phy(dev, mdiodev, bus->dev.of_node); in of_mdiobus_link_mdiodev()
522 * mdiobus_create_device - create a full MDIO device given
535 mdiodev = mdio_device_create(bus, bi->mdio_addr); in mdiobus_create_device()
537 return -ENODEV; in mdiobus_create_device()
539 strscpy(mdiodev->modalias, bi->modalias, in mdiobus_create_device()
540 sizeof(mdiodev->modalias)); in mdiobus_create_device()
541 mdiodev->bus_match = mdio_device_bus_match; in mdiobus_create_device()
542 mdiodev->dev.platform_data = (void *)bi->platform_data; in mdiobus_create_device()
553 struct phy_device *phydev = ERR_PTR(-ENODEV); in mdiobus_scan()
562 /* For DT, see if the auto-probed phy has a corresponding child in mdiobus_scan()
565 of_mdiobus_link_mdiodev(bus, &phydev->mdio); in mdiobus_scan()
567 /* Search for a swnode for the phy in the swnode hierarchy of the bus. in mdiobus_scan()
568 * If there is no swnode for the phy provided, just ignore it. in mdiobus_scan()
570 if (dev_fwnode(&bus->dev) && !dev_fwnode(&phydev->mdio.dev)) { in mdiobus_scan()
571 snprintf(node_name, sizeof(node_name), "ethernet-phy@%d", in mdiobus_scan()
573 fwnode = fwnode_get_named_child_node(dev_fwnode(&bus->dev), in mdiobus_scan()
576 device_set_node(&phydev->mdio.dev, fwnode); in mdiobus_scan()
582 return ERR_PTR(-ENODEV); in mdiobus_scan()
589 * mdiobus_scan_c22 - scan one address on a bus for C22 MDIO devices.
596 * PHY devices typically do. Hence this function assumes anything
597 * found is a PHY, or can be treated as a PHY. Other MDIO devices,
607 * mdiobus_scan_c45 - scan one address on a bus for C45 MDIO devices.
614 * PHY devices typically do. Hence this function assumes anything
615 * found is a PHY, or can be treated as a PHY. Other MDIO devices,
628 if ((bus->phy_mask & BIT(i)) == 0) { in mdiobus_scan_bus_c22()
632 if (IS_ERR(phydev) && (PTR_ERR(phydev) != -ENODEV)) in mdiobus_scan_bus_c22()
644 if ((bus->phy_mask & BIT(i)) == 0) { in mdiobus_scan_bus_c45()
648 if (bus->mdio_map[i]) in mdiobus_scan_bus_c45()
652 if (IS_ERR(phydev) && (PTR_ERR(phydev) != -ENODEV)) in mdiobus_scan_bus_c45()
677 oui = phydev->phy_id >> 10; in mdiobus_prevent_c45_scan()
686 * __mdiobus_register - bring up all the PHYs on a given bus and attach them to bus
706 if (!bus || !bus->name) in __mdiobus_register()
707 return -EINVAL; in __mdiobus_register()
710 if (!!bus->read != !!bus->write || !!bus->read_c45 != !!bus->write_c45) in __mdiobus_register()
711 return -EINVAL; in __mdiobus_register()
714 if (!bus->read && !bus->read_c45) in __mdiobus_register()
715 return -EINVAL; in __mdiobus_register()
717 if (bus->parent && bus->parent->of_node) in __mdiobus_register()
718 bus->parent->of_node->fwnode.flags |= in __mdiobus_register()
721 WARN(bus->state != MDIOBUS_ALLOCATED && in __mdiobus_register()
722 bus->state != MDIOBUS_UNREGISTERED, in __mdiobus_register()
723 "%s: not in ALLOCATED or UNREGISTERED state\n", bus->id); in __mdiobus_register()
725 bus->owner = owner; in __mdiobus_register()
726 bus->dev.parent = bus->parent; in __mdiobus_register()
727 bus->dev.class = &mdio_bus_class; in __mdiobus_register()
728 bus->dev.groups = NULL; in __mdiobus_register()
729 dev_set_name(&bus->dev, "%s", bus->id); in __mdiobus_register()
737 if (bus->state == MDIOBUS_ALLOCATED) in __mdiobus_register()
738 fwnode_handle_get(dev_fwnode(&bus->dev)); in __mdiobus_register()
745 bus->state = MDIOBUS_UNREGISTERED; in __mdiobus_register()
747 err = device_register(&bus->dev); in __mdiobus_register()
749 pr_err("mii_bus %s failed to register\n", bus->id); in __mdiobus_register()
750 return -EINVAL; in __mdiobus_register()
753 mutex_init(&bus->mdio_lock); in __mdiobus_register()
754 mutex_init(&bus->shared_lock); in __mdiobus_register()
756 /* assert bus level PHY GPIO reset */ in __mdiobus_register()
757 gpiod = devm_gpiod_get_optional(&bus->dev, "reset", GPIOD_OUT_HIGH); in __mdiobus_register()
759 err = dev_err_probe(&bus->dev, PTR_ERR(gpiod), in __mdiobus_register()
761 bus->id); in __mdiobus_register()
762 device_del(&bus->dev); in __mdiobus_register()
765 bus->reset_gpiod = gpiod; in __mdiobus_register()
766 fsleep(bus->reset_delay_us); in __mdiobus_register()
768 if (bus->reset_post_delay_us > 0) in __mdiobus_register()
769 fsleep(bus->reset_post_delay_us); in __mdiobus_register()
772 if (bus->reset) { in __mdiobus_register()
773 err = bus->reset(bus); in __mdiobus_register()
778 if (bus->read) { in __mdiobus_register()
786 if (!prevent_c45_scan && bus->read_c45) { in __mdiobus_register()
794 bus->state = MDIOBUS_REGISTERED; in __mdiobus_register()
795 dev_dbg(&bus->dev, "probed\n"); in __mdiobus_register()
800 mdiodev = bus->mdio_map[i]; in __mdiobus_register()
804 mdiodev->device_remove(mdiodev); in __mdiobus_register()
805 mdiodev->device_free(mdiodev); in __mdiobus_register()
809 if (bus->reset_gpiod) in __mdiobus_register()
810 gpiod_set_value_cansleep(bus->reset_gpiod, 1); in __mdiobus_register()
812 device_del(&bus->dev); in __mdiobus_register()
822 if (WARN_ON_ONCE(bus->state != MDIOBUS_REGISTERED)) in mdiobus_unregister()
824 bus->state = MDIOBUS_UNREGISTERED; in mdiobus_unregister()
827 mdiodev = bus->mdio_map[i]; in mdiobus_unregister()
831 if (mdiodev->reset_gpio) in mdiobus_unregister()
832 gpiod_put(mdiodev->reset_gpio); in mdiobus_unregister()
834 mdiodev->device_remove(mdiodev); in mdiobus_unregister()
835 mdiodev->device_free(mdiodev); in mdiobus_unregister()
839 if (bus->reset_gpiod) in mdiobus_unregister()
840 gpiod_set_value_cansleep(bus->reset_gpiod, 1); in mdiobus_unregister()
842 device_del(&bus->dev); in mdiobus_unregister()
847 * mdiobus_free - free a struct mii_bus
857 if (bus->state == MDIOBUS_ALLOCATED) { in mdiobus_free()
862 WARN(bus->state != MDIOBUS_UNREGISTERED, in mdiobus_free()
863 "%s: not in UNREGISTERED state\n", bus->id); in mdiobus_free()
864 bus->state = MDIOBUS_RELEASED; in mdiobus_free()
866 put_device(&bus->dev); in mdiobus_free()
873 u64_stats_update_begin(&stats->syncp); in mdiobus_stats_acct()
875 u64_stats_inc(&stats->transfers); in mdiobus_stats_acct()
877 u64_stats_inc(&stats->errors); in mdiobus_stats_acct()
882 u64_stats_inc(&stats->reads); in mdiobus_stats_acct()
884 u64_stats_inc(&stats->writes); in mdiobus_stats_acct()
886 u64_stats_update_end(&stats->syncp); in mdiobus_stats_acct()
891 * __mdiobus_read - Unlocked version of the mdiobus_read function
893 * @addr: the phy address
904 lockdep_assert_held_once(&bus->mdio_lock); in __mdiobus_read()
906 if (bus->read) in __mdiobus_read()
907 retval = bus->read(bus, addr, regnum); in __mdiobus_read()
909 retval = -EOPNOTSUPP; in __mdiobus_read()
912 mdiobus_stats_acct(&bus->stats[addr], true, retval); in __mdiobus_read()
919 * __mdiobus_write - Unlocked version of the mdiobus_write function
921 * @addr: the phy address
933 lockdep_assert_held_once(&bus->mdio_lock); in __mdiobus_write()
935 if (bus->write) in __mdiobus_write()
936 err = bus->write(bus, addr, regnum, val); in __mdiobus_write()
938 err = -EOPNOTSUPP; in __mdiobus_write()
941 mdiobus_stats_acct(&bus->stats[addr], false, err); in __mdiobus_write()
948 * __mdiobus_modify_changed - Unlocked version of the mdiobus_modify function
950 * @addr: the phy address
980 * __mdiobus_c45_read - Unlocked version of the mdiobus_c45_read function
982 * @addr: the phy address
994 lockdep_assert_held_once(&bus->mdio_lock); in __mdiobus_c45_read()
996 if (bus->read_c45) in __mdiobus_c45_read()
997 retval = bus->read_c45(bus, addr, devad, regnum); in __mdiobus_c45_read()
999 retval = -EOPNOTSUPP; in __mdiobus_c45_read()
1002 mdiobus_stats_acct(&bus->stats[addr], true, retval); in __mdiobus_c45_read()
1009 * __mdiobus_c45_write - Unlocked version of the mdiobus_write function
1011 * @addr: the phy address
1025 lockdep_assert_held_once(&bus->mdio_lock); in __mdiobus_c45_write()
1027 if (bus->write_c45) in __mdiobus_c45_write()
1028 err = bus->write_c45(bus, addr, devad, regnum, val); in __mdiobus_c45_write()
1030 err = -EOPNOTSUPP; in __mdiobus_c45_write()
1033 mdiobus_stats_acct(&bus->stats[addr], false, err); in __mdiobus_c45_write()
1040 * __mdiobus_c45_modify_changed - Unlocked version of the mdiobus_modify function
1042 * @addr: the phy address
1073 * mdiobus_read_nested - Nested version of the mdiobus_read function
1075 * @addr: the phy address
1089 mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); in mdiobus_read_nested()
1091 mutex_unlock(&bus->mdio_lock); in mdiobus_read_nested()
1098 * mdiobus_read - Convenience function for reading a given MII mgmt register
1100 * @addr: the phy address
1111 mutex_lock(&bus->mdio_lock); in mdiobus_read()
1113 mutex_unlock(&bus->mdio_lock); in mdiobus_read()
1120 * mdiobus_c45_read - Convenience function for reading a given MII mgmt register
1122 * @addr: the phy address
1134 mutex_lock(&bus->mdio_lock); in mdiobus_c45_read()
1136 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_read()
1143 * mdiobus_c45_read_nested - Nested version of the mdiobus_c45_read function
1145 * @addr: the phy address
1161 mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); in mdiobus_c45_read_nested()
1163 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_read_nested()
1170 * mdiobus_write_nested - Nested version of the mdiobus_write function
1172 * @addr: the phy address
1187 mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); in mdiobus_write_nested()
1189 mutex_unlock(&bus->mdio_lock); in mdiobus_write_nested()
1196 * mdiobus_write - Convenience function for writing a given MII mgmt register
1198 * @addr: the phy address
1210 mutex_lock(&bus->mdio_lock); in mdiobus_write()
1212 mutex_unlock(&bus->mdio_lock); in mdiobus_write()
1219 * mdiobus_c45_write - Convenience function for writing a given MII mgmt register
1221 * @addr: the phy address
1235 mutex_lock(&bus->mdio_lock); in mdiobus_c45_write()
1237 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_write()
1244 * mdiobus_c45_write_nested - Nested version of the mdiobus_c45_write function
1246 * @addr: the phy address
1263 mutex_lock_nested(&bus->mdio_lock, MDIO_MUTEX_NESTED); in mdiobus_c45_write_nested()
1265 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_write_nested()
1272 * __mdiobus_modify - Convenience function for modifying a given mdio device
1275 * @addr: the phy address
1292 * mdiobus_modify - Convenience function for modifying a given mdio device
1295 * @addr: the phy address
1304 mutex_lock(&bus->mdio_lock); in mdiobus_modify()
1306 mutex_unlock(&bus->mdio_lock); in mdiobus_modify()
1313 * mdiobus_c45_modify - Convenience function for modifying a given mdio device
1316 * @addr: the phy address
1327 mutex_lock(&bus->mdio_lock); in mdiobus_c45_modify()
1330 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_modify()
1337 * mdiobus_modify_changed - Convenience function for modifying a given mdio
1340 * @addr: the phy address
1350 mutex_lock(&bus->mdio_lock); in mdiobus_modify_changed()
1352 mutex_unlock(&bus->mdio_lock); in mdiobus_modify_changed()
1359 * mdiobus_c45_modify_changed - Convenience function for modifying a given mdio
1362 * @addr: the phy address
1373 mutex_lock(&bus->mdio_lock); in mdiobus_c45_modify_changed()
1375 mutex_unlock(&bus->mdio_lock); in mdiobus_c45_modify_changed()
1382 * mdio_bus_match - determine if given MDIO driver supports the given
1397 /* Both the driver and device must type-match */ in mdio_bus_match()
1398 if (!(mdiodrv->mdiodrv.flags & MDIO_DEVICE_IS_PHY) != in mdio_bus_match()
1399 !(mdio->flags & MDIO_DEVICE_FLAG_PHY)) in mdio_bus_match()
1405 if (mdio->bus_match) in mdio_bus_match()
1406 return mdio->bus_match(dev, drv); in mdio_bus_match()
1415 /* Some devices have extra OF data and an OF-style MODALIAS */ in mdio_uevent()
1417 if (rc != -ENODEV) in mdio_uevent()