1  /* SPDX-License-Identifier: GPL-2.0 */
2  #ifndef __LINUX_MDIO_BITBANG_H
3  #define __LINUX_MDIO_BITBANG_H
4  
5  #include <linux/phy.h>
6  
7  struct module;
8  
9  struct mdiobb_ctrl;
10  
11  struct mdiobb_ops {
12  	struct module *owner;
13  
14  	/* Set the Management Data Clock high if level is one,
15  	 * low if level is zero.
16  	 */
17  	void (*set_mdc)(struct mdiobb_ctrl *ctrl, int level);
18  
19  	/* Configure the Management Data I/O pin as an input if
20  	 * "output" is zero, or an output if "output" is one.
21  	 */
22  	void (*set_mdio_dir)(struct mdiobb_ctrl *ctrl, int output);
23  
24  	/* Set the Management Data I/O pin high if value is one,
25  	 * low if "value" is zero.  This may only be called
26  	 * when the MDIO pin is configured as an output.
27  	 */
28  	void (*set_mdio_data)(struct mdiobb_ctrl *ctrl, int value);
29  
30  	/* Retrieve the state Management Data I/O pin. */
31  	int (*get_mdio_data)(struct mdiobb_ctrl *ctrl);
32  };
33  
34  struct mdiobb_ctrl {
35  	const struct mdiobb_ops *ops;
36  	unsigned int override_op_c22;
37  	u8 op_c22_read;
38  	u8 op_c22_write;
39  };
40  
41  int mdiobb_read_c22(struct mii_bus *bus, int phy, int reg);
42  int mdiobb_write_c22(struct mii_bus *bus, int phy, int reg, u16 val);
43  int mdiobb_read_c45(struct mii_bus *bus, int devad, int phy, int reg);
44  int mdiobb_write_c45(struct mii_bus *bus, int devad, int phy, int reg, u16 val);
45  
46  /* The returned bus is not yet registered with the phy layer. */
47  struct mii_bus *alloc_mdio_bitbang(struct mdiobb_ctrl *ctrl);
48  
49  /* The bus must already have been unregistered. */
50  void free_mdio_bitbang(struct mii_bus *bus);
51  
52  #endif
53