app_bridge.h 2.9 KB

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