app_bridge.h 3.1 KB

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