spi_dev.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. /*
  2. * Copyright (c) 2006-2023, 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_ssize_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_ssize_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. #ifdef RT_USING_DEVICE_OPS
  35. const static struct rt_device_ops spi_bus_ops =
  36. {
  37. RT_NULL,
  38. RT_NULL,
  39. RT_NULL,
  40. _spi_bus_device_read,
  41. _spi_bus_device_write,
  42. RT_NULL
  43. };
  44. #endif
  45. rt_err_t rt_spi_bus_device_init(struct rt_spi_bus *bus, const char *name)
  46. {
  47. struct rt_device *device;
  48. RT_ASSERT(bus != RT_NULL);
  49. device = &bus->parent;
  50. /* set device type */
  51. device->type = RT_Device_Class_SPIBUS;
  52. /* initialize device interface */
  53. #ifdef RT_USING_DEVICE_OPS
  54. device->ops = &spi_bus_ops;
  55. #else
  56. device->init = RT_NULL;
  57. device->open = RT_NULL;
  58. device->close = RT_NULL;
  59. device->read = _spi_bus_device_read;
  60. device->write = _spi_bus_device_write;
  61. device->control = RT_NULL;
  62. #endif
  63. /* register to device manager */
  64. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  65. }
  66. /* SPI Dev device interface, compatible with RT-Thread 0.3.x/1.0.x */
  67. static rt_ssize_t _spidev_device_read(rt_device_t dev,
  68. rt_off_t pos,
  69. void *buffer,
  70. rt_size_t size)
  71. {
  72. struct rt_spi_device *device;
  73. device = (struct rt_spi_device *)dev;
  74. RT_ASSERT(device != RT_NULL);
  75. RT_ASSERT(device->bus != RT_NULL);
  76. return rt_spi_transfer(device, RT_NULL, buffer, size);
  77. }
  78. static rt_ssize_t _spidev_device_write(rt_device_t dev,
  79. rt_off_t pos,
  80. const void *buffer,
  81. rt_size_t size)
  82. {
  83. struct rt_spi_device *device;
  84. device = (struct rt_spi_device *)dev;
  85. RT_ASSERT(device != RT_NULL);
  86. RT_ASSERT(device->bus != RT_NULL);
  87. return rt_spi_transfer(device, buffer, RT_NULL, size);
  88. }
  89. static rt_err_t _spidev_device_control(rt_device_t dev,
  90. int cmd,
  91. void *args)
  92. {
  93. switch (cmd)
  94. {
  95. case 0: /* set device */
  96. break;
  97. case 1:
  98. break;
  99. }
  100. return RT_EOK;
  101. }
  102. #ifdef RT_USING_DEVICE_OPS
  103. const static struct rt_device_ops spi_device_ops =
  104. {
  105. RT_NULL,
  106. RT_NULL,
  107. RT_NULL,
  108. _spidev_device_read,
  109. _spidev_device_write,
  110. _spidev_device_control
  111. };
  112. #endif
  113. rt_err_t rt_spidev_device_init(struct rt_spi_device *dev, const char *name)
  114. {
  115. struct rt_device *device;
  116. RT_ASSERT(dev != RT_NULL);
  117. device = &(dev->parent);
  118. /* set device type */
  119. device->type = RT_Device_Class_SPIDevice;
  120. #ifdef RT_USING_DEVICE_OPS
  121. device->ops = &spi_device_ops;
  122. #else
  123. device->init = RT_NULL;
  124. device->open = RT_NULL;
  125. device->close = RT_NULL;
  126. device->read = _spidev_device_read;
  127. device->write = _spidev_device_write;
  128. device->control = _spidev_device_control;
  129. #endif
  130. /* register to device manager */
  131. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  132. }