

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

E·XFl

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



interrupt request to the ARM7TDMI. It integrates an 8-level priority controller, and, using the Auto-vectoring feature, reduces the interrupt latency time.

The Parallel Input/Output Controllers (PIOA, PIOB) controls up to 54 I/O lines. It enables the user to select specific pins for on-chip peripheral input/output functions, and general-purpose input/output signal pins. The PIO controllers can be programmed to detect an interrupt on a signal change from each line.

There are three embedded system timers. The Real-time Timer (RTT) counts elapsed seconds and can generate periodic or programmed interrupts. The Period Interval Timer (PIT) can be used as a user-programmable time-base, and can generate periodic ticks. The Watchdog (WD) can be used to prevent system lock-up if the software becomes trapped in a deadlock.

The Special Function (SF) module integrates the Chip ID and the Reset Status registers.

#### 5.2.2 User Peripherals

Two USARTs, independently configurable, enable communication at a high baud rate in synchronous or asynchronous mode. The format includes start, stop and parity bits and up to 9 data bits. Each USART also features a Time-out and a Time-guard register, facilitating the use of the two dedicated Peripheral Data Controller (PDC) channels.

The two 3-channel, 16-bit Timer/Counters (TC) are highly-programmable and support capture or waveform modes. Each TC channel can be programmed to measure or generate different kinds of waves, and can detect and control two input/output signals. Each TC also has three external clock signals.

Two independently configurable SPIs provide communication with external devices in master or slave mode. Each has four external chip selects which can be connected to up to 15 devices. The data length is programmable, from 8- to 16-bit.

AT91M42800A





39









# 11.18 Abort Address Status Register

| Register Name:<br>Access Type:<br>Offset:<br>Reset Value: | EBI_AASR<br>Read-only<br>0x34<br>0x0 | U  |     |     |    |    |    |
|-----------------------------------------------------------|--------------------------------------|----|-----|-----|----|----|----|
| 31                                                        | 30                                   | 29 | 28  | 27  | 26 | 25 | 24 |
|                                                           |                                      |    | ABT | ADD |    |    |    |
| 23                                                        | 22                                   | 21 | 20  | 19  | 18 | 17 | 16 |
|                                                           |                                      |    | ABT | ADD |    |    |    |
| 15                                                        | 14                                   | 13 | 12  | 11  | 10 | 9  | 8  |
|                                                           |                                      |    | ABT | ADD |    |    |    |
| 7                                                         | 6                                    | 5  | 4   | 3   | 2  | 1  | 0  |
|                                                           |                                      |    | ABT | ADD |    |    |    |

#### • ABTADD: Abort Address

This field contains the address required by the last aborted access.

# 12.8 PMC System Clock Disable Register

| Register Name<br>Access Type:<br>Offset: | PMC_S<br>Write-or<br>0x04 |    | 5  |    |         |    |          |
|------------------------------------------|---------------------------|----|----|----|---------|----|----------|
| 31                                       | 30                        | 29 | 28 | 27 | 26      | 25 | 24       |
| -                                        | -                         | -  | -  | -  | -       | -  | -        |
| 23                                       | 22                        | 21 | 20 | 19 | 18<br>— | 17 | 16       |
| 15                                       | 14                        | 13 | 12 | 11 | 10      | 9  | 8        |
| -                                        | -                         | -  | -  | -  | -       | -  | -        |
| 7                                        | 6                         | 5  | 4  | 3  | 2       | 1  | 0<br>CPU |

# • CPU: System Clock Disable

0 = No effect.

1 = Disables the System Clock.

### 12.9 PMC System Clock Status Register

| Register Name<br>Access Type:<br>Offset:<br>Reset Value: | -  | CSR |    |    |    |     |     |
|----------------------------------------------------------|----|-----|----|----|----|-----|-----|
| 31                                                       | 30 | 29  | 28 | 27 | 26 | 25  | 24  |
| -                                                        | _  | -   | -  | -  | -  | -   | -   |
| 23                                                       | 22 | 21  | 20 | 19 | 18 | 17  | 16  |
| -                                                        | —  | -   | -  | -  | -  | -   | -   |
| 15                                                       | 14 | 13  | 12 | 11 | 10 | 9   | 8   |
| -                                                        | _  | -   | -  | -  | _  | -   | -   |
| 7                                                        | 6  | 5   | 4  | 3  | 2  | 1   | 0   |
| /                                                        |    | 5   | 4  | 3  | 2  | · · | CPU |
|                                                          | -  | -   | -  | -  | -  | -   | UPU |

### CPU: System Clock Status

0 = System Clock is disabled.

1 = System Clock is enabled.



#### CSS: Clock Source Selection

0 = The clock source is the Slow Clock.

1 = The clock source is the output of the PLL.

#### • MUL: Phase Lock Loop Factor

0 = The PLL is disabled, reducing at the minimum its power consumption.

1 up to 2047 = The PLL output is at frequency (MUL+1) x Slow Clock frequency when the LOCK bit is set.

#### • PLLCOUNT: PLL Lock Counter

Specifies the number of 32,768 Hz clock cycles for the PLL lock timer to count before the PLL is locked, after the PLL is started.





# 13.4 System Timer User Interface

System Timer Base Address: 0xFFFF8000

Table 5. System Timer Registers

| Offset | Register Name                 | Register<br>Mnemonic | Access | Reset Value               |
|--------|-------------------------------|----------------------|--------|---------------------------|
| 0x00   | Control Register              | ST_CR                | W      | _                         |
| 0x04   | Period Interval Mode Register | ST_PIMR              | R/W    | 0x0000000 <sup>(1)</sup>  |
| 0x08   | Watchdog Mode Register        | ST_WDMR              | R/W    | 0x00020000 <sup>(1)</sup> |
| 0x0C   | Real-time Mode Register       | ST_RTMR              | R/W    | 0x00008000                |
| 0x10   | Status Register               | ST_SR                | R      | _                         |
| 0x14   | Interrupt Enable Register     | ST_IER               | W      | _                         |
| 0x18   | Interrupt Disable Register    | ST_IDR               | W      | _                         |
| 0x1C   | Interrupt Mask Register       | ST_IMR               | R      | 0x0                       |
| 0x20   | Real-time Alarm Register      | ST_RTAR              | R/W    | 0x0                       |
| 0x24   | Current Real-time Register    | ST_CRTR              | R      | 0x0                       |

Note: 1. Corresponds to maximum value of the counter.

## 13.5 System Timer Control Register

| Register Name<br>Access Type:<br>Offset: | ST_CR<br>Write-or<br>0x00 |    |    |    |    |    |       |
|------------------------------------------|---------------------------|----|----|----|----|----|-------|
| 31                                       | 30                        | 29 | 28 | 27 | 26 | 25 | 24    |
| _                                        | _                         | -  | -  | -  | -  | -  | _     |
| 23                                       | 22                        | 21 | 20 | 19 | 18 | 17 | 16    |
| _                                        | _                         | -  | -  | -  | -  | -  | -     |
| 15                                       | 14                        | 13 | 12 | 11 | 10 | 9  | 8     |
| _                                        | _                         | -  | -  | _  | -  | _  | _     |
| 7                                        | 6                         | 5  | 4  | 3  | 2  | 1  | 0     |
| -                                        | _                         | -  | -  | -  | -  | -  | WDRST |

#### • WDRST: Watchdog Timer Restart

0 = No effect.

1 = Reload the start-up value in the Watchdog Timer.

# 15. PIO: Parallel I/O Controller

The AT91M42800A has 54 programmable I/O lines. I/O lines are multiplexed with an external signal of a peripheral to optimize the use of available package pins (see Tables Table 15-1 on page 100 and Table 15-2 on page 101). These lines are controlled by two separate and identical PIO Controllers called PIOA and PIOB. Each PIO controller also provides an internal interrupt signal to the Advanced Interrupt Controller.

Note: After a hardware reset, the PIO clock is disabled by default (see Section 12. "PMC: Power Management Controller" on page 55). The user must configure the Power Management Controller before any access to the User Interface of the PIO.

### 15.1 Multiplexed I/O Lines

When a peripheral signal is not used in an application, the corresponding pin can be used as a parallel I/O. Each parallel I/O line is bi-directional, whether the peripheral defines the signal as input or output. Figure 15-1 shows the multiplexing of the peripheral signals with Parallel I/O signals.

A pin is controlled by the registers PIO\_PER (PIO Enable) and PIO\_PDR (PIO Disable). The register PIO\_PSR (PIO Status) indicates whether the pin is controlled by the corresponding peripheral or by the PIO Controller.

When the PIO is selected, the peripheral input line is connected to zero.

#### 15.2 Output Selection

The user can enable each individual I/O signal as an output with the registers PIO\_OER (Output Enable) and PIO\_ODR (Output Disable). The output status of the I/O signals can be read in the register PIO\_OSR (Output Status). The direction defined has effect only if the pin is configured to be controlled by the PIO Controller.

#### 15.3 I/O Levels

Each pin can be configured to be driven high or low. The level is defined in four different ways, according to the following conditions.

- If a pin is controlled by the PIO Controller and is defined as an output (see Section 15.2 "Output Selection" on page 97 above), the level is programmed using the registers PIO\_SODR (Set Output Data) and PIO\_CODR (Clear Output Data). In this case, the programmed value can be read in PIO\_ODSR (Output Data Status).
- If a pin is controlled by the PIO Controller and is not defined as an output, the level is determined by the external circuit.
- If a pin is not controlled by the PIO Controller, the state of the pin is defined by the peripheral (see peripheral datasheets).

In all cases, the level on the pin can be read in the register PIO\_PDSR (Pin Data Status).

#### 15.4 Filters

Optional input glitch filtering is available on each pin and is controlled by the registers PIO\_IFER (Input Filter Enable) and PIO\_IFDR (Input Filter Disable). The input glitch filtering can be selected whether the pin is used for its peripheral function or as a parallel I/O line. The register PIO\_IFSR (Input Filter Status) indicates whether or not the filter is activated for each pin.





### 15.5 Interrupts

Each parallel I/O can be programmed to generate an interrupt when a level change occurs. This is controlled by the PIO\_IER (Interrupt Enable) and PIO\_IDR (Interrupt Disable) registers which enable/disable the I/O interrupt by setting/clearing the corresponding bit in the PIO\_IMR. When a change in level occurs, the corresponding bit in the PIO\_ISR (Interrupt Status) is set whether the pin is used as a PIO or a peripheral and whether it is defined as input or output. If the corresponding interrupt in PIO\_IMR (Interrupt Mask) is enabled, the PIO interrupt is asserted.

When PIO\_ISR is read, the register is automatically cleared.

#### 15.6 User Interface

Each individual I/O is associated with a bit position in the Parallel I/O user interface registers. Each of these registers are 32 bits wide. If a parallel I/O line is not defined, writing to the corresponding bits has no effect. Undefined bits read zero.

#### 15.7 Multi-driver (Open Drain)

Each I/O can be programmed for multi-driver option. This means that the I/O is configured as open drain (can only drive a low level) in order to support external drivers on the same pin. An external pull-up is necessary to guarantee a logic level of one when the pin is not being driven.

Registers PIO\_MDER (Multi-Driver Enable) and PIO\_MDDR (Multi-Driver Disable) control this option. Multi-driver can be selected whether the I/O pin is controlled by the PIO Controller or the peripheral. PIO\_MDSR (Multi-Driver Status) indicates which pins are configured to support external drivers.

# 15.18 PIO Set Output Data Register

| Register Name:<br>Access Type:<br>Offset: | PIO_SODR<br>Write-only<br>0x30 | 5   |     |     |     |     |     |
|-------------------------------------------|--------------------------------|-----|-----|-----|-----|-----|-----|
| 31                                        | 30                             | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                       | P30                            | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                        | 22                             | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                       | P22                            | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                        | 14                             | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                       | P14                            | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                         | 6                              | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                        | P6                             | P5  | P4  | P3  | P2  | P1  | P0  |

This register is used to set PIO output data. It affects the pin only if the corresponding PIO output line is enabled and if the pin is controlled by the PIO. Otherwise, the information is stored.

0 = No effect.

1 = PIO output data on the corresponding pin is set.

| Register Name<br>Access Type:<br>Offset: | : PIO_COI<br>Write-onl<br>0x34 |     |     |     |     |     |     |
|------------------------------------------|--------------------------------|-----|-----|-----|-----|-----|-----|
| 31                                       | 30                             | 29  | 28  | 27  | 26  | 25  | 24  |
| P31                                      | P30                            | P29 | P28 | P27 | P26 | P25 | P24 |
| 23                                       | 22                             | 21  | 20  | 19  | 18  | 17  | 16  |
| P23                                      | P22                            | P21 | P20 | P19 | P18 | P17 | P16 |
| 15                                       | 14                             | 13  | 12  | 11  | 10  | 9   | 8   |
| P15                                      | P14                            | P13 | P12 | P11 | P10 | P9  | P8  |
| 7                                        | 6                              | 5   | 4   | 3   | 2   | 1   | 0   |
| P7                                       | P6                             | P5  | P4  | P3  | P2  | P1  | P0  |

### 15.19 PIO Clear Output Data Register

This register is used to clear PIO output data. It affects the pin only if the corresponding PIO output line is enabled and if the pin is controlled by the PIO. Otherwise, the information is stored.

0 = No effect.

1 = PIO output data on the corresponding pin is cleared.



# 18.6 TC Block Control Register

| Register Name:<br>Access Type:<br>Offset: | TC_BCF<br>Write-on<br>0xC0 |    |    |      |    |    |      |
|-------------------------------------------|----------------------------|----|----|------|----|----|------|
| 31                                        | 30                         | 29 | 28 | 27   | 26 | 25 | 24   |
| -                                         | _                          | -  | -  | -    | _  | _  | -    |
| 23                                        | 22                         | 21 | 20 | 19   | 18 | 17 | 16   |
| _                                         | -                          | -  | -  | -    | _  | _  | -    |
| 15                                        | 14                         | 13 | 12 | . 11 | 10 | 9  | 8    |
| _                                         | -                          | -  | -  | -    | _  | _  | -    |
| 7                                         | 6                          | 5  | 4  | 3    | 2  | 1  | 0    |
| -                                         | _                          | _  | -  | -    | _  | _  | SYNC |

### • SYNC: Synchro Command (Code Label TC\_SYNC)

0 = No effect.

1 = Asserts the SYNC signal which generates a software trigger simultaneously for each of the channels.





# 22. Soldering Profile

### 22.1 LQFP Soldering Profile (Green)

Table 22-1 gives the recommended soldering profile from J-STD-020C.

 Table 22-1.
 Soldering Profile Green Compliant Package

| Profile Feature                            | Green Package       |
|--------------------------------------------|---------------------|
| Average Ramp-up Rate (217°C to Peak)       | 3° C/sec. max.      |
| Preheat Temperature 175°C ±25°C            | 180 sec. max.       |
| Temperature Maintained Above 217°C         | 60 sec. to 150 sec. |
| Time within 5°C of Actual Peak Temperature | 20 sec. to 40 sec.  |
| Peak Temperature Range                     | 260° C              |
| Ramp-down Rate                             | 6° C/sec. max.      |
| Time 25° C to Peak Temperature             | 8 min. max.         |

Note: The package is certified to be backward compatible with Pb/Sn soldering profile.

A maximum of three reflow passes is allowed per component.

### 22.2 BGA Soldering Profile (RoHS-compliant)

Table 22-2 gives the recommended soldering profile from J-STD-20C.

 Table 22-2.
 Soldering Profile RoHS Compliant Package

| Profile Feature                            | Convection or IR/Convection |
|--------------------------------------------|-----------------------------|
| Average Ramp-up Rate (183° C to Peak)      | 3° C/sec. max.              |
| Preheat Temperature 125°C ±25°C            | 180 sec. max                |
| Temperature Maintained Above 183° C        | 60 sec. to 150 sec.         |
| Time within 5°C of Actual Peak Temperature | 20 sec. to 40 sec.          |
| Peak Temperature Range                     | 260° C                      |
| Ramp-down Rate                             | 6° C/sec.                   |
| Time 25°C to Peak Temperature              | 8 min. max                  |

Note: It is recomended to apply a soldering temperature higher than 250°C.

A maximum of three reflow passes is allowed per component.