app_bridge.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * app_bridge.h
  3. *
  4. * Created on: Nov 2, 2023
  5. * Author: juraj
  6. */
  7. #ifndef MODULES_NBUS_INC_APP_BRIDGE_H_
  8. #define MODULES_NBUS_INC_APP_BRIDGE_H_
  9. #include "mcu_platform.h"
  10. typedef enum
  11. {
  12. // read-only sensors
  13. TYPE_UNKNOWN = 0xFF,
  14. TYPE_ACCELEROMETER = 0,
  15. TYPE_GYROSCOPE,
  16. TYPE_MAGNETOMETER,
  17. TYPE_EULER_ANGLES_GAUGE,
  18. TYPE_THERMOMETER,
  19. TYPE_HYGROMETER,
  20. TYPE_PRESSURE_GAUGE,
  21. TYPE_HEART_RATE_MONITOR,
  22. TYPE_LENGTH_GAUGE,
  23. // read-write sensors
  24. TYPE_LED_CONTROLLER,
  25. TYPE_MOTOR_CONTROLLER
  26. } nBus_sensorType_t;
  27. typedef enum
  28. {
  29. PARAM_NONE = 0xFF,
  30. PARAM_TIMEBASE = 0,
  31. PARAM_RESOLUTION,
  32. PARAM_GAIN,
  33. PARAM_OFFSET,
  34. PARAM_SAMPLERATE,
  35. PARAM_RANGE,
  36. PARAM_RANGE0,
  37. PARAM_FILTER,
  38. PARAM_ENABLE,
  39. PARAM_MODE,
  40. _NBUS_PARAM_COUNT // number of parameters, must be last!
  41. } nBus_param_t;
  42. typedef enum
  43. {
  44. STATUS_NOT_SUPPORTED = 0xFF,
  45. STATUS_SUCCESS = 0,
  46. STATUS_FAIL = 1
  47. } nBus_statusType_t;
  48. /**
  49. * @brief Definuje formát dát senzora.
  50. * @note Bajtová reprezentácia (Little Endian) bude nasledovná: | unit_multiplier | sign | value_multiplier | samples |
  51. * byte_length
  52. */
  53. typedef struct __attribute__((packed, aligned(1)))
  54. {
  55. /** Bit určujúci či sú dáta znamienkové.
  56. * 0 = ungigned, 1 = signed */
  57. uint8_t sign : 1;
  58. /** Násobok základnej meranej jednotky (mili, micro, kilo, deka, mega, ...)
  59. * uložený v logaritmickom tvare (pr. 2 -> 10^2).
  60. * @note: povolený rozsah [-64 , +63]
  61. */
  62. int8_t unit_multiplier : 7;
  63. /** Násobok meranej hodnoty uložený v logaritmickom tvare (pr. 1 -> 10^1).
  64. * @note: povolený rozsah [-128 , +127]
  65. */
  66. int8_t value_multiplier : 8;
  67. /** Počet bajtov meranej hodnoty.
  68. * @note: povolený rozsah [1 , 8]
  69. */
  70. uint8_t byte_length : 4;
  71. /** Počet vzoriek meranej hodnoty.
  72. * @note: povolený rozsah [1 , 16]
  73. */
  74. uint8_t samples : 4;
  75. } nBus_sensorFormat_t;
  76. typedef struct
  77. {
  78. uint8_t read_only_count;
  79. uint8_t read_write_count;
  80. } nBus_sensorCount_t;
  81. #define PARAM_VALUE_NONE 0x7FFFFFFF
  82. typedef struct
  83. {
  84. void (*init)(void *hw_interface, void *hw_config);
  85. void (*reset)();
  86. nBus_sensorType_t (*getType)(uint8_t sensor_index);
  87. nBus_sensorCount_t (*getSensorCount)();
  88. uint8_t (*getData)(uint8_t sensor_index, uint8_t *data);
  89. nBus_statusType_t (*setData)(uint8_t *data, uint8_t count, uint8_t *response);
  90. uint8_t (*hasParam)(uint8_t sensor_index, nBus_param_t param_name);
  91. int32_t (*getParam)(uint8_t sensor_index, nBus_param_t param_name);
  92. nBus_statusType_t (*setParam)(uint8_t sensor_index, nBus_param_t param_name, int32_t param_value);
  93. nBus_statusType_t (*start)(void);
  94. nBus_statusType_t (*stop)(void);
  95. void (*read)(void);
  96. uint8_t (*store)(void);
  97. nBus_statusType_t (*calibrate)(uint8_t sensor_index);
  98. nBus_sensorFormat_t (*getSensorFormat)(uint8_t sensor_index);
  99. nBus_statusType_t (*find)(uint8_t enable);
  100. uint8_t (*device_ready)();
  101. } nBusAppInterface_t;
  102. #endif /* MODULES_NBUS_INC_APP_BRIDGE_H_ */