diff options
author | barthess <barthess@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2014-10-12 17:11:10 +0000 |
---|---|---|
committer | barthess <barthess@35acf78f-673a-0410-8e92-d51de3d6d3f4> | 2014-10-12 17:11:10 +0000 |
commit | 6dde2094a0c5334e69970d4ea3c7326139b441cb (patch) | |
tree | f3db0cf0024e3600126738de7d4f2a5e8f1dd5f0 /testhal/STM32/STM32F1xx/I2C/lis3.c | |
parent | 1c2959452edc9504b4fb91ae0dc3c621c185c95e (diff) | |
download | ChibiOS-6dde2094a0c5334e69970d4ea3c7326139b441cb.tar.gz ChibiOS-6dde2094a0c5334e69970d4ea3c7326139b441cb.tar.bz2 ChibiOS-6dde2094a0c5334e69970d4ea3c7326139b441cb.zip |
Added I2C testhal application for STM32F1xx
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@7389 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'testhal/STM32/STM32F1xx/I2C/lis3.c')
-rw-r--r-- | testhal/STM32/STM32F1xx/I2C/lis3.c | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/testhal/STM32/STM32F1xx/I2C/lis3.c b/testhal/STM32/STM32F1xx/I2C/lis3.c new file mode 100644 index 000000000..6a1c79164 --- /dev/null +++ b/testhal/STM32/STM32F1xx/I2C/lis3.c @@ -0,0 +1,92 @@ +/*
+ ChibiOS/RT - Copyright (C) 2006-2013 Giovanni Di Sirio
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ * This is device 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"
+
+#define addr 0b0011101
+
+/* autoincrement bit position. This bit needs to perform reading of
+ * multiple bytes at one request */
+#define AUTO_INCREMENT_BIT (1<<7)
+
+/* slave specific addresses */
+#define ACCEL_STATUS_REG 0x27
+#define ACCEL_CTRL_REG1 0x20
+#define ACCEL_OUT_DATA 0x28
+
+/* buffers */
+static uint8_t accel_rx_data[8];
+static uint8_t accel_tx_data[8];
+
+/*
+ *
+ */
+void lis3Start(void){
+ msg_t status = MSG_OK;
+ systime_t tmo = MS2ST(4);
+
+ /* configure accelerometer */
+ accel_tx_data[0] = ACCEL_CTRL_REG1 | AUTO_INCREMENT_BIT;
+ accel_tx_data[1] = 0b11100111;
+ accel_tx_data[2] = 0b01000001;
+ accel_tx_data[3] = 0b00000000;
+
+ /* sending */
+ i2cAcquireBus(&I2CD1);
+ status = i2cMasterTransmitTimeout(&I2CD1, addr,
+ accel_tx_data, 4, accel_rx_data, 0, tmo);
+ i2cReleaseBus(&I2CD1);
+
+ osalDbgCheck(MSG_OK == status);
+}
+
+/*
+ *
+ */
+#include <math.h>
+void lis3GetAcc(float *result) {
+ msg_t status = MSG_OK;
+ systime_t tmo = MS2ST(4);
+ size_t i = 0;
+ int16_t tmp;
+
+ accel_tx_data[0] = ACCEL_OUT_DATA | AUTO_INCREMENT_BIT;
+ i2cAcquireBus(&I2CD1);
+ status = i2cMasterTransmitTimeout(&I2CD1, addr,
+ accel_tx_data, 1, accel_rx_data, 6, tmo);
+ i2cReleaseBus(&I2CD1);
+
+ osalDbgCheck(MSG_OK == status);
+
+ for (i=0; i<3; i++){
+ tmp = accel_rx_data[i*2] + (accel_rx_data[i*2+1] << 8);
+ result[i] = tmp;
+ result[i] /= 16384; /* convert raw value to G */
+ }
+}
+
|