spi_dev.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. /*
  2. * Copyright (c) 2006-2018, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. */
  9. #include <rtthread.h>
  10. #include <drivers/spi.h>
  11. /* SPI bus device interface, compatible with RT-Thread 0.3.x/1.0.x */
  12. static rt_size_t _spi_bus_device_read(rt_device_t dev,
  13. rt_off_t pos,
  14. void *buffer,
  15. rt_size_t size)
  16. {
  17. struct rt_spi_bus *bus;
  18. bus = (struct rt_spi_bus *)dev;
  19. RT_ASSERT(bus != RT_NULL);
  20. RT_ASSERT(bus->owner != RT_NULL);
  21. return rt_spi_transfer(bus->owner, RT_NULL, buffer, size);
  22. }
  23. static rt_size_t _spi_bus_device_write(rt_device_t dev,
  24. rt_off_t pos,
  25. const void *buffer,
  26. rt_size_t size)
  27. {
  28. struct rt_spi_bus *bus;
  29. bus = (struct rt_spi_bus *)dev;
  30. RT_ASSERT(bus != RT_NULL);
  31. RT_ASSERT(bus->owner != RT_NULL);
  32. return rt_spi_transfer(bus->owner, buffer, RT_NULL, size);
  33. }
  34. static rt_err_t _spi_bus_device_control(rt_device_t dev,
  35. int cmd,
  36. void *args)
  37. {
  38. /* TODO: add control command handle */
  39. switch (cmd)
  40. {
  41. case 0: /* set device */
  42. break;
  43. case 1:
  44. break;
  45. }
  46. return RT_EOK;
  47. }
  48. #ifdef RT_USING_DEVICE_OPS
  49. const static struct rt_device_ops spi_bus_ops =
  50. {
  51. RT_NULL,
  52. RT_NULL,
  53. RT_NULL,
  54. _spi_bus_device_read,
  55. _spi_bus_device_write,
  56. _spi_bus_device_control
  57. };
  58. #endif
  59. rt_err_t rt_spi_bus_device_init(struct rt_spi_bus *bus, const char *name)
  60. {
  61. struct rt_device *device;
  62. RT_ASSERT(bus != RT_NULL);
  63. device = &bus->parent;
  64. /* set device type */
  65. device->type = RT_Device_Class_SPIBUS;
  66. /* initialize device interface */
  67. #ifdef RT_USING_DEVICE_OPS
  68. device->ops = &spi_bus_ops;
  69. #else
  70. device->init = RT_NULL;
  71. device->open = RT_NULL;
  72. device->close = RT_NULL;
  73. device->read = _spi_bus_device_read;
  74. device->write = _spi_bus_device_write;
  75. device->control = _spi_bus_device_control;
  76. #endif
  77. /* register to device manager */
  78. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  79. }
  80. /* SPI Dev device interface, compatible with RT-Thread 0.3.x/1.0.x */
  81. static rt_size_t _spidev_device_read(rt_device_t dev,
  82. rt_off_t pos,
  83. void *buffer,
  84. rt_size_t size)
  85. {
  86. struct rt_spi_device *device;
  87. device = (struct rt_spi_device *)dev;
  88. RT_ASSERT(device != RT_NULL);
  89. RT_ASSERT(device->bus != RT_NULL);
  90. return rt_spi_transfer(device, RT_NULL, buffer, size);
  91. }
  92. static rt_size_t _spidev_device_write(rt_device_t dev,
  93. rt_off_t pos,
  94. const void *buffer,
  95. rt_size_t size)
  96. {
  97. struct rt_spi_device *device;
  98. device = (struct rt_spi_device *)dev;
  99. RT_ASSERT(device != RT_NULL);
  100. RT_ASSERT(device->bus != RT_NULL);
  101. return rt_spi_transfer(device, buffer, RT_NULL, size);
  102. }
  103. static rt_err_t _spidev_device_control(rt_device_t dev,
  104. int cmd,
  105. void *args)
  106. {
  107. switch (cmd)
  108. {
  109. case 0: /* set device */
  110. break;
  111. case 1:
  112. break;
  113. }
  114. return RT_EOK;
  115. }
  116. #ifdef RT_USING_DEVICE_OPS
  117. const static struct rt_device_ops spi_device_ops =
  118. {
  119. RT_NULL,
  120. RT_NULL,
  121. RT_NULL,
  122. _spidev_device_read,
  123. _spidev_device_write,
  124. _spidev_device_control
  125. };
  126. #endif
  127. rt_err_t rt_spidev_device_init(struct rt_spi_device *dev, const char *name)
  128. {
  129. struct rt_device *device;
  130. RT_ASSERT(dev != RT_NULL);
  131. device = &(dev->parent);
  132. /* set device type */
  133. device->type = RT_Device_Class_SPIDevice;
  134. #ifdef RT_USING_DEVICE_OPS
  135. device->ops = &spi_device_ops;
  136. #else
  137. device->init = RT_NULL;
  138. device->open = RT_NULL;
  139. device->close = RT_NULL;
  140. device->read = _spidev_device_read;
  141. device->write = _spidev_device_write;
  142. device->control = _spidev_device_control;
  143. #endif
  144. /* register to device manager */
  145. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  146. }