spi_dev.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  57. }
  58. /* SPI Dev device interface, compatible with RT-Thread 0.3.x/1.0.x */
  59. static rt_err_t _spidev_device_init(rt_device_t dev)
  60. {
  61. struct rt_spi_device* device;
  62. device = (struct rt_spi_device*) dev;
  63. RT_ASSERT(device != RT_NULL);
  64. return RT_EOK;
  65. }
  66. static rt_size_t _spidev_device_read(rt_device_t dev, rt_off_t pos, void *buffer, rt_size_t size)
  67. {
  68. struct rt_spi_device* device;
  69. device = (struct rt_spi_device*) dev;
  70. RT_ASSERT(device != RT_NULL);
  71. RT_ASSERT(device->bus != RT_NULL);
  72. return rt_spi_transfer(device, RT_NULL, buffer, size);
  73. }
  74. static rt_size_t _spidev_device_write(rt_device_t dev, rt_off_t pos, const void *buffer, rt_size_t size)
  75. {
  76. struct rt_spi_device* device;
  77. device = (struct rt_spi_device*) dev;
  78. RT_ASSERT(device != RT_NULL);
  79. RT_ASSERT(device->bus != RT_NULL);
  80. return rt_spi_transfer(device, buffer, RT_NULL, size);
  81. }
  82. static rt_err_t _spidev_device_control(rt_device_t dev, rt_uint8_t cmd, void *args)
  83. {
  84. struct rt_spi_device* device;
  85. device = (struct rt_spi_device*) dev;
  86. RT_ASSERT(device != RT_NULL);
  87. switch (cmd)
  88. {
  89. case 0: /* set device */
  90. break;
  91. case 1:
  92. break;
  93. }
  94. return RT_EOK;
  95. }
  96. rt_err_t rt_spidev_device_init(struct rt_spi_device* dev, const char* name)
  97. {
  98. struct rt_device* device;
  99. RT_ASSERT(dev != RT_NULL);
  100. device = &(dev->parent);
  101. /* set device type */
  102. device->type = RT_Device_Class_SPIDevice;
  103. device->init = _spidev_device_init;
  104. device->open = RT_NULL;
  105. device->close = RT_NULL;
  106. device->read = _spidev_device_read;
  107. device->write = _spidev_device_write;
  108. device->control = _spidev_device_control;
  109. /* register to device manager */
  110. return rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  111. }