Problem with ADXL345/Mega2560 R3 Plus Serial output only zeros untill I touch TX

Hopefully I am posting in the correct forum.
Could someone please help with an explanation and perhaps resolution to my issue with my project.
I am attempting to use an ADXL345 and Mega2560 R3 Plus to work together. It would seem the tap function is not working as it should. Any help would be sincerely be appreciated.

PIN connections are:
Arduino / ADXL345
GND GND
3V3 VCC
10 SC
50 SDO
51 SDA
52 SCL

This is code I found on the net:

//Add the SPI library so we can communicate with the ADXL345 sensor
#include <SPI.h>

//Assign the Chip Select signal to pin 10.
int CS=10;

/* Please follow following Pinouts
*

  • ADXL345 | UNO | Mega 2560
  • SCL | 13 | 52
  • SDA | 11 | 51
  • SDO | 12 | 50
  • CS | 10 | 10
  • GND | GND | GND
  • VCC | 3.3V | 3.3v
    */

//ADXL345 Register Addresses
#define DEVID 0x00 //Device ID Register
#define THRESH_TAP 0x1D //Tap Threshold
#define OFSX 0x1E //X-axis offset
#define OFSY 0x1F //Y-axis offset
#define OFSZ 0x20 //Z-axis offset
#define DURATION 0x21 //Tap Duration
#define LATENT 0x22 //Tap latency
#define WINDOW 0x23 //Tap window
#define THRESH_ACT 0x24 //Activity Threshold
#define THRESH_INACT 0x25 //Inactivity Threshold
#define TIME_INACT 0x26 //Inactivity Time
#define ACT_INACT_CTL 0x27 //Axis enable control for activity and inactivity detection
#define THRESH_FF 0x28 //free-fall threshold
#define TIME_FF 0x29 //Free-Fall Time
#define TAP_AXES 0x2A //Axis control for tap/double tap
#define ACT_TAP_STATUS 0x2B //Source of tap/double tap
#define BW_RATE 0x2C //Data rate and power mode control
#define POWER_CTL 0x2D //Power Control Register
#define INT_ENABLE 0x2E //Interrupt Enable Control
#define INT_MAP 0x2F //Interrupt Mapping Control
#define INT_SOURCE 0x30 //Source of interrupts
#define DATA_FORMAT 0x31 //Data format control
#define DATAX0 0x32 //X-Axis Data 0
#define DATAX1 0x33 //X-Axis Data 1
#define DATAY0 0x34 //Y-Axis Data 0
#define DATAY1 0x35 //Y-Axis Data 1
#define DATAZ0 0x36 //Z-Axis Data 0
#define DATAZ1 0x37 //Z-Axis Data 1
#define FIFO_CTL 0x38 //FIFO control
#define FIFO_STATUS 0x39 //FIFO status

//This buffer will hold values read from the ADXL345 registers.
char values[10];
char output[20];
//These variables will be used to hold the x,y and z axis accelerometer values.
int x,y,z;
double xg, yg, zg;
int tapType=0;

void setup(){
//Initiate an SPI communication instance.
SPI.begin();
//Configure the SPI connection for the ADXL345.
SPI.setDataMode(SPI_MODE3);
//Create a serial connection to display the data on the terminal.
Serial.begin(9600);
Serial.print("Hello Word!");

//Set up the Chip Select pin to be an output from the Arduino.
pinMode(CS, OUTPUT);
//Before communication starts, the Chip Select pin needs to be set high.
digitalWrite(CS, HIGH);

//Create an interrupt that will trigger when a tap is detected.
attachInterrupt(0, tap, RISING);

//Put the ADXL345 into +/- 4G range by writing the value 0x01 to the DATA_FORMAT register.
writeRegister(DATA_FORMAT, 0x01);

//Send the Tap and Double Tap Interrupts to INT1 pin
writeRegister(INT_MAP, 0x9F);
//Look for taps on the Z axis only.
writeRegister(TAP_AXES, 0x01);
//Set the Tap Threshold to 3g
writeRegister(THRESH_TAP, 0x38);
//Set the Tap Duration that must be reached
writeRegister(DURATION, 0x10);

//100ms Latency before the second tap can occur.
writeRegister(LATENT, 0x50);
writeRegister(WINDOW, 0xFF);

//Enable the Single and Double Taps.
writeRegister(INT_ENABLE, 0xE0);

//Put the ADXL345 into Measurement Mode by writing 0x08 to the POWER_CTL register.
writeRegister(POWER_CTL, 0x08); //Measurement mode
readRegister(INT_SOURCE, 1, values); //Clear the interrupts from the INT_SOURCE register.
}

void loop(){
//Reading 6 bytes of data starting at register DATAX0 will retrieve the x,y and z acceleration values from the ADXL345.
//The results of the read operation will get stored to the values[] buffer.
readRegister(DATAX0, 6, values);

//The ADXL345 gives 10-bit acceleration values, but they are stored as bytes (8-bits). To get the full value, two bytes must be combined for each axis.
//The X value is stored in values[0] and values[1].
x = ((int)values[1]<<8)|(int)values[0];
//The Y value is stored in values[2] and values[3].
y = ((int)values[3]<<8)|(int)values[2];
//The Z value is stored in values[4] and values[5].
z = ((int)values[5]<<8)|(int)values[4]; //Convert the accelerometer value to G's. //With 10 bits measuring over a +/-4g range we can find how to convert by using the equation: // Gs = Measurement Value * (G-range/(2^10)) or Gs = Measurement Value * (8/1024) xg = x * 0.0078; yg = y * 0.0078; zg = z * 0.0078; Serial.println("Before if:"); Serial.println(tapType); if(tapType > 0)
{
if(tapType == 1){
Serial.println("SINGLE");
Serial.print(x);
Serial.print(',');
Serial.print(y);
Serial.print(',');
Serial.println(z);
}
else{
Serial.println("DOUBLE");
Serial.print((float)xg,2);
Serial.print("g,");
Serial.print((float)yg,2);
Serial.print("g,");
Serial.print((float)zg,2);
Serial.println("g");
}
Serial.println("After if:");
detachInterrupt(0);
//Delay was 500 change to 5000
delay(5000);
attachInterrupt(0, tap, RISING);
int Type=0;
}
delay(10);
}

//This function will write a value to a register on the ADXL345.
//Parameters:
// char registerAddress - The register to write a value to
// char value - The value to be written to the specified register.
void writeRegister(char registerAddress, char value){
//Set Chip Select pin low to signal the beginning of an SPI packet.
digitalWrite(CS, LOW);
//Transfer the register address over SPI.
SPI.transfer(registerAddress);
//Transfer the desired register value over SPI.
SPI.transfer(value);
//Set the Chip Select pin high to signal the end of an SPI packet.
digitalWrite(CS, HIGH);
}

//This function will read a certain number of registers starting from a specified address and store their values in a buffer.
//Parameters:
// char registerAddress - The register addresse to start the read sequence from.
// int numBytes - The number of registers that should be read.
// char * values - A pointer to a buffer where the results of the operation should be stored.
void readRegister(char registerAddress, int numBytes, char * values){
//Since we're performing a read operation, the most significant bit of the register address should be set.
char address = 0x80 | registerAddress;
//If we're doing a multi-byte read, bit 6 needs to be set as well.
if(numBytes > 1)address = address | 0x40;

//Set the Chip select pin low to start an SPI packet.
digitalWrite(CS, LOW);
//Transfer the starting register address that needs to be read.
SPI.transfer(address);
//Continue to read registers until we've read the number specified, storing the results to the input buffer.
for(int i=0; i<numBytes; i++){
values = SPI.transfer(0x00);
}
//Set the Chips Select pin high to end the SPI packet.
digitalWrite(CS, HIGH);
}
void tap(void){
//Clear the interrupts on the ADXL345
readRegister(INT_SOURCE, 1, values);
if(values[0] & (1<<5))tapType=2;
else tapType=1;;
}
This is the Serial output on start up attached as Serial1 .doc attached. it does not respond to tap or double tap at all
Then when I run my finger over the TX/RX pin area it starts out putting X,Y,Z values as if it received a tap or double tap... out put also responds when the accelerometer is moved as seen from the second attachment.
Serial output1.doc (33 KB)
Serial output2.doc (36 KB)

The ADXL345 isn't 5V-tolerant, but it sounds like you've got it wired directly to the 2560's 5V SPI? The 3.3V VCC is a start, but to use a 5V Arduino like the Mega 2560 with this chip, you need a level converter. Your ADXL345 may be cooked or heading in that direction, as the datasheet indicates that the maximum any of its pins expect to see is 3.6V.

Here's a link to the sparkfun page for this chip, which discusses the level converter requirement (and, of course, suggests that you pick up their level converter board):
https://learn.sparkfun.com/tutorials/adxl345-hookup-guide

Thanks for your response jaholms... my 2560 has a 3v3 and 5v pin... I'm using the 3v3 pin on the arduino to connect to the ADXL345 vcc pin which is therefor only seeing 3volt.

Is that not correct?

Also the arduino does start to output xyz data but only when I place my finger over or near the TX & RX pins on the Arduino...then it also starts to respond to tilt and elevation position changes.

Now when I first start it up... it only output 0,0,0 data and does not respond to tap or double tap... tilt or elevation changes until I place my finger near or on the Arduino TX/RX pins... I'm baffled and very new to this.

Zekedog844u:
Thanks for your response jaholms... my 2560 has a 3v3 and 5v pin... I'm using the 3v3 pin on the arduino to connect to the ADXL345 vcc pin which is therefor only seeing 3volt.

Is that not correct?

Nope. This is a 3.3V part, so powering it with 3.3V as you are doing is right, but the Arduino's SPI is also 5V, and you're not doing anything to mate that with the ADXL345's 3.3V SPI. You need to do that, or at the very least things won't work, and it's possible you'll destroy something. My guess at what's happening here is that the ADXL345 is doing it's best to tolerate the 5V SPI even though the datasheet says it should see 3.6V max, and when the ADXL345 tries to send data to the Arduino, its 3.3V logic highs are only sometimes (and sometimes not) qualifying as high to the Arduino.

Thank you for getting back to me jaholms. I'm new to this and doing my best to muddle thru this...
So really then this Mega2560 is not compatible with this ADXL345... would I then need resistors in the system to attenuate the the Arduino SPI voltage?

I have seen something like that on the Spark Fun site... but thought it only applied to Arduino with 5v pins.

Thank you for your help.

Zekedog844u:
Thank you for getting back to me jaholms. I'm new to this and doing my best to muddle thru this...
So really then this Mega2560 is not compatible with this ADXL345... would I then need resistors in the system to attenuate the the Arduino SPI voltage?

I have seen something like that on the Spark Fun site... but thought it only applied to Arduino with 5v pins.

Thank you for your help.

Sure. Here's the SparkFun hookup guide for the ADXL345:
https://learn.sparkfun.com/tutorials/adxl345-hookup-guide

It talks about the need for a level-shifter when using the ADXL345 with 5V Arduinos, and gives an example of how to use one. The Mega 2560 is a 5V Arduino. It has a 3.3V supply pin, but nothing on the board uses that 3.3V. It's there purely as a convenience for those needing to power 3.3V peripherals. Actual interfacing of those peripherals is left to the user.

5V/3.3V interfacing is not a huge deal, but I'll stick with all 5V parts or all 3.3V parts given the chance--because I've got Arduinos of both kinds, and also because I'm just lazy.

Jaholms,

thanks for the heads-up on the Logic Level Converter ADA757... I ordered one and hooked it up but unfortunately it wasn't working out the box. I am now using I2C without the converter and have the Accelerometer working just fine.

However, what I would like to do now is wake the Mega2560 from sleep by using the ADXL345... Would this be the correct forum to ask that type of question...or better still would you be able to walk me thru some of the difficulties I'm facing with this implementation.

Thank you in advance...

Hi,
Have you tried the library and example from sparkfun?

It will save you a lot of code and pain.

Tom... :slight_smile:

SparkFun_ADXL345_Arduino_Library.zip (57.2 KB)

Thank you TomGeorge...

Yes I have the sample Sleep code and have as of now modified it somewhat to work with the ADXL345 accelerometer code... I am now experiencing declaration issues and would like some help resolving them please. I am an absolute Nubie so please excuse if I ask questions that may seem off the wall to you.

On line 306 Error... 'Val' was not declared in this scope
I have looked online and it looks as if it points to... "cant find a .h file or somethin"

Attached is the code that I am using which I have modified as best as I could to satisfy my requirements:

If you could please have a look over the attached file and comment on what you feel need to be changed.
Thanks kindly for your time.

sketch_mar07aSleepCode_ADXL_TrailerAlarm_Connect.ino (12.1 KB)