diff options
author | Joey Castillo <joeycastillo@utexas.edu> | 2021-11-30 18:53:43 -0500 |
---|---|---|
committer | Joey Castillo <joeycastillo@utexas.edu> | 2021-11-30 19:33:49 -0500 |
commit | 4ae46f907b2c6f54f87c350920d7f297967764fe (patch) | |
tree | e2bade8481a37f6e04692f3ceef6d760d2a812e1 | |
parent | 48ceef7af3771ca3b175b217bb26398a3214794a (diff) | |
download | Sensor-Watch-4ae46f907b2c6f54f87c350920d7f297967764fe.tar.gz Sensor-Watch-4ae46f907b2c6f54f87c350920d7f297967764fe.tar.bz2 Sensor-Watch-4ae46f907b2c6f54f87c350920d7f297967764fe.zip |
lis2dh driver: add basic interrupt functionality
-rw-r--r-- | apps/Sensor Watch Accelerometer Test/app.c | 65 | ||||
-rw-r--r-- | watch-library/driver/lis2dh.c | 11 | ||||
-rw-r--r-- | watch-library/driver/lis2dh.h | 27 |
3 files changed, 67 insertions, 36 deletions
diff --git a/apps/Sensor Watch Accelerometer Test/app.c b/apps/Sensor Watch Accelerometer Test/app.c index 9ad0d56f..6a4c9e3a 100644 --- a/apps/Sensor Watch Accelerometer Test/app.c +++ b/apps/Sensor Watch Accelerometer Test/app.c @@ -11,18 +11,28 @@ // Also note that this board has its INT1 pin wired to A1, which is not an external // wake pin. Future accelerometer boards will wire interrupt pins to A2 and A4. -uint8_t axis = 0; - void cb_light_pressed() { - axis = 1; } void cb_mode_pressed() { - axis = 2; } void cb_alarm_pressed() { - axis = 3; +} + +uint16_t interrupts = 0; +uint16_t ticks = 0; + +void cb_interrupt_1() { + interrupts++; +} + +void cb_tick() { + if (++ticks == 30) { + interrupts = 0; + ticks = 0; + watch_display_string("IN t 0", 0); + } } void app_init() { @@ -31,6 +41,7 @@ void app_init() { gpio_set_pin_level(A0, true); watch_enable_display(); + watch_display_string("IN 0 0", 0); watch_enable_external_interrupts(); watch_register_interrupt_callback(BTN_MODE, cb_mode_pressed, INTERRUPT_TRIGGER_RISING); @@ -40,9 +51,15 @@ void app_init() { watch_enable_i2c(); lis2dh_begin(); - - lis2dh_set_range(LIS2DH_RANGE_2_G); lis2dh_set_data_rate(LIS2DH_DATA_RATE_10_HZ); + lis2dh_configure_aoi_int1( + LIS2DH_INTERRUPT_CONFIGURATION_OR | + LIS2DH_INTERRUPT_CONFIGURATION_X_HIGH_ENABLE | + LIS2DH_INTERRUPT_CONFIGURATION_Y_HIGH_ENABLE | + LIS2DH_INTERRUPT_CONFIGURATION_Z_HIGH_ENABLE, 96, 0); + + watch_register_interrupt_callback(A1, cb_interrupt_1, INTERRUPT_TRIGGER_RISING); + watch_rtc_register_tick_callback(cb_tick); } void app_wake_from_backup() { @@ -58,34 +75,10 @@ void app_wake_from_standby() { } bool app_loop() { - if (lis2dh_have_new_data()) { - lis2dh_reading reading; - lis2dh_acceleration_measurement measurement = lis2dh_get_acceleration_measurement(&reading); - - // printf("%d,%d,%d\n", reading.x, reading.y, reading.z); - printf("%f,%f,%f\n", measurement.x, measurement.y, measurement.z); - - char buf[11] = {0}; - switch (axis) { - case 1: - sprintf(buf, "AC X%-6d", reading.x); - break; - case 2: - sprintf(buf, "AC Y%-6d", reading.y); - break; - case 3: - sprintf(buf, "AC Z%-6d", reading.z); - break; - default: - sprintf(buf, " %2d%2d%2d", abs(reading.x >> 9), abs(reading.y >> 9), abs(reading.z >> 9)); - if (reading.x < 0) buf[0] = '_'; - if (reading.y < 0) buf[1] = '_'; - if (reading.z < 0) buf[3] = '_'; - break; - } - - watch_display_string(buf, 0); - } + char buf[13] = {0}; + + sprintf(buf, "IN%2d%4d", ticks, interrupts); + watch_display_string(buf, 0); - return false; + return true; } diff --git a/watch-library/driver/lis2dh.c b/watch-library/driver/lis2dh.c index 2593fc69..2ebf53fb 100644 --- a/watch-library/driver/lis2dh.c +++ b/watch-library/driver/lis2dh.c @@ -114,3 +114,14 @@ void lis2dh_set_data_rate(lis2dh_data_rate_t dataRate) { lis2dh_data_rate_t lis2dh_get_data_rate() { return watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL1) >> 4; } + +void lis2dh_configure_aoi_int1(lis2dh_interrupt_configuration configuration, uint8_t threshold, uint8_t duration) { + watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_CTRL3, LIS2DH_CTRL3_VAL_I1_AOI1); + watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_INT1_CFG, configuration); + watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_INT1_THS, threshold); + watch_i2c_write8(LIS2DH_ADDRESS, LIS2DH_REG_INT1_DUR, duration); +} + +lis2dh_interrupt_state lis2dh_get_int1_state() { + return (lis2dh_interrupt_state) watch_i2c_read8(LIS2DH_ADDRESS, LIS2DH_REG_INT1_SRC); +} diff --git a/watch-library/driver/lis2dh.h b/watch-library/driver/lis2dh.h index 57ea85ee..b8162a4c 100644 --- a/watch-library/driver/lis2dh.h +++ b/watch-library/driver/lis2dh.h @@ -61,6 +61,29 @@ typedef enum { } lis2dh_data_rate_t; +typedef enum { + LIS2DH_INTERRUPT_CONFIGURATION_OR = 0b00000000, + LIS2DH_INTERRUPT_CONFIGURATION_AND = 0b10000000, + LIS2DH_INTERRUPT_CONFIGURATION_6D_MOVEMENT = 0b01000000, + LIS2DH_INTERRUPT_CONFIGURATION_6D_POSITION = 0b11000000, // in 6D mode, these have an alternate meaning: + LIS2DH_INTERRUPT_CONFIGURATION_Z_HIGH_ENABLE = 0b00100000, // Z up enable + LIS2DH_INTERRUPT_CONFIGURATION_Z_LOW_ENABLE = 0b00010000, // Z down enable + LIS2DH_INTERRUPT_CONFIGURATION_Y_HIGH_ENABLE = 0b00001000, // Y up enable + LIS2DH_INTERRUPT_CONFIGURATION_Y_LOW_ENABLE = 0b00000100, // Y down enable + LIS2DH_INTERRUPT_CONFIGURATION_X_HIGH_ENABLE = 0b00000010, // X up enable + LIS2DH_INTERRUPT_CONFIGURATION_X_LOW_ENABLE = 0b00000001, // X down enable +} lis2dh_interrupt_configuration; + +typedef enum { + LIS2DH_INTERRUPT_STATE_ACTIVE = 0b01000000, + LIS2DH_INTERRUPT_STATE_Z_HIGH = 0b00100000, // Z up + LIS2DH_INTERRUPT_STATE_Z_LOW = 0b00010000, // Z down + LIS2DH_INTERRUPT_STATE_Y_HIGH = 0b00001000, // Y up + LIS2DH_INTERRUPT_STATE_Y_LOW = 0b00000100, // Y down + LIS2DH_INTERRUPT_STATE_X_HIGH = 0b00000010, // X up + LIS2DH_INTERRUPT_STATE_X_LOW = 0b00000001, // X down +} lis2dh_interrupt_state; + bool lis2dh_begin(); uint8_t lis2dh_get_device_id(); @@ -79,6 +102,10 @@ void lis2dh_set_data_rate(lis2dh_data_rate_t dataRate); lis2dh_data_rate_t lis2dh_get_data_rate(); +void lis2dh_configure_aoi_int1(lis2dh_interrupt_configuration configuration, uint8_t threshold, uint8_t duration); + +lis2dh_interrupt_state lis2dh_get_int1_state(); + // Assumes SA0 is high; if low, its 0x18 #define LIS2DH_ADDRESS (0x19) |