spi_dev.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. #include <rtthread.h>
  2. #include <drivers/spi.h>
  3. /* SPI bus device interface, compatible with RT-Thread 0.3.x/1.0.x */
  4. static rt_err_t _spi_bus_device_init(rt_device_t dev)
  5. {
  6. struct rt_spi_bus* bus;
  7. bus = (struct rt_spi_bus*) dev;
  8. RT_ASSERT(bus != RT_NULL);
  9. return RT_EOK;
  10. }
  11. static rt_size_t _spi_bus_device_read(rt_device_t dev, rt_off_t pos, void *buffer, rt_size_t size)
  12. {
  13. struct rt_spi_bus* bus;
  14. bus = (struct rt_spi_bus*) dev;
  15. RT_ASSERT(bus != RT_NULL);
  16. RT_ASSERT(bus->owner != RT_NULL);
  17. return rt_spi_transfer(bus->owner, RT_NULL, buffer, size);
  18. }
  19. static rt_size_t _spi_bus_device_write(rt_device_t dev, rt_off_t pos, const void *buffer, rt_size_t size)
  20. {
  21. struct rt_spi_bus* bus;
  22. bus = (struct rt_spi_bus*) dev;
  23. RT_ASSERT(bus != RT_NULL);
  24. RT_ASSERT(bus->owner != RT_NULL);
  25. return rt_spi_transfer(bus->owner, buffer, RT_NULL, size);
  26. }
  27. static rt_err_t _spi_bus_device_control(rt_device_t dev, rt_uint8_t cmd, void *args)
  28. {
  29. struct rt_spi_bus* bus;
  30. bus = (struct rt_spi_bus*) dev;
  31. RT_ASSERT(bus != RT_NULL);
  32. switch (cmd)
  33. {
  34. case 0: /* set device */
  35. break;
  36. case 1:
  37. break;
  38. }
  39. return RT_EOK;
  40. }
  41. rt_err_t rt_spi_bus_device_init(struct rt_spi_bus* bus, const char* name)
  42. {
  43. struct rt_device *device;
  44. RT_ASSERT(bus != RT_NULL);
  45. device = &bus->parent;
  46. /* set device type */
  47. device->type = RT_Device_Class_SPIBUS;
  48. /* initialize device interface */
  49. device->init = _spi_bus_device_init;
  50. device->open = RT_NULL;
  51. device->close = RT_NULL;
  52. device->read = _spi_bus_device_read;
  53. device->write = _spi_bus_device_write;
  54. device->control = _spi_bus_device_control;
  55. /* register to device manager */
  56. rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  57. return RT_EOK;
  58. }
  59. /* SPI Dev device interface, compatible with RT-Thread 0.3.x/1.0.x */
  60. static rt_err_t _spidev_device_init(rt_device_t dev)
  61. {
  62. struct rt_spi_device* device;
  63. device = (struct rt_spi_device*) dev;
  64. RT_ASSERT(device != RT_NULL);
  65. return RT_EOK;
  66. }
  67. static rt_size_t _spidev_device_read(rt_device_t dev, rt_off_t pos, void *buffer, rt_size_t size)
  68. {
  69. struct rt_spi_device* device;
  70. device = (struct rt_spi_device*) dev;
  71. RT_ASSERT(device != RT_NULL);
  72. RT_ASSERT(device->bus != RT_NULL);
  73. return rt_spi_transfer(device, RT_NULL, buffer, size);
  74. }
  75. static rt_size_t _spidev_device_write(rt_device_t dev, rt_off_t pos, const void *buffer, rt_size_t size)
  76. {
  77. struct rt_spi_device* device;
  78. device = (struct rt_spi_device*) dev;
  79. RT_ASSERT(device != RT_NULL);
  80. RT_ASSERT(device->bus != RT_NULL);
  81. return rt_spi_transfer(device, buffer, RT_NULL, size);
  82. }
  83. static rt_err_t _spidev_device_control(rt_device_t dev, rt_uint8_t cmd, void *args)
  84. {
  85. struct rt_spi_device* device;
  86. device = (struct rt_spi_device*) dev;
  87. RT_ASSERT(device != RT_NULL);
  88. switch (cmd)
  89. {
  90. case 0: /* set device */
  91. break;
  92. case 1:
  93. break;
  94. }
  95. return RT_EOK;
  96. }
  97. rt_err_t rt_spidev_device_init(struct rt_spi_device* dev, const char* name)
  98. {
  99. struct rt_device* device;
  100. RT_ASSERT(device != RT_NULL);
  101. device = &(dev->parent);
  102. /* set device type */
  103. device->type = RT_Device_Class_SPIDevice;
  104. device->init = _spidev_device_init;
  105. device->open = RT_NULL;
  106. device->close = RT_NULL;
  107. device->read = _spidev_device_read;
  108. device->write = _spidev_device_write;
  109. device->control = _spidev_device_control;
  110. /* register to device manager */
  111. rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  112. return RT_EOK;
  113. }