#### 9.1

#### **OVERVIEW**

This chapter describes the basic system interface features of the ADSP-2100 family processors. The system interface includes various hardware and software features used to control the DSP processor.

Processor control pins include a <u>RESET</u> signal, clock signals, flag inputs and outputs, and interrupt requests. This chapter describes only the logical relationships of control signals; consult individual processor data sheets for actual timing specifications.

### 9.2

### CLOCK SIGNALS

The ADSP-2100 family processors may be operated with a TTL-compatible clock signal input to the CLKIN pin or with a crystal connected between the CLKIN and XTAL pins. If an external clock is used, XTAL must be left unconnected. The CLKIN signal may not be halted or changed in frequency during operation.

The ADSP-2101, ADSP-2105, ADSP-2115, and ADSP-2111 processors operate with an input clock frequency equal to the instruction cycle rate. The ADSP-2171, ADSP-2181, and ADSP-21msp58/59 processors operate with an input clock frequency equal to half the instruction rate; for example, a 16.67 MHz input clock produces a 33 MHz instruction rate (30 ns cycle time). Device timing is relative to the internal clock rate which is indicated by the CLKOUT signal.

Because these processors include an on-chip oscillator circuit, an external crystal can be used. The crystal should be connected between the CLKIN and XTAL pins, with two capacitors connected as shown in Figure 9.1, which can be found on the following page. A parallel-resonant, fundamental frequency, microprocessor-grade crystal should be used. The frequency value selected for the crystal should be equal to the desired instruction rate for the processor (for the ADSP-2101, ADSP-2105, ADSP-2115, and ADSP-2111) or half the desired instruction rate (for the ADSP-2171, ADSP-2181, and ADSP-21msp58/59).



Figure 9.1 External Crystal Connections

The internal phased lock loop of the processors generates an internal clock which is four times the instruction rate.

The processors also generate a CLKOUT signal which is synchronized to the processors' internal cycles and operates at the instruction cycle rate. A phase-locked loop is used to generate CLKOUT and to divide each instruction cycle into a sequence of internal time periods called processor states. The relationship between the phases of CLKIN, CLKOUT, and the processor states is shown in Figure 9.2 for the ADSP-2101, ADSP-2105, ADSP-2115, and ADSP-2111 processors. Figure 9.3 shows the same information for the ADSP-2171, ADSP-2181, and ADSP-21msp58/59 processors. The phases of the internal processor clock are dependent upon the period of the external clock.

The CLKOUT output can be disabled on the ADSP-2171, ADSP-2181, and ADSP-21msp58/59 processors. This is controlled by the CLKODIS bit in the SPORT0 Autobuffer Control Register.



Figure 9.2 Clock Signals & Processor States (ADSP-2101, ADSP-2105, ADSP-2115, ADSP-2111)





### 9.2.1 Synchronization Delay

Each processor has several asynchronous inputs (interrupt requests, for example), which can be asserted in arbitrary phase to the processor clock. The processor synchronizes such signals before recognizing them. The delay associated with signal recognition is called synchronization delay.

Different asynchronous inputs are recognized at different points in the processor cycle. Any asynchronous input must be valid prior to the recognition point to be recognized in a particular cycle. If an input does not meet the setup time on a given cycle, it is recognized either in the current cycle or during the next cycle if it remains valid.

Edge-sensitive interrupt requests are latched internally so that the request signal only has to meet the pulse width requirement. To ensure the recognition of any asynchronous input, however, the input must be asserted for at least one full processor cycle plus setup and hold time. Setup and hold times are specified in the data sheet for each individual device.

### 9.2.2 1x & 1/2x Clock Considerations

Each processor requires only a 1X or 1/2X frequency clock signal. They use what is effectively an on-chip phase-locked loop to generate the higher frequency internal clock signals and CLKOUT. Because these clocks are generated based on the rising edge of CLKIN, there is no ambiguity about the phase relationship of two processors sharing the same input clock. Multiple processor synchronization is simplified as a result.

Using a 1X or 1/2X frequency input clock with the phase-locked loop to generate the various internal clocks imposes certain restrictions. The CLKIN signal must be valid long enough to achieve phase lock before <u>RESET</u> can be deasserted. Also, the clock frequency cannot be changed unless the processor is in <u>RESET</u>. Refer to the processor data sheets for details.

#### 9.3

#### RESET

SOFTWARE-

**RESET** halts execution and causes a hardware reset of the processor. The **RESET** signal must be asserted when the processor is powered up to assure proper initialization.

Tables 9.2–9.7 show the <u>RESET</u> state of various registers, including the processors' on-chip memory-mapped status/control registers. The values of any registers not listed are undefined at reset. The contents of on-chip memory are unchanged after <u>RESET</u>, except as shown in Tables 9.2–9.7 for the data-memory-mapped control/status registers. The CLKOUT signal continues to be generated by the processor during <u>RESET</u>, except when disabled on the ADSP-2171, ADSP-2181, or ADSP-21msp58/59.

The contents of the computation unit (ALU, MAC, Shifter) and data address generator (DAG1, DAG2) registers are undefined following <u>RESET</u>.

When <u>RESET</u> is released, the processor's booting operation takes place, depending on the state of the processor's MMAP pin. Program booting is described in Chapter 10, "Memory Interface."

For the ADSP-2111, ADSP-2171, and ADSP-21msp58/59 processors, which include a host interface port, setting the software reset bit in the HSR7 register has the same affect as asserting <u>RESET</u>. This allows either the host processor or the ADSP-21xx to initiate a reset under software control.

In a multiprocessing system with several processors, a synchronous <u>RESET</u> is required.

### 9.4

### FORCED REBOOTING

Software-forced reboots can be accomplished in several ways. A softwareforced reboot clears the context of the processor and initializes some registers. A *context clear* clears the processor stacks and restart execution at address 0x0000. Table 9.1 shows the different ways each processor can perform a software reboot.

| Processor<br>ADSP-2101<br>ADSP-2105<br>ADSP-2111<br>ADSP-2115 | <i>Reboot Method</i><br>Boot Force | <i>Description</i><br>Setting the BFORCE bit in the System<br>Control Register causes a reboot                                                                                                        |
|---------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADSP-2171                                                     | Boot Force                         | Setting the BFORCE bit in the System<br>Control Register causes a reboot                                                                                                                              |
|                                                               | Powerup Context Reset              | Setting the PUCR bit in the SPORT1<br>Autobuffer & Powerdown Control<br>Register causes a reboot on recovery<br>from powerdown                                                                        |
| ADSP-2181                                                     | BDMA Context Reset                 | Setting the BCR bit in the BDMA<br>Control Register <i>before</i> writing to the<br>BDMA Word Count Register<br>(BWCOUNT) causes a reboot.<br>Execution starts after the BDMA reboot<br>is completed. |
|                                                               | Powerup Context Reset              | Setting the PUCR bit in the SPORT1<br>Autobuffer & Powerdown Control<br>Register causes a reboot on recovery<br>from powerdown                                                                        |

Table 9.1 Software-Forced Rebooting

Tables 9.2–9.7 show the state of the processor registers after a softwareforced reboot. The values of any registers not listed are unchanged by a reboot.

During booting (and rebooting), all interrupts including serial port interrupts are masked and autobuffering is disabled. The serial port(s) remain active; one transfer—from internal shift register to data register can occur for each serial port before there are overrun problems.

The timer runs during a reboot. If a timer interrupt occurs during the reboot, it is masked. Thus, if more than one timer interrupt occurs during the reboot, the processor latches only the first. A timer overrun can occur.

| Control Field               | Description                           | Reset     | Reboot                 |
|-----------------------------|---------------------------------------|-----------|------------------------|
| Bus Exchange Register<br>PX | PX register                           | undefined | undefined              |
| Status Registers<br>IMASK   | Interrupt service enables             | 0         | 0                      |
| ASTAT                       | Arithmetic status                     | 0         | 0                      |
| MSTAT                       | Mode status                           | 0         | unchanged              |
| SSTAT                       | Stack status                          | 0x55      | 0x55                   |
| ICNTL                       | Interrupt control                     | undefined | unchanged              |
| IFC                         | Interrupt force/clear                 | 0         | 0                      |
| Control Registers (memor    | ry-mapped)                            |           |                        |
| BWAIT                       | Boot memory wait states               | 3         | unchanged              |
| BPAGE                       | Boot page                             | 0         | unchanged              |
| SPORT1 configure            | Configuration                         | 1         | unchanged              |
| SPE0                        | SPORT0 enable                         | 0         | unchanged              |
| SPE1                        | SPORT1 enable                         | 0         | unchanged              |
| DWAIT0-4                    | Data memory wait states               | 7         | unchanged              |
| PWAIT                       | Program memory wait                   | 7         | unchanged              |
| TCOUNT                      | Timer count register                  | undefined | operates during reboot |
| TPERIOD                     | Timer period register                 | undefined | unchanged              |
| TSCALE                      | Timer scale register                  | undefined | unchanged              |
| Serial Port Control Regis   | ters (memory-mapped, one set per SPOI | RT)       |                        |
| ISCLK                       | Internal serial clock                 | 0         | unchanged              |
| RFSR, TFSR                  | Frame sync required                   | 0         | unchanged              |
| RFSW, TFSW                  | Frame sync width                      | 0         | unchanged              |
| IRFS, ITFS                  | Internal frame sync                   | 0         | unchanged              |
| INVRFS, INVTFS              | Invert frame sense                    | 0         | unchanged              |
| DTYPE                       | Companding type, format               | 0         | unchanged              |
| SLEN                        | Serial word length                    | 0         | unchanged              |
| SCLKDIV                     | Serial clock divide                   | undefined | unchanged              |
| RFSDIV                      | RFS divide                            | undefined | unchanged              |
| Multichannel word ena       |                                       | undefined | unchanged              |
| MCE                         | Multichannel enable                   | 0         | unchanged              |
| MCL                         | Multichannel length                   | 0         | unchanged              |
| MFD                         | Multichannel frame delay              | 0         | unchanged              |
| INVTDV                      | Invert transmit data valid            | 0         | unchanged              |
| RBUF, TBUF                  | Autobuffering enable                  | 0         | 0                      |
| TIREG, RIREG                | Autobuffer I index                    | undefined | unchanged              |
| TMREG, RMREG                | Autobuffer M index                    | undefined | unchanged              |
| FO (SPORT1 only)            | Flag Out value                        | undefined | unchanged              |

Table 9.2 ADSP-2101/ADSP-2115 State After Reset Or Software Reboot

| Control Field                                                                                                                                                                      | Description                                                                                                                                                                                                                                                                 | Reset                                                                          | Reboot                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bus Exchange Register<br>PX                                                                                                                                                        | PX register                                                                                                                                                                                                                                                                 | undefined                                                                      | undefined                                                                                                                           |
| Status Registers<br>IMASK<br>ASTAT<br>MSTAT<br>SSTAT<br>ICNTL<br>IFC                                                                                                               | Interrupt service enables<br>Arithmetic status<br>Mode status<br>Stack status<br>Interrupt control<br>Interrupt force/clear                                                                                                                                                 | 0<br>0<br>0x55<br>undefined<br>0                                               | 0<br>0<br>unchanged<br>0x55<br>unchanged<br>0                                                                                       |
| Control Registers (memor<br>BWAIT<br>BPAGE<br>SPORT1 configure<br>SPE1<br>DWAIT0–4<br>PWAIT<br>TCOUNT<br>TPERIOD<br>TSCALE                                                         | <i>ry-mapped)</i><br>Boot memory wait states<br>Boot page<br>Configuration<br>SPORT1 enable<br>Data memory wait states<br>Program memory wait<br>Timer count register<br>Timer period register<br>Timer scale register                                                      | 3<br>0<br>1<br>0<br>7<br>7<br>undefined<br>undefined<br>undefined              | unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>operates during reboot<br>unchanged<br>unchanged<br>unchanged      |
| Serial Port 1 Control Reg<br>ISCLK<br>RFSR, TFSR<br>RFSW, TFSW<br>IRFS, ITFS<br>INVRFS, INVTFS<br>DTYPE<br>SLEN<br>SCLKDIV<br>RFSDIV<br>RBUF, TBUF<br>TIREG, RIREG<br>TMREG, RMREG | isters (memory-mapped)<br>Internal serial clock<br>Frame sync required<br>Frame sync width<br>Internal frame sync<br>Invert frame sense<br>Companding type, format<br>Serial word length<br>Serial clock divide<br>RFS divide<br>Autobuffering enable<br>Autobuffer I index | 0<br>0<br>0<br>0<br>0<br>0<br>undefined<br>undefined<br>undefined<br>undefined | unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>0<br>unchanged<br>unchanged |
| FO                                                                                                                                                                                 | Flag Out value                                                                                                                                                                                                                                                              | undefined                                                                      | unchanged                                                                                                                           |

Table 9.3 ADSP-2105 State After Reset Or Software Reboot

| Control Field           | Description                        | Reset         | Reboot               |
|-------------------------|------------------------------------|---------------|----------------------|
| Bus Exchange Register   |                                    |               |                      |
| PX                      | PX register                        | undefined     | undefined            |
| Status Registers        |                                    |               |                      |
| IMASK                   | Interrupt service enables          | 0             | 0                    |
| ASTAT                   | Arithmetic status                  | 0             | 0                    |
| MSTAT                   | Mode status                        | 0             | unchanged            |
| SSTAT                   | Stack status                       | 0x55          | 0x55                 |
| ICNTL                   |                                    | undefined     | unchanged            |
| IFC                     | Interrupt control                  | 0             | 0                    |
| IrC                     | Interrupt force/clear              | 0             | 0                    |
| Control Registers (mem  |                                    |               |                      |
| BWAIT                   | Boot memory wait states            | 3             | unchanged            |
| BPAGE                   | Boot page                          | 0             | unchanged            |
| SPORT1 configure        | Configuration                      | 1             | unchanged            |
| SPE0                    | SPORT0 enable                      | 0             | unchanged            |
| SPE1                    | SPORT1 enable                      | 0             | unchanged            |
| DWAIT0-4                | Data memory wait states            | 7             | unchanged            |
| PWAIT                   |                                    | 7             |                      |
|                         | Program memory wait                | -             | unchanged            |
| TCOUNT                  | Timer count register               | undefined     | operates during rebo |
| TPERIOD                 | Timer period register              | undefined     | unchanged            |
| TSCALE                  | Timer scale register               | undefined     | unchanged            |
| Serial Port Control Reg | isters (memory-mapped, one set per | SPORT)        |                      |
| ISCLK                   | Internal serial clock              | 0             | unchanged            |
| RFSR, TFSR              | Frame sync required                | 0             | unchanged            |
| RFSW, TFSW              | Frame sync width                   | 0             | unchanged            |
| IRFS, ITFS              | Internal frame sync                | 0             | unchanged            |
| INVRFS, INVTFS          | Invert frame sense                 | 0             |                      |
|                         |                                    |               | unchanged            |
| DTYPE                   | Companding type, format            | 0             | unchanged            |
| SLEN                    | Serial word length                 | 0             | unchanged            |
| SCLKDIV                 | Serial clock divide                | undefined     | unchanged            |
| RFSDIV                  | RFS divide                         | undefined     | unchanged            |
| Multichannel word en    | nable bits                         | undefined     | unchanged            |
| MCE                     | Multichannel enable                | 0             | unchanged            |
| MCL                     | Multichannel length                | 0             | unchanged            |
| MFD                     | Multichannel frame delay           | 0             | unchanged            |
| INVTDV                  | Invert transmit data valid         | 0             | unchanged            |
| RBUF, TBUF              | Autobuffering enable               | 0             | 0                    |
|                         | Autobuffer I index                 | undefined     |                      |
| TIREG, RIREG            | Autobuffer M index                 | undefined     | unchanged            |
| TMREG, RMREG            | Autobullet Millidex                | undenned      | unchanged            |
| FO (SPORT1 only)        | Flag Out value                     | undefined     | unchanged            |
| Host Interface Port Reg | isters (memory-mapped)             |               |                      |
| HDR0-5                  | HIP data registers                 | undefined     | used during HIP reb  |
| HSR6                    | HIP status register                | 0x0000        | used during HIP reb  |
| HSR7                    | HIP status register                | 0x0080        | unchanged            |
| 1010                    | HIP interrupt enables              | 0             | unchanged            |
| HMASK                   |                                    | v             | unungeu              |
| HMASK                   | I                                  |               | 0                    |
|                         | 111 State After Reset Or So        | ftware Reboot | 0                    |

| Control Field               | Description                               | Reset     | Reboot                 |
|-----------------------------|-------------------------------------------|-----------|------------------------|
| Bus Exchange Register<br>PX | PX register                               | undefined | undefined              |
| Status Registers            |                                           |           |                        |
| IMASK                       | Interrupt service enables                 | 0         | 0                      |
| ASTAT                       | Arithmetic status                         | 0         | 0                      |
| MSTAT                       | Mode status                               | 0         | unchanged              |
| SSTAT                       | Stack status                              | 0x55      | 0x55                   |
| ICNTL                       | Interrupt control                         | undefined | unchanged              |
| IFC                         | Interrupt force/clear                     | 0         | 0                      |
| Control Registers (memor    | ry-mapped)                                |           |                        |
| BWAIT                       | Boot memory wait states                   | 3         | unchanged              |
| BPAGE                       | Boot page                                 | 0         | unchanged              |
| SPORT1 configure            | Configuration                             | 1         | unchanged              |
| SPE0                        | SPORT0 enable                             | 0         | unchanged              |
| SPE1                        | SPORT1 enable                             | 0         | unchanged              |
| DWAIT0-4                    | Data memory wait states                   | 7         | unchanged              |
| PWAIT                       | Program memory wait                       | 7         | unchanged              |
| TCOUNT                      | Timer count register                      | undefined | operates during reboot |
| TPERIOD                     | Timer period register                     | undefined | unchanged              |
| TSCALE                      | Timer scale register                      | undefined | unchanged              |
| ROMENABLE                   | Program memory ROM enable                 | 0         | unchanged              |
| PDFORCE                     | Powerdown force                           | 0         | unchanged              |
| PUCR                        | Powerup context reset                     | 0         | unchanged              |
| XTALDIS                     | XTAL pindrive disable<br>during powerdown | 0         | unchanged              |
| XTALDELAY                   | Delay startup from powerdown              | 0         | unchanged              |
|                             | (4096 cycles)                             |           |                        |
| Serial Port Control Regis   | ters (memory-mapped, one set per SPOI     | RT)       |                        |
| ISCLK                       | Internal serial clock                     | 0         | unchanged              |
| RFSR, TFSR                  | Frame sync required                       | 0         | unchanged              |
| RFSW, TFSW                  | Frame sync width                          | 0         | unchanged              |
| IRFS, ITFS                  | Internal frame sync                       | 0         | unchanged              |
| INVRFS, INVTFS              | Invert frame sense                        | 0         | unchanged              |
| DTYPE                       | Companding type, format                   | 0         | unchanged              |
| SLEN                        | Serial word length                        | 0         | unchanged              |
| SCLKDIV                     | Serial clock divide                       | undefined | unchanged              |
| RFSDIV                      | RFS divide                                | undefined | unchanged              |
| Multichannel word ena       |                                           | undefined | unchanged              |
| MCE                         | Multichannel enable                       | 0         | unchanged              |
| MCL                         | Multichannel length                       | 0         | unchanged              |
| MFD                         | Multichannel frame delay                  | 0         | unchanged              |
| INVTDV                      | Invert transmit data valid                | 0         | unchanged              |
| RBUF, TBUF                  | Autobuffering enable                      | 0         | 0                      |
| TIREG, RIREG                | Autobuffer I index                        | undefined | unchanged              |
| TMREG, RMREG                | Autobuffer M index                        | undefined | unchanged              |
|                             |                                           |           |                        |

Table 9.5 ADSP-2171 State After Reset Or Software Reboot (cont. on next page)

| FO (SPORT1 only)<br>CLKODIS<br>BIASRND              | Flag Out value<br>CLKOUT disable<br>MAC biased rounding          | undefined<br>0<br>0           | unchanged<br>unchanged<br>unchanged                           |
|-----------------------------------------------------|------------------------------------------------------------------|-------------------------------|---------------------------------------------------------------|
| Host Interface Port Regis<br>HDR0-5<br>HSR6<br>HSR7 | HIP data registers<br>HIP status register<br>HIP status register | undefined<br>0x0000<br>0x0080 | used during HIP reboot<br>used during HIP reboot<br>unchanged |
| HMASK                                               | HIP interrupt enables                                            | 0                             | unchanged                                                     |

#### Table 9.5 ADSP-2171 State After Reset Or Software Reboot

| Description                                                                                                                                                                                                                                                                                                                      | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Reboot                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PX register                                                                                                                                                                                                                                                                                                                      | undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | undefined                                                                                                                                                                          |
| Interrupt service enables<br>Arithmetic status<br>Mode status<br>Stack status<br>Interrupt control<br>Interrupt force/clear                                                                                                                                                                                                      | 0<br>0<br>0x55<br>undefined<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0<br>0<br>unchanged<br>0x55<br>unchanged<br>0                                                                                                                                      |
| <i>Ty-mapped)</i><br>Boot memory wait states<br>Boot page<br>Configuration<br>SPORT0 enable<br>SPORT1 enable<br>Data memory wait states<br>Program memory wait<br>Timer count register<br>Timer period register<br>Timer scale register<br>Powerdown force<br>Powerup context reset<br>XTAL pindrive disable<br>during powerdown | 3<br>0<br>1<br>0<br>7<br>7<br>undefined<br>undefined<br>0<br>0<br>0                                                                                                                                                                                                                                                                                                                                                                                                                                            | unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>operates during reboot<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged<br>unchanged |
| Delay startup from powerdown<br>(4096 cycles)                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | unchanged                                                                                                                                                                          |
|                                                                                                                                                                                                                                                                                                                                  | PX register<br>Interrupt service enables<br>Arithmetic status<br>Mode status<br>Stack status<br>Interrupt control<br>Interrupt force/clear<br><i>y-mapped</i> )<br>Boot memory wait states<br>Boot page<br>Configuration<br>SPORT0 enable<br>SPORT1 enable<br>Data memory wait states<br>Program memory wait<br>Timer count register<br>Timer period register<br>Timer scale register<br>Powerdown force<br>Powerup context reset<br>XTAL pindrive disable<br>during powerdown<br>Delay startup from powerdown | PX registerundefinedInterrupt service enables0Arithmetic status0Mode status0Stack status0x55Interrupt controlundefinedInterrupt force/clear0 <i>y-mapped</i> )                     |

Table 9.6 ADSP-2181 State After Reset Or Software Reboot (cont. on next page)

| Serial Port Control Regist | ters (memory-mapped, one set per SPORT) |           |               |
|----------------------------|-----------------------------------------|-----------|---------------|
| ISCLK                      | Internal serial clock                   | 0         | unchanged     |
|                            |                                         | 0         | unchanged     |
| RFSR, TFSR                 | Frame sync required                     |           | unchanged     |
| RFSW, TFSW                 | Frame sync width                        | 0         | unchanged     |
| IRFS, ITFS                 | Internal frame sync                     | 0         | unchanged     |
| INVRFS, INVTFS             | Invert frame sense                      | 0         | unchanged     |
| DTYPE                      | Companding type, format                 | 0         | unchanged     |
| SLEN                       | Serial word length                      | 0         | unchanged     |
| SCLKDIV                    | Serial clock divide                     | undefined | unchanged     |
| RFSDIV                     | RFS divide                              | undefined | unchanged     |
| Multichannel word ena      |                                         | undefined | unchanged     |
| MCE                        | Multichannel enable                     | 0         | unchanged     |
| MCL                        | Multichannel length                     | 0         | unchanged     |
| MFD                        | Multichannel frame delay                | 0         | unchanged     |
| INVTDV                     | Invert transmit data valid              | 0         |               |
|                            |                                         |           | unchanged     |
| RBUF, TBUF                 | Autobuffering enable                    | 0         | 0             |
| TIREG, RIREG               | Autobuffer I index                      | undefined | unchanged     |
| TMREG, RMREG               | Autobuffer M index                      | undefined | unchanged     |
|                            |                                         | 1 (* 1    | 1 1           |
| FO (SPORT1 only)           | Flag Out value                          | undefined | unchanged     |
| CLKODIS                    | CLKOUT disable                          | 0         | unchanged     |
| BIASRND                    | MAC biased rounding                     | 0         | unchanged     |
| Entomed Montomy Control    | 1 Desistans (non moment moment)         |           |               |
|                            | l Registers (non-memory-mapped)         | 0         | 1 1           |
| DMOVLAY                    | Data memory overlay select              | 0         | unchanged     |
| PMOVLAY                    | Program memory overlay select           | 0         | unchanged     |
| (memory-mapped)            |                                         |           |               |
| DWAIT                      | Data memory overlay wait states         | 0x7       | unchanged     |
| PWAIT                      | Program memory overlay wait states      | 0x7       | unchanged     |
| BMWAIT                     | Byte memory wait states                 | 0x7       | unchanged     |
| IOWAIT0-3                  | I/O memory wait states                  | 0x7       | unchanged     |
| CMSSEL                     | Composite memory select                 | 0xB       | unchanged     |
| 0110022                    | composite memory server                 | 0.12      | antennan.geen |
| Programmable Flag Data     | & Control Registers (memory-mapped)     |           |               |
| PFDATA                     | Programmable flag data                  | undefined | unchanged     |
| PFTYPE                     | Programmable flag direction             | 0         | unchanged     |
|                            |                                         |           | -             |
| DMA Control Registers (    | memory-mapped)                          |           |               |
| IDMAA                      | IDMA Internal Memory Address            | 0x00      | unchanged     |
| IDMAD                      | IDMA Destination Memory Type            | 0         | unchanged     |
| BIAD                       | BDMA Internal Memory Address            | 0         | 0x20*         |
| BEAD                       | BDMA External Memory Address            | 0         | 0x60*         |
| BTYPE                      | BDMA Transfer Word Type                 | 0         | unchanged     |
| BDIR                       | BDMA Transfer Direction                 | 0         | unchanged     |
| BCR                        | BDMA Context Reset                      | 1         | unchanged     |
|                            |                                         |           | 0*            |
| BWCOUNT                    | BDMA Word Count                         | 0x20      | 0             |
| BMPAGE                     | External Byte Memory Page               | 0         | 0*            |

#### Table 9.6 ADSP-2181 State After Reset Or Software Reboot

\* These values assume that you have just completed an initial BDMA boot load of the ADSP-2181 (MMAP=0 & BMODE=0). For more information on BDMA register contents during the boot loading process see Table 9.8. These values will vary with a processor reboot (other than initial load), since they depend on the previous values.

| Control Field                      | Description                                    | Reset     | Reboot                 |
|------------------------------------|------------------------------------------------|-----------|------------------------|
| Bus Exchange Register<br>PX        | PX register                                    | undefined | undefined              |
| Status Registers<br>IMASK<br>ASTAT | Interrupt service enables<br>Arithmetic status | 0<br>0    | 0<br>0                 |
| MSTAT                              | Mode status                                    | 0         | unchanged              |
| SSTAT                              | Stack status                                   | 0x55      | 0x55                   |
| ICNTL                              | Interrupt control                              | undefined | unchanged              |
| IFC                                | Interrupt force/clear                          | 0         | 0                      |
| Control Registers (memo            |                                                |           |                        |
| BWAIT                              | Boot memory wait states                        | 3         | unchanged              |
| BPAGE                              | Boot page                                      | 0         | unchanged              |
| SPORT1 configure                   | Configuration                                  | 1         | unchanged              |
| SPE0                               | SPORT0 enable                                  | 0         | unchanged              |
| SPE1                               | SPORT1 enable                                  | 0         | unchanged              |
| DWAIT0-4                           | Data memory wait states                        | 7         | unchanged              |
| PWAIT                              | Program memory wait                            | 7         | unchanged              |
| TCOUNT                             | Timer count register                           | undefined | operates during reboot |
| TPERIOD                            | Timer period register                          | undefined | unchanged              |
| TSCALE                             | Timer scale register                           | undefined | unchanged              |
| ROMENABLE                          | Program memory ROM enable                      | 0         | unchanged              |
| PDFORCE                            | Powerdown force                                | 0         | unchanged              |
| PUCR                               | Powerup context reset                          | 0         | unchanged              |
| XTALDIS                            | XTAL pindrive disable<br>during powerdown      | 0         | unchanged              |
| XTALDELAY                          | Delay startup from powerdown<br>(4096 cycles)  | 0         | unchanged              |
| Serial Port Control Regis          | ters (memory-mapped, one set per SPORT         | )         |                        |
| ISCLK                              | Internal serial clock                          | 0         | unchanged              |
| RFSR, TFSR                         | Frame sync required                            | 0         | unchanged              |
| RFSW, TFSW                         | Frame sync width                               | 0         | unchanged              |
| IRFS, ITFS                         | Internal frame sync                            | 0         | unchanged              |
| INVRFS, INVTFS                     | Invert frame sense                             | 0         | unchanged              |
| DTYPE                              | Companding type, format                        | 0         | unchanged              |
| SLEN                               | Serial word length                             | 0         | unchanged              |
| SCLKDIV                            | Serial clock divide                            | undefined | unchanged              |
| RFSDIV                             | RFS divide                                     | undefined | unchanged              |
| Multichannel word ena              |                                                | undefined | unchanged              |
| MCE                                | Multichannel enable                            | 0         | unchanged              |
| MCL                                | Multichannel length                            | 0         | unchanged              |
| MFD                                | Multichannel frame delay                       | 0         | unchanged              |
| INVTDV                             | Invert transmit data valid                     | 0         | unchanged              |
| RBUF, TBUF                         | Autobuffering enable                           | 0         | 0                      |
| TIREG, RIREG                       | Autobuffer I index                             | undefined | unchanged              |
| TMREG, RMREG                       | Autobuffer M index                             | undefined | unchanged              |
|                                    |                                                |           |                        |

Table 9.7 ADSP-21msp58/59 State After Reset Or Software Reboot (cont. on next page) 9-12

| FO (SPORT1 only)<br>CLKODIS<br>BIASRND | Flag Out value<br>CLKOUT disable<br>MAC biased rounding | undefined<br>0<br>0 | unchanged<br>unchanged<br>unchanged |
|----------------------------------------|---------------------------------------------------------|---------------------|-------------------------------------|
| Host Interface Port Regist             | ters (memory-mapped)                                    |                     |                                     |
| HDR0-5                                 | HIP data registers                                      | undefined           | used during HIP reboot              |
| HSR6                                   | HIP status register                                     | 0x0000              | used during HIP reboot              |
| HSR7                                   | HIP status register                                     | 0x0080              | unchanged                           |
| HMASK                                  | HIP interrupt enables                                   | 0                   | unchanged                           |
| Analog Autobuffer/Power                | down Registers                                          |                     |                                     |
| ARBUF                                  | Receive autobuffer enable                               | 0                   | 0                                   |
| ATBUF                                  | Transmit autobuffer enable                              | 0                   | 0                                   |
| control bits                           | Analog autobuffer control bits                          | 0                   | unchanged                           |

Table 9.7 ADSP-21msp58/59 State After Reset Or Software Reboot

### 9.4.1 ADSP-2181 Register Values for BDMA Booting

The state of some ADSP-2181 registers during reset and rebooting is influenced by the MMAP and BMODE pins. If these pins are set for a BDMA boot, the values in the BDMA registers change as shown in Table 9.8.

| Register | Process Description*                                         | Value Before Boot | Value After Boot |
|----------|--------------------------------------------------------------|-------------------|------------------|
| BIAD     | BDMA Internal Memory Address.                                | 0                 | 0x20             |
|          | Set for internal address 0.                                  | 0                 | 0                |
| BEAD     | BDMA External Memory Address.<br>Set for external address 0. | 0                 | 0x60             |
| BTYPE    | BDMA Transfer Word Type.                                     | 0                 | 0                |
|          | Set for 24-bit program memory words.                         |                   |                  |
| BDIR     | BDMA Transfer Direction.                                     | 0                 | 0                |
|          | Set to transfer data from byte memory.                       |                   |                  |
| BMPAGE   | BDMA Page Selection.                                         | 0                 | 0                |
|          | Set to byte memory page 0.                                   |                   |                  |
| BWCOUNT  | BDMA Word Count.                                             | 0x20              | 0                |
|          | Set to transfer 32 words.                                    |                   |                  |
| BMWAIT   | BDMA Port Wait States.                                       | 0x7               | 0x7              |
|          | Set to 7 waits per transfer.                                 |                   |                  |
| BCR      | BDMA Context Reset. **                                       | 1                 | 1                |

#### Table 9.8 BDMA Registers Before And After Initial Boot Loading

\* Assuming MMAP=0 and BMODE=0 for a BDMA boot.

\*\* Set to 1 to (a) holdoff instruction execution during BDMA transfer, (b) start execution at address PM(0x0000) after BDMA transfer, and (c) leave a BDMA interrupt pending. This sequence of events occurs if BCR is set before BWCOUNT is written, or after the initial boot.

### 9.5 INTERRUPTS

### EXTERNAL

Each ADSP-2100 family processor has a number of prioritized, individually maskable external interrupts which can be either level- or edge-triggered. These interrupt request pins are named <u>IRQ0</u>, <u>IRQ1</u>, and <u>IRQ2</u>. The <u>IRQ0</u> and <u>IRQ1</u> pins are only available as the (optional) alternate configuration of SPORT1. The configuration of SPORT1 as either a serial port or as interrupts (and flags) is determined by bit 10 of the processor's system control register.

The ADSP-2181 processor additionally has two dedicated level-triggered interrupt request pins and one dedicated edge-triggered interrupt request pin; these are <u>IROLO</u>, <u>IROL1</u>, and <u>IROE</u>.

Internal interrupts, including serial port, timer, host interface port, DMA and analog interface interrupts, are discussed in other chapters. Additional information about interrupt masking, set up, and operation can be found in Chapter 3, "Program Control."

#### 9.5.1 Interrupt Sensitivity

Individual external interrupts can be configured in the ICNTL register as either level-sensitive or edge-sensitive.

Level-sensitive interrupts operate by asserting the interrupt request line  $(\underline{IROx})$  until the request is recognized by the processor. Once recognized, the request must be deasserted before unmasking the interrupt so that the DSP does not continually respond to the interrupt.

In contrast, edge-triggered interrupt requests are latched when any high-tolow transition occurs on the interrupt line. The processor latches the interrupt so that the request line may be held at any level for an arbitrarily long period between interrupts. This latch is automatically cleared when the interrupt is serviced. Edge-triggered interrupts require less external hardware than levelsensitive requests since there is never a need to hold or negate the request. With level-sensitive interrupts, however, many interrupting devices can share a single request input; this allows easy system expansion.

An interrupt request will be serviced if it is not masked (in the IMASK register) and a higher priority request is not pending. Valid requests initiate an interrupt servicing sequence that vectors the processor to the appropriate interrupt vector address. The interrupt vector addresses for each family processor are given in Appendix D. There is a synchronization delay

associated with both external interrupt request lines and internal interrupts.

If an interrupt occurs during a waitstated external memory access or during the extra cycles required to execute an instruction that accesses external memory more than once, it is not recognized between the cycles, only before or after. Edge-sensitive interrupts are latched, but not serviced, during bus grant (<u>BG</u>) unless the GO mode is enabled.

In order to service an interrupt, the processor must be running and executing instructions. The IDLE instruction can be used to effectively halt processor operations while waiting for an interrupt.

Edge-sensitive and level-sensitive interrupt requests are serviced similarly. Edge-sensitive interrupts may remain active (low) indefinitely, while levelsensitive interrupts must be deasserted before the RTI instruction is executed; otherwise, the same interrupt immediately recurs.

Care must be taken with the serial port (SPORT1) that can be configured for alternate functions ( $\underline{IRO0}$  and  $\underline{IRO1}$ ). If the RFS1 or TFS1 input is held low when SPORT1 is configured as the serial port and then is reconfigured as  $\underline{IRO0}$  and  $\underline{IRO1}$ , an interrupt request can be generated. This interrupt request can be cleared with the use of the IFC register.

### 9.6

#### FLAG PINS

All ADSP-21xx processors provide flag pins. The alternate configuration of SPORT1 includes a Flag In (FI) pin and a Flag Out (FO) pin. The configuration of SPORT1 as either a serial port or as flags and interrupts is selected by bit 10 of the processor's system control register.

FI can be used to control program branching, using the IF FLAG\_IN and IF NOT FLAG\_IN conditions of the JUMP and CALL instructions. These conditions are evaluated based on the last state of the FI pin; FLAG\_IN is true if FI was last sampled as a 1 and false if last sampled as a 0. FO can be used as a general purpose external signal. The state of FO is also available as a read-only bit of the SPORT1 control register.

The ADSP-2111, ADSP-2171, ADSP-2181, and ADSP-21msp58/59 processors have three additional flag output pins: FL0, FL1 and FL2. These flags (and FO) can be controlled in software to signal events or conditions to any external device such as a host processor. The Modify Flag Out instruction, which is conditional, can perform SET, RESET and TOGGLE actions—this instruction allows programs executing on the DSP processor to control the state of its flag output pins. Note that if the condition in the Modify Flag Out instruction is CE

(counter expired), the counter is not decremented as in other IF CE instructions.

Flag outputs FL0, FL1 and FL2 are set to 1 at <u>RESET</u>. The Flag Out (F0) is not affected by <u>RESET</u>.

The ADSP-2181 has eight additional general-purpose flag pins, PF7-0. These flags can be programmed as either inputs or outputs; they default to inputs following reset. The PFx pins are programmed with the use of two memory-mapped registers. The Programmable Flag & Composite Select Control Register determines the flag direction: 1=output and 0=input. The Programmable Flag Data Register is used to read and write the values on the pins. Data being read from a pin configured as an input is synchronized to the processor's clock. Pins configured as outputs drive the appropriate output value. When the PFDATA register is read, any pins configured as outputs will read back the value being driven out.

Programmable Flag & Composite Select Control







Figure 9.5 Programmable Flag Data Register (ADSP-2181)

### 9.7 POWERDOWN

The ADSP-2171, ADSP-2181, and ADSP-21msp58/59 provide a powerdown feature that allows the processor to enter a very low power dormant state through hardware or software control. In this CMOS standby state, power consumption is less than 1 mW (approximate). (Refer to the processor data sheet for exact power consumption specifications.)

The powerdown feature is useful for applications where power conservation is necessary, for example in battery-powered operation. Features of powerdown include:

- Internal clocks are disabled
- Processor registers and memory contents are maintained
- Ability to recover from powerdown in less than 100 CLKIN cycles
- Ability to disable internal oscillator when using crystal
- No need to shut down clock for lowest power when using external oscillator
- Interrupt support for executing "housekeeping" code before entering powerdown and after recovering from powerdown
- User selectable powerup context

Even though the processor is put into the powerdown mode, the lowest level of power consumption still might not be achieved if certain guidelines are not followed. Lowest possible power consumption requires no additional current flow through processor output pins and no switching activity on active input pins. Therefore, a careful analysis of pin loading in your circuit is required. The following sections detail the proper powerdown procedure as well as provide guidelines for clock and output pin connections required for optimum low-power performance.

#### 9.7.1 Powerdown Control

You can control several parameters of powerdown operation through control bits in the SPORT1 Autobuffer/Powerdown Control Register (or Analog Autobuffer/Powerdown Control Register on the ADSP-21msp58/59). This control register is memory-mapped at location 0x3FEF and is shown in Figure 9.6.



#### Figure 9.6 SPORT1 Autobuffer / Powerdown Control Register

\* PUCR=1: Clears the PC, STATUS, LOOP and CNTR stacks. IMASK and ASTAT registers are cleared to 0 and SSTAT is set to 0x55. The processor will start executing instructions from address 0x0000.

9 - 18

#### 9.7.2 Entering Powerdown

The powerdown sequence is defined as follows.

- 1.) Initiate the powerdown sequence by applying a high-to-low transition to the <u>PWD</u> pin or by setting the powerdown force control bit (PDFORCE) in the SPORT1 Autobuffer/Powerdown Control Register.
- 2.) The processor vectors to the non-maskable powerdown interrupt vector at address 0x002C. (Note: The powerdown interrupt is never masked. You must be careful not to cause multiple powerdown interrupts to occur or stack overflow may result. Multiple powerdown interrupts can occur if the <u>PWD</u> input is pulsed while the processor is already servicing the powerdown interrupt.)
- 3.) Any number of housekeeping instructions, starting at location 0x002C, can be executed prior to the processor entering the powerdown mode. Typically, this section of code is used to configure the powerdown state, disable on-chip peripherals and clear pending interrupts.
- 4.) The processor now enters powerdown mode when it executes an IDLE instruction (while <u>PWD</u> is asserted). The processor may take either one or two cycles to power down depending upon internal clock states during the execution of the IDLE instruction. All register and memory contents are maintained while in powerdown. Also, all active outputs are held in whatever state they are in before going into powerdown.

If an RTI is executed before the IDLE instruction, then the processor returns from the powerdown interrupt and the powerdown sequence is aborted.

While the processor is in the powerdown mode, the processor is in CMOS standby. This allows the lowest level of power consumption where most input pins are ignored. Active inputs need to be held at CMOS levels to achieve lowest power. More information can be found in the section "Operation During Powerdown" later in this chapter.

### 9.7.3 Exiting Powerdown

The powerdown mode can be exited with the use of the <u>PWD</u> pin or with <u>RESET</u>. There are also several user-selectable modes for start-up from powerdown which specify a start-up delay as well as specify the program flow after start-up. This allows the program to resume from where it left off before powerdown or for the program context to be cleared.

#### 9.7.3.1 Ending Powerdown With The <u>PWD</u> Pin

Applying a low-to-high transition to the <u>PWD</u> pin will take the processor out of powerdown mode. You have the option of selecting the amount of time the processor takes to come out of the powerdown mode with the "delay start-up from powerdown" control bit (XTALDELAY, bit 14 in the Powerdown Control Register.) If this bit is cleared to 0, no additional delay over the quick start-up (100 cycles) is introduced. If this bit is set to 1, a delay of 4096 cycles is introduced. The delay feature is used depending upon the state of an external clock oscillator at the time of powerup or if the internal clock is disabled. This is further discussed in the sections "Systems Using an External TTL/CMOS Clock" and "Systems Using a Crystal and The Internal Oscillator."

You can also program one of two options directing the processor how to resume operation. The context for exiting powerdown is set by bit 12 (PUCR, powerup context reset) of the Powerdown Control Register.

If the PUCR control bit is cleared to 0, the processor will continue to execute instructions following the IDLE instruction. For example, a high-to-low transition is applied to the <u>PWD</u> pin which causes the processor to vector to the powerdown interrupt routine. In this routine, a few housekeeping tasks are performed and the IDLE instruction is executed. The processor powers down. Some time later a low-to-high transition is applied to the <u>PWD</u> pin, causing the processor to exit powerdown mode. Since the PUCR bit is 0, the processor resumes executing instructions in the powerdown interrupt routine, starting at the instruction following the IDLE instruction. When an RTI instruction is encountered, control then passes back to the main routine.

If the PUCR bit is set to 1 for a clear context, the processor resumes operation from powerdown by clearing the PC, STATUS, LOOP and CNTR stacks. The IMASK and ASTAT registers are set to 0 and the SSTAT goes to 0x55. The processor will start executing instructions from address 0x0000.

### 9.7.3.2 Ending Powerdown With The RESET Pin

If <u>RESET</u> is asserted while the processor is in the powerdown mode, the processor is reset and instructions are executed from address 0x0000. A boot is performed if the MMAP pin is set to 0. If the <u>RESET</u> pin is used to exit powerdown, then it must be held low for the appropriate number of cycles. If the clock is stopped at powerup or operating at a different frequency at powerup than it was before powerdown, <u>RESET</u> must be held long enough for the oscillator to stabilize plus an additional 1000 CLKIN cycles for the phase locked loop to lock. The time required for the oscillator to stabilize depends upon the type of crystal used and capacitance of the external crystal circuit. Typically 2000 CLKIN cycles is adequate for clock stabilization time.

If the clock was not stopped at powerup and is at a stable frequency at powerup (same as before powerdown), only 5 cycles of <u>RESET</u> are required.

When ending powerdown with <u>RESET</u>, the XTALDELAY (delay start-up from powerdown) control bit is ignored.

### 9.7.4 Startup Time After Powerdown

The time required to exit the powerdown state depends on whether an internal or external oscillator is used, and the method used to exit powerdown.

### 9.7.4.1 Systems Using An External TTL/CMOS Clock

When the processor is in powerdown, the external clock signal is ignored if the XTALDIS bit (XTAL pin disable) of the Powerdown Control Register is set to 1. It is therefore not necessary to stop the external clock since no power is wasted while the external clock is running. If the external clock is to be stopped anyway, it must be kept running for (at least) one additional cycle after the IDLE instruction is executed.

The XTALDIS bit should always be set before entering powerdown. This specifies that the XTAL pin is not to be driven by the processor. During powerdown there is no need to drive the XTAL pin when an external oscillator is used. Disabling the XTAL pin drive during powerdown lets the input clock run without wasting power.

After the processor is taken out of the powerdown mode by either the  $\underline{PWD}$  pin or <u>RESET</u>, it will begin executing instructions after a maximum startup time of 100 CLKIN cycles as long as the clock oscillator is stable and at the same frequency as before powerdown.

If the external clock is unstable when the processor exits powerdown, then the XTALDELAY control bit can be used. This allows time for the external clock to stabilize by inserting an additional 4096-cycle delay before the processor starts to execute instructions. The start-up delay can only be used when the processor is taken out of powerdown mode with the <u>PWD</u> pin.

If the processor is taken out of powerdown by <u>RESET</u> and the clock is stable and at the same frequency as before powerdown, <u>RESET</u> needs to be held for only 5 cycles.

#### 9.7.4.2 Systems Using A Crystal And The Internal Oscillator

A trade-off can be made so that a fast start-up is possible, but power is consumed by leaving the oscillator running during powerdown. If a fast start-up is desired, then you must clear bits 14 (XTALDELAY) and 15 (XTALDIS) of the Powerdown Control Register to 0 before entering powerdown. This selects no additional delay after start-up from powerdown and drives the external crystal during powerdown. In this configuration, the oscillator will continue to operate and the processor will start executing instructions in less than 100 cycles after the low to high signal transition at the <u>PWD</u> pin. The XTAL pin will also be driven and the powerdown power consumption will be higher than the 1 mW specification. The following code example shows the powerdown interrupt routine.

```
{ Sample Powerdown Code }
{ Located at interrupt vector address 0x002C }
    pwd_int: ax0 = 0x0000; { enable crystal, no delay }
        dm(0x3FEF) = ax0;
        idle;
        rti;
```

*If lowest possible power consumption is required, then you must set the XTALDELAY and XTALDIS bits to 1 before entering powerdown*. This selects the additional 4096 cycle delay to allow the oscillator to start and the phase locked loop to lock after start-up and disables the drive to the XTAL pin during powerdown. The following code example shows the powerdown interrupt routine.

```
{ Sample Powerdown Code }
{ Located at interrupt vector address 0x002C }
    pwd_int: ax0 = 0xC000; { disable crystal, delay }
        dm(0x3FEF) = ax0;
        idle;
        rti;
```

9 – 22

Depending on the particular situation and external system conditions, the powerdown modes shown above could be set conditionally. If you want to powerdown for a long time you may want to set the mode for lowest power consumption. If you want to powerdown for a short time, lowest power consumption may not be that important.

If the <u>RESET</u> pin is used to exit powerdown and the clock has been stopped, then <u>RESET</u> must be held low for 1000 CLKIN cycles plus the time required for the phase locked loop to lock and the crystal oscillator to stabilize (typically 2000 CLKIN cycles.) If the clock is running during powerdown, a <u>RESET</u> signal of only 5 cycles is required.

### 9.7.5 Processor Operation During Powerdown

Some processor circuitry may still be active during powerdown mode. Also, some output pins remain active. A good understanding of these states will allow you to determine the best low-power configuration for your system. By keeping output loading and input switching to a minimum the lowest possible power consumption can be achieved.

### 9.7.5.1 Interrupts And Flags

Interrupts are latched and can be serviced if the processor exits powerdown without a context reset (PUCR=1). Any activity on the interrupt or flag input pins during powerdown will increase the power consumption. There should also be no resistive load on the flag output pins (as with any active output pin) if lowest power is desired.

### 9.7.5.2 SPORTS

The circuitry of the serial ports is not directly affected by powerdown. The SPORTs are indirectly affected if an internally generated SCLK or frame sync is required. SPORT circuitry continues to operate during powerdown.

It is possible to clock data into or out of the serial ports during powerdown. You must supply an external serial clock to support operation during powerdown. No interrupts or autobuffer operations will be serviced during powerdown. Instead, the SPORT interrupts are latched and can be serviced if the processor exits powerdown without resetting the processor. Data clocked into the processor will remain in the receive (RX) registers. Autobuffer transfers will occur after the device exits powerdown if the processor is not powered up with <u>RESET</u>. Note that any SPORT activity will increase the power consumption above the 1 mW specification.

If an external serial clock and an external frame sync signal are supplied, data can be clocked into the RX register or out of the TX register during powerdown. Since the TX register can not be updated while the processor is in powerdown, the same value is repeatedly clocked out the serial port. Also, data in the RX register is continually overwritten since the RX register can not be read by the processor during powerdown.

If an external serial clock is used with an internal frame sync, frame sync signals continue to be generated during powerdown since they are derived from the serial clock. Data bits continue to be received with the RX register being overwritten. Since data is only transmitted when the TX register is written, data bits are only transferred out of the processor if the processor is put in powerdown during a serial port transfer. While the processor is being put into powerdown, the serial port transfer in progress is allowed to complete. Since an internally generated transmit frame sync is used, no subsequent frame syncs are generated while in powerdown.

If internal serial clock is used, there is no SPORT activity during powerdown; the serial clock stops.

Lowest power dissipation is achieved when active SPORT pins are not changing during powerdown and are held at CMOS levels.

#### 9.7.5.3 HIP During Powerdown

The circuitry of the Host Interface Port (HIP) is not directly affected by powerdown on the ADSP-2171 and ADSP-21msp58/59. The HIP is indirectly affected since the processor, when in powerdown, is unable to service interrupts or read and write HIP data registers. HIP circuitry continues to operate during powerdown.

The host can write to the HIP register during powerdown but the processor is disabled and cannot service interrupts. Instead, HIP interrupts are latched and can be serviced if the processor exits powerdown without a context reset (PUCR=1).

If the HDR overwrite bit (bit 7 in HSR7) is cleared, a host acknowledge signal will not be asserted until the processor has read data written by the host. During powerdown, the processor is unable to read the data register and the host acknowledge signal will not be asserted. Care must be taken in a system where the host waits for a host acknowledge. In this case, it is possible that the host will "hang" waiting for the acknowledge while the DSP processor is in powerdown.

While in powerdown, the processor can be reset by writing the HSR software reset bit. This will produce the same results as asserting the <u>RESET</u> pin for five cycles (minimum <u>RESET</u> pulse) on the processor. If an external crystal is used and the clock has been stopped, this reset duration is too short; therefore software reset cannot be used in this mode. Note that any HIP activity will increase the power consumption above the 1 mW specification.

Two mode pins, HMD0 and HMD1, are used to put the processor's HIP into one of four possible modes. When HMD0 = 1, the HIP data bus is multiplexed for both address and data. In this case, the HIP data bus inputs are active during powerdown and any bus activity will result in higher power dissipation. Also, inputs must be at CMOS levels. If this host mode is used and there is potential for the bus to be floating, pull-up resistors should be used on the data lines. If you desire the host to communicate with other devices on the bus while the DSP processor is in powerdown, HMD0 should be held low to avoid extra power to be dissipated. When the HIP is put in other modes where data inputs are not active this is not a problem.

Lowest power dissipation is achieved when the HIP pins are not changing during powerdown and are held at CMOS levels.

### 9.7.5.4 IDMA Port During Powerdown (ADSP-2181)

The IDMA port can receive data during powerdown, but it can not respond with an acknowledge (<u>IACK</u>) signal or increment the IDMA internal address. If you are using a short read or short write and are in the middle of an IDMA transfer, you can complete a single read or write while the processor is in powerdown. If you are using the long read or long write method and are in the middle of an IDMA transfer, your host must be able to handle a "timeout" condition, as the DSP will not return an acknowledge to the transfer in process.

Note that IDMA activity while the DSP is in powerdown uses power and should be avoided to conserve power. For more information on lowest power use, see "Conditions For Lowest Power Consumption."

### 9.7.5.5 BDMA Port During Powerdown (ADSP-2181)

Do not powerdown the ADSP-2181 during a BDMA transfer. If you do, the DSP will not be able to recover correctly from powerdown and the contents of memory accessed by the ADSP-2181's BDMA port will be corrupted.

If you need to go into powerdown mode, either:

- Verify that the BWCOUNT register contains a zero. If a BDMA transfer is in process, poll the BWCOUNT register to determine when the transfer is done. *or*
- Abort any BDMA transfer in progress by writing 1 to the BWCOUNT register and go into powerdown when the BWCOUNT register contains a zero. (Note that the BDMA transfer is not properly completed in this case.)

### 9.7.5.6 Analog Interface (ADSP-21msp5x)

You must powerdown the ADSP-21msp58/59's analog interface separately from the processor, as described in the Analog Interface chapter of this manual. The analog interface does not work during powerdown and causes additional power to be dissipated if it is not disabled. The following code example shows a powerdown interrupt routine for the ADSP-21msp58/59:

```
{ Sample Powerdown Code }
{ located at address 0x002C }
pwd_int: ax0 = 0x0000; { powerdown analog interface}
    dm(0x3FEE) = ax0;
    ax0 = 0x0000; { enable crystal, no delay}
    dm(0x3FEF) = ax0;
    NOP;
    idle;
    rti;
```

It takes three cycles for the analog interface to powerdown. The IDLE instruction should not be executed before these three cycles have elapsed.

### 9.7.6 Conditions For Lowest Power Consumption

The state of all processor pins during powerdown is shown in Table 9.9.

To assure the lowest power consumption, all active input pins should be held at a CMOS level. All active output pins should be free of resistive load since

load current will increase power dissipation. Some pins will be in one of several states depending upon the connection of mode pins. For example, the ADSP-2171's HIP data bus pins may be either active or inactive depending whether a host write is in progress or how the host mode pins are connected. You must perform a careful analysis of each input and output pin in order to insure lowest power dissipation.

Some inputs are active but ignored. The state of these inputs does not matter as long as they are at a CMOS level.

| <u>Pin</u>   | <u>Direction</u> | <u>State During Powerdown</u>                                                                                           |
|--------------|------------------|-------------------------------------------------------------------------------------------------------------------------|
| <u>RESET</u> | Ι                | Active                                                                                                                  |
| PWD          | Ι                | Active                                                                                                                  |
| IRQ2         | Ι                | Active, latched but not serviced                                                                                        |
| IRQE         | Ι                | (ADSP-2181) Active, latched but not serviced                                                                            |
| IRQL0        | Ι                | (ADSP-2181) Active, latched but not serviced                                                                            |
| IRQL1        | Ι                | (ADSP-2181) Active, latched but not serviced                                                                            |
| MMAP         | Ι                | Active                                                                                                                  |
| <u>BR</u>    | Ι                | Active, no response until after powerdown                                                                               |
| BG           | О                | Driven HIGH unless bus is granted                                                                                       |
| CLKIN        | Ι                | Input buffer inactive, but XTAL oscillator is active unless XTALDIS bit is set                                          |
| CLKOUT       | Ο                | Driven HIGH                                                                                                             |
| XTAL         | Ο                | Driven HIGH if XTALDIS set, inversion of CLKIN otherwise                                                                |
| PWDACK       | 0                | Driven HIGH                                                                                                             |
| PMS          | 0                | Driven HIGH, high impedance if bus granted                                                                              |
| DMS          | 0                | Driven HIGH, high impedance if bus granted                                                                              |
| BMS          | 0                | Driven HIGH, high impedance if bus granted                                                                              |
| IOMS         | О                | (ADSP-2181) Driven HIGH, high impedance if bus granted                                                                  |
| CMS          | О                | (ADSP-2181) Driven HIGH, high impedance if bus granted                                                                  |
| RD           | О                | Driven HIGH, high impedance if bus granted                                                                              |
| WR           | Ο                | Driven HIGH, high impedance if bus granted                                                                              |
| ADDR<13:0>   | > O              | High impedance                                                                                                          |
| DATA<23:0>   | > I              | Inactive                                                                                                                |
| DATA<23:0>   | > 0              | High impedance                                                                                                          |
| SCLK0        | Ι                | Active                                                                                                                  |
| SCLK0        | О                | Driven to static level if internal, high impedance otherwise                                                            |
| TFS0         | Ι                | Active if SPORT 0 is enabled                                                                                            |
| TFS0         | 0                | Driven if configured internal or in multichannel mode and SPORT 0                                                       |
|              |                  | enabled, high impedance otherwise                                                                                       |
| RFS0         | Ι                | Active if SPORT 0 is enabled                                                                                            |
| RFS0         | 0                | Driven if configured internal and SPORT 0 enabled, high impedance                                                       |
| DDA          | Ŧ                | otherwise                                                                                                               |
| DR0          | I                | Active if SPORT 0 is enabled                                                                                            |
| DT0          | 0                | Driven if serial port operating. Output may be static or changing depending upon serial clock, high impedance otherwise |
|              |                  |                                                                                                                         |

Table 9.9 Pin States During Powerdown (cont. on next page)

| <u>Pin</u> <u>Dir</u> | ection | State During Powerdown                                                                                                |
|-----------------------|--------|-----------------------------------------------------------------------------------------------------------------------|
| SCLK1                 | Ι      | Active                                                                                                                |
| SCLK1                 | Ο      | Driven to a static level if internal, high impedance otherwise                                                        |
| TFS1/ <u>irq1</u>     | I      | Active if SPORT 1 is enabled or configured alternate ( <u>IRQ1</u> )                                                  |
| TFS1                  | 0      | Driven if SPORT 1 is enabled and configured for internal transmit framing,                                            |
| RFS1/ <u>irq0</u>     | Ι      | high impedance otherwise<br>Active if SPORT 1 is enabled or configured alternate ( <u>IRQ0</u> )                      |
| RFS1                  | I<br>O | Driven if SPORT 1 is enabled of configured attenuate ( <u>1KQU</u> )                                                  |
| iu or                 | U      | high impedance otherwise                                                                                              |
| DR1/FLAGIN            | Ι      | Active if SPORT 1 is enabled or configured alternate (FLAGIN)                                                         |
| DT1/FLAGOUT           | 0      | Driven if serial port operating. Output may be static or changing depending                                           |
|                       |        | upon serial clock. Driven if SPORT 1 is enabled or configured alternate                                               |
|                       |        | (FLAGOUT)                                                                                                             |
| FL<2:0>               | 0      | Driven to previous value                                                                                              |
| PF<7:0>               | I/O    | (ADSP-2181) Active                                                                                                    |
| BMODE                 | Ι      | Active                                                                                                                |
|                       | Ŧ      |                                                                                                                       |
| IRD                   | I<br>I | (ADSP-2181) Active, if <u>IS</u> asserted                                                                             |
| <u>IWR</u><br>IS      | I<br>I | ( <i>ADSP-2181</i> ) Active, if <u>IS</u> asserted<br>( <i>ADSP-2181</i> ) Active                                     |
| IAL                   | I      | (ADSP-2181) Active, if $\underline{IS}$ asserted                                                                      |
| IAD                   | Î/O    | (ADSP-2181) Active, if an operation in progress                                                                       |
| IACK                  | Ó      | (ADSP-2181) Active                                                                                                    |
| HSIZE                 | I      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HMD0                  | I      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HMD1                  | Ī      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HSEL                  | Ι      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HRD                   | Ι      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HWR                   | Ι      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HADR<2:0>             | I      | (ADSP-2171, ADSP-21msp5x) Active                                                                                      |
| HDATA<15:0>           | Ι      | ( <i>ADSP-2171, ADSP-21msp5x</i> ) Active if host writing or HMD1 and                                                 |
| HDATA<15:0>           | 0      | HA2/HALE HIGH, inactive otherwise ( <i>ADSP-2171, ADSP-21msp5x</i> ) Driven if host reading, high impedance otherwise |
| HACK                  | 0      | (ADSP-2171, ADSP-21msp5x) Driven in host reading, high impedance otherwise (ADSP-2171, ADSP-21msp5x) Driven           |
| VIN (NORM)            | I      | ( <i>ADSP-21msp5x</i> ) Inactive, set analog powerdown bit                                                            |
| VIN (AUX)             | Ī      | (ADSP-21msp5x) Inactive, set analog powerdown bit                                                                     |
| VFB (NORM)            | Ο      | (ADSP-21msp5x) Inactive, set analog powerdown bit                                                                     |
| VFB (AUX)             | 0      | ( <i>ADSP-21msp5x</i> ) Inactive, set analog powerdown bit                                                            |
| VOUTP                 | 0      | (ADSP-21msp5x) Driven low in powerdown                                                                                |
| VOUTN                 | 0      | (ADSP-21msp5x) Driven low in powerdown                                                                                |
| VREF                  | Ο      | (ADSP-21msp5x) Reference turned off                                                                                   |

 Table 9.9
 Pin States During Powerdown

### 9.7.7 PWDACK Pin

The powerdown acknowledge pin (PWDACK) is an output that indicates when the processor is powered down. This pin is driven high by the processor when it has powered down and is driven low when the processor has completed its powerup sequence. A low level on the PWDACK pin also indicates that there is a valid CLKOUT signal and that instruction execution has begun. Figure 9.7 shows an example of timing for the powerdown and restart sequence.

The processor is executing code when the <u>PWD</u> pin is brought low. The processor vectors to the powerdown interrupt vector and an IDLE instruction is executed causing the processor to go into powerdown. The CLKOUT and PWDACK signals are driven high by the processor. At this point, the input clock pin is ignored. If the processor is put into the powerdown mode via the powerdown force bit in the powerdown control register, the result is the same as described above.

The input clock is started and the <u>PWD</u> pin is brought high. After the necessary start-up cycles the processor brings the PWDACK output low, begins driving the CLKOUT pin with a clock signal and begins to fetch the instruction after the IDLE instruction. The processor then resumes normal operation.



Figure 9.7 Powerdown Timing Example

When powerdown is terminated with the <u>RESET</u> pin or if a start-up delay is selected, a low level on the PWDACK pin only indicates the start of oscillations on the CLKOUT pin. It will not necessarily indicate the start of instruction execution.

The state of PWDACK and also the CLKOUT signal is undefined during the first 100 cycles of initial reset.

#### 9.7.8 Using Powerdown As A Non-Maskable Interrupt

The powerdown interrupt is never masked. It is possible to use this interrupt for other purposes if desired. The processor will not go into powerdown until an IDLE instruction is executed. If an RTI is executed before the IDLE instruction, then the processor returns from the powerdown interrupt and the powerdown sequence is aborted.

It is possible to place a series of instructions at the powerdown interrupt vector location 0x002C. This routine should end with an RTI instruction and not contain an IDLE instruction if the interrupt is to be used for purposes other than powerdown.