gbphy.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * Greybus Bridged-Phy Bus driver
  3. *
  4. * Copyright 2016 Google Inc.
  5. *
  6. * Released under the GPLv2 only.
  7. */
  8. #ifndef __GBPHY_H
  9. #define __GBPHY_H
  10. struct gbphy_device {
  11. u32 id;
  12. struct greybus_descriptor_cport *cport_desc;
  13. struct gb_bundle *bundle;
  14. struct list_head list;
  15. struct device dev;
  16. };
  17. #define to_gbphy_dev(d) container_of(d, struct gbphy_device, dev)
  18. static inline void *gb_gbphy_get_data(struct gbphy_device *gdev)
  19. {
  20. return dev_get_drvdata(&gdev->dev);
  21. }
  22. static inline void gb_gbphy_set_data(struct gbphy_device *gdev, void *data)
  23. {
  24. dev_set_drvdata(&gdev->dev, data);
  25. }
  26. struct gbphy_device_id {
  27. __u8 protocol_id;
  28. };
  29. #define GBPHY_PROTOCOL(p) \
  30. .protocol_id = (p),
  31. struct gbphy_driver {
  32. const char *name;
  33. int (*probe)(struct gbphy_device *,
  34. const struct gbphy_device_id *id);
  35. void (*remove)(struct gbphy_device *);
  36. const struct gbphy_device_id *id_table;
  37. struct device_driver driver;
  38. };
  39. #define to_gbphy_driver(d) container_of(d, struct gbphy_driver, driver)
  40. int gb_gbphy_register_driver(struct gbphy_driver *driver,
  41. struct module *owner, const char *mod_name);
  42. void gb_gbphy_deregister_driver(struct gbphy_driver *driver);
  43. #define gb_gbphy_register(driver) \
  44. gb_gbphy_register_driver(driver, THIS_MODULE, KBUILD_MODNAME)
  45. #define gb_gbphy_deregister(driver) \
  46. gb_gbphy_deregister_driver(driver)
  47. /**
  48. * module_gbphy_driver() - Helper macro for registering a gbphy driver
  49. * @__gbphy_driver: gbphy_driver structure
  50. *
  51. * Helper macro for gbphy drivers to set up proper module init / exit
  52. * functions. Replaces module_init() and module_exit() and keeps people from
  53. * printing pointless things to the kernel log when their driver is loaded.
  54. */
  55. #define module_gbphy_driver(__gbphy_driver) \
  56. module_driver(__gbphy_driver, gb_gbphy_register, gb_gbphy_deregister)
  57. #ifdef CONFIG_PM
  58. static inline int gbphy_runtime_get_sync(struct gbphy_device *gbphy_dev)
  59. {
  60. struct device *dev = &gbphy_dev->dev;
  61. int ret;
  62. ret = pm_runtime_get_sync(dev);
  63. if (ret < 0) {
  64. dev_err(dev, "pm_runtime_get_sync failed: %d\n", ret);
  65. pm_runtime_put_noidle(dev);
  66. return ret;
  67. }
  68. return 0;
  69. }
  70. static inline void gbphy_runtime_put_autosuspend(struct gbphy_device *gbphy_dev)
  71. {
  72. struct device *dev = &gbphy_dev->dev;
  73. pm_runtime_mark_last_busy(dev);
  74. pm_runtime_put_autosuspend(dev);
  75. }
  76. static inline void gbphy_runtime_get_noresume(struct gbphy_device *gbphy_dev)
  77. {
  78. pm_runtime_get_noresume(&gbphy_dev->dev);
  79. }
  80. static inline void gbphy_runtime_put_noidle(struct gbphy_device *gbphy_dev)
  81. {
  82. pm_runtime_put_noidle(&gbphy_dev->dev);
  83. }
  84. #else
  85. static inline int gbphy_runtime_get_sync(struct gbphy_device *gbphy_dev) { return 0; }
  86. static inline void gbphy_runtime_put_autosuspend(struct gbphy_device *gbphy_dev) {}
  87. static inline void gbphy_runtime_get_noresume(struct gbphy_device *gbphy_dev) {}
  88. static inline void gbphy_runtime_put_noidle(struct gbphy_device *gbphy_dev) {}
  89. #endif
  90. #endif /* __GBPHY_H */