i2c_dev.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #include <rtdevice.h>
  2. static rt_err_t i2c_bus_device_init(rt_device_t dev)
  3. {
  4. struct rt_i2c_bus_device* bus = (struct rt_i2c_bus_device *)dev->user_data;
  5. RT_ASSERT(bus != RT_NULL);
  6. return RT_EOK;
  7. }
  8. static rt_size_t i2c_bus_device_read (rt_device_t dev, rt_off_t pos, void *buffer, rt_size_t count)
  9. {
  10. rt_uint16_t addr;
  11. rt_uint16_t flags;
  12. struct rt_i2c_bus_device* bus = (struct rt_i2c_bus_device *)dev->user_data;
  13. RT_ASSERT(bus != RT_NULL);
  14. RT_ASSERT(buffer != RT_NULL);
  15. i2c_dbg("I2C bus dev [%s] reading %u bytes.\n", dev->parent.name, count);
  16. addr = pos & 0xffff;
  17. flags = (pos >> 16) & 0xffff;
  18. return rt_i2c_master_recv(bus, addr, flags, buffer, count);
  19. }
  20. static rt_size_t i2c_bus_device_write (rt_device_t dev, rt_off_t pos, const void *buffer, rt_size_t count)
  21. {
  22. rt_uint16_t addr;
  23. rt_uint16_t flags;
  24. struct rt_i2c_bus_device* bus = (struct rt_i2c_bus_device *)dev->user_data;
  25. RT_ASSERT(bus != RT_NULL);
  26. RT_ASSERT(buffer != RT_NULL);
  27. i2c_dbg("I2C bus dev writing %u bytes.\n", dev->parent.name, count);
  28. addr = pos & 0xffff;
  29. flags = (pos >> 16) & 0xffff;
  30. return rt_i2c_master_send(bus, addr, flags, buffer, count);
  31. }
  32. static rt_err_t i2c_bus_device_control(rt_device_t dev, rt_uint8_t cmd, void *args)
  33. {
  34. rt_err_t ret;
  35. struct rt_i2c_priv_data *priv_data;
  36. struct rt_i2c_bus_device* bus = (struct rt_i2c_bus_device *)dev->user_data;
  37. RT_ASSERT(bus != RT_NULL);
  38. switch (cmd)
  39. {
  40. case RT_I2C_DEV_CTRL_10BIT: /* set 10-bit addr mode */
  41. bus->flags |= RT_I2C_ADDR_10BIT;
  42. break;
  43. case RT_I2C_DEV_CTRL_ADDR:
  44. bus->addr = *(rt_uint16_t *)args;
  45. break;
  46. case RT_I2C_DEV_CTRL_TIMEOUT:
  47. bus->timeout = *(rt_uint32_t *)args;
  48. break;
  49. case RT_I2C_DEV_CTRL_RW:
  50. priv_data = (struct rt_i2c_priv_data *)args;
  51. ret = rt_i2c_transfer(bus, priv_data->msgs, priv_data->number);
  52. if (ret < 0)
  53. {
  54. return -RT_EIO;
  55. }
  56. break;
  57. default: break;
  58. }
  59. return RT_EOK;
  60. }
  61. rt_err_t rt_i2c_bus_device_device_init(struct rt_i2c_bus_device* bus, const char* name)
  62. {
  63. struct rt_device *device;
  64. RT_ASSERT(bus != RT_NULL);
  65. device = &bus->parent;
  66. device->user_data = bus;
  67. /* set device type */
  68. device->type = RT_Device_Class_I2CBUS;
  69. /* initialize device interface */
  70. device->init = i2c_bus_device_init;
  71. device->open = RT_NULL;
  72. device->close = RT_NULL;
  73. device->read = i2c_bus_device_read;
  74. device->write = i2c_bus_device_write;
  75. device->control = i2c_bus_device_control;
  76. /* register to device manager */
  77. rt_device_register(device, name, RT_DEVICE_FLAG_RDWR);
  78. return RT_EOK;
  79. }