Loading...
Searching...
No Matches
mma8x5x.h
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2014 PHYTEC Messtechnik GmbH
3 * SPDX-FileCopyrightText: 2016 Freie Universität Berlin
4 * SPDX-License-Identifier: LGPL-2.1-only
5 */
6
7#pragma once
8
31
32#include <stdint.h>
33#include "periph/i2c.h"
34
35#ifdef __cplusplus
36extern "C" {
37#endif
38
50#ifndef CONFIG_MMA8X5X_I2C_ADDRESS
51#define CONFIG_MMA8X5X_I2C_ADDRESS 0x1D
52#endif
54
58enum {
64};
65
69enum {
70 MMA8X5X_RATE_800HZ = (0 << 3),
71 MMA8X5X_RATE_400HZ = (1 << 3),
72 MMA8X5X_RATE_200HZ = (2 << 3),
73 MMA8X5X_RATE_100HZ = (3 << 3),
74 MMA8X5X_RATE_50HZ = (4 << 3),
75 MMA8X5X_RATE_1HZ25 = (5 << 3),
76 MMA8X5X_RATE_6HZ25 = (6 << 3),
78};
79
83enum {
87};
88
92enum {
98};
99
103typedef struct {
105 uint8_t addr;
106 uint8_t rate;
107 uint8_t range;
108 uint8_t offset[3];
110
114typedef struct {
116} mma8x5x_t;
117
121typedef struct {
122 int16_t x;
123 int16_t y;
124 int16_t z;
126
137int mma8x5x_init(mma8x5x_t *dev, const mma8x5x_params_t *params);
138
149void mma8x5x_set_user_offset(const mma8x5x_t *dev, int8_t x, int8_t y, int8_t z);
150
157
164
174
189void mma8x5x_read(const mma8x5x_t *dev, mma8x5x_data_t *data);
190
202void mma8x5x_set_motiondetect(const mma8x5x_t *dev, uint8_t int_pin, uint8_t threshold);
203
215void mma8x5x_ack_int(const mma8x5x_t *dev);
216
217#ifdef __cplusplus
218}
219#endif
220
void mma8x5x_set_user_offset(const mma8x5x_t *dev, int8_t x, int8_t y, int8_t z)
Set user offset correction.
int mma8x5x_init(mma8x5x_t *dev, const mma8x5x_params_t *params)
Initialize the MMA8x5x accelerometer driver.
void mma8x5x_ack_int(const mma8x5x_t *dev)
Acknowledge motion detection interrupt.
void mma8x5x_set_active(const mma8x5x_t *dev)
Set active mode, this enables periodic measurements.
void mma8x5x_set_standby(const mma8x5x_t *dev)
Set standby mode.
void mma8x5x_set_motiondetect(const mma8x5x_t *dev, uint8_t int_pin, uint8_t threshold)
Configure motion detection interrupt.
int mma8x5x_is_ready(const mma8x5x_t *dev)
Check for new set of measurement data.
void mma8x5x_read(const mma8x5x_t *dev, mma8x5x_data_t *data)
Read accelerometer's data.
@ MMA8X5X_NOI2C
I2C communication failed.
Definition mma8x5x.h:95
@ MMA8X5X_NODATA
no data available
Definition mma8x5x.h:97
@ MMA8X5X_DATA_READY
new data ready to be read
Definition mma8x5x.h:94
@ MMA8X5X_OK
everything was fine
Definition mma8x5x.h:93
@ MMA8X5X_NODEV
no MMA8X5X device found on the bus
Definition mma8x5x.h:96
@ MMA8X5X_RATE_800HZ
800 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:70
@ MMA8X5X_RATE_200HZ
200 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:72
@ MMA8X5X_RATE_100HZ
100 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:73
@ MMA8X5X_RATE_1HZ25
12.5 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:75
@ MMA8X5X_RATE_400HZ
400 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:71
@ MMA8X5X_RATE_6HZ25
6.25 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:76
@ MMA8X5X_RATE_1HZ56
1.56 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:77
@ MMA8X5X_RATE_50HZ
50 Hz Output Data Rate in WAKE mode
Definition mma8x5x.h:74
@ MMA8X5X_TYPE_MMA8453
MMA8453.
Definition mma8x5x.h:63
@ MMA8X5X_TYPE_MMA8653
MMA8653.
Definition mma8x5x.h:60
@ MMA8X5X_TYPE_MMA8652
MMA8652.
Definition mma8x5x.h:59
@ MMA8X5X_TYPE_MMA8451
MMA8451.
Definition mma8x5x.h:61
@ MMA8X5X_TYPE_MMA8452
MMA8452.
Definition mma8x5x.h:62
@ MMA8X5X_RANGE_4G
+/- 4 g Full Scale Range
Definition mma8x5x.h:85
@ MMA8X5X_RANGE_8G
+/- 8 g Full Scale Range
Definition mma8x5x.h:86
@ MMA8X5X_RANGE_2G
+/- 2 g Full Scale Range
Definition mma8x5x.h:84
uint_fast8_t i2c_t
Default i2c_t type definition.
Definition i2c.h:155
Low-level I2C peripheral driver interface definition.
Data type for the result data.
Definition mma8x5x.h:121
int16_t z
acceleration in Z direction
Definition mma8x5x.h:124
int16_t y
acceleration in Y direction
Definition mma8x5x.h:123
int16_t x
acceleration in X direction
Definition mma8x5x.h:122
Configuration parameters.
Definition mma8x5x.h:103
i2c_t i2c
I2C bus the device is connected to.
Definition mma8x5x.h:104
uint8_t offset[3]
data offset in X, Y, and Z direction
Definition mma8x5x.h:108
uint8_t rate
sampling rate to use
Definition mma8x5x.h:106
uint8_t addr
I2C bus address of the device.
Definition mma8x5x.h:105
uint8_t range
scale range to use
Definition mma8x5x.h:107
Device descriptor for MMA8x5x accelerometers.
Definition mma8x5x.h:114
mma8x5x_params_t params
device configuration parameters
Definition mma8x5x.h:115