# INTEGRATED CIRCUITS



Objective specification File under Integrated Circuits, IC01 1997 Aug 12



HILIP

### **Objective specification**

### ATAPI CD-R block decoder

### CONTENTS

| 1      | FEATURES                                     |
|--------|----------------------------------------------|
| 2      | GENERAL DESCRIPTION                          |
| 2.1    | Memory mapped control registers              |
| 2.2    | Error correction features                    |
| 2.3    | Host interface features                      |
| 2.4    | Buffer memory organisation                   |
| 2.5    | Subcode handling features                    |
| 2.5    | Multimedia output audio control features     |
| -      |                                              |
| 3      | QUICK REFERENCE DATA                         |
| 4      | ORDERING INFORMATION                         |
| 5      | BLOCK DIAGRAM                                |
| 6      | PINNING                                      |
| 6.1    | Detailed description of pin functions        |
| 7      | FUNCTIONAL DESCRIPTION                       |
| 7.1    | Memory field description                     |
| 7.1.1  | DVD-ROM memory field information             |
| 7.2    | CD input control registers                   |
| 7.2.1  | Registers associated with data in process    |
| 7.3    | Multimedia output interface                  |
| 7.3.1  | Subcode input block                          |
| 7.3.2  | Subcode mode transmit control register       |
| 7.3.3  | General description of the multimedia output |
|        | interface                                    |
| 7.3.4  | IEC 958/EBU output                           |
| 7.3.5  | Memory-to-memory block copy function         |
| 7.4    | Interrupt registers                          |
| 7.4.1  | Interrupt 1                                  |
| 7.4.2  | Interrupt 2                                  |
| 7.4.3  | UART interrupt                               |
| 7.5    | Host interface                               |
| 7.5.1  | Introduction                                 |
| 7.5.2  | Description of the host interface block      |
| 7.5.3  | Description of the host interface registers  |
| 7.5.4  | Transfer counter                             |
| 7.5.5  | Packet size store                            |
| 7.5.6  | Sequencer status                             |
| 7.5.7  | Host interface DMA special bits              |
| 7.5.8  | Automatic block pointer reload programming   |
| 7.5.9  | DMA transfer programming of the host         |
|        | interface                                    |
| 7.5.10 | Generic interface operation                  |
| 7.5.11 | DMA transfers in generic mode                |

| 7.5.12<br>7.5.13        | Normal DMA mode<br>Burst DMA mode using multiplexed bus                               |
|-------------------------|---------------------------------------------------------------------------------------|
| 7.6<br>7.6.1            | configuration<br>Microcontroller interface<br>Kernel based firmware                   |
| 7.6.2<br>7.7            | 16-bit registers automatic read and write<br>8051 CPU and memory management functions |
| 7.7.1<br>7.7.2<br>7.7.3 | Sub-CPU bus access timing<br>Buffer memory organisation<br>Subpage                    |
| 7.8<br>7.8              | External memory interface<br>DRAM interface configuration register                    |
| 7.9<br>7.9<br>7.9.1     | UART for communication with CD engine<br>UART basic engine interface                  |
| 7.10<br>7.10.1          | Clock generation control<br>Crystal oscillator                                        |
| 7.10.2<br>7.10.3        | Sub-CPU clock control register<br>SAA7381 system clock control registers              |
| 8                       | LIMITING VALUES                                                                       |
| 9                       | THERMAL CHARACTERISTICS                                                               |
| 10                      | CHARACTERISTICS                                                                       |
| 11                      | TIMING CHARACTERISTICS                                                                |
| 11.1<br>11.2            | External memory interface timing<br>Host interface timing                             |
| 11.2.1<br>11.2.2        | Host interface ATAPI PIO and DMA timing ATA bus timing                                |
| 11.2.3                  | Ultra DMA operation and timing                                                        |
| 11.2.4                  | Ultra DMA read/write timing                                                           |
| 11.3<br>11.4            | Sub-CPU interface timing UART timing                                                  |
| 12                      | APPENDIX A                                                                            |
| 13                      | APPLICATION INFORMATION                                                               |
| 14                      | PACKAGE OUTLINE                                                                       |
| 15                      | SOLDERING                                                                             |
| 15.1                    | Introduction                                                                          |
| 15.2                    | Reflow soldering                                                                      |
| 15.3<br>15.4            | Wave soldering<br>Repairing soldered joints                                           |
| 16                      | DEFINITIONS                                                                           |
| 17                      | LIFE SUPPORT APPLICATIONS                                                             |
|                         |                                                                                       |

### SAA7381

### **1 FEATURES**

- Supports real time error detection and correction in hardware. Error correction to n = 27, error detect to n = 30 and raw data transfer to n = 32.
- DVD-ROM supported in combination with the SAA7335
- Direct generic interface to external Small Computer Systems Interface (SCSI) controller devices
- Operates with up to 16 Mbytes DRAM
  - Hyper-page DRAM up to 33 Mbytes words/s burst
  - Fast-page DRAM at up to 17.5 Mbytes words/s burst
- Has fixed n = 1 or n = 2 rate (44.1 or 88.2 kHz) I<sup>2</sup>S-bus multimedia output for simple audio/video output; features for CAV/quasi-CLV support
  - Supports Philips multimedia audio CODEC
  - Provides 'SHOARMA' Red Book audio buffer
- IEC 958 (SPDIF, AES/EBU and DOBM) output with Q-W subcode and programmable category code, output at n = 1 rate
- Device registers are memory mapped for faster direct access to the chip
- Provides direct access from sub-CPU to buffer RAM to support scratchpad accesses. This eliminates the need for extra RAM chips in the system
- Automatic sequencing of ATAPI packet command protocol, including command termination
- Automated data transfers to and from the host using PIO, DMA and ultra DMA.

### 2 GENERAL DESCRIPTION

The SAA7381 is a block decoder/encoder and buffer manager for high-speed CD-ROM/CD-R functions, that integrates real time error correction and detection and bidirectional ATAPI transfer functions into a single chip.

### 2.1 Memory mapped control registers

The SAA7381 device has a large number of memory mapped registers. These are arranged so that high-level languages see the registers as external byte or 16-bit integer quantities. The block addressing of the SAA7381 facilitates the use of pairs of 16-bit quantities to represent addresses. The reading and writing of 16-bit registers within the device can be performed by two separate 8-bit reads, where the second byte data is latched at the same time as the first byte is read.

### 2.2 Error correction features

The SAA7381 has an on-chip 36 kbits memory that is used as a buffer memory for error and erasure correction processing. This buffer memory reduces the number of external RAM accesses that are needed for error correction and thus allows for an increased rate of data throughput.

The error corrector is switchable between two-pass, single-pass [both with Error Detection/Correction (EDC/ECC)] and EDC only modes to further improve throughput. The presence of the full error corrector removes the need for firmware based control of the error corrector's operation.

### 2.3 Host interface features

The SAA7381 has an ATAPI host interface that may be directly connected to the ATAPI bus thereby reducing the need for external support devices. It supports PIO Mode 4 transfer and Mode 0 ultra DMA. This interface can also be configured as a generic DMA interface for use with external host interface devices (e.g. SCSI controller). The DMA interface has the following features:

- ATAPI command packets are automatically loaded into the command FIFO
- Data transfer to the host is automatically sequenced to reduce inter-block latencies and improve host CPU utilisation
- Host data transfer rate is independent of error corrector operation and the data input path
- The host interface features automatic determination of block length for Mode 2, Form 1 and Form 2 sectors. The block length transferred is programmable.
- The host interface can transfer up to 3 sub-blocks per sector, with each sub-block being transferred dependent on the Form bit. Automatic reload of sub-block pointers and unconditional transfer are supported.

## SAA7381

### 2.4 Buffer memory organisation

Memory is mapped as a 16-bit block number and 12-bit offset into that block. The block oriented memory structure permits the use of 16-bit pointers in software thereby minimising the overhead of accessing memory. The address can be found from the following equation: address = block number  $\times$  2560 + offset.

The microcontroller sees the SAA7381 as a memory mapped peripheral, with control and status registers appearing in the upper address space.

The lowest 52 kbytes (48 kbytes + 4 kbytes) of the 8051 microcontroller external address space is mapped as a window into the memory on a user-specified 1 kbyte boundary within the buffer RAM. This can be used as a scratchpad memory.

The next 4 kbytes is separately mapped as a window into the memory on a user-specified 1 kbyte boundary within the RAM.

The next 7.5 kbytes of the external data space consists of three independently addressed memory segments for accessing block data, subcode information and block headers.

The registers of the SAA7381 are mapped into the top 256 bytes of external data space.

### 2.5 Subcode handling features

The writing of data into the buffer RAM is aligned to the absolute time sync marker with the following features:

- Subcodes are written into memory together with their associated sector data. This eases the provision of specialist features, for example CD + G or Karaoke CD applications.
- All channels of subcode are de-interleaved
- The Q channel is also Cyclic Redundancy Checked (CRC) for increased reliability
- When operating in 3-wire subcode mode, it is possible to control or read the P bit in the P-W subcode stream.

### 2.6 Multimedia output audio control features

The I<sup>2</sup>S-bus input may be processed before feeding to the multimedia audio output in several simple ways:

- As audio is transferred via the buffer memory, it is not necessary to have the CD-DSP I<sup>2</sup>S-bus input at exactly the audio n = 1 or video n = 2 rate. Any faster speed will work because the buffer RAM is used as a FIFO.
- Both channels may be independently controlled. The left channel output may be sourced from zero (digital silence), left or right input; this also applies for the right channel output. This permits basic audio switching and channel swapping.
- IEC 958 (SPDIF, AES/EBU and DOBM) output with Q-W subcode and programmable category code, can be output from the same CD-DSP I<sup>2</sup>S-bus data source.

| SYMBOL                 | PARAMETER                         | MIN.                   | TYP.                                  | MAX. | UNIT |
|------------------------|-----------------------------------|------------------------|---------------------------------------|------|------|
| V <sub>DDD(core)</sub> | digital core supply voltage       | 3.0                    | 3.3                                   | 3.6  | V    |
| V <sub>DDD(pad)</sub>  | digital peripheral supply voltage | V <sub>DDD(core)</sub> | 5.0 or 3.3                            | 5.0  | V    |
| I <sub>DDD</sub>       | supply current                    | tbf                    | 60                                    | tbf  | mA   |
| f <sub>xtal</sub>      | crystal frequency                 | 8                      | 8.4672, 11.289,<br>16.9344 or 33.8688 | 35   | MHz  |
| T <sub>amb</sub>       | operating ambient temperature     | 0                      | -                                     | 70   | °C   |
| T <sub>stg</sub>       | storage temperature               | -55                    | -                                     | +125 | °C   |

### **3 QUICK REFERENCE DATA**

### 4 ORDERING INFORMATION

| TYPE    |         |                                                                                     |          |  |  |  |
|---------|---------|-------------------------------------------------------------------------------------|----------|--|--|--|
| NUMBER  | NAME    | NAME DESCRIPTION VERSION                                                            |          |  |  |  |
| SAA7381 | LQFP144 | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm | SOT486-1 |  |  |  |

## SAA7381

### 5 BLOCK DIAGRAM



# SAA7381

### 6 PINNING

| SYMBOL                  | PIN | TYPE | DRIVE/<br>THRESHOLD | GROUPING                 | DESCRIPTION                                   |
|-------------------------|-----|------|---------------------|--------------------------|-----------------------------------------------|
| n.c.                    | 1   | -    | -                   | _                        | not connected                                 |
| n.c.                    | 2   | -    | -                   | _                        | not connected                                 |
| XDA0                    | 3   | 0    | М                   | RAM                      | output address lines                          |
| XDA1                    | 4   | 0    | М                   |                          |                                               |
| XDA2                    | 5   | 0    | М                   |                          |                                               |
| V <sub>DDD(pad6)</sub>  | 6   | -    | -                   | _                        | digital peripheral supply voltage 6           |
| DGND1                   | 7   | -    | -                   | _                        | digital ground 1                              |
| XDA3                    | 8   | 0    | М                   | RAM                      | output address lines                          |
| XDA4                    | 9   | 0    | М                   |                          |                                               |
| XDA5                    | 10  | 0    | М                   |                          |                                               |
| XDA6                    | 11  | 0    | М                   |                          |                                               |
| XDA7                    | 12  | 0    | М                   |                          |                                               |
| XDA8                    | 13  | 0    | М                   |                          |                                               |
| XDA9                    | 14  | 0    | М                   |                          |                                               |
| XDA10                   | 15  | 0    | М                   |                          |                                               |
| XDA11                   | 16  | 0    | М                   |                          |                                               |
| DGND2                   | 17  | _    | _                   | _                        | digital ground 2                              |
| XRAS                    | 18  | 0    | Н                   | RAM                      | row address strobe output (active LOW)        |
| XCAS                    | 19  | 0    | Н                   |                          | column address strobe output (active LOW)     |
| XWR                     | 20  | 0    | Н                   |                          | write enable output (active LOW)              |
| XDD0                    | 21  | I/O  | M/T                 | RAM                      | data bus input/output                         |
| XDD1                    | 22  | I/O  | M/T                 |                          |                                               |
| V <sub>DDD(core1)</sub> | 23  | -    | _                   | _                        | digital core supply voltage 1                 |
| DGND3                   | 24  | -    | _                   | _                        | digital ground 3                              |
| XDD2                    | 25  | I/O  | M/T                 | RAM                      | data bus input/output                         |
| XDD3                    | 26  | I/O  | M/T                 |                          |                                               |
| XDD4                    | 27  | I/O  | M/T                 |                          |                                               |
| XDD5                    | 28  | I/O  | M/T                 |                          |                                               |
| XDD6                    | 29  | I/O  | M/T                 |                          |                                               |
| XDD7                    | 30  | I/O  | M/T                 |                          |                                               |
| V <sub>DDD(pad7)</sub>  | 31  | _    | _                   | _                        | digital peripheral supply voltage 7           |
| DGND4                   | 32  | _    | _                   | _                        | digital ground 4                              |
| SCKI1                   | 33  | I    | С                   | I <sup>2</sup> S-bus I/O | I <sup>2</sup> S-bus bit clock input          |
| WSI1                    | 34  | I    | С                   |                          | I <sup>2</sup> S-bus word select strobe input |

| SYMBOL                 | PIN      | TYPE   | DRIVE/<br>THRESHOLD | GROUPING                   | DESCRIPTION                                                                                                               |
|------------------------|----------|--------|---------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------|
| n.c.                   | 35 to 38 | -      | _                   | _                          | not connected                                                                                                             |
| SDI1                   | 39       | I      | С                   | I <sup>2</sup> S-bus I/O   | data input from CD engine                                                                                                 |
| n.c.                   | 40       | 0      | М                   |                            | not connected                                                                                                             |
| SFSY                   | 41       | I/O    | L/C                 | subcode I/O                | 3-wire subcode sync input/output                                                                                          |
| RCK                    | 42       | I/O    | L/C                 |                            | 3-wire subcode clock input/output                                                                                         |
| SUBI                   | 43       | I      | С                   |                            | Q and R-W subcode input                                                                                                   |
| n.c.                   | 44       | 0      | L                   |                            | not connected                                                                                                             |
| CFLG                   | 45       | I      | С                   | I <sup>2</sup> S-bus input | CD error corrector flags and absolute time sync                                                                           |
| C2P0                   | 46       | I      | С                   |                            | CD C2 error correction flag input for ERCO                                                                                |
| DGND5                  | 47       | -      | _                   | _                          | digital ground 5                                                                                                          |
| IECO                   | 48       | 0      | М                   | multimedia                 | IEC 958 output                                                                                                            |
| MCK                    | 49       | I/O    | M/C                 | multimedia<br>output       | 256f <sub>s</sub> or 384f <sub>s</sub> clock for multimedia master clock/IEC 958 clock or divided system clock for CD-DSP |
| SCK2                   | 50       | I/O    | L/C                 | multimedia                 | I <sup>2</sup> S-bus bit clock input/output                                                                               |
| WS2                    | 51       | I/O    | L/C                 |                            | I <sup>2</sup> S-bus word select strobe input/output                                                                      |
| SDO2                   | 52       | 0      | М                   |                            | I <sup>2</sup> S-bus data output to DAC/video decoder                                                                     |
| GND                    | 53       | -      | _                   | _                          | ground                                                                                                                    |
| CROUT                  | 54       | 0      | crystal pad         | crystal oscillator         | crystal oscillator output                                                                                                 |
| CRIN                   | 55       | I      | crystal pad         |                            | crystal oscillator/clock input                                                                                            |
| V <sub>DDA</sub>       | 56       | -      | _                   | _                          | analog supply voltage                                                                                                     |
| I <sub>ref</sub>       | 57       | analog | current input       | clock generator            | VCO reference current                                                                                                     |
| POR                    | 58       | I      | Schmitt trigger     | system                     | power-on reset (active LOW)                                                                                               |
| TEST1                  | 59       | I      | С                   | test                       | mode control input test pins                                                                                              |
| TEST2                  | 60       | I      | С                   |                            |                                                                                                                           |
| RESET                  | 61       | I      | Schmitt trigger     | host                       | ATAPI bus reset input from host (active LOW)                                                                              |
| DD7                    | 62       | I/O    | AL/T                | host                       | data bus input/output                                                                                                     |
| DD8                    | 63       | I/O    | AL/T                |                            |                                                                                                                           |
| DD6                    | 64       | I/O    | AL/T                |                            |                                                                                                                           |
| V <sub>DDD(pad1)</sub> | 65       | -      | _                   | _                          | digital peripheral supply voltage 1                                                                                       |
| DGND6                  | 66       | -      | _                   | _                          | digital ground 6                                                                                                          |
| DD9                    | 67       | I/O    | AL/T                | host                       | data bus pin order of ATAPI interface matches                                                                             |
| DD5                    | 68       | I/O    | AL/T                |                            | the pinning of the 40-way IDE connector (slew rate limiting by control of drive capability into                           |
| DD10                   | 69       | I/O    | AL/T                |                            | capacitive load of ATA bus)                                                                                               |
| DD4                    | 70       | I/O    | AL/T                |                            |                                                                                                                           |

| SYMBOL                 | PIN      | ТҮРЕ | DRIVE/<br>THRESHOLD | GROUPING | DESCRIPTION                                                                                     |
|------------------------|----------|------|---------------------|----------|-------------------------------------------------------------------------------------------------|
| n.c.                   | 71 to 74 | _    | _                   | _        | not connected                                                                                   |
| DD11                   | 75       | I/O  | AL/T                | host     | data bus; pin order of ATAPI interface matches                                                  |
| DD3                    | 76       | I/O  | AL/T                |          | the pinning of the 40-way IDE connector (slew rate limiting by control of drive capability into |
| DD12                   | 77       | I/O  | AL/T                |          | capacitive load of ATA bus)                                                                     |
| DD2                    | 78       | I/O  | AL/T                |          |                                                                                                 |
| DD13                   | 79       | I/O  | AL/T                |          |                                                                                                 |
| DD1                    | 80       | I/O  | AL/T                |          |                                                                                                 |
| DD14                   | 81       | I/O  | AL/T                |          |                                                                                                 |
| DD0                    | 82       | I/O  | AL/T                |          |                                                                                                 |
| DD15                   | 83       | I/O  | AL/T                |          |                                                                                                 |
| DMARQ/<br>DMACK        | 84       | 0    | AL                  | host     | DMA request/SCSI DMA acknowledge output (active LOW)                                            |
| DGND7                  | 85       | _    | -                   | _        | digital ground 7                                                                                |
| V <sub>DDD(pad2)</sub> | 86       | _    | -                   | _        | digital peripheral supply voltage 2                                                             |
| DIOW                   | 87       | I    | L/T                 | host     | write cycle write enable/control register write input (active LOW)                              |
| DIOR                   | 88       | I    | L/T                 | host     | read cycle read enable/control register read input (active LOW)                                 |
| IORDY                  | 89       | 0    | AH                  | host     | device is ready to transfer data output<br>(active LOW)                                         |
| DMACK/<br>DMARQ        | 90       | I    | Т                   | host     | DMA acknowledge (active LOW)/SCSI DMA request input                                             |
| INTRQ                  | 91       |      | A                   | host     | host interrupt request (NB 3-state output)                                                      |
| DGND8                  | 92       | _    | -                   | _        | digital ground 8                                                                                |
| V <sub>DDD(pad3)</sub> | 93       | _    | -                   | _        | digital peripheral supply voltage 3                                                             |
| IOCS16                 | 94       | 0    | AH                  | host     | I/O port is 16-bit output (active LOW)                                                          |
| DA1/DBWR               | 95       | I/O  | L/T                 | host     | address wire 1/DMA from generic interface is output from the SAA7381 (active LOW)               |
| PDIAG                  | 96       | I/O  | AL/T                | host     | ATAPI passed diagnostics input/output (active LOW)                                              |
| DA0                    | 97       | I/O  | L/T                 | host     | address wire 0 input/output                                                                     |
| DA2/DBRD               | 98       | I/O  | L/T                 | host     | address wire 2/DMA from generic interface is input to the SAA7381 (active LOW)                  |
| CS0/<br>SCSICS         | 99       | I/O  | L/T                 | host     | chip select 1FX/generic interface chip select (active LOW)                                      |
| CS1                    | 100      | I/O  | L/T                 | host     | chip select 3FX input/output (active LOW)                                                       |
| DASP                   | 101      | I/O  | AH/T                | host     | device active slave present input/output (active LOW)                                           |
| INT2                   | 102      | 0    | L                   | sub-CPU  | sub-CPU interrupt output from the SAA7381<br>drive block and UART                               |

| SYMBOL                  | PIN        | TYPE | DRIVE/<br>THRESHOLD | GROUPING | DESCRIPTION                                                       |
|-------------------------|------------|------|---------------------|----------|-------------------------------------------------------------------|
| DGND9                   | 103        | _    | _                   | _        | digital ground 9                                                  |
| V <sub>DDD(pad4)</sub>  | 104        | _    | _                   | _        | digital peripheral supply voltage 4                               |
| COMACK                  | 105        | Ι    | С                   | UART     | command acknowledge/transmit flow control input                   |
| COMCLK                  | 106        | 0    | L                   | UART     | serial data clock for synchronous mode output                     |
| n.c.                    | 107 to 110 | -    | -                   | _        | not connected                                                     |
| COMOUT                  | 111        | 0    | L                   | UART     | transmit data output                                              |
| COMIN                   | 112        | Ι    | С                   | UART     | receive data input                                                |
| COMSYNC                 | 113        | I    | С                   | UART     | basic engine synchronization input                                |
| SYSSYNC                 | 114        | Ι    | С                   | UART     | basic engine synchronization input                                |
| SCCLK                   | 115        | 0    | М                   | sub-CPU  | sub-CPU clock output                                              |
| RD                      | 116        | I    | Т                   | sub-CPU  | sub-CPU read enable (active LOW)                                  |
| WR/R/W                  | 117        | I    | т                   | sub-CPU  | sub-CPU write enable/and read/write control input (active LOW)    |
| INT                     | 118        | 0    | L                   | sub-CPU  | sub-CPU interrupt request output from host interface (active LOW) |
| SRST                    | 119        | 0    | L                   | sub-CPU  | sub-CPU reset output                                              |
| SCA0/SCD0               | 120        | I/O  | L/T                 | sub-CPU  | multiplexed address/data lines                                    |
| SCA1/SCD1               | 121        | I/O  | L/T                 |          |                                                                   |
| DGND10                  | 122        | -    | -                   | _        | digital ground 10                                                 |
| V <sub>DDD(pad5)</sub>  | 123        | -    | -                   | _        | digital peripheral supply voltage 6                               |
| SCA2/SCD2               | 124        | I/O  | L/T                 | sub-CPU  | multiplexed address/data lines                                    |
| SCA3/SCD3               | 125        | I/O  | L/T                 |          |                                                                   |
| SCA4/SCD4               | 126        | I/O  | L/T                 |          |                                                                   |
| SCA5/SCD5               | 127        | I/O  | L/T                 |          |                                                                   |
| SCA6/SCD6               | 128        | I/O  | L/T                 |          |                                                                   |
| SCA7/SCD7               | 129        | I/O  | L/T                 |          |                                                                   |
| DGND11                  | 130        | _    | -                   | _        | digital ground 11                                                 |
| V <sub>DDD(core2)</sub> | 131        | _    | _                   | _        | digital core supply voltage 2                                     |
| ALE                     | 132        | Ι    | Т                   | sub-CPU  | demultiplex enable input for lower address lines                  |
| PSEN                    | 133        | I    | Т                   | sub-CPU  | program store enable (active LOW)                                 |
| SCA15                   | 134        | Ι    | Т                   | sub-CPU  | upper address lines input                                         |
| SCA14                   | 135        | I    | Т                   |          |                                                                   |
| SCA13                   | 136        | Ι    | Т                   |          |                                                                   |
| SCA12                   | 137        | I    | Т                   |          |                                                                   |
| DGND12                  | 138        | _    | _                   | _        | digital ground 12                                                 |

| SYMBOL | PIN | TYPE | DRIVE/<br>THRESHOLD | GROUPING | DESCRIPTION               |
|--------|-----|------|---------------------|----------|---------------------------|
| SCA11  | 139 | I    | Т                   | sub-CPU  | upper address lines input |
| SCA10  | 140 | I    | Т                   |          |                           |
| SCA9   | 141 | I    | Т                   |          |                           |
| SCA8   | 142 | I    | Т                   |          |                           |
| n.c.   | 143 | _    | _                   | _        | not connected             |
| n.c.   | 144 | _    | _                   | _        | not connected             |



SAA7381

### 6.1 Detailed description of pin functions

 Table 1
 Q and R-W input/output subcode connections (4 pins)

| SYMBOL | DESCRIPTION             | COMMENT                                                                                                                      |
|--------|-------------------------|------------------------------------------------------------------------------------------------------------------------------|
| SFSY   | 3-wire subcode sync     | input subcode frame sync for receiving 3-wire subcode; output subcode frame sync for transmitting 3-wire subcode             |
| RCK    | 3-wire subcode clock    | output bit clock for receiving 3-wire subcode; input bit clock for transmitting 3-wire subcode                               |
| SUBI   | Q and R-W subcode input | configurable for 3-wire or Philips V4 subcode mode; can use either RCK or WSI1 as clock references with appropriate dividers |

 Table 2
 I<sup>2</sup>S-bus multimedia audio output (5 pins)

| SYMBOL | DESCRIPTION                                                                                                                           | COMMENT                                                                                                                                                                                                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| МСК    | 256f <sub>s</sub> or 384f <sub>s</sub> clock for<br>multimedia master<br>clock/IEC 958 clock or<br>divided system clock for<br>CD-DSP | Clock reference input pin when interface is in a master mode; a<br>programmable divider is provided. This pin is also configurable as a<br>programmable clock output intended as a clock reference for a<br>CD-DSP. Should be pulled up if not in use.                  |
| SCK2   | I <sup>2</sup> S-bus bit clock                                                                                                        | This is used for master and slave I <sup>2</sup> S-bus application as both modes are needed. For instance, the Philips multimedia CODEC is an I <sup>2</sup> S-bus slave, hence this must be a master interface. When driving some DACs, this interface can be a slave. |
| WS2    | I <sup>2</sup> S-bus left/right strobe                                                                                                | word select strobe either master or slave                                                                                                                                                                                                                               |
| SDO2   | I <sup>2</sup> S-bus data to DAC/video decoder                                                                                        | I <sup>2</sup> S-bus multimedia data                                                                                                                                                                                                                                    |
| IECO   | IEC 958 output                                                                                                                        | the IEC 958 output combines multimedia data and Q-W subcode                                                                                                                                                                                                             |

 Table 3
 I<sup>2</sup>S-bus connections to CD engine (6 pins)

| SYMBOL | DESCRIPTION                                     | COMMENT                                                                                                                                                                                                                     |
|--------|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCKI1  | I <sup>2</sup> S-bus bit clock                  | this is a separate clock to the multimedia bit clock as this rate is derived from the disc linear velocity                                                                                                                  |
| WSI1   | I <sup>2</sup> S-bus left/right strobe          |                                                                                                                                                                                                                             |
| SDI1   | I <sup>2</sup> S-bus data from CD-DSP           |                                                                                                                                                                                                                             |
| C2P0   | CD C2 error corrector flag<br>from ERCO         | these flags are used to indicate errors from second layer correction to the ERCO                                                                                                                                            |
| CFLG   | CD error corrector flags and absolute time sync | The absolute time sync is used in the CD input process for playing 'Red Book' discs; the error corrector status is also read in from this signal, to provide an indication of C1 and C2 performance for CD-RW applications. |

| Table 4 ATAPI targe | et mode interface |
|---------------------|-------------------|
|---------------------|-------------------|

| ATAPI<br>NAME | ATAPI MEANING                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESET         | ATAPI reset signal: the SAA7381 will not recognize a signal assertion shorter than 20 ns as a valid reset signal.                                                                                                                                                                                                                                                                                                 |
| DD0 to DD7    | ATAPI D0 to D7.                                                                                                                                                                                                                                                                                                                                                                                                   |
| DD8 to DD15   | ATAPI D8 to D15: these data bits are only used in accesses to the 16-bit data port.                                                                                                                                                                                                                                                                                                                               |
| DMARQ         | DMA request: this signal, used for DMA data transfers between host and device, is asserted by the SAA7381 when it is ready to transfer data to or from the host. The direction of data transfer is controlled by DIOR and DIOW.                                                                                                                                                                                   |
| DMACK         | DMA acknowledge: this signal is used by the host in response to DMARQ to initiate DMA transfers.<br>This signal may be temporarily negated by the host to suspend the DMA transfer in process.                                                                                                                                                                                                                    |
| IOCS16        | ATAPI I/O port is a 16-bit open-drain output: during PIO transfer Modes 0, 1 or 2, IOCS16 indicates to the host system that the 16-bit data port has been addressed and that the device is prepared to send or receive a 16-bit data word.                                                                                                                                                                        |
| IORDY         | ATAPI I/O ready open-drain output: this signal is negated to extend the host transfer cycle of any host register access (read or write) when the SAA7381 is not ready to respond to a data transfer request. This signal is only enabled during DIOR/DIOW cycles to the SAA7381. When IORDY is not active, it is in the high-impedance (undriven) state.                                                          |
| DA0 to DA2    | Address bus (device address).                                                                                                                                                                                                                                                                                                                                                                                     |
| DIOW          | ATAPI write strobe: the rising edge of $\overline{\text{DIOW}}$ latches data from the signals, DD0 to DD7 or DD0 to DD15 into a register or the data port of the SAA7381. The SAA7381 will not act on the data until it is latched.                                                                                                                                                                               |
| DIOR          | ATAPI read strobe: the falling edge of $\overline{\text{DIOR}}$ enables data from a register or data port of the SAA7381 onto the signals, DD0 to DD7 or DD0 to DD15. The rising edge of $\overline{\text{DIOR}}$ latches data at the host and the host will not act on the data until it is latched.                                                                                                             |
| CS0           | ATAPI chip select 0 input: this is the chip select signal from the host used to select the ATA command block registers. This signal is also known as CS1FX.                                                                                                                                                                                                                                                       |
| CS1           | ATAPI chip select 1 input: this is the chip select signal from the host used to select the ATA control block registers. This signal is also known as CS3FX.                                                                                                                                                                                                                                                       |
| INTRQ         | ATAPI interrupt output: this signal is used to interrupt the host system. INTRQ is asserted only when the device has a pending interrupt, the device is selected, and the host has cleared the 'nien' bit in the device control register. If the 'nien' bit is equal to 1, or the device is not selected, this output is in a high-impedance state, regardless of the presence or absence of a pending interrupt. |
| PDIAG         | ATAPI passed diagnostics: this signal shall be asserted by device 1 to indicate to device 0 that it has completed diagnostics.                                                                                                                                                                                                                                                                                    |
| DASP          | ATAPI DASP (device active, device 1 present): this is a time-multiplexed signal which indicates that a device is active, or that device 1 is present. This signal is an open-drain output.                                                                                                                                                                                                                        |

SAA7381

### Table 5 Generic host controller interface

| ATAPI<br>NAME | GENERIC<br>INTERFACE<br>NAME | GENERIC HOST CONTROLLER INTERFACE MEANING                      |  |  |  |
|---------------|------------------------------|----------------------------------------------------------------|--|--|--|
| RESET         | RESET                        | controller reset output                                        |  |  |  |
| DD0 to DD7    | D0 to D7                     | controller DMA path/controller data and control bus (optional) |  |  |  |
| DD8 to DD15   | D8 to D15                    | controller upper DMA path (optional)                           |  |  |  |
| DMARQ         | DMACK                        | DMA acknowledge to controller                                  |  |  |  |
| DMACK         | DMARQ                        | DMA request from controller                                    |  |  |  |
| DA1           | DBWR                         | DMA bus write to controller                                    |  |  |  |
| DA2           | DBRD                         | DMA bus read from controller                                   |  |  |  |
| CS0           | SCSICS                       | controller chip select output for sub-CPU read/write cycles    |  |  |  |

### Table 6Miscellaneous pins

| SYMBOL           | DESCRIPTION                    | COMMENT              |
|------------------|--------------------------------|----------------------|
| CRIN             | crystal oscillator/clock input | -                    |
| CROUT            | crystal oscillator output      | -                    |
| I <sub>ref</sub> | VCO reference current          | clock PLL multiplier |
| POR              | power-on reset pin             | -                    |
| TEST1 and TEST2  | mode control test pins         | -                    |

### Table 7 Sub-CPU interface pins

| SYMBOL                        | DESCRIPTION                                                          | COMMENT                                                                                                                                                                                         |
|-------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRST                          | sub-CPU reset                                                        | active HIGH reset if XDD7 is pulled LOW during power-on reset;<br>active LOW reset if XDD7 is pulled HIGH during power-on reset                                                                 |
| INT                           | sub-CPU interrupt request<br>output from host interface              | open-drain sub-processor interrupt from host interface                                                                                                                                          |
| INT2                          | sub-CPU interrupt output<br>from the SAA7381 drive<br>block and UART | open-drain sub-processor interrupt from drive and UART                                                                                                                                          |
| SCCLK                         | sub-CPU clock out                                                    | -                                                                                                                                                                                               |
| RD                            | sub-CPU read enable                                                  | sub-CPU read enable strobe; if grounded permanently, the $\overline{\rm WR}$ signal will act as read/write control input                                                                        |
| WR/R/W                        | sub-CPU write enable/<br>read/write control                          | write enable; alternative usage is read/write if $\overline{RD}$ is held LOW at all times; $\overline{WR}$ has priority over $\overline{RD}$ at all times                                       |
| ALE                           | demultiplex enable input for lower address lines                     | while HIGH, the lower address bits are latched from<br>SCD0 to SCD7; should be used with a Schmitt trigger input to<br>avoid false latching due to ground bounce on the<br>8051 microcontroller |
| PSEN                          | program store enable                                                 | this pin should be tied high using a 10 k $\Omega$ resistor                                                                                                                                     |
| SCD0 to SCD7/<br>SCA0 to SCA7 | sub-CPU data bus<br>multiplexed/low address bus                      | -                                                                                                                                                                                               |
| SCA8 to SCA15                 | sub-CPU address high bits                                            | -                                                                                                                                                                                               |

### SAA7381

### **Table 8**RAM interface pins

| SYMBOL        | DESCRIPTION                            | COMMENT                             |
|---------------|----------------------------------------|-------------------------------------|
| XDA0 to XDA11 | RAM address bits, multiplexed for DRAM | up to 16 Mbytes DRAM only supported |
| XRAS          | DRAM row address strobe                |                                     |
| XCAS          | DRAM column address strobe             |                                     |
| XWR           | RAM write enable                       |                                     |
| XDD0 to XDD7  | RAM data bus                           |                                     |

#### Table 9 Basic engine interface

| SYMBOL  | DESCRIPTION                               | COMMENT                                                      |  |  |
|---------|-------------------------------------------|--------------------------------------------------------------|--|--|
| SYSSYNC | basic engine synchronization input        | generate interrupts on rising and/or falling edges           |  |  |
| COMSYNC | basic engine synchronization input        | generate interrupts on rising and/or falling edges           |  |  |
| COMIN   | receive data                              | -                                                            |  |  |
| COMOUT  | transmit data                             | -                                                            |  |  |
| COMCLK  | serial data clock for synchronous mode    | -                                                            |  |  |
| COMACK  | command acknowledge/transmit flow control | must be HIGH for synchronous mode to transmit next data byte |  |  |

### 7 FUNCTIONAL DESCRIPTION

The SAA7381 device consists of a number of main functional units; a CD engine interface, a multimedia block, a microcontroller interface, an error detection and correction block, a host interface and a memory manager. There are also several smaller blocks including a clock control block and a UART for communication with the CD engine. Each block is independently controlled by a dedicated register set. These registers are memory mapped to the sub-CPU to allow for faster access. The external RAM can also be accessed directly from the microcontroller to support scratchpad accesses and thus eliminate the need for further memory devices in the system.

### 7.1 Memory field description

The CD input function of the SAA7381 buffer manager receives the main data stream in  $I^2$ S-bus format from the CD-DSP, performs sync detection and partitions the data into blocks.

It then writes the blocks to the buffer memory and onboard ERCO RAM. Any detected errors are then corrected and over written into the buffer memory.

Memory is segmented and addressable by segment pointers. The segment pointers consist of a block number, offset pointer and byte number within the block. The data within each segment is organised in the same manner (see Table 10).

The arrangement of data within each segment in memory differs from other Philips devices, because of the different error correction processing possibilities within the SAA7381.

Addresses 0 to 2355 are written to memory by the drive processor when enabled.

## SAA7381

 Table 10
 The memory map of a block in the buffer RAM for standard density mode (see Table 11)

| ADDRESS (OFFSET) | TYPE OF DATA                                                  |
|------------------|---------------------------------------------------------------|
| 0 to 3           | header field                                                  |
| 4 to 2339        | block data field                                              |
| 2340 to 2351     | sync field                                                    |
| 2352             | copy of STAT0                                                 |
| 2353             | copy of STAT1                                                 |
| 2354             | copy of STAT2                                                 |
| 2355             | number of C2 flags in sector (compressed format)              |
| 2356 to 2451     | 96-byte de-interleaved R-W data field                         |
| 2452 to 2463     | 12-byte Q-subcode field                                       |
| 2464 to 2465     | copy of STAT4 field; only valid if ERCO did run on this block |
| 2466 to 2559     | user work space                                               |

### Table 11 Description of Table 10

| DATA             | DESCRIPTION                                                                                                                                                     |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Header field     | The 4-byte header data consists of a 3-byte block address of absolute time (minutes, seconds and frame, bytes 0 to 3). The fourth byte is for the mode of data: |  |  |  |  |
|                  | Mode 0 = zero mode                                                                                                                                              |  |  |  |  |
|                  | Mode 1 = data storage with EDC and ECC                                                                                                                          |  |  |  |  |
|                  | Mode 2 = data storage                                                                                                                                           |  |  |  |  |
| Block data field | in the CD-ROM mode the block data consists of 2048 bytes of user data and 288 bytes of auxiliary data                                                           |  |  |  |  |
|                  | User data:                                                                                                                                                      |  |  |  |  |
|                  | Mode 0= all 2048 bytes in user data are zero                                                                                                                    |  |  |  |  |
|                  | Mode 1= all 2048 bytes are available to the user                                                                                                                |  |  |  |  |
|                  | Mode 2= all 2048 bytes are available to the user                                                                                                                |  |  |  |  |
|                  | Auxiliary data:                                                                                                                                                 |  |  |  |  |
|                  | Mode 0= all 288 bytes in Aux data are zero                                                                                                                      |  |  |  |  |
|                  | Mode 1= the Aux field is in accordance with the EDC and ECC specification                                                                                       |  |  |  |  |
|                  | Mode 2= all 288 bytes are available to the user                                                                                                                 |  |  |  |  |
| Sync field       | The 12-byte sync field is the next segment in memory. All bytes in the sync field are FFH, except the first and last bytes which are \$00.                      |  |  |  |  |

SAA7381

| DATA                                             | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Number of C2 flags in sector (compressed format) | While storage of C2 flag positions is not possible as a consequence of the architecture of the SAA7381, a count of the number of flags seen per block is made in a single-byte counter. This counter packs the possibly 12-bit count into a single byte in the following way, at the expense of resolution in the count values for large counts.                                                                                    |  |  |
|                                                  | C2count_val = count (5 down to 0) $\times$ [4 ^ count (7 down to 6)], the resolution of the count is therefore:                                                                                                                                                                                                                                                                                                                     |  |  |
|                                                  | C2count_val 0 to 63: counter resolution = 1                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                                  | C2count_val 64 to 255: counter resolution = 4                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                                  | C2count_val 256 to 1023: counter resolution = 16                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|                                                  | C2count_val 1024 to 4095: counter resolution = 64                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| 96-byte de-interleaved<br>R-W data field         | Written to memory by the automatic Q-channel copy process (copy2 channel). If the copy process is not enabled, these fields are not written (see Section 7.3.5). These bytes may either be R-W de-interleaved or presented as raw Q-W subcode bytes. If the copy2 interleaving mode is set to <b>raw</b> , interleaved copying is still required as the subcode temporary holding buffer has Q bytes interspersed with the raw R-W. |  |  |
| 12-byte Q-subcode field                          | As above: these will not be separated out if the copy2 interleaving option is set to <b>raw</b> .                                                                                                                                                                                                                                                                                                                                   |  |  |
| 2 copies of STAT4 field                          | Address 2465 and 2466 are copies of the STAT4 register written by the ERCO when<br>enabled. This allows the user to determine if the STAT4 register has been written to by the<br>ERCO. If seg2465 = seg2466 then STAT4 definitely has not been written by the ERCO.<br>If seg2465 $\neq$ seg2466 then STAT4 probably has not been written by the ERCO.                                                                             |  |  |
|                                                  | Via direct access to buffer memory, the sub-CPU will be able to look at all of the blocks so far corrected, to check their status, in a background task.                                                                                                                                                                                                                                                                            |  |  |
|                                                  | ERCO failures do not have to be dealt with immediately, as the status of every block loaded in to RAM is stored with that block, and it is not overwritten until the RAM block is filled with new data from CD input.                                                                                                                                                                                                               |  |  |
|                                                  | The error corrector will be controlled additionally to permit the use of single pass P-Q or only EDC operation to allow for greater than $n = 14$ operation of the ERCO.                                                                                                                                                                                                                                                            |  |  |
|                                                  | The ERCO status will be copied into the RAM along with the data. This is possible because the RAM now has spare capacity to store the information, as part of the change from linear to segment/offset addressing.                                                                                                                                                                                                                  |  |  |
|                                                  | It is possible to program transfers into RAM of more than one block without processor intervention. It is also possible to continually loop on the same buffer area of RAM, by not altering the reload register values when the reload interrupt occurs.                                                                                                                                                                            |  |  |

### 7.1.1 DVD-ROM MEMORY FIELD INFORMATION

The buffer arrangement for DVD usage is basically the same (data followed by flags) but the size of the block data differs, and the ERCO flags are at a different offset, and as the ERCO is not in use, the flags relating to ERCO performance will not be valid.

SAA7381

### 7.2 CD input control registers

The CD input process is intended to be as automated as possible. Data is read in from the front end, descrambled if in CD-ROM mode and then written to RAM. The registers that control the address of where the data is written to are in the memory processor block.

The input data is synchronized, decoded and written to the buffer RAM. The input data format is software programmable.

The synchronization is performed by using a sync detector and a sync interpolator. The sync detector can detect CD-ROM syncs and syncs from the CFLG pin, for use with Red Book, audio and for DVD. When no sync is found, it is optionally interpolated.

After decoding, each full sector of data (2352 bytes) comprising sync, header and sub-header is written to the buffer RAM. The R-W and Q subcode is added by a software-initiated automatic block copy process.

7.2.1 REGISTERS ASSOCIATED WITH DATA IN PROCESS

Table 12 IFCONFIG (write only; address FF10H) (see Table 13)

| BIT 7    | BIT 6  | BIT 5  | BIT 4  | BIT 3    | BIT 2    | BIT 1       | BIT 0       |
|----------|--------|--------|--------|----------|----------|-------------|-------------|
| ipconfig | ckdiv1 | ckdiv0 | subsel | modulo 1 | modulo 0 | config swap | config wclk |

### Table 13 Description of the IFCONFIG register bits

| BIT     | NAME         | VALUE | MEANING                                                             |  |
|---------|--------------|-------|---------------------------------------------------------------------|--|
| 7       | ipconfig     | 0     | I <sup>2</sup> S-bus mode                                           |  |
|         |              | 1     | EIAJ serial interface mode                                          |  |
| 6 and 5 | ckdiv1 and   | 00    | oversample, bit clock division ratio = 2                            |  |
|         | ckdiv0       | 01    | oversample, bit clock division ratio = 4                            |  |
|         |              | 10    | oversample, bit clock division ratio = 8                            |  |
|         |              | 11    | bit clock division ratio = 1 (no division)                          |  |
| 4       | subsel       | 0     | both copies of sub-header contribute to STAT1/sh0err to sh3err      |  |
|         |              | 1     | first copy only of sub-header contributes to STAT1/sh0err to sh3err |  |
| 3 and 2 | modulo 1 and | 00    | modulo count 2352                                                   |  |
|         | modulo 0     | 01    |                                                                     |  |
|         |              | 10    | modulo count 2064                                                   |  |
|         |              | 11    | modulo count 2064, but do not count bytes with flag = 1             |  |
| 1       | config swap  | 0     | the received data from the CD-DSP or drive FIFO is not swapped      |  |
|         |              | 1     | the received data from the CD-DSP or drive FIFO is swapped          |  |
| 0       | config wclk  | 0     | the internal 'irclk' is not inverted                                |  |
|         |              | 1     | the internal 'irclk' is inverted                                    |  |

SAA7381

| ADDRESS | NAME           | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF21H   | DRIVECURSEG-L  | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF20H   | DRIVECURSEG-H  | incen | wren  | _     | s12   | s11   | s10   | s9    | s8    |
| FF60H   | DRIVECURCOUNT  | c7    | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF27H   | DRIVENEXTSEG-L | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF26H   | DRIVENEXTSEG-H | incen | wren  | _     | s12   | s11   | s10   | s9    | s8    |
| FF61H   | DRIVENEXTCOUNT | c7    | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF23H   | DRIVEPREVSEG-L | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF22H   | DRIVEPREVSEG-H | incen | wren  | -     | s12   | s11   | s10   | s9    | s8    |
| FF24H   | DRIVEOFFSET-H  | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF25H   | DRIVEOFFSET-L  | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |

Table 14 CD input control registers (see Table 15)

There are two sets of address registers, one giving the current (DRIVECURSEG) number of the segment being filled and a segment/block counter. The other set contains the values (DRIVENEXTSEG) to use on completion of the current group of blocks being filled or emptied (in CD-R). The DRIVEPREVSEG register is loaded with the value of the DRIVECURSEG register at the end of each CD-ROM block.

The reloading of the registers will trigger an interrupt, if enabled, of the sub-CPU, which will then have to reload the 'next' registers. before the transfer requested in the 'current' registers are exhausted.

Memory is split into segments, each segment is 2560 bytes. The drive data is written one block at a time at the segment number pointed to by the DRIVECURSEG register. For the next block the 'DRIVECURSEG' is updated as follows.

| BIT | NAME                 | VALUE | MEANING                                                        |
|-----|----------------------|-------|----------------------------------------------------------------|
| 7   | incen <sup>(1)</sup> | 0     | hold value of DRIVECURSEG                                      |
|     |                      | 1     | increment DRIVECURSEG at the end of each CD-ROM block received |
| 6   | wren <sup>(2)</sup>  | 0     | enable writes of data transferred                              |
|     |                      | 1     | disable write of data transferred                              |

Table 15 Description of the 'incen' and 'wren' bits (see Table 14)

#### Notes

- 1. If 'incen' is logic 1, the 'DRIVECURSEG' pointer will increment every sector sync. The 'DRIVECURCOUNT' will decrement every sector sync independent of 'incen'. If 'incen' is logic 0 then the pointer will remain fixed pointing at the same segment of RAM. If the reading of data from CD is enabled by the 'wrreq' bit in the CTRL0 register, and the 'wren' bit is logic 0 the segment will be repeatedly filled by the data coming in from the CD-ROM.
- 2. If 'wren' is logic 1 and 'incen' is logic 1 then the DRIVECURSEG register will increment with each sync time and the DRIVECURCOUNT register will decrement but data will not be written to external RAM. This allows the triggering of the reading of data or the writing of data some time in the future.

| ADDRESS      | NAME  | BIT 7 | BIT 6  | BIT 5 | BIT 4    | BIT 3   | BIT 2 | BIT 1  | BIT 0  |
|--------------|-------|-------|--------|-------|----------|---------|-------|--------|--------|
| <b>FF0DH</b> | CTRL0 | decen | ahead  | e01rq | autoform | eramrq  | wrreq | eccrq  | encode |
| <b>FF0EH</b> | CTRL1 | syien | syden  | asyn  | cowren   | onepass | -     | -      | _      |
| FF0FH        | CTRL2 | modrq | formrq | —     | automode | mbckrq  | _     | dscren | _      |

 Table 16
 Control and status registers (see Tables 17, 18 and 19)

### SAA7381

| BIT | NAME     | VALUE | DESCRIPTION                                                                                           |
|-----|----------|-------|-------------------------------------------------------------------------------------------------------|
| 7   | decen    | 0     | disable decoding, drive in 'full reset' state, no monitor of I <sup>2</sup> S-bus line, no interrupts |
|     |          | 1     | enable decoding                                                                                       |
| 6   | ahead    | 0     | obsolete                                                                                              |
|     |          | 1     | must be set to logic 1                                                                                |
| 5   | e01rq    | 0     | disable error correction of bytes for which an error has been detected, but not yet corrected         |
|     |          | 1     | enable CRC miscorrection correction of the C2 flag bytes                                              |
| 4   | autoform | 0     | disable automatic Form detection                                                                      |
|     |          | 1     | enable automatic Form detection                                                                       |
| 3   | eramrq   | 0     | disable erasure flag use                                                                              |
|     |          | 1     | enable erasure flag use                                                                               |
| 2   | wrreq    | 0     | disable data writes to the buffer and pointer updates, only header and status information recovered   |
|     |          | 1     | enables data writes to the buffer and pointer updates                                                 |
| 1   | eccrq    | 0     | disable ECC correction only EDC checking                                                              |
|     |          | 1     | enable ECC correction, ERCO active                                                                    |
| 0   | encode   | 0     | must be set to logic 0                                                                                |
|     |          | 1     |                                                                                                       |

 Table 17 Description of the CTRL0 register bits (resetting the chip sets all the bits in this register to 0)

Table 18 Description of the CTRL1 register bits (the reset function clears all the flags in this register)

| BIT | NAME    | VALUE | DESCRIPTION                                             |
|-----|---------|-------|---------------------------------------------------------|
| 7   | syien   | 0     | disable sync interpolation                              |
|     |         | 1     | enable sync interpolation                               |
| 6   | syden   | 0     | disable sync detection                                  |
|     |         | 1     | enable sync detection                                   |
| 5   | asyn    | 0     | CD-ROM sync detection                                   |
|     |         | 1     | audio sync detection                                    |
| 4   | cowren  | 0     | disable rewriting of corrected error bytes              |
|     |         | 1     | enable rewriting of error bytes during error correction |
| 3   | onepass | 0     | normal error corrector operation                        |
|     |         | 1     | one pass only error correction                          |

SAA7381

| BIT | NAME     | VALUE | DESCRIPTION                                 |  |
|-----|----------|-------|---------------------------------------------|--|
| 7   | modrq    | 0     | Mode 1 request                              |  |
|     |          | 1     | Mode 2 request                              |  |
| 6   | formrq   | 0     | Form 1 request                              |  |
|     |          | 1     | Form 2 request                              |  |
| 4   | automode | 0     | disable automatic determination of mode bit |  |
|     |          | 1     | enable automatic determination of mode bit  |  |
| 3   | mbckrq   | 0     | disable mode check function                 |  |
|     |          | 1     | enable mode check function                  |  |
| 1   | dscren   | 0     | disable descrambling function               |  |
|     |          | 1     | enable descrambling function                |  |

 Table 19 Description of the CTRL2 register bits

**Table 20** Sub-CPU registers during read (see Tables 21, 22, 23, 27 and 28)

| ADDRESS      | NAME     | BIT 7                                           | BIT 6  | BIT 5  | BIT 4     | BIT 3     | BIT 2  | BIT 1  | BIT 0  |
|--------------|----------|-------------------------------------------------|--------|--------|-----------|-----------|--------|--------|--------|
| FF00H        | HEAD0    |                                                 |        |        | min       | utes      |        |        |        |
| FF01H        | HEAD1    |                                                 |        |        | seco      | onds      |        |        |        |
| FF02H        | HEAD2    |                                                 |        |        | frar      | nes       |        |        |        |
| FF03H        | HEAD3    |                                                 |        |        | mc        | de        |        |        |        |
| FF04H        | SUBHEAD0 |                                                 |        |        | file nu   | ımber     |        |        |        |
| FF05H        | SUBHEAD1 |                                                 |        |        | channel   | number    |        |        |        |
| FF06H        | SUBHEAD2 |                                                 |        |        | subn      | node      |        |        |        |
| FF07H        | SUBHEAD3 |                                                 |        |        | coding In | formation |        |        |        |
| FF08H        | STAT0    | _                                               | ilsync | nosyn  | lblk      | _         | sblk   | erablk | _      |
| FF09H        | STAT1    | minerr                                          | secerr | blkerr | moderr    | sh0err    | sh1err | sh2err | sh3err |
| <b>FF0AH</b> | STAT2    | rmod3 rmod2 rmod1 rmod0 mode form rform1 rform2 |        |        |           |           |        |        |        |
| FF0BH        | STAT3    | valst                                           | _      | _      | _         | _         | _      | _      | -      |
| FF0CH        | STAT4    | crcok                                           | cblk   | uceblk | _         | nocor     | mode   | form   | qok    |

Table 21 Description of the STAT0 register bits (resetting the chip clears all bits in this register)

| BIT | NAME   | VALUE | DESCRIPTION                                                               |
|-----|--------|-------|---------------------------------------------------------------------------|
| 7   | _      | _     | reserved                                                                  |
|     |        | -     | reserved                                                                  |
| 6   | ilsync | 0     | -                                                                         |
|     |        | 1     | sync pattern detected at word count 0 to 1174                             |
| 5   | nosyn  | 0     | -                                                                         |
|     |        | 1     | sync pattern inserted by sync interpolator not coincident with data sync  |
| 4   | lblk   | 0     | -                                                                         |
|     |        | 1     | with 'syien' at logic 0, no sync found; data block size has been extended |
| 3   | _      | -     | reserved                                                                  |
|     |        | _     | reserved                                                                  |

### SAA7381

| BIT | NAME   | VALUE | DESCRIPTION                                              |
|-----|--------|-------|----------------------------------------------------------|
| 2   | sblk   | 0     | -                                                        |
|     |        | 1     | short block indication                                   |
| 1   | erablk | 0     | -                                                        |
|     |        | 1     | one or more bytes of the block are flagged with C2 flags |
| 0   | -      | -     | reserved                                                 |
|     |        | _     | reserved                                                 |

 Table 22
 Description of the STAT1 register bits; address FF09H (see notes 1 and 2)

| BIT 7                 | BIT 6                 | BIT 5                 | BIT 4                 | BIT 3                 | BIT 2                 | BIT 1                 | BIT 0                 |
|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| minerr <sup>(3)</sup> | secerr <sup>(3)</sup> | blkerr <sup>(3)</sup> | moderr <sup>(3)</sup> | sh0err <sup>(4)</sup> | sh1err <sup>(4)</sup> | sh2err <sup>(4)</sup> | sh3err <sup>(4)</sup> |

### Notes

- 1. Resetting the chip clears all bits in this register.
- 2. The bits in this register indicate the reliability of data in the HEAD0 to HEAD3 and SUBHEAD0 to SUBHEAD3 registers.
- 3. Bits 'minerr', 'secerr', 'blkerr' and 'moderr' indicate errors in the minutes, seconds, frames and mode bytes in the header of the current block.
- 4. Bits 'sh0err' to 'sh3err' indicate errors in the respective bytes in the subheader.

 Table 23
 Description of the STAT2 register bits; address FF0AH (see Tables 24, 25 and 26)

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1  | BIT 0  |
|-------|-------|-------|-------|-------|-------|--------|--------|
| rmod3 | rmod2 | rmod1 | rmod0 | mode  | form  | rform1 | rform2 |

### Table 24 Description of the 'mode' and 'form' bits

| mode | form | SETTING                                     |  |  |  |  |
|------|------|---------------------------------------------|--|--|--|--|
| 0    | 0    | Mode 1                                      |  |  |  |  |
| 1    | 0    | Mode 2, Form 1                              |  |  |  |  |
| X    | 1    | Mode 2, Form 2 or ECC correction impossible |  |  |  |  |

### Table 25 Description of the 'rform' bits

| rform1 | rform2 | MEANING            |
|--------|--------|--------------------|
| 0      | 0      | Form 1             |
| 0      | 1      | Form 2             |
| 1      | Х      | error in Form byte |

### SAA7381

Table 26 Description of the 'rmod' bits

| rmod3 to rmod30 <sup>(1)</sup> | MEANING                                                |
|--------------------------------|--------------------------------------------------------|
| 0000                           | mode 0                                                 |
| 0001                           | mode 1                                                 |
| 0010                           | mode 2                                                 |
| 0011                           | mode 3                                                 |
| 0100                           | mode 4                                                 |
| 0101                           | mode 5                                                 |
| 0110                           | mode 6                                                 |
| 0111                           | mode 7                                                 |
| 1XXX                           | packet written CD-R, run in/run out, link, XXX is mode |
| 1111                           | mode = 7 or error in mode byte                         |

#### Note

1. rmod3 = bit 7 #, bit 6 #, bit 5 #, bit 4 #, bit 3 # C2P0 (where # is logic OR). This is non-zero for packet written CD-R. rmod2 = bit 2 # C2P0 (where C2P0 is C2 flag for mode byte).

rmod1 = bit 1 # C2P0 (where C2P0 is C2 flag for mode byte).

rmod0 = bit 0 # C2P0 (where C2P0 is C2 flag for mode byte).

### Table 27 Description of the STAT3 register bit

| BIT | NAME  | VALUE | DESCRIPTION                                       |
|-----|-------|-------|---------------------------------------------------|
| 7   | valst | 0     | registers associated with decoder interrupt valid |
|     |       | 1     | registers invalid                                 |

 Table 28 Description of the STAT4 register bits (this register contains the interrupt status on reading)

| BIT | NAME   | VALUE | DESCRIPTION                           |
|-----|--------|-------|---------------------------------------|
| 7   | crcok  | 0     | -                                     |
|     |        | 1     | cyclic redundancy check OK            |
| 6   | cblk   | 0     | -                                     |
|     |        | 1     | there has been an error in this block |
| 5   | uceblk | 0     | -                                     |
|     |        | 1     | uncorrectable errors in block         |
| 4   | -      | 0     | reserved                              |
|     |        | 1     | reserved                              |
| 3   | nocor  | 0     | -                                     |
|     |        | 1     | ERCO was not started on this block    |
| 2   | mode   | 0     | Mode 1 used in correcting this block  |
|     |        | 1     | Mode 2 used in correcting this block  |
| 1   | form   | 0     | Form 1 used in correcting this block  |
|     |        | 1     | Form 2 used in correcting this block  |
| 0   | qok    | 0     | Q channel CRC no error                |
|     |        | 1     | Q channel CRC error                   |

### SAA7381

 Table 29
 Auxiliary segment pointer

| ADDRESS | NAME         | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|--------------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF29H   | AUXSEGMENT-L | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF28H   | AUXSEGMENT-H | —     | -     | _     | s12   | s11   | s10   | s9    | s8    |

The auxiliary segment pointer points at a group of segments which hold the data FIFOs used in the SAA7381. These are the 'large' FIFOs rather than the small resynchronizing FIFOs inside the SAA7381.

The subcode input/output and  $n = 1 I^2S$ -bus interfaces use these FIFOs (in addition, the shadow debug registers can use some of this space).

The FIFOs are arranged to optimally occupy a contiguous group of segments in the external RAM.

### 7.3 Multimedia output interface

This block deals with subcode input and output in addition to an audio output which is independent of the I<sup>2</sup>S-bus input output path connected to the CD-R engine.

Q and R-W subcode features:

- · Supports semiautomatic de-interleaving/interleaving
- Subcode sync is aligned with the start of the current block in RAM
- Supports subcode resynchronization when subcode sync is lost
- Supports Philips 'V4' and 3-wire formats
- · Has selectable polarity on RCK
- Uses WSI1 pin as timing reference
- Supports regeneration of subcode from IEC 958 output using WS2 as timing reference
- Can accept subcode input while I<sup>2</sup>S-bus from CD-DSP is oversampled audio at n = 2 or n = 4 oversample

Audio output (multimedia) features:

- Has data output for simple audio or digital video for n = 1 or n = 2 rate regardless of input CD-DSP data rate
- 4096-byte FIFO for audio samples, requires firmware polling for refills using the block copy engine
- Permits CAV and quasi-CLV systems to maintain n = 1 audio output
- Basic channel swap, mono-L or mono-R modes, includes muting and L + R summed mono
- IEC 958 output with subcode Q-W for use in CAV and other modes where there is no n = 1 clock in the CD-DSP subsystem

- IEC 958 interface has fully programmable category code and copyright bits for flexibility
- Subcode on IEC 958 is only available in CD-ROM mode, because the subcode output FIFO is shared.
- Master and slave I<sup>2</sup>S-bus modes are available
  - IEC 958 is only available when the I<sup>2</sup>S-bus is in the master mode.
- Can be configured to provide a clock for an external CD-DSP function via the MCK pin
- Can operate in 64fs or 48fs I<sup>2</sup>S-bus modes
- IEC 958 can operate at n = 2 although not permitted by standard.

#### 7.3.1 SUBCODE INPUT BLOCK

7.3.1.1 Q-W subcode handling

The subcode data is initially converted from serial-to-parallel format and is then handled as Q-W bytes.

The de-interleaving is performed by a de-interleaving block copy mode in the memory processor's block copy engine. Subcode blocks will always be aligned with a block of CD-ROM data, although the subcode Minutes, Seconds, Frames (MSF) absolute time may have an uncertainty of  $\pm$ 5 frames in terms of the actual CD-ROM block it is referring to. This offset is unknown but consistent in any given application. The block copy engine will be automatically triggered when the subcode synchronization is found.

The error corrector will then compute the CRC syndrome of the subcode and deposit it in the CRC bytes. The sub-CPU will have to perform the actual correction if a non-zero syndrome appears.

This syndrome, if calculated during encoding by the ERCO, can be used as the CRC written to disc for the subcode.

SAA7381

### 7.3.1.2 Description of subcode interface

The subcode interface allows the reception and transmission of subcodes. The subcodes will be received/transmitted to two on-chip 512-byte FIFOs, one for transmit and one for receive. No interrupts are associated with these FIFOs as the block copy engine removes data or fills these as necessary.

There is, however, an interrupt which is asserted when a sync is found in an unexpected location.

### 7.3.2 SUBCODE MODE TRANSMIT CONTROL REGISTER

Table 30 Subcode mode transmit control register (SUBMODETX; address FF13H); see Table 31

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| _     | —     | _     | pbit  | —     | txena |       | V4    |

### Table 31 Description of the SUBMODETX register bits

| BIT | NAME  | VALUE | DESCRIPTION                            |  |  |  |  |  |
|-----|-------|-------|----------------------------------------|--|--|--|--|--|
| 4   | pbit  | 0     | P bit logic 1 in 3-wire mode (default) |  |  |  |  |  |
|     |       | 1     | P bit logic 0 in 3-wire mode           |  |  |  |  |  |
| 2   | txena | 0     | subcode transmit interface is disabled |  |  |  |  |  |
|     |       | 1     | subcode transmit interface is enabled  |  |  |  |  |  |
| 0   | V4    | 0     | Philips SRI 3-wire subcode             |  |  |  |  |  |
|     |       | 1     | Philips V4 mode; note 1                |  |  |  |  |  |

Note

1. Philips V4 subcode transmit mode must be selected for correct insertion of subcode into the IEC 958 data stream.

| Table 32 Subcode mode receive control register (SUBMODERX, address FF17H); see Table 33 | RX, address FF1/H); see Table 33 |
|-----------------------------------------------------------------------------------------|----------------------------------|
|-----------------------------------------------------------------------------------------|----------------------------------|

| BIT 7 | BIT 6 | BIT 5 | BIT 4  | BIT 3  | BIT 2 | BIT 1    | BIT 0   |
|-------|-------|-------|--------|--------|-------|----------|---------|
| —     | —     | —     | wsdiv1 | wsdiv0 | rxena | rckinvrx | rxsubqw |

### Table 33 Description of the SUBMODERX register bits

| BIT | NAME     | VALUE | DESCRIPTION                           |
|-----|----------|-------|---------------------------------------|
| 4   | wsdiv1   | 00    | no oversampling (normal CD-ROM modes) |
|     |          | 01    | 2 times oversampling                  |
| 3   | wsdiv0   | 10    | 4 times oversampling                  |
|     |          | 11    | 8 times oversampling                  |
| 2   | rxena    | 0     | subcode receive interface is disabled |
|     |          | 1     | subcode receive interface is enabled  |
| 1   | rckinvrx | 0     | normal RCK output                     |
|     |          | 1     | invert the RCK output                 |
| 0   | rxsubqw  | 0     | 3-wire subcode                        |
|     |          | 1     | Philips V4 mode (sub Q-W)             |

SAA7381

| ADDRESS | NAME            | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF2BH   | SUBPOINTR-L     | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF2AH   | SUBPOINTR-H     | -     | _     | -     | _     | -     | -     | -     | s8    |
| FF2FH   | SUBPOINTW-L     | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF2EH   | SUBPOINTW-H     | _     | _     | _     | _     | _     | _     | _     | s8    |
| FF2DH   | SUBBASEPOINTR-L | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF2CH   | SUBBASEPOINTR-H | -     | _     | _     | -     | _     | _     | _     | s8    |
| FF31H   | SUBBASEPOINTW-L | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF30H   | SUBBASEPOINTW-H | _     | _     | _     | -     | _     | _     | _     | s8    |

Table 34 Subcode general (input/output pointers)

### 7.3.2.1 Subcode buffering

The subcode is buffered in the AUXSEGMENT register. Two offset pointers, SUBPOINTR-L and SUBPOINTR-H, and SUBPOINTW-L and SUBPOINTW-H are associated with it. The R pointer is for the subcode output and the W pointer for the subcode input.

Pointers are also provided to point at the offset into the AUXSEGMENT register where the start of a subcode frame will be found, SUBBASEPOINTR-L and SUBBASEPOINTR-H and SUBBASEPOINTW-L and SUBBASEPOINTW-H. The block copy engine is expected to use these to automatically move the subcode into the segment pointed at by DRIVECURSEG register.

### 7.3.3 GENERAL DESCRIPTION OF THE MULTIMEDIA OUTPUT INTERFACE

### Table 35 Multimedia output interface register bits

| ADDRESS | NAME                   | BIT 7 | BIT 6 | BIT 5     | BIT 4 | BIT 3   | BIT 2          | BIT 1 | BIT 0 |
|---------|------------------------|-------|-------|-----------|-------|---------|----------------|-------|-------|
| FF32H   | CDDA-H                 | _     | -     | _         | _     | _       | _              | a9    | a8    |
| FF33H   | CDDA-L                 | а7    | a6    | a5        | a4    | a3      | a2             | a1    | a0    |
| FF34H   | DAOFFSET-H             | _     | -     | _         | —     | a11     | a10            | a9    | a8    |
| FF35H   | DAOFFSET-L             | а7    | a6    | a5        | a4    | a3      | a2             | a1    | a0    |
| FF16H   | MMCTRL <sup>(1)</sup>  | mmdiv |       |           | spdx2 | wslen   | mcl            | ksel  |       |
| FF70H   | IECCTRL <sup>(2)</sup> | iecen | data  | copyright | preem | vbit    | _              | ac    | cu    |
| FF71H   | IECCAT                 | cat7  | cat6  | cat5      | cat4  | cat3    | cat2           | cat1  | cat0  |
| FF14H   | MMAUD <sup>(3)</sup>   | daen  | eiaj  | master    | _     | leftm   | node rightmode |       | node  |
| FF15H   | MCK_CON <sup>(4)</sup> | _     | _     | _         | _     | mckxtal | mckoe          | d     | iv    |

#### Notes

- 1. See Table 36.
- 2. See Table 39.
- 3. See Table 38.
- 4. See Table 41.

SAA7381

### 7.3.3.1 Basic description of the multimedia output interface

The multimedia data output may be used either with an internal clock or an externally provided clock. The clock used should be a correct multiple of 44100 Hz in order for the block to correctly output IEC 958.

The multimedia interface data FIFO is located in the block of segments associated with AUXSEGMENT master/slave mode operation (see Fig.3).



| BIT     | NAME   | VALUE | DESCRIPTION                                                                   |
|---------|--------|-------|-------------------------------------------------------------------------------|
| 7       | mmdiv  | _     | see Table 37                                                                  |
| 6       |        | _     |                                                                               |
| 5       |        | _     |                                                                               |
| 4       |        | _     |                                                                               |
| 3       | spdx2  | 0     | I <sup>2</sup> S-bus output is single speed                                   |
|         |        | 1     | I <sup>2</sup> S-bus (and IEC 958) output is double speed; video applications |
| 2       | wslen  | 0     | I <sup>2</sup> S-bus bit clock is 64 times the sample rate                    |
|         |        | 1     | I <sup>2</sup> S-bus bit clock is 48 times the sample rate                    |
| 1 and 0 | mcksel | 00    | multimedia internal clock is CRIN pin                                         |
|         |        | 01    | multimedia internal clock is MCK pin                                          |
|         |        | 10    | multimedia internal clock is system clock                                     |

| Table 36 Description of the MMCTRL register | eaister bits |
|---------------------------------------------|--------------|
|---------------------------------------------|--------------|

### SAA7381

|              |                                   |                                                |                  | I <sup>2</sup> S-BUS                           |                         |                         |       |                      |
|--------------|-----------------------------------|------------------------------------------------|------------------|------------------------------------------------|-------------------------|-------------------------|-------|----------------------|
| DIVIDER CODE | mcł                               | I <sup>2</sup> S-BUS,<br>48 BITS PER<br>SAMPLE |                  | I <sup>2</sup> S-BUS,<br>64 BITS PER<br>SAMPLE |                         | IEC 958                 |       |                      |
|              | MULTIMEDIA<br>CLOCK<br>OVERSAMPLE | REQUIRED<br>FREQUENCY<br>(Hz)                  | n = 1            | n = 2                                          | n = 1                   | n = 2                   | n = 1 | (n = 2)              |
| 0000         | 48fs                              | 2116800                                        | 1 <sup>(1)</sup> | _                                              | _                       | _                       | _     | _                    |
| 0001         | 64f <sub>s</sub>                  | 2822400                                        | -                | _                                              | <b>1</b> <sup>(1)</sup> | _                       | _     | _                    |
| 0010         | 96f <sub>s</sub>                  | 4233600                                        | 2                | 1 <sup>(1)</sup>                               | 1.5 <sup>(1)</sup>      | _                       | _     | _                    |
| 0011         | 128f <sub>s</sub>                 | 5644800                                        | -                | _                                              | 2                       | <b>1</b> <sup>(1)</sup> | 1     | -                    |
| 0100         | 192f <sub>s</sub>                 | 8467200                                        | 4                | 2                                              | 3                       | 1.5 <sup>(1)</sup>      | 1.5   | -                    |
| 0101         | 256f <sub>s</sub>                 | 11289600                                       | _                | _                                              | 4                       | 2                       | 2     | (1)                  |
| 0110         | 384f <sub>s</sub>                 | 16934400                                       | 8                | 4                                              | 6                       | 3                       | 3     | (1.5) <sup>(2)</sup> |
| 0111         | 512f <sub>s</sub>                 | 22579200                                       | -                | _                                              | 8                       | 4                       | 4     | (2)                  |
| 1000         | 768f <sub>s</sub>                 | 33868800                                       | 16               | 8                                              | 12                      | 6                       | 6     | (3)                  |
| 1001         | 1024f <sub>s</sub>                | 45158400                                       | -                | _                                              | 16                      | 8                       | 8     | (4)                  |
| 1010         | 1 536f <sub>s</sub>               | 67737600                                       | 32               | 16                                             | 24                      | 12                      | 12    | (6)                  |

Table 37 mmdiv/mcksel relationship to clocks needed for I<sup>2</sup>S-bus and IEC 958

### Notes

- 1. For these combinations the duty factor of the output SCK2 clock is not necessarily 50%. These combinations are therefore not recommended.
- 2. This is illegal but possible.

| Table 38 | Description | of the MMAUD | register | control bits |
|----------|-------------|--------------|----------|--------------|
|----------|-------------|--------------|----------|--------------|

| BIT | NAME                | VALUE | DESCRIPTION                                                                                                 |
|-----|---------------------|-------|-------------------------------------------------------------------------------------------------------------|
| 7   | daen <sup>(1)</sup> | 0     | CD-DA interface is off                                                                                      |
|     |                     | 1     | CD-DA Interface is on                                                                                       |
| 6   | eiaj                | 0     | I <sup>2</sup> S-bus serial mode                                                                            |
|     |                     | 1     | EIAJ16 serial mode                                                                                          |
| 5   | master              | 0     | I <sup>2</sup> S-bus is slave                                                                               |
|     |                     | 1     | I <sup>2</sup> S-bus is master                                                                              |
| 3   | leftmode            | 00    | I <sup>2</sup> S-bus left channel output is left (default)                                                  |
|     |                     | 01    | I <sup>2</sup> S-bus left channel output is right                                                           |
| 2   |                     | 10    | I <sup>2</sup> S-bus left channel output is muted                                                           |
|     |                     | 11    | reserved                                                                                                    |
| 1   | rightmode           | 00    | I <sup>2</sup> S-bus right channel output is right (default). This is the opposite default to left channel. |
|     |                     | 01    | I <sup>2</sup> S-bus right channel output is left                                                           |
| 0   | ] [                 | 10    | I <sup>2</sup> S-bus right channel output is muted                                                          |
|     |                     | 11    | reserved                                                                                                    |

### Note

1. If enabled, data is written to the CDDA interface from a FIFO located in the CDDA register space. If either 'daen' = 1 or 'iecen' = 1 (ieccrtl), the interface will become active.

SAA7381

### 7.3.4 IEC 958/EBU OUTPUT

Table 39 Description of the IECCTRL register control bits (notes 1 and 2)

| BIT    | NAME      | VALUE | DESCRIPTION                                                                                                     |
|--------|-----------|-------|-----------------------------------------------------------------------------------------------------------------|
| 7      | iecen     | 0     | IEC 958 interface is off                                                                                        |
|        |           | 1     | IEC 958 Interface is on                                                                                         |
| 6      | data      | 0     | IEC 958 contains audio information                                                                              |
|        |           | 1     | IEC 958 contains data                                                                                           |
| 5      | copyright | 0     | IEC 958 C bit in system channel is logic 0                                                                      |
|        |           | 1     | IEC 958 C bit in system channel is logic 1                                                                      |
| 4      | preem     | 0     | audio pre-emphasis off/IEC 958 contains data                                                                    |
|        |           | 1     | audio pre-emphasis on (only appears in IEC 958 C channel;<br>de-emphasis bit is not implemented in the SAA7381) |
| 3      | vbit      | 0     | audio samples suitable for conversion                                                                           |
|        |           | 1     | mute audio, or signal is data and should not be digital-to-analog converted at any time                         |
| 2      | _         | _     | reserved                                                                                                        |
|        |           | _     | reserved                                                                                                        |
| 1 to 0 | accu      | 00    | level II clock accuracy                                                                                         |
|        |           | 01    | level III clock accuracy (depends on mck/system clock)                                                          |
|        |           | 10    | reserved                                                                                                        |
|        |           | 11    | reserved                                                                                                        |

### Notes

1. In order for the IEC interface to operate correctly, it will require a clock at 128fs to be present.

2. The 'vbit' is copied into the V bit of the IEC 958 frame.

 Table 40 IEC 958 system channel bit mapping (note 1)

| BIT NUMBER | BIT OFFSET |      |           |       |       |       |      |      |  |  |
|------------|------------|------|-----------|-------|-------|-------|------|------|--|--|
|            | +0         | +1   | +2        | +3    | +4    | +5    | +6   | +7   |  |  |
| 0          | 0          | data | copyright | preem | _     | 0     | 0    | 0    |  |  |
| 8          | cat0       | cat1 | cat2      | cat3  | cat4  | cat5  | cat6 | cat7 |  |  |
| 16         | 0          | 0    | 0         | 0     | 0     | 0     | 0    | 0    |  |  |
| 24         | 0          | 0    | 0         | 0     | accu0 | accu1 | 0    | 0    |  |  |

### Note

1. The C bit is updated on an IEC frame-by-frame basis, the bit offset corresponds to the IEC frame offset. They are repeated for both left and right channels. Bit 0 is present in the C bit of the first sample pair of the IEC superframe of 192 sample pairs.

SAA7381

| BIT     | NAME    | VALUE | DESCRIPTION                                            |
|---------|---------|-------|--------------------------------------------------------|
| 3       | mckxtal | 0     | MCK reference is system clock (default)                |
|         |         | 1     | MCK reference is the CRIN pin                          |
| 2       | mckoe   | 0     | MCK pin is 3-state, an input to the MM block (default) |
|         |         | 1     | MCK pin is output                                      |
| 1 and 0 | div     | 00    | MCK reference is divided by 2 (default)                |
|         |         | 01    | MCK reference is divided by 1.5                        |
|         |         | 10    | MCK reference is divided by 1                          |
|         |         | 11    | MCK reference is divided by 4                          |

Table 41 Description of the MCK\_CON register bits (note 1)

#### Note

1. The bits in this register control the use of the MCK pin as an output to clock a CD-DSP. The division ratios chosen are suitable for the SAA7335 or CDR60 devices. If the MCK pin is not being used then it should be pulled HIGH for correct selection of the internal multimedia clocks.

### 7.3.5 MEMORY-TO-MEMORY BLOCK COPY FUNCTION

This function is provided for the user to move and copy blocks of RAM. Two pointer sets are provided. The second of these is for the semi-automatic subcode copying function of the subcode in the block. It is independent of the first copy register set, which is available for e.g. audio copying needed in the PLAY AUDIO function with the SAA7381, and for subcode copying when recording.

When started, the copy process will copy the COPYCOUNT register bytes from the 'FROM' pointers to the 'TO' pointers. A copying process may be stopped during its operation by writing to the 'copyend' bit.

### 7.3.5.1 Automatic copying of received subcode-to-data block

When enabled, the newly received subcode will be automatically transferred to the current host segment in RAM.

The only register that is user programmable in the subcode copying engine is the COPYFROM2OFFSET pointer.

The 'COPYFROM2OFFSET' pointer is set up by the sub-CPU to point into the subcode input FIFO. It points at the first byte of subcode to be copied into the current host data block. Once triggered, this copy is automatically set-up to correctly transfer the next block of subcode correctly without host intervention.

Copying of the subcode in the opposite direction is performed by the sub-CPU commanding an interleaved copy of data using the user block copy registers. This does not have to be as fast for subcode output to the user channel of the IEC 958 output as this is only specified to n = 1 rate.

SAA7381

### Table 42 Block copy registers

| ADDRESS | NAME                       | BIT 7 | BIT 6 | BIT 5  | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0           |
|---------|----------------------------|-------|-------|--------|-------|-------|-------|-------|-----------------|
| FF67H   | COPYCONTROL <sup>(1)</sup> | dfrom | dto   | dfrom2 | dto2  | en1   | en2   | raw   | sub_deint_order |
| FF3BH   | COPYFROMSEG-L              | s7    | s6    | s5     | s4    | s3    | s2    | s1    | s0              |
| FF3AH   | COPYFROMSEG-H              | _     | _     | _      | _     | s11   | s10   | s9    | s8              |
| FF37H   | COPYFROMOFFSET-L           | a7    | a6    | a5     | a4    | a3    | a2    | a1    | a0              |
| FF36H   | COPYFROMOFFSET-H           | -     | -     | -      | -     | a11   | a10   | a9    | a8              |
| FF3DH   | COPYTOSEG-L                | s7    | s6    | s5     | s4    | s3    | s2    | s1    | s0              |
| FF3CH   | COPYTOSEG-H                | -     | -     | -      | -     | s11   | s10   | s9    | s8              |
| FF39H   | COPYTOOFFSET-L             | a7    | a6    | a5     | a4    | a3    | a2    | a1    | a0              |
| FF38H   | COPYTOOFFSET-H             | -     | -     | -      | -     | a11   | a10   | a9    | a8              |
| FF63H   | COPYCOUNT-L                | c7    | c6    | c5     | c4    | c3    | c2    | c1    | c0              |
| FF62H   | COPYCOUNT-H                | —     | -     | _      | _     | c11   | c10   | c9    | c8              |
| FF3FH   | FROM2OFFSET-L              | a7    | a6    | a5     | a4    | a3    | a2    | a1    | a0              |
| FF3EH   | FROM2OFFSET-H              | _     | -     | -      | _     | a11   | a10   | a9    | a8              |
| FF41H   | TO2OFFSET-L                | a7    | a6    | a5     | a4    | a3    | a2    | a1    | a0              |
| FF40H   | TO2OFFSET-H                | _     | _     | _      | _     | a11   | a10   | a9    | _               |

### Note

1. See Table 43.

### Table 43 Description of the COPYCONTROL register bits

| BIT | NAME            | VALUE | DESCRIPTION                                                     |
|-----|-----------------|-------|-----------------------------------------------------------------|
| 7   | dfrom           | 0     | linear addressing with COPYOFFSET                               |
|     |                 | 1     | interleaved addressing with COPYOFFSET                          |
| 6   | dto             | 0     | linear addressing with COPYTOOFFSET                             |
|     |                 | 1     | interleaved addressing with COPYTOOFFSET                        |
| 5   | dfrom2          | 0     | linear addressing in copy from block, subcode copy engine       |
|     |                 | 1     | interleaved addressing in copy to block, subcode copy engine    |
| 4   | dto2            | 0     | linear addressing in copy to block, subcode copy engine         |
|     |                 | 1     | interleaved addressing in copy to block, user block copy engine |
| 3   | en1             | 0     | user block copy disabled                                        |
|     |                 | 1     | user block copy enabled                                         |
| 2   | en2             | 0     | subcode block copy disabled                                     |
|     |                 | 1     | subcode block copy enabled                                      |
| 1   | raw             | 0     | enable complete subcode de-interleaving process                 |
|     |                 | 1     | de-interleave R-W bytes, but skip Q byte de-interleaving        |
| 0   | sub_deint_order | 0     | de-interleave received subcode (CD-ROM)                         |
|     |                 | 1     | Interleave transmitted subcode (CD-R)                           |

SAA7381

### 7.4 Interrupt registers

The interrupt system in the SAA7381 is intended to make it possible to acknowledge interrupts both independently without interference or together. There are two interrupt pins to the sub-CPU from the SAA7381. The INT pin is associated only with the host interface register IFSTAT (address FF92H). The INT2 pin is associated with 6 interrupt registers which cover the SAA7381 drive block and UART. Two status/reset registers and two interrupt enable register for the drive block and one status/reset register plus an interrupt enable register for the UART.

| Table 11 IESTAT | interrupt register fo | r the heat interface. | address EE02U   | note 1) |
|-----------------|-----------------------|-----------------------|-----------------|---------|
| Table 44 IFSTAT | interrupt register fo | r the nost intenace,  | address FF92H ( | note I) |

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4      | BIT 3 | BIT 2 | BIT 1   | BIT 0                |
|--------|-------|-------|-------|------------|-------|-------|---------|----------------------|
| R      | cmdi  | dtei  | drqi  | ultra_stop | dtbsy | srsti | reset08 | a0comp/<br>crc_error |

#### Note

1. Interrupt status bits are described in the host interface; see Section 7.5.3.18.

#### 7.4.1 INTERRUPT 1

By writing a logic 1 to the INT1RESET register the bits will negate the INT1STATUS register bits. Writing a logic 1 to an INT1ENABLE bit will enable the corresponding status bit. Writing a logic 0 will disable the status to zero.

 Table 45 INT1STATUS: drive interrupt register status; address FF7AH (see Table 54)

| ACCESS | BIT 7 | BIT 6 | BIT 5  | BIT 4 | BIT 3  | BIT 2  | BIT 1 | BIT 0 |
|--------|-------|-------|--------|-------|--------|--------|-------|-------|
| R      | dec   | nocor | erablk | cblk  | uceblk | crc-ng | q-ng  | int2  |

 Table 46 INT1RESET: drive interrupt register reset; address FF7AH (see Table 54)

| ACCESS | BIT 7 | BIT 6 | BIT 5  | BIT 4 | BIT 3  | BIT 2  | BIT 1 | BIT 0 |
|--------|-------|-------|--------|-------|--------|--------|-------|-------|
| W      | dec   | nocor | erablk | cblk  | uceblk | crc-ng | q-ng  | —     |

7.4.1.1 INT1ENABLE: drive interrupt register enable bits

 Table 47
 INT1ENABLE: drive interrupt register enable; address FF7BH (see Table 54)

| ACCESS | BIT 7 | BIT 6 | BIT 5  | BIT 4 | BIT 3  | BIT 2  | BIT 1 | BIT 0 |
|--------|-------|-------|--------|-------|--------|--------|-------|-------|
| W      | dec   | nocor | erablk | cblk  | uceblk | crc-ng | q-ng  | int2  |

SAA7381

### 7.4.2 INTERRUPT 2

By writing a logic 1 to INT2RESET register bits will negate the INT2STATUS bit. Writing a logic 1 to an INT2ENABLE bit will enable the corresponding status bit. Writing a logic 0 will disable the status to zero.

| ACCESS | BIT 7                 | BIT 6           | BIT 5                | BIT 4   | BIT 3              | BIT 2    | BIT 1 | BIT 0   |
|--------|-----------------------|-----------------|----------------------|---------|--------------------|----------|-------|---------|
| R      | hostbyte<br>countzero | drive<br>reload | hostrel<br>countzero | copyend | subcode<br>syncint | dmatxint | int1  | uartint |

Table 49 INT2RESET: drive interrupt register reset; address FF7CH (see Table 54)

| ACCESS | BIT 7     | BIT 6  | BIT 5     | BIT 4   | BIT 3   | BIT 2    | BIT 1 | BIT 0 |
|--------|-----------|--------|-----------|---------|---------|----------|-------|-------|
| W      | hostbyte  | drive  | hostrel   | copyend | subcode | dmatxini | _     | —     |
|        | countzero | reload | countzero |         | syncint |          |       |       |

### Table 50 INT2ENABLE: drive interrupt register enable; address FF7DH (see Table 54)

| ACCESS | BIT 7                 | BIT 6           | BIT 5                | BIT 4   | BIT 3              | BIT 2    | BIT 1 | BIT 0 |
|--------|-----------------------|-----------------|----------------------|---------|--------------------|----------|-------|-------|
| W      | hostbyte<br>countzero | drive<br>reload | hostrel<br>countzero | copyend | subcode<br>syncint | dmatxini | -     | -     |

### 7.4.3 UART INTERRUPT

By writing a logic 1 to the INT2RESET register bits will negate the INT2STATUS bit. Writing a logic 1 to an INT2ENABLE bit will enable the corresponding status bit. Writing a logic 0 will disable the status to zero.

The INT2 interrupt corresponds to not (INT1 or INT2 or UARTINT).

### Table 51 UARTINTSTATUS: UART interrupt register status; address FF78H (see Table 54)

| ACCESS | BIT 7   | BIT 6   | BIT 5      | BIT 4      | BIT 3      | BIT 2   | BIT 1   | BIT 0    |
|--------|---------|---------|------------|------------|------------|---------|---------|----------|
| R      | comsync | syssync | notcomsync | notsyssync | nottxbfull | rxbfull | overrun | rxparity |

#### Table 52 UARTINTRESET: UART interrupt register reset; address FF78H (see Table 54)

| Α | CCESS | BIT 7   | BIT 6   | BIT 5      | BIT 4      | BIT 3      | BIT 2   | BIT 1   | BIT 0    |
|---|-------|---------|---------|------------|------------|------------|---------|---------|----------|
|   | W     | comsync | syssync | notcomsync | notsyssync | nottxbfull | rxbfull | overrun | rxparity |

#### Table 53 UARTINTENABLE: UART interrupt register enable; address FF79H (see Table 54)

| ACCESS | BIT 7   | BIT 6   | BIT 5      | BIT 4      | BIT 3      | BIT 2   | BIT 1   | BIT 0    |
|--------|---------|---------|------------|------------|------------|---------|---------|----------|
| W      | comsync | syssync | notcomsync | notsyssync | nottxbfull | rxbfull | overrun | rxparity |

SAA7381

|             | ption of the interrupt |                                                                                                                        |
|-------------|------------------------|------------------------------------------------------------------------------------------------------------------------|
| REGISTER    | INTERRUPT              | DESCRIPTION                                                                                                            |
| INTERRUPT 1 | dec                    | block by block decoder interrupt                                                                                       |
|             | nocor                  | ERCO cannot be started on current block                                                                                |
|             | erablk                 | one or more bytes coming from CD-DSP have been flagged with error                                                      |
|             | cblk                   | corrected current block.                                                                                               |
|             | uceblk                 | one or more bytes remain in error                                                                                      |
|             | crc-ng                 | bad CRC on current block                                                                                               |
|             | q-ng                   | bad Q CRC on current block                                                                                             |
|             | int2                   | indicates that interrupt is caused by an enabled interrupt from INT2                                                   |
| INTERRUPT 2 | hostbytecountzero      | the host counter decremented to zero and may have been reloaded; requires sub-CPU intervention when reload is disabled |
|             | drivereload            | drive processing pointers have reloaded                                                                                |
|             | hostcursegcntzero      | the host reload count decremented to zero; no more host reloads are available                                          |
|             | copyend                | copy process has finished                                                                                              |
|             | subcode syncint        | subcode receive block detection of early subcode 98 frame sync period                                                  |
|             | dmatxint               | asserts when 'dmacount' reaches zero with 'dmaon' bit set                                                              |
|             | int1                   | indicates that interrupt is caused by an enabled interrupt from INT1                                                   |
|             | uartint                | indicates that the interrupt is from the UART interrupt register                                                       |
| UART INT    | comsync                | UART COMSYNC pin rising edge interrupt                                                                                 |
|             | syssync                | SYSSYNC pin rising edge interrupt                                                                                      |
|             | notcomsync             | COMSYNC falling edge interrupt                                                                                         |
|             | notsyssync             | SYSSYNC pin falling edge interrupt                                                                                     |
|             | nottxbfull             | transmit buffer has become empty                                                                                       |
|             | rxbfull                | receive buffer has become full                                                                                         |
|             | overrun                | receive buffer has overrun                                                                                             |
|             | rxparity               | a character has been received with illegal parity                                                                      |
|             |                        |                                                                                                                        |

### Table 54 Description of the interrupt register bits

### 7.5 Host interface

### 7.5.1 INTRODUCTION

The SAA7381 host interface block is responsible for the transfer of data and control information between the memory processor, external host and microcontroller. The host interface operates in conjunction with the SAA7381 Auxiliary block (Aux block). The Aux block contains several registers that automate the SAA7381 memory processor in its task of supplying the host interface with data from the buffer memory and receiving data from the host interface automates data transfer to and from the host, whereas the Aux block automates data transfer, via the memory processor and buffer memory, depending on the CD format.

 Supports ATA Packet Interface (ATAPI revision 2.6) for CD-ROMs

- Supports ATA/ATAPI 16-bit PIO data transfers for Modes 0, 1, 2, 3 and 4
- Supports ATA/ATAPI single/multi word DMA transfers for Modes 0, 1 and 2
- Supports ultra DMA for Mode 0
- Supports generic interface connection to external SCSI controller device (NCR 53CF92)
- Command and status registers of external generic interface controller are optionally mapped via the host interface pins of the SAA7381. The SAA7381 becomes the bus master.
- Operates automatically with multi-block host data transfers

The host interface features are as follows:

### SAA7381

- Reduces microcontroller load in simple streaming transfers to or from host using a circular buffer
- Recognizes ATA SRST, the ATAPI reset command (0X08) and the ATAPI packet command (0XA0) and handles these automatically in ATAPI mode
- Handles unexpected ATA commands during PIO data transfers
- Provides automatic DRQ for all PIO data transfers
- Provides automatic detection of ATAPI packet (A0) command and reception of the packet bytes
- Provides automatic completion sequence for PIO DMA and ultra DMA transfers
- Supports shadowing of registers for single drive configurations with non-existent slave.

7.5.2 DESCRIPTION OF THE HOST INTERFACE BLOCK

The host interface block consists of three FIFOs which can be configured by the DTCTR register to generate the required data path through the host interface block. The design supports ATAPI (revision 2.6) for CD-ROM interfaces. The host interface has a shadow status register to permit proper ATA operation. The PDIAG and DASP signals are controlled by the register bits in the host interface block.

The microcontroller has access to all registers in the host interface block. The microcontroller can control all operations required for data transfer to and from the host, but may configure the host interface sequencer to automate the following three operations:

- 1. Automation of detection of the A0 packet command and reception of the 12-byte packet.
- 2. Automation of the data transfer sequences for PIO, DMA and ultra DMA modes of data transfer.
- 3. Automation of completion sequences for PIO, DMA and ultra DMA modes of data transfer.

The host interface provides a generic interface mode for a glueless connection to an external SCSI controller device. In this mode the microcontroller can configure the registers of the SCSI controller device and initiate DMA transfers.

### 7.5.2.1 The SAA7381 host interface ATAPI registers visible to the host

Table 55 Host interface registers as seen from the host (note 1)

| CS0 | CS1 | DA2 | DA1 | DA0 | HOST READ (DIOR)                       | HOST WRITE (DIOW)                   |
|-----|-----|-----|-----|-----|----------------------------------------|-------------------------------------|
| 1   | 0   | 1   | 1   | 0   | ALT STATUS: alternative status         | ADCTRL: ATAPI device control        |
| 1   | 0   | 1   | 1   | 1   | ADRADR: ATAPI drive address            | not used                            |
| 0   | 1   | 0   | 0   | 0   | DATA: data register                    | DATA: data register                 |
| 0   | 1   | 0   | 0   | 1   | AERR: ATAPI error register             | AFEAT: ATAPI features register      |
| 0   | 1   | 0   | 0   | 1   | SHERR: ATAPI error register (shadow)   | unused                              |
| 0   | 1   | 0   | 1   | 0   | AINTR: ATAPI interrupt reason register | unused                              |
| 0   | 1   | 0   | 1   | 1   | ASAMT: ATAPI SAM TAG register          | ASAMT: ATAPI SAM TAG register       |
| 0   | 1   | 1   | 0   | 0   | DBCL: ATAPI byte count low             | DBCL: ATAPI byte count low          |
| 0   | 1   | 1   | 0   | 1   | DBCH: ATAPI byte count high            | DBCH: ATAPI byte count high         |
| 0   | 1   | 1   | 1   | 0   | ADRSEL: ATAPI drive select register    | ADRSEL: ATAPI drive select register |
| 0   | 1   | 1   | 1   | 1   | ASTAT: ATAPI status register           | ACMD: ATAPI command register        |
| 0   | 1   | 1   | 1   | 1   | SHSTAT: ATAPI status register (shadow) | unused                              |

### Note

1. The operation of these registers complies with the ATA-3 specification (revision 6) and the ATAPI specification (revision 2.6).

### 7.5.2.2 The SAA7381 host interface registers visible by the microcontroller

The registers listed in Table 56 are used by the microcontroller to control the operation of the host interface block. The ATAPI command block registers (ADATA, ASTAT, ADRADR, ASAMT, ADRSEL, AINTR, AERR, ACMD, ADCTR, AFEAT and APCMD) are dual port registers which can be accessed either by the microcontroller or the host PC depending the state of the BSY flag, bit 7 of the ASTAT register.

| ADDR  | ACCESS | NAME    | BIT 7                                   | BIT 6   | BIT 5   | BIT 4             | BIT 3   | BIT 2            | BIT 1     | BIT 0                |  |
|-------|--------|---------|-----------------------------------------|---------|---------|-------------------|---------|------------------|-----------|----------------------|--|
| FF80H | W      | ADATA   | ATAPI Data register                     |         |         |                   |         |                  |           |                      |  |
| FF81H | RW     | IFCTRL  | cmdien                                  | dteien  | drqien  | ultra_<br>stopien | _       | srstien          | _         | -                    |  |
| FF82H | RW     | DBCL    | Data Byte Count register (bits 7 to 0)  |         |         |                   |         |                  |           |                      |  |
| FF83H | RW     | DBCH    | Data Byte Count register (bits 15 to 8) |         |         |                   |         |                  |           |                      |  |
| FF84H | W      | DTRG    | Data transfer Trigger register          |         |         |                   |         |                  |           |                      |  |
| FF85H | W      | DTACK   | Data Transfer Acknowledge register      |         |         |                   |         |                  |           |                      |  |
| FF86H | W      | RESET   | reserved hsel                           |         |         |                   |         |                  |           |                      |  |
| FF87H | RW     | ASTAT   | ATAPI Status register (see Table 61)    |         |         |                   |         |                  |           |                      |  |
| FF88H | W      | ITRG    | host Interrupt Trigger register         |         |         |                   |         |                  |           |                      |  |
| FF89H | W      | ADRADR  | ATAPI Drive Address register            |         |         |                   |         |                  |           |                      |  |
| FF8AH | RW     | ASAMT   | ATAPI SAM tag register                  |         |         |                   |         |                  |           |                      |  |
| FF8BH | RW     | DTCTR   | reserve<br>d                            | dmamode | dma     | ultra_dma         | rdrv    |                  | trant     |                      |  |
| FF8CH | RW     | ADRSEL  | ATAPI Drive Select register             |         |         |                   |         |                  |           |                      |  |
| FF8DH | RW     | AINTR   | ATAPI Interrupt Reason register         |         |         |                   |         |                  |           |                      |  |
| FF8EH | RW     | AERR    | ATAPI Error Register                    |         |         |                   |         |                  |           |                      |  |
| FF8FH | R      | ACMD    | ATAPI Command register                  |         |         |                   |         |                  |           |                      |  |
| FF90H | R      | ADCTR   | ATAPI Device Control Register           |         |         |                   |         |                  |           |                      |  |
| FF91H | R      | AFEAT   | ATAPI Features register                 |         |         |                   |         |                  |           |                      |  |
| FF92H | RW     | IFSTAT  | cmdi                                    | dtei    | drqi    | ultra_stop        | dtbsy   | srsti            | reset08   | a0comp/<br>crc_error |  |
| FF93H | R      | APCMD   | ATAPI Packet Command register           |         |         |                   |         |                  |           |                      |  |
| FF94H | RW     | HICONF0 | ultractrl2 to ultractrl0                |         |         | dynhosthiprior    |         | hrequest         |           | shadow               |  |
| FF95H | RW     | HICONF1 | dmaen                                   | shhpbit | udmaoff | flushfifo         | _       | unmaskdtie       | clear_reg | ultractrl3           |  |
| FF96H | RW     | HISEQ   | autoa0                                  | autodrq | comp    | error             | sus_seq | repeat<br>autoA0 | _         | _                    |  |

Table 56 Host registers as seen by the microcontroller

1997 Aug 12

ATAPI CD-R block decoder

Objective specification

1997 Aug 12

| ADDR  | ACCESS | NAME                 | BIT 7        | BIT 6                        | BIT 5 | BIT 4      | BIT 3            | BIT 2  | BIT 1 | BIT 0   |  |  |
|-------|--------|----------------------|--------------|------------------------------|-------|------------|------------------|--------|-------|---------|--|--|
| FF97H | RW     | SHSTAT               | 0            | 0                            | 0     | 0          | 0                | 0      | 0     | shcheck |  |  |
| FF98H | RW     | SHERR                | 0            | 0                            | 0     | 0          | 0                | shabrt | 0     | 0       |  |  |
| FF99H | RW     | HIDEV                | pdiag<br>out |                              |       |            |                  |        |       |         |  |  |
| FF9AH | R      | HISTAT               |              | not used                     |       |            |                  |        |       |         |  |  |
| FFA0H | RW     | TRANSFER<br>COUNTER  |              | byte count (bits 7 to 0)     |       |            |                  |        |       |         |  |  |
| FFA1H | RW     | TRANSFER<br>COUNTER  |              | byte count (bits 15 to 8)    |       |            |                  |        |       |         |  |  |
| FFA2H | RW     | TRANSFER<br>COUNTER  |              |                              |       | byte count | (bits 23 to 16   | )      |       |         |  |  |
| FFA3H | RW     | TRANSFER<br>COUNTER  |              |                              |       | byte count | (bits 31 to 24   | )      |       |         |  |  |
| FFA4H | RW     | PACKETSIZE<br>STORE  |              |                              |       | byte cour  | nt (bits 7 to 0) |        |       |         |  |  |
| FFA5H | RW     | PACKETSIZE<br>STORE  |              | byte count (bits 15 to 8)    |       |            |                  |        |       |         |  |  |
| FFA6H | R      | SEQUENCER<br>_STATUS | _            | sequence state (bits 5 to 0) |       |            |                  |        |       |         |  |  |

SAA7381

ATAPI CD-R block decoder

SAA7381

## 7.5.3 DESCRIPTION OF THE HOST INTERFACE REGISTERS

This section describes the operation of the register bits in the SAA7381 host interface block.

## 7.5.3.1 ADATA

This is a 12-byte FIFO used to transfer data from the microcontroller to the host. To transfer data the 'trant' bits (0 to 2) of the DTCTR register must be set to 101.

## 7.5.3.2 IFCTRL

### Table 57 IFCTRL: address FF81H (note 1)

| ACCESS | BIT 7  | BIT 6  | BIT 5  | BIT 4         | BIT 3 | BIT 2   | BIT 1 | BIT 0 |
|--------|--------|--------|--------|---------------|-------|---------|-------|-------|
| RW     | cmdien | dteien | drqien | ultra_stopien | _     | srstien | -     | -     |

### Note

Bits 'cmdien', 'dreien', 'dreien' and 'ultra\_stopien', are the enable bits for interrupt bits 'cmdi', 'drei', 'drei' and 'ultra\_stop' in the IFSTAT register. These are interrupt masks, enabling/disabling the microcontroller interrupt pin. They do not affect the bits in the IFSTAT register. If set to logic 1, the corresponding interrupt is enabled. It should be noted that these masks do not clear the interrupts. Bit 2 (srstien) is asserted at power-on reset, enabling the 'srsti' interrupt. If set to logic 1 the 'srsti' interrupt is disabled.

## 7.5.3.3 DBCL and DBCH

These are the ATAPI byte count registers. DBCL is the lower byte (bits 7 to 0) register and DBCH is the higher byte (bits 15 to 8) register. These registers are read/writable for both the PC host and microcontroller.

## Table 58 ATAPI byte count registers; addresses FF82H (DBCL) and FF83H DBCH)

| ACCESS | BIT 7 | BIT 6                                        | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |  |  |
|--------|-------|----------------------------------------------|-------|-------|-------|-------|-------|-------|--|--|
| RW     |       | Data Byte Count register bits (bits 7 to 0)  |       |       |       |       |       |       |  |  |
| RW     |       | Data Byte Count register bits (bits 15 to 8) |       |       |       |       |       |       |  |  |

The data byte counter is used by the microcontroller to control the number of bytes that are transferred during a data transfer. During memory-to-host data transfers the data byte counter is decremented after every host read. During host-to-memory data transfers the data byte counter is decremented as data is written into the external buffer memory. The host may write to DBCL/DBCH to indicate to the microcontroller the maximum transfer/reception length, which may be updated by the auto sequencer PACKETSIZE STORE registers or from the TRANSFER COUNTER (for the remainder packet size) or directly by the microcontroller. The host can then read back the updated byte count to be transferred.

## 7.5.3.4 DTRG

Writing to this register starts a data transfer. The data written is discarded.

## 7.5.3.5 DTACK

Writing to this register clears the DTEI interrupt and the 'A0comp/crc\_error' flag. The data written is discarded.

SAA7381

## 7.5.3.6 RESET

Writing to this register resets the SAA7381 and initializes all the registers on the device.

Table 59 RESET; address FF86H (note 1)

| ACCESS | BIT 7 | BIT 6 | BIT 5    | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|-------|-------|----------|-------|-------|-------|-------|-------|
| W      |       |       | reserved |       | hsel  |       |       |       |

### Note

1. The 'hsel' bits (see Table 60) control the mode of operation of the host interface block. After a power-on reset the 'hsel' bits default to 000, i.e. the host 3-state pins are 3-stated. The firmware must configure the 'hsel' bits for the desired mode of operation after every hardware reset. It should be noted that any write operation by the microcontroller to this register will result in the resetting of all other SAA7381 registers to their default condition.

### Table 60 Description of the 'hsel' bits

| hsel2 to hsel0 | HOST INTERFACE MODE | DESCRIPTION                                         |
|----------------|---------------------|-----------------------------------------------------|
| 000            | unknown host        | all host pins 3-state, default after hardware reset |
| 001            | ΑΤΑΡΙ               | ATAPI Interface mode                                |
| 011            | generic 8-bit       | generic interface mode, with 8-bit transfers        |
| 100            | generic 16-bit      | generic interface mode, with 16-bit transfers       |
| others         | reserved            | for future enhancements                             |

# 7.5.3.7 ASTAT

This is the ATAPI status register.

## Table 61 ASTAT: address FF87H (notes 1 and 2)

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| RW     | bsy   | drdy  | dmar  | dsc   | drq   | corr  | reset | check |

### Notes

- 1. The 'bsy' flag bit 7 will be set to logic 1 when:
  - a) The host writes to the ACMD register and the SAA7381 is the selected drive.
  - b) The host writes the execute drive diagnostic command (90H) to the ACMD register.
  - c) The host writes to the ADCTR register and sets the 'srst' bit.
  - d) There is a hardware reset.
- 2. If a host interrupt is asserted then it will be cleared by writing to this register.

# 7.5.3.8 ITRG

In the ATAPI mode writing to this register generates a PC host interrupt on the INT pin. This interrupt is cleared when the PC host reads the ATAPI status register (ASTAT) or writes to the ATAPI command register.

## 7.5.3.9 ADRADR

This is the ATAPI drive address register for the SAA7381. This uses an obsolete register address ( $\overline{CS1} \rightarrow DA0 = 10111$ ) from the ATAPI register map in the ATAPI specification. Bit 7 of this register is high-impedance when read by the host. After a reset the ATAPI registers are all cleared except for the ASTAT register which has its 'bsy' bit set.

SAA7381

# 7.5.3.10 ASAMT

This is the ATAPI SAM TAG byte register.

## 7.5.3.11 DTCTR

The DTCTR register controls data transfer flows in the host interface block. When reset this register is cleared to all zeros except for the 'rdrv' bit which is set to logic 1. This means the SAA7381 will be then set to device 1 (slave) after a reset.

There are several possible data transfers through the SAA7381 host interface block and these are selected using the 'trant' bits. The transfers are described in Table 64.

### Table 62 DTCTR: address FF8BH (see Tables 63 and 64)

| ACCESS | BIT 7    | BIT 6   | BIT 5 | BIT 4     | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|----------|---------|-------|-----------|-------|-------|-------|-------|
| RW     | reserved | dmamode | dma   | ultra_dma | rdrv  |       | trant |       |

## Table 63 Description of the DTCTR register bits

| BIT | NAME      | DESCRIPTION                                                                                                                                                                                                                                                                                                  |
|-----|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | dmamode   | DMA mode select; controls whether the DMA transfer is single word or multi-word                                                                                                                                                                                                                              |
|     |           | dmamode = 1; host Interface DMA data transfers are multi-word                                                                                                                                                                                                                                                |
|     |           | dmamode = 0; host Interface DMA data transfers single word                                                                                                                                                                                                                                                   |
| 5   | dma       | this bit is used to configure the SAA7381 hardware for either a DMA type transfer or a PIO type transfer                                                                                                                                                                                                     |
|     |           | dma = 1; configures the SAA7381 for a DMA transfer                                                                                                                                                                                                                                                           |
|     |           | dma = 0; configures the SAA7381 for a PIO type transfer                                                                                                                                                                                                                                                      |
| 4   | ultra_dma | this bit configures the SAA7381 for ultra DMA transfers. The SAA7381 must also be configured for multi-word DMA transfers for correct operation of ultra DMA i.e. bits 5 and 6 of the DTCTR register must also be set to logic 1 to select ultra DMA                                                         |
|     |           | ultra_dma = 1; configure the SAA7381 for ultra DMA (must be select dma = 1 and dmamode = 1)                                                                                                                                                                                                                  |
|     |           | ultra_dma = 0; default for non-ultra DMA transfers                                                                                                                                                                                                                                                           |
| 3   | rdrv      | this bit selects the device number: the polarity of this bit must be the same as the 'drv' bit in the ATAPI drive select register (ADRSEL) in order for the SAA7381 to communicate with the PC host interface. After reset the microcontroller should configure the 'rdrv' bit as no default may be assumed. |
|     |           | rdrv = 1; the SAA7381 is device 1 i.e slave                                                                                                                                                                                                                                                                  |
|     |           | rdrv = 0; the SAA7381 is device 0 i.e master                                                                                                                                                                                                                                                                 |

SAA7381

| trant<br>(bits 2 to 0) | FROM            | то              | MAXIMUM<br>BYTES      | NOTES                                             |
|------------------------|-----------------|-----------------|-----------------------|---------------------------------------------------|
| 000                    | _               | host            | 65535<br>(ATAPI, PIO) | maximum bytes for auto sequence DMA is 4.3 Gbytes |
| 001                    | host            | memory          | 65535<br>(ATAPI, PIO) | maximum bytes for auto sequence DMA is 4.3 Gbytes |
| 010                    | microcontroller | memory          | _                     | redundant                                         |
| 011                    | memory          | microcontroller | _                     | redundant                                         |
| 100                    | host            | microcontroller | 12                    | PIO; DBC not used, always 12 bytes                |
| 101                    | microcontroller | host            | 12                    | DMA and PIO                                       |
| 11X                    | reserved        | reserved        | reserved              | _                                                 |

## Table 64 Description of the 'trant' bits

## 7.5.3.12 ADRSEL

This is the ATAPI drive select register.

## Table 65 ADRSEL: address FF8CH

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4              | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|-------|-------|-------|--------------------|-------|-------|-------|-------|
| RW     | 1     | 1     | 1     | drv <sup>(1)</sup> | Ι     | —     | -     | —     |

### Note

1. Bit 4 of this register is the 'drv' bit. When this bit is the same as the 'rdrv' bit in the DTCTR register then the SAA7381 will be the selected ATAPI drive and will respond to commands and produce interrupts. The host interrupt pin will also be enabled when the SAA7381 is the selected drive.

# 7.5.3.13 AINTR

This is the ATAPI interrupt reason register. See the ATAPI specification for a detailed description of these register bits.

## Table 66 AINTR: address FF8DH

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2   | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|-------|---------|-------|-------|
| RW     | -     | —     | —     | _     |       | release | io    | cod   |

## 7.5.3.14 AERR

This is the ATAPI error register. See the ATAPI specification for a detailed description of these register bits.

### Table 67 AERR: address FF8EH

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| RW     |       | sens  | e key |       | mcr   | abrt  | eom   | -     |

SAA7381

# 7.5.3.15 ACMD

This is the ATAPI command register. This register is read-only to the microcontroller and write-only to the host. The host should only write to this register when the 'bsy' and 'drq' flags are both zero (see ASTAT register; Section 7.5.3.7).

A 'cmdi' interrupt is generated when:

- The host writes to this register while the SAA7381 is the selected drive (the 'drv' bit in register ADRSEL is equal to the 'rdrv' bit in register DTCTR)
- The host writes the execute drive diagnostic command (90H) to this register.

The microcontroller interrupt (cmdi) is cleared by the SAA7381 when the ACMD register is read by the microcontroller.

## 7.5.3.16 ADCTR

This is the ATAPI device control register.

### Table 68 ADCTR: address FF90H

| ACCESS | BIT 7 | BIT 6    | BIT 5 | BIT 4 | BIT 3 | BIT 2               | BIT 1               | BIT 0 |
|--------|-------|----------|-------|-------|-------|---------------------|---------------------|-------|
| R      |       | reserved |       |       |       | srst <sup>(1)</sup> | nien <sup>(2)</sup> | 0     |

### Notes

- 1. Setting the 'srst' bit causes a 'srsti' interrupt and the 'bsy' bit to be set.
- 2. Bit 'nien' is used to enable or disable the host interrupt. When 'nien' is logic 0 and the drive is selected then the host interrupt pin will be enabled. If 'nien' is logic 1 or the drive is not selected then the host interrupt pin will be in a high-impedance state.

## 7.5.3.17 AFEAT

This is the ATAPI features register. See the ATAPI specification for a detailed description of these register bits.

## Table 69 AFEAT: address FF91H

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1   | BIT 0 |
|--------|-------|-------|-------|-------|-------|-------|---------|-------|
| R      | -     | _     | _     | _     | _     | —     | overlap | dma   |

## 7.5.3.18 IFSTAT

### Table 70 IFSTAT: address FF92H (note 1); see Table 71

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4      | BIT 3 <sup>(2)</sup> | BIT 2 | BIT 1 <sup>(2)</sup> | BIT 0 <sup>(2)</sup> |
|--------|-------|-------|-------|------------|----------------------|-------|----------------------|----------------------|
| RW     | cmdi  | dtei  | drqi  | ultra_stop | dtbsy                | srsti | reset08              | a0comp/<br>crc_error |

### Notes

- 1. All interrupts may be negated by writing a logic 1 to their associated IFSTAT locations.
- 2. These bits are flags which do not generate interrupts.

SAA7381

# Table 71 Description of the IFSTAT register bits

| BIT | NAME                 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | cmdi                 | Command interrupt: in the ATAPI mode this bit is asserted when the PC host has written to the ATAPI command register (see ACMD register; Section 7.5.3.15) and the drive is selected. It is also asserted when the host writes the execute drive diagnostic command (90H) to the ATAPI command register, regardless of whether the drive is selected. It is negated when the microcontroller reads the ACMD register or writes logic 1 to 'cmdi'.                                                                                                                                                                                                                                                                                          |
| 6   | dtei                 | Data transfer end interrupt: this bit is asserted at the end of data transfer. It is negated when the microcontroller writes to the DTACK register or writes logic 1 to 'dtei'. If the ATAPI mode is selected this bit is also asserted when a packet command has been received and after a microcontroller memory transfer. The interrupt generated by this bit can be masked by the auto sequencer.                                                                                                                                                                                                                                                                                                                                      |
| 5   | drqi                 | Auto sequencer data request interrupt: if enabled by 'drqien' (IFCTRL; see Table 57), this bit is asserted after every load of the packet size store into DBCH/DBCL during an 'autodrq' DMA sequence. 'drqi' is cleared along with its associated interrupt by the microcontroller writing logic 1 to 'drqi'.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4   | ultra_stop           | Ultra ATA stop before end of transfer interrupt: if enabled by 'ultra_stopien' (IFCTRL; see Table 57), this bit is asserted if the host stops an ultra ATA data transfer before the TRANSFER COUNTER has reached zero, when 'autodrq' is selected, or before the DBCH/DBCL task file registers reach zero when 'autodrq' is not selected. 'ultra_stop' is cleared along with its associated interrupt by the microcontroller writing logic 1 to 'ultra_stop' (IFSTAT; see Table 70).                                                                                                                                                                                                                                                       |
| 3   | dtbsy                | Data transfer busy: this bit indicates if a data transfer is taking place. It is asserted by writing to the DTRG register and is negated at the end of the transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2   | srsti                | Interrupt/status transfer busy: in ATAPI mode this bit is asserted when the host writes to the ATAPI device control register and sets the 'srsti' bit. It is negated when the microcontroller reads the ADCTR register or by writing a logic 1 to the 'srst' (ADCTR; see Table 68). It should be noted that if this bit is asserted in the ATAPI mode then the microcontroller interrupt will also be asserted. The 'srsti' interrupt cannot be disabled.                                                                                                                                                                                                                                                                                  |
| 1   | reset08              | The reset command 08 has been received: this bit indicates that the last command received was the 08 reset command. Reading the command register ACMD will negate this bit and its associated interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0   | a0comp/<br>crc_error | The A0 command auto sequence is completed or ultra ATA CRC error flag: this bit<br>indicates that A0 command auto sequence is completed i.e. the correct A0 command has<br>been read and the host interface has been configured to receive the 12 byte packet. This<br>bit does generate an interrupt but should be used in conjunction with the 'dtei' interrupt.<br>A microcontroller write to DTACK will negate the 'a0comp' bit.<br>After an ultra DMA data transfer (read from the SAA7381 or write to the SAA7381) this bit<br>may be used in conjunction with the DTEI interrupt to indicate data integrity. If the<br>'crc_error' bit = 0 then the last data transfer was corrupt. Again writing to DTACK will<br>negate this bit. |

# 7.5.3.19 APCMD

During the ATAPI mode this register is used to read the packet command sent by the host. The packet command can only be received if the appropriate mode has been selected (see DTCTR register; Table 62) and a data transfer has been started (see DTRG register; see Table 56).

SAA7381

# 7.5.3.20 HICONF0

This is the host interface configuration register 0

 Table 72
 HICONF0: address
 FF94H

| AC | CESS | BIT 7                    | BIT 6 | BIT 5  | BIT 4    | BIT 3 | BIT 2 | BIT 1  | BIT 0 |
|----|------|--------------------------|-------|--------|----------|-------|-------|--------|-------|
|    | RW   | ultractrl2 to ultractrl0 |       | dynhos | thiprior | hreq  | uest  | shadow |       |

## Table 73 Description of the HICONF0 register bits

| BIT     | NAME                     | DESCRIPTION                                                                                                        |
|---------|--------------------------|--------------------------------------------------------------------------------------------------------------------|
| 7 to 5  | ultractrl2 to ultractrl0 | ultra control bits (3 to 1), see Section 7.5.3.22                                                                  |
| 4       | dynhosthiprior           | dynhosthiprior (1)                                                                                                 |
|         |                          | 0 = N = Dynamic Host High Priority asserted when FIFO is $\frac{1}{3}$ full                                        |
|         |                          | 1 = N = Dynamic Host High Priority asserted when FIFO is $\frac{1}{2}$ full                                        |
| 3       | dynhosthiprior           | dynhosthiprior (0)                                                                                                 |
|         |                          | 0 = (default) dynamic host high priority off                                                                       |
|         |                          | 1 = dynamic host high priority on when FIFO bytes, N, off when > N                                                 |
| 2 and 1 | hrequest                 | hrequest = 00; (default) assert host request when FIFO $\frac{2}{3}$ full                                          |
|         |                          | hrequest = 01; assert host request when FIFO $\frac{1}{2}$ full                                                    |
|         |                          | hrequest = 10; assert host request when FIFO $\frac{1}{3}$ full                                                    |
|         |                          | hrequest = 11; assert host request when FIFO (full $-2$ bytes)                                                     |
| 0       | shadow                   | shadow enable: this bit controls whether shadowing of single drive configurations is enabled                       |
|         |                          | shadow = 1; enables shadowing for single drive configurations when the SAA7381 is master and slave is non existent |
|         |                          | shadow = 0; disables shadowing                                                                                     |

## 7.5.3.21 HICONF1

This is the host interface configuration register 1.

 Table 74
 HICONF1: address
 FF95H (see Table 75)

| ACCESS | BIT 7 | BIT 6   | BIT 5   | BIT 4     | BIT 3 | BIT 2      | BIT 1     | BIT 0      |
|--------|-------|---------|---------|-----------|-------|------------|-----------|------------|
| RW     | dmaen | shhpbit | udmaoff | flushfifo | -     | unmaskdtei | clear_reg | ultractrl3 |

SAA7381

| BIT | NAME       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | dmaen      | DMA suspend: this bit controls whether DMA transfers in generic mode are suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |            | dmaen = 1; host Interface DMA data transfers in generic can be temporarily interrupted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |            | dmaen = 0; host Interface DMA data transfers in generic mode cannot be suspended                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6   | shhpbit    | this bit allows statistical host high priority to be turned off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |            | shhpbit = 0; (default) statistical host high priority turned on                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |            | shhpbit = 1; statistical host high priority turned off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5   | udmaoff    | this bit allows 'udma' to be turned off at the end of a transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |            | udmaoff = 0; (default) switch off the 'ultra_ata' bit in the DTCTR register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |            | udmaoff = 1; do nothing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4   | flushfifo  | Flush 12-byte command FIFO: writing a logic 1 to this bit will 'flush' clear the command FIFO pointer to zero. Clearing the pointer is required if a spurious command is received while the FIFO is being loaded and is also used to ensure a 12-byte command read by the auto sequencer.                                                                                                                                                                                                                                                                                                               |
|     |            | flushfifo = 1; writing a logic 1 clears the FIFO pointer to zero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |            | flushfifo = 0; do nothing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2   | unmaskdtei | Unmask data transfer end interrupt during 'autodrq' sequence: this bit will disable the auto sequencer masking of the 'dtei' interrupts during the 'autodrq' sequence. The 'dtei', bit 6 of the IFSTAT register is not effected by 'unmaskdtei'. If 'unmaskdtei' is asserted the sequencer on detecting the next 'dtei' interrupt, will set the 'bsy' flag, negate the 'drq' flag and suspend operation. The microcontroller may then reconfigure the host interface before negating unmaskdtei bit. When 'unmaskdtei' is negated the sequencer will negate the 'dtei' interrupt and operate as normal. |
|     |            | unmaskdtei = 1; disable 'autodrq' sequencer masking of 'dtei' interrupts and suspend the sequence operation on next 'dtei' interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |            | unmaskdtei = 0; no effect, or restart 'autodrq' sequencer operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1   | clear_reg  | Clear auto sequencer transfer counter and packet size store to zero: this bit will clear the transfer counter and packet size store to zero if a logic 1 is written to it. After the write operation the registers operate as normal and the 'clear_reg' bit will have no effect unless written to again.                                                                                                                                                                                                                                                                                               |
|     |            | clear_reg = 1; clears to zero transfer counter and packet size store                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |            | clear_reg = 0; no effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | ultractrl3 | ultra control bit 3; see Section 7.5.3.22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# SAA7381

## 7.5.3.22 Description of the ultra control bits

The 'ultractrl' register bits can be used to add system clock cycles to various timing limits used in the host interface ultra DMA transfer engine.

This enables the SAA7381 to meet ultra DMA Mode 0 timings when the SAA7381 system clock is higher than 33.8688 MHz.

When the SAA7381 system clock is 33.8688 MHz, maximum data transfer rates in ultra DMA Mode 0 are achieved by setting 'ultractrl' to (0001).

For information on meeting Mode 0 timings for system clocks other than 33.8688 MHz, please consult the user manual or product support.

# 7.5.3.23 HISEQ

 Table 76
 HISEQ: host interface sequencer register; address FF96H (see Table 77)

| ACCESS | BIT 7  | BIT 6   | BIT 5 | BIT 4 | BIT 3   | BIT 2         | BIT 1 | BIT 0 |
|--------|--------|---------|-------|-------|---------|---------------|-------|-------|
| RW     | autoa0 | autodrq | comp  | error | sus_seq | repeat autoa0 | _     | _     |

### Table 77 Description of the HISEQ register bits

| BIT | NAME          | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | autoa0        | automatic A0 packet transfer enable: this bit enables the sequencer to automatically handle transfer of A0 packet bytes                                                                                                                                                                                                                                                                                                                                                                            |
|     |               | autoa0 = 1; enables automatic transfer of A0 packet bytes                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |               | autoa0 = 0; disables automatic transfer of A0 packet bytes                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6   | autodrq       | enables the auto data request sequence: this bit enables automatic handling of data requests in PIO and DMA mode transfers                                                                                                                                                                                                                                                                                                                                                                         |
|     |               | autodrq = 1; auto sequencer is enabled to perform auto data requests                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |               | autodrq = 0; auto sequencer is not enabled to perform auto data request                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5   | comp          | Completion sequence for 'autodrq': this bit indicates that the auto completion sequence should be performed after the last data transfer. This bit is only valid when the auto sequencer is enabled.                                                                                                                                                                                                                                                                                               |
|     |               | comp = 1; enable the auto sequencer to automate the completion sequence                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |               | comp = 0; disable the auto completion sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4   | error         | completion sequence with error status: this bit is copied to the check bit of the ASTAT register just before an auto completion sequence is performed                                                                                                                                                                                                                                                                                                                                              |
|     |               | error = 1; completion sequence with error status in check bit of ASTAT                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |               | error = 0; completion without error status                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3   | sus_seq       | Suspend auto sequence: this bit suspends the auto sequencer for debug. If the suspend state is a write to register state then the write operation will only take place when after the 'sus_seq' bit is negated.                                                                                                                                                                                                                                                                                    |
|     |               | sus_seq = 1; suspend sequencer in present state                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |               | sus_seq = 0; normal sequence operation                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2   | repeat autoa0 | Repeat the A0 packet reception auto sequence after an 'autodrq' or auto completion sequence. This bit, if set before an 'autodrq' or auto completion sequence, will be copied to 'autoa0' bit when the sequencer is reset at the end of an 'autodrq' or auto completion sequence. This bit is negated at the end of the 'autoA0' sequence. Its effect is to repeat the 'autoA0' sequence one more time only. It should be noted that this bit is only available on RODAP and not the M1 data base. |
|     |               | repeat autoa0 = 1; repeat 'autoA0' sequencer after 'autodrq' or auto completion<br>repeat autoa0 = 0; no effect                                                                                                                                                                                                                                                                                                                                                                                    |

# SAA7381

## 7.5.3.24 SHSTAT

Table 78 SHSTAT: shadow status register; address FF97H

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0                  |
|--------|-------|-------|-------|-------|-------|-------|-------|------------------------|
| W      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | shcheck <sup>(1)</sup> |

## Note

1. Shadow check bit: 'shcheck' is the ATAPI CHECK bit in the slave shadow status register for the non-existent drive.

- a) 1 = Indicates an error has occurred.
- b) 0 = Indicates no error has occurred.

## 7.5.3.25 SHERR

Table 79 SHERR: shadow error register; address FF98H

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2                 | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|-------|-----------------------|-------|-------|
| W      | 0     | 0     | 0     | 0     | 0     | shabrt <sup>(1)</sup> | 0     | 0     |

## Note

- 1. Shadow abort bit: 'shabrt' is the ATAPI 'abrt' bit in the slave shadow error register for the non-existent drive. This bit will be read by the host in shadow mode only.
  - a) 1 = indicates requested command has been aborted.
  - b) 0 = indicates requested command successful.

## 7.5.3.26 HIDEV

 Table 80
 HIDEV: host interface device register; address FF99H (see Table 81)

| ACCESS | BIT 7     | BIT 6           | BIT 5    | BIT 4          | BIT 3    | BIT 2   | BIT 1 | BIT 0    |
|--------|-----------|-----------------|----------|----------------|----------|---------|-------|----------|
| RW     | pdiag out | pdiag<br>enable | dasp out | dasp<br>enable | pdiag in | dasp in | _     | hosthipi |

SAA7381

| BIT | NAME      | DESCRIPTION                                                                                                                                     |
|-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | pdiag out | this bit is the passed diagnostics signal output from the SAA7381                                                                               |
|     |           | pdiag out = 1; writing logic 1 to this bit drives the $\overline{PDIAG}$ pin HIGH if the pad enable                                             |
|     |           | ('pdiag enable' bit 6) is set to logic 1. It is recommended that this bit is written LOW and                                                    |
|     |           | that the enable bit is driven to emulate an open-collector output.                                                                              |
|     |           | pdiag out = 0; writing logic 0 to this bit sets the PDIAG pin LOW if the pad enable ('pdiag enable' bit 6) is set to logic 1                    |
| 6   | pdiag pad | this bit default is an input to the SAA7381                                                                                                     |
|     | enable    | pdiag pad enable = 1; writing logic 1 to this bit enables the $\overline{PDIAG}$ driver output of the SAA7381                                   |
|     |           | pdiag pad enable = 0; default on power-up allowing external control of the 'pdiag in' bit 3                                                     |
| 5   | dasp out  | This bit is the device active slave present signal output. This pin is open-collector with an                                                   |
|     |           | external pull-up resistor. The DASP bit must be set to logic 1 in order to determine if any                                                     |
|     |           | other device is driving this signal.                                                                                                            |
|     |           | dasp out = 1; writing logic 1 to this bit drives $\overline{DASP}$ HIGH if the pad enable ('dasp enable'                                        |
|     |           | bit 4) is set to logic 1. It is recommended that this bit is written LOW and that the enable bit is driven to emulate an open-collector output. |
|     |           | dasp out = 0; writing logic 0 to this bit sets the $\overline{\text{DASP}}$ pin LOW if the pad enable (dasp                                     |
|     |           | enable bit 4) is set to logic 1                                                                                                                 |
| 4   | dasp pad  | this bit default is an input to the SAA7381                                                                                                     |
|     | enable    | dasp pad enable = 1; writing logic 1 to this bit enables the $\overline{DASP}$ driver output of the SAA7381                                     |
|     |           | dasp pad enable = 0; default on power-up allowing external control of the dasp in bit 2                                                         |
| 3   | pdiag in  | this bit is the passed diagnostics signal input to the SAA7381, only valid if 'pdiag enable' bit 6 is set to logic 0 (default = 0)              |
| 2   | dasp in   | this bit is the device active slave present signal input to the SAA7381, only valid if<br>'dasp enable' bit 4 is set to logic 0 (default = 0)   |
| 0   | hosthipi  | This bit allows the host interface to increase its priority rating when requesting a data                                                       |
|     |           | transfer between itself and the SAA7381 memory processor. With host high priority set the                                                       |
|     |           | host data transfer requests are given the second highest priority, the highest given to the microcontroller.                                    |
|     |           | hosthipi = 1; writing logic 1 increase host interface priority above all other data transfer                                                    |
|     |           | requests, bar the microcontroller.                                                                                                              |
|     |           | hosthipi = 0; writing logic 0 to this bit (default setting) gives low priority to the host interface data transfer request.                     |

SAA7381

### 7.5.4 TRANSFER COUNTER

The transfer counter register defines the total transfer length to be transferred to or from the host. This register is loaded by the microcontroller and decrements synchronously with the DBCH/DBCL registers. The remainder packet size can be loaded from the transfer counter into DBCH or DBCL when the transfer counter value becomes less than the packet size store.

### Table 82 Transfer counter register

| ADDRESS | ACCESS | BIT 7 | BIT 6                      | BIT 5 | BIT 4         | BIT 3         | BIT 2 | BIT 1 | BIT 0 |  |
|---------|--------|-------|----------------------------|-------|---------------|---------------|-------|-------|-------|--|
| FFA0H   | RW     |       | byte count (bits 7 to 0)   |       |               |               |       |       |       |  |
| FFA1H   | RW     |       | byte count (bits 15 to 8)  |       |               |               |       |       |       |  |
| FFA2H   | RW     |       | byte count (bits 23 to 16) |       |               |               |       |       |       |  |
| FFA3H   | RW     |       |                            | k     | oyte count (l | oits 31 to 24 | .)    |       |       |  |

### 7.5.5 PACKET SIZE STORE

The packet size store will be loaded from the DBCH or DBCL registers when the host writes to ACMD, provided the drive is selected. It may also be updated by the microcontroller. The DBCH/DBCL registers will be auto loaded from the packet size store on condition that the transfer counter contains an equal or greater value than that held in the packet size store.

### Table 83 Packet size store

| ADDRESS | ACCESS | BIT 7 | BIT 6                    | BIT 5 | BIT 4        | BIT 3         | BIT 2 | BIT 1 | BIT 0 |  |
|---------|--------|-------|--------------------------|-------|--------------|---------------|-------|-------|-------|--|
| FFA4H   | RW     |       | byte count (bits 7 to 0) |       |              |               |       |       |       |  |
| FFA5H   | RW     |       |                          |       | byte count ( | bits 15 to 8) |       |       |       |  |

### 7.5.6 SEQUENCER STATUS

### 7.5.6.1 Sequencer status

For debugging the auto sequencer a sequencer status register has been provided (address FF6AH). A suspend sequence bit has been provided ('hiseq' bit 4; see Table 76), which if asserted (logic 1) will suspend the auto sequencer operation at its present state. The suspended state may then be read from the sequencer state register. If the sequencer state is a write to a host interface registers state, then the sequencer will perform the write operation after the suspend sequencer bit is negated by the microcontroller.

## Table 84 Sequencer status: address FFA6H (note 1)

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3         | BIT 2            | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|---------------|------------------|-------|-------|
| R      | -     | _     |       | 5     | sequencer sta | ite (bits 5 to 0 | )     |       |

### Note

1. For an explanation of the sequence state number see the user guide. The user guide is available from product support.

# SAA7381

## 7.5.6.2 Auxiliary block memory processor registers

The registers given in Table 85 are located in the Aux block of the and control the SAA7381 memory processor buffer management. Transfer to/from the host is possible as soon as the HOSTBYTECOUNT is non-zero, and the HOSTCURSEGCNT is non-zero.

The 'chan0' and 'chan1' bits control the sequencing of sub-block transfers. They indicate the number of offset/length pairs to use for each block being transferred. Normally only channels 0 and 1 are needed for Mode 2 host transfers. Channels 2 and 3 are available for special READ-CD command options. An interrupt is associated with HOSTBYTECOUNT becoming zero. This is an indication to the microcontroller to reload the HOSTCURSEG and HOSTBYTECOUNT registers for the next transfer.

The HOSTCURSEG, HOSTBYTEOFFSET and HOSTBYTECOUNT registers indicate the address of the next byte to be transferred to or from the host, in order that the status of the interface may be read. The operation of the HOSTBYTECOUNT and HOSTBYTEOFFSET registers is given in Table 85.

| ADDR  | ACCESS | NAME                | BIT 7    | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|-------|--------|---------------------|----------|-------|-------|-------|-------|-------|-------|-------|
| FF45H | RW     | HOSTCURSEG-L        | s7       | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF44H | RW     | HOSTCURSEG-H        | chan1    | chan0 | _     | s12   | s11   | s10   | s9    | s8    |
| FF66H | RW     | HOSTCURSEGCNT       | b7       | b6    | b5    | b4    | b3    | b2    | b1    | b0    |
| FF59H | RW     | HOSTSUBBLKOFFSET0-L | a7       | a6    | a5    | a4    | a3    | a2    | a1    | a0    |
| FF58H | RW     | HOSTSUBBLKOFFSET0-H | autoform | form  | _     | _     | a11   | a10   | a9    | a8    |
| FF5DH | RW     | HOSTSUBBLKOFFSET1-L | a7       | a6    | a5    | a4    | a3    | a2    | a1    | a0    |
| FF5CH | RW     | HOSTSUBBLKOFFSET1-H | autoform | form  | _     | _     | a11   | a10   | a9    | a8    |
| FF51H | RW     | HOSTSUBBLKOFFSET2-L | a7       | a6    | a5    | a4    | a3    | a2    | a1    | a0    |
| FF50H | RW     | HOSTSUBBLKOFFSET2-H | autoform | form  | _     | _     | a11   | a10   | a9    | a8    |
| FF55H | RW     | HOSTNEXTSEG-L       | a7       | a6    | a5    | a4    | a3    | a2    | a1    | a0    |
| FF54H | RW     | HOSTNEXTSEG-H       | autoform | form  | _     | a12   | a11   | a10   | a9    | a8    |
| FF5BH | RW     | HOSTSUBBLKCOUNT0-L  | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF5AH | RW     | HOSTSUBBLKCOUNT0-H  | -        | _     | _     | -     | c11   | c10   | c9    | c8    |
| FF5FH | RW     | HOSTSUBBLKCOUNT1-L  | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF5EH | RW     | HOSTSUBBLKCOUNT1-H  | -        | -     | -     | -     | c11   | c10   | c9    | c8    |
| FF53H | RW     | HOSTSUBBLKCOUNT2-L  | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF52H | RW     | HOSTSUBBLKCOUNT2-H  | -        | _     | _     | _     | c11   | c10   | c9    | c8    |
| FF57H | RW     | HOSTNEXTSEGCOUNT    | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF56H | RW     | HOSTRELOADFLAGS     | rel1     | rel2  | _     | _     | c11   | c10   | c9    | c8    |
| FF43H | RW     | HOSTBYTEOFFSET-L    | a7       | a6    | a5    | a4    | a3    | a2    | a1    | a0    |
| FF42H | RW     | HOSTBYTEOFFSET-H    | autoform | form  | -     | -     | a11   | a10   | a9    | a8    |
| FF65H | RW     | HOSTBYTECOUNT-L     | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |
| FF64H | RW     | HOSTBYTECOUNT-H     | _        | _     | _     | _     | c11   | c10   | c9    | c8    |
| FF69H | RW     | HOSTRELSEG-L        | s7       | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF68H | RW     | HOSTRELSEG-H        | chan1    | chan0 | _     | s12   | s11   | s10   | s9    | s8    |
| FF6BH | RW     | AUX_FORM_SCAN       | c7       | c6    | c5    | c4    | c3    | c2    | c1    | c0    |

### Table 85 Host interface DMA pointers

SAA7381

## Table 86 Decoding 'chan' bits

| VALUE | DESCRIPTION                                |
|-------|--------------------------------------------|
| 00    | use extent 0                               |
| 01    | use extent 0 to 1                          |
| 10    | use extent 0 to 2                          |
| 11    | use extent 0 to 3 (see also Section 7.5.8) |

7.5.7 HOST INTERFACE DMA SPECIAL BITS

Table 87 Decoding bits 7 and 6 of HOSTSUBBLKOFFSETX-H (note 1)

| BIT | NAME     | VALUE | DESCRIPTION                                                                          |
|-----|----------|-------|--------------------------------------------------------------------------------------|
| 7   | autoform | 0     | unconditional transfer                                                               |
|     |          | 1     | only transfer if previous Form bit matches bit 6                                     |
| 6   | form     | 0     | match last Form bit = 0, perform this transfer if success else reload host registers |
|     |          | 1     | match last Form bit = 1, perform this transfer if success else reload host registers |

### Note

1. The last Form bit is the LSB of the byte that is situated at offset 12 in the current segment pointed at by HOSTCURSEG. This is the stored Form byte in the header.

# 7.5.8 AUTOMATIC BLOCK POINTER RELOAD PROGRAMMING

If either bit 6 or bit 7 are set in the HOSTRELOADFLAGS register, then when the HOSTRELOADCOUNT register becomes zero, the value of HOSTCURSEGCNT will be copied from HOSTNEXTSEGCOUNT and HOSTRELSEGMENT will be copied from HOSTNEXTSEG.

This causes the host transfer process to continue looping over the same region of memory in emulation of the Chaucer and Sequioia devices.

At the same time one of the bits HOSTRELOADFLAGS (bits 7 and 6) is reset on reload of the registers. The other bit retains its value. Therefore:

- Single auto-reload is allowed: HOSTRELOADFLAGS (bits 7 and 6) = 1 0
- No auto-reload: HOSTRELOADFLAGS (bits 7 and 6) = 0 0; pointer can be used as sub-block extent 3
- Multiple auto-reload: HOSTRELOADFLAGS (bits 7 and 6) = 0 1.

7.5.9 DMA TRANSFER PROGRAMMING OF THE HOST INTERFACE

The host interface is optimized for the normal read commands, handling all data transfers or contiguous data plus header requests automatically, with auto Form detection in Mode 2.

If discontinuous data which requires more than 3 sub-block extents e.g. for READ-CD is required then it is necessary to program the HOSTCURSEG, HOSTBYTECOUNT and HOSTBYTEOFFSET for each discontinuous part of each block that is to be transferred. Writing the value 1 into the 'hostblock' will cause the transfer to take place.

# SAA7381

## 7.5.10 GENERIC INTERFACE OPERATION

Implementation of the generic interface with the NCR 53CF92 in a multiplexed bus configuration is shown in Fig.4. The host interface, after power-up, needs to be configured for the SCSI controller by writing the value 3 to the RESET register (address FF86H) for an 8-bit data transfer configuration and the value 4 for a 16-bit data transfer configuration. The NCR 53CF92 device is configured by tying it's mode pin to ground. In this mode the NCR 53CF92 device expects from the microcontroller a multiplexed address/data bus. Multiplexed address/data bus is the only mode supported by the SAA7381. The active LOW Chip Select (CS) signal from the SAA7381 is generated by the host interface. There are 32 specific SCSI addresses in the SAA7381 memory map, between location FFC0H and FFDFH. The CS pin will be active LOW for addresses in this range. The standard register set on the NCR 53CF92 contains 16 registers which are accessed when the CS is true. The specific register being accessed is determined by the states of the RD and WR signals together with the address pins A3 to A0.



SAA7381

7.5.11 DMA TRANSFERS IN GENERIC MODE

The host interface in generic mode will support two types of DMA transfer to the NCR device, namely:

- Normal DMA mode
- Burst DMA mode.

Both of these modes are 8 bit DMA transfers. During data transfers the microcontroller can suspend the DMA transfer (via HICONF1 register 'dmaen' bit 7) under the following conditions:

- An Interrupt received
- An abort received
- A register read required.

7.5.12 NORMAL DMA MODE

In this mode the host Interface transfers data in single bytes. This DMA mode is configured by setting 'dmamode' (DTCTR register bit 6) to zero, and DMA (DTCTR register bit 5) to one. Data flow direction and byte counts are configured the same as ATAPI DMA modes of data transfer, but with command information being received via the NCR SCSI controller registers external to the SAA7381 operation. The data transfer takes place as long as the DMA request signal DMARQ is true. The DMACK signal is toggled by the host Interface for each byte transferred as shown in Fig.5.



7.5.13 BURST DMA MODE USING MULTIPLEXED BUS CONFIGURATION

In this mode the DMA data is available on the DMA bus when both, DBRD or DBWR and DMACK are true. DMACK remains asserted throughout the transfer while DBRD toggles for each transfer as shown in Fig.6. To configure the host interface the DMA mode and DMA bits (DTCTR bits 6 and 5) should be set to logic 1.

# SAA7381



## 7.6 Microcontroller interface

This section provides a brief introduction to the software and hardware environment expected in a system using the SAA7381 device. Because all of the SAA7381 registers are randomly accessible, the processor controlling the SAA7381 is able to use interrupts.

## 7.6.1 KERNEL BASED FIRMWARE

It is recommended that the sub-CPU runs a multi-tasking kernel to properly support the multiple 'threads' of operation that are required of it in use. Therefore the memory mapper specified in this document has the concept of having 2 pages of memory for data. Then one page of data space can be switched in to the memory map for each thread as needed, while still keeping a fixed part of the memory map for the interrupt service routines and other fixed housekeeping code and data.

## 7.6.2 16-BIT REGISTERS AUTOMATIC READ AND WRITE

All of the 16-bit registers provided in the SAA7381, are used by writing the Most Significant Bit (MSB) first. These registers are located in the address range FF20H to FF6FH together with some 8-bit registers. To facilitate 'snapshot' reading or writing of the 16-bit register an 8-bit holding register is provided to store the 'spare' byte of data.

This is implemented in such a way that a 16-bit read consists of a sample of the value of the register at the instant that the high byte was read from that register. The low byte is kept in a holding register and presented to the sub-CPU when the low byte is requested. Even if the sub-CPU is interrupted (and the holding register is then stacked and replaced during the service routine) the 16-bit read will be the value of the register at a single instance in time.

Similarly for writing, the high byte is held in the holding register to be written later to the 16-bit register at the same time as the low byte is written to the SAA7381. Again the holding register must be saved during an Interrupt Service Routine (ISR) if the ISR itself is likely to cause any 16-bit reads or writes to take place. It should be noted that any ISR, which requires access to a 16-bit or 8-bit register in the address range FF20H to FF6FH, will overwrite the holding register and therefore its contents must be stacked before the interrupt is serviced. Furthermore, there is only one holding register that may be accessed both for reading and writing. In this way the interrupt routine can easily save data that was stored in the holding register before it was written.

A single location (TEMP\_DATA, register FF6FH) is used as the location to read the value of the holding register, regardless of which address was used in the original read or write process. The IRS stacking process of the holding register is illustrated in Fig.8.

# SAA7381





# SAA7381

## 7.7 8051 CPU and memory management functions

The 8051 CPU and memory management functions are as follows:

- Device registers are memory mapped for faster direct access to the chip
- Provides direct access from sub-CPU to buffer RAM to support scratchpad accesses; this eliminates the need for extra RAM chips in the system
- Address space reserved for generic host interface control and status pass-through (it is shared with ATAPI register space; see Section 7.5)
- Interfaces to 8051 multiplexed address and data bus
- Two dynamically controllable RAM access modes allow trade-off between accessible scratchpad RAM size and RAM access time.

### 7.7.1 SUB-CPU BUS ACCESS TIMING

The fast and slow RAM access timing diagrams are illustrated in Figs 10 and 9. It should be noted that fast RAM access is not recommended due to its negative effect on the RAM bandwidth and the overall system performance. In the fast RAM access mode all external accesses below C000 are expected to be program fetches. A DRAM access cycle is not begun. Above C000, the RAM cycle begins on the falling edge of ALE hence the number of 8051 wait states can be reduced. This is not however recommended.

The disadvantage is, that the RAM access cycle is started regardless of whether it will be needed. This has the effect of aborting any other on-going use of the buffer memory and reducing the available bandwidth.

Consequently, the number of wait states on accessing RAM must be greater. In return, more RAM is accessible.

In the slow RAM access mode the RAM access cycle starts on the falling edge of  $\overline{\text{RD}}$  or  $\overline{\text{WR}}$ , if  $\overline{\text{PSEN}}$  is HIGH, this being the first time in the 8051 external memory access cycle that it is possible to determine that an XDATA access is in fact being made.

This access mode has a lower impact on the buffer RAM memory bandwidth as only accesses that are needed are made. The two modes are under control of a register bit, and it is possible to switch between them at any time.



# SAA7381



# 7.7.2 BUFFER MEMORY ORGANISATION

Memory is mapped as a 12-bit block number and a 12-bit offset into that block. The block oriented memory structure permits the use of 16-bit pointers in software, minimising the overhead of accessing memory. The address can be found from the following equation:

 $address = block\_number \times 2560 + offset$ 

The sub-CPU sees the SAA7381 as a memory mapped peripheral, with control and status registers appearing in the highest 256 bytes of the external address space (PDATA space).

The phrase (PDATA space) is meant to imply that the code will access registers most efficiently if the PDATA (8051 port P2) pointer is set to point at the register space of the SAA7381. If the PDATA space is better used as context switching space then it can be used for that purpose.

All registers and RAM are accessible in the XDATA space at all times, the PDATA is just a movable 256 byte window with faster access into XDATA. The lowest 56 kbytes of the 8051 external address data space is mappable as two windows into the memory of 52 kbytes and 4 kbytes, on any user-specified 256 byte boundary within the RAM. This is usable as scratchpad RAM.

The two pages permits the paging of process context information for use with a multi-tasking kernel, while still keeping some global variables.

The next 7.5 kbytes is mapped as a window into memory starting at a user-specified block number. This is usable for accessing block data, subcode information, error corrector status and block headers.

The 64 kbytes memory mapping is shown in Fig.11.

# SAA7381



| ADDRESS        | SEGMENT SIZE<br>(BYTES) | USED FOR                                         | ADDRESS FUNCTION    |
|----------------|-------------------------|--------------------------------------------------|---------------------|
| FFCOH to FFFFH | 64                      | the SAA7381s dead space                          | none; note 1        |
| FF00H to FFBFH | 192                     | the SAA7381 register access, debug write to DRAM | none; notes 2 and 3 |
| E000H to FEFFH | 7936                    | segments in DRAM                                 | note 4              |
| D000H to DFFFH | 4096                    | subpage 2 in DRAM                                | note 5              |
| C000H to CFFFH | 4096                    | subpage 1 in DRAM                                | note 6              |
| 0000H to BFFFH | 49152                   | subpage 1 in DRAM                                | notes 1 and 6       |

Table 88 The SAA7381 memory map

# Notes

- 1. If the SAA7381 is addressed in this area it will not access the DRAM and the data output of the sub-CPU interface to the microcontroller is disabled. If the SAA7381 host interface has been configured for generic mode and the address access from FFC0H to FFDFH, a chip select signal is asserted 'zero' on the output pin XDA1.
- 2. CPU address (bits 23 to 8) = 0. CPU address (bits 7 to 0) = address (bits 7 to 0).
- 3. Read in this segment is always from internal the SAA7381 registers. Write is to internal the SAA7381 registers and, optionally, also to DRAM if debug is set (conf\_8051, bit 1 = 1).
- CPU address (bits 8 to 0) = address (bits 8 to 0). CPU address (bits 23 to 9) = subseg 1 (bits 12 to 0) + subseg 1 (12 to 0) × 4 + address (bits 12 to 9).
- CPU address (bits 9 to 0) = address (bits 9 to 0). CPU address (bits 23 to 10) = subseg 2 (bits 15 to 2) + address (bits 11 and 10).
- CPU address (bits 9 to 0) = address (bits 9 to 0). CPU address (bits 23 to 10) = subseg 1 (bits 15 to 2) + address (bits 15 to 10).

SAA7381

## 7.7.3 SUBPAGE

The lowest 52 kbytes (0X000H to 0XCFFFH) of the external data memory is mapped to SUBPAGE1. If the user requires less RAM than is provided here (up to 52 kbytes), the 1024 byte granularity of positioning the offsets permits the pages to be overlapped. In the fast RAM access mode, the lowest 48 kbytes are not accessible as they are assumed to be ROM space.

The next 4 kbytes (0XD000H to 0XDFFFH) of the external data memory is always mapped to SUBPAGE2, and is always available.

## Table 89 Subpage RAM offsets

| ADDRESS | NAME       | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|------------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF18H   | SUBPAGE1-H | a23   | a22   | a21   | a20   | a19   | a18   | a17   | a16   |
| FF19H   | SUBPAGE1-L | a15   | a14   | a13   | a12   | a11   | a10   | -     | -     |
| FF1AH   | SUBPAGE2-H | a23   | a22   | a21   | a20   | a19   | a18   | a17   | a16   |
| FF1BH   | SUBPAGE2-L | a15   | a14   | a13   | a12   | _     | a10   | _     | _     |

# 7.7.3.1 Sub-CPU segment page

The sub-CPU may access three adjacent segments of data offset from the base segment pointed to by 'subseg'. These are mapped as a contiguous 7.5 kbytes block at the top of memory from 0XE000 to 0XF800.

The buffer address is formed using the following equation: Buffer address = subseg (down to 0)  $\times$  2560 + sub-CPU (a12 down to 0)

This permits the writing of headers and looking at subcode information which may span more than one segment. Linked lists in the 'spare' space at the end of a segment may be more easily manipulated if the segment and its neighbours are visible to the sub-CPU in a consistent manner.

It is also possible to indirectly access any part of RAM by using the block copy registers to move the data to and from the sub-CPU subpages.

# 7.7.3.2 Sub-CPU segment page restriction

It should be noted that the SAA7381 device does not have the concept of a defined upper limit on the segment addressed block. Hence the segment page is always 3 contiguous segments of RAM, even when near or at the top of accessible RAM or at the top of the firmware defined data input buffer. In this case 1 or 2 of the blocks accessed will be beyond the buffer.

| ADDRESS | NAME     | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|----------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF1CH   | SUBSEG-H | s7    | s6    | s5    | s4    | s3    | s2    | s1    | s0    |
| FF1DH   | SUBSEG-L | -     | _     | -     | _     | s11   | s10   | s9    | s8    |

 Table 90
 Sub-CPU segment RAM offsets

# 7.8 External memory interface

The external memory interface is designed to operate with up to 128 Mbits hyper-page 33 MHz DRAM (EDO RAM) It is also designed to operate with fast-page DRAM giving a 17.5 Mbyte/s burst transfer rate. Figures 13 and 14 illustrate the timing diagram for fast-page mode.

It should be noted that during the power-on reset cycle it is necessary to pull the XDATA bus to all zeros to configure the SAA7381 for use with the 8051 microcontroller.

SAA7381

## 7.8.1 DRAM INTERFACE CONFIGURATION REGISTER

Table 91 DRAM\_CONFIG: address FF6AH (see Table 92)

| ACCESS | BIT 7 | BIT 6 | BIT 5 | BIT 4     | BIT 3     | BIT 2     | BIT 1     | BIT 0     |
|--------|-------|-------|-------|-----------|-----------|-----------|-----------|-----------|
| W      | -     | -     | -     | feature 4 | feature 3 | feature 2 | feature 1 | feature 0 |

## Table 92 Description of the DRAM interface features

| feature 4 | feature 3 | feature 2 | feature 1 | feature 0 | OPTION                                                                                                                               |
|-----------|-----------|-----------|-----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 0         | Х         | Х         | Х         | Х         | refresh every 256 system clock cycles                                                                                                |
| 1         | Х         | Х         | Х         | Х         | refresh every 511 system clock cycles                                                                                                |
| Х         | 1         | Х         | Х         | Х         | minimum RAS LOW is 2 clock cycles                                                                                                    |
| Х         | 0         | Х         | Х         | Х         | minimum RAS LOW is 3 clock cycles                                                                                                    |
| Х         | Х         | 1         | 0         | Х         | 1 Mbit × 4 DRAM used                                                                                                                 |
| Х         | Х         | 1         | 1         | Х         | 4 Mbit × 4 DRAM used                                                                                                                 |
| X         | Х         | 0         | Х         | Х         | 512 kbits $\times$ 8, 1 Mbit $\times$ 8, 2 Mbits $\times$ 8, 4 Mbits $\times$ 8, 8 Mbits $\times$ 8 or 16 Mbits $\times$ 8 DRAM used |
| Х         | Х         | Х         | Х         | 0         | use fast-page mode device                                                                                                            |
| Х         | Х         | Х         | Х         | 1         | use hyper-page mode device                                                                                                           |

## 7.9 UART for communication with CD engine

The following are required for communication with the CD engine:

- Clock prescaler for selectable baud rate
- Synchronous slave peripheral interface
- Asynchronous UART
- DMA to reduce sub-CPU loading in SPI mode
- Interrupt options available.

## 7.9.1 UART BASIC ENGINE INTERFACE

The basic engine interface implements both a synchronous peripheral interface and an asynchronous high-speed serial interface. The same registers are shared between the functions involved. Transmitted and received data in asynchronous mode is sent or received with parity bits in 8-bit, one parity bit, one STOP bit format. The registers that are implemented are described below.

Two 16-bit DMA pointers (SPI\_RX\_OFF and SPI\_TX\_OFF) are provided so that the interface may be used in a DMA mode. As a byte is transferred to or from the UART registers, it is possible to copy it into a part of the AUXSEG RAM (16-bit register AUXSEGMENT-H or AUXSEGMENT-L) in the SAA7381s buffer memory.

The pointers auto-increment and wrap within the region assigned, so if the user wishes the data to appear in the

same place in the buffer for each DMA transfer it will be necessary to reload these pointers before re-enabling DMA for the data transfer.

DMA operation can be independently on for the transmit and receive channels.

To enable the DMA receive channel the UART\_DMA\_CTRL bit 7 must be set to logic 1. When the receive DMA channel is active the sub-CPU cannot read the receive register (RXDATA address FF77H) any more but the SAA7381 will automatically copy the contents of the RXDATA register to the address pointed at by the SPI\_RX\_OFFSET pointer if it is full, increment the SPI\_RX\_OFFSET pointer and reset the 'rvbfull' bit.

The SPI offset registers are available in both synchronous and asynchronous modes and not just for SPI.

The SPI\_RX\_OFFSET register may be read to determine how many bytes have been received.

The polarity of the SPI clock is selectable from the UARTCOM register (see Table 94).

To enable the DMA transmit channel the UART\_DMA\_CTRL bit 6 must be set to logic 1 and, at the same time, bits 5 to 0 ('txdmacount') must be greater than zero. When the transmit channel is active the sub-CPU can write to the transmit register (TXDATA address FF77H), however, the SAA7381 will automatically perform the following operation.

SAA7381

If (transmit register empty) TRANSMITREG = RAM [AUXSEGMENT × 2560 + SPI\_TX\_OFFSET]

SPI\_TX\_OFFSET = SPI\_TX\_OFFSET + 1

uart\_dma\_ctrl (5:0) = uart\_dma\_ctrl (5:0) - 1 end if;

Transmission will automatically stop when the 'uart\_dma\_ctrl' (bits 5 to 0) (the 'txdmacount') has incremented to zero. This condition will produce the interrupt.

Data transmission rates are selectable by writing a value n(0 to 255) to the UART\_PRE\_SCALER register. The baud rate for each mode can then be calculated as follows:

For the SPI mode  $f_{SPI} = \frac{f_{sysclk}}{[2 \times (n+1)]}$ 

For the S2B mode 
$$f_{S2B} = \frac{f_{sysclk}}{[16 \times (n+1)]}$$

Table 93 UART general registers

| ADDRESS | NAME                           | BIT 7                        | BIT 6                                       | BIT 5       | BIT 4       | BIT 3       | BIT 2   | BIT 1   | BIT 0            |  |
|---------|--------------------------------|------------------------------|---------------------------------------------|-------------|-------------|-------------|---------|---------|------------------|--|
| FF28H   | AUXSEGMENT-H                   | bit 15                       | bit 14                                      | bit 13      | bit 12      | bit 11      | bit 10  | bit 9   | bit 8            |  |
| FF29H   | AUXSEGMENT-L                   | bit 7                        | bit 6                                       | bit 5       | bit 4       | bit 3       | bit 2   | bit 1   | bit 0            |  |
| FF4AH   | SPI_RX_OFF-H                   | bit 15                       | bit 14                                      | bit 13      | bit 12      | bit 11      | bit 10  | bit 9   | bit 8            |  |
| FF4BH   | SPI_RX_OFF-L                   | bit 7                        | bit 6                                       | bit 5       | bit 4       | bit 3       | bit 2   | bit 1   | bit 0            |  |
| FF4CH   | SPI_TX_OFF-H                   | bit 15                       | bit 14                                      | bit 13      | bit 12      | bit 11      | bit 10  | bit 9   | bit 8            |  |
| FF4DH   | SPI_TX_OFF-L                   | bit 7                        | bit 6                                       | bit 5       | bit 4       | bit 3       | bit 2   | bit 1   | bit 0            |  |
| FF74H   | UART_PRE_SCALER (rw)7          | prescale value (bits 7 to 0) |                                             |             |             |             |         |         |                  |  |
| FF75H   | UART_DMA_CTRL (rw)             | rcvdma on                    | rcvdma on txdma on txdmacount (bits 5 to 0) |             |             |             |         |         |                  |  |
| FF76H   | UARTCOM (w)                    | paron                        | spion                                       | _           | _           | _           | _       | _       | parpol<br>clkpol |  |
| FF77H   | RXDATA (w)                     | d7                           | d6                                          | d5          | d4          | d3          | d2      | d1      | d0               |  |
| FF7H    | RXDATA (r)                     | d7                           | d6                                          | d5          | d4          | d3          | d2      | d1      | d0               |  |
| FF78H   | UARTTINTSTAT/RESET (rw)        | comsync                      | syssync                                     | not comsync | not syssync | not txbfull | rvbfull | overrun | rvparity         |  |
| FF79H   | UARTTINTEN (w)                 | comsyn                       | syssync                                     | not comsync | not syssync | not txbfull | rvbfull | overrun | rvparity         |  |
| FF7EH   | UARTSTAT (r) <sup>(1)</sup>    | comsync                      | syssync                                     | comsync     | syssync     | txbfull     | rxbfull | overrun | rxparity         |  |
| FF7FH   | UARTAUXSTAT (r) <sup>(2)</sup> | comiack                      | txfull                                      | rxfull      | _           | -           | _       | _       | -                |  |

#### Notes

1. See Table 95.

2. See Table 96.

1997 Aug 12

SAA7381

## Table 94 Description of the UARTCOM register bits

| BIT | NAME          | VALUE | DESCRIPTION                           |
|-----|---------------|-------|---------------------------------------|
| 7   | paron         | 0     | disable parity bit in S2B mode        |
|     |               | 1     | enable parity bit in S2B mode         |
| 6   | spion         | 0     | S2B transmission mode                 |
|     |               | 1     | SPI transmission mode                 |
| 0   | parpol clkpol | 0     | SPI clock active LOW; S2B even parity |
|     |               | 1     | SPI clock active HIGH; S2B odd parity |

# Table 95 Description of the UARTSTAT register bits

| BIT | NAME     | VALUE | DESCRIPTION                                                        |
|-----|----------|-------|--------------------------------------------------------------------|
| 7   | comsync  | 0     | comsync pin level                                                  |
|     |          | 1     |                                                                    |
| 6   | syssync  | 0     | syssync pin level                                                  |
|     |          | 1     |                                                                    |
| 5   | comsync  | 0     | inverted comsync pin level                                         |
|     |          | 1     |                                                                    |
| 4   | syssync  | 0     | inverted syssync pin level                                         |
|     |          | 1     |                                                                    |
| 3   | txbfull  | 0     | -                                                                  |
|     |          | 1     | transmit data buffer is empty and ready for another byte           |
| 2   | rxbfull  | 0     | receive data buffer is not valid                                   |
|     |          | 1     | receive data buffer is valid                                       |
| 1   | overrun  | 0     | -                                                                  |
|     |          | 1     | a byte was lost because the 'rxdata' register was not read in time |
| 0   | rxparity | 0     | -                                                                  |
|     |          | 1     | received parity bit is in error                                    |

# Table 96 Description of the UARTAUXSTAT register bits

| BIT | NAME    | VALUE | DESCRIPTION                                                             |
|-----|---------|-------|-------------------------------------------------------------------------|
| 7   | comiack | 0     | comiack pin level                                                       |
|     |         | 1     |                                                                         |
| 6   | txfull  | 0     | _                                                                       |
|     |         | 1     | transmit register is full (a byte is being sent)                        |
| 5   | rxfull  | 0     | _                                                                       |
|     |         | 1     | receive register holds a byte, need to read a byte immediately to avoid |
|     |         |       | overrun                                                                 |

Table 97 CD playback error rate measurement registers

| ADDRESS | NAME      | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| FF11H   | C1BLERCNT | d7    | d6    | d5    | d4    | d3    | d2    | d1    | d0    |
| FF12H   | C2BLERCNT | d7    | d6    | d5    | d4    | d3    | d2    | d1    | d0    |

SAA7381

## 7.10 Clock generation control

### 7.10.1 CRYSTAL OSCILLATOR

The crystal oscillator is a conventional 2-pin inverting design operating from 8 to 35 MHz; this oscillator is also capable of operating with a 33.8 MHz ceramic resonator. It is capable of oscillating with both fundamental and 3rd-overtone mode crystals. External components should be used to suppress the fundamental output of the 3rd-overtone types as shown in Fig.12. When operating with lower frequency crystals,  $R_s$  must be greater than 0  $\Omega$  to avoid overdriving the crystal.



SAA7381

## 7.10.2 SUB-CPU CLOCK CONTROL REGISTER

This register controls the clocking of the sub-CPU and the generation of wait states, ensuring a low jitter in the clock while allowing wait states.

| Table 98         CONF_8051: address         FF73H (see Table 99) | Table 98 | CONF | 8051: address | FF73H | (see Table 99) |  |
|------------------------------------------------------------------|----------|------|---------------|-------|----------------|--|
|------------------------------------------------------------------|----------|------|---------------|-------|----------------|--|

| BIT 7  | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|
| modsel | wait2 | wait1 | wait0 | div2  | div1  | div0  | debug |

## Table 99 Description of the CONF\_8051 register bits

| BIT    | NAME           | VALUE | DESCRIPTION                                          |
|--------|----------------|-------|------------------------------------------------------|
| 7      | modsel         | 0     | wait state control                                   |
|        |                | 1     |                                                      |
| 6 to 4 | wait2 to wait0 | 000   | 0 wait states                                        |
|        |                | 001   | 1 wait state                                         |
|        |                | 010   | 2 wait states                                        |
|        |                | 011   | 3 wait states                                        |
|        |                | 100   | 4 wait states                                        |
|        |                | 101   | 5 wait states                                        |
|        |                | 110   | 6 wait states                                        |
|        |                | 111   | 7 wait states                                        |
| 3 to 1 | div2 to div0   | 000   | 8051 clock is sysclk; note 1                         |
|        |                | 001   | 8051 clock is sysclk/1.5; note 1                     |
|        |                | 010   | 8051 clock is sysclk/2                               |
|        |                | 011   | 8051 clock is sysclk/3                               |
|        |                | 100   | 8051 clock is sysclk/4                               |
|        |                | 1XX   | undefined                                            |
| 0      | debug          | 0     | -                                                    |
|        |                | 1     | register writes are shadowed through into buffer RAM |

### Note

1. The clock pulse provided to the 8051 is equal to the HIGH period of sysclk for divide-by-1 and divide-by-1.5. For all other division ratios the clock pulse HIGH time is equal to one cycle of sysclk.

## 7.10.3 SAA7381 SYSTEM CLOCK CONTROL REGISTERS

## Table 100 CLK\_CON register

| ADDRESS | NAME                   | BIT 7  | BIT 6  | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
|---------|------------------------|--------|--------|-------|-------|-------|-------|-------|-------|
| FF9EH   | MULTI_CON              | mode   | m6     | m5    | m4    | m3    | m2    | m1    | m0    |
| FF9FH   | CLK_CON <sup>(1)</sup> | pllpwr | pllena | _     | _     | -     | -     | xtal1 | xtal0 |

### Note

1. Write operations to bit 6 of CLK\_CON register may become unreliable once this bit has been written to with a logic 1.

SAA7381

| BIT     | NAME      | VALUE | DESCRIPTION                                  | f <sub>PLL</sub> (kHz) | NOTES   |
|---------|-----------|-------|----------------------------------------------|------------------------|---------|
| 7       | pllpwr    | 0     | PLL is powered-down                          | -                      | default |
|         |           | 1     | PLL is powered-up                            | -                      | -       |
| 6       | pllena    | 0     | system clock source is CRIN                  | -                      | default |
|         |           | 1     | system clock source is from clock multiplier | -                      | -       |
| 1 and 0 | xtal1 and | 00    | crystal is 8.4672 MHz; divide-by-16 529.2    |                        | -       |
|         | xtal0     | 01    | crystal is 11.289 MH; divide-by-22           | 513.1                  | _       |
|         |           | 10    | crystal is 16.9344 MHz; divide-by-32         | 529.2                  | default |
|         |           | 11    | crystal is 33.8688 MHz; divide-by-64         | 529.2                  | -       |

## Table 101 Description of the CLK\_CON register bits

Table 102 The relationship between the values of the<br/>m bits and VCO frequency for a normalised<br/>PLL frequency of 500 kHz; note 1

| m6 to m0<br>(HEX) | FREQUENCY (MHz) | m6 to m0<br>(HEX) | FREQUENCY (MHz) |
|-------------------|-----------------|-------------------|-----------------|
| 02                | 3               | 58                | 29              |
| 04                | 4               | 30                | 30              |
| 08                | 5               | 60                | 31              |
| 11                | 6               | 41                | 32              |
| 22                | 7               | 03                | 33              |
| 44                | 8               | 06                | 34              |
| 09                | 9               | 0C                | 35              |
| 13                | 10              | 19                | 36              |
| 26                | 11              | 33                | 37              |
| 4C                | 12              | 66                | 38              |
| 18                | 13              | 4D                | 39              |
| 31                | 14              | 1A                | 40              |
| 62                | 15              | 35                | 41              |
| 45                | 16              | 6A                | 42              |
| 0B                | 17              | 54                | 43              |
| 17                | 18              | 29                | 44              |
| 2E                | 19              | 53                | 45              |
| 5D                | 20              | 27                | 46              |
| ЗA                | 21              | 4E                | 47              |
| 75                | 22              | 1C                | 48              |
| 6B                | 23              | 39                | 49              |
| 56                | 24              | 73                | 50              |
| 2D                | 25              | 67                | 51              |
| 5B                | 26              | 4F                | 52              |
| 36                | 27              | 1E                | 53              |
| 6C                | 28              | 3D                | 54              |

SAA7381

| m6 to m0<br>(HEX) | FREQUENCY (MHz) |
|-------------------|-----------------|
| 7B                | 55              |
| 76                | 56              |
| 6D                | 57              |
| 5A                | 58              |
| 34                | 59              |
| 68                | 60              |
| 50                | 61              |
| 21                | 62              |
| 42                | 63              |
| 05                | 64              |
| 0A                | 65              |
| 15                | 66              |
| 2A                | 67              |
| 55                | 68              |
| 2B                | 69              |
| 57                | 70              |
| 2F                | 71              |
| 5F                | 72              |
| 3E                | 73              |
| 7D                | 74              |
| 7A                | 75              |
| 74                | 76              |
| 69                | 77              |
| 52                | 78              |
| 25                | 79              |
| 4A                | 80              |
| 14                | 81              |
| 28                | 82              |
| 51                | 83              |
| 23                | 84              |
| 46                | 85              |
| 0D                | 86              |
| 1B                | 87              |
| 37                | 88              |
| 6E                | 89              |
| 5C                | 90              |
| 38                | 91              |
| 71                | 92              |
| 63                | 93              |
| 47                | 94              |

| m6 to m0<br>(HEX) | FREQUENCY (MHz) |
|-------------------|-----------------|
| 0F                | 95              |
| 1F                | 96              |
| 3F                | 97              |
| 7F                | 98              |
| 7E                | 99              |
| 7C                | 100             |
| 78                | 101             |
| 70                | 102             |
| 61                | 103             |
| 43                | 104             |
| 07                | 105             |
| 0E                | 106             |
| 1D                | 107             |
| 3B                | 108             |
| 77                | 109             |
| 6F                | 110             |
| 5E                | 111             |
| 3C                | 112             |
| 79                | 113             |
| 72                | 114             |
| 65                | 115             |
| 4B                | 116             |
| 16                | 117             |
| 2C                | 118             |
| 59                | 119             |
| 32                | 120             |
| 64                | 121             |
| 49                | 122             |
| 12                | 123             |
| 24                | 124             |
| 48                | 125             |
| 10                | 126             |
| 20                | 127             |
| 40                | 128             |

# Note

 It should be noted that the mode bit (MSB high byte) has not been included in the table. The oscillator output frequency can be determined by dividing the VCO frequency given in Table 102 according to the mode bit described in Table 103.

SAA7381

Table 103 Explanation of mode bit

| MODE BIT | DIVISION RATIO                                                        |
|----------|-----------------------------------------------------------------------|
| 0        | divide the frequency from Table 102 by 4 to obtain 'sysclk' frequency |
| 1        | divide the frequency from Table 102 by 2 to obtain 'sysclk' frequency |

## 8 LIMITING VALUES

In accordance with the Absolute Maximum Rating System (IEC 134)

| SYMBOL                 | PARAMETER                        | MIN. | MAX.                 | UNIT |
|------------------------|----------------------------------|------|----------------------|------|
| V <sub>DDD(core)</sub> | core digital supply voltage      | -0.5 | +4.5                 | V    |
| V <sub>DDD(pad)</sub>  | periphery digital supply voltage | -0.5 | +6.5                 | V    |
| V <sub>DDA</sub>       | analog supply voltage            | -0.5 | +4.6                 | V    |
| V <sub>i(max)</sub>    | maximum voltage on any input     | -0.5 | $V_{DDD(pad)} + 0.5$ | V    |
| Vo                     | output voltage on any output     | -0.5 | +6.5                 | V    |
| I <sub>o</sub>         | output current (continuous)      | -    | 20                   | mA   |
| Р                      | power dissipation                | -    | 400                  | mW   |
| T <sub>stg</sub>       | storage temperature              | -55  | +125                 | °C   |
| T <sub>amb</sub>       | operating ambient temperature    | 0    | 70                   | °C   |

# 9 THERMAL CHARACTERISTICS

| SYMBOL             | PARAMETER                                   | CONDITIONS  | VALUE | UNIT |
|--------------------|---------------------------------------------|-------------|-------|------|
| R <sub>thj-a</sub> | thermal resistance from junction to ambient | in free air | 55    | K/W  |

## **10 CHARACTERISTICS**

| SYMBOL          | PARAMETER                        | CONDITIONS                  | MIN.                     | TYP. | MAX.                     | UNIT |  |  |
|-----------------|----------------------------------|-----------------------------|--------------------------|------|--------------------------|------|--|--|
| Digital Inputs  |                                  |                             |                          |      |                          |      |  |  |
| INPUTS DESIGN   | ATED BY 'C' (CMOS VOLTAGE LEVE   | LS)                         |                          |      |                          |      |  |  |
| V <sub>IL</sub> | LOW-level input voltage          |                             | -0.3                     | -    | 0.3V <sub>DDD(pad)</sub> | V    |  |  |
| V <sub>IH</sub> | HIGH-level input voltage         |                             | 0.7V <sub>DDD(pad)</sub> | -    | $V_{DDD(pad)} + 0.3$     | V    |  |  |
| I <sub>LI</sub> | input leakage current            | $V_i = 0$ to $V_{DDD(pad)}$ | -10                      | -    | +10                      | μA   |  |  |
| Ci              | input capacitance                |                             | -                        | -    | 10                       | pF   |  |  |
| INPUTS DESIGN   | ated by 'T' (TTL voltage levels) |                             |                          |      |                          |      |  |  |
| V <sub>IL</sub> | LOW-level input voltage          |                             | -0.3                     | -    | +0.8                     | V    |  |  |
| V <sub>IH</sub> | HIGH-level input voltage         |                             | 2.0                      | -    | $V_{DDD(pad)} + 0.3$     | V    |  |  |
| ILI             | input leakage current            | $V_i = 0$ to $V_{DDD(pad)}$ | -10                      | -    | +10                      | μA   |  |  |
| C <sub>i</sub>  | input capacitance                |                             | -                        | -    | 10                       | pF   |  |  |

# SAA7381

| SYMBOL               | PARAMETER                                                  | CONDITIONS                            | MIN.                        | TYP. | MAX.                     | UNIT |
|----------------------|------------------------------------------------------------|---------------------------------------|-----------------------------|------|--------------------------|------|
| POR AND RE           | SET (SCHMITT TRIGGER)                                      |                                       |                             |      | 1                        |      |
| V <sub>th(pos)</sub> | Schmitt trigger positive-going switching threshold voltage |                                       | -                           | -    | 0.8V <sub>DDD(pad)</sub> | V    |
| V <sub>th(neg)</sub> | Schmitt trigger negative-going switching threshold voltage |                                       | 0.2V <sub>DDD(pad)</sub>    | -    | -                        | V    |
| V <sub>hys</sub>     | hysteresis voltage                                         |                                       | 1.0                         | -    | -                        | V    |
| Ci                   | input capacitance                                          |                                       | _                           | -    | 3                        | pF   |
| Digital Outp         | uts                                                        |                                       |                             |      |                          | -    |
| OUTPUTS DES          | SIGNATED BY 'L' (CMOS LEVELS)                              |                                       |                             |      |                          |      |
| V <sub>OL</sub>      | LOW-level output voltage                                   | $I_{OL} = 2 \text{ mA}$               | 0                           | -    | 0.4                      | V    |
| V <sub>OH</sub>      | HIGH-level output voltage                                  | $I_{OH} = -2 \text{ mA}$              | $V_{DDD(pad)} - 0.4$        | _    | V <sub>DDD</sub>         | V    |
| CL                   | load capacitance                                           |                                       | -                           | _    | 20                       | pF   |
| t <sub>o(r)</sub>    | output rise time                                           | C <sub>L</sub> = 20 pF;<br>10% to 90% | -                           | -    | 10                       | ns   |
| t <sub>o(f)</sub>    | output fall time                                           | C <sub>L</sub> = 20 pF;<br>90% to 10% | -                           | -    | 10                       | ns   |
| OUTPUTS DES          | GIGNATED BY 'M' (CMOS LEVELS)                              |                                       |                             |      |                          |      |
| V <sub>OL</sub>      | LOW-level output voltage                                   | $I_{OL} = 4 \text{ mA}$               | 0                           | -    | 0.4                      | V    |
| V <sub>OH</sub>      | HIGH-level output voltage                                  | I <sub>OH</sub> = -4 mA               | V <sub>DDD(pad)</sub> - 0.4 | _    | V <sub>DDD</sub>         | V    |
| CL                   | load capacitance                                           |                                       | _                           | -    | 20                       | pF   |
| t <sub>o(r)</sub>    | output rise time                                           | C <sub>L</sub> = 20 pF;<br>10% to 90% | -                           | -    | 8                        | ns   |
| t <sub>o(f)</sub>    | output fall time                                           | C <sub>L</sub> = 20 pF;<br>90% to 10% | -                           | -    | 8                        | ns   |
| OUTPUTS DES          | GIGNATED BY 'H' (CMOS LEVELS)                              |                                       |                             |      |                          | -    |
| V <sub>OL</sub>      | LOW-level output voltage                                   | $I_{OL} = 8 \text{ mA}$               | 0                           | _    | 0.4                      | V    |
| V <sub>OH</sub>      | HIGH-level output voltage                                  | I <sub>OH</sub> = -8 mA               | V <sub>DDD(pad)</sub> - 0.4 | _    | V <sub>DDD</sub>         | V    |
| CL                   | load capacitance                                           |                                       | -                           | _    | 20                       | pF   |
| t <sub>o(r)</sub>    | output rise time                                           | C <sub>L</sub> = 20 pF;<br>10% to 90% | -                           | -    | 6                        | ns   |
| t <sub>o(f)</sub>    | output fall time                                           | C <sub>L</sub> = 20 pF;<br>90% to 10% | -                           | -    | 6                        | ns   |
| OUTPUTS: DE          | SIGNATED BY 'AL' (ATA DATA BUS LE                          | VELS)                                 | •                           |      | •                        | -    |
| V <sub>OL</sub>      | LOW-level output voltage                                   | $I_{OL} = 4 \text{ mA}$               | 0                           | -    | 0.4                      | V    |
| V <sub>OH</sub>      | HIGH-level output voltage                                  | $I_{OH} = -4 \text{ mA}$              | 2.4                         | -    | V <sub>DDD</sub>         | V    |
| CL                   | load capacitance                                           |                                       | -                           | -    | 100                      | pF   |
| t <sub>o(r)</sub>    | output rise time                                           | C <sub>L</sub> = 40 pF;<br>10% to 90% | 5                           | -    | -                        | ns   |
| t <sub>o(f)</sub>    | output fall time                                           | C <sub>L</sub> = 40 pF;<br>90% to 10% | 5                           | -    | -                        | ns   |

# SAA7381

| SYMBOL            | PARAMETER                     | CONDITIONS                            | MIN.                      | TYP.   | MAX.                      | UNIT |
|-------------------|-------------------------------|---------------------------------------|---------------------------|--------|---------------------------|------|
| OUTPUTS: DE       | SIGNATED BY 'AH' (ATA LEVELS) |                                       | -                         | -      |                           | _!   |
| V <sub>OL</sub>   | LOW-level output voltage      | I <sub>OL</sub> = 12 mA               | 0                         | -      | 0.4                       | V    |
| V <sub>OH</sub>   | HIGH-level output voltage     | I <sub>OH</sub> = -4 mA               | 2.4                       | _      | V <sub>DDD</sub>          | V    |
| CL                | load capacitance              |                                       | -                         | -      | 100                       | pF   |
| t <sub>o(r)</sub> | output rise time              | C <sub>L</sub> = 40 pF;<br>10% to 90% | 5                         | -      | -                         | ns   |
| t <sub>o(f)</sub> | output fall time              | C <sub>L</sub> = 40 pF;<br>90% to 10% | 5                         | _      | -                         | ns   |
| Crystal osci      | lator input: CRIN             |                                       |                           |        |                           |      |
| f <sub>CLK</sub>  | external clock frequency      |                                       | 8                         | 8.4677 | 35                        | MHz  |
| V <sub>IL</sub>   | LOW-level input voltage       |                                       | -0.3                      | _      | 0.3V <sub>DDD(core)</sub> | V    |
| VIH               | HIGH-level input voltage      |                                       | 0.7V <sub>DDD(core)</sub> | -      | $V_{DDD(C)} + 0.3$        | V    |
| ILI               | input leakage current         |                                       | -10                       | -      | +10                       | μA   |
| Ci                | input capacitance             |                                       | -                         | -      | 10                        | pF   |
| Crystal osci      | llator output: CROUT          |                                       |                           |        |                           | •    |
| f <sub>xtal</sub> | crystal frequency             |                                       | -                         | -      | 35                        | MHz  |
| gm                | transconductance              |                                       | 16                        | -      | _                         | mS   |
| R <sub>o</sub>    | output resistance             |                                       | -                         | -      | -                         |      |
| G <sub>v</sub>    | small signal voltage gain     | $G_V = gm \times R_o$                 | 5                         | -      | -                         | V/V  |
| C <sub>fb</sub>   | feedback capacitance          |                                       | _                         | -      | 5                         | pF   |
| Co                | output capacitance            |                                       | -                         | _      | 10                        | pF   |

SAA7381

## **11 TIMING CHARACTERISTICS**

# 11.1 External memory interface timing

 Table 104 DRAM interface timing (fast-page mode); see Figs 13 and 14 and note 1

| SYMBOL                   | PARAMETER                             | MIN. | MAX.  | UNIT |
|--------------------------|---------------------------------------|------|-------|------|
| T <sub>cy</sub>          | read or write cycle period            | 160  | _     | ns   |
| t <sub>ACC(CAS)</sub>    | access time from CAS                  | _    | 20    | ns   |
| t <sub>ACC(RAS)</sub>    | access time from RAS                  | _    | -     | ns   |
| t <sub>RASH</sub>        | RAS HIGH time                         | 70   | -     | ns   |
| t <sub>RASL</sub>        | RAS LOW time                          | 80   | 10000 | ns   |
| t <sub>h(RAS)</sub>      | RAS hold time                         | 20   | -     | ns   |
| t <sub>CASL</sub>        | CAS LOW time                          | 20   | 10000 | ns   |
| t <sub>h(CAS)</sub>      | CAS hold time                         | 80   | -     | ns   |
| t <sub>d(CASH-RAS)</sub> | delay time CAS HIGH to RAS            | 10   | -     | ns   |
| t <sub>d(RAS-CAS)</sub>  | RAS to CAS delay time                 | 25   | -     | ns   |
| t <sub>d(RAS-CA)</sub>   | RAS to column address delay time      | 20   | _     | ns   |
| t <sub>su(RA)</sub>      | row address set-up time               | 0    | -     | ns   |
| t <sub>h(RA)</sub>       | row address hold time                 | 15   | -     | ns   |
| t <sub>su(CA)</sub>      | column address set-up time            | 0    | _     | ns   |
| t <sub>h(CA)</sub>       | column address hold time              | 20   | _     | ns   |
| t <sub>h(CA-RASL)</sub>  | column address hold time from RAS LOW | 60   | -     | ns   |
| t <sub>I(CA-RAS)</sub>   | column address to RAS lead time       | 40   | _     | ns   |
| t <sub>h(R)</sub>        | read command hold time                | 0    | -     | ns   |
| t <sub>h(R-RAS)</sub>    | read command hold time from RAS       | 60   | -     | ns   |
| t <sub>su(W)</sub>       | write command set-up time             | 0    | -     | ns   |
| t <sub>h(W)</sub>        | write command hold time               | 15   | -     | ns   |
| t <sub>WL</sub>          | write command LOW time                | 15   | -     | ns   |
| t <sub>h(W-RAS)</sub>    | write command hold time from RAS      | 60   | -     | ns   |
| t <sub>I(W-CAS)</sub>    | write command to CAS lead time        | 20   | -     | ns   |
| t <sub>I(W-RAS)</sub>    | write command to RAS lead time        | 20   | -     | ns   |
| t <sub>su(DO)</sub>      | data output set-up time               | 0    | _     | ns   |
| t <sub>h(DO)</sub>       | data output hold time                 | 15   | _     | ns   |
| t <sub>h(DO-RAS)</sub>   | data output hold time from RAS        | 60   | -     | ns   |

## Note

1. For further information regarding the DRAM timing please consult the device user manual or contact product support.

SAA7381

# ATAPI CD-R block decoder



SAA7381

# ATAPI CD-R block decoder



SAA7381

#### 11.2 Host interface timing

This section deals with the implemented timings of the SAA7381 host interface in both the ATAPI and generic interface modes. The timings of the ATAPI PIO Mode 3 and Mode 4 are also taken into account.

Table 105 Basic AC characteristics, ATA bus

| SYMBOL         | PARAMETER                                   | CONDITIONS                                                                | MIN. | MAX. | UNIT |
|----------------|---------------------------------------------|---------------------------------------------------------------------------|------|------|------|
| t <sub>r</sub> | rise time for any signal on ATAPI interface | 10 to 90% of full signal amplitude with a total capacitive load of 100 pf | 5    | -    | ns   |
| t <sub>f</sub> | fall time for any signal on ATAPI interface | 10 to 90% of full signal amplitude with a total capacitive load of 100 pf | 5    | -    | ns   |
| Ci             | input capacitance for each host or device   |                                                                           | _    | 25   | pf   |
| Co             | output capacitance for each host or device  |                                                                           | _    | 25   | pf   |

11.2.1 HOST INTERFACE ATAPI PIO AND DMA TIMING

This section deals with the implemented timings of the SAA7381 host interface in both the ATAPI and generic interface modes. The timings of the ATAPI PIO Mode 3 and Mode 4 are also taken into account (see Table 105).

SAA7381

#### 11.2.2 ATA BUS TIMING

The figures and timing characteristics detail the timing as specified in the ATA-3 documentation.

| Table 106 Timing of PIO data trans | fer to and from device: see Fig 15    |
|------------------------------------|---------------------------------------|
|                                    | 101 10 and 110111 00 100, 300 1 19.10 |

| SYMBOL                                | PARAMETER                         | CONDITIONS     | MIN. | MAX. | UNIT |
|---------------------------------------|-----------------------------------|----------------|------|------|------|
| T <sub>cy</sub>                       | cycle time                        | note 1         |      |      |      |
| -                                     |                                   | Mode 0         | 600  | _    | ns   |
|                                       |                                   | Mode 1         | 383  | _    | ns   |
|                                       |                                   | Mode 2         | 240  | _    | ns   |
|                                       |                                   | Mode 3         | 180  | _    | ns   |
|                                       |                                   | Mode 4         | 120  | _    | ns   |
| t <sub>su(A-DIOR/DIOW)</sub>          | address valid to DIOR/DIOW set-up | Mode 0         | 70   | _    | ns   |
| , , , , , , , , , , , , , , , , , , , | time                              | Mode 1         | 50   | _    | ns   |
|                                       |                                   | Mode 2         | 30   | _    | ns   |
|                                       |                                   | Mode 3         | 30   | _    | ns   |
|                                       |                                   | Mode 4         | 25   | _    | ns   |
| t <sub>W(DIOR/DIOW)</sub>             | DIOR/DIOW pulse width             | 16-bit; note 1 |      |      |      |
| . ,                                   |                                   | Mode 0         | 165  | _    | ns   |
|                                       |                                   | Mode 1         | 125  | _    | ns   |
|                                       |                                   | Mode 2         | 100  | _    | ns   |
|                                       |                                   | Mode 3         | 80   | _    | ns   |
|                                       |                                   | Mode 4         | 70   | _    | ns   |
|                                       |                                   | 8-bit; note 1  |      |      |      |
|                                       |                                   | Mode 0         | 290  | _    | ns   |
|                                       |                                   | Mode 1         | 290  | _    | ns   |
|                                       |                                   | Mode 2         | 290  | _    | ns   |
|                                       |                                   | Mode 3         | 80   | _    | ns   |
|                                       |                                   | Mode 4         | 70   | _    | ns   |
| t <sub>rec(DIOR/DIOW)</sub>           | DIOR/DIOW recovery time           | note 1         |      |      |      |
|                                       |                                   | Mode 0         | _    | _    | ns   |
|                                       |                                   | Mode 1         | _    | _    | ns   |
|                                       |                                   | Mode 2         | _    | _    | ns   |
|                                       |                                   | Mode 3         | 70   | _    | ns   |
|                                       |                                   | Mode 4         | 25   | _    | ns   |
| t <sub>su(DIOW)</sub>                 | DIOW data set-up time             | Mode 0         | 60   | _    | ns   |
|                                       |                                   | Mode 1         | 45   | _    | ns   |
|                                       |                                   | Mode 2         | 30   | _    | ns   |
|                                       |                                   | Mode 3         | 30   | -    | ns   |
|                                       |                                   | Mode 4         | 20   | _    | ns   |

| SYMBOL                      | PARAMETER                         | CONDITIONS | MIN. | MAX. | UNIT |
|-----------------------------|-----------------------------------|------------|------|------|------|
| t <sub>h(DIOW)</sub>        | DIOW data hold time               | Mode 0     | 30   | -    | ns   |
|                             |                                   | Mode 1     | 20   | _    | ns   |
|                             |                                   | Mode 2     | 15   | -    | ns   |
|                             |                                   | Mode 3     | 10   | -    | ns   |
|                             |                                   | Mode 4     | 10   | _    | ns   |
| t <sub>su(DIOR)</sub>       | DIOR data set-up time             | Mode 0     | 50   | -    | ns   |
| . ,                         |                                   | Mode 1     | 35   | -    | ns   |
|                             |                                   | Mode 2     | 20   | -    | ns   |
|                             |                                   | Mode 3     | 20   | -    | ns   |
|                             |                                   | Mode 4     | 20   | -    | ns   |
| t <sub>h(DIOR)</sub>        | DIOR data hold time               | Mode 0     | 5    | -    | ns   |
| · · · ·                     |                                   | Mode 1     | 5    | -    | ns   |
|                             |                                   | Mode 2     | 5    | -    | ns   |
|                             |                                   | Mode 3     | 5    | _    | ns   |
|                             |                                   | Mode 4     | 5    | _    | ns   |
| t <sub>z(DIOR)</sub>        | DIOR data 3-state                 | note 2     |      |      |      |
| 2(2:01)                     |                                   | Mode 0     | _    | 30   | ns   |
|                             |                                   | Mode 1     | _    | 30   | ns   |
|                             |                                   | Mode 2     | _    | 30   | ns   |
|                             |                                   | Mode 3     | _    | 30   | ns   |
|                             |                                   | Mode 4     | _    | 30   | ns   |
| t <sub>ass(A-IOCS16)</sub>  | address valid to IOCS16 assertion | note 3     |      |      |      |
|                             | time                              | Mode 0     | _    | 90   | ns   |
|                             |                                   | Mode 1     | _    | 50   | ns   |
|                             |                                   | Mode 2     | _    | 40   | ns   |
|                             |                                   | Mode 3     | _    | _    | ns   |
|                             |                                   | Mode 4     | _    | _    | ns   |
| t <sub>rel(A-IOCS16)</sub>  | address valid to IOCS16 released  | note 3     |      |      |      |
|                             | time                              | Mode 0     | _    | 60   | ns   |
|                             |                                   | Mode 1     | _    | 45   | ns   |
|                             |                                   | Mode 2     | _    | 30   | ns   |
|                             |                                   | Mode 3     | _    | _    | ns   |
|                             |                                   | Mode 4     | _    | _    | ns   |
| t <sub>h(DIOR/DIOW-A)</sub> | DIOR/DIOW to address valid hold   | Mode 0     | 20   | _    | ns   |
|                             | time                              | Mode 1     | 15   | _    | ns   |
|                             |                                   | Mode 2     | 10   | _    | ns   |
|                             |                                   | Mode 3     | 10   | _    | ns   |
|                             |                                   | Mode 4     | 10   | _    | ns   |

# SAA7381

| SYMBOL                    | PARAMETER                       | CONDITIONS | MIN. | MAX. | UNIT |
|---------------------------|---------------------------------|------------|------|------|------|
| t <sub>R(DAT-IORDY)</sub> | read data valid to IORDY active | Mode 0     | 0    | _    | ns   |
|                           | (if IORDY initially LOW after   | Mode 1     | 0    | _    | ns   |
|                           | t <sub>su(IORDY)</sub> )        | Mode 2     | 0    | -    | ns   |
|                           |                                 | Mode 3     | 0    | -    | ns   |
|                           |                                 | Mode 4     | 0    | _    | ns   |
| t <sub>su(IORDY)</sub>    | IORDY set-up time               | note 4     |      |      |      |
|                           |                                 | Mode 0     | 35   | -    | ns   |
|                           |                                 | Mode 1     | 35   | _    | ns   |
|                           |                                 | Mode 2     | 35   | _    | ns   |
|                           |                                 | Mode 3     | 35   | -    | ns   |
|                           |                                 | Mode 4     | 35   | _    | ns   |
| t <sub>W(IORDY)</sub>     | IORDY pulse width               | Mode 0     | -    | 1250 | ns   |
|                           |                                 | Mode 1     | -    | 1250 | ns   |
|                           |                                 | Mode 2     | -    | 1250 | ns   |
|                           |                                 | Mode 3     | _    | 1250 | ns   |
|                           |                                 | Mode 4     | _    | 1250 | ns   |

#### Notes

- T<sub>cy</sub> is the minimum total cycle time, t<sub>W(DIOR/DIOW)</sub> is the minimum command active time, and t<sub>rec(DIOR/DIOW)</sub> is the minimum command recovery time or command inactive time. The actual cycle time equals the sum of the actual command active time and the actual command inactive time. The three timing requirements of T<sub>cy</sub>, t<sub>W(DIOR/DIOW)</sub>, and t<sub>rec(DIOR/DIOW)</sub> shall be met. The minimum total cycle time requirements is greater than the sum of t<sub>W(DIOR/DIOW)</sub> and t<sub>rec(DIOR/DIOW)</sub>. This means a host implementation can lengthen either or both t<sub>W(DIOR/DIOW)</sub> or t<sub>rec(DIOR/DIOW)</sub> to ensure that T<sub>cy</sub> is equal to or greater than the value reported in the devices identify drive data. A device implementation shall support any legal host implementation.
- 2. This parameter specifies the time from the negation edge of DIOR to the time that the data bus is no longer driven by the device (3-state).
- 3. The delay from the activation of  $\overline{\text{DIOR}}$  or  $\overline{\text{DIOW}}$  until the state of  $\overline{\text{IORDY}}$  is first sampled. If  $\overline{\text{IORDY}}$  is inactive then the host shall wait until  $\overline{\text{IORDY}}$  is active before the PIO cycle can be completed. If the device is not driving  $\overline{\text{IORDY}}$  negated at the  $t_{su(IORDY)}$  after the activation of  $\overline{\text{DIOR}}$  or  $\overline{\text{DIOW}}$ , then  $t_{su(DIOR)}$  shall be met and  $t_{R(DAT-IORDY)}$  is not applicable. If the device is driving  $\overline{\text{IORDY}}$  negated at the time  $t_{su(IORDY)}$  after the activation of  $\overline{\text{DIOR}}$  or  $\overline{\text{DIOW}}$ , then  $t_{su(IORDY)}$  after the activation of  $\overline{\text{DIOR}}$  or  $\overline{\text{DIOW}}$ , then  $t_{su(IORDY)}$  after the activation of  $\overline{\text{DIOR}}$  or  $\overline{\text{DIOW}}$ , then  $t_{R(DAT-IORDY)}$  shall be met and  $t_{su(DOR)}$  is not applicable.
- 4.  $t_{ass(A-IOCS16)}$  and  $t_{rel(A-IOCS16)}$  apply only to Modes 0, 1 and 2. This signal is not valid for other modes.



SAA7381

Table 107 Single word DMA timing; see Fig.16

| SYMBOL                           | PARAMETER             | CONDITIONS | MIN.                               | MAX. | UNIT |
|----------------------------------|-----------------------|------------|------------------------------------|------|------|
| T <sub>cy</sub>                  | cycle time            | Mode 0     | 960                                | -    | ns   |
|                                  |                       | Mode 1     | 480                                | _    | ns   |
|                                  |                       | Mode 2     | 240                                | -    | ns   |
| t <sub>d(DMACK-DMARQ)</sub>      | DMACK to DMARQ delay  | Mode 0     | _                                  | 200  | ns   |
| · · ·                            |                       | Mode 1     | -                                  | 100  | ns   |
|                                  |                       | Mode 2     | -                                  | 80   | ns   |
| t <sub>W(DIOR/DIOW)</sub>        | DIOR/DIOW pulse width | Mode 0     | 480                                | -    | ns   |
|                                  | 16-bit                | Mode 1     | 240                                | -    | ns   |
|                                  |                       | Mode 2     | 120                                | -    | ns   |
| t <sub>ACC(DIOR)</sub>           | DIOR data access time | Mode 0     | _                                  | 250  | ns   |
|                                  |                       | Mode 1     | -                                  | 150  | ns   |
|                                  |                       | Mode 2     | -                                  | 60   | ns   |
| t <sub>h(DIOR)</sub>             | DIOR data hold time   | Mode 0     | 5                                  | -    | ns   |
|                                  |                       | Mode 1     | 5                                  | -    | ns   |
|                                  |                       | Mode 2     | 5                                  | -    | ns   |
| t <sub>su(DIOW)</sub>            | DIOW data set-up time | Mode 0     | 250                                | -    | ns   |
|                                  |                       | Mode 1     | 100                                | -    | ns   |
|                                  |                       | Mode 2     | 35                                 | -    | ns   |
| t <sub>h(DIOW)</sub>             | DIOW data hold time   | Mode 0     | 50                                 | -    | ns   |
|                                  |                       | Mode 1     | 30                                 | -    | ns   |
|                                  |                       | Mode 2     | 20                                 | -    | ns   |
| t <sub>su(DMACK-DIOR/DIOW)</sub> | DMACK to DIOR/DIOW    | Mode 0     | 0                                  | _    | ns   |
|                                  | set-up time           | Mode 1     | 0                                  | -    | ns   |
|                                  |                       | Mode 2     | 0                                  | -    | ns   |
| t <sub>h(DIOR/DIOW-DMACK)</sub>  | DIOR/DIOW to DMACK    | Mode 0     | 0                                  | -    | ns   |
|                                  | hold time             | Mode 1     | 0                                  | -    | ns   |
|                                  |                       | Mode 2     | 0                                  | -    | ns   |
| t <sub>su(DIOR)</sub>            | DIOR set-up time      | Mode 0     | $t_{W(DIOR/DIOW)} - t_{ACC(DIOR)}$ | -    | ns   |
|                                  |                       | Mode 1     | $t_{W(DIOR/DIOW)} - t_{ACC(DIOR)}$ | -    | ns   |
|                                  |                       | Mode 2     | $t_{W(DIOR/DIOW)} - t_{ACC(DIOR)}$ | _    | ns   |



SAA7381

| SYMBOL                            | PARAMETER                      | CONDITIONS | MIN. | MAX. | UNIT |
|-----------------------------------|--------------------------------|------------|------|------|------|
| T <sub>cy</sub>                   | cycle time                     | note 1     |      |      |      |
|                                   |                                | Mode 0     | 480  | _    | ns   |
|                                   |                                | Mode 1     | 150  | _    | ns   |
|                                   |                                | Mode 2     | 120  | _    | ns   |
| t <sub>W(DIOR/DIOW)</sub>         | DIOR/DIOW pulse width 16-bit   | Mode 0     | 215  | _    | ns   |
|                                   |                                | Mode 1     | 80   | _    | ns   |
|                                   |                                | Mode 2     | 70   | _    | ns   |
| t <sub>ACC(DIOR)</sub>            | DIOR data access time          | Mode 0     | -    | 150  | ns   |
|                                   |                                | Mode 1     | -    | 60   | ns   |
|                                   |                                | Mode 2     | -    | _    | ns   |
| t <sub>h(DIOR)</sub>              | DIOR data hold time            | note 2     |      |      |      |
|                                   |                                | Mode 0     | 5    | _    | ns   |
|                                   |                                | Mode 1     | 5    | _    | ns   |
|                                   |                                | Mode 2     | 5    | _    | ns   |
| t <sub>su(DIOW)</sub>             | DIOW data set-up time          | Mode 0     | 100  | _    | ns   |
|                                   |                                | Mode 1     | 30   | _    | ns   |
|                                   |                                | Mode 2     | 20   | _    | ns   |
| t <sub>h(DIOW)</sub>              | DIOW data hold time            | Mode 0     | 20   | _    | ns   |
|                                   |                                | Mode 1     | 15   | _    | ns   |
|                                   |                                | Mode 2     | 10   | _    | ns   |
| t <sub>su(DMACK</sub> -DIOR/DIOW) | DMACK to DIOR/DIOW set-up time | Mode 0     | 0    | _    | ns   |
|                                   |                                | Mode 1     | 0    | _    | ns   |
|                                   |                                | Mode 2     | 0    | _    | ns   |
| t <sub>h(DIOR/DIOW-DMACK)</sub>   | DIOR/DIOW to DMACK hold time   | Mode 0     | 20   | _    | ns   |
|                                   |                                | Mode 1     | 5    | _    | ns   |
|                                   |                                | Mode 2     | 5    | _    | ns   |
| t <sub>Wneg(DIOR)</sub>           | DIOR negated pulse width       | note 1     |      |      |      |
|                                   |                                | Mode 0     | 50   | _    | ns   |
|                                   |                                | Mode 1     | 50   | _    | ns   |
|                                   |                                | Mode 2     | 25   | _    | ns   |
| t <sub>Wneg(DIOW)</sub>           | DIOW negated pulse width       | note 1     |      |      |      |
|                                   |                                | Mode 0     | 215  | _    | ns   |
|                                   |                                | Mode 1     | 50   | _    | ns   |
|                                   |                                | Mode 2     | 25   | _    | ns   |
| t <sub>d(DIOR-DMARQ)</sub>        | delay time from DIOR to DMARQ  | Mode 0     | -    | 120  | ns   |
|                                   |                                | Mode 1     | _    | 40   | ns   |
|                                   |                                | Mode 2     | _    | 35   | ns   |

Table 108 Multi-word DMA timing; see Fig.17

### SAA7381

| SYMBOL                     | PARAMETER                        | CONDITIONS | MIN. | MAX. | UNIT |
|----------------------------|----------------------------------|------------|------|------|------|
| t <sub>d(DIOW-DMARQ)</sub> | delay time from DIOW to DMARQ    | Mode 0     | -    | 40   | ns   |
|                            |                                  | Mode 1     | -    | 40   | ns   |
|                            |                                  | Mode 2     | -    | 35   | ns   |
| t <sub>d(DMACK-z)</sub>    | delay time from DMACK to 3-state | note 2     |      |      |      |
|                            |                                  | Mode 0     | _    | 20   | ns   |
|                            |                                  | Mode 1     | _    | 25   | ns   |
|                            |                                  | Mode 2     | _    | 25   | ns   |

#### Notes

- 1. T<sub>cy</sub> is the minimum total cycle time, t<sub>W(DIOR/DIOW)</sub> is the minimum command active time, and t<sub>Wneg(DIOR)</sub> or t<sub>Wneg(DIOW)</sub>, as appropriate) is the minimum command recovery time or command inactive time. The actual cycle time equals the sum of the actual command active time and the actual command inactive time. The three timing requirements of T<sub>cy</sub>, t<sub>W(DIOR/DIOW)</sub> and t<sub>Wneg(DIOR)</sub> or t<sub>Wneg(DIOW)</sub> shall be met. The minimum total cycle time requirement, T<sub>cy</sub>, is greater than the sum of t<sub>W(DIOR/DIOW)</sub> and t<sub>Wneg(DIOR)</sub> or t<sub>Wneg(DIOR)</sub> or t<sub>Wneg(DIOW)</sub>. This means a host implementation can lengthen either or both t<sub>W(DIOR/DIOW)</sub> or t<sub>Wneg(DIOR)</sub> or t<sub>Wneg(DIOW)</sub> to ensure that T<sub>cy</sub> is equal to the value reported in the devices identify drive data. A device implementation shall support any legal host implementation.
- 2. The original ATA standard defined a maximum value for t<sub>h(DIOR)</sub>. The meaning of this value was not clear. This parameter has been renamed to t<sub>d(DMACK-z)</sub> and specifies the time from the negation edge of DMACK to the time the device data signals are no longer driven by the device (3-state). The t<sub>d(DMACK-z)</sub> parameter applies only at the end of a multi-word DMA cycle, i.e., when DMACK is negated. The device may actively drive the Device Data signals, or may 3-state the device data signals, while DMACK is active from the first time that DIOR is asserted until DMACK is negated as long as t<sub>ACC(DIOR)</sub> and t<sub>h(DIOR)</sub> requirements are met.



SAA7381

#### 11.2.3 ULTRA DMA OPERATION AND TIMING

Selection of ultra DMA is similar to multi-word DMA operation. Bits 5, 6 and 7 of the DTCTR register should all be set to logic 1 and data byte counts and data flow selection does not change from ATAPI DMA operation.

The 'ultra\_stop' interrupt (IFSTAT bit 4) when enabled by 'ultra\_stopien' (IFCTRL bit 4) will interrupt the microcontroller if the host stops a transfer before the required data has been transfer i.e. the data byte count has not reached zero.

A flag, 'crc\_error' (IFSTAT bit 0) if asserted in conjunction with the 'dtei' interrupt (IFSTAT bit 6) will indicate to the microcontroller that the last transfer of data was corrupt.

No changes of pin direction are required for ultra DMA, but the ATA description changes (see Table 109).

#### Table 109 Ultra DMA pin changes

| ATA PIN NAME | ULTRA DMA READ PIN NAME   | ULTRA DMA WRITE PIN NAME       | COMMENT                                                                                                                                        |
|--------------|---------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| IORDY        | sender strobe             | D_DMARDY<br>(device DMA ready) | D_DMARDY can be used to pause transmission                                                                                                     |
| DMARQ        | DMARQ                     | DMARQ                          | similar to ATAPI DMA                                                                                                                           |
| DMACK        | DMACK                     | DMACK                          | similar to ATAPI DMA, but also<br>used at the end of transmission<br>for the CRC strobe                                                        |
| DIOR         | STOP                      | sender strobe                  | stop can terminate the data<br>transfer before all bytes have<br>been transferred; this action will<br>generate a microcontroller<br>interrupt |
| DIOW         | H_DMARDY (host DMA ready) | STOP                           | H_DMARDY can be used by to pause transmission                                                                                                  |

#### 11.2.4 ULTRA DMA READ/WRITE TIMING

This section provides the timing diagrams for the ultra DMA protocol. The timing diagrams are shown in Figs 18 to 26. The timing information is provided in Table 110.

#### Table 110 Timing parameter values; see Figs 18 to 26

| SYMBOL                 | PARAMETER                                          | CONDITIONS | MIN. | MAX. | UNIT |
|------------------------|----------------------------------------------------|------------|------|------|------|
| T <sub>cy</sub>        | cycle time (from STROBE edge to STROBE             | Mode 0     | 117  | -    | ns   |
|                        | edge)                                              | Mode 1     | 77   | -    | ns   |
|                        |                                                    | Mode 2     | 57   | -    | ns   |
| t <sub>su(D)(RX)</sub> | data set-up time (at receiver)                     | Mode 0     | 15   | -    | ns   |
|                        |                                                    | Mode 1     | 10   | -    | ns   |
|                        |                                                    | Mode 2     | 7    | -    | ns   |
| t <sub>h(D)(RX)</sub>  | data hold time (at receiver)                       | Mode 0     | 3    | -    | ns   |
|                        |                                                    | Mode 1     | 3    | -    | ns   |
|                        |                                                    | Mode 2     | 3    | -    | ns   |
| t <sub>su(DV)</sub>    | data valid set-up time (at sender); time from data | Mode 0     | 75   | -    | ns   |
| · · /                  | bus being valid until STROBE edge                  | Mode 1     | 48   | -    | ns   |
|                        |                                                    | Mode 2     | 38   | _    | ns   |

| SYMBOL                           | PARAMETER                                                                                  | CONDITIONS | MIN. | MAX. | UNIT |
|----------------------------------|--------------------------------------------------------------------------------------------|------------|------|------|------|
| t <sub>h(DV)</sub>               | data valid hold time (at sender); time from                                                | Mode 0     | 8    | -    | ns   |
|                                  | STROBE edge until data goes invalid                                                        | Mode 1     | 8    | -    | ns   |
|                                  |                                                                                            | Mode 2     | 8    | -    | ns   |
| t <sub>li</sub>                  | limited interlock time; time allowed between an                                            | Mode 0     | 0    | 150  | ns   |
|                                  | action by one agent and the following action by                                            | Mode 1     | 0    | 150  | ns   |
|                                  | the other agent                                                                            | Mode 2     | 0    | 150  | ns   |
| t <sub>li(min)</sub>             | limited interlock time with minimum                                                        | Mode 0     | 20   | 150  | ns   |
|                                  |                                                                                            | Mode 1     | 20   | 150  | ns   |
|                                  |                                                                                            | Mode 2     | 20   | 150  | ns   |
| t <sub>ui</sub>                  | unlimited interlock time                                                                   | Mode 0     | 0    | -    | ns   |
|                                  |                                                                                            | Mode 1     | 0    | -    | ns   |
|                                  |                                                                                            | Mode 2     | 0    | -    | ns   |
| t <sub>(O-z)(max)</sub>          | maximum time allowed for outputs to 3-state                                                | Mode 0     | _    | 10   | ns   |
|                                  |                                                                                            | Mode 1     | _    | 10   | ns   |
|                                  |                                                                                            | Mode 2     | _    | 10   | ns   |
| t <sub>d(min)</sub>              | minimum delay time for output drivers turning on                                           | Mode 0     | 20   | _    | ns   |
|                                  | (from high-impedance)                                                                      | Mode 1     | 20   | -    | ns   |
|                                  |                                                                                            | Mode 2     | 20   | -    | ns   |
| t <sub>env</sub>                 | envelope time (all control signal transitions are within the DACKb envelope by this time)  | Mode 0     | 20   | 70   | ns   |
|                                  |                                                                                            | Mode 1     | 20   | 70   | ns   |
|                                  |                                                                                            | Mode 2     | 20   | 70   | ns   |
| t <sub>res(STROBE</sub> -DMARDY) | STROBE-to-DMARDY response time to ensure synchronous pause case (when receiver is pausing) | Mode 0     | _    | 50   | ns   |
|                                  |                                                                                            | Mode 1     | _    | 30   | ns   |
|                                  |                                                                                            | Mode 2     | -    | 20   | ns   |
| t(READY-STROBE)                  | READY-to-final-STROBE time (this long after                                                | Mode 0     | _    | 75   | ns   |
|                                  | DMARDYb de-assertion, no more STROBE                                                       | Mode 1     | _    | 60   | ns   |
|                                  | edges may be sent)                                                                         | Mode 2     | _    | 50   | ns   |
| t(READY-PAUSE)                   | READY-to-pause time: time until a receiver may                                             | Mode 0     | 160  | -    | ns   |
|                                  | assume that the sender has paused after                                                    | Mode 1     | 125  | -    | ns   |
|                                  | de-asserting DMARDYb                                                                       | Mode 2     | 100  | -    | ns   |
| t <sub>pu</sub>                  | pull-up time before allowing IORDY to go                                                   | Mode 0     | _    | 20   | ns   |
|                                  | high-impedance                                                                             | Mode 1     | _    | 20   | ns   |
|                                  |                                                                                            | Mode 2     | _    | 20   | ns   |
| t <sub>(IORDY)(max)</sub>        | maximum time driver must wait before driving                                               | Mode 0     | 0    | -    | ns   |
|                                  | IORDY                                                                                      | Mode 1     | 0    | -    | ns   |
|                                  |                                                                                            | Mode 2     | 0    | -    | ns   |
| t <sub>su(ass/deass)</sub>       | set-up time before assertion and de-assertion of                                           | Mode 0     | 20   | -    | ns   |
| ,                                | DACKb                                                                                      | Mode 1     | 20   | -    | ns   |
|                                  |                                                                                            | Mode 2     | 20   | _    | ns   |

| SYMBOL                       | PARAMETER                                                | CONDITIONS | MIN. | MAX. | UNIT |
|------------------------------|----------------------------------------------------------|------------|------|------|------|
| t <sub>h(ass/deass)</sub>    | hold time before assertion and de-assertion of           | Mode 0     | 20   | -    | ns   |
| DACKb                        | DACKb                                                    | Mode 1     | 20   | -    | ns   |
|                              |                                                          | Mode 2     | 20   | -    | ns   |
| t <sub>ss(STROBE-STOP)</sub> | (STROBE-STOP) time from STROBE edge to negation of DMARQ |            | 50   | -    | ns   |
|                              | or assertion of STOP                                     | Mode 1     | 50   | -    | ns   |
|                              |                                                          | Mode 2     | 50   | -    | ns   |



















# SAA7381



#### 11.3 Sub-CPU interface timing

| Table 111 Timing parameter | values for Figs 28 and 29 |
|----------------------------|---------------------------|
|----------------------------|---------------------------|

| SYMBOL              | PARAMETER                | MIN. | MAX.                                   | UNIT |
|---------------------|--------------------------|------|----------------------------------------|------|
| t <sub>AVLL</sub>   | address valid to ALE LOW | 10   | _                                      | ns   |
| t <sub>RLDV</sub>   | RD LOW to valid data in  | _    | 7t <sub>CLCL</sub> + 20 <sup>(1)</sup> | ns   |
| t <sub>W(ALE)</sub> | ALE pulse width          | 35   | _                                      | ns   |
| t <sub>h(A)</sub>   | address hold time        | 10   | _                                      | ns   |
| t <sub>DVWL</sub>   | DATA valid before WR LOW | 0    | _                                      | ns   |

#### Note

1.  $t_{CLCL}$  = the SAA7381 system clock period.





# SAA7381

#### 11.4 UART timing



| txfull                                                                            |
|-----------------------------------------------------------------------------------|
| rxfull                                                                            |
|                                                                                   |
| SerIn, SerOut BIT 7 BIT 6 BIT 5 BIT 4 BIT 3 BIT 2 BIT 1 BIT 0                     |
| 'erln' samples                                                                    |
| See Section 7.9 for relevant timing.                                              |
| Fig.31 Timing diagram of SPI mode, byte transmission of UART in synchronous mode. |

| Philips Semiconductors |  |
|------------------------|--|
|------------------------|--|

Objective specification

# SAA7381

# ATAPI CD-R block decoder

95

| ADDRESS | NAME       | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|------------|--------|-------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF00H   | HEAD0      | R      | drive | 8                 | see Table 20 | HEAD0                                | -                                        |
| FF01H   | HEAD1      | R      | drive | 8                 |              | HEAD1                                | -                                        |
| FF02H   | HEAD2      | R      | _     | 8                 |              | HEAD2                                | -                                        |
| FF03H   | HEAD3      | R      | _     | 8                 |              | HEAD3                                | -                                        |
| FF04H   | SUBHEAD0   | R      | _     | 8                 |              | SHEAD0                               | -                                        |
| FF05H   | SUBHEAD1   | R      | _     | 8                 |              | SHEAD1                               | -                                        |
| FF06H   | SUBHEAD2   | R      | _     | 8                 |              | SHEAD2                               | -                                        |
| FF07H   | SUBHEAD3   | R      | _     | 8                 |              | SHEAD3                               | -                                        |
| FF08H   | STAT0      | R      | _     | 8                 |              | STAT0                                | -                                        |
| FF09H   | STAT1      | R      | _     | 8                 |              | STAT1                                | -                                        |
| FF0AH   | STAT2      | R      | _     | 8                 |              | STAT2                                | -                                        |
| FF0BH   | STAT3      | R      | _     | 8                 |              | STAT3                                | -                                        |
| FF0CH   | STAT4      | R      | _     | 8                 |              | STAT3                                | _                                        |
| FF0DH   | CTRL0      | W      | _     | 8                 | see Table 16 | CTRL0                                | -                                        |
| FFOEH   | CTRL1      | W      | _     | 8                 |              | CTRL1                                | _                                        |
| FF0FH   | CTRL2      | W      | _     | 8                 |              | CTRL1                                | _                                        |
| FF10H   | IFCONFIG   | W      | drive | 8                 | see Table 12 | IFCONFIG                             | FECTRL                                   |
| FF11H   | C1BLERCNT  | R      | _     | 8                 | see Table 97 | _                                    | -                                        |
| FF12H   | C2BLERCNT  | R      | _     | 8                 |              | _                                    | _                                        |
| FF13H   | SUBMODETX  | W      | _     | 8                 | see Table 30 | _                                    | -                                        |
| FF14H   | MMAUD      | W      | _     | 8                 | see Table 35 | _                                    | -                                        |
| FF15H   | MCK_CON    | W      | _     | 8                 |              | _                                    | _                                        |
| FF16H   | MMCTRL     | W      | _     | 8                 |              | _                                    | -                                        |
| FF17H   | SUBMODERX  | W      | _     | 8                 | see Table 32 | _                                    | -                                        |
| FF18H   | SUBPAGE1-H | W      | -     | 16                | see Table 89 | _                                    | PAGEREG                                  |
| FF19H   | SUBPAGE1-L | W      | _     |                   |              | _                                    | PAGEREG                                  |
| FF1AH   | SUBPAGE2-H | W      | _     | 16                |              | _                                    | -                                        |
| FF1BH   | SUBPAGE2-L | W      | _     |                   |              | _                                    | -                                        |

# 12 APPENDIX A

#### Table 112 The SAA7381 register map

1997 Aug 12

| _        |
|----------|
| 9        |
| Ó        |
| 7        |
| ≻        |
|          |
| ū        |
| <u> </u> |
| Ν        |
|          |

| ADDRESS | NAME            | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|-----------------|--------|-------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF1CH   | SUBSEG1-H       | W      | _     | 16                | see Table 90 | _                                    | MICFRM#                                  |
| FF1DH   | SUBSEG1-L       | W      | _     | 1                 | ļ            | _                                    | MICFRM#                                  |
| FF1EH   | _               | _      | -     | -                 | _            | _                                    | _                                        |
| FF1FH   |                 | _      | _     | _                 | _            | _                                    | _                                        |
| FF20H   | DRIVECURSEG-H   | RW     | _     | 16                | see Table 14 | -                                    | FEFRM#                                   |
| FF21H   | DRIVECURSEG-L   | RW     | _     | 1                 | ļ            | _                                    | FEFRM#                                   |
| FF22H   | DRIVEPREVSEG-H  | RW     | -     | 16                |              | _                                    | LASTCMPFM/<br>ECCFRM                     |
| FF23H   | DRIVEPREVSEG-L  | RW     | _     | -                 | 1            | _                                    | FEFRMOFF                                 |
| FF24H   | DRIVEOFFSET-H   | RW     | -     | 16                | 1 1          | _                                    | FEFRMOFF                                 |
| FF25H   | DRIVEOFFSET-L   | RW     | _     | 1                 | 1            | -                                    | -                                        |
| FF26H   | DRIVENEXTSEG-H  | RW     | _     | 16                | see Table 14 | _                                    | -                                        |
| FF27H   | DRIVENEXTSEG-L  | RW     | -     | 1                 |              |                                      | -                                        |
| FF28H   | AUXSEGMENT-H    | RW     | _     | 16                | see Table 29 | _                                    | _                                        |
| FF29H   | AUXSEGMENT-L    | RW     | _     | 1                 | 1            | -                                    | -                                        |
| FF2AH   | SUBPOINTR-H     | RW     | _     | 16                | see Table 34 | _                                    | _                                        |
| FF2BH   | SUBPOINTR-L     | RW     | _     | 1                 | 1            | -                                    | _                                        |
| FF2CH   | SUBBASEPOINTR-H | RW     | _     | 16                | 1 1          | _                                    | -                                        |
| FF2DH   | SUBBASEPOINTR-L | RW     | _     | 1                 | 1            | -                                    | _                                        |
| FF2EH   | SUBPOINTW-H     | RW     | _     | 16                | 1 1          | SUB-H                                | _                                        |
| FF2FH   | SUBPOINTW-L     | RW     | _     | 1                 | [            | SUB-L                                | _                                        |
| FF30H   | SUBBASEPOINTW-H | RW     | _     | 16                | 1 r          | SUB-H                                | -                                        |
| FF31H   | SUBBASEPOINTW-L | RW     | _     | 1                 | ļ            | SUB-L                                | _                                        |
| FF32H   | CDDA-H          | RW     | -     | 16                | see Table 35 | _                                    | _                                        |
| FF33H   | CDDA-L          | RW     | _     |                   | 1 r          | _                                    | -                                        |
| FF34H   | DAOFFSET-H      | RW     | -     | 16                | ] [          | _                                    | _                                        |
| FF35H   | DAOFFSET-L      | RW     | _     | 1                 | l l          | _                                    | _                                        |

# Philips Semiconductors

ATAPI CD-R block decoder

| ADDRESS | NAME             | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|------------------|--------|-------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF36H   | COPYFROMOFFSET-H | RW     | _     |                   | see Table 42 |                                      | -                                        |
| FF37H   | COPYFROMOFFSET-L | RW     | _     |                   |              | _                                    | _                                        |
| FF38H   | COPYTOOFFSET-H   | RW     | -     | 16                |              | _                                    | _                                        |
| FF39H   | COPYTOOFFSET-L   | RW     | -     |                   |              | _                                    | _                                        |
| FF3AH   | COPYFROMSEG-H    | RW     | _     | 16                |              | _                                    | -                                        |
| FF3BH   | COPYFROMSEG-L    | RW     | -     | -                 |              | _                                    | _                                        |
| FF3CH   | COPYTOSEG-H      | RW     | _     |                   |              | _                                    | -                                        |
| FF3DH   | COPYTOSEG-L      | RW     | _     |                   |              | _                                    | -                                        |
| FF3EH   | FROM2OFFSET-H    | RW     | -     | 16                |              | _                                    | _                                        |
| FF3FH   | FROM2OFFSET-L    | RW     | _     |                   |              | _                                    | -                                        |
| FF40H   | TO2OFFSET-H      | RW     | _     | 16                |              | _                                    | -                                        |
| FF41H   | TO2OFFSET-L      | RW     | _     |                   |              | _                                    | _                                        |
| FF42H   | HOSTBYTEOFFSET-H | RW     | _     | 16                | see Table 85 | DAC                                  | -                                        |
| FF43H   | HOSTBYTEOFFSET-L | RW     | _     | -                 |              | DAC                                  | -                                        |
| FF44H   | HOSTCURSEG-H     | RW     | -     | 16                |              | DAC                                  | SCSICFRM                                 |
| FF45H   | HOSTCURSEG-L     | RW     | _     |                   |              | DAC                                  | SCSICFRM                                 |
| FF46H   | _                | _      | _     | _                 | _            | _                                    | _                                        |
| FF47H   | _                | _      | -     | _                 | _            | _                                    | _                                        |
| FF48H   | _                | _      | _     | _                 | _            | _                                    | _                                        |
| FF49H   | _                | _      | _     | _                 | _            | _                                    | -                                        |
| FF4AH   | SPI_RX_OFF-H     | RW     | -     | 16                | see Table 93 | _                                    | _                                        |
| FF4BH   | SPI_RX_OFF-L     | RW     | _     | 1                 |              | _                                    | _                                        |
| FF4CH   | SPI_TX_OFF-H     | RW     | -     | 16                | ]            | _                                    | _                                        |
| FF4DH   | SPI_TX_OFF-L     | RW     | _     | 1                 |              | _                                    | _                                        |
| FF4EH   | _                | _      | _     | _                 | _            | _                                    | _                                        |
| FF4FH   | _                | _      | _     | _                 | _            | _                                    | _                                        |

SAA7381

1997 Aug 12

Objective specification

| ADDRESS | NAME                | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|---------------------|--------|-------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF50H   | HOSTSUBBLKOFFSET2-H | RW     | _     | 16                | see Table 85 | _                                    | -                                        |
| FF51H   | HOSTSUBBLKOFFSET2-L | RW     | _     | 1                 |              | _                                    | -                                        |
| FF52H   | HOSTSUBBLKCOUNT2-H  | RW     | _     | 16                |              | _                                    | -                                        |
| FF53H   | HOSTSUBBLKCOUNT2-L  | RW     | _     | 1                 |              | _                                    | -                                        |
| FF54H   | HOSTNEXTSEG-H       | RW     | _     | 16                |              | _                                    | SCSISFRM                                 |
| FF55H   | HOSTNEXTSEG-L       | RW     | _     | 1                 |              | _                                    | SCSISFRM                                 |
| FF56H   | HOSTRELOADFLAGS     | RW     | _     | 16                |              | _                                    | -                                        |
| FF57H   | HOSTNEXTSEGCOUNT    | RW     | _     |                   |              | _                                    | -                                        |
| FF58H   | HOSTSUBBLKOFFSET0-H | RW     | _     | 16                |              | _                                    | -                                        |
| FF59H   | hostsubblkoffset0-L | RW     | _     | 1                 |              | _                                    | -                                        |
| FF5AH   | HOSTSUBBLKCOUNT0-H  | RW     | _     | 16                |              | _                                    | -                                        |
| FF5BH   | HOSTSUBBLKCOUNT0-L  | RW     | _     | 1                 |              | _                                    | _                                        |
| FF5CH   | HOSTSUBBLKOFFSET1-H | RW     | _     | 16                |              | _                                    | -                                        |
| FF5DH   | HOSTSUBBLKOFFSET1-L | RW     | _     |                   |              | _                                    | _                                        |
| FF5EH   | HOSTSUBBLKCOUNT1-H  | RW     | _     | 16                |              | _                                    | -                                        |
| FF5FH   | HOSTSUBBLKCOUNT1-L  | RW     | _     | ]                 |              | _                                    | _                                        |
| FF60H   | DRIVECURCOUNT       | RW     | -     | 8                 | see Table 14 | _                                    | -                                        |
| FF61H   | DRIVENEXTCOUNT      | RW     | _     | 8                 |              | _                                    | -                                        |
| FF62H   | COPYCOUNT-H         | RW     | _     | 8                 | see Table 42 | _                                    | _                                        |
| FF63H   | COPYCOUNT-L         | RW     | _     | 8                 |              | _                                    | _                                        |
| FF64H   | HOSTBYTECOUNT-H     | RW     | _     | 8                 | see Table 85 | _                                    | _                                        |
| FF65H   | HOSTBYTECOUNT-L     | RW     | _     | 8                 |              | _                                    | _                                        |
| FF66H   | HOSTCURSEGCNT       | RW     | _     | 8                 |              | _                                    | _                                        |
| FF67H   | COPYCONTROL         | RW     | _     | 8                 | see Table 42 | _                                    | _                                        |
| FF68H   | HOSTRELSEG-H        | RW     | -     | 16                | see Table 85 | _                                    | -                                        |
| FF69H   | HOSTRELSEG-L        | RW     | _     |                   |              | _                                    | -                                        |
| FF6AH   | DRAM_CONFIG         | W      | _     | 8                 | see Table 90 | MEMS                                 | DRAMSEL                                  |
| FF6BH   | AUX_FORM_SCAN       | RW     | _     | 8                 | see Table 85 | _                                    | _                                        |
| FF6CH   | _                   | _      | _     | _                 | -            | _                                    | -                                        |
| FF6DH   | _                   | -      | _     | -                 | -            | _                                    | _                                        |

# ATAPI CD-R block decoder

SAA7381

Objective specification

86

1997 Aug 12

| _        |
|----------|
| 9        |
| õ        |
| 7        |
| ⊳        |
|          |
| g        |
| <u> </u> |
| N        |
|          |

| ADDRESS | NAME              | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT                                 | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|-------------------|--------|-------|-------------------|-----------------------------------------|--------------------------------------|------------------------------------------|
| FF6EH   | _                 | _      | _     | _                 | -                                       | _                                    | -                                        |
| FF6FH   | TEMP_DATA         | RW     | _     | 8                 | holding<br>register; see<br>Section 7.6 | _                                    | -                                        |
| FF70H   | IECCTRL           | W      | _     | 8                 | see Table 35                            | _                                    | -                                        |
| FF71H   | IECCAT            | W      | _     | 8                 |                                         | _                                    | -                                        |
| FF72H   | _                 | _      | _     | _                 | _                                       | _                                    | -                                        |
| FF73H   | CONF_8051         | W      | _     | 8                 | see Table 98                            | _                                    | -                                        |
| FF74H   | UART_PRESCALER    | RW     | _     | 8                 | see Table 93                            | _                                    | _                                        |
| FF75H   | UART_DMA_CTRL     | RW     | _     | 8                 |                                         | _                                    | BRGSEL                                   |
| FF76H   | UARTCOM           | W      | _     | 8                 |                                         | _                                    | -                                        |
| FF77H   | RXDATA/TXDATA     | RW     | _     | 8                 |                                         | _                                    | SERCOM                                   |
| FF78H   | UARTINTSTAT/RESET | RW     | _     | 8                 |                                         | _                                    | -                                        |
| FF79H   | UARTINTENABLE     | W      | _     | 8                 |                                         | _                                    | -                                        |
| FF7AH   | INT1STAT/RESET    | RW     | _     | 8                 | see<br>Tables 45 and<br>46              | _                                    | -                                        |
| FF7BH   | INT1ENABLE        | W      | _     | 8                 | see Table 47                            | _                                    | -                                        |
| FF7CH   | INT2STAT/RESET    | RW     | _     | 8                 | see<br>Tables 48 and<br>49              | _                                    | -                                        |
| FF7DH   | INT2ENABLE        | W      | _     | 8                 | see Table 50                            | _                                    | _                                        |
| FF7EH   | UARTSTAT          | R      | _     | 8                 | see Table 93                            | _                                    | _                                        |
| FF7FH   | UARTAUXSTAT       | R      | _     | 8                 | ] [                                     | _                                    | -                                        |

SAA7381

99

Philips Semiconductors

| 1997 |  |
|------|--|
| Aug  |  |
| 12   |  |

| ADDRESS | NAME    | ACCESS | BLOCK    | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|---------|--------|----------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF80H   | ADATA   | RW     | _        | 8                 | see Table 56 | ADATA                                | -                                        |
| FF81H   | IFCTRL  | RW     | _        | 8                 |              | IFCTRL                               | -                                        |
| FF82H   | DBCL    | RW     | _        | 8                 |              | DBCL                                 | -                                        |
| FF83H   | DBCH    | RW     | _        | 8                 |              | DBCH                                 | -                                        |
| FF84H   | DTRG    | W      | _        | 8                 |              | DTRG                                 | -                                        |
| FF85H   | DTACK   | W      | _        | 8                 |              | DTACK                                | -                                        |
| FF86H   | RESET   | W      | _        | 8                 |              | RESET                                | -                                        |
| FF87H   | ASTAT   | RW     | _        | 8                 |              | ASTAT                                | -                                        |
| FF88H   | ITRG    | W      | _        | 8                 |              | ITRG                                 | -                                        |
| FF89H   | ADRADR  | W      | _        | 8                 |              | ADRADR                               | -                                        |
| FF8AH   | ASAMT   | RW     | _        | 8                 |              | ASAMT                                | _                                        |
| FF8BH   | DTCTR   | RW     | _        | 8                 |              | DTCTR                                | _                                        |
| FF8CH   | ADRSEL  | RW     | _        | 8                 |              | ADRSEL                               | -                                        |
| FF8DH   | AINTR   | RW     | _        | 8                 |              | AINTR                                | -                                        |
| FF8EH   | AERR    | RW     | _        | 8                 |              | AERR                                 | _                                        |
| FF8FH   | ACMD    | R      | _        | 8                 |              | ACMD                                 | -                                        |
| FF90H   | ADCTR   | R      | _        | 8                 |              | ADCTR                                | -                                        |
| FF91H   | AFEAT   | R      | _        | 8                 |              | AFEAT                                | _                                        |
| FF92H   | IFSTAT  | RW     | _        | 8                 |              | IFSTAT                               | -                                        |
| FF93H   | APCMD   | R      | _        | 8                 |              | APCMD                                | -                                        |
| FF94H   | HICONF0 | RW     | _        | 8                 |              | _                                    | _                                        |
| FF95H   | HICONF1 | RW     | _        | 8                 |              | _                                    | -                                        |
| FF96H   | HISEQ   | RW     | _        | 8                 |              | _                                    | _                                        |
| FF97H   | SHSTAT  | RW     | _        | 8                 |              | _                                    | _                                        |
| FF98H   | SHERR   | RW     | _        | 8                 |              | _                                    | _                                        |
| FF99H   | HIDEV   | RW     | _        | 8                 |              | _                                    | _                                        |
| FF9AH   | HISTAT  | R      | _        | 8                 |              | _                                    | _                                        |
| FF9BH   |         |        | 3 unused | d address loca    | tions        |                                      | •                                        |
| FF9CH   |         |        |          |                   |              |                                      |                                          |
| FF9DH   |         |        |          |                   |              |                                      |                                          |

SAA7381

100

| ADDRESS | NAME                                      | ACCESS | BLOCK | NUMBER<br>OF BITS | COMMENT      | ELM 'NEAR<br>EQUIVALENT'<br>REGISTER | CHAUCER 'NEAR<br>EQUIVALENT'<br>REGISTER |
|---------|-------------------------------------------|--------|-------|-------------------|--------------|--------------------------------------|------------------------------------------|
| FF9EH   | MULTI_CON                                 | _      | _     | 8                 | see Table    |                                      | _                                        |
| FF9FH   | CLK_CON                                   | _      | _     |                   | [ F          |                                      | CLKSEL                                   |
| FFA0H   | TRANSFERCOUNT (7 to 0)                    | RW     | _     | 32                | see Table 56 |                                      | -                                        |
| FFA1H   | TRANSFERCOUNT (15 to 8)                   | RW     | _     | 1                 | ſ            |                                      | _                                        |
| FFA2H   | TRANSFERCOUNT (23 to 16)                  | RW     | _     |                   | ſ            |                                      | _                                        |
| FFA3H   | TRANSFERCOUNT (31 to 24)                  | RW     | _     | 1                 | [ [          |                                      | -                                        |
| FFA4H   | PACKETSIZE_STORE(L)                       | RW     | _     | 16                | [            |                                      | _                                        |
| FFA5H   | PACKETSIZE_STORE(H)                       | RW     |       |                   | [ F          |                                      |                                          |
| FFA6H   | SEQUENCER_STATUS                          | R      |       | 8                 | [[           |                                      |                                          |
| FFA7H   | 25 unused address locations               |        |       |                   |              |                                      |                                          |
| FFBFH   |                                           |        |       |                   |              |                                      |                                          |
| FFC0H   | 32 generic addresses in 3-state locations |        |       |                   |              |                                      |                                          |
| FFDFH   |                                           |        |       |                   |              |                                      |                                          |
| FFE0H   | 32 3-state address locations              |        |       |                   |              |                                      |                                          |
| FFFFH   | 1                                         |        |       |                   |              |                                      |                                          |

1997 Aug 12

Philips Semiconductors

# SAA7381

#### **13 APPLICATION INFORMATION**



### SAA7381

#### 14 PACKAGE OUTLINE



### SAA7381

#### 15 SOLDERING

#### 15.1 Introduction

There is no soldering method that is ideal for all IC packages. Wave soldering is often preferred when through-hole and surface mounted components are mixed on one printed-circuit board. However, wave soldering is not always suitable for surface mounted ICs, or for printed-circuits with high population densities. In these situations reflow soldering is often used.

This text gives a very brief insight to a complex technology. A more in-depth account of soldering ICs can be found in our *"IC Package Databook"* (order code 9398 652 90011).

#### 15.2 Reflow soldering

Reflow soldering techniques are suitable for all LQFP packages.

Reflow soldering requires solder paste (a suspension of fine solder particles, flux and binding agent) to be applied to the printed-circuit board by screen printing, stencilling or pressure-syringe dispensing before package placement.

Several techniques exist for reflowing; for example, thermal conduction by heated belt. Dwell times vary between 50 and 300 seconds depending on heating method. Typical reflow temperatures range from 215 to  $250 \,^{\circ}$ C.

Preheating is necessary to dry the paste and evaporate the binding agent. Preheating duration: 45 minutes at 45 °C.

#### 15.3 Wave soldering

Wave soldering is **not** recommended for LQFP packages. This is because of the likelihood of solder bridging due to closely-spaced leads and the possibility of incomplete solder penetration in multi-lead devices. If wave soldering cannot be avoided, the following conditions must be observed:

- A double-wave (a turbulent wave with high upward pressure followed by a smooth laminar wave) soldering technique should be used.
- The footprint must be at an angle of 45° to the board direction and must incorporate solder thieves downstream and at the side corners.

#### Even with these conditions, do not consider wave soldering LQFP packages LQFP48 (SOT313-2), LQFP64 (SOT314-2) or LQFP80 (SOT315-1).

During placement and before soldering, the package must be fixed with a droplet of adhesive. The adhesive can be applied by screen printing, pin transfer or syringe dispensing. The package can be soldered after the adhesive is cured.

Maximum permissible solder temperature is 260 °C, and maximum duration of package immersion in solder is 10 seconds, if cooled to less than 150 °C within 6 seconds. Typical dwell time is 4 seconds at 250 °C.

A mildly-activated flux will eliminate the need for removal of corrosive residues in most applications.

#### 15.4 Repairing soldered joints

Fix the component by first soldering two diagonallyopposite end leads. Use only a low voltage soldering iron (less than 24 V) applied to the flat part of the lead. Contact time must be limited to 10 seconds at up to 300 °C. When using a dedicated tool, all other leads can be soldered in one operation within 2 to 5 seconds between 270 and 320 °C.

SAA7381

#### **16 DEFINITIONS**

| Data sheet status                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                       |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|
| Objective specification                                                                                                                                                                                                                                                                                                                                                                                                                                   | This data sheet contains target or goal specifications for product development.       |  |  |  |
| Preliminary specification                                                                                                                                                                                                                                                                                                                                                                                                                                 | This data sheet contains preliminary data; supplementary data may be published later. |  |  |  |
| Product specification                                                                                                                                                                                                                                                                                                                                                                                                                                     | This data sheet contains final product specifications.                                |  |  |  |
| Limiting values                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                       |  |  |  |
| Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability. |                                                                                       |  |  |  |
| Application information                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                       |  |  |  |

Where application information is given, it is advisory and does not form part of the specification.

#### 17 LIFE SUPPORT APPLICATIONS

These products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips for any damages resulting from such improper use or sale.

# SAA7381

NOTES

# SAA7381

NOTES

# Philips Semiconductors – a worldwide company

Netherlands: Postbus 90050, 5600 PB EINDHOVEN, Bldg. VB, Argentina: see South America Tel. +31 40 27 82785, Fax. +31 40 27 88399 Australia: 34 Waterloo Road, NORTH RYDE, NSW 2113, New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. +61 2 9805 4455, Fax. +61 2 9805 4466 Tel. +64 9 849 4160, Fax. +64 9 849 7811 Austria: Computerstr. 6, A-1101 WIEN, P.O. Box 213, Tel. +43 160 1010, Norway: Box 1, Manglerud 0612, OSLO, Fax. +43 160 101 1210 Tel. +47 22 74 8000, Fax. +47 22 74 8341 Belarus: Hotel Minsk Business Center, Bld. 3, r. 1211, Volodarski Str. 6, 220050 MINSK, Tel. +375 172 200 733, Fax. +375 172 200 773 Philippines: Philips Semiconductors Philippines Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Belgium: see The Netherlands Metro MANILA, Tel. +63 2 816 6380, Fax. +63 2 817 3474 Brazil: see South America Poland: UI. Lukiska 10, PL 04-123 WARSZAWA, Bulgaria: Philips Bulgaria Ltd., Energoproject, 15th floor, Tel. +48 22 612 2831, Fax. +48 22 612 2327 51 James Bourchier Blvd., 1407 SOFIA, Tel. +359 2 689 211, Fax. +359 2 689 102 Portugal: see Spain Romania: see Italy Canada: PHILIPS SEMICONDUCTORS/COMPONENTS, Tel. +1 800 234 7381 Russia: Philips Russia, UI. Usatcheva 35A, 119048 MOSCOW, Tel. +7 095 755 6918, Fax. +7 095 755 6919 China/Hong Kong: 501 Hong Kong Industrial Technology Centre, 72 Tat Chee Avenue, Kowloon Tong, HONG KONG, Singapore: Lorong 1, Toa Payoh, SINGAPORE 1231, Tel. +852 2319 7888, Fax. +852 2319 7700 Tel. +65 350 2538, Fax. +65 251 6500 Slovakia: see Austria Colombia: see South America Czech Republic: see Austria Slovenia: see Italy Denmark: Prags Boulevard 80, PB 1919, DK-2300 COPENHAGEN S, South Africa: S.A. PHILIPS Pty Ltd., 195-215 Main Road Martindale, Tel. +45 32 88 2636, Fax. +45 31 57 0044 2092 JOHANNESBURG, P.O. Box 7430 Johannesburg 2000, Tel. +27 11 470 5911, Fax. +27 11 470 5494 Finland: Sinikalliontie 3, FIN-02630 ESPOO, Tel. +358 9 615800, Fax. +358 9 61580920 South America: Rua do Rocio 220, 5th floor, Suite 51, 04552-903 São Paulo, SÃO PAULO - SP, Brazil, France: 4 Rue du Port-aux-Vins. BP317. 92156 SURESNES Cedex. Tel. +55 11 821 2333, Fax. +55 11 829 1849 Tel. +33 1 40 99 6161, Fax. +33 1 40 99 6427 Spain: Balmes 22 08007 BARCELONA Germany: Hammerbrookstraße 69, D-20097 HAMBURG, Tel. +34 3 301 6312. Fax. +34 3 301 4107 Tel. +49 40 23 53 60, Fax. +49 40 23 536 300 Sweden: Kottbygatan 7, Akalla, S-16485 STOCKHOLM, Greece: No. 15, 25th March Street, GR 17778 TAVROS/ATHENS, Tel. +46 8 632 2000, Fax. +46 8 632 2745 Tel. +30 1 4894 339/239, Fax. +30 1 4814 240 Switzerland: Allmendstrasse 140, CH-8027 ZÜRICH, Hungary: see Austria Tel. +41 1 488 2686, Fax. +41 1 481 7730 India: Philips INDIA Ltd, Band Box Building, 2nd floor, Taiwan: Philips Semiconductors, 6F, No. 96, Chien Kuo N. Rd., Sec. 1, 254-D, Dr. Annie Besant Road, Worli, MUMBAI 400 025, TAIPEI, Taiwan Tel. +886 2 2134 2865, Fax. +886 2 2134 2874 Tel. +91 22 493 8541, Fax. +91 22 493 0966 Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd. Indonesia: see Singapore 209/2 Sanpavuth-Bangna Road Prakanong, BANGKOK 10260, Ireland: Newstead, Clonskeagh, DUBLIN 14, Tel. +66 2 745 4090, Fax. +66 2 398 0793 Tel. +353 1 7640 000, Fax. +353 1 7640 200 Turkey: Talatpasa Cad. No. 5, 80640 GÜLTEPE/ISTANBUL, Israel: RAPAC Electronics, 7 Kehilat Saloniki St, PO Box 18053, Tel. +90 212 279 2770, Fax. +90 212 282 6707 TEL AVIV 61180, Tel. +972 3 645 0444, Fax. +972 3 649 1007 Ukraine: PHILIPS UKRAINE, 4 Patrice Lumumba str., Building B, Floor 7, Italy: PHILIPS SEMICONDUCTORS, Piazza IV Novembre 3, 252042 KIEV, Tel. +380 44 264 2776, Fax. +380 44 268 0461 20124 MILANO, Tel. +39 2 6752 2531, Fax. +39 2 6752 2557 United Kingdom: Philips Semiconductors Ltd., 276 Bath Road, Haves. Japan: Philips Bldg 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108, MIDDLESEX UB3 5BX, Tel. +44 181 730 5000, Fax. +44 181 754 8421 Tel. +81 3 3740 5130, Fax. +81 3 3740 5077 United States: 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Korea: Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. +1 800 234 7381 Tel. +82 2 709 1412, Fax. +82 2 709 1415 Uruguay: see South America Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Vietnam: see Singapore Tel. +60 3 750 5214, Fax. +60 3 757 4880 Yugoslavia: PHILIPS, Trg N. Pasica 5/v, 11000 BEOGRAD, Mexico: 5900 Gateway East, Suite 200, EL PASO, TEXAS 79905, Tel. +381 11 625 344, Fax.+381 11 635 777 Tel. +9-5 800 234 7381

For all other countries apply to: Philips Semiconductors, Marketing & Sales Communications, Building BE-p, P.O. Box 218, 5600 MD EINDHOVEN, The Netherlands, Fax. +31 40 27 24825

© Philips Electronics N.V. 1997

Middle East: see Italy

SCA55

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner.

The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.

Printed in The Netherlands

547027/1200/01/pp108

Date of release: 1997 Aug 12

Document order number: 9397 750 01999

Let's make things better.

Internet: http://www.semiconductors.philips.com



