

# AN-831 Application Note

One Technology Way • P.O. Box 9106 • Norwood, MA 02062-9106, U.S.A. • Tel: 781.329.4700 • Fax: 781.461.3113 • www.analog.com

### Implementing a Counter with the ADuC702x Family by Aude Richard

#### INTRODUCTION

The ADuC702x family has an on-chip programmable logic array that consists of 16 gates with flip-flops on the output. This glue logic can be used for different functions. This application note describes how to implement a 3-bit counter but it can also apply to a simple sequence generation.

#### THE PLA

The programmable logic array (PLA) can be described as glue logic and its function is to remove the requirement for simple external logic. It consists of two independent blocks of eight elements. The two blocks can have different clocks, however, each element within a block uses the same block clock.

Each of the 16 elements contains a two-input look-up table and a flip-flop. The look-up table can be configured to generate any logic function based on one or two inputs. The flip-flop can be clocked with the block clock or it can be bypassed.



#### SYNCHRONOUS COUNTER

The flip-flops in a synchronous counter all receive the same clock signal. To implement a three-bit counter, three flip-flops and three outputs are required, as well as some logic to determine the next state (see Table 1 and Table 2).

| Table 1. Transition Table |                |                       |                |                |                       |    |  |  |  |
|---------------------------|----------------|-----------------------|----------------|----------------|-----------------------|----|--|--|--|
|                           | Actual Outputs |                       |                | Next Outputs   |                       |    |  |  |  |
| State                     | Q <sub>2</sub> | <b>Q</b> <sub>1</sub> | Q <sub>0</sub> | D <sub>2</sub> | <b>D</b> <sub>1</sub> | Do |  |  |  |
| 0                         | 0              | 0                     | 0              | 0              | 0                     | 1  |  |  |  |
| 1                         | 0              | 0                     | 1              | 0              | 1                     | 0  |  |  |  |
| 2                         | 0              | 1                     | 0              | 0              | 1                     | 1  |  |  |  |
| 3                         | 0              | 1                     | 1              | 1              | 0                     | 0  |  |  |  |
| 4                         | 1              | 0                     | 0              | 1              | 0                     | 1  |  |  |  |
| 5                         | 1              | 0                     | 1              | 1              | 1                     | 0  |  |  |  |
| 6                         | 1              | 1                     | 0              | 1              | 1                     | 1  |  |  |  |
| 7                         | 1              | 1                     | 1              | 0              | 0                     | 0  |  |  |  |

#### Table 2. Functions

|                                                                      |   | Q <sub>1</sub> , Q <sub>0</sub> |                                                |                                  |                     |  |  |  |
|----------------------------------------------------------------------|---|---------------------------------|------------------------------------------------|----------------------------------|---------------------|--|--|--|
| D <sub>2</sub>                                                       |   | 00                              | 01                                             | 11                               | 10                  |  |  |  |
| Q <sub>2</sub>                                                       | 0 | 0                               | 0                                              | 1                                | 0                   |  |  |  |
|                                                                      | 1 | 1                               | 1                                              | 0                                | 1                   |  |  |  |
| $D_2 = \overline{Q_2}Q_1Q_0 + Q_2\overline{Q_1} + Q_2\overline{Q_0}$ |   |                                 |                                                |                                  |                     |  |  |  |
|                                                                      |   | Q <sub>1</sub> , Q <sub>0</sub> |                                                |                                  |                     |  |  |  |
|                                                                      |   |                                 | <b>Q</b> <sub>1</sub> ,                        | , <b>Q</b> <sub>0</sub>          |                     |  |  |  |
| <b>D</b> <sub>1</sub>                                                |   | 00                              | Q <sub>1</sub> ,<br>01                         | , Q₀<br>11                       | 10                  |  |  |  |
| <b>D</b> <sub>1</sub><br>Q <sub>2</sub>                              | 0 | <b>00</b><br>0                  | Q <sub>1</sub> ,<br>01<br>1                    | <b>Q</b> <sub>0</sub><br>11<br>0 | <b>10</b>           |  |  |  |
| <b>D</b> <sub>1</sub><br>Q <sub>2</sub>                              | 0 | <b>00</b><br>0<br>0             | <b>Q</b> <sub>1</sub> ,<br><b>01</b><br>1<br>1 | . <b>Q₀</b><br>11<br>0<br>0      | <b>10</b><br>1<br>1 |  |  |  |

$$D_0 = \overline{Q}$$



Figure 2. Schematic

#### **IMPLEMENTATION ON THE ADUC702x**

To implement a three-bit counter, three flip-flops and three general-purpose outputs are required.

Because each PLA element contains only a two input gate, the three input gates need to be replaced with two input gates.

 $\mathrm{D_2}$  can also be written as

$$D_2 = \overline{Q_2}Q_1Q_0 + Q_2\overline{Q_1} + Q_2\overline{Q_0} = \overline{Q_2}Q_1Q_0 + Q_2\overline{Q_1Q_0}$$

This can easily be implemented with two input gates.

Note that the clock used for the flip-flops is fully programmable. It can be one of three GPIOs: the HCLK, internal oscillator, or Timer 1 overflow. The Timer 1 overflow offers a great deal of flexibility with four clock sources, a prescaler, and a 32-bit counter.



Figure 3. Implementation Using the PLA Tool

#### CONCLUSION

There are three main advantages to implementing a 3-bit counter using the PLA:

- There is no requirement for an external component.
- As an integrated solution, no processing power is required.
- The clock is fully programmable, with no requirement for an external clock signal.

This application note only discusses the case of a 3-bit counter. However, any simple sequence generation can be easily implemented using the same technique.

The main disadvantage of this technique is due to the limited number of gates and outputs available on the part.

The graphical PLA configuration tool is available to download on Analog Devices' website, www.analog.com.

### **Application Note**

#### Table 3. Relevant Extract from Companion Code PLAinit.c

```
//Code Generated By the ADuC 702X PLA Tool
//FileType:
                 C PLA Configuration File
//Source:
                  C Source Code
                         24/10/2005 22:20:13
//Date:
#include "ADuC7026.h"
void plaInitialize( )
{
      // Configure Port Pins for PLA mode
            In order for the PLA Tool to configure the required GPIO pins
11
11
            you must make the necessary selections on the outputs tab !!!
GP1CON = 0x3000000;
GP2CON = 0 \times 00000330;
      // Configure individual elements
      PLAELMO = 0 \times 0 2 DC;
      PLAELM1 = 0 \times 07 CF;
      PLAELM2 = 0 \times 0051;
      PLAELM3 = 0 \times 0145;
      PLAELM5 = 0 \times 07D1;
      PLAELM6 = 0 \times 07CC;
      PLAELM7 = 0 \times 018A;
      // Clk Source configuration
      PLACLK = 0x0004;
```

}

## NOTES

@2011 Analog Devices, Inc. All rights reserved. Trademarks and registered trademarks are the property of their respective owners. AN05852-0-1/11(A)



www.analog.com

Rev. A | Page 4 of 4