-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaccelerometroSPI.h
224 lines (196 loc) · 6.81 KB
/
accelerometroSPI.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
#ifndef ACCELEROMETRO_H
#define ACCELEROMETRO_H
#ifndef SPI_MISO
#define SPI_MISO PIN_D4
#define SPI_MOSI PIN_D5
#define SPI_SCL PIN_D6
#define SPI_SS PIN_D7
#endif
//NOta: probar si es posible no tener el ENABLE pin para controlarlo de manera independiente, se tiene que verificar con el reloj
#use spi(MASTER, MODE=2, DI=SPI_MISO, DO=SPI_MOSI, CLK=SPI_SCL, ENABLE=SPI_SS, BITS=8, BAUD=9600)
//definiciones para las direcciones de los registros
#define MMA7455_XOUTL 0x00 // Read only, Output Value X LSB
#define MMA7455_XOUTH 0x01 // Read only, Output Value X MSB
#define MMA7455_YOUTL 0x02 // Read only, Output Value Y LSB
#define MMA7455_YOUTH 0x03 // Read only, Output Value Y MSB
#define MMA7455_ZOUTL 0x04 // Read only, Output Value Z LSB
#define MMA7455_ZOUTH 0x05 // Read only, Output Value Z MSB
#define MMA7455_XOUT8 0x06 // Read only, Output Value X 8 bits
#define MMA7455_YOUT8 0x07 // Read only, Output Value Y 8 bits
#define MMA7455_ZOUT8 0x08 // Read only, Output Value Z 8 bits
#define MMA7455_STATUS 0x09 // Read only, Status Register
#define MMA7455_DETSRC 0x0A // Read only, Detection Source Register
#define MMA7455_TOUT 0x0B // Temperature Output Value (Optional)
#define MMA7455_RESERVED1 0x0C // Reserved
#define MMA7455_I2CAD 0x0D // Read/Write, I2C Device Address
#define MMA7455_USRINF 0x0E // Read only, User Information (Optional)
#define MMA7455_WHOAMI 0x0F // Read only, "Who am I" value (Optional)
#define MMA7455_XOFFL 0x10 // Read/Write, Offset Drift X LSB
#define MMA7455_XOFFH 0x11 // Read/Write, Offset Drift X MSB
#define MMA7455_YOFFL 0x12 // Read/Write, Offset Drift Y LSB
#define MMA7455_YOFFH 0x13 // Read/Write, Offset Drift Y MSB
#define MMA7455_ZOFFL 0x14 // Read/Write, Offset Drift Z LSB
#define MMA7455_ZOFFH 0x15 // Read/Write, Offset Drift Z MSB
#define MMA7455_MCTL 0x16 // Read/Write, Mode Control Register
#define MMA7455_INTRST 0x17 // Read/Write, Interrupt Latch Reset
#define MMA7455_CTL1 0x18 // Read/Write, Control 1 Register
#define MMA7455_CTL2 0x19 // Read/Write, Control 2 Register
#define MMA7455_LDTH 0x1A // Read/Write, Level Detection Threshold Limit Value
#define MMA7455_PDTH 0x1B // Read/Write, Pulse Detection Threshold Limit Value
#define MMA7455_PD 0x1C // Read/Write, Pulse Duration Value
#define MMA7455_LT 0x1D // Read/Write, Latency Time Value (between pulses)
#define MMA7455_TW 0x1E // Read/Write, Time Window for Second Pulse Value
#define MMA7455_RESERVED2 0x1F // Reserved
// Defines for the bits, to be able to change
// between bit number and binary definition.
// By using the bit number, programming the MMA7455
// is like programming an AVR microcontroller.
// But instead of using "(1<<X)", or "_BV(X)",
// the Arduino "bit(X)" is used.
#define MMA7455_D0 0x01 //0
#define MMA7455_D1 0x02 //1
#define MMA7455_D2 0x04 //2
#define MMA7455_D3 0x08 //3
#define MMA7455_D4 0x10 //4
#define MMA7455_D5 0x20 //5
#define MMA7455_D6 0x40 //6
#define MMA7455_D7 0x80 //7
// Status Register
#define MMA7455_DRDY MMA7455_D0
#define MMA7455_DOVR MMA7455_D1
#define MMA7455_PERR MMA7455_D2
// Mode Control Register
#define MMA7455_MODE0 MMA7455_D0
#define MMA7455_MODE1 MMA7455_D1
#define MMA7455_GLVL0 MMA7455_D2
#define MMA7455_GLVL1 MMA7455_D3
#define MMA7455_STON MMA7455_D4
#define MMA7455_SPI3W MMA7455_D5
#define MMA7455_DRPD MMA7455_D6
#define MMA7455_8g 0x00
#define MMA7455_2g 0x04
#define MMA7455_4g 0x08
#define MMA7455_STANDBY 0x00
#define MMA7455_MEASURE 0x01
#define MMA7455_LEVEL 0x02
#define MMA7455_PULSE 0x03
// Control 1 Register
#define MMA7455_INTPIN MMA7455_D0
#define MMA7455_INTREG0 MMA7455_D1
#define MMA7455_INTREG1 MMA7455_D2
#define MMA7455_XDA MMA7455_D3
#define MMA7455_YDA MMA7455_D4
#define MMA7455_ZDA MMA7455_D5
#define MMA7455_THOPT MMA7455_D6
#define MMA7455_DFBW MMA7455_D7
// Control 2 Register
#define MMA7455_LDPL MMA7455_D0
#define MMA7455_PDPL MMA7455_D1
#define MMA7455_DRVO MMA7455_D2
// Interrupt Latch Reset Register
#define MMA7455_CLR_INT1 MMA7455_D0
#define MMA7455_CLR_INT2 MMA7455_D1
// Detection Source Register
#define MMA7455_INT1 MMA7455_D0
#define MMA7455_INT2 MMA7455_D1
#define MMA7455_PDZ MMA7455_D2
#define MMA7455_PDY MMA7455_D3
#define MMA7455_PDX MMA7455_D4
#define MMA7455_LDZ MMA7455_D5
#define MMA7455_LDY MMA7455_D6
#define MMA7455_LDX MMA7455_D7
// I2C Device Address Register
#define MMA7455_I2CDIS MMA7455_D7
// Default I2C address for the MMA7455
#define MMA7455_I2C_ADDRESS 0x1D
//#define MMA7455_I2C_ADDRESS_READ 0X3B
#define MMA7455_I2C_ADDRESS_READ 0XA1
//#define MMA7455_I2C_ADDRESS_WRITE 0X3A
#define MMA7455_I2C_ADDRESS_WRITE 0XA0
// When using an union for the registers and
// the axis values, the byte order of the accelerometer
// should match the byte order of the compiler and AVR chip.
// Both have the lower byte at the lower address,
// so they match.
// This union is only used by the low level functions.
typedef union
{
struct
{
unsigned int8 x_lsb;
unsigned int8 x_msb;
unsigned int8 y_lsb;
unsigned int8 y_msb;
unsigned int8 z_lsb;
unsigned int8 z_msb;
} reg;
struct
{
int16 x;
int16 y;
int16 z;
} value;
} xyz_union;
typedef struct
{
/* data */
unsigned int8 MODE_CONTROL;
unsigned int8 CONTROL_1;
unsigned int8 CONTROL_2;
int8 XOFFL;
int8 XOFFH;
int8 YOFFL;
int8 YOFFH;
int8 ZOFFL;
int8 ZOFFH;/*,//no implemntado
char _LEVEL_DETECTION_THREHOLDS;
char _PULSE_DETECTION_THREHOLDS;
char _PULSE_DURATION;
char _LANTENCY_TIME;
char _TIME_WINDOWS;
*/
} CONFIG_MMA7455;
//configuracion incial del MMA7455
int init_MMA(void);
//recalibra el offset del MMA7455
int calibrate_MMA(void);
//cambio de configuracion del MMA7455
void set_config(*CONFIG_MMA7455);
//Lectura de los valores de x y z
int xyz_MMA( int *pX, int *pY, int *pZ);
//Lectura de datosd desde el MMA7455
int read_MMA(char address, int8 *value);
int read_MMA(unsigned char start_address, int8 *buffer,unsigned int size);
//Escritura de datos en el MMA7455
int write_MMA(char address, int8 *value);
int write_MMA(char start_address, int8 *pData, unsigned int size);
//#define testmma
#endif
/*
DEFINICIONES:
MOV = deteccion de movimiento
CL = deteccion de caida libre
Initialize the sensor
Sensitivity:
2g : GLVL0
4g : GLVL1
8g : GLVL1 | GLVL0
Mode:
Standby : 0
Measurement : MODE0
Level Detection : MODE1
Pulse Detection : MODE1 | MODE0
tabla 1: configuracion de INTRG
------------------------
INT2TRG INT1 INT2
00 LD PD
01 PD LD
10 sPD dPD
------------------------
tabla2: configuracion de pines de interrupciones
-------------------
INTPIN
0 INT1bit --> INT1pin, INT2bit --> INT2pin
1 INT1bit --> INT2pin, INT2bit --> INT1pin
-------------------
*/