linux/include/linux/phy.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0-or-later */
   2/*
   3 * Framework and drivers for configuring and reading different PHYs
   4 * Based on code in sungem_phy.c and (long-removed) gianfar_phy.c
   5 *
   6 * Author: Andy Fleming
   7 *
   8 * Copyright (c) 2004 Freescale Semiconductor, Inc.
   9 */
  10
  11#ifndef __PHY_H
  12#define __PHY_H
  13
  14#include <linux/compiler.h>
  15#include <linux/spinlock.h>
  16#include <linux/ethtool.h>
  17#include <linux/linkmode.h>
  18#include <linux/netlink.h>
  19#include <linux/mdio.h>
  20#include <linux/mii.h>
  21#include <linux/mii_timestamper.h>
  22#include <linux/module.h>
  23#include <linux/timer.h>
  24#include <linux/workqueue.h>
  25#include <linux/mod_devicetable.h>
  26#include <linux/u64_stats_sync.h>
  27#include <linux/irqreturn.h>
  28#include <linux/iopoll.h>
  29#include <linux/refcount.h>
  30
  31#include <linux/atomic.h>
  32
  33#define PHY_DEFAULT_FEATURES    (SUPPORTED_Autoneg | \
  34                                 SUPPORTED_TP | \
  35                                 SUPPORTED_MII)
  36
  37#define PHY_10BT_FEATURES       (SUPPORTED_10baseT_Half | \
  38                                 SUPPORTED_10baseT_Full)
  39
  40#define PHY_100BT_FEATURES      (SUPPORTED_100baseT_Half | \
  41                                 SUPPORTED_100baseT_Full)
  42
  43#define PHY_1000BT_FEATURES     (SUPPORTED_1000baseT_Half | \
  44                                 SUPPORTED_1000baseT_Full)
  45
  46extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_features) __ro_after_init;
  47extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_basic_t1_features) __ro_after_init;
  48extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_features) __ro_after_init;
  49extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_fibre_features) __ro_after_init;
  50extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_gbit_all_ports_features) __ro_after_init;
  51extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_features) __ro_after_init;
  52extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_fec_features) __ro_after_init;
  53extern __ETHTOOL_DECLARE_LINK_MODE_MASK(phy_10gbit_full_features) __ro_after_init;
  54
  55#define PHY_BASIC_FEATURES ((unsigned long *)&phy_basic_features)
  56#define PHY_BASIC_T1_FEATURES ((unsigned long *)&phy_basic_t1_features)
  57#define PHY_GBIT_FEATURES ((unsigned long *)&phy_gbit_features)
  58#define PHY_GBIT_FIBRE_FEATURES ((unsigned long *)&phy_gbit_fibre_features)
  59#define PHY_GBIT_ALL_PORTS_FEATURES ((unsigned long *)&phy_gbit_all_ports_features)
  60#define PHY_10GBIT_FEATURES ((unsigned long *)&phy_10gbit_features)
  61#define PHY_10GBIT_FEC_FEATURES ((unsigned long *)&phy_10gbit_fec_features)
  62#define PHY_10GBIT_FULL_FEATURES ((unsigned long *)&phy_10gbit_full_features)
  63
  64extern const int phy_basic_ports_array[3];
  65extern const int phy_fibre_port_array[1];
  66extern const int phy_all_ports_features_array[7];
  67extern const int phy_10_100_features_array[4];
  68extern const int phy_basic_t1_features_array[2];
  69extern const int phy_gbit_features_array[2];
  70extern const int phy_10gbit_features_array[1];
  71
  72/*
  73 * Set phydev->irq to PHY_POLL if interrupts are not supported,
  74 * or not desired for this PHY.  Set to PHY_MAC_INTERRUPT if
  75 * the attached MAC driver handles the interrupt
  76 */
  77#define PHY_POLL                -1
  78#define PHY_MAC_INTERRUPT       -2
  79
  80#define PHY_IS_INTERNAL         0x00000001
  81#define PHY_RST_AFTER_CLK_EN    0x00000002
  82#define PHY_POLL_CABLE_TEST     0x00000004
  83#define MDIO_DEVICE_IS_PHY      0x80000000
  84
  85/**
  86 * enum phy_interface_t - Interface Mode definitions
  87 *
  88 * @PHY_INTERFACE_MODE_NA: Not Applicable - don't touch
  89 * @PHY_INTERFACE_MODE_INTERNAL: No interface, MAC and PHY combined
  90 * @PHY_INTERFACE_MODE_MII: Median-independent interface
  91 * @PHY_INTERFACE_MODE_GMII: Gigabit median-independent interface
  92 * @PHY_INTERFACE_MODE_SGMII: Serial gigabit media-independent interface
  93 * @PHY_INTERFACE_MODE_TBI: Ten Bit Interface
  94 * @PHY_INTERFACE_MODE_REVMII: Reverse Media Independent Interface
  95 * @PHY_INTERFACE_MODE_RMII: Reduced Media Independent Interface
  96 * @PHY_INTERFACE_MODE_REVRMII: Reduced Media Independent Interface in PHY role
  97 * @PHY_INTERFACE_MODE_RGMII: Reduced gigabit media-independent interface
  98 * @PHY_INTERFACE_MODE_RGMII_ID: RGMII with Internal RX+TX delay
  99 * @PHY_INTERFACE_MODE_RGMII_RXID: RGMII with Internal RX delay
 100 * @PHY_INTERFACE_MODE_RGMII_TXID: RGMII with Internal RX delay
 101 * @PHY_INTERFACE_MODE_RTBI: Reduced TBI
 102 * @PHY_INTERFACE_MODE_SMII: ??? MII
 103 * @PHY_INTERFACE_MODE_XGMII: 10 gigabit media-independent interface
 104 * @PHY_INTERFACE_MODE_XLGMII:40 gigabit media-independent interface
 105 * @PHY_INTERFACE_MODE_MOCA: Multimedia over Coax
 106 * @PHY_INTERFACE_MODE_QSGMII: Quad SGMII
 107 * @PHY_INTERFACE_MODE_TRGMII: Turbo RGMII
 108 * @PHY_INTERFACE_MODE_100BASEX: 100 BaseX
 109 * @PHY_INTERFACE_MODE_1000BASEX: 1000 BaseX
 110 * @PHY_INTERFACE_MODE_2500BASEX: 2500 BaseX
 111 * @PHY_INTERFACE_MODE_5GBASER: 5G BaseR
 112 * @PHY_INTERFACE_MODE_RXAUI: Reduced XAUI
 113 * @PHY_INTERFACE_MODE_XAUI: 10 Gigabit Attachment Unit Interface
 114 * @PHY_INTERFACE_MODE_10GBASER: 10G BaseR
 115 * @PHY_INTERFACE_MODE_25GBASER: 25G BaseR
 116 * @PHY_INTERFACE_MODE_USXGMII:  Universal Serial 10GE MII
 117 * @PHY_INTERFACE_MODE_10GKR: 10GBASE-KR - with Clause 73 AN
 118 * @PHY_INTERFACE_MODE_MAX: Book keeping
 119 *
 120 * Describes the interface between the MAC and PHY.
 121 */
 122typedef enum {
 123        PHY_INTERFACE_MODE_NA,
 124        PHY_INTERFACE_MODE_INTERNAL,
 125        PHY_INTERFACE_MODE_MII,
 126        PHY_INTERFACE_MODE_GMII,
 127        PHY_INTERFACE_MODE_SGMII,
 128        PHY_INTERFACE_MODE_TBI,
 129        PHY_INTERFACE_MODE_REVMII,
 130        PHY_INTERFACE_MODE_RMII,
 131        PHY_INTERFACE_MODE_REVRMII,
 132        PHY_INTERFACE_MODE_RGMII,
 133        PHY_INTERFACE_MODE_RGMII_ID,
 134        PHY_INTERFACE_MODE_RGMII_RXID,
 135        PHY_INTERFACE_MODE_RGMII_TXID,
 136        PHY_INTERFACE_MODE_RTBI,
 137        PHY_INTERFACE_MODE_SMII,
 138        PHY_INTERFACE_MODE_XGMII,
 139        PHY_INTERFACE_MODE_XLGMII,
 140        PHY_INTERFACE_MODE_MOCA,
 141        PHY_INTERFACE_MODE_QSGMII,
 142        PHY_INTERFACE_MODE_TRGMII,
 143        PHY_INTERFACE_MODE_100BASEX,
 144        PHY_INTERFACE_MODE_1000BASEX,
 145        PHY_INTERFACE_MODE_2500BASEX,
 146        PHY_INTERFACE_MODE_5GBASER,
 147        PHY_INTERFACE_MODE_RXAUI,
 148        PHY_INTERFACE_MODE_XAUI,
 149        /* 10GBASE-R, XFI, SFI - single lane 10G Serdes */
 150        PHY_INTERFACE_MODE_10GBASER,
 151        PHY_INTERFACE_MODE_25GBASER,
 152        PHY_INTERFACE_MODE_USXGMII,
 153        /* 10GBASE-KR - with Clause 73 AN */
 154        PHY_INTERFACE_MODE_10GKR,
 155        PHY_INTERFACE_MODE_MAX,
 156} phy_interface_t;
 157
 158/*
 159 * phy_supported_speeds - return all speeds currently supported by a PHY device
 160 */
 161unsigned int phy_supported_speeds(struct phy_device *phy,
 162                                      unsigned int *speeds,
 163                                      unsigned int size);
 164
 165/**
 166 * phy_modes - map phy_interface_t enum to device tree binding of phy-mode
 167 * @interface: enum phy_interface_t value
 168 *
 169 * Description: maps enum &phy_interface_t defined in this file
 170 * into the device tree binding of 'phy-mode', so that Ethernet
 171 * device driver can get PHY interface from device tree.
 172 */
 173static inline const char *phy_modes(phy_interface_t interface)
 174{
 175        switch (interface) {
 176        case PHY_INTERFACE_MODE_NA:
 177                return "";
 178        case PHY_INTERFACE_MODE_INTERNAL:
 179                return "internal";
 180        case PHY_INTERFACE_MODE_MII:
 181                return "mii";
 182        case PHY_INTERFACE_MODE_GMII:
 183                return "gmii";
 184        case PHY_INTERFACE_MODE_SGMII:
 185                return "sgmii";
 186        case PHY_INTERFACE_MODE_TBI:
 187                return "tbi";
 188        case PHY_INTERFACE_MODE_REVMII:
 189                return "rev-mii";
 190        case PHY_INTERFACE_MODE_RMII:
 191                return "rmii";
 192        case PHY_INTERFACE_MODE_REVRMII:
 193                return "rev-rmii";
 194        case PHY_INTERFACE_MODE_RGMII:
 195                return "rgmii";
 196        case PHY_INTERFACE_MODE_RGMII_ID:
 197                return "rgmii-id";
 198        case PHY_INTERFACE_MODE_RGMII_RXID:
 199                return "rgmii-rxid";
 200        case PHY_INTERFACE_MODE_RGMII_TXID:
 201                return "rgmii-txid";
 202        case PHY_INTERFACE_MODE_RTBI:
 203                return "rtbi";
 204        case PHY_INTERFACE_MODE_SMII:
 205                return "smii";
 206        case PHY_INTERFACE_MODE_XGMII:
 207                return "xgmii";
 208        case PHY_INTERFACE_MODE_XLGMII:
 209                return "xlgmii";
 210        case PHY_INTERFACE_MODE_MOCA:
 211                return "moca";
 212        case PHY_INTERFACE_MODE_QSGMII:
 213                return "qsgmii";
 214        case PHY_INTERFACE_MODE_TRGMII:
 215                return "trgmii";
 216        case PHY_INTERFACE_MODE_1000BASEX:
 217                return "1000base-x";
 218        case PHY_INTERFACE_MODE_2500BASEX:
 219                return "2500base-x";
 220        case PHY_INTERFACE_MODE_5GBASER:
 221                return "5gbase-r";
 222        case PHY_INTERFACE_MODE_RXAUI:
 223                return "rxaui";
 224        case PHY_INTERFACE_MODE_XAUI:
 225                return "xaui";
 226        case PHY_INTERFACE_MODE_10GBASER:
 227                return "10gbase-r";
 228        case PHY_INTERFACE_MODE_25GBASER:
 229                return "25gbase-r";
 230        case PHY_INTERFACE_MODE_USXGMII:
 231                return "usxgmii";
 232        case PHY_INTERFACE_MODE_10GKR:
 233                return "10gbase-kr";
 234        case PHY_INTERFACE_MODE_100BASEX:
 235                return "100base-x";
 236        default:
 237                return "unknown";
 238        }
 239}
 240
 241
 242#define PHY_INIT_TIMEOUT        100000
 243#define PHY_FORCE_TIMEOUT       10
 244
 245#define PHY_MAX_ADDR    32
 246
 247/* Used when trying to connect to a specific phy (mii bus id:phy device id) */
 248#define PHY_ID_FMT "%s:%02x"
 249
 250#define MII_BUS_ID_SIZE 61
 251
 252struct device;
 253struct phylink;
 254struct sfp_bus;
 255struct sfp_upstream_ops;
 256struct sk_buff;
 257
 258/**
 259 * struct mdio_bus_stats - Statistics counters for MDIO busses
 260 * @transfers: Total number of transfers, i.e. @writes + @reads
 261 * @errors: Number of MDIO transfers that returned an error
 262 * @writes: Number of write transfers
 263 * @reads: Number of read transfers
 264 * @syncp: Synchronisation for incrementing statistics
 265 */
 266struct mdio_bus_stats {
 267        u64_stats_t transfers;
 268        u64_stats_t errors;
 269        u64_stats_t writes;
 270        u64_stats_t reads;
 271        /* Must be last, add new statistics above */
 272        struct u64_stats_sync syncp;
 273};
 274
 275/**
 276 * struct phy_package_shared - Shared information in PHY packages
 277 * @addr: Common PHY address used to combine PHYs in one package
 278 * @refcnt: Number of PHYs connected to this shared data
 279 * @flags: Initialization of PHY package
 280 * @priv_size: Size of the shared private data @priv
 281 * @priv: Driver private data shared across a PHY package
 282 *
 283 * Represents a shared structure between different phydev's in the same
 284 * package, for example a quad PHY. See phy_package_join() and
 285 * phy_package_leave().
 286 */
 287struct phy_package_shared {
 288        int addr;
 289        refcount_t refcnt;
 290        unsigned long flags;
 291        size_t priv_size;
 292
 293        /* private data pointer */
 294        /* note that this pointer is shared between different phydevs and
 295         * the user has to take care of appropriate locking. It is allocated
 296         * and freed automatically by phy_package_join() and
 297         * phy_package_leave().
 298         */
 299        void *priv;
 300};
 301
 302/* used as bit number in atomic bitops */
 303#define PHY_SHARED_F_INIT_DONE  0
 304#define PHY_SHARED_F_PROBE_DONE 1
 305
 306/**
 307 * struct mii_bus - Represents an MDIO bus
 308 *
 309 * @owner: Who owns this device
 310 * @name: User friendly name for this MDIO device, or driver name
 311 * @id: Unique identifier for this bus, typical from bus hierarchy
 312 * @priv: Driver private data
 313 *
 314 * The Bus class for PHYs.  Devices which provide access to
 315 * PHYs should register using this structure
 316 */
 317struct mii_bus {
 318        struct module *owner;
 319        const char *name;
 320        char id[MII_BUS_ID_SIZE];
 321        void *priv;
 322        /** @read: Perform a read transfer on the bus */
 323        int (*read)(struct mii_bus *bus, int addr, int regnum);
 324        /** @write: Perform a write transfer on the bus */
 325        int (*write)(struct mii_bus *bus, int addr, int regnum, u16 val);
 326        /** @reset: Perform a reset of the bus */
 327        int (*reset)(struct mii_bus *bus);
 328
 329        /** @stats: Statistic counters per device on the bus */
 330        struct mdio_bus_stats stats[PHY_MAX_ADDR];
 331
 332        /**
 333         * @mdio_lock: A lock to ensure that only one thing can read/write
 334         * the MDIO bus at a time
 335         */
 336        struct mutex mdio_lock;
 337
 338        /** @parent: Parent device of this bus */
 339        struct device *parent;
 340        /** @state: State of bus structure */
 341        enum {
 342                MDIOBUS_ALLOCATED = 1,
 343                MDIOBUS_REGISTERED,
 344                MDIOBUS_UNREGISTERED,
 345                MDIOBUS_RELEASED,
 346        } state;
 347
 348        /** @dev: Kernel device representation */
 349        struct device dev;
 350
 351        /** @mdio_map: list of all MDIO devices on bus */
 352        struct mdio_device *mdio_map[PHY_MAX_ADDR];
 353
 354        /** @phy_mask: PHY addresses to be ignored when probing */
 355        u32 phy_mask;
 356
 357        /** @phy_ignore_ta_mask: PHY addresses to ignore the TA/read failure */
 358        u32 phy_ignore_ta_mask;
 359
 360        /**
 361         * @irq: An array of interrupts, each PHY's interrupt at the index
 362         * matching its address
 363         */
 364        int irq[PHY_MAX_ADDR];
 365
 366        /** @reset_delay_us: GPIO reset pulse width in microseconds */
 367        int reset_delay_us;
 368        /** @reset_post_delay_us: GPIO reset deassert delay in microseconds */
 369        int reset_post_delay_us;
 370        /** @reset_gpiod: Reset GPIO descriptor pointer */
 371        struct gpio_desc *reset_gpiod;
 372
 373        /** @probe_capabilities: bus capabilities, used for probing */
 374        enum {
 375                MDIOBUS_NO_CAP = 0,
 376                MDIOBUS_C22,
 377                MDIOBUS_C45,
 378                MDIOBUS_C22_C45,
 379        } probe_capabilities;
 380
 381        /** @shared_lock: protect access to the shared element */
 382        struct mutex shared_lock;
 383
 384        /** @shared: shared state across different PHYs */
 385        struct phy_package_shared *shared[PHY_MAX_ADDR];
 386};
 387#define to_mii_bus(d) container_of(d, struct mii_bus, dev)
 388
 389struct mii_bus *mdiobus_alloc_size(size_t size);
 390
 391/**
 392 * mdiobus_alloc - Allocate an MDIO bus structure
 393 *
 394 * The internal state of the MDIO bus will be set of MDIOBUS_ALLOCATED ready
 395 * for the driver to register the bus.
 396 */
 397static inline struct mii_bus *mdiobus_alloc(void)
 398{
 399        return mdiobus_alloc_size(0);
 400}
 401
 402int __mdiobus_register(struct mii_bus *bus, struct module *owner);
 403int __devm_mdiobus_register(struct device *dev, struct mii_bus *bus,
 404                            struct module *owner);
 405#define mdiobus_register(bus) __mdiobus_register(bus, THIS_MODULE)
 406#define devm_mdiobus_register(dev, bus) \
 407                __devm_mdiobus_register(dev, bus, THIS_MODULE)
 408
 409void mdiobus_unregister(struct mii_bus *bus);
 410void mdiobus_free(struct mii_bus *bus);
 411struct mii_bus *devm_mdiobus_alloc_size(struct device *dev, int sizeof_priv);
 412static inline struct mii_bus *devm_mdiobus_alloc(struct device *dev)
 413{
 414        return devm_mdiobus_alloc_size(dev, 0);
 415}
 416
 417struct mii_bus *mdio_find_bus(const char *mdio_name);
 418struct phy_device *mdiobus_scan(struct mii_bus *bus, int addr);
 419
 420#define PHY_INTERRUPT_DISABLED  false
 421#define PHY_INTERRUPT_ENABLED   true
 422
 423/**
 424 * enum phy_state - PHY state machine states:
 425 *
 426 * @PHY_DOWN: PHY device and driver are not ready for anything.  probe
 427 * should be called if and only if the PHY is in this state,
 428 * given that the PHY device exists.
 429 * - PHY driver probe function will set the state to @PHY_READY
 430 *
 431 * @PHY_READY: PHY is ready to send and receive packets, but the
 432 * controller is not.  By default, PHYs which do not implement
 433 * probe will be set to this state by phy_probe().
 434 * - start will set the state to UP
 435 *
 436 * @PHY_UP: The PHY and attached device are ready to do work.
 437 * Interrupts should be started here.
 438 * - timer moves to @PHY_NOLINK or @PHY_RUNNING
 439 *
 440 * @PHY_NOLINK: PHY is up, but not currently plugged in.
 441 * - irq or timer will set @PHY_RUNNING if link comes back
 442 * - phy_stop moves to @PHY_HALTED
 443 *
 444 * @PHY_RUNNING: PHY is currently up, running, and possibly sending
 445 * and/or receiving packets
 446 * - irq or timer will set @PHY_NOLINK if link goes down
 447 * - phy_stop moves to @PHY_HALTED
 448 *
 449 * @PHY_CABLETEST: PHY is performing a cable test. Packet reception/sending
 450 * is not expected to work, carrier will be indicated as down. PHY will be
 451 * poll once per second, or on interrupt for it current state.
 452 * Once complete, move to UP to restart the PHY.
 453 * - phy_stop aborts the running test and moves to @PHY_HALTED
 454 *
 455 * @PHY_HALTED: PHY is up, but no polling or interrupts are done. Or
 456 * PHY is in an error state.
 457 * - phy_start moves to @PHY_UP
 458 */
 459enum phy_state {
 460        PHY_DOWN = 0,
 461        PHY_READY,
 462        PHY_HALTED,
 463        PHY_UP,
 464        PHY_RUNNING,
 465        PHY_NOLINK,
 466        PHY_CABLETEST,
 467};
 468
 469#define MDIO_MMD_NUM 32
 470
 471/**
 472 * struct phy_c45_device_ids - 802.3-c45 Device Identifiers
 473 * @devices_in_package: IEEE 802.3 devices in package register value.
 474 * @mmds_present: bit vector of MMDs present.
 475 * @device_ids: The device identifer for each present device.
 476 */
 477struct phy_c45_device_ids {
 478        u32 devices_in_package;
 479        u32 mmds_present;
 480        u32 device_ids[MDIO_MMD_NUM];
 481};
 482
 483struct macsec_context;
 484struct macsec_ops;
 485
 486/**
 487 * struct phy_device - An instance of a PHY
 488 *
 489 * @mdio: MDIO bus this PHY is on
 490 * @drv: Pointer to the driver for this PHY instance
 491 * @phy_id: UID for this device found during discovery
 492 * @c45_ids: 802.3-c45 Device Identifiers if is_c45.
 493 * @is_c45:  Set to true if this PHY uses clause 45 addressing.
 494 * @is_internal: Set to true if this PHY is internal to a MAC.
 495 * @is_pseudo_fixed_link: Set to true if this PHY is an Ethernet switch, etc.
 496 * @is_gigabit_capable: Set to true if PHY supports 1000Mbps
 497 * @has_fixups: Set to true if this PHY has fixups/quirks.
 498 * @suspended: Set to true if this PHY has been suspended successfully.
 499 * @suspended_by_mdio_bus: Set to true if this PHY was suspended by MDIO bus.
 500 * @sysfs_links: Internal boolean tracking sysfs symbolic links setup/removal.
 501 * @loopback_enabled: Set true if this PHY has been loopbacked successfully.
 502 * @downshifted_rate: Set true if link speed has been downshifted.
 503 * @is_on_sfp_module: Set true if PHY is located on an SFP module.
 504 * @mac_managed_pm: Set true if MAC driver takes of suspending/resuming PHY
 505 * @state: State of the PHY for management purposes
 506 * @dev_flags: Device-specific flags used by the PHY driver.
 507 *              Bits [15:0] are free to use by the PHY driver to communicate
 508 *                          driver specific behavior.
 509 *              Bits [23:16] are currently reserved for future use.
 510 *              Bits [31:24] are reserved for defining generic
 511 *                           PHY driver behavior.
 512 * @irq: IRQ number of the PHY's interrupt (-1 if none)
 513 * @phy_timer: The timer for handling the state machine
 514 * @phylink: Pointer to phylink instance for this PHY
 515 * @sfp_bus_attached: Flag indicating whether the SFP bus has been attached
 516 * @sfp_bus: SFP bus attached to this PHY's fiber port
 517 * @attached_dev: The attached enet driver's device instance ptr
 518 * @adjust_link: Callback for the enet controller to respond to changes: in the
 519 *               link state.
 520 * @phy_link_change: Callback for phylink for notification of link change
 521 * @macsec_ops: MACsec offloading ops.
 522 *
 523 * @speed: Current link speed
 524 * @duplex: Current duplex
 525 * @port: Current port
 526 * @pause: Current pause
 527 * @asym_pause: Current asymmetric pause
 528 * @supported: Combined MAC/PHY supported linkmodes
 529 * @advertising: Currently advertised linkmodes
 530 * @adv_old: Saved advertised while power saving for WoL
 531 * @lp_advertising: Current link partner advertised linkmodes
 532 * @eee_broken_modes: Energy efficient ethernet modes which should be prohibited
 533 * @autoneg: Flag autoneg being used
 534 * @link: Current link state
 535 * @autoneg_complete: Flag auto negotiation of the link has completed
 536 * @mdix: Current crossover
 537 * @mdix_ctrl: User setting of crossover
 538 * @interrupts: Flag interrupts have been enabled
 539 * @interface: enum phy_interface_t value
 540 * @skb: Netlink message for cable diagnostics
 541 * @nest: Netlink nest used for cable diagnostics
 542 * @ehdr: nNtlink header for cable diagnostics
 543 * @phy_led_triggers: Array of LED triggers
 544 * @phy_num_led_triggers: Number of triggers in @phy_led_triggers
 545 * @led_link_trigger: LED trigger for link up/down
 546 * @last_triggered: last LED trigger for link speed
 547 * @master_slave_set: User requested master/slave configuration
 548 * @master_slave_get: Current master/slave advertisement
 549 * @master_slave_state: Current master/slave configuration
 550 * @mii_ts: Pointer to time stamper callbacks
 551 * @lock:  Mutex for serialization access to PHY
 552 * @state_queue: Work queue for state machine
 553 * @shared: Pointer to private data shared by phys in one package
 554 * @priv: Pointer to driver private data
 555 *
 556 * interrupts currently only supports enabled or disabled,
 557 * but could be changed in the future to support enabling
 558 * and disabling specific interrupts
 559 *
 560 * Contains some infrastructure for polling and interrupt
 561 * handling, as well as handling shifts in PHY hardware state
 562 */
 563struct phy_device {
 564        struct mdio_device mdio;
 565
 566        /* Information about the PHY type */
 567        /* And management functions */
 568        struct phy_driver *drv;
 569
 570        u32 phy_id;
 571
 572        struct phy_c45_device_ids c45_ids;
 573        unsigned is_c45:1;
 574        unsigned is_internal:1;
 575        unsigned is_pseudo_fixed_link:1;
 576        unsigned is_gigabit_capable:1;
 577        unsigned has_fixups:1;
 578        unsigned suspended:1;
 579        unsigned suspended_by_mdio_bus:1;
 580        unsigned sysfs_links:1;
 581        unsigned loopback_enabled:1;
 582        unsigned downshifted_rate:1;
 583        unsigned is_on_sfp_module:1;
 584        unsigned mac_managed_pm:1;
 585
 586        unsigned autoneg:1;
 587        /* The most recently read link state */
 588        unsigned link:1;
 589        unsigned autoneg_complete:1;
 590
 591        /* Interrupts are enabled */
 592        unsigned interrupts:1;
 593
 594        enum phy_state state;
 595
 596        u32 dev_flags;
 597
 598        phy_interface_t interface;
 599
 600        /*
 601         * forced speed & duplex (no autoneg)
 602         * partner speed & duplex & pause (autoneg)
 603         */
 604        int speed;
 605        int duplex;
 606        int port;
 607        int pause;
 608        int asym_pause;
 609        u8 master_slave_get;
 610        u8 master_slave_set;
 611        u8 master_slave_state;
 612
 613        /* Union of PHY and Attached devices' supported link modes */
 614        /* See ethtool.h for more info */
 615        __ETHTOOL_DECLARE_LINK_MODE_MASK(supported);
 616        __ETHTOOL_DECLARE_LINK_MODE_MASK(advertising);
 617        __ETHTOOL_DECLARE_LINK_MODE_MASK(lp_advertising);
 618        /* used with phy_speed_down */
 619        __ETHTOOL_DECLARE_LINK_MODE_MASK(adv_old);
 620
 621        /* Energy efficient ethernet modes which should be prohibited */
 622        u32 eee_broken_modes;
 623
 624#ifdef CONFIG_LED_TRIGGER_PHY
 625        struct phy_led_trigger *phy_led_triggers;
 626        unsigned int phy_num_led_triggers;
 627        struct phy_led_trigger *last_triggered;
 628
 629        struct phy_led_trigger *led_link_trigger;
 630#endif
 631
 632        /*
 633         * Interrupt number for this PHY
 634         * -1 means no interrupt
 635         */
 636        int irq;
 637
 638        /* private data pointer */
 639        /* For use by PHYs to maintain extra state */
 640        void *priv;
 641
 642        /* shared data pointer */
 643        /* For use by PHYs inside the same package that need a shared state. */
 644        struct phy_package_shared *shared;
 645
 646        /* Reporting cable test results */
 647        struct sk_buff *skb;
 648        void *ehdr;
 649        struct nlattr *nest;
 650
 651        /* Interrupt and Polling infrastructure */
 652        struct delayed_work state_queue;
 653
 654        struct mutex lock;
 655
 656        /* This may be modified under the rtnl lock */
 657        bool sfp_bus_attached;
 658        struct sfp_bus *sfp_bus;
 659        struct phylink *phylink;
 660        struct net_device *attached_dev;
 661        struct mii_timestamper *mii_ts;
 662
 663        u8 mdix;
 664        u8 mdix_ctrl;
 665
 666        void (*phy_link_change)(struct phy_device *phydev, bool up);
 667        void (*adjust_link)(struct net_device *dev);
 668
 669#if IS_ENABLED(CONFIG_MACSEC)
 670        /* MACsec management functions */
 671        const struct macsec_ops *macsec_ops;
 672#endif
 673};
 674
 675static inline struct phy_device *to_phy_device(const struct device *dev)
 676{
 677        return container_of(to_mdio_device(dev), struct phy_device, mdio);
 678}
 679
 680/**
 681 * struct phy_tdr_config - Configuration of a TDR raw test
 682 *
 683 * @first: Distance for first data collection point
 684 * @last: Distance for last data collection point
 685 * @step: Step between data collection points
 686 * @pair: Bitmap of cable pairs to collect data for
 687 *
 688 * A structure containing possible configuration parameters
 689 * for a TDR cable test. The driver does not need to implement
 690 * all the parameters, but should report what is actually used.
 691 * All distances are in centimeters.
 692 */
 693struct phy_tdr_config {
 694        u32 first;
 695        u32 last;
 696        u32 step;
 697        s8 pair;
 698};
 699#define PHY_PAIR_ALL -1
 700
 701/**
 702 * struct phy_driver - Driver structure for a particular PHY type
 703 *
 704 * @mdiodrv: Data common to all MDIO devices
 705 * @phy_id: The result of reading the UID registers of this PHY
 706 *   type, and ANDing them with the phy_id_mask.  This driver
 707 *   only works for PHYs with IDs which match this field
 708 * @name: The friendly name of this PHY type
 709 * @phy_id_mask: Defines the important bits of the phy_id
 710 * @features: A mandatory list of features (speed, duplex, etc)
 711 *   supported by this PHY
 712 * @flags: A bitfield defining certain other features this PHY
 713 *   supports (like interrupts)
 714 * @driver_data: Static driver data
 715 *
 716 * All functions are optional. If config_aneg or read_status
 717 * are not implemented, the phy core uses the genphy versions.
 718 * Note that none of these functions should be called from
 719 * interrupt time. The goal is for the bus read/write functions
 720 * to be able to block when the bus transaction is happening,
 721 * and be freed up by an interrupt (The MPC85xx has this ability,
 722 * though it is not currently supported in the driver).
 723 */
 724struct phy_driver {
 725        struct mdio_driver_common mdiodrv;
 726        u32 phy_id;
 727        char *name;
 728        u32 phy_id_mask;
 729        const unsigned long * const features;
 730        u32 flags;
 731        const void *driver_data;
 732
 733        /**
 734         * @soft_reset: Called to issue a PHY software reset
 735         */
 736        int (*soft_reset)(struct phy_device *phydev);
 737
 738        /**
 739         * @config_init: Called to initialize the PHY,
 740         * including after a reset
 741         */
 742        int (*config_init)(struct phy_device *phydev);
 743
 744        /**
 745         * @probe: Called during discovery.  Used to set
 746         * up device-specific structures, if any
 747         */
 748        int (*probe)(struct phy_device *phydev);
 749
 750        /**
 751         * @get_features: Probe the hardware to determine what
 752         * abilities it has.  Should only set phydev->supported.
 753         */
 754        int (*get_features)(struct phy_device *phydev);
 755
 756        /* PHY Power Management */
 757        /** @suspend: Suspend the hardware, saving state if needed */
 758        int (*suspend)(struct phy_device *phydev);
 759        /** @resume: Resume the hardware, restoring state if needed */
 760        int (*resume)(struct phy_device *phydev);
 761
 762        /**
 763         * @config_aneg: Configures the advertisement and resets
 764         * autonegotiation if phydev->autoneg is on,
 765         * forces the speed to the current settings in phydev
 766         * if phydev->autoneg is off
 767         */
 768        int (*config_aneg)(struct phy_device *phydev);
 769
 770        /** @aneg_done: Determines the auto negotiation result */
 771        int (*aneg_done)(struct phy_device *phydev);
 772
 773        /** @read_status: Determines the negotiated speed and duplex */
 774        int (*read_status)(struct phy_device *phydev);
 775
 776        /**
 777         * @config_intr: Enables or disables interrupts.
 778         * It should also clear any pending interrupts prior to enabling the
 779         * IRQs and after disabling them.
 780         */
 781        int (*config_intr)(struct phy_device *phydev);
 782
 783        /** @handle_interrupt: Override default interrupt handling */
 784        irqreturn_t (*handle_interrupt)(struct phy_device *phydev);
 785
 786        /** @remove: Clears up any memory if needed */
 787        void (*remove)(struct phy_device *phydev);
 788
 789        /**
 790         * @match_phy_device: Returns true if this is a suitable
 791         * driver for the given phydev.  If NULL, matching is based on
 792         * phy_id and phy_id_mask.
 793         */
 794        int (*match_phy_device)(struct phy_device *phydev);
 795
 796        /**
 797         * @set_wol: Some devices (e.g. qnap TS-119P II) require PHY
 798         * register changes to enable Wake on LAN, so set_wol is
 799         * provided to be called in the ethernet driver's set_wol
 800         * function.
 801         */
 802        int (*set_wol)(struct phy_device *dev, struct ethtool_wolinfo *wol);
 803
 804        /**
 805         * @get_wol: See set_wol, but for checking whether Wake on LAN
 806         * is enabled.
 807         */
 808        void (*get_wol)(struct phy_device *dev, struct ethtool_wolinfo *wol);
 809
 810        /**
 811         * @link_change_notify: Called to inform a PHY device driver
 812         * when the core is about to change the link state. This
 813         * callback is supposed to be used as fixup hook for drivers
 814         * that need to take action when the link state
 815         * changes. Drivers are by no means allowed to mess with the
 816         * PHY device structure in their implementations.
 817         */
 818        void (*link_change_notify)(struct phy_device *dev);
 819
 820        /**
 821         * @read_mmd: PHY specific driver override for reading a MMD
 822         * register.  This function is optional for PHY specific
 823         * drivers.  When not provided, the default MMD read function
 824         * will be used by phy_read_mmd(), which will use either a
 825         * direct read for Clause 45 PHYs or an indirect read for
 826         * Clause 22 PHYs.  devnum is the MMD device number within the
 827         * PHY device, regnum is the register within the selected MMD
 828         * device.
 829         */
 830        int (*read_mmd)(struct phy_device *dev, int devnum, u16 regnum);
 831
 832        /**
 833         * @write_mmd: PHY specific driver override for writing a MMD
 834         * register.  This function is optional for PHY specific
 835         * drivers.  When not provided, the default MMD write function
 836         * will be used by phy_write_mmd(), which will use either a
 837         * direct write for Clause 45 PHYs, or an indirect write for
 838         * Clause 22 PHYs.  devnum is the MMD device number within the
 839         * PHY device, regnum is the register within the selected MMD
 840         * device.  val is the value to be written.
 841         */
 842        int (*write_mmd)(struct phy_device *dev, int devnum, u16 regnum,
 843                         u16 val);
 844
 845        /** @read_page: Return the current PHY register page number */
 846        int (*read_page)(struct phy_device *dev);
 847        /** @write_page: Set the current PHY register page number */
 848        int (*write_page)(struct phy_device *dev, int page);
 849
 850        /**
 851         * @module_info: Get the size and type of the eeprom contained
 852         * within a plug-in module
 853         */
 854        int (*module_info)(struct phy_device *dev,
 855                           struct ethtool_modinfo *modinfo);
 856
 857        /**
 858         * @module_eeprom: Get the eeprom information from the plug-in
 859         * module
 860         */
 861        int (*module_eeprom)(struct phy_device *dev,
 862                             struct ethtool_eeprom *ee, u8 *data);
 863
 864        /** @cable_test_start: Start a cable test */
 865        int (*cable_test_start)(struct phy_device *dev);
 866
 867        /**  @cable_test_tdr_start: Start a raw TDR cable test */
 868        int (*cable_test_tdr_start)(struct phy_device *dev,
 869                                    const struct phy_tdr_config *config);
 870
 871        /**
 872         * @cable_test_get_status: Once per second, or on interrupt,
 873         * request the status of the test.
 874         */
 875        int (*cable_test_get_status)(struct phy_device *dev, bool *finished);
 876
 877        /* Get statistics from the PHY using ethtool */
 878        /** @get_sset_count: Number of statistic counters */
 879        int (*get_sset_count)(struct phy_device *dev);
 880        /** @get_strings: Names of the statistic counters */
 881        void (*get_strings)(struct phy_device *dev, u8 *data);
 882        /** @get_stats: Return the statistic counter values */
 883        void (*get_stats)(struct phy_device *dev,
 884                          struct ethtool_stats *stats, u64 *data);
 885
 886        /* Get and Set PHY tunables */
 887        /** @get_tunable: Return the value of a tunable */
 888        int (*get_tunable)(struct phy_device *dev,
 889                           struct ethtool_tunable *tuna, void *data);
 890        /** @set_tunable: Set the value of a tunable */
 891        int (*set_tunable)(struct phy_device *dev,
 892                            struct ethtool_tunable *tuna,
 893                            const void *data);
 894        /** @set_loopback: Set the loopback mood of the PHY */
 895        int (*set_loopback)(struct phy_device *dev, bool enable);
 896        /** @get_sqi: Get the signal quality indication */
 897        int (*get_sqi)(struct phy_device *dev);
 898        /** @get_sqi_max: Get the maximum signal quality indication */
 899        int (*get_sqi_max)(struct phy_device *dev);
 900};
 901#define to_phy_driver(d) container_of(to_mdio_common_driver(d),         \
 902                                      struct phy_driver, mdiodrv)
 903
 904#define PHY_ANY_ID "MATCH ANY PHY"
 905#define PHY_ANY_UID 0xffffffff
 906
 907#define PHY_ID_MATCH_EXACT(id) .phy_id = (id), .phy_id_mask = GENMASK(31, 0)
 908#define PHY_ID_MATCH_MODEL(id) .phy_id = (id), .phy_id_mask = GENMASK(31, 4)
 909#define PHY_ID_MATCH_VENDOR(id) .phy_id = (id), .phy_id_mask = GENMASK(31, 10)
 910
 911/* A Structure for boards to register fixups with the PHY Lib */
 912struct phy_fixup {
 913        struct list_head list;
 914        char bus_id[MII_BUS_ID_SIZE + 3];
 915        u32 phy_uid;
 916        u32 phy_uid_mask;
 917        int (*run)(struct phy_device *phydev);
 918};
 919
 920const char *phy_speed_to_str(int speed);
 921const char *phy_duplex_to_str(unsigned int duplex);
 922
 923/* A structure for mapping a particular speed and duplex
 924 * combination to a particular SUPPORTED and ADVERTISED value
 925 */
 926struct phy_setting {
 927        u32 speed;
 928        u8 duplex;
 929        u8 bit;
 930};
 931
 932const struct phy_setting *
 933phy_lookup_setting(int speed, int duplex, const unsigned long *mask,
 934                   bool exact);
 935size_t phy_speeds(unsigned int *speeds, size_t size,
 936                  unsigned long *mask);
 937void of_set_phy_supported(struct phy_device *phydev);
 938void of_set_phy_eee_broken(struct phy_device *phydev);
 939int phy_speed_down_core(struct phy_device *phydev);
 940
 941/**
 942 * phy_is_started - Convenience function to check whether PHY is started
 943 * @phydev: The phy_device struct
 944 */
 945static inline bool phy_is_started(struct phy_device *phydev)
 946{
 947        return phydev->state >= PHY_UP;
 948}
 949
 950void phy_resolve_aneg_pause(struct phy_device *phydev);
 951void phy_resolve_aneg_linkmode(struct phy_device *phydev);
 952void phy_check_downshift(struct phy_device *phydev);
 953
 954/**
 955 * phy_read - Convenience function for reading a given PHY register
 956 * @phydev: the phy_device struct
 957 * @regnum: register number to read
 958 *
 959 * NOTE: MUST NOT be called from interrupt context,
 960 * because the bus read/write functions may wait for an interrupt
 961 * to conclude the operation.
 962 */
 963static inline int phy_read(struct phy_device *phydev, u32 regnum)
 964{
 965        return mdiobus_read(phydev->mdio.bus, phydev->mdio.addr, regnum);
 966}
 967
 968#define phy_read_poll_timeout(phydev, regnum, val, cond, sleep_us, \
 969                                timeout_us, sleep_before_read) \
 970({ \
 971        int __ret = read_poll_timeout(phy_read, val, (cond) || val < 0, \
 972                sleep_us, timeout_us, sleep_before_read, phydev, regnum); \
 973        if (val <  0) \
 974                __ret = val; \
 975        if (__ret) \
 976                phydev_err(phydev, "%s failed: %d\n", __func__, __ret); \
 977        __ret; \
 978})
 979
 980
 981/**
 982 * __phy_read - convenience function for reading a given PHY register
 983 * @phydev: the phy_device struct
 984 * @regnum: register number to read
 985 *
 986 * The caller must have taken the MDIO bus lock.
 987 */
 988static inline int __phy_read(struct phy_device *phydev, u32 regnum)
 989{
 990        return __mdiobus_read(phydev->mdio.bus, phydev->mdio.addr, regnum);
 991}
 992
 993/**
 994 * phy_write - Convenience function for writing a given PHY register
 995 * @phydev: the phy_device struct
 996 * @regnum: register number to write
 997 * @val: value to write to @regnum
 998 *
 999 * NOTE: MUST NOT be called from interrupt context,
1000 * because the bus read/write functions may wait for an interrupt
1001 * to conclude the operation.
1002 */
1003static inline int phy_write(struct phy_device *phydev, u32 regnum, u16 val)
1004{
1005        return mdiobus_write(phydev->mdio.bus, phydev->mdio.addr, regnum, val);
1006}
1007
1008/**
1009 * __phy_write - Convenience function for writing a given PHY register
1010 * @phydev: the phy_device struct
1011 * @regnum: register number to write
1012 * @val: value to write to @regnum
1013 *
1014 * The caller must have taken the MDIO bus lock.
1015 */
1016static inline int __phy_write(struct phy_device *phydev, u32 regnum, u16 val)
1017{
1018        return __mdiobus_write(phydev->mdio.bus, phydev->mdio.addr, regnum,
1019                               val);
1020}
1021
1022/**
1023 * __phy_modify_changed() - Convenience function for modifying a PHY register
1024 * @phydev: a pointer to a &struct phy_device
1025 * @regnum: register number
1026 * @mask: bit mask of bits to clear
1027 * @set: bit mask of bits to set
1028 *
1029 * Unlocked helper function which allows a PHY register to be modified as
1030 * new register value = (old register value & ~mask) | set
1031 *
1032 * Returns negative errno, 0 if there was no change, and 1 in case of change
1033 */
1034static inline int __phy_modify_changed(struct phy_device *phydev, u32 regnum,
1035                                       u16 mask, u16 set)
1036{
1037        return __mdiobus_modify_changed(phydev->mdio.bus, phydev->mdio.addr,
1038                                        regnum, mask, set);
1039}
1040
1041/*
1042 * phy_read_mmd - Convenience function for reading a register
1043 * from an MMD on a given PHY.
1044 */
1045int phy_read_mmd(struct phy_device *phydev, int devad, u32 regnum);
1046
1047/**
1048 * phy_read_mmd_poll_timeout - Periodically poll a PHY register until a
1049 *                             condition is met or a timeout occurs
1050 *
1051 * @phydev: The phy_device struct
1052 * @devaddr: The MMD to read from
1053 * @regnum: The register on the MMD to read
1054 * @val: Variable to read the register into
1055 * @cond: Break condition (usually involving @val)
1056 * @sleep_us: Maximum time to sleep between reads in us (0
1057 *            tight-loops).  Should be less than ~20ms since usleep_range
1058 *            is used (see Documentation/timers/timers-howto.rst).
1059 * @timeout_us: Timeout in us, 0 means never timeout
1060 * @sleep_before_read: if it is true, sleep @sleep_us before read.
1061 * Returns 0 on success and -ETIMEDOUT upon a timeout. In either
1062 * case, the last read value at @args is stored in @val. Must not
1063 * be called from atomic context if sleep_us or timeout_us are used.
1064 */
1065#define phy_read_mmd_poll_timeout(phydev, devaddr, regnum, val, cond, \
1066                                  sleep_us, timeout_us, sleep_before_read) \
1067({ \
1068        int __ret = read_poll_timeout(phy_read_mmd, val, (cond) || val < 0, \
1069                                  sleep_us, timeout_us, sleep_before_read, \
1070                                  phydev, devaddr, regnum); \
1071        if (val <  0) \
1072                __ret = val; \
1073        if (__ret) \
1074                phydev_err(phydev, "%s failed: %d\n", __func__, __ret); \
1075        __ret; \
1076})
1077
1078/*
1079 * __phy_read_mmd - Convenience function for reading a register
1080 * from an MMD on a given PHY.
1081 */
1082int __phy_read_mmd(struct phy_device *phydev, int devad, u32 regnum);
1083
1084/*
1085 * phy_write_mmd - Convenience function for writing a register
1086 * on an MMD on a given PHY.
1087 */
1088int phy_write_mmd(struct phy_device *phydev, int devad, u32 regnum, u16 val);
1089
1090/*
1091 * __phy_write_mmd - Convenience function for writing a register
1092 * on an MMD on a given PHY.
1093 */
1094int __phy_write_mmd(struct phy_device *phydev, int devad, u32 regnum, u16 val);
1095
1096int __phy_modify_changed(struct phy_device *phydev, u32 regnum, u16 mask,
1097                         u16 set);
1098int phy_modify_changed(struct phy_device *phydev, u32 regnum, u16 mask,
1099                       u16 set);
1100int __phy_modify(struct phy_device *phydev, u32 regnum, u16 mask, u16 set);
1101int phy_modify(struct phy_device *phydev, u32 regnum, u16 mask, u16 set);
1102
1103int __phy_modify_mmd_changed(struct phy_device *phydev, int devad, u32 regnum,
1104                             u16 mask, u16 set);
1105int phy_modify_mmd_changed(struct phy_device *phydev, int devad, u32 regnum,
1106                           u16 mask, u16 set);
1107int __phy_modify_mmd(struct phy_device *phydev, int devad, u32 regnum,
1108                     u16 mask, u16 set);
1109int phy_modify_mmd(struct phy_device *phydev, int devad, u32 regnum,
1110                   u16 mask, u16 set);
1111
1112/**
1113 * __phy_set_bits - Convenience function for setting bits in a PHY register
1114 * @phydev: the phy_device struct
1115 * @regnum: register number to write
1116 * @val: bits to set
1117 *
1118 * The caller must have taken the MDIO bus lock.
1119 */
1120static inline int __phy_set_bits(struct phy_device *phydev, u32 regnum, u16 val)
1121{
1122        return __phy_modify(phydev, regnum, 0, val);
1123}
1124
1125/**
1126 * __phy_clear_bits - Convenience function for clearing bits in a PHY register
1127 * @phydev: the phy_device struct
1128 * @regnum: register number to write
1129 * @val: bits to clear
1130 *
1131 * The caller must have taken the MDIO bus lock.
1132 */
1133static inline int __phy_clear_bits(struct phy_device *phydev, u32 regnum,
1134                                   u16 val)
1135{
1136        return __phy_modify(phydev, regnum, val, 0);
1137}
1138
1139/**
1140 * phy_set_bits - Convenience function for setting bits in a PHY register
1141 * @phydev: the phy_device struct
1142 * @regnum: register number to write
1143 * @val: bits to set
1144 */
1145static inline int phy_set_bits(struct phy_device *phydev, u32 regnum, u16 val)
1146{
1147        return phy_modify(phydev, regnum, 0, val);
1148}
1149
1150/**
1151 * phy_clear_bits - Convenience function for clearing bits in a PHY register
1152 * @phydev: the phy_device struct
1153 * @regnum: register number to write
1154 * @val: bits to clear
1155 */
1156static inline int phy_clear_bits(struct phy_device *phydev, u32 regnum, u16 val)
1157{
1158        return phy_modify(phydev, regnum, val, 0);
1159}
1160
1161/**
1162 * __phy_set_bits_mmd - Convenience function for setting bits in a register
1163 * on MMD
1164 * @phydev: the phy_device struct
1165 * @devad: the MMD containing register to modify
1166 * @regnum: register number to modify
1167 * @val: bits to set
1168 *
1169 * The caller must have taken the MDIO bus lock.
1170 */
1171static inline int __phy_set_bits_mmd(struct phy_device *phydev, int devad,
1172                u32 regnum, u16 val)
1173{
1174        return __phy_modify_mmd(phydev, devad, regnum, 0, val);
1175}
1176
1177/**
1178 * __phy_clear_bits_mmd - Convenience function for clearing bits in a register
1179 * on MMD
1180 * @phydev: the phy_device struct
1181 * @devad: the MMD containing register to modify
1182 * @regnum: register number to modify
1183 * @val: bits to clear
1184 *
1185 * The caller must have taken the MDIO bus lock.
1186 */
1187static inline int __phy_clear_bits_mmd(struct phy_device *phydev, int devad,
1188                u32 regnum, u16 val)
1189{
1190        return __phy_modify_mmd(phydev, devad, regnum, val, 0);
1191}
1192
1193/**
1194 * phy_set_bits_mmd - Convenience function for setting bits in a register
1195 * on MMD
1196 * @phydev: the phy_device struct
1197 * @devad: the MMD containing register to modify
1198 * @regnum: register number to modify
1199 * @val: bits to set
1200 */
1201static inline int phy_set_bits_mmd(struct phy_device *phydev, int devad,
1202                u32 regnum, u16 val)
1203{
1204        return phy_modify_mmd(phydev, devad, regnum, 0, val);
1205}
1206
1207/**
1208 * phy_clear_bits_mmd - Convenience function for clearing bits in a register
1209 * on MMD
1210 * @phydev: the phy_device struct
1211 * @devad: the MMD containing register to modify
1212 * @regnum: register number to modify
1213 * @val: bits to clear
1214 */
1215static inline int phy_clear_bits_mmd(struct phy_device *phydev, int devad,
1216                u32 regnum, u16 val)
1217{
1218        return phy_modify_mmd(phydev, devad, regnum, val, 0);
1219}
1220
1221/**
1222 * phy_interrupt_is_valid - Convenience function for testing a given PHY irq
1223 * @phydev: the phy_device struct
1224 *
1225 * NOTE: must be kept in sync with addition/removal of PHY_POLL and
1226 * PHY_MAC_INTERRUPT
1227 */
1228static inline bool phy_interrupt_is_valid(struct phy_device *phydev)
1229{
1230        return phydev->irq != PHY_POLL && phydev->irq != PHY_MAC_INTERRUPT;
1231}
1232
1233/**
1234 * phy_polling_mode - Convenience function for testing whether polling is
1235 * used to detect PHY status changes
1236 * @phydev: the phy_device struct
1237 */
1238static inline bool phy_polling_mode(struct phy_device *phydev)
1239{
1240        if (phydev->state == PHY_CABLETEST)
1241                if (phydev->drv->flags & PHY_POLL_CABLE_TEST)
1242                        return true;
1243
1244        return phydev->irq == PHY_POLL;
1245}
1246
1247/**
1248 * phy_has_hwtstamp - Tests whether a PHY time stamp configuration.
1249 * @phydev: the phy_device struct
1250 */
1251static inline bool phy_has_hwtstamp(struct phy_device *phydev)
1252{
1253        return phydev && phydev->mii_ts && phydev->mii_ts->hwtstamp;
1254}
1255
1256/**
1257 * phy_has_rxtstamp - Tests whether a PHY supports receive time stamping.
1258 * @phydev: the phy_device struct
1259 */
1260static inline bool phy_has_rxtstamp(struct phy_device *phydev)
1261{
1262        return phydev && phydev->mii_ts && phydev->mii_ts->rxtstamp;
1263}
1264
1265/**
1266 * phy_has_tsinfo - Tests whether a PHY reports time stamping and/or
1267 * PTP hardware clock capabilities.
1268 * @phydev: the phy_device struct
1269 */
1270static inline bool phy_has_tsinfo(struct phy_device *phydev)
1271{
1272        return phydev && phydev->mii_ts && phydev->mii_ts->ts_info;
1273}
1274
1275/**
1276 * phy_has_txtstamp - Tests whether a PHY supports transmit time stamping.
1277 * @phydev: the phy_device struct
1278 */
1279static inline bool phy_has_txtstamp(struct phy_device *phydev)
1280{
1281        return phydev && phydev->mii_ts && phydev->mii_ts->txtstamp;
1282}
1283
1284static inline int phy_hwtstamp(struct phy_device *phydev, struct ifreq *ifr)
1285{
1286        return phydev->mii_ts->hwtstamp(phydev->mii_ts, ifr);
1287}
1288
1289static inline bool phy_rxtstamp(struct phy_device *phydev, struct sk_buff *skb,
1290                                int type)
1291{
1292        return phydev->mii_ts->rxtstamp(phydev->mii_ts, skb, type);
1293}
1294
1295static inline int phy_ts_info(struct phy_device *phydev,
1296                              struct ethtool_ts_info *tsinfo)
1297{
1298        return phydev->mii_ts->ts_info(phydev->mii_ts, tsinfo);
1299}
1300
1301static inline void phy_txtstamp(struct phy_device *phydev, struct sk_buff *skb,
1302                                int type)
1303{
1304        phydev->mii_ts->txtstamp(phydev->mii_ts, skb, type);
1305}
1306
1307/**
1308 * phy_is_internal - Convenience function for testing if a PHY is internal
1309 * @phydev: the phy_device struct
1310 */
1311static inline bool phy_is_internal(struct phy_device *phydev)
1312{
1313        return phydev->is_internal;
1314}
1315
1316/**
1317 * phy_on_sfp - Convenience function for testing if a PHY is on an SFP module
1318 * @phydev: the phy_device struct
1319 */
1320static inline bool phy_on_sfp(struct phy_device *phydev)
1321{
1322        return phydev->is_on_sfp_module;
1323}
1324
1325/**
1326 * phy_interface_mode_is_rgmii - Convenience function for testing if a
1327 * PHY interface mode is RGMII (all variants)
1328 * @mode: the &phy_interface_t enum
1329 */
1330static inline bool phy_interface_mode_is_rgmii(phy_interface_t mode)
1331{
1332        return mode >= PHY_INTERFACE_MODE_RGMII &&
1333                mode <= PHY_INTERFACE_MODE_RGMII_TXID;
1334};
1335
1336/**
1337 * phy_interface_mode_is_8023z() - does the PHY interface mode use 802.3z
1338 *   negotiation
1339 * @mode: one of &enum phy_interface_t
1340 *
1341 * Returns true if the PHY interface mode uses the 16-bit negotiation
1342 * word as defined in 802.3z. (See 802.3-2015 37.2.1 Config_Reg encoding)
1343 */
1344static inline bool phy_interface_mode_is_8023z(phy_interface_t mode)
1345{
1346        return mode == PHY_INTERFACE_MODE_1000BASEX ||
1347               mode == PHY_INTERFACE_MODE_2500BASEX;
1348}
1349
1350/**
1351 * phy_interface_is_rgmii - Convenience function for testing if a PHY interface
1352 * is RGMII (all variants)
1353 * @phydev: the phy_device struct
1354 */
1355static inline bool phy_interface_is_rgmii(struct phy_device *phydev)
1356{
1357        return phy_interface_mode_is_rgmii(phydev->interface);
1358};
1359
1360/**
1361 * phy_is_pseudo_fixed_link - Convenience function for testing if this
1362 * PHY is the CPU port facing side of an Ethernet switch, or similar.
1363 * @phydev: the phy_device struct
1364 */
1365static inline bool phy_is_pseudo_fixed_link(struct phy_device *phydev)
1366{
1367        return phydev->is_pseudo_fixed_link;
1368}
1369
1370int phy_save_page(struct phy_device *phydev);
1371int phy_select_page(struct phy_device *phydev, int page);
1372int phy_restore_page(struct phy_device *phydev, int oldpage, int ret);
1373int phy_read_paged(struct phy_device *phydev, int page, u32 regnum);
1374int phy_write_paged(struct phy_device *phydev, int page, u32 regnum, u16 val);
1375int phy_modify_paged_changed(struct phy_device *phydev, int page, u32 regnum,
1376                             u16 mask, u16 set);
1377int phy_modify_paged(struct phy_device *phydev, int page, u32 regnum,
1378                     u16 mask, u16 set);
1379
1380struct phy_device *phy_device_create(struct mii_bus *bus, int addr, u32 phy_id,
1381                                     bool is_c45,
1382                                     struct phy_c45_device_ids *c45_ids);
1383#if IS_ENABLED(CONFIG_PHYLIB)
1384int fwnode_get_phy_id(struct fwnode_handle *fwnode, u32 *phy_id);
1385struct mdio_device *fwnode_mdio_find_device(struct fwnode_handle *fwnode);
1386struct phy_device *fwnode_phy_find_device(struct fwnode_handle *phy_fwnode);
1387struct phy_device *device_phy_find_device(struct device *dev);
1388struct fwnode_handle *fwnode_get_phy_node(struct fwnode_handle *fwnode);
1389struct phy_device *get_phy_device(struct mii_bus *bus, int addr, bool is_c45);
1390int phy_device_register(struct phy_device *phy);
1391void phy_device_free(struct phy_device *phydev);
1392#else
1393static inline int fwnode_get_phy_id(struct fwnode_handle *fwnode, u32 *phy_id)
1394{
1395        return 0;
1396}
1397static inline
1398struct mdio_device *fwnode_mdio_find_device(struct fwnode_handle *fwnode)
1399{
1400        return 0;
1401}
1402
1403static inline
1404struct phy_device *fwnode_phy_find_device(struct fwnode_handle *phy_fwnode)
1405{
1406        return NULL;
1407}
1408
1409static inline struct phy_device *device_phy_find_device(struct device *dev)
1410{
1411        return NULL;
1412}
1413
1414static inline
1415struct fwnode_handle *fwnode_get_phy_node(struct fwnode_handle *fwnode)
1416{
1417        return NULL;
1418}
1419
1420static inline
1421struct phy_device *get_phy_device(struct mii_bus *bus, int addr, bool is_c45)
1422{
1423        return NULL;
1424}
1425
1426static inline int phy_device_register(struct phy_device *phy)
1427{
1428        return 0;
1429}
1430
1431static inline void phy_device_free(struct phy_device *phydev) { }
1432#endif /* CONFIG_PHYLIB */
1433void phy_device_remove(struct phy_device *phydev);
1434int phy_get_c45_ids(struct phy_device *phydev);
1435int phy_init_hw(struct phy_device *phydev);
1436int phy_suspend(struct phy_device *phydev);
1437int phy_resume(struct phy_device *phydev);
1438int __phy_resume(struct phy_device *phydev);
1439int phy_loopback(struct phy_device *phydev, bool enable);
1440void phy_sfp_attach(void *upstream, struct sfp_bus *bus);
1441void phy_sfp_detach(void *upstream, struct sfp_bus *bus);
1442int phy_sfp_probe(struct phy_device *phydev,
1443                  const struct sfp_upstream_ops *ops);
1444struct phy_device *phy_attach(struct net_device *dev, const char *bus_id,
1445                              phy_interface_t interface);
1446struct phy_device *phy_find_first(struct mii_bus *bus);
1447int phy_attach_direct(struct net_device *dev, struct phy_device *phydev,
1448                      u32 flags, phy_interface_t interface);
1449int phy_connect_direct(struct net_device *dev, struct phy_device *phydev,
1450                       void (*handler)(struct net_device *),
1451                       phy_interface_t interface);
1452struct phy_device *phy_connect(struct net_device *dev, const char *bus_id,
1453                               void (*handler)(struct net_device *),
1454                               phy_interface_t interface);
1455void phy_disconnect(struct phy_device *phydev);
1456void phy_detach(struct phy_device *phydev);
1457void phy_start(struct phy_device *phydev);
1458void phy_stop(struct phy_device *phydev);
1459int phy_config_aneg(struct phy_device *phydev);
1460int phy_start_aneg(struct phy_device *phydev);
1461int phy_aneg_done(struct phy_device *phydev);
1462int phy_speed_down(struct phy_device *phydev, bool sync);
1463int phy_speed_up(struct phy_device *phydev);
1464
1465int phy_restart_aneg(struct phy_device *phydev);
1466int phy_reset_after_clk_enable(struct phy_device *phydev);
1467
1468#if IS_ENABLED(CONFIG_PHYLIB)
1469int phy_start_cable_test(struct phy_device *phydev,
1470                         struct netlink_ext_ack *extack);
1471int phy_start_cable_test_tdr(struct phy_device *phydev,
1472                             struct netlink_ext_ack *extack,
1473                             const struct phy_tdr_config *config);
1474#else
1475static inline
1476int phy_start_cable_test(struct phy_device *phydev,
1477                         struct netlink_ext_ack *extack)
1478{
1479        NL_SET_ERR_MSG(extack, "Kernel not compiled with PHYLIB support");
1480        return -EOPNOTSUPP;
1481}
1482static inline
1483int phy_start_cable_test_tdr(struct phy_device *phydev,
1484                             struct netlink_ext_ack *extack,
1485                             const struct phy_tdr_config *config)
1486{
1487        NL_SET_ERR_MSG(extack, "Kernel not compiled with PHYLIB support");
1488        return -EOPNOTSUPP;
1489}
1490#endif
1491
1492int phy_cable_test_result(struct phy_device *phydev, u8 pair, u16 result);
1493int phy_cable_test_fault_length(struct phy_device *phydev, u8 pair,
1494                                u16 cm);
1495
1496static inline void phy_device_reset(struct phy_device *phydev, int value)
1497{
1498        mdio_device_reset(&phydev->mdio, value);
1499}
1500
1501#define phydev_err(_phydev, format, args...)    \
1502        dev_err(&_phydev->mdio.dev, format, ##args)
1503
1504#define phydev_info(_phydev, format, args...)   \
1505        dev_info(&_phydev->mdio.dev, format, ##args)
1506
1507#define phydev_warn(_phydev, format, args...)   \
1508        dev_warn(&_phydev->mdio.dev, format, ##args)
1509
1510#define phydev_dbg(_phydev, format, args...)    \
1511        dev_dbg(&_phydev->mdio.dev, format, ##args)
1512
1513static inline const char *phydev_name(const struct phy_device *phydev)
1514{
1515        return dev_name(&phydev->mdio.dev);
1516}
1517
1518static inline void phy_lock_mdio_bus(struct phy_device *phydev)
1519{
1520        mutex_lock(&phydev->mdio.bus->mdio_lock);
1521}
1522
1523static inline void phy_unlock_mdio_bus(struct phy_device *phydev)
1524{
1525        mutex_unlock(&phydev->mdio.bus->mdio_lock);
1526}
1527
1528void phy_attached_print(struct phy_device *phydev, const char *fmt, ...)
1529        __printf(2, 3);
1530char *phy_attached_info_irq(struct phy_device *phydev)
1531        __malloc;
1532void phy_attached_info(struct phy_device *phydev);
1533
1534/* Clause 22 PHY */
1535int genphy_read_abilities(struct phy_device *phydev);
1536int genphy_setup_forced(struct phy_device *phydev);
1537int genphy_restart_aneg(struct phy_device *phydev);
1538int genphy_check_and_restart_aneg(struct phy_device *phydev, bool restart);
1539int genphy_config_eee_advert(struct phy_device *phydev);
1540int __genphy_config_aneg(struct phy_device *phydev, bool changed);
1541int genphy_aneg_done(struct phy_device *phydev);
1542int genphy_update_link(struct phy_device *phydev);
1543int genphy_read_lpa(struct phy_device *phydev);
1544int genphy_read_status_fixed(struct phy_device *phydev);
1545int genphy_read_status(struct phy_device *phydev);
1546int genphy_suspend(struct phy_device *phydev);
1547int genphy_resume(struct phy_device *phydev);
1548int genphy_loopback(struct phy_device *phydev, bool enable);
1549int genphy_soft_reset(struct phy_device *phydev);
1550irqreturn_t genphy_handle_interrupt_no_ack(struct phy_device *phydev);
1551
1552static inline int genphy_config_aneg(struct phy_device *phydev)
1553{
1554        return __genphy_config_aneg(phydev, false);
1555}
1556
1557static inline int genphy_no_config_intr(struct phy_device *phydev)
1558{
1559        return 0;
1560}
1561int genphy_read_mmd_unsupported(struct phy_device *phdev, int devad,
1562                                u16 regnum);
1563int genphy_write_mmd_unsupported(struct phy_device *phdev, int devnum,
1564                                 u16 regnum, u16 val);
1565
1566/* Clause 37 */
1567int genphy_c37_config_aneg(struct phy_device *phydev);
1568int genphy_c37_read_status(struct phy_device *phydev);
1569
1570/* Clause 45 PHY */
1571int genphy_c45_restart_aneg(struct phy_device *phydev);
1572int genphy_c45_check_and_restart_aneg(struct phy_device *phydev, bool restart);
1573int genphy_c45_aneg_done(struct phy_device *phydev);
1574int genphy_c45_read_link(struct phy_device *phydev);
1575int genphy_c45_read_lpa(struct phy_device *phydev);
1576int genphy_c45_read_pma(struct phy_device *phydev);
1577int genphy_c45_pma_setup_forced(struct phy_device *phydev);
1578int genphy_c45_an_config_aneg(struct phy_device *phydev);
1579int genphy_c45_an_disable_aneg(struct phy_device *phydev);
1580int genphy_c45_read_mdix(struct phy_device *phydev);
1581int genphy_c45_pma_read_abilities(struct phy_device *phydev);
1582int genphy_c45_read_status(struct phy_device *phydev);
1583int genphy_c45_config_aneg(struct phy_device *phydev);
1584int genphy_c45_loopback(struct phy_device *phydev, bool enable);
1585int genphy_c45_pma_resume(struct phy_device *phydev);
1586int genphy_c45_pma_suspend(struct phy_device *phydev);
1587
1588/* Generic C45 PHY driver */
1589extern struct phy_driver genphy_c45_driver;
1590
1591/* The gen10g_* functions are the old Clause 45 stub */
1592int gen10g_config_aneg(struct phy_device *phydev);
1593
1594static inline int phy_read_status(struct phy_device *phydev)
1595{
1596        if (!phydev->drv)
1597                return -EIO;
1598
1599        if (phydev->drv->read_status)
1600                return phydev->drv->read_status(phydev);
1601        else
1602                return genphy_read_status(phydev);
1603}
1604
1605void phy_driver_unregister(struct phy_driver *drv);
1606void phy_drivers_unregister(struct phy_driver *drv, int n);
1607int phy_driver_register(struct phy_driver *new_driver, struct module *owner);
1608int phy_drivers_register(struct phy_driver *new_driver, int n,
1609                         struct module *owner);
1610void phy_error(struct phy_device *phydev);
1611void phy_state_machine(struct work_struct *work);
1612void phy_queue_state_machine(struct phy_device *phydev, unsigned long jiffies);
1613void phy_trigger_machine(struct phy_device *phydev);
1614void phy_mac_interrupt(struct phy_device *phydev);
1615void phy_start_machine(struct phy_device *phydev);
1616void phy_stop_machine(struct phy_device *phydev);
1617void phy_ethtool_ksettings_get(struct phy_device *phydev,
1618                               struct ethtool_link_ksettings *cmd);
1619int phy_ethtool_ksettings_set(struct phy_device *phydev,
1620                              const struct ethtool_link_ksettings *cmd);
1621int phy_mii_ioctl(struct phy_device *phydev, struct ifreq *ifr, int cmd);
1622int phy_do_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd);
1623int phy_do_ioctl_running(struct net_device *dev, struct ifreq *ifr, int cmd);
1624int phy_disable_interrupts(struct phy_device *phydev);
1625void phy_request_interrupt(struct phy_device *phydev);
1626void phy_free_interrupt(struct phy_device *phydev);
1627void phy_print_status(struct phy_device *phydev);
1628int phy_set_max_speed(struct phy_device *phydev, u32 max_speed);
1629void phy_remove_link_mode(struct phy_device *phydev, u32 link_mode);
1630void phy_advertise_supported(struct phy_device *phydev);
1631void phy_support_sym_pause(struct phy_device *phydev);
1632void phy_support_asym_pause(struct phy_device *phydev);
1633void phy_set_sym_pause(struct phy_device *phydev, bool rx, bool tx,
1634                       bool autoneg);
1635void phy_set_asym_pause(struct phy_device *phydev, bool rx, bool tx);
1636bool phy_validate_pause(struct phy_device *phydev,
1637                        struct ethtool_pauseparam *pp);
1638void phy_get_pause(struct phy_device *phydev, bool *tx_pause, bool *rx_pause);
1639
1640s32 phy_get_internal_delay(struct phy_device *phydev, struct device *dev,
1641                           const int *delay_values, int size, bool is_rx);
1642
1643void phy_resolve_pause(unsigned long *local_adv, unsigned long *partner_adv,
1644                       bool *tx_pause, bool *rx_pause);
1645
1646int phy_register_fixup(const char *bus_id, u32 phy_uid, u32 phy_uid_mask,
1647                       int (*run)(struct phy_device *));
1648int phy_register_fixup_for_id(const char *bus_id,
1649                              int (*run)(struct phy_device *));
1650int phy_register_fixup_for_uid(u32 phy_uid, u32 phy_uid_mask,
1651                               int (*run)(struct phy_device *));
1652
1653int phy_unregister_fixup(const char *bus_id, u32 phy_uid, u32 phy_uid_mask);
1654int phy_unregister_fixup_for_id(const char *bus_id);
1655int phy_unregister_fixup_for_uid(u32 phy_uid, u32 phy_uid_mask);
1656
1657int phy_init_eee(struct phy_device *phydev, bool clk_stop_enable);
1658int phy_get_eee_err(struct phy_device *phydev);
1659int phy_ethtool_set_eee(struct phy_device *phydev, struct ethtool_eee *data);
1660int phy_ethtool_get_eee(struct phy_device *phydev, struct ethtool_eee *data);
1661int phy_ethtool_set_wol(struct phy_device *phydev, struct ethtool_wolinfo *wol);
1662void phy_ethtool_get_wol(struct phy_device *phydev,
1663                         struct ethtool_wolinfo *wol);
1664int phy_ethtool_get_link_ksettings(struct net_device *ndev,
1665                                   struct ethtool_link_ksettings *cmd);
1666int phy_ethtool_set_link_ksettings(struct net_device *ndev,
1667                                   const struct ethtool_link_ksettings *cmd);
1668int phy_ethtool_nway_reset(struct net_device *ndev);
1669int phy_package_join(struct phy_device *phydev, int addr, size_t priv_size);
1670void phy_package_leave(struct phy_device *phydev);
1671int devm_phy_package_join(struct device *dev, struct phy_device *phydev,
1672                          int addr, size_t priv_size);
1673
1674#if IS_ENABLED(CONFIG_PHYLIB)
1675int __init mdio_bus_init(void);
1676void mdio_bus_exit(void);
1677#endif
1678
1679int phy_ethtool_get_strings(struct phy_device *phydev, u8 *data);
1680int phy_ethtool_get_sset_count(struct phy_device *phydev);
1681int phy_ethtool_get_stats(struct phy_device *phydev,
1682                          struct ethtool_stats *stats, u64 *data);
1683
1684static inline int phy_package_read(struct phy_device *phydev, u32 regnum)
1685{
1686        struct phy_package_shared *shared = phydev->shared;
1687
1688        if (!shared)
1689                return -EIO;
1690
1691        return mdiobus_read(phydev->mdio.bus, shared->addr, regnum);
1692}
1693
1694static inline int __phy_package_read(struct phy_device *phydev, u32 regnum)
1695{
1696        struct phy_package_shared *shared = phydev->shared;
1697
1698        if (!shared)
1699                return -EIO;
1700
1701        return __mdiobus_read(phydev->mdio.bus, shared->addr, regnum);
1702}
1703
1704static inline int phy_package_write(struct phy_device *phydev,
1705                                    u32 regnum, u16 val)
1706{
1707        struct phy_package_shared *shared = phydev->shared;
1708
1709        if (!shared)
1710                return -EIO;
1711
1712        return mdiobus_write(phydev->mdio.bus, shared->addr, regnum, val);
1713}
1714
1715static inline int __phy_package_write(struct phy_device *phydev,
1716                                      u32 regnum, u16 val)
1717{
1718        struct phy_package_shared *shared = phydev->shared;
1719
1720        if (!shared)
1721                return -EIO;
1722
1723        return __mdiobus_write(phydev->mdio.bus, shared->addr, regnum, val);
1724}
1725
1726static inline bool __phy_package_set_once(struct phy_device *phydev,
1727                                          unsigned int b)
1728{
1729        struct phy_package_shared *shared = phydev->shared;
1730
1731        if (!shared)
1732                return false;
1733
1734        return !test_and_set_bit(b, &shared->flags);
1735}
1736
1737static inline bool phy_package_init_once(struct phy_device *phydev)
1738{
1739        return __phy_package_set_once(phydev, PHY_SHARED_F_INIT_DONE);
1740}
1741
1742static inline bool phy_package_probe_once(struct phy_device *phydev)
1743{
1744        return __phy_package_set_once(phydev, PHY_SHARED_F_PROBE_DONE);
1745}
1746
1747extern struct bus_type mdio_bus_type;
1748
1749struct mdio_board_info {
1750        const char      *bus_id;
1751        char            modalias[MDIO_NAME_SIZE];
1752        int             mdio_addr;
1753        const void      *platform_data;
1754};
1755
1756#if IS_ENABLED(CONFIG_MDIO_DEVICE)
1757int mdiobus_register_board_info(const struct mdio_board_info *info,
1758                                unsigned int n);
1759#else
1760static inline int mdiobus_register_board_info(const struct mdio_board_info *i,
1761                                              unsigned int n)
1762{
1763        return 0;
1764}
1765#endif
1766
1767
1768/**
1769 * phy_module_driver() - Helper macro for registering PHY drivers
1770 * @__phy_drivers: array of PHY drivers to register
1771 * @__count: Numbers of members in array
1772 *
1773 * Helper macro for PHY drivers which do not do anything special in module
1774 * init/exit. Each module may only use this macro once, and calling it
1775 * replaces module_init() and module_exit().
1776 */
1777#define phy_module_driver(__phy_drivers, __count)                       \
1778static int __init phy_module_init(void)                                 \
1779{                                                                       \
1780        return phy_drivers_register(__phy_drivers, __count, THIS_MODULE); \
1781}                                                                       \
1782module_init(phy_module_init);                                           \
1783static void __exit phy_module_exit(void)                                \
1784{                                                                       \
1785        phy_drivers_unregister(__phy_drivers, __count);                 \
1786}                                                                       \
1787module_exit(phy_module_exit)
1788
1789#define module_phy_driver(__phy_drivers)                                \
1790        phy_module_driver(__phy_drivers, ARRAY_SIZE(__phy_drivers))
1791
1792bool phy_driver_is_genphy(struct phy_device *phydev);
1793bool phy_driver_is_genphy_10g(struct phy_device *phydev);
1794
1795#endif /* __PHY_H */
1796