1 // SPDX-License-Identifier: GPL-2.0
3 * Greybus Bridged-Phy Bus driver
5 * Copyright 2016 Google Inc.
13 struct greybus_descriptor_cport
*cport_desc
;
14 struct gb_bundle
*bundle
;
15 struct list_head list
;
18 #define to_gbphy_dev(d) container_of(d, struct gbphy_device, dev)
20 static inline void *gb_gbphy_get_data(struct gbphy_device
*gdev
)
22 return dev_get_drvdata(&gdev
->dev
);
25 static inline void gb_gbphy_set_data(struct gbphy_device
*gdev
, void *data
)
27 dev_set_drvdata(&gdev
->dev
, data
);
30 struct gbphy_device_id
{
34 #define GBPHY_PROTOCOL(p) \
39 int (*probe
)(struct gbphy_device
*,
40 const struct gbphy_device_id
*id
);
41 void (*remove
)(struct gbphy_device
*);
42 const struct gbphy_device_id
*id_table
;
44 struct device_driver driver
;
46 #define to_gbphy_driver(d) container_of(d, struct gbphy_driver, driver)
48 int gb_gbphy_register_driver(struct gbphy_driver
*driver
,
49 struct module
*owner
, const char *mod_name
);
50 void gb_gbphy_deregister_driver(struct gbphy_driver
*driver
);
52 #define gb_gbphy_register(driver) \
53 gb_gbphy_register_driver(driver, THIS_MODULE, KBUILD_MODNAME)
54 #define gb_gbphy_deregister(driver) \
55 gb_gbphy_deregister_driver(driver)
58 * module_gbphy_driver() - Helper macro for registering a gbphy driver
59 * @__gbphy_driver: gbphy_driver structure
61 * Helper macro for gbphy drivers to set up proper module init / exit
62 * functions. Replaces module_init() and module_exit() and keeps people from
63 * printing pointless things to the kernel log when their driver is loaded.
65 #define module_gbphy_driver(__gbphy_driver) \
66 module_driver(__gbphy_driver, gb_gbphy_register, gb_gbphy_deregister)
69 static inline int gbphy_runtime_get_sync(struct gbphy_device
*gbphy_dev
)
71 struct device
*dev
= &gbphy_dev
->dev
;
74 ret
= pm_runtime_get_sync(dev
);
76 dev_err(dev
, "pm_runtime_get_sync failed: %d\n", ret
);
77 pm_runtime_put_noidle(dev
);
84 static inline void gbphy_runtime_put_autosuspend(struct gbphy_device
*gbphy_dev
)
86 struct device
*dev
= &gbphy_dev
->dev
;
88 pm_runtime_mark_last_busy(dev
);
89 pm_runtime_put_autosuspend(dev
);
92 static inline void gbphy_runtime_get_noresume(struct gbphy_device
*gbphy_dev
)
94 pm_runtime_get_noresume(&gbphy_dev
->dev
);
97 static inline void gbphy_runtime_put_noidle(struct gbphy_device
*gbphy_dev
)
99 pm_runtime_put_noidle(&gbphy_dev
->dev
);
102 static inline int gbphy_runtime_get_sync(struct gbphy_device
*gbphy_dev
) { return 0; }
103 static inline void gbphy_runtime_put_autosuspend(struct gbphy_device
*gbphy_dev
) {}
104 static inline void gbphy_runtime_get_noresume(struct gbphy_device
*gbphy_dev
) {}
105 static inline void gbphy_runtime_put_noidle(struct gbphy_device
*gbphy_dev
) {}
108 #endif /* __GBPHY_H */