From b927b5de01d213d3db8a2d3baf0b8a5907c54a30 Mon Sep 17 00:00:00 2001
From: fleur <spacecarrot@fleurshax.net>
Date: Sun, 25 Aug 2019 09:28:13 +0000
Subject: [PATCH] feat(light-sensor): Add API-call for direct readout

---
 epicardium/epicardium.h           | 9 +++++++++
 epicardium/modules/light_sensor.c | 7 +++++++
 pycardium/modules/light_sensor.c  | 9 ++++++++-
 pycardium/modules/qstrdefs.h      | 1 +
 4 files changed, 25 insertions(+), 1 deletion(-)

diff --git a/epicardium/epicardium.h b/epicardium/epicardium.h
index 74b0c814..ff910c39 100644
--- a/epicardium/epicardium.h
+++ b/epicardium/epicardium.h
@@ -102,6 +102,7 @@ typedef _Bool bool;
 #define API_LIGHT_SENSOR_RUN       0x80
 #define API_LIGHT_SENSOR_GET       0x81
 #define API_LIGHT_SENSOR_STOP      0x82
+#define API_LIGHT_SENSOR_READ	   0x83
 
 #define API_BUTTONS_READ           0x90
 
@@ -1399,6 +1400,14 @@ API(API_LIGHT_SENSOR_GET, int epic_light_sensor_get(uint16_t* value));
  */
 API(API_LIGHT_SENSOR_STOP, int epic_light_sensor_stop());
 
+/**
+ * Get the light level directly. Each call has an intrinsic delay of about 240us, I recommend another 100-300us delay via utime.sleep_ms() between calls. Whether or not the IR LED is fast enough is another issue.
+ *
+ * :return: Light level
+ */
+API(API_LIGHT_SENSOR_READ, uint16_t epic_light_sensor_read(void));
+
+
 /**
  * File
  * ====
diff --git a/epicardium/modules/light_sensor.c b/epicardium/modules/light_sensor.c
index ff2cd81c..3f3573f1 100644
--- a/epicardium/modules/light_sensor.c
+++ b/epicardium/modules/light_sensor.c
@@ -27,6 +27,13 @@ static int light_sensor_init()
 	return 0;
 }
 
+uint16_t epic_light_sensor_read()
+{
+	ADC_StartConvert(ADC_CH_7, 0, 0);
+	ADC_GetData(&last_value);
+	return last_value;
+}
+
 static void readAdcCallback()
 {
 	if (hwlock_acquire(HWLOCK_ADC, 0) != 0) {
diff --git a/pycardium/modules/light_sensor.c b/pycardium/modules/light_sensor.c
index ce8343aa..a27791de 100644
--- a/pycardium/modules/light_sensor.c
+++ b/pycardium/modules/light_sensor.c
@@ -42,11 +42,18 @@ static mp_obj_t mp_light_sensor_stop()
 }
 static MP_DEFINE_CONST_FUN_OBJ_0(light_sensor_stop_obj, mp_light_sensor_stop);
 
+static mp_obj_t mp_light_sensor_read()
+{
+	return mp_obj_new_int_from_uint(epic_light_sensor_read());
+}
+static MP_DEFINE_CONST_FUN_OBJ_0(light_sensor_read_obj, mp_light_sensor_read);
+
 static const mp_rom_map_elem_t light_sensor_module_globals_table[] = {
 	{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_light_sensor) },
 	{ MP_ROM_QSTR(MP_QSTR_start), MP_ROM_PTR(&light_sensor_start_obj) },
 	{ MP_ROM_QSTR(MP_QSTR_stop), MP_ROM_PTR(&light_sensor_stop_obj) },
-	{ MP_ROM_QSTR(MP_QSTR_get_reading), MP_ROM_PTR(&light_sensor_get_obj) }
+	{ MP_ROM_QSTR(MP_QSTR_get_reading), MP_ROM_PTR(&light_sensor_get_obj) },
+	{ MP_ROM_QSTR(MP_QSTR_read), MP_ROM_PTR(&light_sensor_read_obj) },
 };
 static MP_DEFINE_CONST_DICT(
 	light_sensor_module_globals, light_sensor_module_globals_table
diff --git a/pycardium/modules/qstrdefs.h b/pycardium/modules/qstrdefs.h
index 095f9898..a02bcbd8 100644
--- a/pycardium/modules/qstrdefs.h
+++ b/pycardium/modules/qstrdefs.h
@@ -97,6 +97,7 @@ Q(light_sensor)
 Q(start)
 Q(get_reading)
 Q(stop)
+Q(read)
 
 /* bme680 */
 Q(bme680)
-- 
GitLab