BH1750.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /**
  2. * @file BH1750.h
  3. * @author Oleksii Kutuzov (oleksii.kutuzov@icloud.com)
  4. * @brief
  5. * @version 0.1
  6. * @date 2022-11-06
  7. *
  8. * @copyright Copyright (c) 2022
  9. *
  10. * Ported from:
  11. * https://github.com/lamik/Light_Sensors_STM32
  12. */
  13. #include "BH1750.h"
  14. BH1750_mode bh1750_mode = BH1750_DEFAULT_MODE; // Current sensor mode
  15. uint8_t bh1750_mt_reg = BH1750_DEFAULT_MTREG; // Current MT register value
  16. BH1750_STATUS bh1750_init() {
  17. if(BH1750_OK == bh1750_reset()) {
  18. if(BH1750_OK == bh1750_set_mt_reg(BH1750_DEFAULT_MTREG)) {
  19. return BH1750_OK;
  20. }
  21. }
  22. return BH1750_ERROR;
  23. }
  24. BH1750_STATUS bh1750_reset() {
  25. uint8_t command = 0x07;
  26. bool status;
  27. furi_hal_i2c_acquire(I2C_BUS);
  28. status = furi_hal_i2c_tx(I2C_BUS, BH1750_ADDRESS, &command, 1, I2C_TIMEOUT);
  29. furi_hal_i2c_release(I2C_BUS);
  30. if(status) {
  31. return BH1750_OK;
  32. }
  33. return BH1750_ERROR;
  34. }
  35. BH1750_STATUS bh1750_set_power_state(uint8_t PowerOn) {
  36. PowerOn = (PowerOn ? 1 : 0);
  37. bool status;
  38. furi_hal_i2c_acquire(I2C_BUS);
  39. status = furi_hal_i2c_tx(I2C_BUS, BH1750_ADDRESS, &PowerOn, 1, I2C_TIMEOUT);
  40. furi_hal_i2c_release(I2C_BUS);
  41. if(status) {
  42. return BH1750_OK;
  43. }
  44. return BH1750_ERROR;
  45. }
  46. BH1750_STATUS bh1750_set_mode(BH1750_mode mode) {
  47. if(!((mode >> 4) || (mode >> 5))) {
  48. return BH1750_ERROR;
  49. }
  50. if((mode & 0x0F) > 3) {
  51. return BH1750_ERROR;
  52. }
  53. bool status;
  54. bh1750_mode = mode;
  55. furi_hal_i2c_acquire(I2C_BUS);
  56. status = furi_hal_i2c_tx(I2C_BUS, BH1750_ADDRESS, &mode, 1, I2C_TIMEOUT);
  57. furi_hal_i2c_release(I2C_BUS);
  58. if(status) {
  59. return BH1750_OK;
  60. }
  61. return BH1750_ERROR;
  62. }
  63. BH1750_STATUS bh1750_set_mt_reg(uint8_t mt_reg) {
  64. if(mt_reg < 31 || mt_reg > 254) {
  65. return BH1750_ERROR;
  66. }
  67. bh1750_mt_reg = mt_reg;
  68. uint8_t tmp[2];
  69. bool status;
  70. tmp[0] = (0x40 | (mt_reg >> 5));
  71. tmp[1] = (0x60 | (mt_reg & 0x1F));
  72. furi_hal_i2c_acquire(I2C_BUS);
  73. status = furi_hal_i2c_tx(I2C_BUS, BH1750_ADDRESS, &tmp[0], 1, I2C_TIMEOUT);
  74. furi_hal_i2c_release(I2C_BUS);
  75. if(!status) {
  76. return BH1750_ERROR;
  77. }
  78. furi_hal_i2c_acquire(I2C_BUS);
  79. status = furi_hal_i2c_tx(I2C_BUS, BH1750_ADDRESS, &tmp[1], 1, I2C_TIMEOUT);
  80. furi_hal_i2c_release(I2C_BUS);
  81. if(status) {
  82. return BH1750_OK;
  83. }
  84. return BH1750_ERROR;
  85. }
  86. BH1750_STATUS bh1750_trigger_manual_conversion() {
  87. if(BH1750_OK == bh1750_set_mode(bh1750_mode)) {
  88. return BH1750_OK;
  89. }
  90. return BH1750_ERROR;
  91. }
  92. BH1750_STATUS bh1750_read_light(float* result) {
  93. float result_tmp;
  94. uint8_t rcv[2];
  95. bool status;
  96. furi_hal_i2c_acquire(I2C_BUS);
  97. status = furi_hal_i2c_rx(I2C_BUS, BH1750_ADDRESS, rcv, 2, I2C_TIMEOUT);
  98. furi_hal_i2c_release(I2C_BUS);
  99. if(status) {
  100. result_tmp = (rcv[0] << 8) | (rcv[1]);
  101. if(bh1750_mt_reg != BH1750_DEFAULT_MTREG) {
  102. result_tmp *= (float)((uint8_t)BH1750_DEFAULT_MTREG / (float)bh1750_mt_reg);
  103. }
  104. if(bh1750_mode == ONETIME_HIGH_RES_MODE_2 || bh1750_mode == CONTINUOUS_HIGH_RES_MODE_2) {
  105. result_tmp /= 2.0;
  106. }
  107. *result = result_tmp / BH1750_CONVERSION_FACTOR;
  108. return BH1750_OK;
  109. }
  110. return BH1750_ERROR;
  111. }