summaryrefslogtreecommitdiff
path: root/src/driver
diff options
context:
space:
mode:
authorDaniel Friesel <derf@finalrewind.org>2021-12-27 14:54:01 +0100
committerDaniel Friesel <derf@finalrewind.org>2021-12-27 14:54:01 +0100
commit53de8b4b7ae2c99d16ebe43876368c2d51a791e2 (patch)
tree4b09775a80d4d56d1e40d19d38ed3a7557295ba6 /src/driver
parent095e405c93ccdb6f8a358697f68a394ce1654999 (diff)
add VEML6075 driver
Diffstat (limited to 'src/driver')
-rw-r--r--src/driver/Kconfig4
-rw-r--r--src/driver/veml6075.cc82
2 files changed, 86 insertions, 0 deletions
diff --git a/src/driver/Kconfig b/src/driver/Kconfig
index 4b3693c..3ff88e7 100644
--- a/src/driver/Kconfig
+++ b/src/driver/Kconfig
@@ -95,6 +95,10 @@ config driver_scd4x
bool "Sensirion SCD4x CO2 Sensor"
depends on meta_driver_i2c
+config driver_veml6075
+bool "VEML6075 UV Sensor"
+depends on meta_driver_i2c
+
config driver_sharp96
bool "sharp LS013B4DN 96x96px Transflective LC Display"
depends on ( arch_msp430fr5969lp || arch_msp430fr5994lp ) && meta_driver_spi
diff --git a/src/driver/veml6075.cc b/src/driver/veml6075.cc
new file mode 100644
index 0000000..a3e41f6
--- /dev/null
+++ b/src/driver/veml6075.cc
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2020 Daniel Friesel
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ *
+ * Driver for VEML6075 Ambient Light Sensor.
+ */
+#include "driver/veml6075.h"
+#if defined(CONFIG_meta_driver_hardware_i2c)
+#include "driver/i2c.h"
+#elif defined(CONFIG_driver_softi2c)
+#include "driver/soft_i2c.h"
+#endif
+
+bool VEML6075::init()
+{
+ txbuf[0] = 0x00;
+ txbuf[1] = 0x00; // 50ms integration time, normal dynamic
+ if (i2c.xmit(address, 2, txbuf, 0, rxbuf) != 0) {
+ return false;
+ }
+ return true;
+}
+
+bool VEML6075::readUVCounts(float *uva, float *uvb)
+{
+ uint16_t uva_counts, uvb_counts, comp_visible, comp_ir;
+ txbuf[0] = 0x07;
+ if (i2c.xmit(address, 2, txbuf, 2, rxbuf) != 0) {
+ return false;
+ }
+ uva_counts = ((uint16_t)rxbuf[1] << 8) + rxbuf[0];
+
+ txbuf[0] = 0x09;
+ if (i2c.xmit(address, 2, txbuf, 2, rxbuf) != 0) {
+ return false;
+ }
+ uvb_counts = ((uint16_t)rxbuf[1] << 8) + rxbuf[0];
+
+ txbuf[0] = 0x0a;
+ if (i2c.xmit(address, 2, txbuf, 2, rxbuf) != 0) {
+ return false;
+ }
+ comp_visible = ((uint16_t)rxbuf[1] << 8) + rxbuf[0];
+
+ txbuf[0] = 0x0b;
+ if (i2c.xmit(address, 2, txbuf, 2, rxbuf) != 0) {
+ return false;
+ }
+ comp_ir = ((uint16_t)rxbuf[1] << 8) + rxbuf[0];
+
+ *uva = uva_counts - uva_a_coef * comp_visible - uva_b_coef * comp_ir;
+ *uvb = uvb_counts - uvb_c_coef * comp_visible - uvb_d_coef * comp_ir;
+
+ return true;
+}
+
+bool VEML6075::readUV(float *uva, float *uvb)
+{
+ float uva_counts, uvb_counts;
+ if (!readUVCounts(&uva_counts, &uvb_counts)) {
+ return false;
+ }
+
+ *uva = uva_counts * uva_counts_per_uwcm2;
+ *uvb = uvb_counts * uvb_counts_per_uwcm2;
+ return true;
+}
+
+bool VEML6075::readUVI(float *uva, float *uvb)
+{
+ float uva_counts, uvb_counts;
+ if (!readUVCounts(&uva_counts, &uvb_counts)) {
+ return false;
+ }
+
+ *uva = uva_counts * uva_uvi_response;
+ *uvb = uvb_counts * uvb_uvi_response;
+ return true;
+}
+
+VEML6075 veml6075(0x10);