encoder.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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. * 2019-08-08 balanceTWK the first version
  9. */
  10. #include <rtthread.h>
  11. #include <rtdevice.h>
  12. static rt_err_t rt_encoder_init(struct rt_device *dev)
  13. {
  14. rt_encoder_t *encoder;
  15. encoder = (rt_encoder_t *)dev;
  16. if (encoder->ops->init)
  17. {
  18. return encoder->ops->init(encoder);
  19. }
  20. else
  21. {
  22. return -RT_ENOSYS;
  23. }
  24. }
  25. static rt_err_t rt_encoder_open(struct rt_device *dev, rt_uint16_t oflag)
  26. {
  27. rt_encoder_t *encoder;
  28. encoder = (rt_encoder_t *)dev;
  29. if (encoder->ops->control)
  30. {
  31. return encoder->ops->control(encoder, ENCODER_SWITCH_ON, RT_NULL);
  32. }
  33. else
  34. {
  35. return -RT_ENOSYS;
  36. }
  37. }
  38. static rt_err_t rt_encoder_close(struct rt_device *dev)
  39. {
  40. rt_encoder_t *encoder;
  41. encoder = (rt_encoder_t *)dev;
  42. if (encoder->ops->control)
  43. {
  44. return encoder->ops->control(encoder, ENCODER_SWITCH_OFF, RT_NULL);
  45. }
  46. else
  47. {
  48. return -RT_ENOSYS;
  49. }
  50. }
  51. static rt_size_t rt_encoder_read(struct rt_device *dev, rt_off_t pos, void *buffer, rt_size_t size)
  52. {
  53. rt_encoder_t *encoder;
  54. encoder = (rt_encoder_t *)dev;
  55. if (encoder->ops->get_count)
  56. {
  57. *(rt_int32_t *)buffer = encoder->ops->get_count(encoder);
  58. }
  59. return 1;
  60. }
  61. static rt_err_t rt_encoder_control(struct rt_device *dev, int cmd, void *args)
  62. {
  63. rt_err_t result;
  64. rt_encoder_t *encoder;
  65. result = RT_EOK;
  66. encoder = (rt_encoder_t *)dev;
  67. switch (cmd)
  68. {
  69. case ENCODER_INFO_GET:
  70. *(struct rt_encoder_info *)args = *encoder->info;
  71. break;
  72. case ENCODER_SWITCH_ON:
  73. case ENCODER_SWITCH_OFF:
  74. case ENCODER_COUNT_CLEAR:
  75. result = encoder->ops->control(encoder, cmd, args);
  76. break;
  77. default:
  78. result = -RT_ENOSYS;
  79. break;
  80. }
  81. return result;
  82. }
  83. #ifdef RT_USING_DEVICE_OPS
  84. const static struct rt_device_ops encoder_ops =
  85. {
  86. rt_encoder_init,
  87. rt_encoder_open,
  88. rt_encoder_close,
  89. rt_encoder_read,
  90. RT_NULL,
  91. rt_encoder_control
  92. };
  93. #endif
  94. rt_err_t rt_device_encoder_register(rt_encoder_t *encoder, const char *name, void *user_data)
  95. {
  96. struct rt_device *device;
  97. RT_ASSERT(encoder != RT_NULL);
  98. RT_ASSERT(encoder->ops != RT_NULL);
  99. RT_ASSERT(encoder->info != RT_NULL);
  100. device = &(encoder->parent);
  101. device->type = RT_Device_Class_Miscellaneous;
  102. device->rx_indicate = RT_NULL;
  103. device->tx_complete = RT_NULL;
  104. #ifdef RT_USING_DEVICE_OPS
  105. device->ops = &encoder_ops;
  106. #else
  107. device->init = rt_encoder_init;
  108. device->open = rt_encoder_open;
  109. device->close = rt_encoder_close;
  110. device->read = rt_encoder_read;
  111. device->write = RT_NULL;
  112. device->control = rt_encoder_control;
  113. #endif
  114. device->user_data = user_data;
  115. return rt_device_register(device, name, RT_DEVICE_FLAG_RDONLY | RT_DEVICE_FLAG_STANDALONE);
  116. }