Professional Documents
Culture Documents
com
ADXL345
Evaluation Boards
PmodACL
EVAL-ADXL313-Z-M
EVAL-ADXL345Z
EVAL-ADXL345Z-DB
Reference Circuits
CN0133
Overview
The ADXL345 is a small, thin, low power, 3-axis accelerometer with high resolution (13-bit)
measurement at up to 16 g. Digital output data is formatted as 16-bit twos complement and is
accessible through either a SPI (3- or 4-wire) or I2C digital interface.
The ADXL345 is well suited for mobile device applications. It measures the static acceleration of
gravity in tilt-sensing applications, as well as dynamic acceleration resulting from motion or shock. Its
high resolution (4 mg/LSB) enables measurement of inclination changes less than 1.0.
Several special sensing functions are provided. Activity and inactivity sensing detect the presence or
lack of motion and if the acceleration on any axis exceeds a user-set level. Tap sensing detects single
and double taps. Free-fall sensing detects if the device is falling. These functions can be mapped to
one of two interrupt output pins. An integrated, patent pending 32-level first in, first out (FIFO) buffer
can be used to store data to minimize host processor intervention.
Rev 24 May 2013 13:47 | Page 1
Low power modes enable intelligent motion-based power management with threshold sensing and
active acceleration measurement at extremely low power dissipation.
The ADXL345 is supplied in a small, thin, 3 mm 5 mm 1 mm, 14-lead, plastic package.
Applications
Driver Description
The driver contains two parts:
The driver for the ADXL345 part, which may be used, without modifications, with any microcontroller.
The Communication Driver, where the specific communication functions for the desired type of
processor and communication protocol have to be implemented. This driver implements the
communication with the device and hides the actual details of the communication protocol to the
ADI driver.
The Communication Driver has a standard interface, so the ADXL345 driver can be used exactly as it
is provided.
Rev 24 May 2013 13:47 | Page 2
If the SPI communication is chosen, there are three functions which are called by the ADXL345 driver:
Description
Initializes the communication
peripheral and checks if the
ADXL345 part is present.
Function
void ADXL345_SetRegisterValue(unsigned char registerAddress,
unsigned char registerValue)
unsigned char ADXL345_GetRegisterValue(unsigned char
registerAddress)
void ADXL345_SetPowerMode(unsigned char pwrMode)
void ADXL345_GetXyz(short* x, short* y, short* z)
void ADXL345_GetGxyz(float* x, float* y, float* z)
void ADXL345_SetTapDetection(unsigned char tapType, unsigned char
tapAxes, unsigned char tapDur, unsigned char tapLatent, unsigned
char tapWindow, unsigned char tapThresh, unsigned char tapInt)
void ADXL345_SetActivityDetection(unsigned char actOnOff, unsigned
char actAxes, unsigned char actAcDc, unsigned char actThresh,
unsigned char actInt)
void ADXL345_SetInactivityDetection(unsigned char inactOnOff,
unsigned char inactAxes, unsigned char inactAcDc, unsigned char
inactThresh, unsigned char inactTime, unsigned char inactInt)
void ADXL345_SetFreeFallDetection(unsigned char ffOnOff, unsigned
char ffThresh, unsigned char ffTime, unsigned char ffInt)
void ADXL345_SetOffset(unsigned char xOffset, unsigned char yOffset,
unsigned char zOffset)
void ADXL345_SetRangeResolution(unsigned char gRange, unsigned
char fullRes)
28 Sep 2012 12:22 Dragos Bogdan
Description
Writes data into a register.
Reads the value of a register.
Places the device into
standby/measure mode.
Reads the raw output data of
each axis.
Reads the raw output data of
each axis and converts it to g.
Enables/disables the tap
detection.
Enables/disables the activity
detection.
Enables/disables the
inactivity detection.
Enables/disables the free-fall
detection.
Calibrates the accelerometer.
Selects the measurement
range.
HW Platform(s):
Downloads
Required Hardware
Required Software
Hardware Setup
There are two options:
The ADXL345 part installed on the Renesas Demonstration Kit (RDK) for RL78G13 can be used. In
this case, the I2C protocol has to be chosen.
A PmodACL can be connected to the PMOD1 connector. In this case, the SPI protocol has to be
Rev 24 May 2013 13:47 | Page 5
chosen.
Run the IAR Embedded Workbench for Renesas RL78 integrated development environment.
Choose to create a new project (Project Create New Project).
Select the RL78 tool chain, the Empty project template and click OK.
Select a location and a name for the project (ADIEvalBoard for example) and click Save.
From the Setup tab of the Debugger category select the TK driver and click OK.
Extract the files from the lab .zip archive and copy them into the projects folder.
The new source files have to be included into the project. Open the Add Files window (Project
Rev 24 May 2013 13:47 | Page 10
Add Files), select all the copied files and click open.
At this moment, all the files are included into the project.
The project is ready to be compiled and downloaded on the board. Press the F7 key to compile it.
Press CTRL + D to download and debug the project.
A window will appear asking to configure the emulator. Keep the default settings and press OK.
Required Hardware
Required Software
The ADXL345 demonstration project for the Renesas RL78G14 platform consists
of three parts: the ADXL345 Driver, the PmodACL Demo for RL78G14 and
the RL78G14 Common Drivers.
All three parts have to be downloaded.
Hardware Setup
There are two options:
The ADXL345 part installed on the Renesas Demonstration Kit (RDK) for RL78G14 can be used. In
this case, the I2C protocol has to be chosen with 'ADXL345_Init()' function.
A PmodACL can be connected to the PMOD1 connector. In this case, the SPI protocol has to be
chosen with 'ADXL345_Init()' function.
Demo Kit for RL78G14 for controlling and monitoring the operation of the ADI part.
Run the IAR Embedded Workbench for Renesas RL78 integrated development environment.
Choose to create a new project (Project Create New Project).
Select the RL78 tool chain, the Empty project template and click OK.
Select a location and a name for the project (ADIEvalBoard for example) and click Save.
From the Setup tab of the Debugger category select the TK driver and click OK.
The new source files have to be included into the project. Open the Add Files window (Project
Add Files), select all the copied files and click open.
At this moment, all the files are included into the project.
The project is ready to be compiled and downloaded on the board. Press the F7 key to compile it.
Press CTRL + D to download and debug the project.
A window will appear asking to configure the emulator. Keep the default settings and press OK.
Required Hardware
Required Software
Hardware Setup
There are two options:
The ADXL345 part installed on the Renesas Demonstration Kit (RDK) for RX62N can be used. In this
case, the I2C protocol has to be chosen.
A PmodACL can be connected to the Renesas Demonstration Kit (RDK) for RX62N (in this case, the
SPI protocol has to be chosen):
PmodACL
PmodACL
PmodACL
PmodACL
PmodACL
PmodACL
Pin
Pin
Pin
Pin
Pin
Pin
1
2
3
4
5
6
(CS)
(MOSI)
(MISO)
(CLK)
(GND)
(VCC)
YRDKRX62N
YRDKRX62N
YRDKRX62N
YRDKRX62N
YRDKRX62N
YRDKRX62N
J8
J8
J8
J8
J8
J8
connector
connector
connector
connector
connector
connector
Pin
Pin
Pin
Pin
Pin
Pin
15
19
22
20
4
3
The RPDL (Renesas Peripheral Driver Library) has to integrated in the project. Unzip the RPDL files
(double-click on the file RPDL_RX62N.exe). Navigate to where the RPDL files were unpacked and
double-click on the Copy_RPDL_RX62N.bat to start the copy process. Choose the LQFP package,
type the full path where the project was created and after the files were copied, press any key to
close the window.
The new source files have to be included in the project. Use the key sequence Alt, P, A to open the
Add files to project ADIEvalBoard window. Double click on the RPDL folder. From the Files of type
drop-down list, select C source file (*.C). Select all of the files and press Add.
To avoid conflicts with standard project files remove the files intprg.c and vecttbl.c which are
included in the project. Use the key sequence Alt, P, R to open the Remove Project Files window.
Select the files, click on Remove and press OK.
Next the new directory has to be included in the project. Use the key sequence Alt, B, R to open the
RX Standard Toolchain window. Select the C/C++ tab, select Show entries for: Include file
directories and press Add. Select Relative to: Project directory, type RPDL as sub-directory and
Rev 24 May 2013 13:47 | Page 28
press OK.
The library file path has to be added in the project. Select the Link/Library tab, select Show entries
for: Library files and press Add. Select Relative to: Project directory, type RPDL\RX62N_library
as file path and press OK.
Because the intprg.c file was removed the PIntPrg specified in option start has to be removed.
Change Category to Section. Press Edit, select PIntPRG and press Remove. From this
window the address of each section can be also modified. After all the changes are made press OK
two times.
At this point the files extracted from the zip file located in the Software Tools section have to be
added into the project. Copy all the files from the archive into the project folder.
Now, the files have to be included in the project. Use the key sequence Alt, P, A to open the Add
files to project ADIEvalBoard window. Navigate into ADI folder. From the Files of type drop-down
list, select Project Files. Select all the copied files and press Add.
Now, the project is ready to be built. Press F7. The message after the Build Process is finished has to
Rev 24 May 2013 13:47 | Page 32
be 0 Errors, 0 Warnings. To run the program on the board, you have to download the firmware into
the microprocessors memory.
03 Feb 2012 14:32 Dragos Bogdan
More information
www.analog.com