module.c 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Greybus Module code
  4. *
  5. * Copyright 2016 Google Inc.
  6. * Copyright 2016 Linaro Ltd.
  7. */
  8. #include <linux/greybus.h>
  9. #include "greybus_trace.h"
  10. static ssize_t eject_store(struct device *dev,
  11. struct device_attribute *attr,
  12. const char *buf, size_t len)
  13. {
  14. struct gb_module *module = to_gb_module(dev);
  15. struct gb_interface *intf;
  16. size_t i;
  17. long val;
  18. int ret;
  19. ret = kstrtol(buf, 0, &val);
  20. if (ret)
  21. return ret;
  22. if (!val)
  23. return len;
  24. for (i = 0; i < module->num_interfaces; ++i) {
  25. intf = module->interfaces[i];
  26. mutex_lock(&intf->mutex);
  27. /* Set flag to prevent concurrent activation. */
  28. intf->ejected = true;
  29. gb_interface_disable(intf);
  30. gb_interface_deactivate(intf);
  31. mutex_unlock(&intf->mutex);
  32. }
  33. /* Tell the SVC to eject the primary interface. */
  34. ret = gb_svc_intf_eject(module->hd->svc, module->module_id);
  35. if (ret)
  36. return ret;
  37. return len;
  38. }
  39. static DEVICE_ATTR_WO(eject);
  40. static ssize_t module_id_show(struct device *dev,
  41. struct device_attribute *attr, char *buf)
  42. {
  43. struct gb_module *module = to_gb_module(dev);
  44. return sprintf(buf, "%u\n", module->module_id);
  45. }
  46. static DEVICE_ATTR_RO(module_id);
  47. static ssize_t num_interfaces_show(struct device *dev,
  48. struct device_attribute *attr, char *buf)
  49. {
  50. struct gb_module *module = to_gb_module(dev);
  51. return sprintf(buf, "%zu\n", module->num_interfaces);
  52. }
  53. static DEVICE_ATTR_RO(num_interfaces);
  54. static struct attribute *module_attrs[] = {
  55. &dev_attr_eject.attr,
  56. &dev_attr_module_id.attr,
  57. &dev_attr_num_interfaces.attr,
  58. NULL,
  59. };
  60. ATTRIBUTE_GROUPS(module);
  61. static void gb_module_release(struct device *dev)
  62. {
  63. struct gb_module *module = to_gb_module(dev);
  64. trace_gb_module_release(module);
  65. kfree(module);
  66. }
  67. struct device_type greybus_module_type = {
  68. .name = "greybus_module",
  69. .release = gb_module_release,
  70. };
  71. struct gb_module *gb_module_create(struct gb_host_device *hd, u8 module_id,
  72. size_t num_interfaces)
  73. {
  74. struct gb_interface *intf;
  75. struct gb_module *module;
  76. int i;
  77. module = kzalloc(struct_size(module, interfaces, num_interfaces),
  78. GFP_KERNEL);
  79. if (!module)
  80. return NULL;
  81. module->hd = hd;
  82. module->module_id = module_id;
  83. module->num_interfaces = num_interfaces;
  84. module->dev.parent = &hd->dev;
  85. module->dev.bus = &greybus_bus_type;
  86. module->dev.type = &greybus_module_type;
  87. module->dev.groups = module_groups;
  88. module->dev.dma_mask = hd->dev.dma_mask;
  89. device_initialize(&module->dev);
  90. dev_set_name(&module->dev, "%d-%u", hd->bus_id, module_id);
  91. trace_gb_module_create(module);
  92. for (i = 0; i < num_interfaces; ++i) {
  93. intf = gb_interface_create(module, module_id + i);
  94. if (!intf) {
  95. dev_err(&module->dev, "failed to create interface %u\n",
  96. module_id + i);
  97. goto err_put_interfaces;
  98. }
  99. module->interfaces[i] = intf;
  100. }
  101. return module;
  102. err_put_interfaces:
  103. for (--i; i >= 0; --i)
  104. gb_interface_put(module->interfaces[i]);
  105. put_device(&module->dev);
  106. return NULL;
  107. }
  108. /*
  109. * Register and enable an interface after first attempting to activate it.
  110. */
  111. static void gb_module_register_interface(struct gb_interface *intf)
  112. {
  113. struct gb_module *module = intf->module;
  114. u8 intf_id = intf->interface_id;
  115. int ret;
  116. mutex_lock(&intf->mutex);
  117. ret = gb_interface_activate(intf);
  118. if (ret) {
  119. if (intf->type != GB_INTERFACE_TYPE_DUMMY) {
  120. dev_err(&module->dev,
  121. "failed to activate interface %u: %d\n",
  122. intf_id, ret);
  123. }
  124. gb_interface_add(intf);
  125. goto err_unlock;
  126. }
  127. ret = gb_interface_add(intf);
  128. if (ret)
  129. goto err_interface_deactivate;
  130. ret = gb_interface_enable(intf);
  131. if (ret) {
  132. dev_err(&module->dev, "failed to enable interface %u: %d\n",
  133. intf_id, ret);
  134. goto err_interface_deactivate;
  135. }
  136. mutex_unlock(&intf->mutex);
  137. return;
  138. err_interface_deactivate:
  139. gb_interface_deactivate(intf);
  140. err_unlock:
  141. mutex_unlock(&intf->mutex);
  142. }
  143. static void gb_module_deregister_interface(struct gb_interface *intf)
  144. {
  145. /* Mark as disconnected to prevent I/O during disable. */
  146. if (intf->module->disconnected)
  147. intf->disconnected = true;
  148. mutex_lock(&intf->mutex);
  149. intf->removed = true;
  150. gb_interface_disable(intf);
  151. gb_interface_deactivate(intf);
  152. mutex_unlock(&intf->mutex);
  153. gb_interface_del(intf);
  154. }
  155. /* Register a module and its interfaces. */
  156. int gb_module_add(struct gb_module *module)
  157. {
  158. size_t i;
  159. int ret;
  160. ret = device_add(&module->dev);
  161. if (ret) {
  162. dev_err(&module->dev, "failed to register module: %d\n", ret);
  163. return ret;
  164. }
  165. trace_gb_module_add(module);
  166. for (i = 0; i < module->num_interfaces; ++i)
  167. gb_module_register_interface(module->interfaces[i]);
  168. return 0;
  169. }
  170. /* Deregister a module and its interfaces. */
  171. void gb_module_del(struct gb_module *module)
  172. {
  173. size_t i;
  174. for (i = 0; i < module->num_interfaces; ++i)
  175. gb_module_deregister_interface(module->interfaces[i]);
  176. trace_gb_module_del(module);
  177. device_del(&module->dev);
  178. }
  179. void gb_module_put(struct gb_module *module)
  180. {
  181. size_t i;
  182. for (i = 0; i < module->num_interfaces; ++i)
  183. gb_interface_put(module->interfaces[i]);
  184. put_device(&module->dev);
  185. }