dev_spi_bus.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2022-12-06 GuEe-GUI first version
  9. * 2025-12-25 lhxj mark OFW node as taken to prevent platform bus duplication; fix cppcheck warning
  10. */
  11. #include "dev_spi_dm.h"
  12. #define DBG_TAG "spi.bus"
  13. #define DBG_LVL DBG_INFO
  14. #include <rtdbg.h>
  15. extern rt_err_t rt_spidev_device_init(struct rt_spi_device *dev, const char *name);
  16. static struct rt_bus spi_bus;
  17. void spi_bus_scan_devices(struct rt_spi_bus *bus)
  18. {
  19. #ifdef RT_USING_OFW
  20. if (bus->parent.ofw_node)
  21. {
  22. struct rt_ofw_node *np = bus->parent.ofw_node, *spi_dev_np;
  23. rt_ofw_foreach_available_child_node(np, spi_dev_np)
  24. {
  25. struct rt_spi_device *spi_dev;
  26. if (!rt_ofw_prop_read_bool(spi_dev_np, "compatible"))
  27. {
  28. continue;
  29. }
  30. if ((bus->mode & RT_SPI_BUS_MODE_SPI) == RT_SPI_BUS_MODE_SPI)
  31. {
  32. spi_dev = rt_calloc(1, sizeof(struct rt_spi_device));
  33. }
  34. else if ((bus->mode & RT_SPI_BUS_MODE_QSPI) == RT_SPI_BUS_MODE_QSPI)
  35. {
  36. spi_dev = rt_calloc(1, sizeof(struct rt_qspi_device));
  37. }
  38. else
  39. {
  40. LOG_E("Unknown bus mode = %x", bus->mode);
  41. RT_ASSERT(0);
  42. }
  43. if (!spi_dev)
  44. {
  45. rt_ofw_node_put(spi_dev_np);
  46. LOG_E("Not memory to create spi device: %s",
  47. rt_ofw_node_full_name(spi_dev_np));
  48. return;
  49. }
  50. spi_dev->parent.ofw_node = spi_dev_np;
  51. spi_dev->parent.type = RT_Device_Class_Unknown;
  52. spi_dev->name = rt_ofw_node_name(spi_dev_np);
  53. spi_dev->bus = bus;
  54. rt_dm_dev_set_name(&spi_dev->parent, rt_ofw_node_full_name(spi_dev_np));
  55. if (spi_device_ofw_parse(spi_dev))
  56. {
  57. continue;
  58. }
  59. /* Mark this OFW node as taken to prevent platform bus from creating duplicate device */
  60. spi_dev_np->dev = &spi_dev->parent;
  61. rt_spi_device_register(spi_dev);
  62. }
  63. }
  64. #endif /* RT_USING_OFW */
  65. }
  66. rt_err_t rt_spi_driver_register(struct rt_spi_driver *driver)
  67. {
  68. RT_ASSERT(driver != RT_NULL);
  69. driver->parent.bus = &spi_bus;
  70. return rt_driver_register(&driver->parent);
  71. }
  72. rt_err_t rt_spi_device_register(struct rt_spi_device *device)
  73. {
  74. RT_ASSERT(device != RT_NULL);
  75. return rt_bus_add_device(&spi_bus, &device->parent);
  76. }
  77. static rt_bool_t spi_match(rt_driver_t drv, rt_device_t dev)
  78. {
  79. const struct rt_spi_device_id *id;
  80. struct rt_spi_driver *driver = rt_container_of(drv, struct rt_spi_driver, parent);
  81. struct rt_spi_device *device = rt_container_of(dev, struct rt_spi_device, parent);
  82. if ((id = driver->ids))
  83. {
  84. for (; id->name[0]; ++id)
  85. {
  86. if (!rt_strcmp(id->name, device->name))
  87. {
  88. device->id = id;
  89. device->ofw_id = RT_NULL;
  90. return RT_TRUE;
  91. }
  92. }
  93. }
  94. #ifdef RT_USING_OFW
  95. device->ofw_id = rt_ofw_node_match(device->parent.ofw_node, driver->ofw_ids);
  96. if (device->ofw_id)
  97. {
  98. device->id = RT_NULL;
  99. return RT_TRUE;
  100. }
  101. #endif
  102. return RT_FALSE;
  103. }
  104. static rt_err_t spi_probe(rt_device_t dev)
  105. {
  106. rt_err_t err;
  107. struct rt_spi_bus *bus;
  108. struct rt_spi_driver *driver = rt_container_of(dev->drv, struct rt_spi_driver, parent);
  109. struct rt_spi_device *device = rt_container_of(dev, struct rt_spi_device, parent);
  110. if (!device->bus)
  111. {
  112. return -RT_EINVAL;
  113. }
  114. err = driver->probe(device);
  115. if (err)
  116. {
  117. return err;
  118. }
  119. bus = device->bus;
  120. if (bus->cs_pins[0] >= 0)
  121. {
  122. device->cs_pin = bus->cs_pins[device->chip_select[0]];
  123. rt_pin_mode(device->cs_pin, PIN_MODE_OUTPUT);
  124. }
  125. else
  126. {
  127. device->cs_pin = PIN_NONE;
  128. }
  129. /* Driver not register SPI device to system */
  130. if (device->parent.type == RT_Device_Class_Unknown)
  131. {
  132. rt_spidev_device_init(device, rt_dm_dev_get_name(&device->parent));
  133. }
  134. return RT_EOK;
  135. }
  136. static rt_err_t spi_remove(rt_device_t dev)
  137. {
  138. struct rt_spi_driver *driver = rt_container_of(dev->drv, struct rt_spi_driver, parent);
  139. struct rt_spi_device *device = rt_container_of(dev, struct rt_spi_device, parent);
  140. if (driver && driver->remove)
  141. {
  142. driver->remove(device);
  143. }
  144. rt_free(device);
  145. return RT_EOK;
  146. }
  147. static rt_err_t spi_shutdown(rt_device_t dev)
  148. {
  149. struct rt_spi_driver *driver = rt_container_of(dev->drv, struct rt_spi_driver, parent);
  150. struct rt_spi_device *device = rt_container_of(dev, struct rt_spi_device, parent);
  151. if (driver && driver->shutdown)
  152. {
  153. driver->shutdown(device);
  154. }
  155. rt_free(device);
  156. return RT_EOK;
  157. }
  158. static struct rt_bus spi_bus =
  159. {
  160. .name = "spi",
  161. .match = spi_match,
  162. .probe = spi_probe,
  163. .remove = spi_remove,
  164. .shutdown = spi_shutdown,
  165. };
  166. static int spi_bus_init(void)
  167. {
  168. rt_bus_register(&spi_bus);
  169. return 0;
  170. }
  171. INIT_CORE_EXPORT(spi_bus_init);