pulse_encoder.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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_pulse_encoder_init(struct rt_device *dev)
  13. {
  14. struct rt_pulse_encoder_device *pulse_encoder;
  15. pulse_encoder = (struct rt_pulse_encoder_device *)dev;
  16. if (pulse_encoder->ops->init)
  17. {
  18. return pulse_encoder->ops->init(pulse_encoder);
  19. }
  20. else
  21. {
  22. return -RT_ENOSYS;
  23. }
  24. }
  25. static rt_err_t rt_pulse_encoder_open(struct rt_device *dev, rt_uint16_t oflag)
  26. {
  27. struct rt_pulse_encoder_device *pulse_encoder;
  28. pulse_encoder = (struct rt_pulse_encoder_device *)dev;
  29. if (pulse_encoder->ops->control)
  30. {
  31. return pulse_encoder->ops->control(pulse_encoder, PULSE_ENCODER_CMD_ENABLE, RT_NULL);
  32. }
  33. else
  34. {
  35. return -RT_ENOSYS;
  36. }
  37. }
  38. static rt_err_t rt_pulse_encoder_close(struct rt_device *dev)
  39. {
  40. struct rt_pulse_encoder_device *pulse_encoder;
  41. pulse_encoder = (struct rt_pulse_encoder_device *)dev;
  42. if (pulse_encoder->ops->control)
  43. {
  44. return pulse_encoder->ops->control(pulse_encoder, PULSE_ENCODER_CMD_DISABLE, RT_NULL);
  45. }
  46. else
  47. {
  48. return -RT_ENOSYS;
  49. }
  50. }
  51. static rt_size_t rt_pulse_encoder_read(struct rt_device *dev, rt_off_t pos, void *buffer, rt_size_t size)
  52. {
  53. struct rt_pulse_encoder_device *pulse_encoder;
  54. pulse_encoder = (struct rt_pulse_encoder_device *)dev;
  55. if (pulse_encoder->ops->get_count)
  56. {
  57. *(rt_int32_t *)buffer = pulse_encoder->ops->get_count(pulse_encoder);
  58. }
  59. return 1;
  60. }
  61. static rt_err_t rt_pulse_encoder_control(struct rt_device *dev, int cmd, void *args)
  62. {
  63. rt_err_t result;
  64. struct rt_pulse_encoder_device *pulse_encoder;
  65. result = RT_EOK;
  66. pulse_encoder = (struct rt_pulse_encoder_device *)dev;
  67. switch (cmd)
  68. {
  69. case PULSE_ENCODER_CMD_CLEAR_COUNT:
  70. result = pulse_encoder->ops->clear_count(pulse_encoder);
  71. break;
  72. case PULSE_ENCODER_CMD_GET_TYPE:
  73. *(enum rt_pulse_encoder_type *)args = pulse_encoder->type;
  74. break;
  75. case PULSE_ENCODER_CMD_ENABLE:
  76. case PULSE_ENCODER_CMD_DISABLE:
  77. result = pulse_encoder->ops->control(pulse_encoder, cmd, args);
  78. break;
  79. default:
  80. result = -RT_ENOSYS;
  81. break;
  82. }
  83. return result;
  84. }
  85. #ifdef RT_USING_DEVICE_OPS
  86. const static struct rt_device_ops pulse_encoder_ops =
  87. {
  88. rt_pulse_encoder_init,
  89. rt_pulse_encoder_open,
  90. rt_pulse_encoder_close,
  91. rt_pulse_encoder_read,
  92. RT_NULL,
  93. rt_pulse_encoder_control
  94. };
  95. #endif
  96. rt_err_t rt_device_pulse_encoder_register(struct rt_pulse_encoder_device *pulse_encoder, const char *name, void *user_data)
  97. {
  98. struct rt_device *device;
  99. RT_ASSERT(pulse_encoder != RT_NULL);
  100. RT_ASSERT(pulse_encoder->ops != RT_NULL);
  101. device = &(pulse_encoder->parent);
  102. device->type = RT_Device_Class_Miscellaneous;
  103. device->rx_indicate = RT_NULL;
  104. device->tx_complete = RT_NULL;
  105. #ifdef RT_USING_DEVICE_OPS
  106. device->ops = &pulse_encoder_ops;
  107. #else
  108. device->init = rt_pulse_encoder_init;
  109. device->open = rt_pulse_encoder_open;
  110. device->close = rt_pulse_encoder_close;
  111. device->read = rt_pulse_encoder_read;
  112. device->write = RT_NULL;
  113. device->control = rt_pulse_encoder_control;
  114. #endif
  115. device->user_data = user_data;
  116. return rt_device_register(device, name, RT_DEVICE_FLAG_RDONLY | RT_DEVICE_FLAG_STANDALONE);
  117. }