module.c 4.9 KB

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