lis3dh/main.c

118 lines
2.9 KiB
C
Raw Normal View History

2023-12-21 20:52:17 +00:00
#define _GNU_SOURCE
2023-12-21 18:17:20 +00:00
#include <stdio.h>
2023-12-23 13:31:59 +00:00
#include <stdlib.h>
2023-12-21 20:52:17 +00:00
#include <unistd.h>
2023-12-21 23:29:22 +00:00
#include <math.h>
2023-12-21 18:17:20 +00:00
#include "lis3dh.h"
2023-12-28 18:10:34 +00:00
#include "interrupt.h"
2023-12-21 20:52:17 +00:00
#include "i2c.h"
2023-12-21 18:17:20 +00:00
2023-12-30 13:10:40 +00:00
#define GPIO_INTERRUPT_PIN_INT1 12
#define GPIO_INTERRUPT_PIN_INT2 16
2023-12-28 18:10:34 +00:00
2023-12-23 13:31:59 +00:00
/* calc magnitude of accel [x y z] vector */
2023-12-29 23:24:15 +00:00
static float mag(float x, float y, float z) {
2023-12-23 10:28:43 +00:00
return sqrt( powf(x, 2) + powf(y, 2) + powf(z, 2) );
2023-12-21 23:29:22 +00:00
}
2023-12-23 13:31:59 +00:00
/* print message then exit */
2023-12-29 23:24:15 +00:00
static void quit(const char *msg, lis3dh_t *lis) {
2023-12-23 13:31:59 +00:00
lis->dev.deinit();
fprintf(stderr, "%s\n", msg);
exit(1);
}
2023-12-21 18:17:20 +00:00
int main() {
lis3dh_t lis;
2023-12-23 10:28:43 +00:00
struct lis3dh_fifo_data fifo;
2023-12-29 23:24:15 +00:00
int i, k;
2023-12-21 18:17:20 +00:00
2023-12-23 13:31:59 +00:00
/* set fn ptrs to rw on bus (i2c or SPI) */
2023-12-21 20:52:17 +00:00
lis.dev.init = i2c_init;
lis.dev.read = i2c_read;
lis.dev.write = i2c_write;
lis.dev.sleep = usleep;
lis.dev.deinit = i2c_deinit;
/* initialise LIS3DH struct */
2023-12-22 08:26:10 +00:00
if (lis3dh_init(&lis)) {
2023-12-23 13:31:59 +00:00
quit("init()", &lis);
2023-12-21 23:29:22 +00:00
}
/* reset device because it sometimes corrupts itself */
if (lis3dh_reset(&lis)) {
quit("reset()", &lis);
}
2023-12-28 18:10:34 +00:00
/* register interrupt */
2023-12-30 13:10:40 +00:00
if (int_register(GPIO_INTERRUPT_PIN_INT1)) {
2023-12-28 18:10:34 +00:00
quit("int_register()", &lis);
}
2023-12-23 13:31:59 +00:00
/* set up config */
2023-12-27 19:54:47 +00:00
lis.cfg.mode = LIS3DH_MODE_NORMAL;
2023-12-23 10:28:43 +00:00
lis.cfg.range = LIS3DH_FS_2G;
lis.cfg.rate = LIS3DH_ODR_100_HZ;
2023-12-22 21:59:31 +00:00
lis.cfg.fifo.mode = LIS3DH_FIFO_MODE_STREAM;
2023-12-30 13:10:40 +00:00
lis.cfg.fifo.trig = LIS3DH_FIFO_TRIG_INT2;
2023-12-31 14:14:12 +00:00
lis.cfg.pin1.wtm = 1;
lis.cfg.pin1.latch = 1;
2023-12-30 13:10:40 +00:00
lis.cfg.filter.mode = LIS3DH_FILTER_MODE_AUTORESET;
2023-12-29 23:24:15 +00:00
lis.cfg.filter.cutoff = LIS3DH_FILTER_CUTOFF_8;
2023-12-21 23:29:22 +00:00
2023-12-31 15:24:40 +00:00
lis.cfg.en_adc = 1;
2023-12-31 15:41:24 +00:00
lis.cfg.en_temp = 1;
2023-12-31 15:24:40 +00:00
2023-12-23 13:31:59 +00:00
/* write device config */
2023-12-22 08:26:10 +00:00
if (lis3dh_configure(&lis)) {
2023-12-23 13:31:59 +00:00
quit("configure()", &lis);
2023-12-21 18:17:20 +00:00
}
2023-12-23 10:28:43 +00:00
2023-12-29 23:24:15 +00:00
for(i=0; i<50; i++) {
2023-12-31 15:24:40 +00:00
/* wait for interrupt from LIS3DH */
2023-12-30 13:10:40 +00:00
if (int_poll(GPIO_INTERRUPT_PIN_INT1)) {
2023-12-29 23:24:15 +00:00
quit("int_poll()", &lis);
}
2023-12-31 15:24:40 +00:00
/* clear latched interrupt on INT1 */
2023-12-29 23:24:15 +00:00
if (lis3dh_clear_int1(&lis)) {
quit("clear_int1()", &lis);
}
/* read stored fifo data into `fifo' struct */
if (lis3dh_read_fifo(&lis, &fifo)) {
quit("read_fifo()", &lis);
}
2023-12-31 15:24:40 +00:00
/* read ADCs */
if (lis3dh_read_adc(&lis)) {
quit("read_adc()", &lis);
}
2023-12-31 15:41:24 +00:00
/* read temp from ADC3 and overwrite local ADC reading for ADC3 */
if (lis3dh_read_temp(&lis)) {
quit("read_temp()", &lis);
}
2023-12-29 23:24:15 +00:00
for(k=0; k<fifo.size; k++) {
2023-12-31 15:24:40 +00:00
printf("x: %04.04f y: %04.04f z: %04.04f mag: %04.04f ADC1:%.1f, ADC2:%.1f, ADC3:%.1f\n",
2023-12-29 23:24:15 +00:00
fifo.x[k], fifo.y[k], fifo.z[k],
2023-12-31 15:24:40 +00:00
mag(fifo.x[k], fifo.y[k], fifo.z[k]),
lis.adc.adc1, lis.adc.adc2, lis.adc.adc3);
2023-12-29 23:24:15 +00:00
}
2023-12-28 18:10:34 +00:00
}
/* unregister interrupt */
2023-12-30 13:10:40 +00:00
if (int_unregister(GPIO_INTERRUPT_PIN_INT1)) {
2023-12-28 18:10:34 +00:00
quit("int_unregister()", &lis);
2023-12-23 13:31:59 +00:00
}
/* deinitalise struct */
2023-12-22 08:26:10 +00:00
if (lis3dh_deinit(&lis)) {
2023-12-23 13:31:59 +00:00
quit("deinit()", &lis);
2023-12-21 18:17:20 +00:00
}
return 0;
}