2011-04-01 18:23:35 +00:00
|
|
|
/**
|
|
|
|
* This is most complex and difficult device.
|
|
|
|
* It realize "read through write" paradigm. This is not standard, but
|
|
|
|
* most of I2C devices use this paradigm.
|
|
|
|
* You must write to device reading address, send restart to bus,
|
|
|
|
* and then begin reading process.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "ch.h"
|
|
|
|
#include "hal.h"
|
|
|
|
|
|
|
|
#include "lis3.h"
|
|
|
|
|
|
|
|
|
2011-08-05 17:24:23 +00:00
|
|
|
#define lis3_addr 0b0011101
|
|
|
|
|
|
|
|
|
2011-06-24 10:36:41 +00:00
|
|
|
/* buffers */
|
2011-12-06 09:09:53 +00:00
|
|
|
static uint8_t accel_rx_data[ACCEL_RX_DEPTH];
|
|
|
|
static uint8_t accel_tx_data[ACCEL_TX_DEPTH];
|
2011-04-01 18:23:35 +00:00
|
|
|
|
2011-08-05 17:24:23 +00:00
|
|
|
static int16_t acceleration_x = 0;
|
|
|
|
static int16_t acceleration_y = 0;
|
|
|
|
static int16_t acceleration_z = 0;
|
|
|
|
|
2011-04-01 18:23:35 +00:00
|
|
|
/* Error trap */
|
2011-06-22 08:38:54 +00:00
|
|
|
static void i2c_lis3_error_cb(I2CDriver *i2cp, const I2CSlaveConfig *i2cscfg){
|
2011-04-01 18:23:35 +00:00
|
|
|
(void)i2cscfg;
|
|
|
|
int status = 0;
|
|
|
|
status = i2cp->id_i2c->SR1;
|
|
|
|
while(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This callback raise up when transfer finished */
|
2011-06-22 08:38:54 +00:00
|
|
|
static void i2c_lis3_cb(I2CDriver *i2cp, const I2CSlaveConfig *i2cscfg){
|
2011-08-05 17:24:23 +00:00
|
|
|
(void)i2cp;
|
|
|
|
(void)i2cscfg;
|
2011-04-01 18:23:35 +00:00
|
|
|
}
|
|
|
|
|
2011-06-21 20:17:14 +00:00
|
|
|
|
2011-06-24 10:36:41 +00:00
|
|
|
/* Accelerometer lis3lv02dq config */
|
2011-06-21 20:17:14 +00:00
|
|
|
static const I2CSlaveConfig lis3 = {
|
2011-12-06 09:09:53 +00:00
|
|
|
i2c_lis3_cb,
|
|
|
|
i2c_lis3_error_cb,
|
2011-06-21 20:17:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-04-01 18:23:35 +00:00
|
|
|
/**
|
|
|
|
* Init function. Here we will also start personal serving thread.
|
|
|
|
*/
|
|
|
|
int init_lis3(void){
|
2011-06-17 07:10:30 +00:00
|
|
|
/* configure accelerometer */
|
2011-07-03 18:02:55 +00:00
|
|
|
accel_tx_data[0] = ACCEL_CTRL_REG1 | AUTO_INCREMENT_BIT; /* register address */
|
|
|
|
accel_tx_data[1] = 0b11100111;
|
|
|
|
accel_tx_data[2] = 0b01000001;
|
|
|
|
accel_tx_data[3] = 0b00000000;
|
2011-04-01 18:23:35 +00:00
|
|
|
|
|
|
|
/* sending */
|
2011-08-05 17:24:23 +00:00
|
|
|
i2cMasterTransmit(&I2CD1, &lis3, lis3_addr, accel_tx_data, 4, accel_rx_data, 0);
|
2011-04-01 18:23:35 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void request_acceleration_data(void){
|
2011-07-03 18:02:55 +00:00
|
|
|
accel_tx_data[0] = ACCEL_OUT_DATA | AUTO_INCREMENT_BIT; // register address
|
2011-12-06 09:09:53 +00:00
|
|
|
i2cAcquireBus(&I2CD1);
|
2011-08-05 17:24:23 +00:00
|
|
|
i2cMasterTransmit(&I2CD1, &lis3, lis3_addr, accel_tx_data, 1, accel_rx_data, 6);
|
2011-12-06 09:09:53 +00:00
|
|
|
i2cReleaseBus(&I2CD1);
|
2011-08-05 17:24:23 +00:00
|
|
|
|
|
|
|
acceleration_x = accel_rx_data[0] + (accel_rx_data[1] << 8);
|
|
|
|
acceleration_y = accel_rx_data[2] + (accel_rx_data[3] << 8);
|
|
|
|
acceleration_z = accel_rx_data[4] + (accel_rx_data[5] << 8);
|
2011-04-01 18:23:35 +00:00
|
|
|
}
|
|
|
|
|