Loading...
Searching...
No Matches
adxl345_regs.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2017 Mesotic SAS
3 *
4 * This file is subject to the terms and conditions of the GNU Lesser
5 * General Public License v2.1. See the file LICENSE in the top level
6 * directory for more details.
7 */
8
9#pragma once
10
20
21#ifdef __cplusplus
22 extern "C" {
23#endif
24
29#define ADXL345_CHIP_ID_REG (0x00)
30#define ADXL345_THRESH_TAP (0x1D)
31#define ADXL345_OFFSET_X (0x1E)
32#define ADXL345_OFFSET_Y (0x1F)
33#define ADXL345_OFFSET_Z (0x20)
34#define ADXL345_TAP_DUR (0x21)
35#define ADXL345_TAP_LAT (0x22)
36#define ADXL345_TAP_WIN (0x23)
37#define ADXL345_THRESH_ACT (0x24)
38#define ADXL345_THRESH_INACT (0x25)
39#define ADXL345_TIME_INACT (0x26)
40#define ADXL345_ACT_INACT_CTL (0x27)
41#define ADXL345_THRESH_FF (0x28)
42#define ADXL345_TIME_FF (0x29)
43#define ADXL345_TAP_AXES (0x2A)
44#define ADXL345_ACT_TAP_STATUS (0x2B)
45#define ADXL345_BW_RATE (0x2C)
46#define ADXL345_POWER_CTL (0x2D)
47#define ADXL345_INT_ENABLE (0x2E)
48#define ADXL345_INT_MAP (0x2F)
49#define ADXL345_INT_SOURCE (0x30)
50#define ADXL345_DATA_FORMAT (0x31)
51#define ADXL345_DATA_X0 (0x32)
52#define ADXL345_DATA_X1 (0x33)
53#define ADXL345_DATA_Y0 (0x34)
54#define ADXL345_DATA_Y1 (0x35)
55#define ADXL345_DATA_Z0 (0x36)
56#define ADXL345_DATA_Z1 (0x37)
57#define ADXL345_FIFO_CTL (0x38)
58#define ADXL345_FIFO_STATUS (0x39)
60
65#define ADXL345_CHIP_ID (0xE5)
67
72#define ADXL345_RES_10_BITS (0x03FF)
73#define ADXL345_RES_11_BITS (0x07FF)
74#define ADXL345_RES_12_BITS (0x0FFF)
75#define ADXL345_RES_13_BITS (0x1FFF)
77
82#define ADXL345_INACT_Z_ENABLE (1 << 0)
83#define ADXL345_INACT_Y_ENABLE (1 << 1)
84#define ADXL345_INACT_X_ENABLE (1 << 2)
85#define ADXL345_INACT_ACDC (1 << 3)
86#define ADXL345_ACT_Z_ENABLE (1 << 4)
87#define ADXL345_ACT_Y_ENABLE (1 << 5)
88#define ADXL345_ACT_X_ENABLE (1 << 6)
89#define ADXL345_ACT_ACDC (1 << 7)
91
96#define ADXL345_TAP_Z_ENABLE (1 << 0)
97#define ADXL345_TAP_Y_ENABLE (1 << 1)
98#define ADXL345_TAP_X_ENABLE (1 << 2)
99#define ADXL345_SUPPRESS (1 << 3)
100#define ADXL345_TAP_ALL_ENABLE (ADXL345_TAP_Z_ENABLE | \
101 ADXL345_TAP_Y_ENABLE | \
102 ADXL345_TAP_X_ENABLE)
104
109#define ADXL345_TAP_Z_SRC (1 << 0)
110#define ADXL345_TAP_Y_SRC (1 << 1)
111#define ADXL345_TAP_X_SRC (1 << 2)
112#define ADXL345_ASLEEP (1 << 3)
113#define ADXL345_ACT_Z_SRC (1 << 4)
114#define ADXL345_ACT_Y_SRC (1 << 5)
115#define ADXL345_ACT_X_SRC (1 << 6)
117
122#define ADXL345_RATE_MASK (0x0F)
123#define ADXL345_LOWPOWER (1 << 4)
125
130#define ADXL345_WAKEUP_8HZ (0x00)
131#define ADXL345_WAKEUP_4HZ (0x01)
132#define ADXL345_WAKEUP_2HZ (0x02)
133#define ADXL345_WAKEUP_1HZ (0x03)
134#define ADXL345_SLEEP_BIT (1 << 2)
135#define ADXL345_MEASURE_BIT (1 << 3)
136#define ADXL345_AUTOSLEEP_BIT (1 << 4)
137#define ADXL345_LINK_BIT (1 << 5)
139
145#define ADXL345_OVERRUN (1 << 0)
146#define ADXL345_WATERMARK (1 << 1)
147#define ADXL345_FREEFALL (1 << 2)
148#define ADXL345_INACTIVITY (1 << 3)
149#define ADXL345_ACTIVITY (1 << 4)
150#define ADXL345_DOUBLE_TAP (1 << 5)
151#define ADXL345_SINGLE_TAP (1 << 6)
152#define ADXL345_DATA_READY (1 << 7)
154
159#define ADXL345_RANGE_MASK (0x03)
160#define ADXL345_JUSTIFY (1 << 2)
161#define ADXL345_FULL_RES (1 << 3)
162#define ADXL345_INT_INVERT (1 << 5)
163#define ADXL345_SPI_BIT (1 << 6)
164#define ADXL345_SELF_TEST (1 << 7)
166
171#define ADXL345_SAMPLES_MASK (0x0F)
172#define ADXL345_FIFO_TRIGGER_POS (4)
173#define ADXL345_FIFO_TRIGGER (1 << ADXL345_FIFO_TRIGGER_POS)
174#define ADXL345_FIFO_MODE_POS (6)
175#define ADXL345_FIFO_MODE_MASK (0xC0)
177
182#define ADXL345_FIFO_ENTRIES_MASK (0x3F)
183#define ADXL345_FIFO_TRIG (1 << 7)
185
186#ifdef __cplusplus
187}
188#endif
189