pulse_encoder.c 3.5 KB

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