

# **APPLICATION NOTE**

# **AT89LP ADC Implementation**

#### 8 - Bit Atmel Microcontrollers

## **Features**

- Initializes ADC for 8-bit, Single Ended Mode
- Application to all AT89LP Microcontrollers with an ADC Module
- Source Code Provided Introduction

### Introduction

The ATMEL AT89LP microcontrollers feature on-chip Flash, enhanced single cycle execution, and an integrated ADC/DAC module. This application note describes how to initialize the on-board ADC and gives useful suggestions in improving the sampling accuracy.

## Analog - To - Digital Converter

For our AT89LP devices, our ADC supports up to 8 input analog channels that can be configured in single ended mode or differential mode. In addition, resolution of the AT89LP ADC can be selected to a standard 8-bit resolution or a high precision 10-bit resolution.

As shown in Figure 2-1, the AT89LP51ED2 will be shown with basic passive components to allow users to manually adjust the voltage input and display the value through an array of LEDS.

Figure 1-1. Example ADC Circuit



The analog input is controlled by using a variable resistor (R1) that can be increased / decreased by the user. Since the device is being used in single ended mode, the resistor (R1) will be able to deliver a signal that can be from one end (0V) to the other (Vcc). The push-button switch allows to the system to trigger the on-board timer which when times out, triggers the conversion of the ADC. Port 2 of the AT89LP51ED2 is connected to an array of LEDS to give a visual 8-bit representation of the newly converted output. A status LED (D9) has been added to P3.5 of the AT89LP51ED2 to show the when the ADC is busy/done.

The AT89LP51ED2 I/O ports have 4 unique modes that can be configured:

- Quasi-bidirectional
- Push-Pull Output
- Input Only (High Impedance)
- Open-Drain

For this application, that analog input channel, P0 will be configured as "Input Only" while all others will be set to quasi-bidirectional. For P0, "Input Only" offers the best port structure that rejects outside EMI that could cause accuracy of the ADC to be compromised.



As stated earlier, Timer 0 of the AT89LP51ED2 will be used to trigger an ADC conversion. The software will count from 0 to 255 after which the Timer 0 overflag will set and cause the ADC interrupt to be serviced. The ADC interrupt routine will move the newly converted value from the DADH register to Port 2 and set the status led (D9).

Timer 0 will begin counting as soon as the push-button switch (SW1) is pressed. The software is waiting for a pulse to be generated on the P1.1 before it starts Timer 0 and ADC conversion starts after which the new value will be displayed on Port 2. Each subsequent pulse detected on P1.1 will issue another conversion of the ADC of the AT89LP51ED2 device.

### **Noise Considerations**

Generally, digital systems generate EMI which could cause accuracy issues when analog values are being samples and converted. If accuracy of the system is critical, the following are useful tips in reducing the EMI in most applications.

- Disable ALE: In normal operation, ALE is pulsed at a constant rate of 1/3 the oscillator frequency in compatibility mode (1/2 the oscillator speed in "Fast Mode"). This pin is used to latch the low byte of the address during access to external memory. By setting the DISALE bit in the AUXR (Auxiliary Control) register, ALE will only be pulsed when external memory access is performed.
- IDLE Mode: The mode is one of two power saving modes our 8051 device come equipped with (other being Power-Down). Idle mode stops the internal CPU clock and holds the values of the RAM, stack pointer, program counter, program status word, and accumulator. In addition, all ports pins hold the logic state at the time Idle was invoked. Idle mode of the device is achieved by setting IDL bit in the PCON (Power Control) register.
- Analog Channel Input: The user can disconnect the analog inputs from the ADC to further decrease the amount of EMI that is being absorbed by the device. By clearing the ACON bit in the DADI (Input Control Register), the analog inputs are disconnected to from the ADC to not allow any type of noise to affect accuracy of the ADC during conversion.



# **Example Source Code**

```
; ADC Example for AT89LPxx devices
; Analog Input on P0.0, Single Ended Mode, 8-bit resolution
; External Reference Vdd Select
; Internal RC Clock Selected
; Hardware Trigger via Timer 0 overflow
; Converted Result will be in the DADH Register
```

| org      | 0x0063                 |                                           | ;Analog Interrupt Routine                   |
|----------|------------------------|-------------------------------------------|---------------------------------------------|
|          | mov<br>setb<br>reti    | P2, DADH<br>P4.7                          | ; Output value to port<br>; ADC completed   |
| start:   | mov                    | P0M0, #0xFF                               | ; P0 tristate                               |
|          | mov<br>mov<br>mov      | P0M1, #0x00<br>P1M0, #0x00<br>P2M0, #0x00 | ; Other Ports bidirectional                 |
|          | mov<br>mov             | P3M0, #0x00<br>P4M0, #0x00                | 5                                           |
|          | orl<br>mov<br>mov      | AUXR, #0x01<br>TMOD, #0x01<br>IEN0, #0x82 | ; Disable ALE<br>; T0 Mode1<br>; EA         |
|          | mov                    | IEN1, #0x20                               | ; EAD                                       |
|          | mov                    | DADC, #0x18                               | ; Enable, Left-Adjust,<br>; Int RC Osc      |
|          | mov                    | DADI, #0x10                               | ; IREF=0, DIFF=0, Channel 0                 |
| convert: |                        |                                           |                                             |
|          | mov<br>mov             | TCON, #0x00<br>TH0, #0xFF                 | ; Initialize Timer<br>; Reload Values       |
|          | mov                    | TL0, #0x00                                | , , , , , , , , , , , , , , , , , , , ,     |
|          | mov<br>mov             | DADH, #0x00<br>DADL, #0x00                | ; Clear ADC result registers                |
|          | orl                    | DADI, #0x80                               | ; Connect                                   |
|          | clr                    | P4.7                                      | ; ADC ready                                 |
|          | jb<br>jnb              | P1.1, \$<br>P1.1, \$                      | ; Wait for user to issue pulse              |
|          | setb TR0<br>mov<br>clr | PCON, #0x11<br>TR0                        | ; Overflow will trigger ADC<br>; Enter Idle |
|          | anl<br>sjmp<br>END     | DADI, #0x7F<br>convert                    | ; Disconnect                                |





#### **Atmel Corporation**

2325 Orchard Parkway San Jose, CA 95131 USA

**Tel:** (+1)(408) 441-0311 **Fax:** (+1)(408) 487-2600

www.atmel.com

## Atmel Asia Limited

Unit 01-5 & 16, 19F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG

**Tel:** (+852) 2245-6100 **Fax:** (+852) 2722-1369

#### **Atmel Munich GmbH**

Business Campus
Parkring 4
D-85748 Garching b. Munich
GERMANY

**Tel:** (+49) 89-31970-0 **Fax:** (+49) 89-3194621

## Atmel Japan G.K.

16F Shin-Osaki Kangyo Building 1-6-4 Osaki

Shinagawa-ku, Tokyo 141-0032

JAPAN

**Tel:** (+81)(3) 6417-0300 **Fax:** (+81)(3) 6417-0370

© 2012 Atmel Corporation. All rights reserved. / Rev.: 1/12

Atmel<sup>®</sup>, logo and combinations thereof, and others are registered trademarks or trademarks of Atmel Corporation or its subsidiaries. Other terms and product names may be trademarks of others.

Disclaimer: The information in this document is provided in connection with Atmel products. No license, express or implied, by estoppel or otherwise, to any intellectual property right is granted by this document or in connection with the sale of Atmel products. EXCEPT AS SET FORTH IN THE ATMEL TERMS AND CONDITIONS OF SALES LOCATED ON THE ATMEL WEBSITE, ATMEL ASSUMES NO LIABILITY WHATSOEVER AND DISCLAIMS ANY EXPRESS, IMPLIED OR STATUTORY WARRANTY RELATING TO ITS PRODUCTS INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE, SPECIAL OR INCIDENTAL DAMAGES (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS AND PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OR INABILITY TO USE THIS DOCUMENT, EVEN IF ATMEL HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. Atmel makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and products descriptions at any time without notice. Atmel does not make any commitment to update the information contained herein. Unless specifically provided otherwise, Atmel products are not suitable for, and shall not be used in, automotive applications. Atmel products are not intended, authorized, or warranted for use as components in applications intended to support or sustain life.