Advisory July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ®) Ethernet QoS Using IEEE ® 802.1q Description The Agere Systems, Inc. Voice over Internet Protocol (VoIP) Phone-On-A-Chip™ solution currently implements a quality of service (QoS) strategy that uses a proprietary voice packet prioritization scheme called Ethernet Quality of Service using BlackBurst (EQuB). This scheme uses an algorithm (implemented in hardware) to ensure that voice packets transmitted from the device are given the highest priority on their collision domain. The Phone-On-A-Chip solution will now become more standards based by implementing a QoS strategy that incorporates a software-based IEEE 802.1q tagging protocol for outgoing Ethernet frames. This QoS implementation will utilize an IEEE 802.1q protocol stack from Wind River Systems® and will be integrated into the VxWorks® board support package (BSP) for the T8302 as part of our standard software solution. Virtual local area network (VLAN) tag insertion will be supported on a per-port, per-socket, and global basis. Note: As a result of migrating to this software/standards-based priority scheme, Agere will no longer support its current proprietary hardware-based EQuB scheme. Customers using the Phone-On-A-Chip IP Solution Development Design Kit should be aware of this enhancement and should structure their application software accordingly (to incorporate the features provided by the IEEE 802.1q stack). It is hoped that this migration will aid customers of Agere in implementing their own systemwide QoS mechanism when designing their end product into an IP network. Additional information may be obtained at the T8300 Phone-On-A-Chip website: http://www.agere.com/phone_chip ARM is a registered trademark of Advanced RISC Machines Limited. IEEE is a registered trademark of The Institute of Electrical and Electronics Engineers, Inc. Wind River Systems and VxWorks are registered trademarks of Wind River Systems, Inc. For additional information, contact your Agere Systems Account Manager or the following: INTERNET: http://www.agere.com E-MAIL: [email protected] N. AMERICA: Agere Systems Inc., 555 Union Boulevard, Room 30L-15P-BA, Allentown, PA 18109-3286 1-800-372-2447, FAX 610-712-4106 (In CANADA: 1-800-553-2448, FAX 610-712-4106) ASIA PACIFIC: Agere Systems Singapore Pte. Ltd., 77 Science Park Drive, #03-18 Cintech III, Singapore 118256 Tel. (65) 778 8833, FAX (65) 777 7495 CHINA: Agere Systems (Shanghai) Co., Ltd., 33/F Jin Mao Tower, 88 Century Boulevard Pudong, Shanghai 200121 PRC Tel. (86) 21 50471212, FAX (86) 21 50472266 JAPAN: Agere Systems Japan Ltd., 7-18, Higashi-Gotanda 2-chome, Shinagawa-ku, Tokyo 141, Japan Tel. (81) 3 5421 1600, FAX (81) 3 5421 1700 EUROPE: Data Requests: DATALINE: Tel. (44) 7000 582 368, FAX (44) 1189 328 148 Technical Inquiries: GERMANY: (49) 89 95086 0 (Munich), UNITED KINGDOM: (44) 1344 865 900 (Ascot), FRANCE: (33) 1 40 83 68 00 (Paris), SWEDEN: (46) 8 594 607 00 (Stockholm), FINLAND: (358) 9 3507670 (Helsinki), ITALY: (39) 02 6608131 (Milan), SPAIN: (34) 1 807 1441 (Madrid) Agere Systems Inc. reserves the right to make changes to the product(s) or information contained herein without notice. No liability is assumed as a result of their use or application. Phone-On-A-Chip is a trademark of Agere Systems, Inc. Copyright © 2001 Agere Systems Inc. All Rights Reserved July 2001 AY01-026IPT (Must accompany DS01-213IPT) Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM *) 1 Introduction Agere Systems’ Phone-On-A-Chip™ IP Solution is a highly-integrated device set that forms the basic building blocks for an internet protocol telephone (IPT), residing on a local area network (LAN). At this time, the IPT consists of two individual ICs, the T8302 IPT_ARM (advanced RISC machine) and the companion T8301 IPT_DSP (digital signal processor). This two-device solution comprises the basis for a single-IC integration of the system in the near future. The single-IC implementation will contain the functions of both IPT ICs. For conceptual objectives, features for both ICs are listed in this document. The general-purpose processor IC (IPT_ARM ) controls the system I/O (Ethernet, USB, IrDA, etc.) and provides general telephone control features (LED control, keypad button scanning, LCD module interface, etc.). A block diagram of the IPT_ARM can be found in Figure 2 on page 27. At the heart of the IPT_DSP integrated circuit is Agere Systems’ DSP1627 digital signal processor core. The DSP1627’s high-performance (80 MIPS) and single-cycle multiply accumulate instruction provide excellent support for execution of voice compression/decompression and echo cancellation algorithms. The DSP1627 core and the digital-to-analog (D/A), analog-to-digital converters (A/D), low-pass filters, and audio amplifier circuitry drive standard business telephone handsets and speakerphone hardware. This document describes the general-purpose processor IC T8302 for the IP phone. Throughout this discussion the IC will be referred to simply as IPT_ARM. * ARM is a registered trademark of Advanced RISC Machines Limited. T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents Contents Page 1 Introduction ........................................................................................................................................................... 1 1.1 PT_ARM Features ........................................................................................................................................ 15 1.2 IPT_DSP Features .......................................................................................................................................16 2 Pinout Information ............................................................................................................................................... 17 2.1 272-Pin PBGA Pin Diagram ......................................................................................................................... 17 2.2 Pin List ..........................................................................................................................................................18 3 Overview ............................................................................................................................................................. 26 3.1 ARM 940T and AMBA Bridge ....................................................................................................................... 28 3.2 IPT_ARM Memory and I/O Map ................................................................................................................... 28 4 Reset/Clock Management ..................................................................................................................................29 4.1 Reset/Clock Management Controller Theory of Operation ........................................................................... 31 4.1.1 Reset Operation ..................................................................................................................................31 4.1.2 Operation of the Clock Switching Logic .............................................................................................. 32 4.1.2.1 PLL Operation ......................................................................................................................... 32 4.1.3 Latency ................................................................................................................................................ 33 4.1.4 Real-Time Clock (RTC) ....................................................................................................................... 33 4.2 Reset/Clock Management Registers ............................................................................................................ 35 4.2.1 Pause Register .................................................................................................................................... 35 4.2.2 Version ID Register ............................................................................................................................. 36 4.2.3 Clock Management Register ...............................................................................................................36 4.2.4 Clock Status Register .......................................................................................................................... 37 4.2.5 System Clock Source Encoding .......................................................................................................... 38 4.2.6 Clock Control Register ........................................................................................................................ 38 4.2.7 Soft Reset Register ............................................................................................................................. 38 4.2.8 PLL Control Register ...........................................................................................................................39 4.2.9 Reset Status (Control/Clear) Registers ............................................................................................... 40 4.2.10 Reset Peripheral Control (Read, Clear, Set) Registers ..................................................................... 40 4.2.11 RTC External Divider Register .......................................................................................................... 41 4.2.12 RTC Clock Prescale Registers .......................................................................................................... 42 4.2.13 RTC Control Register ........................................................................................................................ 43 4.2.14 RTC Seconds Alarm Register ........................................................................................................... 44 4.2.15 RTC Seconds Count Register ........................................................................................................... 44 4.2.16 RTC Divider Register ........................................................................................................................ 44 4.2.17 RTC Interrupt Status Register ........................................................................................................... 45 4.2.18 RTC Interrupt Enable Register .......................................................................................................... 45 4.3 Operation on Reset ...................................................................................................................................... 46 5 Programmable Interrupt Controller (PIC) ............................................................................................................ 47 5.1 Interrupt Controller Operation ....................................................................................................................... 47 5.1.1 Interrupt Registers ............................................................................................................................... 48 5.2 Programmable Interrupt Controller Registers ............................................................................................... 50 5.2.1 Interrupt Request Status Register IRSR ............................................................................................. 51 5.2.2 Interrupt Request Enable Registers IRER (Set, Clear) .......................................................................51 5.2.3 Interrupt Request Soft Register IRQSR .............................................................................................. 52 5.2.4 Interrupt Priority Control Registers IPCR[15:1] ................................................................................... 52 5.2.5 Interrupt In-Service Registers ISR (ISRI, ISRF) .................................................................................. 53 5.2.6 Interrupt Request Source Clear Register IRQESCR ........................................................................... 53 5.2.7 Interrupt Priority Enable Registers IPER (Set, Clear) .........................................................................54 5.2.8 External Interrupt Control Registers .................................................................................................... 55 6 Programmable Direct Memory Access (DMA) Controller ................................................................................... 56 6.1 DMA Operation ............................................................................................................................................. 56 2 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Contents Page 6.1.1 DMA Transfer Setup Procedure .......................................................................................................... 57 6.1.2 DMA Mode 0. Memory-to-Memory in Blocks of Burst Count Size ...................................................... 58 6.1.3 Mode 1. Peripheral-to-Memory in Blocks of Burst Count Size ............................................................58 6.1.4 Mode 2. Memory-to-Peripheral in Blocks of Burst Count Size ............................................................59 6.1.4.1 Software-Triggered DMA Mode .............................................................................................. 60 6.2 DMA Registers .............................................................................................................................................. 61 6.2.1 DMA Control Registers for Channels [0:3] .......................................................................................... 62 6.2.2 DMA Source Address Registers for Channels [0:3] ............................................................................ 63 6.2.3 DMA Preload Destination Start Address Registers for Channels [0:3] ............................................... 64 6.2.4 DMA Preload Transfer Count Registers for Channels [0:3] ................................................................ 65 6.2.5 DMA Transfer Count Registers for Channels [0:3] .............................................................................. 65 6.2.6 DMA Burst and Hold Count Registers ................................................................................................. 65 6.2.7 DMA Status Register ........................................................................................................................... 66 6.2.8 DMA Interrupt Register ....................................................................................................................... 68 6.2.9 DMA Interrupt Enable Register ........................................................................................................... 68 7 Programmable Timers ........................................................................................................................................70 7.1 Timers Operation .......................................................................................................................................... 70 7.2 Interval Timer (IT) ......................................................................................................................................... 70 7.3 Watchdog Timer ........................................................................................................................................... 71 7.4 Timer Registers ............................................................................................................................................ 73 7.4.1 Count Rate Register ............................................................................................................................74 7.4.2 Encoding of Interval Timer Count Rates (ITR) and Watchdog Timer Count Rates (WTR) ................. 74 7.4.3 WT Timer Count Register ................................................................................................................... 75 7.4.4 Timer Status Register ......................................................................................................................... 75 7.4.5 Timer Interrupt Mask Register ............................................................................................................. 75 7.4.6 Timer Control Register ........................................................................................................................ 76 7.4.7 IT Count Registers .............................................................................................................................. 77 8 External Memory Interface (EMI) ........................................................................................................................ 78 8.1 IPT_ARM Processor Memory Map ............................................................................................................... 78 8.2 External FLASH/SRAM Memory Interface (EMI FLASH) ............................................................................. 78 8.3 EMI FLASH Memory Access ........................................................................................................................ 78 8.3.1 External Write ...................................................................................................................................... 78 8.3.2 External Read ..................................................................................................................................... 79 8.3.3 Wait-States .......................................................................................................................................... 79 8.3.4 Hold State ........................................................................................................................................... 79 8.3.5 Hold Disable ........................................................................................................................................79 8.3.6 Error Conditions .................................................................................................................................. 79 8.4 ROM/RAM Remapping .................................................................................................................................83 8.4.1 Programmable Addresses ................................................................................................................... 83 8.5 EMI FLASH Registers ................................................................................................................................... 84 8.5.1 Chip Select Configuration Register FLASH_CS ................................................................................. 84 8.5.2 Chip Select Configuration Registers CS1, CS2, CS3 ......................................................................... 85 8.5.3 Hold and Wait-States Encoding .......................................................................................................... 87 8.5.4 Chip Select Base Address Registers FLASH_CS, CS1, CS2, CS3, Internal SRAM .......................... 87 8.5.5 Block Size Field Encoding ................................................................................................................... 88 8.5.6 Status Register .................................................................................................................................... 88 8.5.7 Options Register .................................................................................................................................89 8.6 External SDRAM Memory Interface ..............................................................................................................89 8.6.1 External SDRAM Memory Map ........................................................................................................... 89 8.6.2 SDRAM Memory Range Base Address Register ................................................................................ 90 Agere Systems Inc. 3 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents (continued) Contents Page 8.6.3 SDRAM Control Register ....................................................................................................................90 8.6.4 SDRAM Timing and Configuration Register ........................................................................................ 90 8.6.5 SDRAM Manual Access Register ....................................................................................................... 91 8.7 SDRAM Timing ............................................................................................................................................. 92 8.8 Signals ..........................................................................................................................................................94 8.8.1 Address, A[23:0] ..................................................................................................................................94 8.8.2 Data, D[15:0] .......................................................................................................................................94 8.8.3 Byte Enable, BE1N ............................................................................................................................. 94 8.8.4 Read/Write Signals, RDN, WRN ......................................................................................................... 94 8.8.5 Chip Selects, FLASH_CS, CS1, CS2, CS3 ........................................................................................ 94 8.8.6 External WAIT, EXWAIT ..................................................................................................................... 94 8.8.7 EMI SDRAM, Synchronous DRAM Memory Interface ........................................................................ 95 8.8.8 SDRAM Address Functionality ............................................................................................................ 95 8.8.9 SDRAM Clock, SDRCK ....................................................................................................................... 95 8.8.10 SDRASN, SDCASN, SDWEN ........................................................................................................... 95 8.8.11 SDUDQM, SDLDQM ......................................................................................................................... 95 9 DSP Communications Controller (DCC) ............................................................................................................. 96 9.1 ARM Processor Memory and I/O Map ......................................................................................................... 96 9.2 DCC Token Register .................................................................................................................................... 97 9.3 DCC Interrupt Registers ............................................................................................................................... 97 9.3.1 DSP2ARM Interrupt Register .............................................................................................................. 98 9.3.2 ARM 2DSP Interrupt Register ............................................................................................................. 98 9.4 DCC Controller I/O Signals ...........................................................................................................................99 9.5 DSP Read/Write Timing Diagrams ...............................................................................................................99 10 Ethernet 10/100 MAC .................................................................................................................................... 101 10.1 Features .................................................................................................................................................102 10.2 General MAC Information ...................................................................................................................... 102 10.3 MAC Transmitter .................................................................................................................................... 103 10.4 MAC Receiver ........................................................................................................................................ 103 10.4.1 Address Matching Registers ....................................................................................................... 103 10.5 MAC Controller, Registers, and Counters .............................................................................................. 104 10.6 Control Frame Operation ....................................................................................................................... 104 10.7 Register Descriptions ............................................................................................................................. 106 10.7.1 MAC Controller Setup Register ................................................................................................... 106 10.7.2 MAC Packet Delay Alarm Value Register ...................................................................................108 10.7.3 MAC Controller Interrupt Enable Register ...................................................................................108 10.7.4 MAC Control Frame Destination Address Registers ................................................................... 109 10.7.5 MAC Control Frame Source Address Registers .......................................................................... 109 10.7.6 MAC Control Frame Length/Type Register ................................................................................. 110 10.7.7 MAC Control Frame Opcode Register ........................................................................................110 10.7.8 MAC Control Frame Data Register ............................................................................................. 111 10.7.9 VLAN Type1 Type/Length Field Register .................................................................................... 111 10.7.10 VLAN Type2 Type/Length Field Register .................................................................................. 111 10.7.11 MAC Transmit FIFO Register .................................................................................................... 111 10.7.12 MAC Receive FIFO Register ..................................................................................................... 112 10.7.13 MAC Receive Control FIFO Register ........................................................................................112 10.7.14 MDIO Address Register ............................................................................................................ 114 10.7.15 MDIO Data Register ..................................................................................................................114 10.7.16 MAC PHY Powerdown Register ................................................................................................ 115 10.7.17 MAC Controller Transmit Control Register ................................................................................ 115 4 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Contents Page 10.7.18 MAC Controller Transmit Start Register ....................................................................................116 10.7.19 MAC Transmit Status Register .................................................................................................. 116 10.7.20 MAC Collision Counter .............................................................................................................. 118 10.7.21 MAC Packet Delay Counter ...................................................................................................... 118 10.7.22 MAC Transmitted Packet Counter ............................................................................................. 118 10.7.23 MAC Transmitted Single Collision Counter ............................................................................... 118 10.7.24 MAC Transmitted Multiple Collision Counter .............................................................................119 10.7.25 MAC Excess Collision Counter ................................................................................................. 119 10.7.26 MAC Packet Deferred Counter .................................................................................................. 119 10.7.27 MAC Controller Receive Control Register ................................................................................. 119 10.7.28 MAC FIFO Status Register ........................................................................................................ 120 10.7.29 MAC Controller Interrupt Status Register ..................................................................................120 10.8 Signal Information .................................................................................................................................. 121 10.8.1 MII MAC I/O Signals .................................................................................................................... 121 11 10/100 2-Port Repeater and Backplane Segment Controller ......................................................................... 123 11.1 MII Transmit and Receive Interface .......................................................................................................124 11.1.1 Repeater Slice Interface .............................................................................................................. 124 11.1.2 PHY Interface .............................................................................................................................. 124 11.1.3 Backplane Interface ..................................................................................................................... 125 11.1.3.1 MAC Interface ............................................................................................................... 125 11.1.4 Receive Path ...............................................................................................................................126 11.1.5 Transmit Path .............................................................................................................................. 126 11.2 Input Clocks ...........................................................................................................................................126 11.3 Repeater Slice Theory of Operation .......................................................................................................126 11.3.1 Repeater Core ............................................................................................................................. 126 11.3.2 10/100 Mbits/s Operation ............................................................................................................126 11.3.3 Collisions ..................................................................................................................................... 127 11.3.4 Partition and Isolate ..................................................................................................................... 127 11.3.4.1 Partitioning .................................................................................................................... 127 11.3.4.2 MAU Jabber Lockup Protection (MJLP) ........................................................................ 127 11.3.4.3 Receive Jabber ............................................................................................................. 127 11.3.4.4 Isolate on an Incorrect Clock Frequency ....................................................................... 128 11.3.4.5 Automatic Speed Mismatch Protection ......................................................................... 128 11.3.5 Carrier Integrity Monitor ............................................................................................................... 128 11.4 Repeater Slice Interfaces ....................................................................................................................... 129 11.4.1 Repeater Slice ARM Interface .....................................................................................................129 11.4.2 Repeater Slice Interface ............................................................................................................. 129 11.4.3 Repeater Slice Input Clocks ........................................................................................................ 131 11.4.4 Backplane Segment 10/100 Mbits/s Serial Mac Interface Port B ................................................ 132 11.5 Repeater Slice Register Map ................................................................................................................. 133 11.5.1 Global Maximum Frame Size Register ........................................................................................ 134 11.5.2 Global Configuration Register .....................................................................................................135 11.5.3 Port Control Registers, for Port 0, 1 ............................................................................................ 136 11.5.4 Port Configuration Register 0 for Port 0, 1 ..................................................................................136 11.5.5 Port Configuration Register 1, for Port 0, 1 ................................................................................. 138 11.5.6 Global Interrupt Enable Register ................................................................................................. 139 11.5.7 Global Interrupt Status Register .................................................................................................. 140 11.5.8 Global Port Status Register, for Port 0, 1 ....................................................................................141 12 Ethernet 10/100 PHY(s) ................................................................................................................................. 142 12.1 10 Mbits Transceiver Features ............................................................................................................... 142 Agere Systems Inc. 5 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents (continued) Contents Page 12.2 100 Mbits/s Transceiver Features .......................................................................................................... 142 12.3 General Features ................................................................................................................................... 143 12.4 Signal Information .................................................................................................................................. 143 12.4.1 MII/5-Bit Serial Interface Signals ................................................................................................. 143 12.4.2 10/100 Mbits/s Twisted Pair (TP) Interface Signals .................................................................... 145 12.4.3 Status Signals ............................................................................................................................. 146 12.4.4 Clock and Reset Signals .............................................................................................................146 12.5 MII Station Management ........................................................................................................................ 146 12.5.1 MII Management Frame Format .................................................................................................. 147 12.5.2 Summary of Management Registers ........................................................................................... 148 12.5.3 MR0 Control Register Bit Description ..........................................................................................149 12.5.4 MR1 Status Register Bit Description ........................................................................................... 150 12.5.5 MR2 MR3 PHY Identifier Registers (1 and 2) Bit Description ..................................................... 150 12.5.6 MR4 Autonegotiation Advertisement Register Bit Description .................................................... 151 12.5.7 MR5 Autonegotiation Link Partner Ability (Base Page) Register Bit Description ........................151 12.5.8 MR5 Autonegotiation Link Partner (LP) Ability Register (Next Page) Bit Description .................152 12.5.9 MR6 Autonegotiation Expansion Register Bit Description .......................................................... 152 12.5.10 MR7 Next Page Transmit Register Bit Description .................................................................. 153 12.5.11 MR16 PCS Control Register Bit Description ............................................................................. 153 12.5.12 MR17 Autonegotiation (Read Register A) ................................................................................. 154 12.5.13 MR18 Autonegotiation (Read Register B) ................................................................................. 154 12.5.14 MR21 RXER Counter ................................................................................................................ 155 12.5.15 MR28 Device-Specific Register 1 (Status Register) Bit Description ......................................... 155 12.5.16 MR29 Device-Specific Register 2 (100 Mbits/s Control) Bit Description ................................... 156 12.5.17 MR30 Device-Specific Register 3 (10 Mbits/s Control) Bit Description ..................................... 157 12.5.18 MR31 Device-Specific Register 4 (Quick Status) Bit Description .............................................. 158 13 USB Host Controller ....................................................................................................................................... 161 13.1 Description ............................................................................................................................................. 161 13.2 USB Registers ....................................................................................................................................... 162 13.2.1 USB Operational Registers Summary ......................................................................................... 163 13.3 The Control and Status Partition ............................................................................................................ 163 13.3.1 Hc Revision Register ................................................................................................................... 163 13.3.2 Hc Control Register ..................................................................................................................... 164 13.3.3 Hc Command Status Register ..................................................................................................... 166 13.3.4 Hc Interrupt Status Register ........................................................................................................ 167 13.3.5 Hc Interrupt Enable Register ....................................................................................................... 169 13.3.6 Hc Interrupt Disable Register ......................................................................................................170 13.4 Memory Pointer Partition ....................................................................................................................... 171 13.4.1 Hc HCCA Register ...................................................................................................................... 171 13.4.2 Hc Period Current ED Register ................................................................................................... 171 13.4.3 Hc Control Head ED Register ..................................................................................................... 172 13.4.4 Hc Control Current ED Register .................................................................................................. 172 13.4.5 Hc Bulk Head ED Register .......................................................................................................... 173 13.4.6 Hc Bulk Current ED Register ....................................................................................................... 173 13.4.7 Hc Done Head Register .............................................................................................................. 174 13.5 Frame Counter Partition .........................................................................................................................174 13.5.1 Hc Fm Interval Register ............................................................................................................... 174 13.5.2 Hc Fm Remaining Register ......................................................................................................... 175 13.5.3 Hc Fm Number Register .............................................................................................................. 176 13.5.4 Hc Periodic Start Register ........................................................................................................... 176 6 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Contents Page 13.5.5 Hc LS Threshold Register ........................................................................................................... 176 13.6 Root Hub Partition .................................................................................................................................. 177 13.6.1 Hc Rh Descriptor A Register .......................................................................................................177 13.6.2 Hc Rh Descriptor B Register .......................................................................................................180 13.6.3 Hc Rh Status Register ................................................................................................................. 181 13.6.4 Hc Rh Port Status [1:NDP] Register ............................................................................................ 182 14 IrDA_ACC and UART_ACC ........................................................................................................................... 187 14.1 ACC Operation ....................................................................................................................................... 187 14.1.1 Transmit and Receive Operation ................................................................................................. 188 14.1.2 Transfer Operating Modes .......................................................................................................... 188 14.1.3 Programming the Baud Rate .......................................................................................................188 14.1.4 Extended Characters ...................................................................................................................189 14.2 ACC Registers ....................................................................................................................................... 189 14.2.1 Baud Rate Register ..................................................................................................................... 190 14.2.2 Baud Rate Counter Register .......................................................................................................190 14.2.3 FIFO Status Register ...................................................................................................................191 14.2.4 Receiver Control Register ........................................................................................................... 192 14.2.5 ACC Parity Bit Encoding ............................................................................................................. 192 14.2.6 Transmitter Control Register .......................................................................................................192 14.2.7 Mode Control Register ................................................................................................................ 193 14.2.8 Tx/Rx FIFO Register ...................................................................................................................194 14.2.9 IrDA Feature Register ................................................................................................................. 194 14.3 IrDA Formatter ....................................................................................................................................... 197 14.3.1 IrDA Formatter Operation ............................................................................................................197 14.4 DMA Support for ACC I/O Data ............................................................................................................. 199 14.5 Operation on Reset ................................................................................................................................ 199 15 Synchronous Serial Interface (SSI) ................................................................................................................ 200 15.1 Description .............................................................................................................................................200 15.1.1 Clocks .......................................................................................................................................... 200 15.1.2 Date Transfer .............................................................................................................................. 201 15.1.3 Pin Configuration ......................................................................................................................... 201 15.1.4 SSN Input .................................................................................................................................... 201 15.1.5 Configurations ............................................................................................................................. 201 15.1.6 Slave Chip Select ........................................................................................................................ 202 15.2 SSI Registers ......................................................................................................................................... 203 15.2.1 SSI Data Register ........................................................................................................................ 203 15.2.2 SSI Control Register 1 ................................................................................................................. 204 15.2.3 SSI Control Register 2 Bit Descriptions ....................................................................................... 205 15.2.3.1 SSN ...............................................................................................................................205 15.2.3.2 FASTCLEAR ................................................................................................................. 205 15.2.3.3 MDOD ........................................................................................................................... 205 15.2.3.4 SCOD ............................................................................................................................ 206 15.3 SSI Operation ......................................................................................................................................... 207 15.3.1 SPHA = 0 Format ........................................................................................................................ 208 15.3.1.1 Master Operation ........................................................................................................... 209 15.3.1.2 Slave Operation ............................................................................................................. 209 15.3.2 SPHA = 1 Format ........................................................................................................................ 209 15.3.2.1 Master ........................................................................................................................... 210 15.3.2.2 Slave ............................................................................................................................. 211 15.3.3 Transfer Start .............................................................................................................................. 211 Agere Systems Inc. 7 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents (continued) Contents 16 17 18 19 8 Page 15.3.4 Transfer End ............................................................................................................................... 211 15.3.4.1 Master Operation ........................................................................................................... 211 15.3.4.2 Slave Operation .............................................................................................................211 15.3.5 Interrupt Generation ....................................................................................................................212 15.3.6 Status Flags and Error Conditions .............................................................................................. 212 15.3.6.1 SDONE .......................................................................................................................... 212 15.3.6.2 WCOLL Flag ..................................................................................................................212 15.3.6.3 MODF ............................................................................................................................ 212 15.3.6.4 RD_ORUN ..................................................................................................................... 213 15.3.7 SSI Transfer Abort ....................................................................................................................... 213 15.3.8 SSNEN Control Register Bit ........................................................................................................ 214 Parallel Peripheral Interface (PPI) ................................................................................................................. 215 16.1 PPI Operation ........................................................................................................................................ 215 16.1.1 PPI Pin Configuration on Reset ................................................................................................... 216 16.1.2 Procedure for Writing to an Output Pin ....................................................................................... 216 16.1.3 Procedure for Reading from an Input Pin .................................................................................... 216 16.1.3.1 Additional Read/Write Notes ......................................................................................... 216 16.1.4 PPI Port Interrupts ....................................................................................................................... 217 16.2 PPI Registers ......................................................................................................................................... 218 16.2.1 PPI Data Direction Register ........................................................................................................ 218 16.3 PPI Port Data Register ........................................................................................................................... 218 16.3.1 PPI Interrupt Enable Register ......................................................................................................219 16.3.2 PPI Port Sense Register .............................................................................................................219 16.3.3 PPI Port Polarity Register ............................................................................................................ 220 16.3.4 PPI Pull-Up Enable Register ....................................................................................................... 221 16.3.5 PPI Port Data Clear Register ......................................................................................................221 16.3.6 PPI Port Data Set Register .......................................................................................................... 221 16.4 Summary of Programming Modes ......................................................................................................... 222 Key and Lamp Controller (KLC) ..................................................................................................................... 223 17.1 KLC Operation ....................................................................................................................................... 224 17.1.1 LED Drive Matrix Operation ........................................................................................................ 224 17.1.2 Key Scan Matrix Operation ......................................................................................................... 224 17.1.3 KLC Interrupts ............................................................................................................................. 226 17.1.4 Timing and Reset ........................................................................................................................ 226 17.2 KLC LED Drive and Key Scan Matrix Pins ............................................................................................ 226 17.3 KLC Register .......................................................................................................................................... 227 17.3.1 Lamp Rate Registers ................................................................................................................... 227 17.3.2 KLC Noscan Control Register ..................................................................................................... 228 17.3.3 Key Scan Status Register ........................................................................................................... 229 17.3.4 KLC Interrupt Register ................................................................................................................. 230 17.3.5 KLC Interrupt Enable Register .................................................................................................... 230 JTAG/Boundary Scan .................................................................................................................................... 231 18.1 Debug Support ....................................................................................................................................... 231 18.2 The Principle of Boundary Scan Architecture ........................................................................................231 18.2.1 Instruction Register ..................................................................................................................... 233 18.3 Boundary Scan Register ........................................................................................................................ 234 Electrical Specifications ................................................................................................................................. 242 19.1 Absolute Maximum Ratings ................................................................................................................... 242 19.2 Handling Precautions ............................................................................................................................. 242 19.3 Crystal Specifications ............................................................................................................................. 242 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Contents Page 19.3.1 System Clock Crystal .................................................................................................................. 242 19.4 PHY Clock Crystal .................................................................................................................................. 243 19.5 Real-Time Clock Crystal ........................................................................................................................ 243 19.6 dc Electrical Characteristics ...................................................................................................................243 19.7 Power Consumption ...............................................................................................................................244 20 Change History .............................................................................................................................................. 245 21 Contact Us ...................................................................................................................................................... 245 Figures Page Figure 1. 272-Pin PBGA Pin Diagram .....................................................................................................................17 Figure 2. IPT_ARM Block Diagram ......................................................................................................................... 27 Figure 3. Reset/Clock Management Controller Block Diagram ...............................................................................29 Figure 4. Real-Time Clock Block Diagram ..............................................................................................................34 Figure 5. Interrupt Controller Block Diagram ........................................................................................................... 48 Figure 6. DMA Controller Block Diagram 1 ............................................................................................................. 56 Figure 7. DMA Controller Block Diagram 2 ............................................................................................................. 60 Figure 8. Programmable Timer Architecture Block Diagram ................................................................................... 70 Figure 9. Interval Timer Block Diagram ................................................................................................................... 71 Figure 10. Watchdog Timer Block Diagram............................................................................................................. 72 Figure 11. EMI FLASH/SRAM Read Interface Timing Diagram .............................................................................. 81 Figure 12. EMI FLASH/SRAM Write Interface Timing Diagram .............................................................................. 82 Figure 13. ROM/RAM Remapping........................................................................................................................... 83 Figure 14. SDRAM Read Timing Diagram ..............................................................................................................92 Figure 15. SDRAM Write Timing Diagram............................................................................................................... 93 Figure 16. DSP Communications Controller Block Diagram ................................................................................... 96 Figure 17. DSP Read Interface Timing Diagram ..................................................................................................... 99 Figure 18. DSP Write Interface Timing Diagram ................................................................................................... 100 Figure 19. Ethernet 10/100 MAC Block Diagram .................................................................................................. 101 Figure 20. Repeater Slice and Backplane Segment Block ....................................................................................123 Figure 21. USB Block Diagram.............................................................................................................................. 162 Figure 22. ACC Block Diagram ............................................................................................................................. 187 Figure 23. IrDA Transmit Data Timing Diagram and Width Programmability ........................................................198 Figure 24. IrDA Receive Data Timing Diagram, Minimum Pulse Width ................................................................ 199 Figure 25. SSI Functional Block Diagram.............................................................................................................. 202 Figure 26. SSI Transfer Timing Diagram, (SPHA = 0)........................................................................................... 208 Figure 27. SSI Transfer Timing Diagram, (SPHA = 1)........................................................................................... 210 Figure 28. Parallel Peripheral Interface (PPI) Block Diagram ............................................................................... 215 Figure 29. Minimum Data Input Pulse Width ......................................................................................................... 217 Figure 30. KLC Interface Matrix............................................................................................................................. 223 Figure 31. Boundary Scan Architecture................................................................................................................. 232 Figure 32. JTAG Interface Timing Diagram........................................................................................................... 233 Agere Systems Inc. 9 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents Tables Page Table 1. PBGA-272 Package ................................................................................................................................. 18 Table 2. ARM Processor Memory and I/O Map ...................................................................................................... 28 Table 3. Reset/Clock Management Controller Signals ........................................................................................... 30 Table 4. Reset/Clock Controller Register Map ....................................................................................................... 35 Table 5. Pause Register ......................................................................................................................................... 36 Table 6. Version ID Register 0xE000 0010 ............................................................................................................ 36 Table 7. Clock Management Register ..................................................................................................................... 37 Table 8. Clock Status Register ................................................................................................................................ 37 Table 9. System Clock Source Encoding ...............................................................................................................38 Table 10. Clock Control Register ............................................................................................................................ 38 Table 11. Soft Reset Register ................................................................................................................................ 39 Table 12. PLL Control Register .............................................................................................................................. 39 Table 13. Reset Status (Control/Clear) Registers .................................................................................................. 40 Table 14. Reset Peripheral Control (Read, Clear, Set) Registers .......................................................................... 41 Table 15. RTC External Divider Register ...............................................................................................................42 Table 16. RTC Clock Prescale Registers ...............................................................................................................42 Table 17. RTC Control Register ............................................................................................................................. 43 Table 18. RTC Seconds Alarm Register ................................................................................................................ 44 Table 19. RTC Seconds Count Register ................................................................................................................ 44 Table 20. RTC Divider Register .............................................................................................................................. 45 Table 21. RTC Interrupt Status Register ................................................................................................................ 45 Table 22. RTC Interrupt Enable Register ...............................................................................................................45 Table 23. Interrupt Registers ..................................................................................................................................48 Table 24. Interrupt Request Signals (IRQ) ............................................................................................................. 49 Table 25. Programmable Interrupt Controller Register Map ................................................................................... 50 Table 26. Interrupt Request Status Register IRSR .................................................................................................51 Table 27. Interrupt Request Enable Registers IRER (Set = IRESR, Clear = IRECR) ............................................ 51 Table 28. Interrupt Request Soft Register IRQSR .................................................................................................. 52 Table 29. Interrupt Priority Control Registers IPCR[15:1] ....................................................................................... 52 Table 30. Interrupt In-Service Registers ISR (ISRI, ISRF) .....................................................................................53 Table 31. Interrupt Source Encoding for Interrupt In-Service Registers ................................................................. 53 Table 32. Interrupt Request Source Clear Register IRQESCR ..............................................................................54 Table 33. Interrupt Priority Enable Registers IPER (Set = IPESR, Clear = IPECR) ...............................................54 Table 34. External Interrupt Control Registers ....................................................................................................... 55 Table 35. DMA Controller Register Map ................................................................................................................. 61 Table 36. DMA Control Registers for Channels [0:3] ............................................................................................. 62 Table 37. DMA Source Address Registers for Channels [0:3] ............................................................................... 64 Table 38. DMA Preload Destination Start Address Registers for DMA Channels [0:3] .......................................... 64 Table 39. DMA Destination Address Registers for DMA Channels [0:3] ................................................................ 64 Table 40. DMA Preload Transfer Count Registers for Channels [0:3] .................................................................... 65 Table 41. DMA Transfer Count Registers for Channels [0:3] ................................................................................. 65 Table 42. DMA Burst and Hold Count Registers for Channel [0:3] ........................................................................ 66 Table 43. DMA Status Register .............................................................................................................................. 66 Table 44. DMA Interrupt Register ...........................................................................................................................68 Table 45. DMA Interrupt Enable Register ...............................................................................................................69 Table 46. Timer Controller Register Map ...............................................................................................................73 Table 47. Count Rate Register ............................................................................................................................... 74 Table 48. Encoding of Interval Timer and Watchdog Timer Count Rates .............................................................. 74 Table 49. WT Count Register ................................................................................................................................. 75 Table 50. Timer Status Register ............................................................................................................................. 75 10 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Tables Page Table 51. Timer Interrupt Mask Register ................................................................................................................ 76 Table 52. Timer Control Register ........................................................................................................................... 76 Table 53. IT Count Registers .................................................................................................................................. 77 Table 54. IPT_ARM Processor Memory Map .........................................................................................................78 Table 55. EMI FLASH/SRAM Read Access Timing Parameters ............................................................................ 81 Table 56. EMI FLASH/SRAM Write Access Timing Parameters ............................................................................ 82 Table 57. EMI FLASH Register Map ...................................................................................................................... 84 Table 58. Chip Select Configuration Register FLASH_CS ..................................................................................... 84 Table 59. Chip Select Configuration Registers CS1, CS2, CS3 ............................................................................. 85 Table 60. Hold States Encoding ............................................................................................................................. 87 Table 61. Wait-States Encoding ............................................................................................................................. 87 Table 62. Chip Select Base Address Registers FLASH_CS, CS1, CS2, CS3, Internal SRAM .............................. 87 Table 63. Block Size Field Encoding ...................................................................................................................... 88 Table 64. Status Register ....................................................................................................................................... 88 Table 65. Options Register ..................................................................................................................................... 89 Table 66. External SDRAM Memory Map ..............................................................................................................89 Table 67. SDRAM Memory Range Base Address Register ................................................................................... 90 Table 68. SDRAM Control Register ........................................................................................................................ 90 Table 69. SDRAM Timing and Configuration Register ...........................................................................................90 Table 70. SDRAM Manual Access Register ........................................................................................................... 91 Table 71. SDRAM Access Cycles, Using a 64 Mbit SDRAM ................................................................................. 95 Table 72. ARM Processor Memory and I/O Map .................................................................................................... 96 Table 73. Token Register ....................................................................................................................................... 97 Table 74. DSP2ARM Interrupt Register ................................................................................................................ 98 Table 75. ARM 2DSP Interrupt Register ................................................................................................................ 98 Table 76. DCC Controller I/O Signals .....................................................................................................................99 Table 77. MAC Register Map ...............................................................................................................................105 Table 78. MAC Controller Setup Register ............................................................................................................106 Table 79. MAC Packet Delay Alarm Value Register ............................................................................................ 108 Table 80. MAC Controller Interrupt Enable Register ............................................................................................ 108 Table 81. MAC Control Frame Destination Address Registers ............................................................................ 109 Table 82. MAC Control Frame Source Address Registers ................................................................................... 109 Table 83. MAC Control Frame Length/Type Register .......................................................................................... 110 Table 84. MAC Control Frame Opcode Register .................................................................................................. 110 Table 85. MAC Control Frame Data Register .......................................................................................................111 Table 86. VLAN Type1 Type/Length Field Register ............................................................................................. 111 Table 87. VLAN Type2 Type/Length Field Register ............................................................................................. 111 Table 88. MAC Transmit FIFO Register ............................................................................................................... 111 Table 89. MAC Receive FIFO Register ................................................................................................................ 112 Table 90. MAC Receive Control FIFO Register ................................................................................................... 112 Table 91. MDIO Address Register ........................................................................................................................ 114 Table 92. MDIO Data Register ............................................................................................................................. 114 Table 93. MAC PHY Powerdown Register ........................................................................................................... 115 Table 94. MAC Controller Transmit Control Register ........................................................................................... 115 Table 95. MAC Controller Transmit Start Register ............................................................................................... 116 Table 96. MAC Transmit Status Register ............................................................................................................. 116 Table 97. MAC Collision Counter ......................................................................................................................... 118 Table 98. MAC Packet Delay Counter .................................................................................................................. 118 Table 99. MAC Transmitted Packet Counter ........................................................................................................ 118 Table 100. MAC Transmitted Single Collision Counter ........................................................................................ 118 Agere Systems Inc. 11 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents (continued) Tables Page Table 101. MAC Transmitted Multiple Collision Counter ...................................................................................... 119 Table 102. MAC Excess Collision Counter ........................................................................................................... 119 Table 103. MAC Packet Deferred Counter ........................................................................................................... 119 Table 104. MAC Controller Receive Control Register ..........................................................................................119 Table 105. MAC FIFO Status Register ................................................................................................................. 120 Table 106. MAC Controller Interrupt Status Register ........................................................................................... 120 Table 107. MII MAC I/O Signals ........................................................................................................................... 121 Table 108. DMA Interface Signals ....................................................................................................................... 122 Table 109. Repeater Slice ARM Interface ............................................................................................................ 129 Table 110. Repeater Slice Interface ..................................................................................................................... 129 Table 111. Repeater Slice Input Clocks ............................................................................................................... 131 Table 112. Backplane Segment 10/100 Mbits/s Serial Mac Interface Port B ....................................................... 132 Table 113. Repeater Slice Register Map .............................................................................................................. 133 Table 114. Global Maximum Frame Size Register .............................................................................................. 134 Table 115. Global Configuration Register ........................................................................................................... 135 Table 116. Port Control Registers for Port 0, 1 .................................................................................................... 136 Table 117. Port Configuration Register 0 for Port 0, 1 ......................................................................................... 136 Table 118. Port Configuration Register 1, for Port 0, 1 ........................................................................................138 Table 119. Global Interrupt Enable Register ........................................................................................................ 139 Table 120. Global Interrupt Status Register ........................................................................................................ 140 Table 121. Global Port Status Register, for Port 0, 1 ........................................................................................... 141 Table 122. MII/5-Bit Serial Interface Signals ........................................................................................................ 143 Table 123. 10/100 Mbits/s Twisted Pair (TP) Interface Signals ............................................................................145 Table 124. Status Signals .....................................................................................................................................146 Table 125. Clock and Reset Signals ....................................................................................................................146 Table 126. MII Management Frame Format ......................................................................................................... 147 Table 127. Summary of Management Registers (MR) ......................................................................................... 148 Table 128. MR0 Control Register Bit Description ................................................................................................. 149 Table 129. MR1 Status Register Bit Description .................................................................................................. 150 Table 130. MR2 MR3 PHY Identifier Registers (1 and 2) Bit Description ............................................................ 150 Table 131. MR4 Autonegotiation Advertisement Register Bit Description ........................................................... 151 Table 132. MR5 Autonegotiation Link Partner Ability (Base Page) Register Bit Description ...............................151 Table 133. MR5 Autonegotiation Link Partner (LP) Ability Register (Next Page) Bit Description ........................152 Table 134. MR6 Autonegotiation Expansion Register Bit Description .................................................................. 152 Table 135. MR7 Next Page Transmit Register Bit Description ............................................................................. 153 Table 136. MR16 PCS Control Register Bit Description ...................................................................................... 153 Table 137. MR17 Autonegotiation (Read Register A) ..........................................................................................154 Table 138. MR18 Autonegotiation (Read Register B) ..........................................................................................154 Table 139. MR21 RXER Counter .........................................................................................................................155 Table 140. MR28 Device-Specific Register 1 (Status Register) Bit Description ................................................... 155 Table 141. MR29 Device-Specific Register 2 (100 Mbits/s Control) Bit Description ............................................ 156 Table 142. MR30 Device-Specific Register 3 (10 Mbits/s Control) Bit Description .............................................. 157 Table 143. MR31 Device-Specific Register 4 (Quick Status) Bit Description ....................................................... 158 Table 144. USB Operational Register Map .......................................................................................................... 163 Table 145. Hc Revision Register .......................................................................................................................... 163 Table 146. Hc Control Register ............................................................................................................................ 164 Table 147. Hc Command Status Register ............................................................................................................ 166 Table 148. Hc Interrupt Status Register .............................................................................................................. 167 Table 149. Hc Interrupt Enable Register .............................................................................................................. 169 Table 150. Hc Interrupt Disable Register ............................................................................................................ 170 12 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Table of Contents (continued) Tables Page Table 151. Hc HCCA Register ............................................................................................................................. 171 Table 152. Hc Period Current ED Register ......................................................................................................... 171 Table 153. Hc Control Head ED Register ............................................................................................................172 Table 154. Hc Control Current ED Register ......................................................................................................... 172 Table 155. Hc Bulk Head ED Register ................................................................................................................. 173 Table 156. Hc Bulk Current ED Register ............................................................................................................. 173 Table 157. Hc Done Head Register ..................................................................................................................... 174 Table 158. Hc Fm Interval Register ..................................................................................................................... 175 Table 159. Hc Fm Remaining Register ............................................................................................................... 175 Table 160. Hc Fm Number Register .................................................................................................................... 176 Table 161. Hc Periodic Start Register ................................................................................................................. 176 Table 162. Hc LS Threshold Register ................................................................................................................. 177 Table 163. Hc Rh Descriptor A Register ............................................................................................................. 178 Table 164. Hc Rh Descriptor B Register ............................................................................................................. 180 Table 165. Hc Rh Status Register ....................................................................................................................... 181 Table 166. Hc Rh Port Status Register [1:NDP] .................................................................................................. 182 Table 167. ACC Transfer Modes ..........................................................................................................................188 Table 168. Extended Characters ..........................................................................................................................189 Table 169. IrDA_ACC and UART_ACC Communication Controller Register Map .............................................. 189 Table 170. Baud Rate Register ............................................................................................................................ 190 Table 171. Baud Rate Counter Register .............................................................................................................. 190 Table 172. FIFO Status Register ..........................................................................................................................191 Table 173. Receiver Control Register .................................................................................................................. 192 Table 174. ACC Parity Bit Encoding ..................................................................................................................... 192 Table 175. Transmitter Control Register .............................................................................................................. 193 Table 176. Mode Control Register ........................................................................................................................ 193 Table 177. Tx/Rx FIFO Register ........................................................................................................................... 194 Table 178. IrDA Feature Register ......................................................................................................................... 194 Table 179. ACC Interrupt Register ....................................................................................................................... 195 Table 180. ACC Interrupt Enable Register ........................................................................................................... 196 Table 181. SSI Register Map ...............................................................................................................................203 Table 182. SSI Data Register .............................................................................................................................. 203 Table 183. SSI Control Register 1 ........................................................................................................................ 204 Table 184. SSI Clock Divide Bit Encoding ............................................................................................................205 Table 185. SSI Control Register 2 ........................................................................................................................ 206 Table 186. SSI Interrupt Register ........................................................................................................................ 206 Table 187. SSI Interrupt Enable Register ............................................................................................................207 Table 188. PPI Parallel I/O Controller Register Map ............................................................................................ 218 Table 189. PPI Data Direction Register ................................................................................................................ 218 Table 190. PPI Port Data Register ....................................................................................................................... 219 Table 191. PPI Interrupt Enable Register ............................................................................................................. 219 Table 192. PPI Port Sense Register .................................................................................................................... 220 Table 193. PPI Port Polarity Register ...................................................................................................................220 Table 194. PPI Pull-Up Enable Register .............................................................................................................. 221 Table 195. PPI Port Data Clear Register .............................................................................................................. 221 Table 196. PPI Port Data Set Register ................................................................................................................. 222 Table 197. PPI Programming Modes ...................................................................................................................222 Table 198. KLC Matrix Pins .................................................................................................................................. 226 Table 199. KLC Register Map .............................................................................................................................. 227 Table 200. Lamp Rate Registers ..........................................................................................................................228 Agere Systems Inc. 13 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 Table of Contents (continued) Tables Page Table 201. Lamp Rate Bit Encoding ..................................................................................................................... 228 Table 202. Noscan Control Register ....................................................................................................................229 Table 203. Noscan Delay Interval Encoding ........................................................................................................ 229 Table 204. Key Scan Status Register....................................................................................................................230 Table 205. KLC Interrupt Register ........................................................................................................................ 230 Table 206. KLC Interrupt Enable Register ............................................................................................................ 230 Table 207. Boundary Scan Pin Functions ............................................................................................................ 231 Table 208. Instruction Register ............................................................................................................................. 233 Table 209. Boundary Scan Register Description .................................................................................................. 234 Table 210. Absolute Maximum Ratings ................................................................................................................ 242 Table 211. System Clock (XTAL0, XTAL1) Specifications ...................................................................................242 Table 212. PHY Clock (XLO, XHI) Crystal Specifications .................................................................................... 243 Table 213. Real-Time Clock (XRTC0, XRTC1) Specifications ............................................................................. 243 Table 214. Reset Pulse ........................................................................................................................................ 243 Table 215. dc Electrical Characteristics ............................................................................................................... 243 Table 216. Power Consumption ........................................................................................................................... 244 Table 217. Change History of DS01-213IPT ......................................................................................................... 245 14 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 1 Introduction (continued) 1.1 PT_ARM Features The IPT_ARM is a high-performance communications processor; it supports 100 Mbits/s Ethernet, USB, and IrDA, and provides all general system processing functions. The features of the IPT_ARM are as follows: ■ ARM 940T with ARM 9TDMI 32-bit core processor. ■ Processor clock speeds up to 57.6 MHz. ■ Instruction cache, 1K x 32. ■ Data cache, 1K x 32. ■ Internal SRAM, 1K x 32. ■ Two 10/100Base-T Ethernet PHYs. ■ Ethernet 10/100 repeater capabilities for in-line Ethernet connection from network to PC. ■ USB host bus interface including isochronous support. ■ IrDA infrared communications interface. ■ Asynchronous communications interface. ■ Serial communications controller and interface. ■ Parallel I/O up to 16 bits. ■ LED control interface. ■ Keyboard scan circuitry. ■ DMA control for up to four channels. ■ Four general-purpose timer counters for flexible timing control. ■ Real-time clock. ■ SDRAM external memory interface. ■ FLASH external memory interface. ■ Interprocessor communication memories for data transfer to the IPT_DSP. ■ Interprocessor token and interrupt registers for control and communication between the IPT_ARM and the IPT_DSP. ■ JTAG control for test and debugging. ■ Implementation in 0.25 µm, 3 V silicon technology. ■ Packaged in a 272-pin PBGA. Agere Systems Inc. 15 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 1 Introduction (continued) 1.2 IPT_DSP Features The IPT_ARM is intended to be used with its companion IC, the audio digital signal-processor integrated circuit (IPT_DSP). The combination of the IPT_ARM and the IPT_DSP provides a powerful solution for the implementation of the IP exchange business phone. The features of the IPT_DSP are as follows: ■ DSP1627 core with bit manipulation unit. ■ DSP clock speeds up to 80 MHz. ■ Instruction ROM, 32K x 16 (zero wait-state at 80 MHz). ■ Dual-port RAM, 6K x 16 (zero wait-state at 80 MHz). ■ Internal SRAM, 16K x 16 (single wait-state at 80 MHz). ■ 16-bit analog-to-digital converter. ■ Programmable gain amplifier on audio input. ■ Fixed gain differential microphone input. ■ Analog input SRAM buffer, 512 x 16. ■ Timed DMA for analog input SRAM. ■ Two 16-bit digital-to-analog converters. ■ Independent simultaneous speaker and handset outputs. ■ Two integrated differential speaker driver outputs. ■ Two analog output SRAM buffers, 512 x 16 each. ■ Two timed DMA outputs for simultaneous handset and speaker audio output. ■ Low-pass filtering on audio inputs and outputs. ■ Serial I/O interface. ■ General-purpose timer counter. ■ Bit I/O interface. ■ JTAG test and debugging control. ■ Implementation in 0.35 µm, 5 V silicon technology. ■ Packaged in 100-pin TQFP. 16 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 2 Pinout Information 2.1 272-Pin PBGA Pin Diagram 27.00 ± 0.20 +0.70 24.00 –0.00 A1 BALL IDENTIFIER ZONE TOP VIEW +0.70 24.00 –0.00 27.00 ± 0.20 MOLD COMPOUND PWB 1.17 ± 0.05 0.36 ± 0.04 2.13 ± 0.19 SEATING PLANE 0.20 SOLDER BALL 0.60 ± 0.10 19 SPACES @ 1.27 = 24.13 CENTER ARRAY FOR THERMAL ENHANCEMENT A1 BALL CORNER Y W V U T R P N M L K J H G F E D C B A 0.75 ± 0.15 BOTTOM VIEW 19 SPACES @ 1.27 = 24.13 1 2 3 4 5 6 7 8 9 10 12 11 14 13 16 15 18 17 20 19 Figure 1. 272-Pin PBGA Pin Diagram 5-4406 (F).b Agere Systems Inc. 17 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 2 Pinout Information (continued) 2.2 Pin List Table 1. PBGA-272 Package Ball H1 J4 J3 J2 J1 K2 K3 K1 L1 L2 L3 B1 C2 D2 D3 E4 C1 D1 E3 E2 E1 F3 G4 F2 F1 G3 G2 G1 H3 H2 L4 P4 T1 T4 V1 M1 N2 18 Signal Description I/O ARM to DSP Communications Interface DSP_A[0] DSP interface address bus bit 0 (LSB) I DSP_A[1] DSP interface address bus bit 1 I DSP_A[2] DSP interface address bus bit 2 I DSP_A[3] DSP interface address bus bit 3 I DSP_A[4] DSP interface address bus bit 4 I DSP_A[5] DSP interface address bus bit 5 I DSP_A[6] DSP interface address bus bit 6 I DSP_A[7] DSP interface address bus bit 7 I DSP_A[8] DSP interface address bus bit 8 I DSP_A[9] DSP interface address bus bit 9 I DSP_A[10] DSP interface address bus bit 10 (MSB) I DSP_D[0] DSP interface data bus bit 0 (LSB) I/O DSP_D[1] DSP interface data bus bit 1 I/O DSP_D[2] DSP interface data bus bit 2 I/O DSP_D[3] DSP interface data bus bit 3 I/O DSP_D[4] DSP interface data bus bit 4 I/O DSP_D[5] DSP interface data bus bit 5 I/O DSP_D[6] DSP interface data bus bit 6 I/O DSP_D[7] DSP interface data bus bit 7 I/O DSP_D[8] DSP interface data bus bit 8 I/O DSP_D[9] DSP interface data bus bit 9 I/O DSP_D[10] DSP interface data bus bit 10 I/O DSP_D[11] DSP interface data bus bit 11 I/O DSP_D[12] DSP interface data bus bit 12 I/O DSP_D[13] DSP interface data bus bit 13 I/O DSP_D[14] DSP interface data bus bit 14 I/O DSP_D[15] DSP interface data bus bit 15 (MSB) I/O DSP_RWN Read high write low memory signal I DSP_MCSN Chip select interprocessor memory I DSP_ICSN Chip select interprocessor semaphores and interrupt I/O DSP_INTN0 DSP interrupt I/O Crystal for Main Clock and Real-Time Clock XRTC0 Input pin to connect 32.768 kHz crystal I XRTC1 Output pin to connect 32.768 kHz crystal O XTAL0 Output pin to connect 11.52 MHz crystal O XTAL1 Input pin to connect 11.52 MHz crystal I TSTCLK Test mode clock input O RTS0N Reset output O Pull-Up/Down Source/Sink Current — — — — — — — — — — — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up — — — — 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma — — — — — — — — — — 4 ma/4 ma 4 ma/4 ma Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball Signal B11 A10 B10 C10 FLASH_CS CS1 CS2 CS3 D9 A8 A9 B9 C9 B8 C8 A7 B7 C11 A11 D10 SDRASN SDCASN EXWAIT EXINT1 EXINT2 SDWEN SDRCK SDLDQM SDUDQM RDN WRN BE1N A6 C7 B6 A5 D7 C6 B5 A4 C5 B4 A3 D5 C4 B3 B2 A2 A19 B18 B17 C17 D16 A18 D [15] D [14] D [13] D [12] D [11] D [10] D [9] D [8] D [7] D [6] D [5] D [4] D [3] D [2] D [1] D [0] A[23] A[22] A[21] A[20] A[19] A[18] Description I/O Pull-Up/Down External Memory Interface for FLASH and General Chip Select FLASH chip select O — Chip select 1 for SRAM O — Chip select 2 for SRAM O — Chip select 3 for SRAM O — External Memory Interface SDRAM Control Signals Row address strobe, active-low O — Column address strobe, active-low O — External WAIT pin I — External interrupt input #1 I* — External interrupt input #2 I* — Write enable O — SDRAM clock O — SDLDQM is lower data byte enable O — SDUDQM is upper byte enable O — Read strobe O — Write strobe O — Byte enable O — Common External Memory Interface EMI data bus bit 15 (MSB) I/O 50 kΩ pull-up EMI data bus bit 14 I/O 50 kΩ pull-up EMI data bus bit 13 I/O 50 kΩ pull-up EMI data bus bit 12 I/O 50 kΩ pull-up EMI data bus bit 11 I/O 50 kΩ pull-up EMI data bus bit 10 I/O 50 kΩ pull-up EMI data bus bit 9 I/O 50 kΩ pull-up EMI data bus bit 8 I/O 50 kΩ pull-up EMI data bus bit 7 I/O 50 kΩ pull-up EMI data bus bit 6 I/O 50 kΩ pull-up EMI data bus bit 5 I/O 50 kΩ pull-up EMI data bus bit 4 I/O 50 kΩ pull-up EMI data bus bit 3 I/O 50 kΩ pull-up EMI data bus bit 2 I/O 50 kΩ pull-up EMI data bus bit 1 I/O 50 kΩ pull-up EMI data bus bit 0 (LSB) I/O 50 kΩ pull-up EMI address bus bit 23 (MSB) O — EMI address bus bit 22 O — EMI address bus bit 21 O — EMI address bus bit 20 O — EMI address bus bit 19 O — EMI address bus bit 18 O — Source/Sink Current 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma — — 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma *Schmitt trigger input. Agere Systems Inc. 19 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball Signal A17 C16 B16 A16 C15 D14 B15 A15 C14 B14 A14 C13 B13 A13 D12 C12 B12 A12 A[17] A[16] A[15] A[14] A[13] A[12] A[11] A[10] A[9] A[8] A[7] A[6] A[5] A[4] A[3] A[2] A[1] A[0] E18 D19 E17 D18 Y1 PRTPWR PWRFLTN DPLS DMNS USBALTCK W1 V3 W2 V2 MDOSDI MDISDO SSN SCK J19 J18 J17 H20 H19 H18 G20 G19 F20 G18 PPI[15] PPI[14] PPI[13] PPI[12] PPI[11] PPI[10] PPI[9] PPI[8] PPI[7] PPI[6] Description I/O Pull-Up/Down Common External Memory Interface (continued) EMI address bus bit 17 O — EMI address bus bit 16 O — EMI address bus bit 15 O — EMI address bus bit 14 O — EMI address bus bit 13 O — EMI address bus bit 12 O — EMI address bus bit 11 O — EMI address bus bit 10 O — EMI address bus bit 9 O — EMI address bus bit 8 O — EMI address bus bit 7 O — EMI address bus bit 6 O — EMI address bus bit 5 O — EMI address bus bit 4 O — EMI address bus bit 3 O — EMI address bus bit 2 O — EMI address bus bit 1 O — EMI address bus bit 0 (LSB) O — USB Interface Bidirectional port power I/O* — Input port power fault I 50 kΩ pull-up Bidirectional differential USB port signal I/O — Bidirectional differential USB port signal I/O — Universal serial bus alternate clock I* 50 kΩ pull-up Synchronous Serial Interface Master data output, slave data input I/O* 50 kΩ pull-up Master data input, slave data output I/O* — Synchronous serial select I/O* — Clock signal I/O* — Parallel Port Interface Parallel peripheral interface bit 15 I/O* — Parallel peripheral interface bit 14 I/O* — Parallel peripheral interface bit 13 I/O* — Parallel peripheral interface bit 12 I/O* — Parallel peripheral interface bit 11 I/O* — Parallel peripheral interface bit 10 I/O* — Parallel peripheral interface bit 9 I/O* — Parallel peripheral interface bit 8 I/O* — Parallel peripheral interface bit 7 I/O* — Parallel peripheral interface bit 6 I/O* — Source/Sink Current 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 7 ma/7 ma 4 ma/4 ma — — — 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma *Schmitt trigger input. 20 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball Signal F19 E20 G17 F18 E19 D20 PPI[5] PPI[4] PPI[3] PPI[2] PPI[1] PPI[0] W3 Y2 W4 V4 U5 Y3 Y4 V5 W5 Y5 V6 U7 W6 Y6 V7 W7 Y7 V8 W8 K_ROW[6] K_ROW[5] K_ROW[4] K_ROW[3] K_ROW[2] K_ROW[1] K_ROW[0] K_COL[7] K_COL[6] K_COL[5] K_COL[4] K_COL[3] K_COL[2] K_COL[1] K_COL[0] LCNTRL MSGLED SPKRLED SWHOOK M19 M20 V20 U20 TPOB[1] TPO[1] TPI[1] TPIB[1] L19 L20 T19 T20 TPOB[0] TPO[0] TPI[0] TPIB[0] Description Parallel Port Interface (continued) Parallel peripheral interface bit 5 Parallel peripheral interface bit 4 Parallel peripheral interface bit 3 Parallel peripheral interface bit 2 Parallel peripheral interface bit 1 Parallel peripheral interface bit 0 Key and Lamp Controller Row 6—0. Row outputs for the LED drive matrix and key scan matrix Column 7—0. Column outputs for LED drive matrix and inputs for key scan matrix High active output used to enable LED drive matrix Message LED direct drive output pin Speaker LED direct drive output pin Switch-hook Ethernet Port to the PC Transmit data, negative differential Transmit data, positive differential Received data, positive differential Received data, negative differential Ethernet Port to the Network Transmit data, negative differential Transmit data, positive differential Received data, positive differential Received data, negative differential I/O Pull-Up/Down Source/Sink Current I/O* I/O* I/O* I/O* I/O* I/O* — — — — — — 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma I/O I/O I/O I/O I/O I/O I/O I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* O O O I* — — — — — — — 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down — — — — 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma O O I I — — — — — — — — O O I I — — — — — — — — *Schmitt trigger input. Agere Systems Inc. 21 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball Signal Description Ethernet 10/100 PHY Port 1 Y11 ECLP Analog factory test points (PHY section) W11 ECLN V11 ATBOP U11 ATBON P18 RMCLK 32 MHz bypass for PHY clock P19 XLO Crystal oscillator input, PHY clock P20 XHI Crystal oscillator output, PHY clock K17 LS10_OK [0] Link10, status PHY 1 K19 LS100_OK [0] Link100, status PHY 1 W19 XS [0] Transmit status PHY 1 Ethernet 10/100 PHY Port 2 J20 LS10_OK [1] Link10, status PHY 2 K18 LS100_OK [1] Link100, status PHY 2 Y20 XS [1] Transmit status PHY 2 P17 REXTBS Band gap reference for the receive channel M18 REXT10 Current setting 10 Mbits/s M17 REXT100 Current setting 100 Mbits/s Test Points W12 Testpt[19] Factory test points V12 Testpt[18] U12 Testpt[17] Y13 Testpt[16] W13 Testpt[15] V13 Testpt[14] Y14 Testpt[13] W14 Testpt[12] Y15 Testpt[11] V14 Testpt[10] W15 Testpt[9] Y16 Testpt[8] U14 Testpt[7] V15 Testpt[6] W16 Testpt[5] Y17 Testpt[4] V16 Testpt[3] W17 Testpt[2] Y18 Testpt[1] U16 Testpt[0] M2 CLKREF Test mode clock output Y9 SC_MODEN Scan mode select W10 SC_ENAN Scan mode enable I/O Pull-Up/Down Source/Sink Current O O O O I I O O O O — — — — — — — — — — — — — — — — — 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma O O O O O O — — — — — — 8 ma/8 ma 8 ma/8 ma 8 ma/8 ma — — — I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* I/O* O I/O* I/O* — — — — — — — — — — — — — — — — — — — — — 50 kΩ pull-up 50 kΩ pull-up 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma 4 ma/4 ma *Schmitt trigger input. 22 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball Signal Description T2 U1 T3 Y8 U9 V9 W9 T_ACK T_REQB T_REQA TMODE[0] TMODE[1] TMODE[2] TMODE[3] N3 P1 P2 R1 P3 V18 JTDO JTRSTN JTMS JTDI JTCK JMODE JTAG test data output JTAG test reset input JTAG test mode select JTAG test data input JTAG test clock JMODE select B19 A20 B20 C18 IRDATX0 IRDARX0 TX1 RX1 IrDA ACC transmit IrDA ACC receive UART transmit UART receive I/O Pull-Up/Down Source/Sink Current O I I I I I I — 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 4 ma/4 ma — — — — — — O I* I* I* I* I* — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 4 ma/4 ma — — — — — O I* O I* — — — — 4 ma/4 ma — 4 ma/4 ma — I* I I I I — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up — — — — — — Test Interface Controller (TIC) Test mode acknowledge Factory test inputs Test Test Test Test mode input mode input mode input mode input JTAG and Test IrDA Miscellaneous N1 RESETN Chip reset input V17 OMUXSEL[0] Test mode MUX W18 OMUXSEL[1] Y19 OMUXSEL[2] C3 VREF Output buffer voltage reference for DCC and EMI interfaces Ball M3 M4 R2 R3 U2 U3 Y10 Y12 W20 T18 R18 R19 R20 N18 Power VSSPLL VDDPLL VSSX2 VDDX2 VSSX1 VDDX1 VDDA VSSA VDDA VDDA VDDA VDDM VDDA VDDA Power and Ground PLL VSS PLL VDD 32 kHz crystal ground 32 kHz crystal power 11.52 MHz crystal ground 11.52 MHz crystal power Analog VDD Analog VSS Analog VDD Analog VDD Analog VDD Moat VDD Analog VDD Analog VDD *Schmitt trigger input. Agere Systems Inc. 23 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball C19 C20 D11 D15 D6 F17 F4 K4 L17 R17 R4 U10 U15 U6 A1 D13 D17 D4 D8 H17 H4 J10 J11 J12 J9 K10 K11 K12 K9 L10 L11 L12 L9 M10 M11 M12 M9 N17 N4 U13 U17 U4 U8 24 Power VSSU VDDU VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VDD VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS VSS Power and Ground (continued) USB ground USB power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power (thermal) Power Power Power Power Power Power Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 2 Pinout Information (continued) Table 1. PBGA-272 Package (continued) Ball V10 V19 U18 U19 T17 N19 N20 L18 K20 No Connects NC NC NC NC NC NC NC NC NC Agere Systems Inc. No connect No connect No connect No connect No connect No connect No connect No connect No connect 25 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 3 Overview The IPT_ARM contains several system-level functions that would typically require separate ICs. The following functions are implemented on a single IC: a full 32-bit microprocessor with integrated cache, a complete two-port Ethernet subsystem including a two-port repeater, a host USB, IrDA, UART, and SSI communications controllers. In addition, there are general peripheral controllers including parallel I/O, key scanning, and LED control circuitry. The IPT_ARM processor communicates with memory through the AMBA* ASB bus. This bus supports 32-bit word accesses as well as half-word and byte accesses. The AMBA APB bridge provides a flexible interface for communicating with the on-chip peripheral devices. The IPT_ARM can be used in a system that meets European Class B emissions requirements. The IPT_ARM block diagram in Figure 2 on page 27 shows the following system blocks: ■ ARM 940T 32-bit CPU. ■ AMBA ASB bus for high-performance memory access. ■ AMBA APB bridge for communication with and control of IPT_ARM peripherals. ■ Four-channel DMA controller to move data from memory to memory or to/from memory from/to IPT_ARM peripherals. ■ Interrupt controller with programmable priority for efficient system operation. ■ Reset/clock management controller with internal PLL circuitry to provide programmable clock frequencies, including a one-second real time clock. ■ General timer unit with four interval timers and a watchdog timer. ■ External memory interface with support for SDRAM, FLASH, and SRAM memories. ■ DSP communications controller with interrupts, token registers, and buffer memories for efficient interprocessor communications. ■ 1K x 32 internal SRAM for general-purpose storage. ■ Ethernet MAC. ■ Two-port Ethernet repeater. ■ Two Ethernet PHYs. ■ USB host controller. ■ IrDA communications controller. ■ UART communications controller. ■ SSI communications controller. ■ 16-bit parallel port interface. ■ Key and lamp controller (KLC). ■ JTAG. * AMBA is a trademark of ARM Limited. 26 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) RMCLK XLO XHI ECLP ECLN ATBOP ATBON 3 Overview (continued) MII MANAGEMENT SIGNALS 4-bit MII Tx FIFO 32 x 32 Rx FIFO 32 x 32 BACKPLANE SEGMENT REPEATER SLICE 0 10/100 REPEATER SLICE 1 DSP COMMUNICATIONS INTERFACE DSP_INTN0 DSP_RWN RD DSP_A[10:0] 4 WIRE TEST PT[19:0] TEST WR SC_MODEN TESTPT[19:0] 3 OMNXSEL[2:0] SCK ARM940T PROCESSOR CORE 2-PORT RAM ARM RD 512 x 32 RD SSN SSI INSTRUCTION CACHE 1K x 32 DATA CACHE 1K x 32 APB BUS EXTERNAL MEMORY FLASH INTERFACE A[23:0] MDISDI MDISDO INTERNAL SRAM 1K x 32 FLASH_CS AMBA ASB INTERFACE IRDATX0 UART A IrDA ASB BUS IRDARX0 TX1 D[15:0] UART B REGISTERS EMI-FLASH WRN REXT100 REXT10 REXTBS CHANNEL 2 SC_ENAN BE1N EXWAIT ETHERNET PORT 2 PHY 10/100 4 TMODE[3:0] MULTIPLEXED SIGNALS DSP_D[15:0] CS_[3:1] LS100_OK[1,0] CLKREF INTERRUPT CONTROLLER 2-PORT RAM DSP RD 512 x 32 WR 4 WIRE XS[1,0] LS10_OK[1,0] 4-bit MII TOKEN AND INTERRUPT REGISTERS DSP_MCSN DSP_ICSN ETHERNET PORT 1 PHY 10/100 125 MHz 4-bit MII ETHERNET MAC 10/100 Mbits/s CHANNEL 1 10/100 REPEATER RX1 RDN SDRCK USBALTCK DMA CONTROLLER AMBA APB BRIDGE SDLDQM DPLS USB HOST CONTROLLER EXTERNAL MEMORY SDRAM INTERFACE SDUDQM SDCASN DMNS PRTWR PWRFLTN SDRASN SDWEN K_ROW[6:0] APB BUS REGISTERS EMI-SDRAM EXINT1 K_COL[7:0] EXINT2 PPI PARALLEL PERIPHERAL INTERFACE 16 I/O KEY AND LAMP CONTROLLER LCNTRL MSG_LED SPKRLED SWHOOK PPI[15:0] TIMER MODULE 4 INTERVAL TIMERS 1 WATCHDOG TIMER RTS0N XTAL0 RESETN XTAL1 XRTC0 TSTCLK XRTC1 T_REQA TACK TIC T_REQB JTCK JTMS JTDI JTDO JTRSTN JMODE JTAG RESET/CLOCK MANAGEMENT UNIT 5-8233(F)a Figure 2. IPT_ARM Block Diagram Agere Systems Inc. 27 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 3 Overview (continued) 3.1 ARM 940T and AMBA Bridge The ARM 940T is a full 32-bit microprocessor with integrated instruction and data cache. This processor core contains many high-performance features. The AMBA APB bridge is a flexible interface between the high-performance AMBA ASB bus and the AMBA APB bus. Documentation for the ARM 940T and these buses can be found at the website: http://www.arm.com 3.2 IPT_ARM Memory and I/O Map The buses, along with an external memory controller provide the logic and decoding to access and support the memories and peripherals on and off the IPT_ARM. The IPT_ARM processor memory and I/O map is shown below. . Table 2. ARM Processor Memory and I/O Map Description This range is shared between ROM (FLASH), external SDRAM, FLASH_CS, CS1, CS2, CS3, and internal SRAM with programmable base addresses. Reserved for ARM 940T processor. Reserved. Reset/clock controller register map (see Table 4 on page 35); includes version ID register. Programmable interrupt controller register map (see Table 25 on page 50). DMA controller register map (see Table 35 on page 61). EMI FLASH register map (see Table 57 on page 84). SSI register map (see Table 181 on page 203). Timer controller register map (see Table 46 on page 73). PPI parallel I/O controller register map (see Table 188 on page 218). USB operational register map (see Table 144 on page 163). IrDA_ACC communications controller register map (see Table 169 on page 189). UART_ACC communications controller register map (see Table 169 on page 189). Reserved. RTC control registers (see Table 17 on page 43). Key and lamp controller registers (see Table 202 on page 229). Reserved. ARM processor memory and I/O map (see Table 72 on page 96). MAC register map (see Table 77 on page 105). Reserved. Repeater slice register map (see Table 113 on page 133). Reserved. ARM 2DSP data buffer (512x32) ARM write only (see Table 72 on page 96). Reserved. DSP2ARM data buffer (512x32) read-only (see Table 72 on page 96). Reserved. 28 Address 0x0000 0000:0xBFFF FFFF 0xC000 0000:0xCFFF FFFF 0xD000 0000:0xDFFF FFFF 0xE000 0000:0xE000 0FFF 0xE000 1000:0xE000 1FFF 0xE000 2000:0xE000 2FFF 0xE000 3000:0xE000 3FFF 0xE000 4000:0xE000 4FFF 0xE000 5000:0xE000 5FFF 0xE000 6000:0xE000 6FFF 0xE000 7000:0xE000 7FFF 0xE000 8000:0xE000 8FFF 0xE000 9000:0xE000 9FFF 0xE000 A000:0xE000 AFFF 0xE000 C000:0xE000 CFFF 0xE000 D100:0xE000 DFFF 0xE000 E000:0xE000 EFFF 0xE000 F000:0xE000 FFFF 0xE001 0000:0xE001 0FFF 0xE001 1000:0xE001 1FFF 0xE001 2000:0xE001 2FFF 0xE001 3000:0xE003 FFFF 0xE004 0000:0xE004 07FF 0xE004 0800:0xE005 FFFF 0xE006 0000:0xE006 07FF 0xE008 0000:0xFFFF FFFF Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management The reset/clock management controller controls clock generation and clock selection; it maintains a real-time clock, generates a power-on reset, and identifies the source of a reset condition. The block diagram of the reset/clock management controller is shown below. * USB_ALT_CLK PRESCALE_USB_CLK USB_CLK (48 MHz) USB CLK SWITCH USB PRESCALER * (6) RST PLL_CLK USBEXT/USBPLL EXT_CLK PLL PRESCALE_PLL_CLK RF LOCK PLL PRESCALER * (5) RST FAST CLK SWITCH VCO FREQUENCY EXT PRESCALER * (0) RST RTC EXTERNAL DIVIDER REGISTER EXT_PROG_CLK 32.768 kHz * FAST_CLK * SLOW_CLK 57.6 MHz SYSTEM SYS_CLK SWITCH SDRCK KLC_CLK RTC_OSC_CLK XRTC0 XRTC1 (FROM PLL) EN_SDRCK SLOW CLK SWITCH * (0xB0) FB * PLLC/CMEC PRESCALE_EXT_CLK PLL LOCK DETECT B_CLK * CMRT RTC_CLK RTC SWITCH ESCE EXTRTC VDD VSS POWER_UP RESET GENERATOR WDG_RST PWR_RST RESET SOURCE REGISTER AND CONTROLLER EXT_RST SOFT_RST INT_RST RST0N CLKOFF * Indicates the default position or setting. 5-9074(F) Figure 3. Reset/Clock Management Controller Block Diagram The reset/clock management controller contains the following features: Clock Sources ■ EXT_CLK input from an external 11.52 MHz crystal. This provides an input to generate the system FAST_CLK, as well as an input that can be divided for the system slow clock. The crystal is connected to XLO and XHI. ■ RTC_OSC_CLK input from an external 32.768 kHz crystal. This can provide an input to generate the RTC_CLK, as well as the system SLOW_CLK. The real-time clock circuit uses the 32 kHz RTC_CLK for maintaining elapsed real time and interrupting the ARM 940T core at the programmed number of seconds if enabled. This real-time clock implementation does not have a battery back-up feature so it is reset on all powerup resets. Pseudo real-time clock can be generated by dividing EXT_CLK, using the RTC external divider register in systems without a 32 kHz crystal. Agere Systems Inc. 29 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) Dividers/Prescalers/PLL ■ RTC external divider register to generate a slower system clock from EXT_CLK for reduced power dissipation. ■ PLL (phase-locked loop) for generating a programmable PLL_CLK from the EXT_CLK: — PLL prescaler to generate a system FAST_CLK from PLL_CLK. —EXT prescaler to generate a system FAST_CLK from EXT_CLK. ■ USB prescaler for generating the 48 MHz USB_CLK from PLL_CLK. MUX ■ System switch (please reference Figure 3 on page 29) for selecting SYS_CLK from either the FAST_CLK source or from the SLOW_CLK source. ■ SLOW_CLK switch for selecting SLOW_CLK from either EXT_PROG_CLK or RTC_OSC_CLK. ■ RTC switch for selecting RTC_CLK from either EXT_PROG_CLK or RTC_OSC_CLK. ■ FAST_CLK switch for selecting FAST_CLK from either PRESCALE_PLL_CLK or PRESCALE_EXT_CLK. ■ USB_CLK switch for selecting USB_CLK from either USB_ALT_CLK or PRESCALE_USB_CLK. Edge and zero/zero detectors on clock switching MUXes to ensure that all clock changes occur without glitching the system clock. Reset ■ Powerup reset generator for Ethernet PHYs. An external powerup reset circuit is required for chipwide powerup. ■ External reset output RSTN maintained until released by software. Table 3. Reset/Clock Management Controller Signals Signal Description Clock Signals RTC_CLK This is the clock output to real-time clock block. BCLK This is the main system clock. KLC_CLK This is the clock that times the KLC block. SDRCK This is the SDRAM clock. EXT_CLK This signal comes from a crystal oscillator buffer connected to XLO and XHI. It may be used as a clock source for system and peripheral clocks. USB_ALT_CLK This is an external clock source for USB_CLK. USB_CLK This signal goes to the USB block to clock it. XRTC0 These two signals go to a 32.768 kHz crystal oscillator buffer and generate RTC_OSC_CLK. XRTC1 MUX EXTRTC This signal switches between either EXT_PROG_CLK or RTC_OSC_CLK for RTC_CLK. EN_SDRCK This signal enables the SDRAM clock signal. CMRT This signal is used to switch between FAST_CLK and SLOW_CLK for SYS_CLK. ESCE This bit is used to switch between the EXT_PROG_CLK and RTC_OSC_CLK for the SLOW_CLK source. USB_EXT/ These signals switch between USB_ALT_CLK and USB_PRESCALE_CLK for the USB_CLK USB_PLL source. 30 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 3. Reset/Clock Management Controller Signals (continued) Signal PLLC/CMEC SOFT_RST WDG_RST EXT_RST INT_RST RTS0N RF, FB CLKOFF Description These signals switch between PRESCALE_PLL_CLK and PRESCALE_EXT_CLK for the FAST_CLK source. Reset This is a soft reset input to the reset controller. This is the watchdog timer reset coming from the timer block. This is the external hardware reset. This signal resets internal circuitry. This signal is used as the external reset output. Miscellaneous RF (reference clock) and FB (feedback clock) come from the PLL and are used to determine when the PLL is locked. This signal is generated by the reset controller to kill B_CLK. B_CLK is the clock that governs the ASB and APB interfaces. To kill the B_CLK, set the CLKOFF bit of the clock control register to 1. Then write a 1 to the pause register (see Table 5 on page 36), causing CLKOFF to go high and putting the chip in wait-for-interrupt (WFI) mode. To get out of this mode, one of the two external interrupts should become active, provided the appropriate settings for the two external interrupt registers in the PIC (programmable interrupt controller) are made. . 4.1 Reset/Clock Management Controller Theory of Operation The reset/clock management controller is governed by the control and status registers described below. The system powers up using the external 11.52 MHz crystal as the system clock. Although the PLL (phase-locked loop) is enabled on powerup, the user needs to wait until the PLL stabilizes before switching to it as the system clock source. The system clock may be switched to an external, low-frequency 32 kHz oscillator by setting the appropriate bits in the clock management register (see Table 7 on page 37) and clock control registers (see Table 10 on page 38). 4.1.1 Reset Operation There are four reset signals that reset the IPT_ARM core and its peripherals. 1. External reset (EXT_RST) 2. Powerup reset (PWR_RST) 3. Watchdog timer reset (WDG_RST) 4. Software reset (SOFT_RST) Within the reset status (control, clear) register (see Table 13 on page 40), there are four status bits identifying the cause of the most recent full chip reset. In all cases, the core resumes fetching instruction at memory address 0x00000000. ■ POR indicates that the device is reset due to assertion of the powerup reset. ■ ER indicates that the external reset pin was activated. ■ WR indicates that a device reset is forced by the watchdog timer (see Watchdog Timer on page 71) in the programmable timer unit. ■ SFT indicates a software reset (see Table 11 on page 39). Agere Systems Inc. 31 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) The four conditions are mutually exclusive, and appropriate actions can be taken within the boot code depending on which bit is set. When one of these reset sources becomes active, the appropriate reset source is recorded in the reset status (control/clear) register (see Table 13 on page 40). A reset signal is sent to the ARM 940T core and all of the peripheral blocks are reset. The internal resets are deasserted synchronously with the falling edge of the system clock after the source of the reset is deasserted. The RTS0N pin is maintained active-low until released by software via the reset peripheral control (read, clear, set) register (see Table 14 on page 41). A reset from any of the four sources previously mentioned immediately causes the following: ■ The clock source is switched to the 11.52 MHz external input with the clock divider set to 1. ■ The PLL is powered up and its programmable registers are preset. ■ The EMI (external memory interface) and the peripheral devices are powered up in their default power-on state. (In general, most register bits in the reset/clock management controller are set to a default on state, whereas most peripheral registers are reset to 0. Any exceptions to this will be specifically noted when the register bits are discussed.) ■ The internal reset signal (INT_RST), as well as the external reset (RTS0N) signal, is asserted immediately whenever any of the four reset sources are asserted. The external RTS0N signal remains active until cleared in the reset peripheral control register (read, clear, set); see Table 14 on page 41. Deasserting RTS0N is accomplished by writing 0 to the ERS bit in the reset peripheral control clear register. 4.1.2 Operation of the Clock Switching Logic The clock switching logic is controlled by software. For example, when switching from the external clock to the PLL clock, the PLLE enable bit in the clock control register (see Table 10 on page 38) is set to 1 to enable the PLL, then the PLLC bit in the clock management register (see Table 7 on page 37) is set to 1. The PLL can be shut down to conserve power by resetting the enable bit (PLLE). 4.1.2.1 PLL Operation The PLL oscillator is controlled by PLLE of the clock control register (see Table 10 on page 38). The PLL generates a clock signal when PLLE is set to 1. It typically takes about 30 µs for the PLL oscillator to restart and lock in from the inactive state (with a maximum of 250 µs). The input to the PLL comes from the input clock EXT_CLK. The PLL cannot operate without this external input clock. To use the PLL clock, first stabilize the clock output and then lock it to the programmed frequency. The clock switching logic waits until lock occurs before switching to the PLL clock. The frequency of the PLL output clock (PLL_CLK) is determined by the values loaded into the 3-bit N divider and the 5-bit M divider (see Table 12 on page 39). When the PLL clock is selected and locked (by setting PLLC in the clock management register) the frequency of PLL_CLK is related to the frequency of EXT_CLK by the following equation: PLL_CLK = EXT_CLK x (MBITS + 1)/(NBITS + 1) The coding of the Mbits and Nbits is described in Table 12 on page 39. For example: The frequency of PLL_CLK is designed to be 288 MHz in this application. 288 MHz = 11.52 MHz x (24 + 1)/(0 + 1) 32 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) The default values for MBITS and NBITS in this design are: MBITS = 24 (0x18) and NBITS = 0 (0x0). To use the PLL clock the following steps should be taken by software: ■ Program MBITS and NBITS. Choose the MBITS and NBITS values in the PLL control register (see Table 12 on page 39) by selecting the lowest value for NBITS and the appropriate value of MBITS required to obtain the desired frequency of the internal clock. ■ The clock switching logic waits for the PLL to lock before switching to the PLL as the system clock. Any write to the PLL control register (see Table 12 on page 39) resets the lock flag and causes the clock switching logic to switch to EXT_CLK. ■ The lock-in time depends on the operating frequency and the values programmed for MBITS and NBITS. ■ The frequency of the PLL output clock (PLL_CLK) should fall within the range defined in the data sheet. Change the bits in the PLL control register (see Table 12 on page 39) only while the PLL is not providing the internal clock source. ■ To select PLL as the SYS_CLK, set PLLC in the clock management register (see Table 7 on page 37) to 1. ■ To deselect PLL as the SYS_CLK, select another clock in the clock management register by setting either CMRT or CMEC to 1. When an external interrupt is encountered while in WFI mode (see Section 4.2.1 on page 35), the system automatically switches back to the last fast clock. 4.1.3 Latency The switch between the EXT_CLK and PLL_CLK is synchronous. This causes the actual switching to take place several cycles after the PLLC or the CMEC bit is changed. During this time, actual code is executed. The PLL is not disabled until the PLLE bit in the clock control register (see Table 10 on page 38) is set to 0. To find out when the switching is complete, poll the clock status register (see Table 8 on page 37). 4.1.4 Real-Time Clock (RTC) The real-time clock (RTC_CLK) defaults to a 32.768 kHz clock generated by a crystal oscillator connected at XRTC0 and XRTC1. The input clock is divided by 32,768 to generate a clock with a one-second period that increments a 29-bit seconds counter. In addition, it can generate interrupts at a programmed time. Some features of the RTC are: ■ 17-year time interval with 1 second resolution. ■ Programmed time alarm interrupt. ■ Clock source selectable between RTC_OSC_CLK and EXT_PROG_CLK. To use a real-time alarm interrupt, the following steps have to take place: 1. The clock source is selected. Either RTC_OSC_CLK or EXT_PROG_CLK. 2. The appropriate seconds value is loaded into the RTC seconds alarm register (see Table 18 on page 44). 3. The RTC clock interrupt is enabled in the RTC interrupt enable register (bit 0 AI ENA) (see Table 22 on page 45). 4. The RTC interrupt status register bit AI (see Table 21 on page 45) is set to 1 when the timer RTC alarm expires. Agere Systems Inc. 33 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) The RTC circuitry does not have an external uninterruptable power supply, therefore, it will not keep time when power is turned off to the IPT_ARM. The RTC seconds alarm register (see Table 18 on page 44) is reset to 0 during powerup reset, or hardware reset, but this register is not affected by the other reset sources. A block diagram of the real-time clock is shown in Figure 4 below. EXTRTC XRTC0 XRTC1 CRYSTAL OSCILLATOR (32.768 kHz) RTC_CLK CLOCK SELECT DIVIDER SECONDS COUNTER PERIPHERAL BUS SECONDS ALARM RTC INTERRUPT 5-8231 (F) Figure 4. Real-Time Clock Block Diagram 34 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) 4.2 Reset/Clock Management Registers The reset/clock management registers are used to program the status of the clock and power configuration of the system. Table 4. Reset/Clock Controller Register Map Register Pause register (see Table 5 on page 36). Clock management register (see Table 7 on page 37). Reserved. Reserved Version ID register Clock status register (see Table 8 on page 37). Clock control register (see Table 10 on page 38). Reserved. Soft reset register (see Table 11 on page 39). PPL control register (see Table 12 on page 39). Reserved. Reset status (control, clear) register (see Table 13 on page 40). Reserved. Reset peripheral control (read, clear, set) register (see Table 14 on page 41). RTC external divider register (see Table 15 on page 42). RTC clock prescale register (see Table 16 on page 42). RTC control register (see Table 17 on page 43). RTC seconds alarm register (see Table 18 on page 44). RTC seconds count register (see Table 19 on page 44). RTC divider register (see Table 20 on page 45). RTC interrupt status register (see Table 21 on page 45). RTC interrupt enable register (see Table 22 on page 45). Reserved. Address 0xE000 0000 0xE000 0004 0xE000 0008 0xE000 000C 0xE000 0010 0xE000 0014 0xE000 0018 0xE000 001C:0xE000 001F 0xE000 0020 0xE000 0024 0xE000 0028:0xE000 002C 0xE000 0030:0xE000 0034 0xE000 0038:0xE000 003F 0xE000 0040:0xE000 0048 0xE000 0050 0xE000 0054:0xE000 005C 0xE000 C000 0xE000 C004 0XE000 C008 0xE000 C00C 0xE000 C010 0xE000 C014 0xE000 C018:0xE000 C01C 4.2.1 Pause Register The pause register puts the chip into wait-for-interrupt (WFI) mode. WFI mode is used to conserve power by turning off clocks to the peripherals. Writing a 1 to this bit causes the system to go into WFI mode after completing any active memory requests. WFI mode is used to conserve power by turning the clocks off. Notes: CLKOFF should always be set when using WFI mode. When the system is shut down using CLKOFF (see Table 10 on page 38) the SDRAM will not refresh. Valid data must be preserved in the SDRAM. Agere Systems Inc. 35 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) Table 5 shows the format of the pause register. Table 5. Pause Register Address 0xE000 0000 31:1 RSVD Bit # Name Bit # 31:1 0 Name RSVD PAUSE 0 PAUSE Description Reserved. Specifies if the system is in wait-for-interrupt (WFI) mode. If 1, the system is in WFI mode. If 0, the system is in normal mode. 4.2.2 Version ID Register The version ID register contains the chip identification and version information for the device. This register is read only. The format of the version ID register is shown in Table 6. Table 6. Version ID Register 0xE000 0010 Address 0xE000 0010 Bit # Name Bit # 31:16 15:0 31:16 Device ID 15:0 Version ID Name Device ID Version ID Description These bits will always contain 0x8302. These bits will contain the version identification of the device. 4.2.3 Clock Management Register The clock management register selects the source of the clock to the chip blocks. Writing a 1 to a bit in this register causes the clock switching logic to switch to the selected clock. If more than one bit is set, the lowest numbered bit takes precedence. Regarding the USBEXT and USBPLL control bits: if both are set, then USBEXT takes precedence. For example, if bits 1 and 0 are both written to 1, the clock switches to the USB_ALT_CLK. If all zeros are written, nothing happens. CMRT, PLLC, and CMEC control the source of the system clock. The system clock can be either the slow clock, the PLL clock or the external 11.52 MHz crystal. Table 7 shows the format of the clock management register. . 36 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 7. Clock Management Register Bit # Name Bit # 31:6 5 31:6 RSVD 5 USBEXT Address 0xE000 0004 4 3 USBPLL EXTRTC 2 CMRT 1 PLLC 0 CMEC Name Description RSVD Reserved. USBEXT Switches USB clock source (USB_CLK) to USB_ALT_CLK. If 1, the clock switching logic switches the USB clock to the USB_ALT_CLK and then clears this bit. If 0, the clock switching logic is not activated. Switches USB clock source (USB_CLK) to the PRESCALE_USB_CLK. 4 USBPLL 3 If 1, the clock switching logic switches the USB_CLK to the PRESCALE_USB_CLK and then clears this bit. If 0, the clock switching logic is not activated. EXTRTC Controls the source of the real-time clock (RTC_CLK). 2 1 0 CMRT If 1, the RTC_CLK is driven by the RTC_OSC_CLK. If 0, the RTC_CLK is driven off of the RTC external divider register on EXT_CLK. CMRT switches the system clock source (SYS_CLK) to the slow clock (SLOW_CLK). PLLC If 1, the clock switching logic switches the system clock source (SYS_CLK) to the SLOW_CLK, and then clears this register. If 0, the logic to switch to the SLOW_CLK is not activated. PLLC switches the system clock source (SYS_CLK) to the PLL clock. CMEC If 1, the clock switching logic switches the system clock source to the PLL clock, and then clears this register. If 0, the logic to switch to the PLL is not activated. CMEC switches the system clock source (SYS_CLK) to the external clock (EXT_CLK). If 1, the clock switching logic switches the system clock source to EXT_CLK, and then clears this register. If 0, the logic to switch to EXT_CLK is not activated. 4.2.4 Clock Status Register The clock status register indicates the current clock source for the system clock (SYS_CLK) and the previous fast clock source (FAST_CLK). CSC and PFSC default to 00. Table 8 shows the format of the clock status register. Table 8. Clock Status Register Bit # Name Bit # 31:4 3:2 1:0 Agere Systems Inc. 31:4 RSVD Name RSVD PFSC CSC Address 0xE000 0014 3:2 PFSC 1:0 CSC Description Reserved. Identifies the previous fast clock source (FAST_CLK); see Table 9 below. Identifies the clock that is the current source of the system clock (SYS_CLK); see Table 9 below. 37 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) 4.2.5 System Clock Source Encoding Table 9 shows the encoding of the clock sources for the clock status register (Table 8). Table 9. System Clock Source Encoding Bits (1:0 or 3:2) 00 01 10 11 Description External clock (PRESCALE_EXT_CLK). Phase-locked loop clock (PRESCALE_PLL_CLK). Slow clock (SLOW_CLK). Reserved. 4.2.6 Clock Control Register The clock control register configures basic clock functions. Table 10 shows the format of the clock control register. Table 10. Clock Control Register Bit # Name Bit # 31:4 3 2 1 0 31:4 RSVD Address 0xE000 0018 3 2 ESCE PLLE 1 RSVD 0 CLKOFF Name RSVD ESCE Reserved. External slow clock enable. PLLE If 1, the slow clock source is the EXT_CLK divided by the specified value in the RTC external divider register (see Table 15 on page 42). If 0, the real-time clock crystal (RTC_OSC_CLK) is the SLOW_CLK source. Enables the PLL. This bit is reset to 1. RSVD CLKOFF Description If 1, the PLL is enabled. If 0, the PLL is disabled. Reserved. Determines if the CLKOFF mode feature is active. (CLKOFF mode shuts off all of the clocks to the core and to the peripherals when in WFI mode.) If 1, CLKOFF mode is active. If 0, CLKOFF mode is not active. Note: CLKOFF should always be set to 1 when using WFI mode. This bit is reset to 0. 4.2.7 Soft Reset Register When written, the soft reset register address causes a software reset to occur. When read, all zeros will be returned. Note: Soft reset has no effect on the RTC block. 38 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 11 shows the format of the soft reset register. Table 11. Soft Reset Register Address 0xE000 0020 31:0 SOFT RESET Bit # Name Bit # 31:0 Name Description SOFT RESET Writing any value to this register causes a soft reset. 4.2.8 PLL Control Register The PLL control register configures the PLL. Table 12 shows the format of the PLL control register. Table 12. PLL Control Register Bit # Name 31:12 RSVD 11 BYPASS Address 0xE000 0024 10:8 7:6 NBITS RSVD 5 FRANGE 4:0 MBITS Bit # Name Description 31:12 RSVD Reserved. Tied to 0. 11 BYPASS Active-high, reset to 0. If 1, PLL output = PLL input. 10:8 NBITS Encodes NBITS. 0 ≤ NBITS ≤ 7. This value is used as a divisor to set the PLL frequency. Actual divisor used is NBITS + 1. 7:6 5 Reset = 00. RSVD Reserved. Tied to 0. FRANGE Frequency range. If PLL output is 100 MHz—400 MHz then set to 0. If PLL output is 400 MHz—500 MHz then set to 1. 4:0 MBITS Reset = 0. Encodes MBITS. 0 ≤ MBITS ≤ 31. This value is used as a multiplier to set the PLL frequency. Actual multiplier used is MBITS + 1. Reset = 24 (0x18). Agere Systems Inc. 39 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) 4.2.9 Reset Status (Control/Clear) Registers The reset status (control/clear) registers identify the source of the last chip reset. The bit in the register corresponding to the reset source is set to 1 and the other bits are cleared. Each bit is cleared by writing a 1 to the corresponding bit in the reset status clear register. Table 13 shows the format of the reset status (control/clear) register. Table 13. Reset Status (Control/Clear) Registers Bit # Name Bit # 31:4 3 2 1 0 31:4 RSVD Name RSVD SFT Address—Control 0xE000 0030, Clear 0xE000 0034 3 2 1 SFT WR POR 0 ER Description Reserved. SFT identifies the last reset as a soft reset. WR If 1, a soft reset has occurred. If 0, the last reset was not a soft reset, or the bit was cleared. Identifies the last reset as a warm reset (caused by the watchdog timer). POR If 1, a warm reset has occurred. If 0, the last reset was not a warm reset, or the bit was cleared. Identifies the last reset as a powerup reset. ER If 1, a powerup reset has occurred. If 0, the last reset was not a powerup reset, or the bit was cleared. Identifies the last reset as an external reset. If 1, an external reset has occurred. If 0, the last reset was not an external reset, or the bit was cleared. 4.2.10 Reset Peripheral Control (Read, Clear, Set) Registers The reset peripheral control (read, clear, set) registers provide the IPT_ARM with a mechanism for resetting an individual peripheral without affecting other elements in the system. A 1 in a bit location corresponding to its assigned peripheral holds the section in reset until the bit is cleared. Individual bits can be set by writing a 1 to the corresponding bit location in the reset peripheral control (set) register. Values are read from the reset peripheral (read) register. Individual bits can be cleared by writing a 1 to the corresponding location in the reset peripheral (clear) register. Table 14 shows the format of the reset peripheral control (read, clear, set) register. 40 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 14. Reset Peripheral Control (Read, Clear, Set) Registers Bit # Name Bit # Name Bit # Name 31:18 RSVD 11 UART 4 RSVD Bit # 31: 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4:3 2 1 0 Name RSVD EREP RSVD EMAC DCC KLC RTC UART IrDA USB PIO SSI DMA INTC RSVD ITIMR RSVD ERS Address—Read 0xE000 0040, Clear 0xE000 0044, Set 0xE000 0048 17 16 15 14 13 EREP RSVD EMAC DCC KLC 10 9 8 7 6 IrDA USB PIO SSI DMA 3 2 1 0 — RSVD ITIMR RSVD ERS — 12 RTC 5 INTC — — Description Reserved. Ethernet repeater circuit. Reserved. Ethernet MAC. DSP communications controller. Key and lamp controller. Real-time clock controller. Asynchronous communications controller channel 1 to UART adjunct. Asynchronous communications controller channel 0 to IrDA receiver. Universal serial bus controller. Parallel input output controller. Synchronous serial input output controller. Direct memory access controller. Interrupt controller. Reserved. Interval and watchdog timer. Reserved. External reset bit, (RTS0N). Note: This register is initialized to all zeros on reset except for the ERS (bit 0), which is set to 1 upon reset. 4.2.11 RTC External Divider Register The RTC external divider register allows the 11.52 MHz external clock (EXT_CLK) to be divided down to produce a pseudo real-time clock in applications where a real-time crystal and real-time accuracy are not needed. The RTC external divider register is a 16-bit register whose value is loaded into a down counter every time the down counter reaches 0. There is a toggle flip-flop that changes state whenever the counter reaches 0. The output clock rate is given by the following equation: EXT_PROG_CLK = EXT_CLK/ECD/2. For a pseudo real-time clock of 32727.27 Hz the programmed value for ECD becomes 176 (0xB0). Table 15 shows the format of the RTC external divider register. Agere Systems Inc. 41 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) Table 15. RTC External Divider Register Address 0xE000 0050 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD ECD 15:0 ECD Description Reserved. RTC divider register. The clock changes state from high to low or low to high every time the RTC divider register counts down to 0. It is then reloaded with the ECD value entered by the user. 4.2.12 RTC Clock Prescale Registers The RTC clock prescale registers indicate the value by which to divide the input clock to get the current clock. If all zeros, the input clock is passed on without division. Only one of the divisor bits in the RTC clock prescale registers may be set at one time. If more than one bit is set, the lowest order bit set will determine the divisor. The format for each of the RTC clock prescale registers is identical and is as follows: Prescaler EXT_PRESCALER PLL_PRESCALER USB_PRESCALER Address 0xE000 0054 0xE000 0058 0xE000 005C Prescaler Input EXT_CLK PLL_CLK USB_CLK Prescaler Output PRESCALE_EXT_CLK PRESCALE_PLL_CLK PRESCALE_USB_CLK Table 16. RTC Clock Prescale Registers 31:7 RSVD Bit # Name Bit # 31: 7 6 5 4 3 2 Addresses 0xE000 0054:0xE000 005C 6 5 4 3 D16 D8 D6 D5 2 D4 1 D3 0 D2 Name Description RSVD Reserved. D16 Indicates that the prescaler input is divided by 16. D8 If 1, divide the clock by 16. If 0, do not divide the clock by 16. Indicates that the prescaler input is divided by 8. D6 If 1, divide the clock by 8. If 0, do not divide the clock by 8. Indicates that the prescaler input is divided by 6. D5 If 1, divide the clock by 6. If 0, do not divide the clock by 6. Indicates that the prescaler input is divided by 5. D4 If 1, divide the clock by 5. If 0, do not divide the clock by 5. Indicates that the prescaler input is divided by 4. If 1, divide the clock by 4. If 0, do not divide the clock by 4. 42 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 16. RTC Clock Prescale Registers (continued) Bit # 1 0 Name Description D3 Indicates that the prescaler input is divided by 3. D2 If 1, divide the clock by 3. If 0, do not divide the clock by 3. Indicates that the prescaler input is divided by 2. If 1, divide the clock by 2. If 0, do not divide the clock by 2. 4.2.13 RTC Control Register The RTC control register selects the real-time clock source and enables the RTC counters. Table 17 shows the format of the RTC control register. Table 17. RTC Control Register Bit # Name Bit # 31:8 7 31:8 RSVD Name RSVD ENA 7 ENA Address 0xE000 C000 6:5 4 3 RSVD BYP RSVD 2 RSVD 1 IE 0 CS Description Reserved. Crystal oscillator enable. Enables the analog portion of the crystal oscillator. If 1, the analog portion of the crystal oscillator is active and using current. If 0, the analog portion of the crystal oscillator is not active and is not using current. This bit is set to 0 if the RTC is not being used or bypass mode is set. 6:5 4 RSVD BYP This bit is set to 1 on reset. These bits are set to 11 on reset. Bypass mode. Bypasses the crystal oscillator circuit. If 1, a crystal is connected between pins XRTC0 and XRTC1. If 0, the CMOS clock on pin XRTC0 is used directly as the clock input. 3:2 1 RSVD IE This bit is set to 0 on reset. Reserved. Increment enable. Enables incrementing the RTC divider register (see Table 20 on page 45). If 1, increment of the RTC divider register is enabled. If 0, increment of the RTC divider register is disabled. 0 CS This bit is reset to 0 on powerup. Clock select. Selects the clock source for the RTC divider register (see Table 20 on page 45). If 1, the clock is from the crystal, or an external CMOS clock. If 0, the clock is the divided SYSTEM_CLK. This bit is reset to 1 on powerup. Agere Systems Inc. 43 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) 4.2.14 RTC Seconds Alarm Register The real-time clock interrupt (see Table 26 on page 51) is asserted when the values in the RTC seconds alarm register (Table 18) and RTC seconds count register (Table 19) are equal. If the RTC interrupt is enabled (AI ENA) in the RTC interrupt enable register (see Table 22 on page 45) and in the PIC (programmable interrupt controller), an interrupt to the processor will occur. The RTC seconds alarm register is reset to 0 during powerup reset, or hardware reset, but this register is not affected by the other reset sources. Table 18 shows the format of the RTC seconds alarm register. Table 18. RTC Seconds Alarm Register Address 0xE000 C004 31:29 RSVD Bit # Name Bit # 31:29 28:0 28:0 SA Name RSVD Reserved. SA Represents time in clock ticks. Description 4.2.15 RTC Seconds Count Register The RTC seconds count register shows the current time in seconds. If UCP is 1 when read, an update occurred and the value is invalid and should be read again. Updates occur once per second. Table 19 shows the format of the RTC seconds count register. Table 19. RTC Seconds Count Register Bit # Name 31 UCP Address 0xE000 C008 30:29 RSVD Bit # 31 Name UCP Update cycle occurred. 30:29 28:0 If 1, an update cycle occurred during a read access. If 0, the value returned was stable. RSVD Reserved. SC Represents time in clock ticks. 28:0 SC Description 4.2.16 RTC Divider Register The RTC divider register contains a count of the clocks that have occurred since the last time the RTC seconds count register (Table 19) was updated. This register is incremented once per input clock cycle. This register is written only during testing, when IE of the RTC control register (see Table 17 on page 43) is set to 0. Otherwise, an interrupt illegal write error is generated. Table 20 shows the format of the RTC divider register. 44 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 4 Reset/Clock Management (continued) Table 20. RTC Divider Register Address 0xE000 C00C 31:15 RSVD Bit # Name Bit # 31:15 14:0 Name RSVD CCC 14:0 CCC Description Reserved. Clock counter. 4.2.17 RTC Interrupt Status Register This register displays the current status of the IWI and AI interrupts. Table 21 shows the format of the RTC interrupt status register. Table 21. RTC Interrupt Status Register 31:2 RSVD Bit # Name Bit # 31:2 1 Name RSVD IWI 0 AI Address 0xE000 C010 1 IWI 0 AI Description Reserved. Illegal write interrupt. Set whenever software attempts to write to the RTC divider register (see Table 20 on page 45) while it is enabled, or when software attempts to write to the RTC seconds count register (see Table 19 on page 44) while the divider is enabled and an update to the seconds counter is about to be made. To reset this bit write a 1 to it. Alarm interrupt. Set when seconds count = alarm register. To clear this bit write a 1 to it. 4.2.18 RTC Interrupt Enable Register This register enables the interrupts in the RTC interrupt status register. Table 22 shows the format of the RTC interrupt enable register. Table 22. RTC Interrupt Enable Register 31:2 RSVD Bit # Name Bit # 31:2 1 Name RSVD IWI ENE 0 AI ENA Address 0xE000 C014 1 IWI ENA 0 AI ENA Description Reserved. Illegal write interrupt enable. If this bit and the IWI bit is set, IRQ_RTC will be active. Default = 0 on reset. Alarm interrupt enable. If this bit is set and the AI bit is set, the real-time clock interrupt will be asserted in the interrupt request status register IRSR (see Table 26 on page 51). The appropriate bit in the interrupt request enable register IRER (see Table 27 on page 51) must also be set. Default = 0 on reset. Agere Systems Inc. 45 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 4 Reset/Clock Management (continued) 4.3 Operation on Reset Upon all resets, the reset/clock management controller performs the following: ■ The PLL is enabled with its default values. ■ All status register bits are reset to 0, except the reset status (control, clear) register (see Table 13 on page 40) that is set to the appropriate source and the exceptions specifically noted in the register descriptions. ■ The source clock is set to the external input clock. 46 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 5 Programmable Interrupt Controller (PIC) The PIC receives signals from 15 interrupt sources. The PIC groups and prioritizes these signals, and drives the two interrupt signals at the interface to the core. Features of the PIC are as follows: ■ 15 maskable interrupt inputs. ■ Two programmable priority groups (IRQ and FIQ). ■ 15 programmable priority levels. 5.1 Interrupt Controller Operation The interrupt controller receives 15 interrupt request signals, IRQ[15:1] as input. The ordering of the IRQ signals is purely arbitrary and does not imply any relative priority. The interrupt request enable register, IRER (see Table 27 on page 51) provides a central point where the interrupts are enabled or disabled for the interrupt request status path. In particular, the interrupt signals on input lines IRQ[15:1] are logically ANDed with IRER[15:1], and the results are transferred to the interrupt request status register IRSR (see Table 26 on page 51). At any time, the core can read the IRSR in order to check for pending interrupts. The interrupt priority control registers IPCR[15:1] (see Table 29 on page 52) provide a means by which the relative priority of the interrupts are assigned programmatically. Each IPCR has an index field that contains the number of the interrupt assigned to that particular priority level. The IPCRs have an implicit priority ordering, where IPCR1 has the highest priority, and IPCR15 has the lowest priority. At reset, all of the IPCRs are disabled. The IPT_ARM core interface includes two maskable interrupt request inputs, IRQ and FIQ, where an active FIQ request pre-empts an active IRQ request. Each interrupt is assigned to either the IRQ group or the FIQ group by assigning a 1 (FIQ) or a 0 (IRQ) to TYP of the corresponding interrupt priority control register (see Table 29 on page 52). Each group is handled independently. These inputs are referred to as core IRQ and core FIQ. The following shows a typical setup method for interrupts: ■ Enable the interrupt in the desired peripheral's interrupt enable register. ■ Enable the specific peripheral interrupt in the interrupt request enable register IRER (Set); see Table 27 on page 51. ■ Enable the specific interrupt priority in the interrupt priority enable register IPER (Set); see Table 33 on page 54. ■ Assign IRQs from the desired peripheral to a priority level (IS) and type (TYP) using the interrupt priority control register N (see Table 29 on page 52). ■ When active the interrupt will be displayed in the interrupt request status register. The interrupt in-service register (ISRI or ISRF) contains the encoded value of the current highest priority interrupt. ■ To get the ARM core to process the interrupt, clear the F or I bit in the ARM current program status register (CPSR). See the ARM 940T Technical Reference Manual for a register description. ■ To clear interrupts 3 through 15, remove the source of the interrupt in the peripheral registers. To clear interrupt 1 or 2, write to the C1 or C2 bit in the interrupt request source clear register IRQESCR (see Table 32 on page 54). Agere Systems Inc. 47 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 5 Programmable Interrupt Controller (PIC) (continued) CORE IRQ FIQ ISRI ISRF IRSR PRIORITY AND CONTROL LOGIC & IRER[15:1] IPCR[15:1] IPER[15:1] PERIPHERAL BUS IRQ[2:1] EDGE/LEVEL SENSE CONTROL LOGIC IRQ[15:9] PERIPHERALS IRQ[7:3] SOFT INTERRUPT IRQ[8] 5-8230(F) Figure 5. Interrupt Controller Block Diagram 5.1.1 Interrupt Registers Table 23. Interrupt Registers Interrupt Register IRSR IRER IRQSR IPCR ISRI ISRF IRQESCR IPER EICR Description Interrupt request status register (see Table 26 on page 51). Interrupt request enable register (see Table 27 on page 51). Interrupt request soft register (see Table 28 on page 52). Interrupt priority control register (see Table 29 on page 52). Interrupt in-service register for core IRQ (see Table 30 on page 53). Interrupt in-service register for core FIQ (see Table 30 on page 53). Interrupt request source clear register (see Table 32 on page 54). Interrupt priority enable register (see Table 33 on page 54). External interrupt control register (see Table 34 on page 55). For FIQ and IRQ, the interrupt control logic determines which interrupt source is to be serviced next and sets the value for that interrupt in the interrupt in-service register, ISRI or ISRF (see Table 30 on page 53). The interrupt controller issues IRQ or FIQ signals to the core. If an interrupt of higher priority is latched in the IRSR before the interrupt in-service register is read, the interrupt in-service register is updated with the value of the higher-priority interrupt. However, if the interrupt in-service register is read, the current register value is frozen until the corresponding bit in the IRSR register is reset to 0. Prior to returning from the interrupt service routine, software must clear the interrupt from the block that sources it. Interrupts (with the exception of the two external interrupts) cannot be cleared by the PIC itself. The two external interrupts could be cleared from the IRSR[1:0] by writing a 1 to the appropriate bit of the interrupt request source clear register (IRQESCR); see Table 32 on page 54. However, if the external interrupt control line is still at the interrupt generating level, the interrupt will persist in the IRSR. 48 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 5 Programmable Interrupt Controller (PIC) (continued) The interrupt service routine also checks the IRSR for other pending interrupt requests and handles these interrupts before returning. The IRQ request signals (for interrupt in-service) are shown in Table 24 below. Table 24. Interrupt Request Signals (IRQ) Interrupt Request Line IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ7 IRQ8 IRQ9 IRQ10 IRQ11 IRQ12 IRQ13 IRQ14 IRQ15 Agere Systems Inc. Interrupt Type External interrupt 1. External interrupt 2. PPIO software interrupt. DMA interrupt. Timer interrupt. DSP interrupt. Repeater interrupt. Software interrupt. UART_ACC interrupt. Ethernet MAC interrupt. IrDA_ACC interrupt. USB interrupt. SSI interrupt. KLC interrupt. Real-time clock interrupt. 49 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 5 Programmable Interrupt Controller (PIC) (continued) 5.2 Programmable Interrupt Controller Registers Table 25. Programmable Interrupt Controller Register Map Register Interrupt request status register IRSR (see Table 26 on page 51). Reserved. Interrupt request enable set register IRER (IRESR) (see Table 27 on page 51). Interrupt request enable clear register IRER (IRECR) (see Table 27 on page 51). Interrupt request soft register IRQSR (see Table 28 on page 52). Reserved. Interrupt priority control register 1 (see Table 29 on page 52). Interrupt priority control register 2. Interrupt priority control register 3. Interrupt priority control register 4. Interrupt priority control register 5. Interrupt priority control register 6. Interrupt priority control register 7. Interrupt priority control register 8. Interrupt priority control register 9. Interrupt priority control register 10. Interrupt priority control register 11. Interrupt priority control register 12. Interrupt priority control register 13. Interrupt priority control register 14. Interrupt priority control register 15. Reserved. Interrupt in-service register ISR (ISRI) (see Table 30 on page 53). Interrupt in-service register ISR (ISRF) (see Table 30 on page 53). Interrupt request source clear register IRQESCR (see Table 32 on page 54). Interrupt priority enable set registers IPER (IPESR) (see Table 33 on page 54). Interrupt priority enable clear registers IPER (IPECR) (see Table 33 on page 54). External interrupt control registers (see Table 34 on page 55). 50 Address 0xE000 1000 0xE000 1004 0xE000 1008 0xE000 100C 0xE000 1010 0xE000 1014 0xE000 1018 0xE000 101C 0xE000 1020 0xE000 1024 0xE000 1028 0xE000 102C 0xE000 1030 0xE000 1034 0xE000 1038 0xE000 103C 0xE000 1040 0xE000 1044 0xE000 1048 0xE000 104C 0xE000 1050 0xE000 1054— 0xE000 1090 0xE000 1094 0xE000 1098 0xE000 109C 0xE000 10A0 0xE000 10A4 0xE000 10A8— 0xE000 10AC Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 5 Programmable Interrupt Controller (PIC) (continued) 5.2.1 Interrupt Request Status Register IRSR The interrupt request status register IRSR indicates the status of the latched IRQ request inputs. The IRSR bits are enabled by the bits in the interrupt request enable register, i.e., the bit will not become set unless the corresponding bit in the interrupt request enable register is also set. Table 26 shows the format of interrupt request status register IRSR. Table 26. Interrupt Request Status Register IRSR 31:16 RSVD Bit # Name Bit # 31:16 n* Address 0xE000 1000 15:1 In* 0 RSVD Name Description RSVD Reserved. In* IRQn status. Indicates that an interrupt is active from interrupt request n. If 1, there is an active interrupt from interrupt source n. If 0, there is no interrupt pending from interrupt source n. 0 IRQ1 and IRQ2 are cleared by writing a 1 to bit 1 or 2 of the IRQESCR. Bits[3:15} are cleared by clearing the interrupt in their corresponding peripheral interrupt registers. RSVD Reserved. * Replace n with any one of the following bits: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, or 15. 5.2.2 Interrupt Request Enable Registers IRER (Set, Clear) The interrupt request enable registers IRER enable or disable an interrupt request signal. Upon disabling an IRER bit, the corresponding bit in the interrupt request status register IRSR is cleared. The interrupt request enable registers IRER have a dual mechanism for setting and clearing the enable bits. Enable bits are allowed to be set or cleared independently with no knowledge of the other bits in the interrupt request enable register IRER. To set the enable bits, perform a write to the interrupt request enable set register IRESR. Each data bit that is set to 1 enables the corresponding interrupt. To clear the enable bits, perform a write to the interrupt request enable clear register IRECR. Each data bit that is set to 1 disables the corresponding interrupt. These registers are set to 0 on all reset conditions. Table 27 shows the format of interrupt request enable registers IRER. Table 27. Interrupt Request Enable Registers IRER (Set = IRESR, Clear = IRECR) 31:16 Bit # RSVD Name Bit # Name 31:16 RSVD Reserved. n* Addresses—Set 0xE000 1008, Clear 0xE000 100C 15:1 En En* 0 RSVD Description Interrupt n enable. Indicates if interrupt n is enabled or disabled. If 1, interrupt n is enabled. If 0, interrupt n is disabled. 0 RSVD Reserved. * Replace n with any one of the following bits: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, or 15. Agere Systems Inc. 51 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 5 Programmable Interrupt Controller (PIC) (continued) 5.2.3 Interrupt Request Soft Register IRQSR The interrupt request soft register IRQSR is used for programmed interrupt. A write to bit 0 (SOFT INTERRUPT) of this register sets or clears the programmed interrupt. Table 28 shows the format of interrupt request soft registers IRQSR. Table 28. Interrupt Request Soft Register IRQSR Address 0xE000 1010 31:1 RSVD Bit # Name Bit # 31:1 0 Name RSVD SOFT INTERRUPT 0 SOFT INTERRUPT Description Reserved. If 1, a soft interrupt is active. If 0, a soft interrupt is not active. 5.2.4 Interrupt Priority Control Registers IPCR[15:1] The interrupt priority control registers IPCR define the relative priority of each interrupt. The interrupt assigned to IPCR[1] has the highest priority, and the interrupt assigned to IPCR[15] has the lowest priority. Only interrupts that are assigned to IPCRs generate interrupts to the core. Table 29 shows the format of interrupt priority control registers IPCR. Address 0xE000 1018 corresponds to IPCR1. Addresses follow in order thereafter. These registers are set to 0 on reset. Table 29. Interrupt Priority Control Registers IPCR[15:1] Addresses—1 = 0xE000 1018, 15 = 0xE000 1050 31:6 5 RSVD TYP Bit # Name Bit # 31:6 5 4:0 Name RSVD TYP IS 4:0 IS Description Reserved. Interrupt type. Indicates which interrupt signal lead on the core is driven when this interrupt is active. If 1, the interrupt will be mapped to FIQ. If 0, the interrupt will be mapped to IRQ. Interrupt source. Assigns an interrupt to the interrupt priority control register. If 00000, there is no interrupt assigned to this priority level. If 00001, IRQ1 is assigned to this priority level. If 01111, IRQ15 is assigned to this priority level. 52 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 5 Programmable Interrupt Controller (PIC) (continued) 5.2.5 Interrupt In-Service Registers ISR (ISRI, ISRF) ISRI is the interrupt in-service register for IRQ type interrupts, and ISRF is the interrupt in-service register for FIQ type interrupts. The interrupt in-service registers ISR contain the encoded value of the current highest priority interrupt. Writes to the ISR are ignored. If reading the ISR, the current value is frozen until the corresponding interrupt is cleared in the IRSR (see Table 26 on page 51) if the freeze enable bit, FRZ, (bit 0 of IPER, see Table 33 on page 54) is set. Table 30 shows the format of interrupt in-service registers ISR. Table 30. Interrupt In-Service Registers ISR (ISRI, ISRF) Bit # Name 31:7 RSVD Bit # 31:7 6:0 Name RSVD IIS Addresses—ISRI 0xE000 1094, SRF 0xE000 1098 6:0 IIS Description Reserved. Interrupt source. . Table 31. Interrupt Source Encoding for Interrupt In-Service Registers Bit 6:0 0000000 0000100 0001000 0001100 0010000 0010100 0011000 0011100 0100000 0100100 0101000 0101100 0110000 0110100 0111000 0111100 Interrupt Source No Interrupt IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ7 IRQ8 IRQ9 IRQ10 IRQ11 IRQ12 IRQ13 IRQ14 IRQ15 5.2.6 Interrupt Request Source Clear Register IRQESCR The interrupt request source clear register IRQESCR clears the service interrupt pertaining to external interrupts. Write a 1 to the corresponding bit to clear the interrupt. Table 32 shows the format of interrupt request source clear register IRQESCR. Note: This register reverts back to 0 upon completion of the write. Agere Systems Inc. 53 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 5 Programmable Interrupt Controller (PIC) (continued) Table 32. Interrupt Request Source Clear Register IRQESCR 31:3 RSVD Bit # Name Bit # 31:3 2 1 0 Name RSVD C2 C1 RSVD Addresses 0xE000 109C 2 1 C2 C1 0 RSVD Description Reserved. Clear external interrupt 2. Writing a 1 to this bit clears interrupt 2. Clear external interrupt 1. Writing a 1 to this bit clears interrupt 1. Reserved. 5.2.7 Interrupt Priority Enable Registers IPER (Set, Clear) The interrupt priority enable registers IPER enable or disable an interrupt source based on its priority level, as encoded in the interrupt priority control registers (see Table 29 on page 52). This simplifies the management of nested interrupt service routines by disabling lower-priority interrupts while enabling higher-priority interrupts relative to the current interrupt. The IPER has a dual mechanism for setting and clearing the enable bits. This sets or clears enable bits independently, with no knowledge of the other bits in the IPER. To set the enable bits, a write is performed to the IPESR. Each data bit that is set to 1 enables the corresponding interrupt prioprity level. To clear the enable bits, a write is performed to the IPECR. Each data bit that is set to 1 disables the corresponding interrupt prioprity level. These registers are set to all ones on all reset conditions. Table 33 shows the format of the interrupt priority enable registers IPER. Table 33. Interrupt Priority Enable Registers IPER (Set = IPESR, Clear = IPECR) 31:16 RSVD Bit # Name Bit # 31:16 n* 0 Addresses—Set 0xE000 10A0 Clear 0xE000 10A4 15:1 En 0 FRZ Name Description RSVD Reserved. En Interrupt n enable. Indicates if interrupt at priority n is enabled or disabled. FRZ If 1, interrupt at priority n is enabled. If 0, interrupt at priority n is disabled. Freeze the IRSR (see Table 26 on page 51). If 1, reading the IRSR causes the current value to be frozen until the corresponding interrupt is cleared. If 0, the IRSR value is not frozen and can change if a higher priority IRQ occurs. * Replace n with any one of the following bits: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, or 15. 54 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 5 Programmable Interrupt Controller (PIC) (continued) 5.2.8 External Interrupt Control Registers The external interrupt control registers configure the corresponding EXINT1 and EXINT2 pins (see Figure 2 on page 27). ENA, SEN, POL, and ASY are writable and readable, however, DAT is read-only. Table 34 shows the format of the external interrupt control registers. Table 34. External Interrupt Control Registers Bit # Name Bit # 31:5 4 3 31:5 RSVD Name RSVD DAT ASY Addresses 0xE000 10A8:0xE000 10AC 4 3 2 DAT ASY POL 1 SEN 0 ENA Description Reserved. Interrupt data. A read-only copy of the data on the interrupt pin delayed by three clock cycles. Asynchronous interrupt. Determines if the pin can cause an interrupt asynchronously. This functionality is only used in the CLKOFF powerdown mode.The external interrupts are always synchronized when not in this mode. If 1, the external interrupt is asynchronous. If 0, the external interrupt is synchronous. 2 POL Reset value is 1. Interrupt polarity. Determines the polarity of the external interrupt. If 1, the external interrupt detects a low-to-high transition or high level. If 0, the external interrupt detects a high-to-low transition or low level. 1 0 SEN ENA Reset value is 0. Interrupt sense. Determines the sense of the interrupt. If 1, the external interrupt is transition-detect. If 0, the external interrupt is level-sensitive. Reset value is 0. Interrupt enable. Determines if the external interrupt is enabled and disables the programmable I/O functionality on the pin if it is MUXed. If 1, the external interrupt is enabled. If 0, the external interrupt is disabled. Reset value is 0. Agere Systems Inc. 55 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller The programmable direct memory access (DMA) controller provides four independent high-speed DMA channels. A DMA channel is used to transfer data between two memory locations more efficiently than under program control of the ARM core. Data is transferred in bytes, half-words, or words. Each DMA channel maintains a 32-bit source and destination address. Some DMA controller features are as follows: ■ Four DMA channels. ■ 32-bit source and destination address pointers. ■ Up to 64K [bytes/half-words/words] transferred at a time. ■ Interrupt generation on DMA transfer completion. ■ Four external DMA request input signals to regulate transfers. ■ Operates in three modes (explained below). ■ Circular buffer mode. ASB (SYSTEM BUS) ASB INTERFACE BRIDGE INTERFACE DMA CONTROL LOGIC TX_DRQ0 (ETHERNET) TX_DRQ1 (IRDA) TX_DRQ2 (UART) TX_DRQ3 (SSI) RX_DRQ0 (ETHERNET) TO BRIDGE RX_DRQ1 (IRDA) RX_DRQ2 (UART) RX_DRQ3 (SSI) APB INTERFACE APB (PERIPHERAL BUS) 5-9380 (F) Figure 6. DMA Controller Block Diagram 1 6.1 DMA Operation Figure 6 above and Figure 7 on page 60 illustrate the functional blocks of the DMA controller. Each DMA channel includes a 32-bit DMA source address register (see Table 37 on page 64), a 32-bit DMA destination address register (see Table 39 on page 64), a 16-bit DMA transfer count register (see Table 41 on page 65), and a DMA control register (see Table 36 on page 62). Each DMA channel operates in one of the modes listed in the next Section. 56 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.1.1 DMA Transfer Setup Procedure All DMA transfers are set up by doing the following: ■ Program the source address through the DMA source address register (see Table 37 on page 64). This is the beginning address where the DMA controller will start the transfer. ■ Program the destination address through the DMA preload destination start address register (see Table 38 on page 64). This is the beginning address where the source data will be transferred. ■ Program the transfer count through the DMA preload transfer count register (see Table 40 on page 65). ■ Program the burst size and number of hold states in the DMA burst and hold count register (see Table 42 on page 66). The DMA releases the bus to allow other masters access to it after each burst by the number of hold states programmed in the DMA burst and hold count register. ■ Program the appropriate control codes into the DMA control register (see Table 36 on page 62). This includes setting the following: — Peripheral select (PS)—selects Ethernet, IrDA, UART, or SSI for modes 1 and 2. — Circular buffer mode (CBM)—specifies buffer wrapping for mode 1. — Channel mode (CMODE)—selects memory-to-memory (mode 0), peripheral-to-memory (mode 1), or memory-to-peripheral (mode 2). — Software DMA request enable (SDRQ_E)—enables software trigger used in modes 1 and 2. — Software trigger DMA request (SDRQ)—software trigger used in modes 1 and 2. — Channel transfer size (CTS)—selects 8-bit, 16-bit, or 32-bit transfers. — Channel increment source address (CIS)—selects auto source address increment during burst read. — Channel increment destination source address (CID)—selects auto destination address increment during burst write. — Channel start (CS)—begin the transfer. Channel Priority: The DMA controller has the highest priority for accessing the system bus. When bursts are transferred, the DMA channel gets uninterrupted access to the system bus. If hold states are specified, the DMA channel deasserts its bus request signal for one or more cycles following each write access to relinquish control of the system bus to the ARM. DMA channels have a fixed priority, with channel 0 having the highest priority and channel 3 having the lowest priority. Operational Comments: To prepare for a DMA transfer, the required values are to be stored in the registers of one of the DMA channels, but with the start bit (CS) of the DMA control register (see Table 36 on page 62) set to 0. The transfer begins when the start bit is set to 1. If the transfer completes, the start bit is automatically set to 0. In memory-to-memory mode (mode 0), the core is stalled for the duration of the transfer burst. The maximum burst size is 256 words. For a DMA transfer to or from a FIFO, writing 0 to the start bit prematurely terminates the transfer. When the DMA channel is active, the address and count registers are read but not written. The source and destination addresses satisfy alignment restrictions. If a word is being transferred, address bits 1:0 of the address are 0; if a half-word is transferred, address bit 0 is zero. Failure to follow alignment restrictions causes the transfer to be terminated and an exception fault recorded in the DMA status register (see Table 43 on page 66). The DMA controller transfers up to 64 k-1 [bytes/half-words/words] at a time. Byte transfer to or from internal RAM is available to support data transfer to or from peripheral modules. Mixed size transfers are not supported. Agere Systems Inc. 57 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.1.2 DMA Mode 0. Memory-to-Memory in Blocks of Burst Count Size DMA mode 0 (memory-to-memory) is selected by setting CMODE[2:0] of the DMA control register (see Table 36 on page 62) to 000. Memory-to-memory transfers are set up as specified in 6.1.1 DMA Transfer Setup Procedure. Note: When SDRAM is one of the memory sources, the DMA transfer may be less efficient than ARM controlled transfers utilizing cache because only one word is transferred at a time. ■ When the start bit (CS) in the DMA control register (see Table 36 on page 62) is set to 1, the DMA transfer will start immediately in memory-to-memory mode as soon as the DMA ready signal is asserted. ■ The DMA will start to read, beginning at the address programmed in the DMA source address register (see Table 37 on page 64). Transfers will be made to the address in the DMA destination address register (see Table 39 on page 64), which is preset by writing to the DMA preload destination start address register (see Table 38 on page 64). ■ The number of items to be transferred is specified in the DMA preload transfer count register (see Table 40 on page 65). ■ The DMA releases the bus to allow other masters access to it after each programmed burst by the number of hold states (also programmed). Burst count (BCNT[7:0]) and hold count (HCNT[7:0]) are programmed in the DMA burst and hold count register (see Table 42 on page 66). Please note when using DMA to SSI, BCNT[7:0] must be set to 0. ■ Reads and writes in mode 0 (memory-to-memory) are performed with a data size programmed in the transfer word size bits (CTS) in the DMA control register (see Table 36 on page 62). Available sizes are 8 bits, 16 bits, or 32 bits. Note: Care should be taken when setting up memory-to-memory (mode 0) transfers to allow for other, needed bus traffic. 6.1.3 Mode 1. Peripheral-to-Memory in Blocks of Burst Count Size DMA mode 1 (peripheral-to-memory) is selected by setting CMODE[2:0] of the DMA control register (see Table 36 on page 62) to 001. Peripheral-to-memory transfers are set up as specified in 6.1.1 DMA Transfer Setup Procedure. ■ In general, all transfers to/from peripherals should be 32-bit transfers. Valid data should be written into or read from memory from the lower 8 bits, 16 bits or all 32 bits as controlled by the peripheral’s register or buffer size. The supported peripherals for DMA are Ethernet, SSI, IrDA, and UART. The ARM 2DSP and DSP2ARM buffers may also be treated as peripherals while using the software triggered DMA mode (see Section 6.1.4.1 on page 60). ■ When the start bit (CS) in the DMA control register (see Table 36 on page 62) is set to 1, the DMA transfer will start immediately in peripheral-to-memory mode (mode 1) as soon as the DMA ready signal is asserted. In the mixed memory peripheral modes (modes 1 and 2), a software trigger (SDRQ) can be used to force the DMA to see DMA ready. Circular Buffer Mode (CBM): Two transfer options are available in mode 1 and they are as follows: ■ The DMA will transfer until the transfer count, programmed through the DMA preload transfer count register (see Table 40 on page 65), is reached. 58 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) ■ Or, the DMA will transfer indefinitely in circular buffer mode until software resets the DMA start bit (CS) in the DMA control register (see Table 36 on page 62). In circular buffer mode, the transfer will continue as data becomes available from the peripheral as indicated by the DMA ready signal from the peripheral. Circular buffer mode is selected by setting the CBM bit in the DMA control register (see Table 36 on page 62) to 1. CBM Operation: ■ The buffer size is set by writing to the DMA preload transfer count register (see Table 40 on page 65). ■ The DMA will then transfer data to the memory as data becomes available from the peripheral until the transfer count TCNT (see Table 41 on page 65) is reached. ■ The DMA destination address register (see Table 39 on page 64) and the DMA transfer count register (see Table 41 on page 65) will then be rewritten with the preset values stored in their respective preload registers. ■ The circular buffer reload counter (PCNTx) in the DMA status register (see Table 43 on page 66) will be incremented whenever the transfer loops back to the preset values. ■ This DMA is gated by the DMA ready signal from the peripheral selected for the transfer. If the DMA ready signal is deasserted before the number of words programmed into the DMA burst and hold count register (see Table 42 on page 66), the burst will halt and the DMA will relinquish the bus for the programmed number of hold states before it will monitor the DMA ready signal again. When the DMA ready signal is reasserted the DMA will request the bus, and will transfer up to burst count again when it receives its bus grant. There is a software controlled DMA mode that does not use the DMA ready signal from the peripheral. This mode is selected by setting the software trigger enable bit (SDRQ_E) in the DMA control register (see Table 36 on page 62). When the user is sure the number of words set up to be transferred is available in the peripheral's buffer, the DMA is triggered by setting the software trigger DMA request bit (SDRQ) in the DMA control register (see Table 36 on page 62).The DMA ready signal is not monitored in this mode. If the DMA attempts to transfer more data than can be buffered in the peripheral, data will be lost and questionable results will occur. Notes: Data transfers to memory from the DSP2ARM/ARM2DSP buffer in the DCC block are much more efficient in this mode, using the peripheral bus address of the DSP2ARM/ARM2DSP buffer, as opposed to using the memory-to-memory mode (mode 0) and the system bus address of the DSP2ARM/ARM2DSP buffer. The memory write and buffer read can occur at the same time since they are on different busses in the IPT_ARM, instead of the sequential read-then-write, that occur in the memory-to-memory mode. 6.1.4 Mode 2. Memory-to-Peripheral in Blocks of Burst Count Size DMA mode 2 (memory-to-peripheral) is selected by setting CMODE[2:0] of the DMA control register (see Table 36 on page 62) to 010. Memory-to-peripheral transfers are set up as specified in 6.1.1 DMA Transfer Setup Procedure. ■ In general, all transfers to/from peripherals should be 32-bit transfers and valid data should be written into or read from memory from the lower 8 bits, 16 bits or all 32 bits as controlled by the peripheral’s register or buffer size. The supported peripherals for DMA are Ethernet, SSI, IrDA, and UART. The ARM 2DSP and DSP2ARM buffers may also be treated as peripherals while using the software triggered DMA mode (see Section 6.1.4.1 on page 60). ■ When the start bit (CS) in the DMA control register (see Table 36 on page 62) is set to 1, the DMA transfer will start immediately in memory-to-peripheral mode (mode 2) as soon as the DMA ready signal is asserted. In the mixed memory peripheral modes (modes 1 and 2), a software trigger (SDRQ) can be used to force the DMA to see DMA ready. The DCC block does not supply a DMA ready signal to trigger the DMA transfers so the software-triggered DMA mode must always be used for these transfers. Agere Systems Inc. 59 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) There is a single transfer option available in mode 2 as follows: ■ The DMA will transfer until the transfer count, programmed through the DMA preload transfer count register (see Table 40 on page 65), is reached. ■ Mode 2 does not support circular buffer mode. 6.1.4.1 Software-Triggered DMA Mode There is a software triggered DMA mode that does not use the DMA ready signal from the peripheral. This mode is selected by setting the software trigger enable bit (SDRQ_E) in the DMA control register (see Table 36 on page 62). When the user is sure the number of words set up to be transferred is available in the peripheral's buffer, the DMA is triggered by setting the software trigger DMA request bit (SDRQ) in the DMA control register. The DMA ready signal is not monitored in this mode. If the DMA attempts to transfer more data then can be buffered in the peripheral, data will be lost and questionable results will occur. Notes: Data transfers to memory from the DSP2ARM/ARM 2DSP buffer in the DCC block are much more efficient in this mode, using the peripheral bus address of the DSP2ARM/ARM 2DSP buffer, as opposed to using the memory-to-memory mode (mode 0) and the system bus address of the DSP2ARM/ARM 2DSP buffer. The memory write and buffer read can occur at the same time since they are on different busses in the IPT_ARM, instead of the sequential read-then-write, that occur in the memory-to-memory mode. INTERRUPT CONTROLLER CONTROL REGISTERS[5:0] IRQ[10:8] CONTROL LOGIC WORD COUNT REGISTERS[3:0] DRC[3:0] SSI INTERFACE ACC INTERFACE DESTINATION ADDRESS REGISTERS[3:0] ADDRESS GENERATOR AMBA SYSTEM BUS INTERFACE SOURCE ADDRESS REGISTERS[3:0] PERIPHERAL BUS INTERFACE 5-8229(F) Figure 7. DMA Controller Block Diagram 2 60 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.2 DMA Registers Table 35. DMA Controller Register Map Register 0 (see Table 36 on page 62). 1. 2. 3. Address DMA control register for channel 0xE000 2000 DMA control register for channel 0xE000 2004 DMA control register for channel 0xE000 2008 DMA control register for channel 0xE000 200C Reserved. 0xE000 2010:201C DMA source address register for channel 0 (see Table 37 on page 64). 0xE000 2020 DMA source address register for channel 1. 0xE000 2024 DMA source address register for channel 2. 0xE000 2028 DMA source address register for channel 3. 0xE000 202C Reserved. 0xE000 2030:203C DMA preload destination start address register for channel 0 (see Table 38 on page 64). 0xE000 2040 DMA preload destination start address register for channel 1. 0xE000 2044 DMA preload destination start address register for channel 2. 0xE000 2048 DMA preload destination start address register for channel 3. 0xE000 204C Reserved. 0xE000 2050:205C DMA destination address register for channel 0 (see Table 39 on page 64). 0xE000 2060 DMA destination address register for channel 1. 0xE000 2064 DMA destination address register for channel 2. 0xE000 2068 DMA destination address register for channel 3. 0xE000 206C Reserved. 0xE000 2070:207C DMA preload transfer count register for channel 0 (see Table 40 on page 65). 0xE000 2080 DMA preload transfer count register for channel 1. 0xE000 2084 DMA preload transfer count register for channel 2. 0xE000 2088 DMA preload transfer count register for channel 3. 0xE000 208C Reserved. 0xE000 2090:209C DMA transfer count register for channel 0 (see Table 41 on page 65). 0xE000 20A0 DMA transfer count register for channel 1. 0xE000 20A4 DMA transfer count register for channel 2. 0xE000 20A8 DMA transfer count register for channel 3. 0xE000 20AC Reserved. 0xE000 20B0:20BC DMA burst and hold count register for channel 0 (see Table 42 on page 66). 0xE000 20C0 DMA burst and hold count register for channel 1. 0xE000 20C4 DMA burst and hold count register for channel 2. 0xE000 20C8 DMA burst and hold count register for channel 3. 0xE000 20CC Reserved. 0xE000 20D0:20FC DMA status register (see Table 43 on page 66). 0xE000 2100 Reserved. 0xE000 2104 DMA interrupt register (see Table 44 on page 68). 0xE000 2108 DMA interrupt enable register (see Table 45 on page 69). 0xE000 210C Agere Systems Inc. 61 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.2.1 DMA Control Registers for Channels [0:3] The DMA control registers programs different modes of DMA transfers. Table 36 shows the format of the DMA control registers. Table 36. DMA Control Registers for Channels [0:3] Bit # Name Bit # Name Bit # 31:15 14:12 Addresses, 0 (00xE000 2000), 1 (0xE000 2004), 2 (0xE000 2008), 3 (0xE000 200C) 31:15 14:12 11 10:8 7 6 RSVD PS[2:0] CBM CMODE[2:0] SDRQ_E SDRQ 5:4 3 2 1 0 — CTS[1:0] RSVD CIS CID CS — Name RSVD PS[2:0] Description Reserved. DMA peripheral select. DMA peripheral select bit encoding. 000 001 010 011 100:111 Ethernet IRDA UART SSI* Reserved These hardware ready selects are only valid when SDRQ_E = 0. Reset value = 000. 11 CBM * Must have FAST_CLEAR set for DMA from SSI. Burst count should be set to 1 (programmed as 0) for DMA to SSI. Circular buffer mode. Used only for peripheral-to-memory transfer mode, (mode1). CBM is ignored in other modes. A CH_DONEx interrupt will not be generated when CBM is active. If set to 1, CBM is enabled. If set to 0, CMB is disabled. Note: CBM should not be used in conjunction with software trigger mode, since there is no mechanism to ensure an endless supply of data. For example, once a peripheral's FIFO is emptied, the data will be unknown. 10:8 Reset value = 0. CMODE[2:0] Channel mode. 000 001 010 011:111 7 6 SDRQ_E SDRQ Memory-to-memory (mode 0) Peripheral-to-memory (mode 1) Memory-to-peripheral (mode 2) Reserved Reset value = 000 Software DMA request enable. Setting this bit to 1 will select SDRQ as the DMA request signal instead of the DRQ input from the peripheral. Valid only for peripheral-to-memory (mode 1) and memory-to-peripheral modes (mode 2). Reset value = 0. Software trigger DMA request. Setting this bit to 1 will trigger the DMA transfer in peripheral-to-memory (mode 1) and memory-to-peripheral modes (mode 2), when SDRQ_E = 1. This bit is automatically cleared by hardware when the transfer is completed. Reset value = 0. 62 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) Table 36. DMA Control Registers for Channels [0:3] (continued) Bit # 5:4 Name CTS[1:0] Description Channel transfer size. 00 01 10 11 Byte Half word (16-bit) Word (32-bit) Reserved Used only in memory-to-memory mode (mode 0). Peripheral-to-memory (mode 1) and memory-to-peripheral mode (mode 2) transfers must always be 32-bit transfers. Mixed size transfers are not supported. 3 2 RSVD CIS Reset value = 00. Reserved. Channel increment source address. If 1, autoincrement source address is active. If 0, autoincrement source address is inactive. Note: The SDRAM controller autoincrements during a burst read, therefore, setting CIS = 0 has no effect in the memory-to-peripheral mode (mode 2) if the source is the SDRAM. However, the SDRAM controller will require a new source address at the start of the next burst, therefore, if the transfer is larger than the burst, the CIS bit should be set to 1. 1 CID Reset value = 0. Channel increment destination address. If 1, autoincrement destination address is active. If 0, autoincrement destination address is inactive. Note: The SDRAM controller autoincrements during a burst write, therefore, setting CID = 0 has no effect in the peripheral-to-memory mode (mode 1) if the destination is the SDRAM. However, the SDRAM controller will require a new destination address at the start of the next burst, therefore, if the transfer is larger than the burst, the CID bit should be set to 1 especially if CBM = 1. 0 CS Reset value = 0. Channel start. In memory-to-memory mode (mode 0), DMA transfer starts as soon as this bit is set to 1. For peripheral-to-memory (mode 1) and memory-to-peripheral mode (mode 2) this bit must be set to 1 after the channel configuration is complete. The transfer starts when the hardware or software DMA trigger goes high. Setting this bit to 0 in the middle of a transfer will kill the DMA transfer (i.e., the ARM breaks-in during a channel hold sequence). This bit is automatically cleared by hardware when the transfer is completed. Reset value = 0. 6.2.2 DMA Source Address Registers for Channels [0:3] The DMA source address registers are 32-bit registers that specify the starting source address. For all reset conditions, the DMA source address registers are reset to 0. The DMA source address registers are written to before starting a DMA operation and can be read at any time to determine the current address being written to by the DMA. Agere Systems Inc. 63 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) The source address increments by the transfer word size after each transfer if the increment source address bit (CIS) is set in the DMA control register (see Table 36 on page 62). Table 37 shows the format of the DMA source address registers. Table 37. DMA Source Address Registers for Channels [0:3] Bit # Name Bit # 31:0 Addresses, 0 (0xE000 2020), 1 (0xE000 2024), 2 (0xE000 2028), 3 (0xE000 202C) 31:0 SADR[31:0] Name Description SADR[31:0] Transfer source address. Written initially by software, updated by hardware to show the current source address. This register in not initialized by hardware. 6.2.3 DMA Preload Destination Start Address Registers for Channels [0:3] The DMA preload destination start address register is a 32-bit register that specifies the starting destination address. For all reset conditions, the DMA destination address register (Table 39) is set to 0. The DMA destination address register is a read-only register. It is updated with the value written in the DMA preload destination start address register whenever the DMA preload destination start register (Table 38) is written, or in circular buffer mode when the DMA transfer count register (see Table 41 on page 65) reaches 0. The DMA destination address register is incremented by the transfer word size after every transfer if the increment destination address bit (CID) is set in the DMA control register (see Table 36 on page 62). The DMA destination address register (Table 39) can be read at any time to determine the current address location being written to. Table 38 shows the format of the DMA preload destination start address register. Table 39 shows the format of the DMA destination address registers. Table 38. DMA Preload Destination Start Address Registers for DMA Channels [0:3] Bit # Name Bit # 31:0 Addresses, 0 (0xE000 2040), 1 (0xE000 2044), 2 (0xE000 2048), 3 (0xE000 204C) 31:0 PLD_DADR[31:0] Name Description PLD_DADR[31:0] Preload destination start address. A write to this register also writes through to the DMA destination address register to initializes it. The contents of this register are used to reload the DMA destination address register (DADR) on a circular buffer wrap around. This register is not initialized or updated by hardware. Table 39. DMA Destination Address Registers for DMA Channels [0:3] Bit # Name Bit # 31:0 Addresses, 0 (0xE000 2060), 1 (0xE000 2064), 2 (0xE000 2068), 3 (0xE000 206C) 31:0 DADR[31:0] Name Description DADR[31:0] Transfer destination address. Updated by hardware to show the current destination address. This register is not initialized by hardware. 64 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.2.4 DMA Preload Transfer Count Registers for Channels [0:3] The DMA transfer count register is a 16-bit register that decrements after each transfer. When the DMA transfer count register reaches 0, the DMA transfer is halted unless it is in circular buffer mode. The DMA transfer count register (Table 41) and the DMA destination address register (see Table 39 on page 64) are reset to the value in their preset registers. The DMA transfer count register is a read-only register that is preset to the number of [bytes/half-words/words] to be transferred by writing to the DMA preload transfer count register. For all reset conditions, the DMA preload transfer count register is set to 0. Table 40 shows the format of the DMA preload transfer count registers. Table 40. DMA Preload Transfer Count Registers for Channels [0:3] Bit # Name Bit # 31:16 15:0 Addresses, 0 (0xE000 2080), 1 (0xE000 2084), 2 (0xE000 2088), 3 (0xE000 208C) 31:16 15:0 RSVD PLD_TCNT[15:0] Name RSVD PLD_TCNT[15:0] Description Reserved. Preload value of the transfer count. A write to this register also writes through to the DMA transfer count register (Table 41) and initializes it. In periphery-to-memory and circular buffer mode, these bits indicate the size of the circular buffer in words. This register is not initialized or updated by hardware. 6.2.5 DMA Transfer Count Registers for Channels [0:3] Table 41. DMA Transfer Count Registers for Channels [0:3] Bit # Name Bit # 31:16 15:0 Addresses, 0 (0xE000 20A0), 1 (0xE000 20A4), 2 (0xE000 20A8), 3 (0xE000 20AC) 31:16 15:0 RSVD TCNT[15:0] Name RSVD TCNT[15:0] Description Reserved. Number of bytes/half-words/words remaining to be transferred. Updated by hardware to show the transfer count remaining. If a start is issued and TCNT = 0x0000, a transfer will not occur, however, a CH_DONEx will be generated in response to the start. 6.2.6 DMA Burst and Hold Count Registers The DMA controller always attempts to send burst count (BCNT) number of transfers and then backs off of the bus for at least hold count (HCNT) number of clock cycles to allow bus activity from other bus masters to occur. The DMA burst and hold count registers (see Table 42 on page 66) allow the programmer to specify how many transfers should be performed in a burst, and how many wait-states should be allowed between bursts. Table 42 shows the format of the DMA burst and hold count registers. Agere Systems Inc. 65 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) Table 42. DMA Burst and Hold Count Registers for Channel [0:3] Bit # Name Bit # 31:16 15:8 7:0 Addresses—0 (0xE000 20C0), 1 (0xE000 20C4), 2 (0xE000 20C8), 3 (0xE000 20CC) 31:16 15:8 7:0 RSVD HCNT[7:0] BCNT[7:0] Name Description RSVD Reserved. HCNT[7:0] Number of hold states between bursts. The minimum hold count is 1, (i.e., HCNT= 0x00 is the same as HCNT= 0x01). During this time, the active DMA channel drops its request for the ASB bus while the other masters (USB, ARM, and the other DMA channels) arbitrate for control of the ASB. Reset value = 0x00. BCNT[7:0] Burst count. Specifies the size of the bursts in which the DMA transfer will take place. BCNT[7:0] actually encodes BCNT + 1 (1 to 256). The size of the transferred items is specified by the CTS bits in the DMA control register (see Table 36 on page 62). These per-channel register bits are not initialized by hardware. Please note: for SSI, BCNT should be set to 0. 6.2.7 DMA Status Register The DMA status register contains bits to indicate write or read faults on the DMA channels as well as the circular buffer restart counters. Table 43 shows the format of the DMA status register. Table 43. DMA Status Register Bit # Name Bit # Name Bit # 31:16 15 14 13:12 31:16 RSVD 7 CRF1 Name RSVD CRF3 CWF3 15 CRF3 6 CWF1 Address 0xE000 2100 14 13:12 CWF3 PCNT3[1:0] 5:4 3 PCNT1[1:0] CRF0 11 CRF2 2 CWF0 10 CWF2 1:0 PCNT0[1:0] 9:8 PCNT2[1:0] — — Description Reserved. Read fault on channel 3. Set by hardware when a read fault occurs during a DMA transfer on channel 3. Cleared by reset or writing a 1 to this bit. Write fault on channel 3. Set by hardware when a write fault occurs during a DMA transfer on channel 3. Cleared by reset or writing a 1 to this bit. PCNT3[1:0] Circular buffer reload counter, channel 3. If channel 3 is in circular buffer mode, the hardware increments this by 1 each time the destination address is reloaded from the corresponding DMA preload destination start address register (see Table 38 on page 64). Cleared by reset or writing a 1 to both bits. 66 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) Table 43. DMA Status Register (continued) Bit # 11 Name CRF2 10 CWF2 9:8 Description Read fault on channel 2. Set by hardware when a read fault occurs during a DMA transmission on channel 2. Cleared by reset or writing a 1 to this bit. Write fault on channel 2. Set by hardware when a write fault occurs during a DMA transmission on channel 2. Cleared by writing a 1 to this bit. PCNT2[1:0] Circular buffer reload counter, channel 2. If channel 2 is in circular buffer mode, the hardware increments this by 1 each time the destination address is reloaded from the corresponding DMA preload destination start address register (see Table 38 on page 64). 7 CRF1 Cleared by reset or writing a 0x11 to these bits. Read fault on channel 1. Set by hardware when a read fault occurs during a DMA transfer on channel 1. 6 CWF1 Cleared by reset or writing a 1 to this bit. Write fault on channel 1. Set by hardware when a write fault occurs during a DMA transfer on channel 1. 5:4 Cleared by reset or writing a 1 to this bit. PCNT1[1:0] Circular buffer reload counter channel 1. If channel 1 is in circular buffer mode, the hardware increments this by 1 each time the destination address is reloaded from the corresponding DMA preload destination start address register (see Table 38 on page 64). 3 CRF0 Cleared by reset or writing a 0x11 to these bits. Read fault on channel 0. Set by hardware when a read fault occurs during a DMA transfer on channel 0. 2 CWF0 Cleared by reset or writing a 1 to this bit. Write fault on channel 0. Set by hardware when a write fault occurs during a DMA transfer on channel 0. 1:0 Cleared by reset or writing a 1 to this bit. PCNT0[1:0] Circular buffer reload counter channel 0. If channel 0 is in circular buffer mode, the hardware increments this by 1 each time the destination address is reloaded from the corresponding DMA preload destination start address register (see Table 38 on page 64). Cleared by reset or writing a 0x11 to these bits. Agere Systems Inc. 67 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 6 Programmable Direct Memory Access (DMA) Controller (continued) 6.2.8 DMA Interrupt Register The DMA interrupt register contains a 4-bit value that indicates the source of a DMA interrupt. For all reset conditions, the DMA interrupt register is set to 0. Table 44 shows the format of the DMA interrupt register. Table 44. DMA Interrupt Register Bit # Name Bit # Name 31:8 RSVD 3 CH_ERR1 Bit # 31:8 7 Name RSVD CH_ERR3 6 5 4 3 2 1 0 7 CH_ERR3 2 CH_DONE1 Address 0xE000 2108 6 CH_DONE3 1 CH_ERR0 5 CH_ERR2 0 CH_DONE0 4 CH_DONE2 — — Description Reserved. DMA channel 3 error interrupt. Set to 1 by hardware on a read or write fault. Cleared by reset or writing 1 to this bit. CH_DONE3 DMA channel 3 transfer interrupt complete. Set to 1 by hardware on transfer complete. CH_ERR2 Cleared by reset or writing 1 to this bit. DMA channel 2 error interrupt. Set to 1 by hardware on a read or write fault. Cleared by reset or writing 1 to this bit. CH_DONE2 DMA channel 2 transfer interrupt complete. Set to 1 by hardware on transfer complete. CH_ERR1 Cleared by reset or writing 1 to this bit. DMA channel 1 error interrupt. Set to 1 by hardware on a read or write fault. Cleared by reset or writing 1 to this bit. CH_DONE1 DMA channel 1 transfer interrupt complete. Set to 1 by hardware on transfer complete. CH_ERR0 Cleared by reset or writing 1 to this bit. DMA channel 0 error interrupt. Set to 1 by hardware on a read or write fault. Cleared by reset or writing 1 to this bit. CH_DONE0 DMA channel 0 transfer interrupt complete. Set to 1 by hardware on transfer complete. Cleared by reset or writing 1 to this bit. 6.2.9 DMA Interrupt Enable Register The DMA interrupt enable register contains an 8-bit value that enables the DMA interrupts from each channel. For all reset conditions, the DMA interrupt enable register is set to 0. Table 45 shows the format of the DMA interrupt enable register. 68 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 6 Programmable Direct Memory Access (DMA) Controller (continued) Table 45. DMA Interrupt Enable Register Bit # Name Bit # Name Bit # 31:8 7 31:8 RSVD 3 CH_ERR1_E Name RSVD CH_ERR3_E Address 0xE000 210C 7 6 CH_ERR3_E CH_DONE3_E 2 1 CH_DONE1_E CH_ERR0_E 5 CH_ERR2_E 0 CH_DONE0_E 4 CH_DONE2_E — — Description Reserved. Enable DMA channel 3 interrupt. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 6 CH_DONE3_E Reset value = 0. Enable DMA channel 3 transfer complete. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 5 CH_ERR2_E Reset value = 0. Enable DMA channel 2 interrupt. If set to 1, interrupts are enabled. If set to 0 interrupts are disabled. 4 CH_DONE2_E Reset value = 0. Enable DMA channel 2 transfer complete. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 3 CH_ERR1_E Reset value = 0. Enable DMA channel 1 interrupt. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 2 CH_DONE1_E Reset value = 0. Enable DMA channel 1 transfer complete. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 1 CH_ERR0_E Reset value = 0. Enable DMA channel 0 interrupt. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. 0 CH_DONE0_E Reset value = 0. Enable DMA channel 0 transfer complete. If set to 1, interrupts are enabled. If set to 0, interrupts are disabled. Reset value = 0. Agere Systems Inc. 69 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 7 Programmable Timers The programmable timers module supports two timer functions: interval timer (IT) and watchdog timer (WT). Features of the timer module are as follows: ■ Watchdog alarm interrupt ■ Watchdog alarm reset ■ Four interval timers ■ Generation of a shared interrupt request from the four interval timer channels 7.1 Timers Operation All of the counters in the programmable timer module operate synchronously with the system clock. The count rates are controlled by a clock prescaler that generates count enable signals at intervals of 2n of the system clock rate. The interval timer and the watchdog timer functions independently select a count rate. Figure 8 shows the programmable timer architecture. PERIPHERAL CLOCK PERIPHERAL BUS WATCHDOG TIMER FUNCTION 32 kHz CLOCK WATCHDOG TIMER RESET INTERVAL TIMER FUNCTION CONTROL/ STATUS/ MASK PERIPHERAL CLOCK WIC INTERRUPT REQUEST 5-8227(F) Figure 8. Programmable Timer Architecture Block Diagram 7.2 Interval Timer (IT) The interval timer function supports four independent timers running off a common prescaler. Each timer consists of a 16-bit, free-running counter, which increments at the selected count rate, and an IT maximum count register (see Table 53 on page 77) that determines the interval. The following text describes the general usage of the interval timers: ■ Set the count rate register (see Table 47 on page 74) to divide the system clock for the interval timers. The count rate is selected by programming the interval timer count rate field (ITR) with an index between 0 and 11. ■ Set the IT maximum count register (see Table 53 on page 77) to set the timer interval. The IT count register (see Table 53 on page 77) is loaded with the IT maximum count register value. ■ Enable timer by setting the ITEx bit in the timer control register (see Table 52 on page 76). When the timer is enabled, the IT count rate register begins decrementing. 70 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 7 Programmable Timers (continued) ■ The IT count register will count down to 0. When it reaches 0, the timer status register (see Table 50 on page 75) bit IxS (I3S:I0S) will be set and the IT count register is reloaded with the value in the IT maximum count register. ■ If IxM (I3M:I0M) in the timer interrupt mask register (see Table 51 on page 76) is set to 1, the timer IRQ in the interrupt request status register (see Table 26 on page 51) will be asserted (assuming it has been enabled in the interrupt request enable register (see Table 27 on page 51). ■ Write 1 to the IxS bit in the timer status register (see Table 50 on page 75) to clear the interval timer status bit. PERIPHERAL BUS The interval timer function is illustrated in Figure 9 below. Only one of the four channels is shown. The IT count registers are free-running counters that maintain the time-base of the interval measurements. IT MAXIMUM COUNT REGISTER n IT COUNT REGISTER n =0 CHANNEL n INTERVAL TIMER COUNT RATE INTERVAL TIMER CHANNEL n ENABLE TO STATUS REGISTERS IRQ INTERNAL TIMER CHANNEL n MASK 5-8228(F)a Figure 9. Interval Timer Block Diagram Comments: ■ The IT maximum count register (see Table 53 on page 77) may be read at any time. ■ Writing the IT maximum count register will cause the IT count register to reset to 0. ■ The period of the interval timers is determined by the count rate value and the value of COUNTVALUE in the IT maximum count register. The status bit will be set every COUNTVALUE + 1 counts of the IT count register. 7.3 Watchdog Timer The watchdog timer function asserts a time-out signal if the system software fails to restart the count sequence within a specified time interval. The watchdog timer block contains a 16-bit binary counter that increments at the selected count rate. The counter is reset to the all-zeros value by writing a value of 0xFADE to the WT count register address (see Table 49 on page 75). If the counter increments to the all-ones value, the watchdog timer time-out signal is asserted. The timeout signal can be configured to generate a watchdog reset or to generate an interrupt. The count rate register for the watchdog timer is configured to divide the 32 kHz RTC crystal or the system clock. Agere Systems Inc. 71 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 7 Programmable Timers (continued) The following text describes the general usage of the watchdog timer: ■ Set the count rate register (see Table 47 on page 74) to divide the clock input for the watchdog timer. The count rate is selected by programming the watchdog timer count rate field (WTR) with an index of between 0 and 11. ■ Set the watchdog timer to run off of the system clock or the RTC crystal by setting the WIC bit in the timer control register (see Table 52 on page 76). This must be done before WTE is set. ■ Set the watchdog timer WTI bit in the timer control register to generate an interrupt or a reset when the timer expires. ■ Set the watchdog timer WTR bit in the timer control register for the desired reset mode. ■ Enable the timer by setting the WTE bit in the timer control register. ■ When the timer is enabled, the WT count register (see Table 49 on page 75) begins counting upwards. Writing 0xFADE to the WT count register will reset the timer and the count will start counting from 0 again. ■ When the WT count register value reaches 0xFFFF, the timer status register bit WTS (see Table 50 on page 75) bit will be set. ■ If WTM is set to 1 in the timer interrupt mask register, the timer IRQ in the interrupt request status register (see Table 26 on page 51) will be asserted (assuming it has been enabled in the interrupt request enable register (see Table 27 on page 51). ■ Write a 1 to the WTS bit of the timer status register (see Table 50 on page 75) to clear the watchdog timer interrupt. The watchdog timer function is illustrated below. WATCHDOG TIMER COUNT RATE WT COUNT REGISTER PERIPHERAL BUS WATCHDOG TIMER ENABLE RESET ? VALUE 0XFADE ? WATCHDOG TIMER TIMEOUT ALL 1s 5-8226(F) Figure 10. Watchdog Timer Block Diagram Comments ■ The WT count register (see Table 49 on page 75) can be read at any time, but cannot be written after the watchdog timer has been enabled. ■ A write access to the WT count register (see Table 49 on page 75) address with a data value 0xFADE causes the WT count register (see Table 49 on page 75) to be set to the all-zeros value. Writing 0xFADE to the WT count register will also clear the WT status bit. ■ If the watchdog timer enable bit WTE (see Table 52 on page 76) is set to 1 and the WT count register increments to the all-ones value, the watchdog timer time-out signal is asserted. The effect of the watchdog time-out is determined by the value of the watchdog timer interrupt bit WTI in the timer control register (see Table 52 on page 76). If WTI is 1, a watchdog time-out will cause an interrupt. If another time-out occurs before the interrupt is cleared in the timer status register, a watchdog reset will occur. If WTI is 0, a time-out will always cause a watchdog reset. 72 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 7 Programmable Timers (continued) ■ Once the watchdog timer function is enabled in the timer control register, it cannot be disabled and the watchdog timer count rate field (WTR) of the count rate register cannot be modified. ■ The WR bit in the reset status (control/clear) register (see Table 13 on page 40) of the reset and power management function is set after the microcontroller restarts, if a watchdog timer reset occurred. ■ WTR of the timer control register (see Table 52 on page 76) is used to determine the effect of reset on the watchdog timer registers. If WTR is 1, the watchdog timer resets on powerup reset or watchdog reset but is not affected by the external reset pin. If WTR is 0, the watchdog timer resets for all three reasons. ■ WIC of the timer control register selects the clock source for the watchdog timer. If 1, the clock source is the 32 kHz clock. If 0, the clock source is the system clock. Note: The watchdog timer functionality should be completely set up before switching to the 32 kHz clock. 7.4 Timer Registers The timer function (interval and watchdog) consists of the registers shown below. All timers depend on the control, status, mask, and count rate registers. . Table 46. Timer Controller Register Map Register Reserved. Count rate register (see Table 47 on page 74). WT count register (16-bit counter) (see Table 49 on page 75). Reserved. Timer status register (see Table 50 on page 75). Timer interrupt mask register (see Table 51 on page 76). Timer control register (see Table 52 on page 76). IT maximum count register 0 (16-bit counter). IT count register 0 (16-bit counter). IT maximum count register 1 (16-bit counter). IT count register 1 (16-bit counter). IT maximum count register 2 (16-bit counter). IT count register 2 (16-bit counter). IT maximum count register 3 (16-bit counter). IT count register 3 (16-bit counter). Reserved. Agere Systems Inc. Address 0xE000 5000—0xE000 5014 0xE000 5018 0xE000 501C 0xE000 5020 0xE000 5024 0xE000 5028 0xE000 502C 0xE000 5030 0xE000 5034 0xE000 5038 0xE000 503C 0xE000 5040 0xE000 5044 0xE000 5048 0xE000 504C 0xE000 5050—0xE000 507F 73 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 7 Programmable Timers (continued) 7.4.1 Count Rate Register The ITR and WTR bits in the count rate register are used to scale the input clock for the interval timers and the watchdog timer. Table 47 shows the format of the count rate register. Use Table 48 below to encode the count rate. Table 47. Count Rate Register Bit # Name Bit # 31:12 11:8 7:4 3:0 31:12 RSVD Address 0xE000 5018 11:8 ITR 7:4 WTR 3:0 RSVD Name Description RSVD Reserved. ITR Interval timer count rate; see Table 48 below. WTR Watchdog timer count rate; see Table 48 below. WTR cannot be modified after the watchdog timer has been enabled. RSVD Reserved. 7.4.2 Encoding of Interval Timer Count Rates (ITR) and Watchdog Timer Count Rates (WTR) These values are used to encode the count rate for the watchdog and interval timers. Table 48. Encoding of Interval Timer and Watchdog Timer Count Rates Bit Field 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100:1111 74 System Clock Divisor 2 4 8 16 32 64 128 256 512 1024 2048 4096 Reserved Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 7 Programmable Timers (continued) 7.4.3 WT Timer Count Register The WT count register holds the current watchdog timer count value. Table 49 shows the format of the WT count register. Table 49. WT Count Register Address 0xE000 501C 31:16 RSVD Bit # Name Bit # 31:16 15:0 15:0 COUNTVALUE Name Description RSVD Reserved. COUNTVALUE WT count register. This register uses a 16-bit counter format. The count rate is based on the programmed count rate value. The value is reset by writing 0xFADE to this register. 7.4.4 Timer Status Register The timer status register displays the interrupt status of both the watchdog timer and each of the 4 interval timers. Table 50 shows the format of the timer status register. Table 50. Timer Status Register Bit # Name 31:12 RSVD Bit # 31:12 11 10:4 3:0 11 WTS Address 0xE000 5024 10:4 3 RSVD I3S 2 I2S 1 I1S 0 I0S Name RSVD WTS Reserved. Watchdog timer interrupt status. Description RSVD I3S:I0S If 1, the watchdog timer interrupt mode is enabled (WTI in the timer control register) and the time-out signal is asserted. Write a 1 to this bit to clear it. Reserved. Interval timer channel status. If 1, the IT count register for the channel has reached 0. Writing a 1 to each of these bits clears the bit. 7.4.5 Timer Interrupt Mask Register The timer interrupt mask register enables and disables the status bits in the timer status register (Table 50) from asserting the timer IRQ in the interrupt request status register, assuming it has been enabled in the interrupt request enable register. If IxM or WTM is set to 1, the IxS or WTS bit in the timer status register (Table 50) will cause the shared IRQ (timer interrupt) in the interrupt request status register (see Table 26 on page 51) to be asserted. Table 51 shows the format of the timer interrupt mask register. Agere Systems Inc. 75 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 7 Programmable Timers (continued) Table 51. Timer Interrupt Mask Register Bit # Name Bit # 31:12 11 10:4 3:0 31:12 RSVD Name RSVD WTM Address 0xE000 5028 10:4 3 RSVD I3M 11 WTM 2 I2M 1 I1M 0 I0M Description Reserved. Watchdog timer interrupt enable. If 1, the watchdog timer interrupt is enabled. If 0, the watchdog timer interrupt is disabled. RSVD Reserved. I3M:I0M Interval timer channel interrupt enable. If 1, the interrupt is enabled for the interval timer channel. If 0, the interrupt is disabled for the interval timer channel. 7.4.6 Timer Control Register The timer control register affects the functionality of both the watchdog timer (WT) and the interval timers (IT). Table 52 shows the format of the timer control register. Table 52. Timer Control Register Bit # Name Bit # Name Bit # 31:15 14:11 10:9 8 7:6 5 31:15 RSVD 8 WTI Name RSVD ITE3:ITE0 14 ITE3 7:6 RSVD Address 0xE000 502C 13 12 ITE2 ITE1 5 4 WIC WTR 11 ITE0 3 WRE 10:9 RSVD 2:0 RSVD Description Reserved. Interval timer channel enable. RSVD WTI If 1, the channel is enabled. If 0, the channel is disabled. Reserved. Must be written with 0s. Watchdog timer interrupt mode. RSVD WIC If 1, the watchdog timer generates an interrupt. If 0, the watchdog timer generates a reset. Reserved. Must be written with 0s. Watchdog timer clock. If 1, the timer runs off of the 32 KHz clock. If 0, the timer runs off of the system clock. This bit is reset to 1 on powerup reset but is not affected by other resets. This bit can’t be changed once WTE is set. 76 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 7 Programmable Timers (continued) Table 52. Timer Control Register (continued) Bit # 4 Name WTR Description Watchdog timer reset mode. If 1, the timer resets only on powerup or watchdog reset. If 0, the timer resets on all sources of reset. This bit resets to 0 on powerup but is not affected by other types of reset. 3 2:0 WTE This bit can't be changed once WTE is set. Watchdog timer enable. Once enabled, the watchdog timer cannot be disabled. RSVD If 1, the timer is enabled to count and the system should write the value (0xFADE) to the WT count register (see Table 49 on page 75) periodically to reset its value to 0 and prevent the watchdog timer from reaching its maximum count value. If 0, the timer is not enabled. Reserved. Must be written with zeros. 7.4.7 IT Count Registers The IT maximum count registers set the interval at which the timers will operate. The IT count registers contain the current timer count value. The count value programmed in the IT maximum count register will be loaded into the IT count register immediately after programming and again after the timer expires. The bit description in Table 53 is the same for all eight registers listed below. Table 53. IT Count Registers Address 0xE000 5030:0xE000 504C 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD COUNTVALUE Register IT maximum count register 0 IT count register 0 IT maximum count register 1 IT count register 1 IT maximum count register 2 IT count register 2 IT maximum count register 3 IT count register 3 Reserved Reserved Agere Systems Inc. 15:0 COUNTVALUE Description Reserved. Count value. Address 0xE000 5030 0xE000 5034 0xE000 5038 0xE000 503C 0xE000 5040 0xE000 5044 0xE000 5048 0xE000 504C 0xE000 5050 0xE000 5054 77 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) The IPT_ARM processor contains an external memory interface that is capable of addressing 16-bit-wide SDRAM, and up to four SRAMs, FLASH memory, or I/O peripherals. Each memory range can be programmed for the desired starting address (base address) and size (up to 64 Mbytes). 8.1 IPT_ARM Processor Memory Map Table 54. IPT_ARM Processor Memory Map Range 0x0000 0000:0xBFFF FFFF 0xC000 0000:0xCFFF FFFF 0xD000 0000:0xDFFF FFFF 0xE000 0000:0xEFFF FFFF 0xF000 0000:0xFFFF FFFF Description Distributed over external ROM (FLASH), external SDRAM, general purpose chip selects CS1, CS2, CS3, and internal 1K x 32 SRAM. Reserved (for ARM 940T processor). Reserved. Peripheral address space. Reserved. 8.2 External FLASH/SRAM Memory Interface (EMI FLASH) The external FLASH/SRAM memory interface provides the following features: ■ Multiaccess timing and buffering to assemble a full 32-bit word (two 16-bit accesses or four 8-bit accesses) during process or full-word reads. ■ Support for in-circuit reprogramming of external FLASH memory. ■ One FLASH chip select (FLASH_CS) for external program memory. ■ Three general-purpose chip selects (CS1, CS2, CS3) for external SRAM or I/O peripherals. ■ Configurable memory maps for FLASH_CS, CS1, CS2, CS3, internal SRAM and SDRAM. ■ Optional setup cycle, wait-states, and hold-states for each device. ■ External WAIT pin (EXWAIT) for slow I/O peripherals. ■ Supports 8-bit and 16-bit devices on the external bus (FLASH memory must be 16-bit). ■ Supports ROM/RAM remapping to allow the RAM to be placed at address 0x00000000. The EMI FLASH contains the logic and configuration information required to provide address and control generation for external FLASH memory and three other external memory areas. Each area is individually programmed for setup, wait, and hold state generation. 8.3 EMI FLASH Memory Access 8.3.1 External Write During the first cycle of the system clock, the A[23:0], BE1N, and WRN signals become valid. If SET (bit 7) of the corresponding chip select configuration register is 0, the appropriate chip select (FLASH_CS, CS1, CS2, CS3) also goes active during this cycle. If an additional cycle of address/control setup with respect to the chip select is desired, SET can be set to 1, and the chip select will go active during the second cycle of the system clock. The write data (D[15:0]) goes active during the second cycle. 78 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) 8.3.2 External Read During the first cycle of the system clock, the A[23:0] and BE1N signals become valid. If SET (bit 7) of the corresponding chip select configuration register is 0, the appropriate chip select (FLASH_CS, CS1, CS2, CS3) and RDN also go active during this cycle. If an additional cycle of address setup with respect to the chip select RDN is desired, the SET bit can be set to 1, and the chip select and RDN will go active during the second cycle of the system clock. 8.3.3 Wait-States During an external read or write, the number of active cycles during each access is determined by the number of wait-states (WS[3:0]) and EXWAIT pin, if it is used. A minimum of 2 wait-states must be programmed for external reads and writes to work properly. WS = 0000 or WS = 0001 are not valid values. Use of the EXWAIT pin (for slow devices) is enabled by setting the WT bit (bit 8) of the appropriate chip select configuration register. The polarity of the EXWAIT pin is programmed by the value of WP [bit 0] in the options register (see Table 65 on page 89). 8.3.4 Hold State If additional hold time is needed between the chip select going inactive and the start of the next access, one, two, or three hold states may be added by setting HS (bits 5:4) of the corresponding chip select configuration register to the appropriate value. 8.3.5 Hold Disable For multiaccess read transactions to a device that requires hold states, it is only necessary to have hold states at the end of the last access and not on each intermediate access. These intermediate hold states are suppressed by setting HD (bit 10) of the appropriate chip select configuration register. 8.3.6 Error Conditions The following errors are recorded in the status register (see Table 64 on page 88): ■ MAC register error. If an attempt is made to read/write the Ethernet MAC registers in the 0xE001 0800:0xE001 FFFF range when the PHY is not active (i.e., when the MAC is not receiving its Tx/Rx clocks), a MAC register error occurs, and is recorded in MACRE (bit 15) of the status register. ■ Alignment error. If a nonaligned word access (with address bits 1:0 being nonzero) or a nonaligned half-word access (with address bit 0 being nonzero) is attempted, an alignment error occurs and is recorded in AE (bit 13) of the status register. ■ Peripheral subword access error. If a half-word or byte access attempt is made to the peripheral address space (0xE000 0000:0xEFFF FFFF), a peripheral subword access error occurs, and is recorded in PSWE (bit 12) of the status register. ■ Peripheral code access error. If an opcode fetch is attempted from peripheral address space (0xE000 0000:0xEFFF FFFF), a peripheral code access error occurs and is recorded in the PCAE bit (bit 10) of the status register. ■ DCC read error. If the ARM processor/DMA controller attempts to read from the ARM2DSP data buffer (0xE004 0000:0xE004 07FF), a DCC read error occurs and is recorded in the DCCRE bit (bit 9) of the status register. Agere Systems Inc. 79 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) ■ DCC write error. If the ARM processor/DMA controller attempts to write to the DSP2ARM data buffer (0xE006 0000:0xE006 07FF), a DCC write error occurs and is recorded in the DCCWE bit (bit 8) of the status register. In all of the above cases, the access is aborted. If the ARM processor was making the request, it jumps to the error vector in the vector table and begins executing code from there (refer to the ARM 940T documentation for information on how the ARM 940T handles errors). If the DMA controller was making the request, a read/write fault is recorded in the DMA status register (see Table 43 on page 66). 80 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) A[23:0] A A+2 t3 t1 t4 CS t5 t2 RDN t6 t8 t7 D[15:0] D0 D1 Figure 11. EMI FLASH/SRAM Read Interface Timing Diagram Table 55. EMI FLASH/SRAM Read Access Timing Parameters Symbol t1 t2 t3 t5 Timing Parameters Address Setup Time to CS and RDN Active. CS, RDN Active Time. Address Hold After CS Inactive, RDN Inactive (except last read access in multicycle read). Address Hold After CS, RDN Inactive (last read access in multicycle read). CS, RDN Inactive Time Between Successive Accesses. t6 t7 t8 Read Data Setup Time Before CS and RDN Inactive. Read Data Hold Time After CS, RDN Inactive. Data 3-State After CS, RDN Inactive. t4 Value (ns) SET ⋅ CLK (max) WS ⋅ CLK (HS + 1) ⋅ CLK ns, if HD = 0 CLK if HD = 1 (HS + 1) ⋅ CLK (SET + HS+1) ⋅ CLK, if HD = 0 (SET + 1) ⋅ CLK, if HD = 1 .5 ⋅ CLK + 1.3 ns (minimum) 0 (minimum) 0 (minimum) Notes: CS refers to FLASH_CS/CS1/CS2/CS3. HD = hold disable (HD) bit 1 in chip select configuration register. HS = hold states (HS[1:0]) bits 5:4 in chip select configuration register, allowed values of HS = 0, 1, 2, and 3. SET = setup bit (SET) bit 7 in chip select configuration register, allowed values of SET = 0 and 1. CLK = system clock period. WS = wait-states (WS[3:0]) bits 3:0 in chip select configuration register, allowed values of WS = 2, 3, 4—15. Multiaccess read/write operations are: 32-bit reads/writes with a bus size of 16 bits/8 bits. 16-bit reads/writes with a bus size of 8 bits. Single access read/write timing looks the same as the last access in a multicycle access. All output parameters assume a 15 pF load. Agere Systems Inc. 81 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) t1 t8 A[23:0] A A+2 t4 t5 CS t3 WRN t9 BE1N t6 t2 t7 D[15:0] D0 D1 Figure 12. EMI FLASH/SRAM Write Interface Timing Diagram . Table 56. EMI FLASH/SRAM Write Access Timing Parameters Symbol t1 t2 t3 t4 t5 t6 t7 t8 t9 Timing Parameter Address, WRN, BE1N Setup Before CS Active. Address Valid to Write Data Valid. CS Active Time. Address Hold After CS Inactive (First Write in Multiple Access Write). Address Hold After CS inactive (Single-Cycle Write Operation or Last Access in a Multicycle Write). WRN, BE1N Inactive After CS Inactive. Data 3-State After CS Inactive. WRN High Between Successive Write Accesses (Multicycle Write). CS Inactive Between Successive Data Accesses. Address. Data Skew. Value (ns) SET ⋅ CLK (maximum) CLK + 1 ns (maximum) WS ⋅ CLK (HS + 1) ⋅ CLK + 1 ns (maximum) HS ⋅ CLK + 1 ns (maximum) HS ⋅ CLK + 1 ns (maximum) (HS + 2) ⋅ CLK + 2 ns (maximum) CLK (SET + HS + 1) ⋅ CLK 1.4 ns (maximum) 1.0 ns (maximum) Notes: CS refers to FLASH_CS/CS1/CS2/CS3. HD = hold disable (HD) bit 1 in chip select configuration register. HS = hold states (HS[1:0]) bits 5:4 in chip select configuration register. Allowed values of HS are 0, 1, 2, and 3. SET = setup bit (SET) bit 7 in chip select configuration register. Allowed values of SET are 0 and 1. CLK = system clock period. WS = wait-states (WS[3:0]) bits 3:0 in chip select configuration register. Allowed values of WS are 2, 3, 4, 5—15. Multiaccess read/write operations are: 32-bit reads/writes with a bus size of 16 bits/8 bits. 16-bit reads/writes with a bus size of 8 bits. Single access read/write timing looks the same as the last access in a multicycle access. All output parameters assume a 15 pF load. 82 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) 8.4 ROM/RAM Remapping An important design consideration is the layout of the memory map, and the memory present at address 0x0. Upon reset, the ARM 940T starts to fetch instructions from address 0x0. This requires ROM to be present at location 0x0 upon reset. However, this has some disadvantages. ROM is slower than RAM, and this slows down the handling of processor exceptions through the vector table. Also, if the vector table is in ROM, it cannot be modified by the code. For these reasons it is preferable to have RAM with the vector table and exception handlers at address 0x0. For this purpose, the system decoder in the IPT_ARM supports ROM/RAM remapping, using the value of the REMAP bit (bit 12) of the chip select configuration register FLASH_CS (see Table 58 on page 84). If REMAP = 0 FLASH_CS will go active at two possible base addresses, address 0x0, and the base address value programmed in the chip select base address register FLASH_CS (see Table 62 on page 87). This allows an aliased copy of ROM to be present at the chip select base address register FLASH_CS. If REMAP = 1 FLASH_CS will go active only at the base address programmed in the chip select base address register FLASH_CS register. In both cases, the address range over which FLASH_CS goes active is determined by the block size (BSZ) (bits 3:0) of the chip select base address register FLASH_CS. For an example of a remap system implementation, refer to the ARM Software Development Toolkit documentation. ROM RAM 0x0 ROM REMAP = 0 ROM ALIASED COPY OF ROM RAM 0x0 REMAP = 1 5-9387 (F) Figure 13. ROM/RAM Remapping 8.4.1 Programmable Addresses The memory addresses for each chip select are programmable by setting a base address and a block size in the corresponding chip select base address register (see Table 62 on page 87). On reset, the chip select base register FLASH_CS is reset to a 2 Mbyte block starting at address 0x0. CS1, CS2, CS3, and the internal SRAM are disabled. The address space from 0x0000 0000:0xBFFF FFFF can be allocated over ROM (FLASH), external SDRAM, general-purpose chip selects FLASH_CS, CS1, CS2, CS3, and internal 1K x 32 SRAM in any way. Each chip select is capable of addressing up to 64 Mbytes Note: FLASH_CS is active-low.. Bits 3:0 (BSZ) of the chip select base address register select the block size of the memory covered by the chip select. When the address is not in one of the ranges above, the value of the chip select base address register bits 23:4 (ADDR[19:0]) is masked by the block size and then matched against bits 31:12 of the address of each memory request. Since this is a match type operation, the base address for each chip select must be a multiple of the block size. Agere Systems Inc. 83 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) 8.5 EMI FLASH Registers The EMI FLASH has registers to configure the base address and other options for each of the chip selects FLASH_CS, CS1, CS2, and CS3, the base address for the internal SRAM, a status register that records all system bus errors, and an options register common to all chip selects (FLASH_CS, CS1, CS2, and CS3). Table 57. EMI FLASH Register Map Register Chip select configuration register FLASH_CS (see Table 58 on page 84). Chip select configuration register CS1 (see Table 59 on page 85). Chip select configuration register CS2 (see Table 59 on page 85). Chip select configuration register CS3 (see Table 59 on page 85). Reserved. Chip select base address register FLASH_CS (see Table 62 on page 87). Chip select base address register CS1 (see Table 62 on page 87). Chip select base address register CS2 (see Table 62 on page 87). Chip select base address register CS3 (see Table 62 on page 87). Chip select internal SRAM base address register (see Table 62 on page 87). Reserved. Status register (see Table 64 on page 88). Options register (see Table 65 on page 89). Address 0xE000 3000 0xE000 3004 0xE000 3008 0xE000 300C 0xE000 3010:0xE000 301C 0xE000 3020 0xE000 3024 0xE000 3028 0xE000 302C 0xE000 3030 0xE000 3034:0xE000 307C 0xE000 3040 0xE000 3044 8.5.1 Chip Select Configuration Register FLASH_CS FLASH_CS is active-low. Table 58. Chip Select Configuration Register FLASH_CS Bit # Name Bit # 31:14 13 12 31:14 RSVD Name RSVD UBE 13 UBE 12 REMAP Address 0xE000 3000 11 10 9 RSVD HD RSVD 8 WT 7 SET 6 RSVD 5:4 HS 3:0 WS Description Reserved. Use byte enables. Used for devices which are 16-bit devices and use byte enables. Byte writes to these devices are illegal if this bit is not set. If 1, byte enables are used by the device. If 0, no byte enables are used by the device. REMAP ROM/RAM remap. Remap ROM to the base address in chip select base address register (FLASH_CS). If REMAP = 1, FLASH_CS goes active only at the base address in the chip select base register FLASH_CS (see Table 62 on page 87). If REMAP = 0, FLASH_CS goes active at address 0x0 as well as at the base address in the chip select base register FLASH_CS. 11 84 RSVD Reset value = 0. Reserved. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) Table 58. Chip Select Configuration Register FLASH_CS (continued) Bit # 10 Name HD Description Hold disable. Disables the hold states between accesses in a multicycle read transaction. If 1, hold states are suppressed between the access. If 0, each access is followed by the specified number of hold states. Note: The hold states at the end of the transaction are not suppressed by this bit. 9 8 RSVD WT Reset value = 0. Reserved. Enable or disable EXWAIT pin. If 1, EXWAIT is enabled. If 0, EXWAIT is disabled. 7 SET Reset value = 0. Setup cycle. Adds an extra cycle of setup time to the address and control signals with respect to the chip select. If 1, the extra setup cycle is added. If 0, the extra setup cycles is not added. 6 5:4 3:0 RSVD HS WS Reset value = 0. Reserved. Hold states. The number of hold states inserted after each read or write access (see Table 60 on page 87). Reset value = 00. Wait-states. The number of wait-states inserted during each read or write access (see Table 61 on page 87). Reset value = 1111. 8.5.2 Chip Select Configuration Registers CS1, CS2, CS3 Table 59. Chip Select Configuration Registers CS1, CS2, CS3 Bit # Name Bit # 31:14 13 12 Addresses—CS1 (0xE000 3004), CS2 (0xE000 3008), CS3 (0xE000 300C) 31:14 13 12 11 10 9 8 7 6 RSVD UBE ENA RSVD HD RSVD WT SET BS Name RSVD UBE ENA 5:4 HS 3:0 WS Description Reserved. Use byte enables. Used for devices which are 16-bit devices and use byte enables. Byte writes to these devices are illegal if this bit is not set. If 1, byte enables are used by the device. If 0, no byte enables are used by the device. Enable chip select. If 1, the chip select is enabled. If 0, the chip select is disabled. Reset value = 0. Agere Systems Inc. 85 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) Table 59. Chip Select Configuration Registers, (CS1, CS2, CS3) (continued) Bit # 11 10 Name CSPOL CS polarity. HD Description 0 = active-low. 1 = active-high. Hold disable. Disables the hold states between accesses in a multicycle read transaction. If 1, hold states are suppressed between the access. If 0, each access is followed by the specified number of hold states. Note: The hold states at the end of the transaction are not suppressed by this bit. 9 8 RSVD WT Reset value = 0. Reserved. Enable or disable EXWAIT pin. If 1, EXWAIT is enabled. If 0, EXWAIT is disabled. 7 SET Reset value = 0. Setup cycle. Adds an extra cycle of setup time to the address and control signals with respect to the chip select. If 1, the extra setup cycle is added. If 0, the extra setup cycles is not added. 6 BS Reset value = 0. Bus size. The data bus size of the device. If 1, the device supports 16-bit transfers and all 16 bits of the data bus are connected to it. If 0, the device supports 8-bit transfers and bits 7:0 of the data bus are connected to it. 5:4 HS Reset value = 0. Hold states. The number of hold states inserted after each read or write access (see Table 60 on page 87). 3:0 WS Reset value = 00. Wait-state. The number of wait-states inserted during each read or write access (see Table 61 on page 87). Reset value = 1111. 86 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) 8.5.3 Hold and Wait-States Encoding Table 60. Hold States Encoding HS[1:0] 00 01 10 11 Number of Hold States 0 1 2 3 Table 61. Wait-States Encoding WS[3:0] 0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111 Number of Wait-States WT Bit = 0 Illegal Illegal 2 3 4 5 6 7 8 9 10 11 12 13 14 15 Number of Wait -States WT Bit = 1 Illegal Illegal 3 + EXWAIT pin 3 + EXWAIT pin 4 + EXWAIT pin 5 + EXWAIT pin 6 + EXWAIT pin 7 + EXWAIT pin 8 + EXWAIT pin 9 + EXWAIT pin 10 + EXWAIT pin 11 + EXWAIT pin 12 + EXWAIT pin 13 + EXWAIT pin 14 + EXWAIT pin 15 + EXWAIT pin 8.5.4 Chip Select Base Address Registers FLASH_CS, CS1, CS2, CS3, Internal SRAM Table 62. Chip Select Base Address Registers FLASH_CS, CS1, CS2, CS3, Internal SRAM Addresses—FLASH_CS (0xE000 3020), CS1(0xE000 3024), CS2 (0xE000 3028), CS3 (0xE000 302C), Internal SRAM (0xE000 3030) 31:24 23:4 3:0 Bit # RSVD ADDR[19:0] BSZ[3:0] Name Bit # 31:24 23:4[19:0] 3:0[3:0] Name RSVD ADDR Description Reserved. Base address. Bits 31:12 of the base address for the chip select. The 32-bit base address must be a multiple of the block size. (Bits 11:0 are always assumed to be 0.) Reset value = 0x00000. BSZ[3:0] Block size. Determines the size of the block at the given memory address for the chip select. This size, in turn, determines which bits of the base address will be compared against the address of the request. Table 63 shows the encoding of the block size field. Reset values are as follows: For FLASH_CS = 1010. For CS1, CS2, CS2, and internal SRAM = 0000. Agere Systems Inc. 87 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) 8.5.5 Block Size Field Encoding Table 63. Block Size Field Encoding Value 0000 0001 0010 0011 0100 0101 0110 0111 Block Size (Bytes) — 4K 8K 16 K 32 K 64 K 128 K 256 K Address Bits to Match Disabled 31:12 31:13 31:14 31:15 31:16 31:17 31:18 Value 1000 1001 1010 1011 1100 1101 1110 1111 Block Size (Bytes) Address Bits to Match 512 K 31:19 1M 31:20 2M 31:21 4M 31:22 8M 31:23 16 M 31:24 32 M 31:25 64 M 31:26 8.5.6 Status Register Table 64. Status Register Bit # Name Bit # 31:16 15 31:16 RSVD Name RSVD MACRE 15 MACRE 14 RSVD Address 0xE000 3040 13 12 11 AE PSWE RSVD 10 PCAE 9 8 DCCRE DCCWE 7:0 RSVD Description Reserved. MAC register error. This bit is set to 1 if an attempt is made to read/write the Ethernet MAC registers in the 0xE001 0800:0xE001 FFFF range when the PHY is not active (i.e., when the MAC is not receiving its Tx/Rx clocks). 14 13 RSVD AE Cleared by writing a 1 to this bit. Reserved. Alignment error. This bit gets set to 1 if a nonaligned word access (with address bits 1:0 being nonzero) or a nonaligned half-word access (with address bit 0 being nonzero) is attempted. 12 PSWE Cleared by writing a 1 to this bit. Peripheral subword access error. If a half-word or byte access attempt is made to the peripheral address space (0xE000 0000:0xEFFF FFFF). 11 10 RSVD PCAE Cleared by writing a 1 to this bit. Reserved. Peripheral code access error. This bit gets set to 1 if an opcode fetch is attempted from peripheral address space (0xE000 0000:0xEFFF FFFF). 9 DCCRE Cleared by writing a 1 to this bit. DCC read error. This bit gets set to 1 if the ARM processor/DMA controller attempts to read from the ARM2DSP data buffer (0xE004 0000:0xE004 07FF). Cleared by writing a 1. 88 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) Table 64. Status Register (continued) Bit # 8 7:0 Name Description DCCWE DCC write error. This bit gets set to 1 if the ARM processor/DMA controller attempts to write to the DSP2ARM data buffer (0xE006 0000:0xE006 07FF). RSVD Cleared by writing a 1. Reserved. 8.5.7 Options Register Table 65. Options Register Address 0xE000 3044 31:1 RSVD Bit # Name Bit # 31:1 0 Name RSVD WP 0 WP Description Reserved. EXWAIT polarity. If 1, EXWAIT is active-high. If 0, EXWAIT is active-low. Reset value = 0. 8.6 External SDRAM Memory Interface SDRAM register features are as follows: ■ Programmable address shifting to support a variety of SDRAM sizes. ■ Block or fast-page mode SDRAM accesses. ■ One external SDRAM memory range. 8.6.1 External SDRAM Memory Map Table 66. External SDRAM Memory Map Register SDRAM memory range base address register (see Table 67 on page 90). SDRAM control register (see Table 68 on page 90). SDRAM timing and configuration register (see Table 69 on page 90). SDRAM manual register (see Table 70 on page 91). Agere Systems Inc. Address 0xE000 B000 0xE000 B004 0xE000 B008 0xE000 B00C 89 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) 8.6.2 SDRAM Memory Range Base Address Register Table 67. SDRAM Memory Range Base Address Register 31:24 RSVD Bit # Name Bit # 31:24 23:4 Name RSVD ADDR 3:0 BSZ Address 0xE000 B000 23:4 ADDR 3:0 BSZ Description Reserved. Base address. Bits 31:12 of the base address for the chip select. The 32-bit base address must be a multiple of the block size. Block size (see Table 63 on page 88). 8.6.3 SDRAM Control Register Table 68. SDRAM Control Register 31:2 RSVD Bit # Name Bit # 31:2 1 0 Name RSVD SDRE GMA Address 0xE000 B004 1 SDRE 0 GMA Description Reserved. SDRAM enable. If 1, the SDRAM auto process is enabled. Generate manual access. When 1 and SDRE = 0, the SDRAM’s bus will be put in manual access state as defined in SDRAM manual access register for one cycle (see Table 70 on page 91). This special mode is used to do the start-up sequence for SDRAM in software. 8.6.4 SDRAM Timing and Configuration Register The external SDRAM memory interface signal should be configured in the SDRAM timing and configuration register (0xE000 B008) for proper operation as follows: ■ RAS to CAS delay—set to 1. ■ CAS to precharge—set to 3. ■ Precharge to RAS—fixed at 4. Table 69. SDRAM Timing and Configuration Register Bit # Name Bit # 31:26 25:16 15:9 8:7 6:5 90 31:26 RSVD Name RSVD RFC RSVD CRCD RSVD 25:16 RFC Address 0xE000 B008 15:9 8:7 6:5 RSVD CRCD RSVD 4:3 CCPD 2 CL 1:0 CAB Description Reserved. Refresh count. Reserved. Clocks RAS to CAS delay. 01—1, 10—2, 11—3, 00—4. Reserved. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) Table 69. SDRAM Timing and Configuration Register (continued) Bit # 4:3 Name CCPD 2 CL 1:0 CAB Description Clocks CAS to precharge delay. 11—3, 00—4. Note: Values 01 and 10 are not supported. CAS latency. 0 = 2 clocks. 1 = 3 clocks. Column address bits: 00—8 column address bits, 0—9 column address bits, 1x—reserved. 8.6.5 SDRAM Manual Access Register Table 70. SDRAM Manual Access Register Bit # Name Bit # 31:19 18 17 16 15 14:0 31:19 RSVD Name RSVD RAS CAS WE RSVD ADDR Agere Systems Inc. 18 RAS Address 0xE000 B00C 17 16 CAS WE 15 RSVD 14:0 ADDR Description Reserved. SDRAM RAS value for manual access. SDRAM CAS value for manual access. SDRAM WE value for manual access. Reserved. SDRAM address bus value for manual access. 91 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) 8.7 SDRAM Timing 0 1 2 3 4 5 6 7 8 9 10 SDRCK t3 t1 t2 t5 SDRASN t4 t9 t8 SDCASN t11 t10 SDWEN A[13:12] BA BANK SELECT BANK SELECT t6 A[10] AUTO RAx CAx RAx CAx PRECHARGE t7 A[11:0] t14 SDLDQM/ SDUDQM t13 t15 D[15:0] Ax0 Ax1 Ax2 Ax3 t12 Reference t1 t2 t3 t4 t5 t6 t7 t8 t9 t10 t11 t12 t13 t14 t15 Parameter SDRCK High Time. SDRCK Low Time. SDRCK Cycle Time. SDRASN Output Delay. SDRASN Output Hold Time. Address/Precharge Output Hold Time. Address/Precharge Maximum Output Delay Time. SDCASN Maximum Output Delay. SDCASN Output Hold Time. SDWEN Maximum Output Delay. SDWEN Output Hold Time. Minimum Data Setup Time. Minimum Data Hold Time. Data I/O Mask Output Delay. Minimum Data I/O Mask Output Hold Time. Minimum — — — — 6.98 ns 7.28 ns — — 7.14 ns — 7.11 ns 0 ns 1.90 ns — — Maximum — — — 7.25 ns — — 7.44 ns 7.27 ns — 7.31 ns — — — 7.89 ns 7.09 ns Figure 14. SDRAM Read Timing Diagram 92 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) 0 1 2 3 4 5 6 7 8 9 10 SDRCK t3 t1 t5 t2 SDRASN t4 t9 t8 SDCASN t11 t10 SDWEN A[13:12] BANK SELECT BA A[10] AUTO PRECHARGE BA CAx BA CAx BANK SELECT t6 t7 A[11:0] t14 SDLDQM/ SDUDQM t12 Reference t1 t2 t3 t4 t5 t6 t7 t8 t9 t10 t11 t12 t13 t14 t15 t13 Ax0 D[15:0] t15 Ax1 Ax2 Ax3 Parameter SDRCK High Time. SDRCK Low Time. SDRCK Cycle Times. SDRASN Output Delay. SDRASN Output Hold Time. Address/Precharge Output Hold Time. Address/Precharge Maximum Output Delay Time. SDCASN Maximum Output Delay. SDCASN Output Hold Time. SDWEN Maximum Output Delay. SDWEN Output Hold Time. Maximum Data Output Valid. Minimum Data Hold Time. Data I/O Mask Output Delay. Minimum Data I/O Mask Output Hold Time. Minimum — — — — 6.98 ns 7.28 ns — — 7.14 ns — 7.11 ns 0 ns 1.90 ns — — Maximum — — — 7.25 ns — — 7.44 ns 7.27 ns — 7.31 ns — — — 7.89 ns 7.09 ns Figure 15. SDRAM Write Timing Diagram Agere Systems Inc. 93 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 8 External Memory Interface (EMI) (continued) 8.8 Signals The EMI controls all the signals needed to access external devices. For transactions that are larger than the width of the device, the EMI creates multiple accesses to read from or write to the device. For example, a 32-bit read from an 8-bit device requires four read accesses. SDRAM, FLASH, and SRAMs share the same address and data bus. 8.8.1 Address, A[23:0] For FLASH_CS, CS1, CS2, and CS3 devices, the address bus signals A[23:0] define the address of the least significant byte transferred during a memory cycle. The address becomes valid during phase 1 of the first cycle of an access and remains valid until phase 1 of first cycle of the next access. Note: For FLASH and SRAM accesses, A[23:0] is used to access memory in units of bytes. If a 16-bit wide SRAM/ FLASH memory device is used, A[1] should be connected to the least significant address input pin of the memory device. For 8-bit wide FLASH/SRAM devices, A[0] should be connected to the least significant address input. 8.8.2 Data, D[15:0] Data bus signals D[15:0] are bidirectional signals that transfer data to and from the chip. Use of the upper 8 bits of the data bus is controlled on a per-device basis by BS (bit 6) of the chip select configuration register. Note: The program memory that is accessed by FLASH_CS always uses a 16-bit data bus. During a read access, the data on the data bus is latched at the end of phase 1 of the last active cycle of the access. For a write access, the data becomes valid during phase 1 of the second cycle of the access. If there is no valid transaction on the EMI, the data bus stays in input mode. 8.8.3 Byte Enable, BE1N BE1N is used as a byte write enable for 16-bit devices that use byte enables. This signal is active-low and goes active when an odd byte is to be written. The UBE bit (bit 13) of the chip select configuration register must be set to 1 before attempting byte writes to 16-bit devices. 8.8.4 Read/Write Signals, RDN, WRN RDN and WRN are active-low signals that indicate whether a read or a write access is taking place. During a read access, RDN goes low and WRN stays high. During a write access, RDN stays high am WRN goes low. If the EMI flash is not being accessed, RDN and WRN stay high. 8.8.5 Chip Selects, FLASH_CS, CS1, CS2, CS3 The chip select signals FLASH_CS, CS1, CS2, and CS3 indicate which of the external devices is accessed. The appropriate chip select becomes active during phase 1 of the first cycle of an access if no setup cycle is used and goes inactive after the last active cycle of the access. FLASH_CS is active-low. CS1, CS2, and CS3 have programmable polarities and are active-low at reset. 8.8.6 External WAIT, EXWAIT This signal can be driven by the external device to add additional wait-states to the memory access cycle, if required. The use of the EXWAIT signal by a particular device is enabled by setting the WT bit (bit 8) of the appropriate chip select configuration register. The polarity of EXWAIT is programmable, and is determined by the WP bit (bit 0) of the options register; see Table 65 on page 89. 94 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 8 External Memory Interface (EMI) (continued) 8.8.7 EMI SDRAM, Synchronous DRAM Memory Interface The EMI SDRAM interface can support one 16-bit wide synchronous DRAM device. SDRAM devices of other widths (8-bit/4-bit) are not supported. Device sizes up to 256 Mbits are supported. The SDRAM's chip select should be tied off to active. 8.8.8 SDRAM Address Functionality Pins A[14:0] are used to output the row/column/bank address of the SDRAM location being accessed. Pins A[23:15] are not used during an SDRAM access. The output on these pins depends upon the type of SDRAM access cycle, e.g., when used with a 64 Mbit 16-bit wide SDRAM device. Table 71. SDRAM Access Cycles, Using a 64 Mbit SDRAM SDRAM Command Cycle Row address strobe (RAS) Column address strobe (CAS) Precharge Address Pins A[13: 0] = row address, where A[13:12] = bank select. A[7:0] = column address. A[10] = precharge mode. If A[10] = 1, all banks are precharged. If A[10] = 0, only the bank selected by the bank select signals on the SDRAM are precharged. 8.8.9 SDRAM Clock, SDRCK This is the clock output that should be connected to the SDRAM. This runs at the same frequency as the IPT_ARM system clock. 8.8.10 SDRASN, SDCASN, SDWEN SDRAM row address strobe (SDRASN), column address strobe (SDCASN), and write enable (SDWEN) are standard SDRAM interface signals. The combination of these three outputs is used to indicate the type of command that is to be performed on SDRAM. 8.8.11 SDUDQM, SDLDQM SDUDQM and SDLDQM are SDRAM upper byte enable and lower data byte enable, respectively. In read mode SDUDQM/SDLDQM go low to turn on the SDRAM's output buffers. In write mode, SDUDQM/SDLDQM go low to allow the corresponding byte to be written. Note: Care should be taken to have the shortest possible routes on the board, and to avoid excessive loading (>15 pF) for all the EMI pins. Agere Systems Inc. 95 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 9 DSP Communications Controller (DCC) The DSP communications controller consists of the following elements: ■ ARM (write only) DSP (read-only) 512 x 32 bit internal SRAM for use as a communications mailbox. ■ ARM (read-only) DSP (write only) 512 x 32 bit internal SRAM for use as a communications mailbox. ■ Token register to support single owner of memory segments or message headers. ■ ARM 2DSP interrupt register. ■ DSP2ARM interrupt register. ■ Dedicated I/O pins for single wait-state DSP accesses. ■ DSP communications controller address map. ■ IPT_ARM peripheral controller circuits. DSP_A[10:0] IPT_DSP INTERFACE ARM2DSP BUFFER (512x32) APB INTERFACE DSP_D[15:0] DSP_RWN DSP2ARM BUFFER (512x32) APB (PERIPHERAL BUS) DSP_MCSN DSP_ICSN INTERRUPT AND TOKEN REGISTERS TO INTERRUPT CONTROLLER IRQ_DCC 5-9379 (F) Figure 16. DSP Communications Controller Block Diagram 9.1 ARM Processor Memory and I/O Map Table 72. ARM Processor Memory and I/O Map Register Token register (see Table 73 on page 97). Reserved. DSP2ARM interrupt register (see Table 74 on page 98). Reserved. ARM 2DSP interrupt register (see Table 75 on page 98). Reserved. ARM 2DSP data buffer; write only by ARM, read-only by DSP. Reserved. DSP2ARM data buffer; write only by DSP, read-only by ARM. 96 Address 0xE000 F000 0xE000 F004:0xE000 F01C 0xE000 F020 0xE000 F024:0xE000 F02C 0xE000 F030 0xE000 F034:0xE000 F03C 0xE004 0000:0xE004 07FF 0xE004 0800:0xE005 FFFF 0xE006 0000:0xE006 07FF Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 9 DSP Communications Controller (DCC) (continued) 9.2 DCC Token Register The DSP communications controller (DCC) provides a 16-bit token register (see Table 73 on page 97). The upper byte (DSPT) of this register is writable only through the DSP interface. The lower byte (ARMT) of this register is writable only through the ARM APB bus. The entire 16-bit token register can be read by either interface. The token register should help the programmer manage the communication buffers. A jitter buffer, for example, can be implemented by using the token bits to mark full areas and empty sections of the buffer. When an audio packet is placed in the buffer by the IPT_ARM, it could interrupt the DSP with information about the section where this packet was placed. The DSP could then use one of its token bits to mark that section as full. At the appropriate time, the DSP could then remove a packet that was placed in its buffer many milliseconds earlier and mark this other section as empty. Table 73. Token Register 31:16 RSVD Bit # Name Bit # 31:16 15:8 Name RSVD DSPT 7:0 ARMT Address 0xE000 F000 15:8 DSPT 7:0 ARMT Description Reserved. DSP writable token bits. These bits can only be written through the DSP interface but they are readable by both the DSP and the ARM. ARM writable token bit. These bits can only be written by the ARM processor but they are readable by both the DSP and the ARM. 9.3 DCC Interrupt Registers There are two DCC interrupt registers in the IPT_ARM. The DSP2ARM interrupt register (see Table 74 on page 98) is used by an external device (the IPT_DSP) to generate an interrupt to the ARM 940T processor core. The ARM 2DSP interrupt register (see Table 75 on page 98) is written by the ARM 940T processor to generate an active-low interrupt output. This interrupt output is to be connected to the IPT_DSP interrupt input (DSP_INT0). Both of these registers are similarly organized. Bit 15, the MSB, is the interrupt bit and can only be written to 1 by the interrupting processor. Bit 15 (DSP2ARM_INT) in the DSP2ARM interrupt register can only be set by the external DSP through the DCC interface. Bit 15 (ARM 2DSP_INT) in the ARM 2DSP interrupt register can only be set by the IPT_ARM processor. DSP2ARM_INT and ARM 2DSP_INT can read by both processors. When bit 15 is set to 1 by the appropriate processor, INT_CLR and INT_FLAG are automatically set to 1. These bits can only be written to 0 by the interrupted processor. When the interrupted processor writes INT_CLR to 0, bit 15 is automatically reset to 0 and clears the interrupt. In addition the interrupted processor can write INT_FLAG to 0 to indicate that it has completed the operation, or freed up the memory. Bits 12:0 (INT_MSG) of the ARM 2DSP interrupt register (see Table 75 on page 98) can only be written by the interrupting processor, which uses these bits to implement a message-passing protocol to signal the purpose of the interrupt. These bits can also be used to identify an offset and length in the interprocessor communication buffers where a message, or data, is stored. This message-interrupt scheme should help the programmers pass data and commands back and forth while preventing a processor from overwriting a set of data in the interprocessor communications buffer before the other processor has finished accessing it. Agere Systems Inc. 97 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 9 DSP Communications Controller (DCC) (continued) 9.3.1 DSP2ARM Interrupt Register Table 74. DSP2ARM Interrupt Register Bit # Name Bit # 31:16 15 14 31:16 RSVD Address 0xE000 F020 15 14 DSP2ARM_INT INT_CLR 13 INT_FLAG 12:0 INT_MSG Name Description RSVD Reserved. DSP2ARM_INT DSP to ARM interrupt. Interrupt from the DSP to the ARM. INT_CLR Interrupt clear. This will clear the interrupt signal. 13 INT_FLAG 12:0 INT_MSG This is controlled only by the ARM. Interrupt flag. Interrupt flag to signal to the DSP that an interrupt was serviced and completed. This is read-only from the DSP. Interrupt message. Interrupt message from the DSP. This is read-only from the ARM. 9.3.2 ARM 2DSP Interrupt Register Table 75. ARM 2DSP Interrupt Register Bit # Name Bit # 31:14 15 14 13 12:0 31:14 RSVD Address 0xE000 F030 15 14 ARM2DSP_INT INT_CLR 13 INT_FLAG 12:0 INT_MSG Name Description RSVD Reserved. ARM 2DSP_INT ARM to DSP interrupt. Interrupt from the ARM to the DSP. INT_CLR Interrupt clear. Interrupt clear will clear the interrupt signal. INT_FLAG INT_MSG This is controlled only by the DSP. Interrupt flag. Interrupt flag to signal to DSP that interrupt was serviced and completed. This is read-only from the ARM. Interrupt message. Interrupt message from the ARM. This is read-only from the DSP. 98 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 9 DSP Communications Controller (DCC) (continued) 9.4 DCC Controller I/O Signals The DCC controller has several I/O signals used to support interprocessor communications. Table 76. DCC Controller I/O Signals Signal DSP_A[10:0] DSP_D[15:0] DSP_RWN DSP_MCSN Description DSP address input signals[10:0]. Used to address the 1 Kword interprocessor memories, tokens, or interrupt registers. DSP data bus[15:0]. This is the interprocessor data bus. DSP read/write not strobe. DSP chip select. Used to indicate a DSP access of the buffer memories. DSP_ICSN If A[10] is low the ARM to DSP memory is accessed. If [A10] is high the DSP to ARM memory is accessed. DSP chip select. Used to indicate an access of the token or interrupt registers. DSP_INTN0 If A[3] = 0 then it is a token register access. If A[3], A[2] = 10 then it is an ARM interrupt register access. If A[3], A[2] = 11 then it is a DSP interrupt register access. DSP interrupt. Indicates an external interrupt signal to the DSP from the ARM processor. 9.5 DSP Read/Write Timing Diagrams DSP_A t3 t1 t5 DSP_MCSN/ DSP_ICSN t6 DSP_RWN t2 t4 DSP_D Symbol t1 t2 t3 t4 t5 t6 Description DSP_A setup to CSN active. CSN active to DSP_D valid. DSP_A hold after CSN inactive. DSP_D high-impedance after CSN inactive. CSN active time. CSN inactive before successive reads. Minimum 0 ns — 0 ns — 15.0 ns 10.0 ns Maximum — 14.0 ns — 9.0 ns — — Figure 17. DSP Read Interface Timing Diagram Agere Systems Inc. 99 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 9 DSP Communications Controller (DCC) (continued) DSP_A t1 t5 DSP_MCSN/ DSP_ICSN DSP_RWN t4 t2 t8 t7 t3 t6 DSP_D Symbol t1 t2 t3 t4 t5 t6 t7 t8 Description DSP_A setup to CSN active. CSN setup to RWN active. DSP_D delay from RWN active. CSN hold from RWN inactive. DSP_A hold from CSN inactive. DSP_D hold from RWN inactive. RWN active time. RWN inactive between successive writes. Minimum 0 ns 0 ns — 0 ns 0 ns — 31.25 ns* 12.5 ns Maximum — — 13.00 ns* — — — — — * This value depends on the number of wait-states programmed into T8301 (N) and the clock period of the T8301 clock (T) as follows: t3 = N x T/2 + wire delay. t7 = (2N + 1) x T/2. For N = 2 and T = 12.5 ns (f = 80 MHz), t3 = 12.5 ns, t7 = 31.25 ns, t8 = 12.5 ns. Figure 18. DSP Write Interface Timing Diagram 100 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC Please refer to Agere’s DNCM01 10/100 Ethernet MAC ASIC Macrocell Data Sheet for references. All the registers inside the MAC controller are read/write through the ARM AMBA peripheral bus interface. The IPT_ARM contains a 10/100 media access controller (MAC) and the logic to completely control packet transmission and reception with minimal setup and intervention from the ARM 940T processor. The registers and logic that control the operation of the MAC are referred to in this document as the MAC controller. The MAC provides the timing and control for transmission and reception of packet bytes on the media through the PHY interfaces. It automatically provides interframe timing, preamble, collision detect, media jam, and CRC (circular redundancy checksum) generation and detection. The MAC controller provides registers for MAC setup and control, 32 x 32 bit FIFOs for receive and transmit data buffering, logic to sequence the 32-bit words into the MAC (8 bits at a time), address matching on received packets, byte counters, and status bits. TX_CLK TX DATA TX_DMA_RDY TXD[3:0] TX FIFO TX_ERR TX_EN ADDRESS MAC CORE COL CRS RX DATA RX_CLK RXD[3:0] DATA DATA RX_DV RX FIFO RX_ERR CAM RX_DMA_RDY MDC MDIO STATUS RX CONTROL FIFO APB REGISTER INTERFACE ADDRESS DATA Figure 19. Ethernet 10/100 MAC Block Diagram Agere Systems Inc. 101 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.1 Features The Ethernet 10/100 MAC provides the following features: ■ Compliant with ISO* 8802.3 1993, IEEE † 802.3u 1995, and IEEE 802.3x 1995 standards for media access control. ■ Data transmission and reception rates of 10 Mbits/s at a clock speed of 2.5 MHz or 100 Mbits/s at a clock speed of 25 MHz. ■ Transmits or receives at full- or half-duplex. ■ Supports flow control. ■ Supports both VLAN type1 and VLAN type2 frame recognition. ■ Extensive network management signals are provided. ■ Transmit and receive functions can be asynchronously reset with no clocks present. ■ Supports full internal scan test methodology. ■ Retransmit capability on early collision detection. ■ Flexible arithmetic or logical physical address matching. ■ Queued storage of packet reception status and byte counts for relaxed real-time interrupt latency requirements. ■ 128 bytes of FIFO buffering in both the transmit and receive directions. ■ Easy setup of control or pause frame transmission for network control. 10.2 General MAC Information The IPT_ARM contains an AMBA peripheral bus interface (APB) to the status and control registers contained in the MAC controller. This interface also has a reset signal that will reset the state machines, counters, and critical logic in the MAC and its controller. The MAC contains the MAC transmit status register, the MAC collision counter, and the MAC control frame registers. The MAC transmit status register (see Table 96 on page 116) provides access to output signals that describe the results of the last transmitted or received frame. The MAC collision counter (see Table 97 on page 118) is a 16-bit counter that reports the number of collisions on a transmit attempt. Valid counts are 0 through 15. When the number of collisions is equal to the retry attempt value, RETRY[1:0], an excessive collision error occurs. The MAC collision counter is cleared before each new packet transmission.The MAC control frame registers hold the reserved multicast destination address, source address, reserved length/type field, control opcode, and data. Flow control is implemented by receiving and sending pause (control) frames. The MAC handles the transfer of data from the control registers to the transmit data bus of the MAC. * ISO is a registered trademark of the International Organization for Standardization. † IEEE is a registered trademark of the Institute of Electrical and Electronics Engineers, Inc. 102 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) 10.3 MAC Transmitter The transmit path consists of a 32x32 FIFO and transmit state machine.The programmer initiates a packet transmission by first setting up the DMA to transfer packet data from memory to the transmit FIFO, excluding the preamble, SFD, and CRC. The START bit (see Table 95 on page 116) is asserted and packet byte count is loaded into the MAC controller transmit start register (see Table 95 on page 116). It is the responsibility of the host system to keep the transmit FIFO from underrunning. In half-duplex mode, the MAC handles the collisions in accordance with IEEE 802.3u. The MAC controller preserves the first 64 bytes of data in the transmit FIFO so that, if there is a collision during the transmission of these bytes, the MAC can retransmit the frame without the host system having to reload the FIFO. If a collision occurs after 64 bytes have been transmitted, the transmission is aborted due to a late collision and an interrupt is generated if it is not masked. The CRC is automatically appended at the end of the data packet and transmitted. An interrupt will be generated at the end of a packet transmission to notify the processor about the successful or unsuccessful packet transmission. If the interrupt is masked, then the host should monitor the MAC transmit status register (see Table 96 on page 116) to determine when the transmitter is finished with the packet transmission. 10.4 MAC Receiver The programmer sets up the IPT_ARM to receive Ethernet packets by programming the MAC controller setup register (see Table 78 on page 106) and address matching registers to determine which packets to accept and to set up the circular input buffer in the IPT_ARM DMA block. If the receiver is enabled the incoming packets are accepted and stored if they match the receive criteria. The MAC can operate in a hardware flow control environment. When operating in full-duplex mode, if a pause frame is received, the MAC controller waits for the time the sender wishes the MAC not to transmit. In addition, the MAC controller also monitors the presence of VLAN type1 and type2 fields. If one of them is present, the maximum legal frame length is extended. An interrupt will be generated (if enabled) on a successful or unsuccessful packet reception and the status and byte count of the received packet will be placed in the receive control FIFO. This information can be used by the programmer to determine the amount of data written into the DMA input circular buffer and to determine the validity of this data. 10.4.1 Address Matching Registers The IPT_ARM has the capability of storing only those packets that meet predefined destination address criteria programmed in 32 pairs of address match memory locations. Address match memory location 0 (memory locations 0XE001 0B00 and 0XE001 0B04) should be programmed with the endpoint's MAC address (the low-order 32 bits of the MAC address go in 0XE001 0B00 and the high-order 16 bits go in the least significant 16 bits of 0XE001 0B04). When the MAC receiver is not in promiscuous mode (PROMM = 0), received unicast packets will only be written to the MAC receive FIFO if their destination addresses match the 48-bit value stored in address match memory location 0. Address match memory locations 1 to 31 (locations 0XE001 0B08 to 0XE001 0BFC) can be used to store up to 31 multicast addresses. These locations are paired in the same way that address match memory location 1 is; the low-order 32 bits of the multicast address go in the first memory location of the pair and the high-order 16 bits go in the least significant 16 bits of the second memory location of the pair. When the MAC receiver is not in the store-all multicast packets mode (SAMUL = 0, see Table 78 on page 106), received multicast packets will only be written to the MAC receive FIFO if their destination addresses match one of the thirty-one 48-bit values. Agere Systems Inc. 103 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.5 MAC Controller, Registers, and Counters There are several registers and counters in the MAC controller. The registers include control setup registers, control registers, and status registers. There are thirty-two 48-bit address matching registers that are used to determine whether received multicast packets are stored. Location 0 in the address match memory registers is always reserved for the MAC’s physical address. The remaining registers are used to store multicast addresses that are compared against received packet destination addresses. If there is a match, the packet is stored. If store-all multicast packets mode is selected (SAMUL set to 1 in the MAC controller setup register; see Table 78 on page 106) all multicast packets will be stored without regard to values in the address match registers. If promiscuous mode is selected (PROMM set to 1 in the MAC controller setup register), all packets are stored (no address matching is performed). The counters are used to control the MDIO interface to the PHYs, assemble and send pause control frames, and recognize VLAN packets. 10.6 Control Frame Operation The MAC supports control frame transmission and automatic pause control frame response for use in flow-control of full-duplex networks. In the transmit direction, the MAC can transmit control frames to the far end without having to go through the process of writing to the transmit FIFO. This is done by programming register addresses 0XE001 000C to 0XE001 002C with the control frame information and then setting the CNTLXMIT bit (in the MAC controller transmit control register) to initiate transmission. In the receive direction, the MAC will respond to the reception of pause commands by pausing the MAC transmitter for the requested number of bit times. To enable this automatic pause response, register addresses 0XE001 000C to 0XE001 0028 must be programmed with the proper values for a pause command. See Table 81—Table 85 for more information. 104 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) Table 77. MAC Register Map Description MAC controller setup register (see Table 78 on page 106). MAC packet delay alarm value (see Table 79 on page 108). MAC controller interrupt enable register (see Table 80 on page 108). MAC control frame destination address register (see Table 81 on page 109). MAC control frame source address registers (see Table 82 on page 109). MAC control frame length/type register (see Table 83 on page 110). MAC control frame opcode register (see Table 84 on page 110). MAC control frame data register (see Table 85 on page 111). VLAN type1 type/length field register (see Table 86 on page 111). VLAN type2 type/length field register (see Table 87 on page 111). MAC transmit FIFO register (see Table 88 on page 111). MAC receive FIFO register (see Table 89 on page 112). MAC receive control FIFO register (see Table 90 on page 112). MDIO address register (see Table 91 on page 114). MDIO data register (see Table 92 on page 114). Reserved. PHY powerdown register (see Table 93 on page 115). Reserved. MAC controller transmit control register (see Table 94 on page 115). MAC controller transmit start register (see Table 95 on page 116). MAC transmit status register (see Table 96 on page 116). MAC collision counter (see Table 97 on page 118). MAC packet delay counter (see Table 98 on page 118). MAC transmitted packet counter (see Table 99 on page 118). MAC transmitted single collision counter (see Table 100 on page 118). MAC transmitted multiple collision counter (see Table 101 on page 119). MAC excess collision counter (see Table 102 on page 119). MAC packet deferred counter (see Table 103 on page 119). Reserved. MAC controller receive control register (see Table 104 on page 119). Reserved. Address match memory location 0—low-order 32 bits (physical address). Address match memory location 0—high-order 16 bits (physical address). Address match memory locations 1 through 31 (multicast address). These locations are arranged in pairs in the same manner as address match memory location 0. The first memory location of each pair holds the loworder 32 bits of the multicast address, and the second least significant 16 bits hold the high-order 16 bits of the multicast address. MAC FIFO status register (see Table 105 on page 120). MAC controller interrupt status register (see Table 106 on page 120). Address 0xE001 0000 0xE001 0004 0xE001 0008 0xE001 000C:0xE001 0014 R/W R/W R/W R/W R/W 0xE001 0018:0xE001 0020 0xE001 0024 0xE001 0028 0xE001 002C 0xE001 0030 0xE001 0034 0xE001 0038 0xE001 003C 0xE001 0040 0xE001 0044 0xE001 0048 0xE001 004C:0xE001 01FC 0xE001 0200 0xE001 0204:0xE001 07FC 0xE001 0800 0xE001 0804 0xE001 0808 0xE001 080C 0xE001 0810 0xE001 0814 0xE001 0818 0xE001 081C 0xE001 0820 0xE001 0824 0xE001 0828:0xE001 09FC 0xE001 0A00 0xE001 0A04:0xE001 0AFC 0xE001 0B00 0xE001 0B04 0xE001 0B08:0xE001 0BFC R/W R/W R/W R/W R/W R/W W R R R/W R/W — R/W — R/W R/W R R R R/W R/W R/W R/W R/W — R/W — R/W R/W R/W 0xE001 0C00 0xE001 0C04 R RO/ ROL* * Read-only latch, ROL. A read-only latch is similar to a read-only field (RO), except that once it is set, it stays set regardless of the state of any event that set it in the first place. It can only be reset by the microprocessor writing a 1 to the bit. Note that the microprocessor writing a 0 to an ROL has no effect at all. Agere Systems Inc. 105 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7 Register Descriptions 10.7.1 MAC Controller Setup Register The MAC controller setup register is used to set up MAC control bits. The transmit and receive state machines are reset with the appropriate reset bits. The transmit and receive enable bits must be set for the MAC controller to send or receive data from the MAC and FIFOs. Table 78. MAC Controller Setup Register Bit # Name Bit # Name 15:14 SPEED_SEL 7 DEFER Bit # 15:14 Name Description SPEED_SEL MDC rate of PCLK (system clock). MDC is the management data clock for the PHYs. The MDC rate must be kept below 6.25 MHz, therefore, SPEED_SEL should be programmed accordingly. For example: if PCLK is 57 MHz, MDC = PCLK/8 = 7.125 MHz, (SPEED_SEL = 11) is an invalid setting and SPEED_SEL = 00, 01 or 10 should be used. 00 MDC = PCLK/64 01 MDC = PCLK/32 10 MDC = PCLK/16 11 MDC = PCLK/8 SBCSTP Store broadcast packets. 13 12 11 SAMUL PROMM 10 9 TMODE INVCRC 8 BSEL 13 SBCSTP 6 ISQE Address 0xE001 0000 12 11 10 SAMUL PROMM TMODE 5 4 3:2 MFDUP APDCRC RETRY[1:0] 9 INVCRC 1:0 PREAMBLE[1:0] 8 BSEL — — If 1, all broadcast packets are stored. If 0, no broadcast packets are stored. Store all multicast packets. Indicates that all multicast packets should be stored. Promiscuous mode. When 1, this indicates all packets should be received without address matching. Reserved for factory testing. This should be programmed to 0. Invert CRC (active-high). Used to invert the polarity of the 32-bit CRC polynomial. The normal CRC is inverted prior to transmission. If INVCRC is high, the normal CRC is reinverted prior to sending, forcing a CRC error. Backoff select (active-low). Used to control whether the binary backoff algorithm is used during collision handling. If BSEL is high, the backoff algorithm is not used. The transmitter jams for 32 TX_CLK cycles and attempts to retransmit after 96 bit times (normal IFG). 7 DEFER If BSEL is low, the transmitter follows the normal binary backoff algorithm following a collision. Defer (active-high). Used to force the transmitter to abort a transmission attempt if it has deferred for more than 24,288 TX_CLK cycles. Deferring starts when the transmitter is ready to transmit, but is prevented from doing so because CRS is active. Defer time is not cumulative. If the transmitter defers for 10,000 bit times, then transmits, collides, backs off, and then has to defer again after completion of backoff, the deferral timer resets to 0 and restarts. If DEFER is low, the transmitter defers indefinitely. 106 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) Table 78. MAC Controller Setup Register (continued) Bit # 6 Name ISQE 5 MFDUP Description Ignore SQE test. Used to ignore the SQE signal from the PHY during the first 64 bit times of interframe gap. If high, the SQE error flag will not be set. MAC full duplex (active-high). Used to control half- or full-duplex operation. When MFDUP is low, the COL input is monitored and the binary backoff algorithm is employed if collisions occur during transmission. When MFDUP is low and CRS is asserted while the MAC’s own packet is being transmitted, the receiver is not enabled since the received packet is the MAC’s own transmitted packet. 4 APDCRC 3:2 RETRY[1:0] 1:0 When MFDUP is high, all packets are received regardless of the status of the transmitter. Append CRC (active-high). Used to control if a 32-bit CRC polynomial is appended to the end of transmitted packet. If high, the CRC is appended. Retry. Used to control the total number of attempts (initial + retries after collision) the MAC makes to transmit a packet. The total attempts follow the table below: RETRY1 RETRY0 ATTEMPTS 0 0 16 0 1 8 1 0 4 1 1 1 PREAMBLE[1:0] Preamble. Used to control the number of preamble bits that will be transmitted before the start of frame delimiter. PREAMBLE1 0 0 1 1 Agere Systems Inc. PREAMBLE0 0 1 0 1 PREAMBLE 56 bits 48 bits 40 bits 8 bits 107 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.2 MAC Packet Delay Alarm Value Register Table 79. MAC Packet Delay Alarm Value Register Address 0xE001 0004 31:0 ALARMVALUE Bit # Name Bit # 31:0 Name Description ALARMVALUE Alarm value. This 32-bit register is a late transmit limit value. If the packet delay count value reaches this limit, the late packet bit is set in the MAC transmit status register (see Table 96 on page 116) if enabled in the MAC controller transmit control register (see Table 94 on page 115). An interrupt will be generated when the late status bit is set, if enabled. 10.7.3 MAC Controller Interrupt Enable Register Table 80. MAC Controller Interrupt Enable Register Bit # Name Bit # Name Bit # 15 14 13:12 11 10 9 8 7 6 5 4 3 2 1 0 108 Address 0xE001 0008 13 12 11 RSVD RSVD DFOVR 5 4 3 TPLI ECI LCI 15 RSGPI 7 TGPI 14 RSBPI 6 RSVD 10 CFOVR 2 EXDEFI 9 CFF 1 EXCOLI 8 CFNE 0 DFUND Name RSGPI RSBPI RSVD DFOVR CFOVR CFF CFNE TGPI RSVD TPLI ECI LCI EXDEFI EXCOLI DFUND Description Good packet interrupt enable. Received and stored good packet interrupt enable. Bad packet interrupt enable. Received and stored bad packet interrupt enable. Reserved. Data FIFO overflow. Receive data FIFO overflow interrupt enable. Control FIFO overflow. Receive control FIFO overflow interrupt enable. Control FIFO full. Receive control FIFO full interrupt enable. Control FIFO not empty. Receive control FIFO not empty. Transmitted good packet interrupt. Transmitted good packet interrupt enable. Reserved. Transmit packet late interrupt. Transmit packet late interrupt enable. Early collision. Early collision detect interrupt enable. Late collision. Late collision detect interrupt enable. Excess deferral. Excess deferral interrupt enable. Excess collision. Excess collision interrupt enable. Transmit data FIFO. Transmit data FIFO data underrun interrupt enable. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) 10.7.4 MAC Control Frame Destination Address Registers Table 81. MAC Control Frame Destination Address Registers Addresses 0xE001 000C:0xE001 0014 47:0 CDEST Bit # Name Bit # 47:0 Name CDEST Description Control frame destination address. This is a 48-bit reserved multicast address register for control frames. When transmitting a MAC control frame, these bits will be used as the destination address field of the outgoing frame. See the CNTLXMIT bit description in Table 95 on page 116. When receiving a MAC control frame, these bits will be compared against the destination address field of the incoming frame. If the received frame is a pause control frame, the IPT_ARM MAC will automatically pause transmitter activity for the required number of bit times. The required values for automatic pause response are: 0xE001 000C:0x0180 0xE001 0010:0xC200 0xE001 0014:0x0001 These bits are only valid for full-duplex mode. 10.7.5 MAC Control Frame Source Address Registers Table 82. MAC Control Frame Source Address Registers Addresses 0xE001 0018:0xE001 0020 47:0 CSOURCE Bit # Name Bit # 47:0 Name Description CSOURCE Control frame source address. This is a 48-bit individual address register of the station sending the frame. When transmitting a MAC control frame, these bits will be used as the source address field of the outgoing frame. See the CNTLXMIT bit description in Table 95 on page 116. Agere Systems Inc. 109 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.6 MAC Control Frame Length/Type Register Table 83. MAC Control Frame Length/Type Register Address 0xE001 0024 15:0 CTYPE Bit # Name Bit # 15:0 Name CTYPE Description Control frame length/type. This is the assigned 2-octet length/type field of a MAC control frame. When transmitting a MAC control frame, these bits will be used as the length/type field of the outgoing frame. See the CNTLXMIT bit description in Table 95 on page 116. When receiving a MAC control frame, these bits will be compared against the length/type field of the incoming frame. If the received frame is a pause control frame and these bits have been programmed to the proper values for a pause frame, the IPT_ARM MAC will automatically pause transmitter activity for the required number of bit times. The required values for automatic pause response are: 0xE001 0024:0x8808. 10.7.7 MAC Control Frame Opcode Register Table 84. MAC Control Frame Opcode Register Bit # Name Bit # 15:0 Address 0xE001 0028 15:0 COPCODE Name Description COPCODE Control frame opcode. This is the 2-octet MAC control opcode field indicating the MAC control function. When transmitting a MAC control frame, these bits will be used as the opcode field of the outgoing frame. See the CNTLXMIT bit description in Table 95 on page 116. When receiving a MAC control frame, these bits will be compared against the opcode field of the incoming frame. If the received frame is a pause control frame and these bits have been programmed to the proper values for a pause frame, the IPT_ARM MAC will automatically pause transmitter activity for the required number of bit times. The required values for automatic pause response are: 0xE001 0028:0x0001. 110 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) 10.7.8 MAC Control Frame Data Register Table 85. MAC Control Frame Data Register Address 0xE001 002C 15:0 CPARAM Bit # Name Bit # 15:0 Name CPARAM Description MAC control parameters. Two octets hold MAC control opcodes specific parameters. When transmitting a MAC control frame, these bits will be used as the least significant two bytes of the data field of the outgoing frame. See the CNTLXMIT bit description in Table 95 on page 116. 10.7.9 VLAN Type1 Type/Length Field Register Table 86. VLAN Type1 Type/Length Field Register Address 0xE001 0030 31:16 RSVD Bit # Name Bit # 31:16 15:0 15:0 TYPE [15:0] Name Description RSVD Reserved. TYPE[15:0] VLAN type1 (read/write). VLAN type1 type/length field value. 10.7.10 VLAN Type2 Type/Length Field Register Table 87. VLAN Type2 Type/Length Field Register Address 0xE001 0034 31:16 RSVD Bit # Name Bit # 31:16 15:0 15:0 TYPE [15:0] Name Description RSVD Reserved. TYPE[15:0] VLAN type2 (read/write). VLAN type2 type/length field value. 10.7.11 MAC Transmit FIFO Register Table 88. MAC Transmit FIFO Register Address 0xE001 0038 31:0 DATA Bit # Name Bit # 31:0 Name DATA Agere Systems Inc. Description Data (Write only). 32-bit data written to this FIFO is transmitted out, LSB first. 111 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.12 MAC Receive FIFO Register Table 89. MAC Receive FIFO Register Address 0xE001 003C 31:0 DATA Bit # Name Bit # 31:0 Name DATA Description Data (read-only). Data received into this register, LSB first. 10.7.13 MAC Receive Control FIFO Register This register is used to access the status words in the receive control FIFO. Each status word has the format shown in Table 90. Table 90. MAC Receive Control FIFO Register Bit # Name Bit # Name Bit # Name 31 IFG 25 LONG 19 RPAUSE Bit # 31 Name IFG 30 RXJAB 29 FAE 28 CRC 27 26 30 RXJAB 24 PHYS 18 RX_VLAN2 Address 0xE001 0040 29 28 FAE CRC 23 22 MULT BROAD 17 16 RX_VLAN1 RXEROUT 27 RUNT 21 RCNTRL 15:0 RXCOUNT 26 FRAG 20 RUNSUP — — Description Short IFG (active-high). Indicates that the interframe gap prior to the start of the packet was less than 76 bit times. Valid on the positive edge of RX_CLK. Receive jabber error (active-high). Indicates that the receive packet length was greater than 1518 bytes, and that the packet had a bad CRC or FAE. Valid on the positive edge of RX_CLK. Frame alignment error (active-high). Indicates a packet was received with a frame alignment error. An FAE occurs when the resultant remainder from the division between the number of bits in a frame and eight is nonzero (nonintegral number of octets), the CRC is invalid, and the octet counters are greater than or equal to 64 and less than or equal to 1518. Valid on the positive edge of RX_CLK. Dribble bits have no effect. CRC error (active-high). Indicates a packet was received with a bit count having a mod 8 remainder equal to 0 (integral number of octets), and that the packet had an incorrect CRC. RUNT Valid on the positive edge of RX_CLK. Runt packet (active-high). Indicates a packet was received with a byte count (including CRC) <64, and the packet had a good CRC. FRAG Valid on the positive edge of RX_CLK. Fragment (active-high). Indicates a packet was received with a byte count (including CRC) <64, and the packet had a bad CRC or FAE. Valid on the positive edge of RX_CLK. 112 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) Table 90. MAC Receive Control FIFO Register (continued) Bit # 25 Name LONG 24 PHYS Valid on the positive edge of RX_CLK. Received physical address (active-high). Indicates that the first bit of the received packet was 0, and that at least 6 bytes of data were received. 23 MULT Valid on the positive edge of RX_CLK. Received multicast address. Indicates that the first bit of the received packet was 1, all address bits were not 1, and that at least 6 bytes of data were received. 22 BROAD 21 RCNTRL Valid on the positive edge of RX_CLK. MAC control frame received. Indicates that the last packet received was a valid MAC control frame. 20 RUNSUP Valid on the positive edge of RX_CLK. Unsupported opcode received. Indicates that the last MAC control frame received had an unsupported opcode. 19 RPAUSE Valid on the positive edge of RX_CLK. PAUSE frames received. Indicates that the last control frame received has a multicast address, length/type field, and opcode for the pause operation. 18 17 16 15:0 Description Frame long error (active-high). Indicates that the received packet’s length was greater than 1518 bytes, and the packet had good CRC. Valid on the positive edge of RX_CLK. Received broadcast address. Indicates that all 48 address bits of a received frame are 1. Valid on the positive edge of RX_CLK. RX_VLAN2 VLAN type2 frame. When this signal is set, the current reception is tagged with a VLAN type2 ID. The thirteenth and fourteenth bytes at the frame are compared to the VLAN type2 type/length field register. This signal is set if there is a nonzero match. RX_VLAN1 VLAN type1 frame. When this signal is set, the current reception is tagged with a VLAN type1 ID. The thirteenth and fourteenth bytes at the frame are compared to the VLAN type1 type/length field register. This signal is set if there is a nonzero match. RXEROUT Receive error output (active-high). Active from RXEOP of an incoming frame to RXSOP of the next frame, synchronous with RXC. RXEOP can be used to strobe RXEROUT. RXEROUT will activate if the RX_ERR input from the MII activates for one or more clocks while RX_DV is high. RXCOUNT Receive byte count. Receive byte count at end of packet. Read-only. Agere Systems Inc. 113 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.14 MDIO Address Register This register is written with the address of the PHY and a specific register within the PHY to initiate a PHY register read or write operation. Table 91. MDIO Address Register Bit # Name Bit # Name 15 PHY4 8 REG2 Bit # 15:11 10:6 5:2 1 Name PHY[4:0] REG[4:0] RSVD WRITE 0 BUSY 14 PHY3 7 REG1 Address 0xE001 0044 13 12 PHY2 PHY1 6 5:2 REG0 RSVD 11 PHY0 1 WRITE 10 REG4 0 BUSY 9 REG3 — — Description PHY address. These bits tell which of the 32 possible PHY devices are being accessed. MII register. These bits select the desired MII register in the selected PHY device. Reserved. These bits are reserved and must be set to 0. MII write. Setting this bit tells the PHY that this will be a write operation using the MII data register. If this bit is not set, this will be a read operation, placing the data in the MII data register. MII busy. This bit should read a logic 0 before writing to the MII address and MII data registers. During a MII register access, this bit will then be set to signify that a read or write is in progress. The MII data register should be kept valid until this bit is cleared during a PHY write operation. The MII data register is invalid until this bit is cleared by the MAC during a PHY read operation. The MII address register should not be written to until this bit is cleared. This bit is read-only. 10.7.15 MDIO Data Register Table 92. MDIO Data Register Address 0xE001 0048 15:0 DATA 15:0 Bit # Name Bit # 15:0 114 Name DATA[15:0] Description MDIO data. 16-bit data value read from the PHY after a MDIO read operation. 16-bit data value to be written to the PHY before a MDIO write operation. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) 10.7.16 MAC PHY Powerdown Register Table 93. MAC PHY Powerdown Register Address 0xE001 0200 1 PHY1 31:2 RSVD Bit # Name Bit # 31:2 1 Name RSVD PHY1 0 PHY0 0 PHY0 Description Reserved. PHY1. Read/write. If 1, power down. Default = 1. PHY0. Read/write. Default = 0. 10.7.17 MAC Controller Transmit Control Register Table 94. MAC Controller Transmit Control Register Bit # Name 15 RXMT 14 RRND Bit # 15 14 5 4 Name RXMT RRND TRME TLME 3 CNTLXMIT 2 1 0 TXABORT RESTARTFIFO RSTFIFO Agere Systems Inc. 5 TRME Address 0xE001 0800 4 3 2 TLME CNTLXMIT TXABORT 1 RESTARTFIFO 0 RSTFIFO Description Reset transmit. Must be written to 0 before attempting to use transmitter. Reset random counter (write 1, then write 0). Transmitter enable. Set to 1 to enable transmission of packets. Transmitter late mode enable. When set to 1, an internal late counter counts the number of transmit clocks from transmit start until the packet is sent or transmission is halted. If the late counter matches the late alarm value (ALARMVALUE; see Table 79 on page 108) an interrupt will be generated if enabled. This allows the processor to know when real time packets are no longer meaningful due to excessive transmission delay. Control transmit request. When this bit is set, the MAC control frame programmed in register addresses 0xE001 0014 to 0XE001 002C will be transmitted. This bit is self-clearing. Transmit abort (active-high). Used to stop a transmission ungracefully. The transmitter immediately terminates a transmission if this input is set. TXABRT should be held high for two or more TX_CLK cycles. When a packet is aborted during preamble, the preamble is completed and the APNDCRC and INVCRC inputs are followed. If TXABORT is activated during transmission, transmission immediately stops, and the APNDCRC and INVCRC inputs are followed. This bit is held high for two TX_CLK cycles, then self-clears. Restart FIFO. This bit only resets the read pointer of the transmit FIFO. Reset FIFO. This bit resets both the read and write pointers of the transmit FIFO. 115 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.18 MAC Controller Transmit Start Register Table 95. MAC Controller Transmit Start Register Address 0xE001 0804 15 START Bit # Name Bit # 15 Name START 14:0 COUNT 14:0 COUNT Description Start bit. The MAC controller starts attempting to transmit a packet when set. This bit is reset by the MAC controller when packet transmission is terminated. Count value. The 15-bit value is the number of bytes to be transmitted, not including the CRC. 10.7.19 MAC Transmit Status Register Table 96. MAC Transmit Status Register Bit # Name Bit # Name Bit # 15 14 13 12 11 10 15 EXDEF 7 LATE 14 DEF 6 TCNTRL Name EXDEF DEF 13 SCOL 5 SQEFAIL Address 0xE001 0808 12 11 10 9 MCOL CERR COLDET LCRS 4 3 2 1 PAUSEACTIVE TX_VLAN2 TX_VLAN1 TXBROAD 8 ABORTED 0 TXMULT Description Excessive deferral (active-high). Indicates transmission ended because of waiting for more than 24,288 bit times for the medium to become not busy. Valid on the positive edge of TX_CLK. The assertion of this bit is temporary. Deferral (active-high). Indicates that a transmission was deferred for one bit time to 24,288 bit times during transmission. SCOL Valid on the positive edge of TX_CLK. Single collision (active-high). Indicates that there was one collision during transmission of the previous packet. MCOL Valid on the positive edge of TX_CLK. Multiple collisions (active-high). Indicates that there was more than one collision during the transmission of the previous packet. CERR Valid on the positive edge of TX_CLK. Collision error (active-high). Indicates that the previous transmission was stopped because of excessive collisions as allowed by the RETRY[1:0] inputs. SCOL and MCOL are also valid if CERR is active. COLDET Valid on the positive edge of TX_CLK. Collision detected (active-high). Indicates that a collision has been detected. This signal is active from the time of a collision until the completion of the 32-bit jam sequence. The COL signal is monitored only when the transmitter is actively transmitting data. This signal is temporary; it may not be held long. Valid on the positive edge of TX_CLK. 116 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) Table 96. MAC Transmit Status Register (continued) Bit # 9 Name LCRS 8 ABORTED 7 LATE 6 TCNTRL 5 SQEFAIL 4 Description Loss of carrier (active-high). Indicates that the CRS input was inactive for one or more bit times while the transmitter is active and in half-duplex. Valid on the positive edge of TX_CLK. Transmission aborted (active-high). Indicates that a transmission has been aborted before completion. This signal is cleared prior to the start of the next packet. Valid on the positive edge of TX_CLK. Late collision (active-high). Indicates that a collision occurred more than 512 bit times from the start of a transmission. The start of transmission is defined as the transmission of the first bit of preamble. Valid on the positive edge of TX_CLK. MAC pause control frame transmitted. Indicates that the last packet sent was a MAC pause control frame. Valid on the positive edge of TX_CLK. SQE test failed (active-high). Indicates that a COL signal was not detected during the first 6.4 µs of interframe gap following a transmit attempt. SQE is inactive if the ISQE input is high. This signal is only useful during test. Valid on the positive edge of TX_CLK. PAUSEACTIVE Pause active (active-high). Active while the transmitter is blocked from transmitting after the reception of a pause command. This output is synchronous with TXC. VLAN type2 frame. When this signal is set, the current transmission is tagged with a VLAN type2 ID. The thirteenth and fourteenth bytes at the frame are compared to the VLAN type2 type/length field register. 3 TX_VLAN2 2 TX_VLAN1 1 TXBROAD This signal is set if there is a nonzero match. Transmit broadcast (active-high). Active from TXEOP (FCEOP) to TXSOP (FCSOP) of the following frame, synchronous with TXC. TXEOP can be used to strobe TXBROAD. 0 TXMULT TXBROAD is active if the transmitted frame has a destination address of all ones. Transmit multicast (active-high). Active from TXEOP (FCEOP) to TXSOP (FCSOP) of the following frame, synchronous with TXC. TXEOP can be used to strobe TXMULT. This signal is set if there is a nonzero match. VLAN type1 frame. When this signal is set, the current transmission is tagged with a VLAN type1 ID. The thirteenth and fourteenth bytes at the frame are compared to the VLAN type1 type/length field register. TXMULT is active if the transmitted frame has a destination address with the first transmitted address bit a 1, and at least one of the following 47 address bits a 0. Agere Systems Inc. 117 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.20 MAC Collision Counter Table 97. MAC Collision Counter Address 0xE001 080C Bit # Name Bit # 31:5 4:0 31:5 RSVD 4:0 COLCOUNT Name Description RSVD Reserved. COLCOUNT Collision count. Counts collisions on a transmission attempt. Cleared on the next transmission. Read-only. 10.7.21 MAC Packet Delay Counter Table 98. MAC Packet Delay Counter Address 0xE001 0810 31:0 PDELCOUNT Bit # Name Bit # 31:0 Name Description PDELCOUNT Packet delay count value. The 32-bit value is a running counter of the number of transmit clocks from the time the transmit start bit is set until the packet has finished being transmitted. This counter is reset to 0 when the transmit start bit is set. 10.7.22 MAC Transmitted Packet Counter Table 99. MAC Transmitted Packet Counter Bit # Name Bit # 15:0 Address 0xE001 0814 15:0 TXPCOUNT Name Description TXPCOUNT TX packet count value. The 16-bit value is a running counter of all packets transmitted. 10.7.23 MAC Transmitted Single Collision Counter Table 100. MAC Transmitted Single Collision Counter Bit # Name Bit # 15:0 118 Address 0xE001 0818 15:0 TXSCOLCOUNT Name Description TXSCOLCOUNT TX single collision count value. The 16-bit value is a running counter of all packets transmitted with a single collision. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) 10.7.24 MAC Transmitted Multiple Collision Counter Table 101. MAC Transmitted Multiple Collision Counter Address 0xE001 081C 15:0 TXMCOUNT Bit # Name Bit # 15:0 Name Description TXMCOLCOUNT TX multiple collision count value. The 16-bit value is a running counter of all packets transmitted with multiple collisions. 10.7.25 MAC Excess Collision Counter Table 102. MAC Excess Collision Counter Address 0xE001 0820 15:0 EXCOLCOUNT Bit # Name Bit # 15:0 Name Description EXCOLCOUNT Excess collision count value. The 16-bit value is a running counter of all packets that are terminated due to excess collisions. 10.7.26 MAC Packet Deferred Counter Table 103. MAC Packet Deferred Counter Address 0xE001 0824 15:0 PDEFCOUNT Bit # Name Bit # 15:0 Name PDEFCOUNT Description Packet deferred count value. The 16-bit value is a running counter of all packets that are terminated due to excess deferral. 10.7.27 MAC Controller Receive Control Register Table 104. MAC Controller Receive Control Register Address 0xE001 0A00 1 RRCV Bit # Name Bit # 1 0 0 RCVE Name RRCV RCVE Description Reset receive. Resets MAC receiver state machines. Must be written to 0 to remove reset. Receiver enable. Set to 1 to enable reception and storage of packets. Agere Systems Inc. 119 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) 10.7.28 MAC FIFO Status Register Table 105. MAC FIFO Status Register Bit # Name Bit # Name Bit # 11 10 9 8 7 6 5 4 3 2 1 0 11 CFF 5 RFE Name CFF RSVD CFE CFOVR RFF RFHF RFE RFOVR TFF TFHF TFE TFUND 10 RSVD 4 RFOVR Address 0xE001 0C00 9 8 CFE CFOVR 3 2 TFF TFHF 7 RFF 1 TFE 6 RFHF 0 TFUND Description Control FIFO full. Reserved. Control FIFO empty. Control FIFO overflow. Receive data FIFO full. Receive data FIFO half full. Receive data FIFO empty. Receive data FIFO overflow. Transmit data FIFO full. Transmit data FIFO half full. Transmit data FIFO empty. Transmit data FIFO underrun. 10.7.29 MAC Controller Interrupt Status Register Table 106. MAC Controller Interrupt Status Register Bit # Name Bit # Name 15 RSGPI 6 RSVD 14 RSBPI 5 TPLI Address 0xE001 0C04 13:12 11 10 RSVD DFOVR CFOVR 4 3 2 ECI LCI EXDEFI 9 CFF 1 EXCOLI Bit # 15* 14* 13:12 11* 10* 9 Name RSGPI RSBPI RSVD DFOVR CFOVR CFF 8 CFNE Read-only. Control FIFO not empty. Receive control FIFO not empty. 7* TGPI Read-only. Good packet interrupt. Transmitted good packet interrupt. 8 CFNE 0 DFUND 7 TGPI — — Description Good packet interrupt. Received and stored good packet interrupt. Bad packet interrupt. Received and stored bad packet interrupt. Reserved. Data FIFO overflow. Receive data FIFO overflow. Control FIFO overflow. Receive control FIFO overflow. Control FIFO full. Receive control FIFO full. * Read-only latch, (ROL). A read-only latch is similar to a read-only (RO) field, except that once it is set, it stays set regardless of the state of any event that set it in the first place. It can only be reset by the microprocessor writing a 1 to the bit. Note that the microprocessor writing a 0 to a ROL has no effect at all. 120 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 10 Ethernet 10/100 MAC (continued) Table 106. MAC Controller Interrupt Status Register (continued) Bit # 6 5* 4* 3* 2* 1* 0* Name RSVD TPLI ECI LCI EXDEFI EXCOLI DFUND Description Reserved. Packet late interrupt. Transmit packet late interrupt. Early collision detect. Early collision detect interrupt. Late collision. Late collision detect interrupt. Excess deferral. Excess deferral interrupt. Excess collision. Excess collision interrupt. FIFO data underrun. Transmit data FIFO data underrun interrupt. * Read-only latch, (ROL). A read-only latch is similar to a read-only (RO) field, except that once it is set, it stays set regardless of the state of any event that set it in the first place. It can only be reset by the microprocessor writing a 1 to the bit. Note that the microprocessor writing a 0 to a ROL has no effect at all. Warning: ARM accesses to the MAC registers within the address space 0xE001 0800—0xE001 FFFF when both Ethernet ports are down or when the repeater is disabled will generate an ARM data abort. The abort occurs because this register space requires clocks that are only present if link is achieved or if the repeater is used. If these registers must be accessed prior to achieving link on the Ethernet ports, the repeater should first be enabled. 10.8 Signal Information 10.8.1 MII MAC I/O Signals Table 107. MII MAC I/O Signals Signal COL Type I CRS I RX_CLK I RXD[3:0] I RX_DV RX_ERR I I TX_CLK I TXD[3:0] TX_ERR TX_EN MDC O O O O MDIO BI Agere Systems Inc. Description Collision. Used to indicate a collision between two stations. Assumed to be active for a minimum of two TX_CLK cycles. COL is sampled during half-duplex transmit operations when TXE is active. Carrier sense. Asynchronously asserted by the physical layer when traffic is detected on the medium. Receive clock. Receive clock operates at 2.5 MHz or 25 MHz. RX_CLK is sourced by the physical layer device. Receive data. 4-bit nibble containing received data. RXD is valid on the rising edge of RX_CLK. Receive data valid. Used to indicate that the data on RXD is valid. Receive error. Asserted by the PHY when it has detected an error with the frame currently being received. Transmit clock. 2.5 MHz or 25 MHz 50% duty cycle, continuously running. TX_CLK clocks all transmitter and timer logic. Transmit data. 4-bit nibble with data to be transmitted. Transmit error. Indicates a transmit error. Transmit enable. Indicates that the data on the TXD[3:0] lines is valid. Management data clock. This is a 2.5 MHz (maximum) clock to exchange management data with a device on MDIO. Management data. This is bidirectional management data for an external device. 121 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 10 Ethernet 10/100 MAC (continued) Table 108. DMA Interface Signals Signal TX_DMA_RDY RX_DMA_RDY Type Description O Transmit DMA ready. This signal is asserted when the TX FIFO is less than half-full. When it is asserted, DMA will transfer data from memory to the MAC TX FIFO. O This signal is deasserted when the TX FIFO becomes full. Receive DMA ready. This signal is asserted when the RX FIFO is at or greater than half-full. MAC will transfer data from RX FIFO to memory when this signal is asserted. This signal is deasserted when the RX FIFO becomes empty or until it becomes empty at the end of packet indication. 122 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller The 10/100 2-port repeater and backplane segment controller provides the following capabilities: ■ 10/100 Mbits/s operation via 25 MHz MII or 10 MHz serial PHY interface with detected speed status and automatic speed mismatch protection. ■ An ARM AMBA peripheral interface to configure the internal registers. ■ Supports 802.3u 1995 class I repeater specifications for 100Base-TX, -FX, and -T4. ■ On-chip receive FIFO retimes data for single-clock synchronous systems. ■ VLAN (virtual lan) using existing Ethernet frames and NICs (network interface card). The repeater slice and backplane segment allow software configuration of multiple segments so that stations can be easily segregated into individual workgroups. ■ Operation at 10 Mbits/s or 100 Mbits/s on a per-port basis based on the autonegotiation scheme of the connected PHY. ■ The REPEATER BYPASS mode (see bits 5:4 in in Table 115 on page 135) connects either PHY0 or PHY1 directly to the MAC, then places the repeater and PHY1 in sleep or low-power mode. RX_ER0 MIICLK RX_DV0 RXD0[3:0] MSTCLK SPD_SEL0 LIS0 MIIRX_DV COL0 CRS0 MIIRXD(3:0) TXD0[3:0] TX_W0 MIIRX_ER TX_ER0 RX_ER1 REPEATER SLICE AND RX_DV1 BACKPLANE SEGMENT BLOCK MIICOL RXD1[3:0] MIICRS SPD_SEL1 LIS1 MIITX_ER COL1 CRS1 MIITX_EN TXD1[3:0] MIITXD(3:0) TX_W1 TX_ER1 NIB10 CLK25 CLK10 B_WD B_A B_RD B_SEL B_RST B_WRITE B_CLK B_WAIT 5-8216(F) Figure 20. Repeater Slice and Backplane Segment Block Agere Systems Inc. 123 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.1 MII Transmit and Receive Interface The transmit and receive interface has three major sections: the repeater slice, the PHY interface, and the backplane interface. 11.1.1 Repeater Slice Interface There is a 2-channel repeater slice: slice 0 and slice 1. Slice 0 is connected to the master PHY going to the network. The master clocks are generated from PHY 0. Slice 1 is connected to the slave PHY going to the personal computer. The repeater provides a centralized hub that retransmits incoming data simultaneously upon reception while retiming and strengthening the signal. Management software or hardware will need to ensure that the ports that feed a segment have the same speed. The repeater core, that includes the repeater state machine, the partition state machine, and the event generator, controls data flow in both directions. ■ The repeater state machine enables the device to operate properly according to the IEEE Standard 802.3u 1995 including collision detection and fragment extension. ■ The partition state machine monitors the receive data stream for excessive and long collisions and disables receipt from the port if collision count or length thresholds are exceeded. Partitioning can be disabled by setting DAP of the port configuration register 0 to 1 (see Table 117 on page 136). 11.1.2 PHY Interface In 100 Mbits/s mode, the PHY interface conforms to the IEEE 802.3 media-independent interface definition. On the receive side, RXDx is clocked onto the repeater slice using the recovered clock from the PHY, RX_CLK, when RX_DVx is asserted. It also accepts and forwards RX_ERx as part of the data stream to the backplane. On the transmit side, TXDx, TX_DVx, and TX_ERx are clocked out using the 25 MHz TX_CLK clock. Alternatively, an internal 25 MHz clock can be used to transfer data and control to the PHY via a register bit in the global configuration register (see Table 115 on page 135). The COL signal from the PHY (see Table 110 on page 129) is monitored for collisions on the link, and the CRS signal is monitored for the presence of a received carrier. In 10 Mbits/s mode, data is transferred to and from the PHY using a 7-pin serial data interface. Data and envelope information are received from the PHY on RXD[0] and CRS in combination with RX_CLK, respectively. Data and envelope information are transmitted to the PHY on TXD[0] and TX_EN with TX_CLK, respectively. The 10 Mbits/s mode will always use the TX_CLK input to transfer data to the PHY. The COL pin is monitored by the repeater slice for collision presence. The repeater slice interfaces to 10 Mbits/s PHYs with a 7-pin serial interface, and to 100 Mbits/s PHYs with the standard MII interface. As previously mentioned, there is an option in 100 Mbits/s mode to use an internal 25 MHz clock to transfer data and control to the PHY. This is controlled via TXCPIN in the global configuration register (see Table 115 on page 135). 124 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) Port configuration register bit CRSDELAY (see Table 117 on page 136), sets a delay for the start of preamble regeneration from the receipt of CRS from the PHY. CRSDELAY should be set to its default value of 0x4, except for T4 applications. Due to the variability of T4 receivers and the requirement for accurate preamble regeneration on the transmit side, the CRSDELAY value sets up a count between 0 and 7 for use in tweaking the start of preamble. Depending on the phase relationship between MAINCLK and RX_CLK, simulation may show the repeater working with a value of one less than this calculated value. This is the worst case and therefore is a proper calculation. The following formula should be used to calculate the proper value for CRSDELAY: CRSDELAY value = [(Maximum number of preamble nibbles received from PHY) – 11] + (CRS to RX_DV delay/40 ns rounded up) Example 1: All 14 possible preamble nibbles are received from the PHY. The maximum delay from CRS active to RX_DV active is 41 ns. CRSDELAY value = (14 – 11) + 1 = 4 Example 2: A maximum of 10 of the 14 possible preamble nibbles are received from the PHY. The maximum delay from CRS active to RX_DV active is 40 ns. CRSDELAY value = (10 – 11) + 1 = 0 If the above calculation results in a negative number, use zero for CRSDELAY. If all 14 preamble nibbles are received from the PHY, the maximum CRS active to RX_DV active allowable delay is 160 ns. 11.1.3 Backplane Interface The architecture of the repeater slice requires the use of external interconnection circuitry (backplane) that must include at least a switch matrix to form a complete repeater unit. The receive path of each port of the chip is in no way coupled to the transmit path of any port as far as the data path is concerned. It is assumed that the repeater slice will interface to an external device, which in turn will be responsible for creating the collision domains to which the repeater slice repeater ports attach. The backplane segment provides this switch function. The backplane segment contains one 10 Mbits/s internal segment and one 100 Mbits/s segment. Each repeater slice port feeds the 10 Mbits/s or the 100 Mbits/s data to the backplane segment. Optionally, the backplane segment 10 Mbits/s can be converted to a 100 Mbits/s segment, so that two 100 Mbits/s segments exist. When the 10/100 Mbits/s segment is configured for 100 Mbits/s operation, there can be no 10 Mbits/s segment connections since only two segments exist. Regardless of which operating mode is selected, it is assumed that data will be looped back to all ports on the same segment, including the port that is sourcing the data. It also provides a nibble mode MAC interface for both 10 Mbits/s and 100 Mbits/s operations. The assignment of the port to a segment depends on the per-port SPD_SEL pin. 11.1.3.1 MAC Interface The backplane segment MAC interface provides a connection to the repeater slice and backplane. In 100 Mbits/s mode, the MAC interface is the nibble-wide MII interface running at 25 MHz as described in IEEE 802.3u 1995, section 22. The backplane segment MAC interface looks like the PHY interface to the attached MAC device. In 10 Mbits/s mode, the MAC interface is a serial NRZ interface running at 10 MHz or a nibble-wide MII interface at 2.5 MHz. The NIB10 pin (see Figure 20 on page 123) selects the option of serial or nibble for the 10 Mbits/s MAC port. Agere Systems Inc. 125 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.1.4 Receive Path The following are the two functional blocks between the PHY MII and backplane interfaces in the receive path: ■ Elasticity buffer (EB). The elasticity buffer is used to retime the data before it is sent to the backplane. In 100 Mbits/s mode, the data exiting the EB is synchronous to the MSTCLK. In 10 Mbits/s mode, data is synchronized to CLK10. ■ Receive control interface. The receive control interface provides a point of control for the repeater state machine over the received data stream. 11.1.5 Transmit Path The transmit path consists of the transmit control interface that provides a point of control for the repeater state machine over the transmitted data stream. TX_CLK from the PHY, or optionally an internally generated 25 MHz clock, is used to clock out data to the PHY. 11.2 Input Clocks Two clocks are required to operate the backplane segment. These clocks are also required to operate the repeater slice. ■ The 10 MHz clock should be phase-aligned to the repeater slice’s 10 MHz clock within ±1 ns. ■ The 25 MHz clock’s input must be phase-aligned to the repeater slice’s 25 MHz input. The rising edge of the 25 MHz clock should not be skewed by more than ±1 ns between the repeater slice and the backplane segment devices. 11.3 Repeater Slice Theory of Operation 11.3.1 Repeater Core IEEE 802.3 clause 27, defines seven applicable state diagrams that describe the intended behavior of a 100Base-X repeater. They are the repeater core, receive, transmit, carrier integrity monitor, receive timer, partition, and repeater data handler. The repeater slice, in conjunction with the PHY and an external switch matrix, provides a complete implementation of the functionality described by these state machines. 11.3.2 10/100 Mbits/s Operation The repeater core of the repeater slice has been designed to work at both 25 MHz and 10 MHz under control of the SPD_SEL input pin (see Table 110 on page 129). Whenever the value of this pin changes, the repeater core is automatically reset and resynchronized to the new clock. This ensures that the logic returns to a known state before the start of operation at the new frequency. The repeater slice also checks the frequency of RX_CLK (receive clock) to verify that it is correct for the selected speed. The detected speed is reflected in the DS bit of the global port status register (see Table 121 on page 141). The repeater slice can be configured via the ASMP bit of the port configuration register 1 (see Table 118 on page 138) so that if a speed mismatch is detected, (i.e., the DS bit and the SPD_SEL are different), the port will be isolated from the repeater. 126 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.3.3 Collisions In the transmit collision state, the repeater sends JAM. Transmit collision is entered because two or more ports on the repeater slice are active at the same time. The repeater slice enters transmit collision state when collision is asserted from the backplane. It is the responsibility of the external switch matrix to determine if two or more repeater slice ports on a segment are active and drive the collision signal. The receive collision state is entered due to a remote collision outside the repeater slice in question, causing a signal quality error (SQE) at the repeater slice without any other ports being active. In other words, the repeater slice has only one port active and it is receiving the COL from the PHY. 11.3.4 Partition and Isolate The repeater slice has been designed to conform to the IEEE 802.3 standard in terms of when a port is isolated or partitioned. The device also has two optional features that may be used to enhance the basic functionality. These features are isolated due to speed mismatch and unpartition on link invalid. 11.3.4.1 Partitioning In both 10 Mbits/s and 100 Mbits/s modes, the partitioning will occur when 64 consecutive collisions have occurred. Note: The repeater slice will not count late collisions as consecutive collisions. In 10 Mbits/s mode, Tw6 is 1050—1125 bit times in duration. If a collision lasts longer than the Tw6 timer, the port will be partitioned in 10 Mbits/s mode. Once partitioned, the port will not pass data onto the backplane. The port will continue to transmit data it sees on the backplane. Tw6 is not implemented for 100 Mbits/s. A port will unpartition when a packet has been received or transmitted from the port for Tw5 = 512 bit times without colliding. The partitioning state machine will be reset when the DAP bit in the port configuration register 0 (see Table 117 on page 136) is set to 1. 11.3.4.2 MAU Jabber Lockup Protection (MJLP) In 10 Mbits/s mode only, the repeater will interrupt an excessively long input by putting silence onto the backplane for a short duration. The length of the excessive input must exceed the Tw3 timer value of 4 ms—7.5 ms for the silence to be inserted. The silence is inserted for Tw4 = 97 bit times and the backplane is again driven if the excessively long packet is still present. The cycle is repeated until the receive event stops. For example, if a packet lasts for 25 ms, a single MJLP will be tallied in the event counter, but the backplane will have three idle periods of Tw4 bit times inserted into the data. The repeater slice does not implement MJLP from the backplane to the PHY interface. It is the responsibility of the PHY to implement a watchdog timer (jabber timer) in the transmit direction. 11.3.4.3 Receive Jabber MJLP is not implemented for 100 Mbits/s mode. Instead, the 100 Mbits/s mode implements a receive jabber (such as the repeater slice device has implemented). The receive jabber handles an excessively long receive event by simply cutting off the output to the backplane after 0.4 ms—0.75 ms. The repeater continues to keep the backplane output for that port silent until the input has gone silent (CRS = RX_DV = 0) at which time it will again allow a new receive event to pass on to the backplane. Note: The port does not repeat transmit data from the backplane when the receive jabber becomes active. Agere Systems Inc. 127 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.3.4.4 Isolate on an Incorrect Clock Frequency The repeater slice continuously checks the frequency of the clock received from the PHY (RX_CLK) using the internally generated 50 MHz clock as a timebase. The result is reflected in the DS and SM bits in the global port status register (see Table 121 on page 141). If the clock frequency is incorrect for the selected speed, the repeater slice can be programmed to isolate the port from the repeater slice by setting the automatic speed mismatch protection bit (ASMP) in the port configuration register 1 to one (see Table 118 on page 138). 11.3.4.5 Automatic Speed Mismatch Protection Once the port has been isolated due to improper speed setting, the ARM can be alerted by an interrupt. When the PHY returns to the selected speed, the port will return without ARM intervention. The speed mismatch circuit comes up from reset for proper operation based on the SPD_SEL pin and assumes that the RX_CLK is correct. The detection logic looks at the RX_CLK frequency (and not the data to determine if the clock is correct or not), using the criteria listed below. ■ An RX_CLK with a period of 60 ns or less will be detected as being a valid 25 MHz clock. ■ An RX_CLK with a period of 80 ns or more will be detected as being a valid 10 MHz clock. This includes an RX_CLK at a dc value of 1 V or 0 V, and everything in between. ■ An RX_CLK with a period between 60 ns and 80 ns will result in the detection logic holding the indication for the last clock speed that was detected. There is a 620 ns window of hysteresis in switching between indicating a valid 25 MHz clock to invalid, and from switching between indicating a valid 10 MHz clock to invalid. The repeater slice must see the newly detected clock speed for at least 620 ns before the switch is made. If the detection logic indicates an invalid RX_CLK for the mode selected and the mode is changed to agree with the detected clock, the invalid indication will change immediately to valid. Unpartition when LINK_STATUS = FAIL In an IEEE 802.3 compliant system, the partition state machine for the port will not reconnect once it has partitioned unless LINK_STATUS = OK were being reported. However, it is often the case that a port has partitioned because the attached cable has had its receive pair shorted to its transmit pair. In such a case, it is convenient to have the partition clear as soon as the condition is corrected, i.e., the cable is removed. To clear the partition the repeater slice has an optional mode where the partition state machine will be independent of LINK_STATUS = FAIL. To enable this mode, the ULF bit in the port configuration register 1 (see Table 118 on page 138) must be set to 1. 11.3.5 Carrier Integrity Monitor The repeater slice contains a carrier integrity monitor (CIM) state machine that monitors CARRIER_STATUS, RXERROR_STATUS, and LINK_STATUS variables via the CRS, RX_ER, LIS, and RX_DV inputs from the PHY. The CIM will isolate the port from the repeater if two consecutive false carriers (CARRIER_STATUS = ON with no subsequent SSDs detected) or a single false carrier in excess of the 468—484 bit time FALSE_CARRIER_TIMER that is implemented are received. In some applications, the PHY will contain the CIM state machine in which case the mode may be disabled by setting CIMD in the port configuration register 1 to one (see Table 118 on page 138). In cases where the PHY does not contain the CIM, it must supply the proper signaling for false carrier indication as described in IEEE 802.3u Table 22-2 (RX_DV = 0, RX_ER = 1, RXD[3:0] = 1110). The port will reconnect per 27.3.1.5.1 of IEEE 802.3. 128 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.4 Repeater Slice Interfaces 11.4.1 Repeater Slice ARM Interface Table 109. Repeater Slice ARM Interface Signal P_CLK P_WRITE P_WAIT P_RST P_A P_WD P_RD Type Description I Peripheral clock. ARM peripheral bus clock. I ARM read/write. Indicates which direction the data bus is in, for the current register. This signal should be driven high when reading a register and low when writing a register. O ARM ready (active-low). This signal indicates that the repeater has latched data during a write cycle and has placed valid data onto the bus during a read cycle. I Reset (active-high). Assumed to be asynchronous. Used to reset repeater core and registers. I ARM address bus. The address bus is used by the ARM to indicate which register is being read or written. I ARM write data bus. This data bus is used by the ARM to write to registers. O ARM read data bus. This data bus is used by the ARM to read from registers. Note: For a fuller explanation and timing diagrams consult: http://www.arm.com/Documentation/UserMans/AMBA/pdf/AMBAvD.pdf 11.4.2 Repeater Slice Interface Table 110. Repeater Slice Interface Signal RXD(1, 0)[3:0] Type I Description Receive data. In 10 Mbits/s mode, RXD[0] is the serial receive data from the PHY and is clocked in on the rising edge of RX_CLK. If RXDVAV is set high in the port configuration register 0 (see Table 117 on page 136), RX_DV and CRS must be asserted for data to be accepted. If RXDVAV is set low in the port configuration register 0, only CRS must be asserted for data to be accepted. RXD[3:1] is ignored in 10 Mbits/s mode. RX_DV(1,0) I In 100 Mbits/s mode, RXD[3:0] represent the 4-bit data being received by the PHY. RX_DV must be asserted for data to be accepted. RXD is clocked into the repeater slice with the rising edge of RX_CLK. RXD[0] is the least significant bit of the nibble. Receive data valid. In 10 Mbits/s mode, RX_DV is ignored if RXDVAV in the port configuration register 0 (see Table 117 on page 136) is set low. CRS represents the packet envelope. If RXDVAV is set high, the repeater uses it to qualify RXD. In 100 Mbits/s mode, RX_DV indicates that RXD[3:0] contain recovered and decoded nibbles of data from the PHY. RX_DV must transition synchronously with respect to the RX_CLK. RX_DV must remain asserted continuously from the first recovered nibble of the frame through the final recovered nibble and must be negated prior to the first RX_CLK that follows the final nibble. RX_DV must encompass the frame, starting no later than the start frame delimiter and excluding any end-of-frame delimiter. Agere Systems Inc. 129 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) Table 110. Repeater Slice Interface (continued) Signal RX_CLK(1,0) Type I Description Receive clock. In 10 Mbits/s mode, RX_CLK clocks data in on RXD[0]. If RXDVAV in the port configuration register 0 is set low and once CRS is asserted, RX_CLK should not transition until valid data is placed on RXD[0]. If RXDVAV is high, a free-running RX_CLK can be applied to this pin because RX_DV will be used to qualify RXD[0]. The repeater slice will not clock in RXD[0] when CRS is deasserted. RX_ER(1,0) I In 100 Mbits/s mode, RX_CLK is a 25 MHz continuous clock that provides the timing reference for the transfer of RX_DV, RXD [3:0], and RX_ER into the repeater slice. The duty cycle of RX_CLK must be no worse than 35/65. When a recovered clock is not available the source must provide a nominal 25 MHz clock. The PHY must guarantee that the minimum high and low times of RX_CLK will be 35% of the nominal period under all conditions, including switching between recovered clock and nominal clock. This means narrow clock slivers must never be applied to RX_CLK. Receive error. In 10 Mbits/s mode, RX_ER is ignored. COL(1,0) I CRS(1,0) I TXD(1,0)[3:0] O In 100 Mbits/s mode, RX_ER indicates the PHY has determined an error condition in the current frame. RX_ER must transition synchronously to RX_CLK. When RX_DV = 0, RX_ER = 1, and RXD[3:0] = 1110 is received, a false carrier is indicated. The false carrier is used by the carrier integrity state machine per 27.3.1.5.1 of IEEE 802.3 when it is enabled via the CIMD bit of each port configuration register. Collision detect. In 100 Mbits/s and 10 Mbits/s modes, COL must be asserted by the attached PHY to signal a collision on the medium and must remain asserted while the collision condition exists. COL can be asynchronously applied to the repeater slice. Carrier sense. CRS must be asserted by the attached PHY when the receive medium is nonidle. CRS shall be deasserted when the receive medium has gone idle. The PHY must ensure that CRS remains asserted throughout the duration of a collision condition. The repeater slice will blind the CRS loopback energy from the PHY for 16 bit times in 100 Mbits/s mode and 4 bit times in 10 Mbits/s mode. Transmit data. In 10 Mbits/s mode, TXD[0] is the serial transmit data to the PHY and is clocked out on the rising edge of TX_CLK. An alternate clocking scheme does not exist for 10 Mbits/s mode. TX_CLK(1,0) I In 100 Mbits/s mode, TXD[3:0] represent the 4-bit data to be transmitted by the PHY. TX_EN will be asserted when data is to be transferred. TXD is clocked out of the repeater slice with TX_CLK. Alternatively, if TXCPIN is set low in the global configuration register (see Table 115 on page 135), data is clocked out with an internal 25 MHz clock. Transmit clock. Transmit data clock is a continuously running clock source by the attached PHY. TX_CLK must be 25 MHz in 100 Mbits/s mode and 10 MHz in 100 Mbits/s mode. This pin is ignored if TXCPIN = low in the global configuration register (see Table 115 on page 135). 130 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) Table 110. Repeater Slice Interface (continued) Signal TX_EN(1,0) Type O Description Transmit enable. In 10 Mbits/s mode, TX_EN indicates that the repeater slice is sourcing serial 10 Mbits/s data on TXD [0]. It is clocked out on the rising edge of the TX_CLK. TX_ER(1,0) In 100 Mbits/s mode, TX_EN indicates the repeater slice is presenting nibbles on the MII for transmission. TX_EN is asserted synchronously with the first nibble of the preamble and will remain asserted while all nibbles to be transmitted are presented to the MII. Exactly 7 octets of preamble and one SFD octet will be driven on TXD [3:0], and then the frame data will be put out on the seventeenth TX_CLK. TX_EN will be deasserted prior to the first TX_CLK following the final nibble of a frame. TX_EN is clocked out of the repeater slice with the rising edge of the TX_CLK clock. Alternatively, if the TXCPIN bit is set low in the global configuration register (see Table 115 on page 135) data is clocked out with an internal 25 MHz clock. Transmit error. O In 10 Mbits/s mode, TX_ER is not asserted. LIS(1,0) Static SPD_SEL (1,0) I In 100 Mbits/s mode, TX_ER indicates the repeater is requesting that the PHY transmit a coding error. TX_ER will be asserted for the remainder of the packet. TX_ER will be deasserted for collisions. TX_ER will change after the rising edge of the TX_CLK clock (or 25 MHz system clocks if the TXCPIN bit is set low). Link integrity status. If RX_DV is true, LIS is a 1, indicating that the link is OK. If RX_DV is false, LIS is a 0, indicating that there is no link. Speed select. If SPD_SEL is set to a 1, the 100 Mbits/s mode is asserted. If SPD_SEL is set to a 0, the 10 Mbits/s mode is asserted. 11.4.3 Repeater Slice Input Clocks Table 111. Repeater Slice Input Clocks Signal CLK10C RX_CLK(1,0) Type Description I Clock. This is a 10 MHz 100 ns clock ± 0.01 ns. The duty cycle high time = 35/65 ns. I Receive clock. This is a 10 MHz or a 25 MHz MII receive clock. TX_CLK(1,0) CLK25 MSTCLK Agere Systems Inc. I I NA In 10 Mbits/s mode: 10 MHz period 100 ns ±.01 ns. The duty cycle high time = 35/65 ns. In 100 Mbits/s mode: 25 MHz period 40 ns ±.004 ns duty cycle high time = 14/26 ns. Transmit clock. This is a 10 MHz or a 25 MHz MII transmit clock. In 10 Mbits/s mode: 10 MHz period 100 ns ±.01 ns duty cycle high time = 35/65 ns. In 100 Mbits/s mode: 25 MHz period 40 ns ±.004 ns duty cycle high time = 14/26 ns. Clock. This is a 25 MHz 40 ns clock ± 0.01 ns. Master clock. This is a buffered version of CLK10 or CLK25. 131 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.4.4 Backplane Segment 10/100 Mbits/s Serial Mac Interface Port B Table 112. Backplane Segment 10/100 Mbits/s Serial Mac Interface Port B Signal MIITXD[3:0] Type I Description MII transmit data. In 10 Mbits/s mode, MIITXD [3:0] represents the 4-bit data to be transmitted by the repeater. MIITX_EN must be asserted when data is to be transferred. MRTXD is clocked into the repeater slice with MIICLK. MIITX_EN I In 100 Mbits/s mode, MIITXD [3:0] represents the 4-bit data to be transmitted by the repeater. MIITX_EN must be asserted when data is to be transferred. MIITXD is clocked into the backplane segment with MIICLK. MII transmit enable. In 10 Mbits/s mode (segment B only), MIITX_EN indicates the MAC is presenting nibbles on the MII for transmissions. MIITX_EN must be asserted synchronously with the first nibble of the preamble and remain asserted while all nibbles to be transmitted are presented to the MII. MIITX_EN must be deasserted prior to the first MIICLK following the final nibble of a frame. MIITX_EN is clocked into the backplane segment with the rising edge of MIICLK. MIITX_ER I In 100 Mbits/s mode, MIITX_EN indicates the MAC is presenting nibbles on the MII for transmission. MIITX_EN must be asserted synchronously with the first nibble of the preamble and remain asserted while all nibbles to be transmitted are presented to the MIITX_EN. MIITX_EN must be deasserted prior to the first MIICLK following the final nibble of a frame. MIITX_EN is clocked into the backplane segment with the rising edge of MIICLK. MII transmit error. In 10 Mbits/s mode, MIITX_ER is not monitored. MIICLK O In 100 Mbits/s mode, MIITX_ER indicates the MAC is requesting that the repeater transmit a coding error. MIITX_ER will be clocked with the rising edge of MIICLK. MII transmit/receive clock. In 10 Mbits/s mode, the 2.5 MHz clock is used to transfer nibble data to or from the MAC. MIIRXD[3:0] O In 100 Mbits/s mode, the 25 MHz clock is used to transfer data to or from the MAC. Receive data. In 10 Mbits/s mode and in 100 Mbits/s mode, MIIRXD [3:0] represents the 4-bit data being sent to the MAC. MIIRX_DV will be asserted when data is to be accepted by the MAC. MIRXD is clocked out of the backplane segment with the falling edge of MIICLK. MIIRXD [0] is the least significant bit of the nibble. 132 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) Table 112. Backplane Segment 10/100 Mbits/s Serial Mac Interface Port B (continued) Signal MIIRX_DV Type O Description MII receive data valid. In 10 Mbits/s mode, MIIRX_DV indicates that MIIRXD [3:0] contains decoded nibbles of data from the MAC. MIIRX_DV will transition synchronously with respect to the MIICLK. MIIRX_DV will remain asserted continuously from the first nibble of the frame through the last nibble and will be gated to the first MIICLK that follows the final nibble. MIIRX_DV is not looped back on a transmit from the MAC. It is only asserted due to either repeater slice ports being active or the expansion port being the source of data. MIIRX_ER O In 100 Mbits/s mode, MIIRX_DV indicates that MIIRXD [3:0] contains decoded nibbles of data from the backplane segment. MIIRX_DV will transition synchronously with respect to the MIICLK. MIIRX_DV will remain asserted continuously from the first nibble of the frame through the last nibble and will be negated prior to the first MIICLK that follows the final nibble. MIIRX_DV will encompass the frame, starting no later than the start of frame delimiter and excluding any end-of-frame delimiter. MIIRX_DV is not looped back on a transmit from the MAC. MII receive error. In 10 Mbits/s mode, MIIRX_ER is driven low. MIICRS O MIICOL O In 100 Mbits/s mode, MIIRX_ER indicates the backplane segment has sensed an error code in the current frame. MIIRX_ER will transition synchronously to MIICLK and remain asserted for the duration of the error being sensed. MII carrier sense or MAC serial 10 Mbits/s carrier sense. MIICRS will be asserted by the backplane segment when the segment is nonidle. MIICRS will be deselected when the segment has gone idle. The backplane segment will ensure that MIICRS remains asserted throughout the duration of a collision condition. The backplane segment will loopback MIITX_EN as MIICRS when the MAC is transmitting to the backplane segment. MII collision or serial 10 Mbits/s MAC collision. In 100 Mbits/s and 10 Mbits/s modes, MIICOL will be asserted by the backplane segment to signal a collision on the medium and will remain asserted while the collision condition exists. MIICOL is clocked out with MIICLK. 11.5 Repeater Slice Register Map Table 113. Repeater Slice Register Map Register Read/Write Reserved. — R/W Global maximum frame size register (see Table 114 on page 134). R/W Global configuration register (see Table 115 on page 135). R/W Port control register for port 0/1 (see Table 116 on page 136). R/W Port configuration register 0, for port 0/1 (see Table 117 on page 136). R/W Port configuration register 1, for port 0/1 (see Table 118 on page 138). R/O Global port status register, for port 0/1 (see Table 121 on page 141). R/W Global interrupt enable register (see Table 119 on page 139). R/W Global interrupt status register (see Table 120 on page 140). Agere Systems Inc. Address 0xE001 2000:2004 0xE001 2008 0xE001 200C 0xE001 2020/2220 0xE001 2024/2224 0xE001 2028/2228 0xE001 2030/2230 0xE001 2180 0xE001 2188 133 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.1 Global Maximum Frame Size Register The global maximum frame size register is intended to be programmed with the maximum valid frame size in bytes. The register defaults to 1518 at reset. Table 114. Global Maximum Frame Size Register Address 0xE001 2008 31:12 RSVD Bit # Name Bit # Name 31:12 RSVD State on RST NA 11:0 MAX_FS[11] MAX_FS[10] MAX_FS[9] MAX_FS[8] MAX_FS[7] MAX_FS[6] MAX_FS[5] MAX_FS[4] MAX_FS[3] MAX_FS[2] MAX_FS[1] MAX_FS[0] (X) 0 (X) 1 (X) 0 (X) 1 (1) 1 (1) 1 (1) 1 (0) 0 (1) 1 (1) 1 (1) 1 (1) 0 134 11:0 MAX_FS[1:0] Description Reserved. These bits are reserved. Their value is undetermined on reads and will be ignored on writes. Max frame size. Binary value representing the maximum size frame that will be considered valid by the statistical event generator. These bits default to 0x5EE for 1518 bytes per frame. The value should only be changed when the port configuration register 0 bit 7, RCVE = 0. Operation is unspecified if MAX_FS is set below 1024 byte times or to 4095 byte times. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.2 Global Configuration Register The global configuration register is used to configure the repeater slice features that affect the operation of all four ports. Table 115. Global Configuration Register Bit # Name Bit # 31:6 5:4 3 2 31:6 RSVD Name RSVD REPEATER BYPASS RSVD TXCPIN Address 0xE001 200C 5:4 3 2 REPEATER BYPASS RSVD TXCPIN 1 GPSFD 0 RSVD State on RST Description (0) Reserved. All bits should be written to 0. (00) Repeater bypass mode. Repeater bypass mode set: — (0) 00 PHY0 ↔ MAC 01 PHY1 ↔ MAC 10 Reserved 11 Repeater is in normal mode of operation Reserved. Should be written to 0. MII 100 Mbits/s mode TXCPIN enable. The 10 Mbits/s mode will always use the TX_CLK from the PHY regardless of the setting of this bit. When programmed high, TX_CLK is used to transfer 100 Mbits/s mode transmit data and control out of the repeater slice to the PHY. When programmed low (default), all ports will clock out transmit data and are controlled with the internal 25 MHz clock that is a delayed version of the MSTCLK input to the repeater slice. This mode reduces latency. 1 GSPS (1) In 100 Mbits/s mode, this bit sets the clocking mode for MII PHY transmit data and control for both slices of the repeater slice. Global speed select. This bit selects the speed of the repeater. If GSPS = 0, the repeater speed is set to 10 Mbits/s. This will force both ports and backplane into the 10 Mbits/s mode. If GSPS = 0 and RX_CLK from either PHY port is not 10 MHz, speed mismatch will be detected and the corresponding bit in the port status register will be set. If GSPS = 1, the repeater speed is set to 100 Mbits/s. This will force both ports and backplane into the 100 Mbits/s mode. If GSPS = 1 and RX_CLK from either PHY port is not 25 MHz, speed mismatch will be detected and they corresponding bit in the port status register will be set. 0 RSVD Agere Systems Inc. — Default = 1. Reserved. Should be written to 0. 135 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.3 Port Control Registers, for Port 0, 1 Table 116. Port Control Registers for Port 0, 1 Address—Port 0 (0xE001 2020), Port 1 (0xE001 2220) 31:1 0 RSVD SRST Bit # Name Bit # 31:1 0 Name RSVD SRST State on RST Description (0) Reserved. (0) Software reset. When this bit is set to 1, the port repeater digital circuits are reset to the power-on state. Note: This bit is provided primarily for diagnostic and debugging purposes and is not intended to be used in place of the RESET pin at system start-up. A full hardware reset is required to place the entire chip in a known state. All registers will retain their values. Write 1 to reset. Write 0 to get out of reset. 11.5.4 Port Configuration Register 0 for Port 0, 1 This register is used to configure the repeater port as described below. This register will default to the values in parenthesis after reset. Table 117. Port Configuration Register 0 for Port 0, 1 Bit # Name 31:15 RSVD Addresses—Port 0 (0xE001 2024), Port 1 (0xE001 2224) 14:12 11:10 9 8 7 CRSDELAY[2:0] RSVD RXDVAV XMTE RCVE 6 DAP 5:0 RSVD Bit # Name State on RST Description 31:15 RSVD (0) Reserved. 14:12 CRSDELAY[2] (1) CRS delay. CRSDELAY[1] (0) In 10 Mbits/s mode, CRS is never delayed, so these bits are ignored in CRSDELAY[0] (0) 10 Mbits/s mode. In 100 Mbits/s mode, these bits are used to set a delay for the start of preamble regeneration from the receipt of CRS from the PHY. This register is typically programmed to a value other than the default (100) when the repeater is connected to a T4 PHY. Due to the variability of T4 receivers and the requirement for accurate preamble generation on the transmit side, this value sets up a count to adjust the start of preamble. The contents of this register will be a 3-bit binary value that represents the number of additional MSTCLK cycles to wait after the assertion of CRS to begin preamble generation on the backplane (i.e., 000 = 0 MSTCLKs, 111 = 7 MSTCLKs). 136 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) Table 117. Port Configuration Register 0 for Port 0, 1 (continued) Bit # 11:10 9 Name RSVD RXDVAV 8 XMTE State on RST Description (0) Reserved. (0) RXDVAV available. Controls input for 10 Mbits/s mode to select whether RX_DV is available from the PHY. If the PHY generates RX_DV in 10 Mbits/s mode, RXDVAV should be set high. If the PHY does not generate RX_DV in 10 Mbits/s mode RXDVAV should be set low. (0) Transmit enable. If 1, data transfer from the backplane interface to PHY for transmission is enabled. If 0, data transfer to the PHY is inhibited. Transmit enable/disable is delayed until activity on the port has ended. 7 RCVE (0) Note: The GSPS bit should be properly set before enabling data transmission to the media. Receive enable. If 1, data transfer from the PHY to the backplane interface is enabled. If 0, data transfer to the backplane is inhibited. Receive enable/disable is delayed until activity on the port has ended. 6 5:0 DAP RSVD Agere Systems Inc. (0) Note: The GSPS bit should be properly set before enabling data sourcing to the backplane. Disable autopartition. (0) If 1, this bit will disable the autopartition state machine. If 0, the autopartition state machine operates normally. Reserved. 137 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.5 Port Configuration Register 1, for Port 0, 1 This register is used to configure the repeater port and defaults to the values in parenthesis after reset. Table 118. Port Configuration Register 1, for Port 0, 1 Bit # Name Bit # 31:5 4 31:5 RSVD Name RSVD CIMD Address—Port 0 (0xE001 2028), Port 1(0xE001 2228) 4 3 2 CIMD ULF ASMP 1:0 RSVD State on RST Description (0) Reserved. (0) Carrier integrity monitor disable. Setting this bit to 1 will disable the carrier integrity monitor state machine. 3 ULF (0) 2 ASMP (0) Setting this bit 0 will allow the CIM state machine to isolate the port from the repeater if the false carrier count reaches the limit of 2 or if there is a single excessively long false carrier. Unpartition on link failure. If this bit is set to 1, the partition state machine will operate normally if LINK_STATUS changes to FAIL, as indicated by the LIS pin. Automatic speed mismatch protection. If 1, enables the automatic speed protection circuit, that will cause the port to be isolated if a speed mismatch is detected. The port status register bit SM is set to 1 to indicate a speed mismatch. 1:0 138 RSVD (0) If 0, the port will not be isolated when a speed mismatch is detected. The value of this bit does not affect the reporting of the detected speed via the DS bit in the global port status register. Reserved. These bits must always be set to 0. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.6 Global Interrupt Enable Register The global interrupt enable register is used to disable/enable a particular bit in the global interrupt status register to drive the pin. If any bit of the global interrupt status register is set and the corresponding global interrupt enable register bit is cleared, the device will drive the pin low until the global interrupt status register is read. Reading the global interrupt status register clears the interrupt. This register will default to the values in parenthesis after reset. Table 119. Global Interrupt Enable Register Bit # Name 31:16 RSVD 15, 7 ISO1 ISO0 14, 6 CLIS1 CLIS0 Bit # 31:16 15 Name RSVD ISO1 State on RST (0) (1) 14 CLIS1 (1) 13 SM1 (1) 12 11 10 RSVD PHY_INT1 VLE1 — — (1) 9 CAS1 (1) 8 7 RSVD ISO0 — (1) 6 CLIS0 (1) 5 SM0 (1) 4 3 2 RSVD PHY_INT0 VLE0 — — (1) 1 CAS0 (1) 0 RSVD — Agere Systems Inc. Address 0xE001 2180 13, 5 12, 8, 0 SM1 RSVD SM0 11, 3 PHY_INT1 PHY_INT0 10, 2 VLE1 VLE0 9, 1 CAS1 CAS0 Description Reserved. ISO1 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the ISO bit in the global interrupt status register is set. CLIS1 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the CLIS bit in the global interrupt status register is set. SM1 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the SM bit in the global interrupt status register is set. Reserved. PHY1 interrupt enable. VLE1 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the VLE bit in the global interrupt status register is set. CAS1 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the CAS bit in the global interrupt status register is set. Reserved. ISO0 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the ISO bit in the global interrupt status register is set. CLIS0 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the CLIS bit in the global interrupt status register is set. SM0 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the SM bit in the global interrupt status register is set. Reserved. PHY0 interrupt enable. VLE0 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the VLE bit in the global interrupt status register is set. CAS0 interrupt enable. Setting this bit to 1 enables generation of repeater interrupt if the CAS bit in the global interrupt status register is set. Reserved. 139 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.7 Global Interrupt Status Register The global interrupt enable register is used to disable/enable a particular bit in the global interrupt status register. If any bit of the global interrupt status register is set and the corresponding global interrupt enable register bit is enabled, the device will drive the repeater interrupt. Reading the global interrupt status register does not clear the interrupt. The interrupt condition will persist unless the processor writes a 1 to the corresponding bit in the global interrupt status register. The processor must decide the priority of simultaneous interrupt conditions. This register will default to the values in parenthesis after reset. Table 120. Global Interrupt Status Register Bit # Name 31:16 RSVD 15, 7 ISO1 ISO0 Bit # Name 31:16 15 14 13 12 11 RSVD ISO1 CLIS1 SM1 RSVD PHY_INT1 State on RST (0) (1) (1) (1) (0) — 10 9 8 7 6 5 4 3 VLE1 CAS1 RSVD ISO0 CLIS0 SM0 RSVD PHY_INT0 (1) (1) (0) (1) (1) (1) — — 2 1 0 VLE0 CAS0 RSVD (1) (1) (0) 140 14, 6 CLIS1 CLIS0 Address 0xE001 2188 13, 5 12, 8, 0 SM1 RSVD SM0 11, 3 PHY_INT1 PHY_INT0 10, 2 VLE1 VLE0 9, 1 CAS1 CAS0 Description Reserved. Isolation status. Change in isolation status of port 1. Link integrity status. Change in link integrity status of port 1. Port 1 error interrupt. Symbol error interrupt setting register of port 1. Reserved. PHY1 interrupt status. These interrupts are coming from PHY1. Even if the repeater is in bypass mode, all the registers will be active and interrupt condition on PHY could be read from this register. Very long event 1. Very long event interrupt setting register of port 1. CAS1 interrupt setting register. Change in autopartitioning status of port 1. Reserved. Isolation status. Change in isolation status of port 0. Link integrity status. Change in link integrity status of port 0. Port 2 error interrupt. Symbol error interrupt setting register of port 0. Reserved. PHY0 interrupt status. These interrupts are coming from PHY0. Even if the repeater is in bypass mode all the registers will be active and interrupt condition on PHY could be read from this register. Very long event 0. Very long event interrupt setting register of port 0. CAS0 interrupt setting register. Change in autopartitioning status of port 0. Reserved. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 11 10/100 2-Port Repeater and Backplane Segment Controller (continued) 11.5.8 Global Port Status Register, for Port 0, 1 The global port status register contains the status of the repeater slice. The register is read-only. Writes will not alter the contents of this register. All status bits are valid with RCVE = 0 or 1 (see Table 117 on page 136). Table 121. Global Port Status Register, for Port 0, 1 Bit # Name 31:8 RSVD Bit # 31:8 7 Name RSVD MIS_ERR 6 LIS 5 4 ISO SM Address—Port 0 (0xE001 2030), Port 1 (0xE001 2230) 7 6 5 4 3 2 MIS_ERR LIS ISO SM DS VLE 1 CAR 0 PART State on RST Description (0) Reserved. These bits are reserved and will return 0s on being read. (0) Data rate mismatch. This bit is set when a data FIFO overrun or underrun has occurred. Once set, the user must read this register to clear this bit. (0) Link integrity status. This bit indicates the status of the link as derived from the LIS inputs from the PHY. (0) (1) A 1 indicates LINK_STATUS = OK. A 0 indicates LINK_STATUS = FAIL. Isolated. This bit indicates whether or not the port has been isolated by the carrier integrity monitor state machine due to excessive false carriers detected. A 1 indicates that the port has been isolated. A 0 indicates a nonisolated condition. Speed mismatch. This bit indicates whether or not the frequency of the RX_CLK clock is correct for the selected speed. A 1 indicates the incorrect frequency. A 0 indicates a correct frequency. 3 2 DS VLE (1) (0) 1 CAR (0) 0 PART (0) Agere Systems Inc. Internal circuitry compares the receive clock frequency to the GSPS pin frequency selection to determine a match or mismatch condition. This bit is valid even when the port is disabled. Detected speed. This bit indicates the frequency of the received clock (RX_CLK) on the port and therefore, the speed of the received data stream. Under normal conditions, the following is true. A 1 indicates a frequency of 10 MHz or 10 Mbits/s. A 0 indicates 25 MHz or 100 Mbits/s. Very long event. In 10 Mbits/s mode, it indicates MJLP has expired. In 100 Mbits/s mode, a 1 indicates the port is in receive jabber due to an excessively long CRS currently being applied. Carrier status. Indicates CRS is asserted at time of polling this bit. This bit is not latched. Autopartition status. A 1 indicates the repeater port is currently partitioned. 141 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) Please refer to Agere’s DNC3X3225 Ethernet Transceiver Macrocell Data Sheet for references. A twisted pair 10/100 Ethernet transceiver macrocell supports transmission and reception over category three unshielded twisted pair (UTP) cable and category 5 UTP. It has been designed specifically for applications that support both 10Base-T and 100Base-X, such as network interface cards (NICs), and switches. The features of the 10/100 Ethernet transceiver macrocell are listed below. 12.1 10 Mbits Transceiver Features ■ DSP based. ■ Compatible with IEEE 802.3u 1995 10Base-T standard for twisted pair cable. ■ Half-duplex and full-duplex operations. ■ Autopolarity detection and correction. ■ Adjustable squelch level for extended wire-length capability (2 levels). ■ Interfaces with IEEE 802.3u media independent interface (MII) or a serial 10 Mbits/s 7-pin interface. ■ On-chip filtering eliminates the need for external filters. 12.2 100 Mbits/s Transceiver Features ■ Compatible with IEEE 802.3u 1995 MII (clause 22). PCS/PMA (clause 24), PMD (clause 25), Mll management, and autonegotiation (clause 28) specifications. ■ Selectable 5-bit code-group (PDT/PDR interface) or 4-bit data nibbles (Mll interface) input/output. ■ Full or half-duplex operations. ■ Optional carrier integrity monitor (CIM). ■ Selectable carrier sense signal generation (MCRS) asserted during either transmission or reception in half-duplex (MCRS asserted during reception only in full-duplex). ■ Adaptive equalization and baseline wander correction. ■ On-chip filtering eliminates the need for external filters. ■ 100 Mbits/s FX transceiver. ■ Compatible with IEEE 802.3u 100Base-FX standard. ■ Disables autonegotiation and 10Base-T. ■ Enables 100Base-FX remote fault signaling. ■ Disables MLT-3 encoder/decoder. ■ Disables scrambler/descrambler. ■ FX mode enable is pin or register selectable. 142 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) 12.3 General Features ■ Autonegotiation and management. ■ Fast link pulse (FLP) burst generator. ■ Arbitration function. ■ Accepts preamble suppression. ■ Operates up to 25 MHz. ■ Supports the MII station management protocol and frame format (clause 22): basic and extended register set. ■ Supports next page. ■ Provides status signals: receive activity, transmit activity, full duplex, collision/jabber, link integrity, and speed indication. ■ Powerdown mode for 10 Mbits/s and 100 Mbits/s operation. ■ Loopback testing for 10 Mbits/s and 100 Mbits/s operation. ■ .25 µm low power CMOS technology. ■ 25 MHz XTAL oscillator input or 25 MHz/50 MHz/125 MHz clock input. ■ Compatible with RMII (standard version) and SMII (standard version). 12.4 Signal Information 12.4.1 MII/5-Bit Serial Interface Signals Some of the signals listed below are internal to the device and are not accessible; they are listed for information only. Table 122. MII/5-Bit Serial Interface Signals Signal Type Description MCOL O Collision detect. This signal signifies in half-duplex mode that a collision has occurred on the network. MCOL is asserted high whenever there is transmit and receive activity on the UTP media. MCOL is the logical AND of MTX_EN and receive activity, and is an asynchronous output. When SER_SEL_PIN is high and in 10Base-T mode, MCOL indicates the jabber timer has expired. MCRS O Carrier sense. When CRS_SEL is low, this signal is asserted high when either the transmit or receive medium is nonidle. This signal remains asserted throughout a collision condition. When CRS_SEL is high, MCRS is asserted on receive activity only. CRS_SEL is set via the MII management interface or the CRS_SEL signal. MRXCLK O Receive clock. 25 MHz clock output in 100 Mbits/s mode, 2.5 MHz output in 10 Mbits/s nibble mode, and 10 MHz in 10 Mbits/s serial mode. MRXCLK has a worst-case 35/65 duty cycle. MRXCLK provides the timing reference for the transfer of MRX_DV, MRXD, and MRX_ER signals. MRX_DV O Receive data valid. When this signal is high, it indicates that the 10/100 ethernet transceiver macrocell is recovering and decoding valid nibbles on MRXD[3:0], and the data is synchronous with MRXCLK. MRX_DV is synchronous with MRXCLK. This signal is not used in serial 10 Mbits/s mode. Agere Systems Inc. 143 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) Table 122. MII/5-Bit Serial Interface Signals (continued) Signal Type MRXD[3:0] O Description Receive data. 4-bit parallel data outputs that are synchronous to MRXCLK. When MRX_ER is asserted high in 100 Mbits/s mode, an error code will be presented on MRXD[3:0] where appropriate. The codes are as follows: Packet errors: ERROR_CODES = 2h. Link errors: ERROR_CODES = 3h. (Packet and link error codes will only be repeated if register MR29, bit 9, and register MR29, bit 8 are enabled.) Premature end errors: ERROR_CODES = 4h. Code errors: ERROR_CODES = 5h. When SER_SEL_PIN is active-high and 10 Mbits/s mode is selected, MRXD[0] is used for data output and MRXD[3:1] are 3-stated. MRX_ER O Receive error. When high, MRX_ER indicates the 10/100 Ethernet transceiver macrocell has detected a coding error in the frame presently being received. MRX_ER is synchronous with MRXCLK. MTXCLK O Transmit clock. 25 MHz clock output in 100 Mbits/s mode, 2.5 MHz output in 10 Mbits/s MII mode, and 10 MHz output in 10 Mbits/s serial mode. MTXCLK provides timing reference for the transfer of the MTX_EN, MTXD, and MTX_ER signals sampled on the rising edge of MTXCLK. MTXD[3:0] I Transmit data. 4-bit parallel input synchronous with MTXCLK. When SER_SEL_PIN is active-high and 10 Mbits/s mode is selected, only MTXD[0] is valid. MTX_EN I Transmit enable. When driven high, this signal indicates there is valid data on MTXD[3:0]. MTX_EN is synchronous with MTXCLK. When SER_SEL_PIN is activehigh and 10 Mbits/s mode is selected, this signal indicates there is valid data on MTXD[0]. MTX_ER I Transmit coding error. When driven high, this signal causes the encoder to intentionally corrupt the byte being transmitted across the MII (00100 will be transmitted). When the encoder/decoder bypass bit is set, this input serves as the MTXD[4] input. When in 10 Mbits/s mode, this signal is ignored. MDC I Management data clock. This is the timing reference for the transfer of data on the MDIO signal. This signal may be asynchronous to MRXCLK and MTXCLK. The maximum clock rate is 25 MHz. This is driven from the repeater. MDIO_IN I Management data input. Control information is driven by the station management, synchronous with MDC, onto this input. MDIO_OUT O Management data output. Status information is driven by the 10/100 Ethernet transceiver macrocell, synchronous with MDC, onto this output. MDIO_HI_Z O Management data output enable. When high, this signal can be used to 3-state the MDIO bidirectional buffer (external to the 10/100 Ethernet transceiver macrocell). 144 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) Table 122. MII/5-Bit Serial Interface Signals (continued) Signal Type INT_MASK I Description Interrupt mask. When set high, no interrupt is generated under any condition. When set low, interrupts are generated according to INT_CONF. This signal is ORed with FULL_DUP. INT_R31 O Maskable status interrupt. This signal will go high whenever there is a change in status. 12.4.2 10/100 Mbits/s Twisted Pair (TP) Interface Signals Some of the signals listed below are internal to the device and are not accessible; they are listed for information only. Table 123. 10/100 Mbits/s Twisted Pair (TP) Interface Signals Signal Type TPI[1] PADI Received data. Positive differential received 125 Mbaud MLT3 or 10 Mbaud Manchester data from magnetics. TPIB[1] PADI Received data. Negative differential received 125 Mbaud MLT3 or 10 Mbaud Manchester data from magnetics. TPO[1] PADO Transmit data. Positive differential transmit 125 Mbaud MLT3 or 10 Mbaud Manchester data to magnetics. TPOB[1] PADO Transmit data. Negative differential transmit 125 Mbaud MLT3 or 10 Mbaud Manchester data to magnetics. REXT10 PADO Current setting 10 Mbits/s. An external resistor 21.0 kΩ ± 1% is placed from this signal to ground to set the 10 Mbits/s TP driver transmit output level. REXT100 PADO Current setting 100 Mbits/s. An external resistor 21.5 kΩ ±1% is placed from this signal to ground to set the 100 Mbits/s TP driver transmit output level. REXTBS PADO Band gap reference for the receive channel. Connect this signal to a 24.9 kΩ ± 1% resistor to ground. The parasitic load capacitance should be less than 15 pF. Agere Systems Inc. Description 145 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) 12.4.3 Status Signals The signals listed in the following table are accessible via package pins and are described for clarity. Table 124. Status Signals Signal XS LS10_OK LS100_OK Type Description O Transmit status. This signal indicates transmit activity. Every transmit activity causes a 2.5 s on, 2.5 s off blink. O Link10. This signal indicates good link status for 10 Mbits/s. O Link100. This signal indicates good link status for 100 Mbits/s. 12.4.4 Clock and Reset Signals The signals listed in the following table are accessible via package pins and are described for clarity. Table 125. Clock and Reset Signals Signal Type Description RMCLK I RMCLK is internally tied low, and is unused. It should be left open to avoid possible EMI issues. XLO I Crystal oscillator input. A 25 MHz crystal ±25 ppm should be connected across XLO and XHI. Alternately, a 25 MHz external CMOS oscillator can be connected to this input. XHI O Crystal oscillator output. 12.5 MII Station Management The primary function of the MII station management is to transfer control and status information about the 10/100 Ethernet transceiver macrocell to a management entity. This function is accomplished by the MDC clock input that has a maximum frequency of 25 MHz, and with the MDIO signal. The MII station management interface uses MDC and MDIO to physically transport information between the PHY and the MII station management entity. In the 10/100 Ethernet transceiver macrocell, the MDIO pin is implemented as the following three signals: ■ MDIO_IN ■ MDIO_OUT ■ MDIO_HIZ MDIO_IN is the information coming from the MAC and is ignored during the TA and DATA fields for MDIO reads. MDIO_HIZ will be high except during MDIO reads, in which case MDIO_OUT is the PHY data. Under no condition should the input MDIO_IN be 3-stated. These can be connected to control an I/O buffer if off-chip access is required. 146 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) A specific set of registers and their contents (see Table 127 on page 148) defines the nature of the information transferred across the MDIO interface. Frames transmitted on the MII station management interface will have the frame structure shown in Table 126 below. The order of bit transmission is from left to right. Note: Reading and writing the MII management register must be completed without interruption. 12.5.1 MII Management Frame Format Table 126. MII Management Frame Format R/W R W PRE 1...1 1...1 Field PRE ST OP PHYADD REGAD TA DATA IDLE ST 01 01 OP 10 01 PHYADD AAAAA AAAAA REGAD RRRRR RRRRR TA Z0 10 DATA DDDDDDDDDDDDDDDD DDDDDDDDDDDDDDDD IDLE Z Z Description Preamble. The 10/100 Ethernet transceiver macrocell will accept frames with no preamble. This is indicated by a 1 in MR1 status register, bit 6 (NO_PA_OK). Start of frame. The start of frame is indicated by a 01 pattern. Operation code. The operation code for a read transaction is 10. The operation code for a write transaction is a 01. PHY address. The PHY address is 5 bits, allowing for 32 unique addresses. The first PHY address bit transmitted and received is the MSB of the address. A station management entity that is attached to multiple PHY entities must have prior knowledge of the appropriate PHY address for each entity. Register address. The register address is 5 bits, allowing for 32 unique registers within each PHY. The first register address bit transmitted and received is the MSB of the address. Turnaround. The turnaround time is a 2-bit time spacing between the register address field, and the data field of a frame, to avoid drive contention on MDIO during a read transaction. During a write to the 10/100 Ethernet transceiver macrocell, these bits are driven to 10 by the station. During a read, the MDIO is not driven during the first bit time and is driven to a 0 by the 10/100 Ethernet transceiver macrocell during the second bit time. Data. The data field is 16 bits. The first bit transmitted and received will be bit 15 of the register being addressed. Idle condition. The IDLE condition on MDIO is a high-impedance state. All three state drivers will be disabled and the PHY’s pull-up resistor will pull the MDIO line to a logic 1. Agere Systems Inc. 147 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) 12.5.2 Summary of Management Registers Table 127. Summary of Management Registers (MR) Address 0 1 2 3 4 5 Register MR0 MR1 MR2 MR3 MR4 MR5 5 MR5 6 7 8:15 16 17 MR6 MR7 MR8:MR15 MR16 MR17 18 MR18 19 20 21 22 23 24 25 26 27 28 29 30 MR19 MR21 MR22 MR23 MR24 MR25 MR26 MR27 MR28 MR29 MR30 MR31 148 Register Type Control (see Table 128 on page 149). Status (see Table 129 on page 150). PHY identifier 1 (see Table 130 on page 150). PHY identifier 2 (see Table 130 on page 150). Autonegotiation advertisement (see Table 131 on page 151). Autonegotiation link partner ability (base page) (see Table 132 on page 151). Autonegotiation link partner (LP) ability (see Table 133 on page 152). Autonegotiation expansion (see Table 134 on page 152). Next page transmit (see Table 135 on page 153). Reserved. PCS control register (see Table 136 on page 153). Autonegotiation (read register A) (see Table 137 on page 154). Autonegotiation (read register B) (see Table 138 on page 154). Agere analog test register. RXER counter (see Table 139 on page 155). Reserved. Reserved. Reserved. Reserved. Reserved. Reserved. Device specific register 1 (see Table 140 on page 155). Device specific register 2 (see Table 141 on page 156). Device specific register 3 (see Table 142 on page 157). Device specific register 4 (see Table 143 on page 158). Default Hex 3000 7849 TBD TBD 01E1 0000 0000 0000 0000 — 0000 0000 0000 — 0000 — — — 2080 0000 — Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) 12.5.3 MR0 Control Register Bit Description Table 128. MR0 Control Register Bit Description Bit # 15 14 13 12 11 10 9 8 Name SW_RESET LOOPBACK SPEED100 NWAY_ENA PWRDN ISOLATE REDONWAY FULL_DUP Type R/W R/W R/W R/W R/W R/W R/W R/W 7 COLTST R/W 6:0 RESERVED NA Agere Systems Inc. Description Reset. Setting this bit to a 1 will reset the 10/100 ethernet transceiver macrocell. All registers will be set to their default state. This bit is self-clearing. Default = 0. Loopback. When this bit is set to 1, no data transmission will take place on the media. Any receive data will be ignored. The loopback signal path will contain all circuitry up to, but not including, the PMD. Default = 0. Speed selection. The value of this bit reflects the current speed of operation (1 = 100 Mbits/s; 0 = 10 Mbits/s). This bit will only affect operating speed when the autonegotiation enable bit (MR0, bit 12) is disabled (0). This bit is ignored when autonegotiation is enabled (MR0, bit 12). This bit is ANDed with the SPEED_PIN signal. Autonegotiation enable. The autonegotiation process will be enabled by setting this bit to a 1. Default = 1. Powerdown. The 10/100 Ethernet transceiver macrocell may be placed in a low-power state by setting this bit to a 1 both the 10 Mbits/s transceiver and the 100 Mbits/s transceiver will be powered down. While in the powerdown state, the 10/100 Ethernet transceiver macrocell will respond to management transactions. Default = 0. Isolate. When this bit is set to a 1, the MII outputs will be brought to the highimpedance state. Default = 0. Restart autonegotiation. Normally, the autonegotiation process is started at powerup. The process may be restarted by setting this bit to 1. NWAYDONE in MR1 is reset when this bit goes to a 1. This bit is self-cleared when autonegotiation restarts. Default = 0. Duplex mode. This bit reflects the mode of operation (1 = full duplex; 0 = half duplex). This bit is ignored when quick status NWAY_ENA in MR0 is enabled. This bit is ORed with the F_DUP pin. Default = 0. Collision test. When this bit is set to a 1, the 10/100 Ethernet transceiver macrocell will assert the MCOL signal in response to MTX_EN. Reserved. All bits will read 0. 149 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) 12.5.4 MR1 Status Register Bit Description Table 129. MR1 Status Register Bit Description Bit # 15 14 13 12 11 10:7 6 Name T4ABLE TXFULDUP TXHAFDUP ENFULDUP ENHAFDUP RESERVED NO_PA_OK Type R R R R R R R 5 NWAYDONE R 4 REM_FLT R 3 NWAYABLE R 2 LSTAT_OK R 1 JABBER R 0 EXT_ABLE R Description 100Base-T4 ability. This bit will always be a 0. (Not able.) 100Base-TX full-duplex ability. This bit will always be a 1. (Able.) 100Base-TX half-duplex ability. This bit will always be a 1. (Able.) 10Base-T full-duplex ability. This bit will always be a 1. (Able.) 10Base-T half-duplex ability. This bit will always be a 1. (Able.) Reserved. All bits will read as a 0. Suppress preamble. When this bit is set to a 1, it indicates that the 10/100 Ethernet transceiver macrocell accepts management frames with the preamble suppressed. Autonegotiation complete. When this bit is a 1, it indicates the autonegotiation process has been completed. The contents of registers MR4, MR5, MR6, and MR7 are now valid. This bit is reset when autonegotiation is started. Default= 0. Remote fault. When this bit is a 1, it indicates a remote fault has been detected. This bit will remain set until cleared by reading the register. Default = 0. Autonegotiation ability. This bit indicates the ability to perform autonegotiation. The value of this bit is always a 1. Link status. When this bit is a 1, it indicates that a valid link has been established. This bit has a latching function: a link failure will cause the bit to clear and stay cleared until it has been read via the management interface. Jabber detect. This bit will be a 1 whenever a jabber condition is detected. It will remain set until it is read, and the jabber condition no longer exists. Extended capability. This bit indicates that the 10/100 Ethernet transceiver macrocell supports the extended register set (register MR2 and beyond). It will always read a 1. 12.5.5 MR2 MR3 PHY Identifier Registers (1 and 2) Bit Description Table 130. MR2 MR3 PHY Identifier Registers (1 and 2) Bit Description Bit # 15:0 of MR2 Name OUI[3:18] 15:10 of MR3 OUI[24:19] 9:4 of MR3 MODEL[5:0] 3:0 of MR3 VERSION[3:0] 150 Type Description R Organizationally unique identifier. The third through the twenty-fourth bit of the OUI assigned to the PHY manufacturer by the IEEE are placed in bits 15:0 (MR2) and 15:10 (MR3). This value is all ones. R Organizationally unique identifier. The remaining 6 bits of the OUI. The value for bits 24:19 is all ones. R Model number. 6-bit model number of the device. The model number is all zeros. R Revision number. The value of the present revision number. The version number is all zeros. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) 12.5.6 MR4 Autonegotiation Advertisement Register Bit Description Table 131. MR4 Autonegotiation Advertisement Register Bit Description Bit # 15 Name NEXT_PAGE Type R/W 14 13 ACK REM_FAULT R/W R/W 12:10 PAUSE R/W 9 8 100BASET4 100BASET_FD R/W R/W 7 100BASETX R/W 6 10BASET_FD R/W 5 10BASET R/W 4:0 SELECT R/W Description Next page. The next page function is activated by setting this bit to a 1. This will allow the exchange of additional data. Data is carried by optional next pages of information. Acknowledge. This bit is the acknowledge bit from the link code word. Remote fault. When set to 1, the 10/100 Ethernet transceiver macrocell indicates to the link partner a remote fault condition. Pause. When set to a 1, it indicates that the 10/100 Ethernet transceiver macrocell 10/100 Ethernet transceiver macrocell wishes to exchange flow control information with its link partner. 100Base-T4. This bit should always be set to 0. 100Base-TX full-duplex. If written to 1, autonegotiation will advertise that the 10/100 Ethernet transceiver macrocell is capable of 100Base-TX full-duplex operation. 100Base-TX. If written to 1 autonegotiation will advertise that the 10/100 Ethernet transceiver macrocell is capable of 100Base-TX operation. 10Base-T full-duplex. If written to 1, autonegotiation will advertise that the 10/100 Ethernet transceiver macrocell is capable of 10Base-T full-duplex operation. 10Base-T. If written to 1, autonegotiation will advertise that the 10/100 Ethernet transceiver macrocell is capable of 10Base-T operation. Selector field. Reset with the value 00001 for IEEE 802.3. 12.5.7 MR5 Autonegotiation Link Partner Ability (Base Page) Register Bit Description Table 132. MR5 Autonegotiation Link Partner Ability (Base Page) Register Bit Description Bit # 15 Name LP_NEXT_PAGE Type R 14 LP_ACK R 13 LP_REM_FAULT R 12:5 LP_TECH_ABILITY R 4:0 LP_SELECT R Agere Systems Inc. Description Link partner next page. When this bit is set to 1, it indicates that the link partner wishes to engage in next page exchange. Link partner acknowledge. When this bit is set to 1, it indicates that the link partner has successfully received at least three consecutive and consistent FLP (fast link pulse) bursts. Remote fault. When this bit is set to 1, it indicates that the link partner has a fault. Technology ability field. This field contains the technology ability of the link partner. These bits are similar to the bits defined for the MR4 register (see Table 131 on page 151). Selector field. This field contains the type of message sent by the link partner. For IEEE 802.3u 1995 compliant link partners, this field should read 00001. 151 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) 12.5.8 MR5 Autonegotiation Link Partner (LP) Ability Register (Next Page) Bit Description Table 133. MR5 Autonegotiation Link Partner (LP) Ability Register (Next Page) Bit Description Bit # 15 Name LP_NEXT_PAGE Type R 14 LP_ACK R 13 LP_MES_PAGE R 12 LP_ACK2 R 11 LP_TOGGLE R Description Next page. A logic 0 indicates that this is the last page to be transmitted. A logic 1 indicates that additional pages will follow. Acknowledge. When this bit is set to a logic 1, it indicates that the link partner has successfully received its partner’s link code word. Message page. This bit is used by the NEXT _PAGE function to differentiate a message page (logic 1) from an unformatted page (logic 0). Acknowledge 2. This bit is used by the NEXT_PAGE function to indicate that a device has the ability to comply with the message (logic 1) or not (logic 0). Toggle. This bit is used by the arbitration function to ensure synchronization with the link partner during next-page exchange. Logic 0 indicates that the previous value of the transmitted link code word was logic 1. 10:0 MCF R Logic 1 indicates that the previous value of the transmitted link code word was logic 0. Message/unformatted code field. With these 11 bits, there are 2048 possible messages. Message code field definitions are described in annex 28C of the IEEE 802.3u 1995 standard. 12.5.9 MR6 Autonegotiation Expansion Register Bit Description . Table 134. MR6 Autonegotiation Expansion Register Bit Description Bit # 15:5 4 Name RESERVED PAR_DET_FAULT Type R R/LH* 3 LP_NEXT_PAGE_ABLE R 2 NEXT_PAGE_ABLE R 1 PAGE_REC R/LH* 0 LP_NWAY_ABLE R Description Reserved. Parallel detection fault. When this bit is set to 1, it indicates that a fault has been detected in the parallel detection function. This fault is due to more than one technology detecting concurrent link conditions. This bit can only be cleared by reading this register. Link partner next page able. When this bit is set to 1, it indicates that the link partner supports the next page function. Next page able. This bit is set to 1 indicating that this device supports the NEXT_PAGE function. Page received. When this bit is set to 1, it indicates that a NEXT_PAGE has been received Link partner autonegotiation capable. When this bit is set to 1, it indicates that the link partner is autonegotiation capable. * LH = latched high. 152 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) 12.5.10 MR7 Next Page Transmit Register Bit Description Table 135. MR7 Next Page Transmit Register Bit Description Bit # 15 14 13 12 11 Name NEXT_PAGE ACK MESSAGE ACK2 TOGGLE Type R/W R R/W R/W R Description Next page. This bit indicates whether or not this is the last next page to be transmitted. If 0, it indicates that this is the last page. If 1, it indicates there is an additional next page. Acknowledge. This bit is the acknowledge bit from the link code word. Message page. This bit is used to differentiate a message page from an unformatted page. If 0, it indicates an unformatted page. If 1, it indicates a formatted page. Acknowledge 2. This bit is used by the next page function to indicate that a device has the ability to comply with the message. It is set as follows: If 0, it indicates the device cannot comply with the message. If 1, it indicates the device will comply with the message. Toggle. This bit is used by the arbitration function to ensure synchronization with the link partner during next page exchange. This bit will always take the opposite value of the toggle bit in the previously exchanged link code word. If the bit is a logic 0, the previous value of the transmitted link code word was a logic 1. 10:0 MCF R/W If the bit is a 1, the previous value of the transmitted link code word was a 0. The initial value of the toggle bit in the first next page transmitted is the inverse of the value of bit 11 in the base link code word, it assumes a value of 1 or 0. Message/unformatted code field. (2048 possible messages with these 11 bits.) 12.5.11 MR16 PCS Control Register Bit Description Table 136. MR16 PCS Control Register Bit Description Bit # 15 14:12 11:4 Name LOCKED RSVD TESTBITS Type R R R/W 3 LOOPBACK R/W 2 1 SCAN FORCE LOOPBACK R/W R/W 0 SPEEDUP COUNTERS R/W Agere Systems Inc. Description Locked. Locked pin from descrambler block. Reserved. Will always be read back as 0. Generic test bits. These bits are for manufacturing test only. A 0 should be written to these bits. Loopback configure. If high, the entire loopback is performed in the PCS macro. If low, only the collision pin is disabled in loopback. Scan test mode. Force loopback. Force a loopback without forcing idle on the transmit side or disabling the collision pin. Speed-up counters. Reduce link monitor counter to 10 ms from 620 µs. (Same as FASTTEST = 1.) 153 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) 12.5.12 MR17 Autonegotiation (Read Register A) Table 137. MR17 Autonegotiation (Read Register A) Bit # 15:13 12 11 10 9 8 7 6 5 4 3 2 1 0 Name RSVD NPW WL WA WB PDF AE FLPL CA AD FLG LSC ADE TD Type — R R R R R R R R R R R R R Description Reserved. Always 0. Next page wait. Wait Link_Fail_Inhibit_Wait_Timer (link status check). Wait Autoneg_Wait_Timer (link status check). Wait Break_Link_Timer (transmit disable). Parallel detection fault. Autonegotiation enable. FLP link good check. Complete acknowledge. Acknowledge detect. FLP link good. Link status check. Ability detect. Transmit disable. 12.5.13 MR18 Autonegotiation (Read Register B) . Table 138. MR18 Autonegotiation (Read Register B) Bit # 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 154 Name RFLP FPASS LPC LPD TP TFC TFE WMT DF TF TC TDB TCB TA TR I Type R R R R R R R R R R R R R R R R Description Receiving FLPs. Any of FLP capture, clock, DATA_0, or DATA_1. FLP pass (FLP Rcv). Link pulse count (FLP Rcv). Link pulse detect (FLP Rcv). Test pass (NLP receive). Test fail count (NLP receive). Test fail extend (NLP receive). Wait max timer ack (NLP receive). Detect freeze (NLP receive). Test fail (NLP receive). Transmit count ack (FLP transmit). Transmit data bit (FLP transmit). Transmit clock bit (FLP transmit). Transmit ability (FLP transmit). Transmit remaining acknowledge (FLP transmit). Idle (FLP transmit). Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) 12.5.14 MR21 RXER Counter Table 139. MR21 RXER Counter 8-Bit, 16-Bit Mode Select Bit 0 is the only bit that can be written to and it selects the operating mode of this register. Setting bit 0 specifies 16-bit or 8-bit counter mode and the indicated register map shown below is used. Bit # Name Type 0 MCWO W Description 16-bit, 8-bit counter mode. If 1, the register is put in an 8-bit counter mode. If 0, the register is put in a 16-bit counter mode. This bit is reset to 0 and can’t be read (write only). 16-Bit Mode, Read-Only (Bit 0 written to 0) 15:0 MC16 R 16-bit counter mode. When in 16-bit counter mode (MCWO = 0), these bits maintain a count of RXERs. This bit is reset on a read operation. 8-Bit Mode, Read-Only (Bit 0 written to 1) 15:12 CDE R Disconnect events count. When in 8-bit mode (MCWO = 1), these bits contain a count of disconnect events, (link unstable 6). This bit is reset on a read operation. 11:8 CFER R False error count. When in 8-bit mode (MCWO = 1), these bits contain a count of false error events. This bit is reset on a read operation. 7:0 MC8 R 8-bit counter mode. When in 8-bit counter mode (MCWO = 1), these bits maintain a count of RXERs. This bit is reset on a read operation. 12.5.15 MR28 Device-Specific Register 1 (Status Register) Bit Description Table 140. MR28 Device-Specific Register 1 (Status Register) Bit Description Bit # 15:9 8 Name RSVD BAD_FRM Type R R/LH* 7 CODE R/LH* 6 5 RSVD DISCON R R/LH* 4 UNLOCKED R/LH* Description Reserved. Read as 0. Bad frame. If this bit is a 1, it indicates that a packet has been received without an SFD. This bit is latching high and will only clear after it has been read or the device has been reset. This bit is only valid in 10 Mbits/s mode. Code violation. When this bit is a 1, it indicates that a Manchester code violation has occurred. Reserved. Disconnect. If this bit is a 1, it indicates a disconnect. This bit will latch high until read. This bit is only valid in 100 Mbits/s mode. Unlocked. Indicates that the TX scrambler lost lock. This bit will latch high until read. This bit is only valid in 100 Mbits/s mode. * LH = latched high. Agere Systems Inc. 155 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) Table 140. MR28 Device-Specific Register 1 (Status Register) Bit Description (continued) Bit # 3 Name RXERR_ST Type R/LH* Description RX error status. Indicates a false carrier. This bit will latch high until read. 2 FRC_JAM R/LH* This bit is only valid in 100 Mbits/s mode. Force jam. This bit will latch high until read. 1 LNK100UP R 0 LNK10UP R This bit is only valid in 100 Mbits/s mode. Link up 100. When this bit is set to a 1, it indicates that a 100 Mbits/s transceiver is up and operational. Link up 10. When this bit is set to a 1, it indicates that a 10 Mbits/s transceiver is up and operational. * LH = latched high. 12.5.16 MR29 Device-Specific Register 2 (100 Mbits/s Control) Bit Description Table 141. MR29 Device-Specific Register 2 (100 Mbits/s Control) Bit Description Bit # 15 14 13 12 11 Name LOCALRST RST1 RST2 100_OFF RSVD Type R/W Description Management reset. This is the local management reset bit. Writing a logic 1 to this bit will cause the lower 16 registers and registers MR28 and MR29 to be reset to their default values. R/W R/W R/W This bit is self-clearing. Generic reset 1. This register is used for manufacture test only. Generic reset 2. This register is used for manufacture test only. 100 Mbits/s transmitter off. R/W If set to 0, it forces TPI low and TPIN high. Default = 1. Reserved. 10 CRS_SEL R/W 9 LINK_ERR R/W Default = 0. Carrier sense select. MCRS will be asserted on receive only when this bit is set to a 1. If this bit is set to logic 0, MCRS will be asserted on receive or transmit. This bit should be set to one when the repeater is used, and cleared to zero when the repeater is bypassed. This bit is ORed with the CRS_SEL pin. Link error indication. If 1, a link error code will be reported on MRXD[3:0] of the 10/100 Ethernet transceiver macrocell when MRX_ER is asserted on the MII. The specific error codes are listed in the MRXD pin description. 8 PKT_ERR R/W If it is 0, it will disable this function. Packet error indication enable. If 1, a packet error code, that indicates that the scrambler is not locked, will be reported on MRXD[3:0] of the 10/100 Ethernet transceiver macrocell when MRX_ER is asserted on the MII. If 0, it will disable this function. 156 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) Table 141. MR29 Device-Specific Register 2 (100 Mbits/s Control) Bit Description (continued) Bit # 7 Name RSVD Type R/W Reserved. 6 EDB R/W Default = 0. Encoder/decoder bypass. R/W If 1, the 4B/5B encoder and 5B/4B decoder function will be disabled. Symbol aligner bypass. R/W If 1, the aligner function will be disabled. Scrambler/descrambler bypass. 5 4 SAB SDB Description If 1, the scrambling/ descrambling functions will be disabled. 3 CARIN_EN R/W This bit is ORed with the SDBT pin. Carrier integrity enable. If 1, carrier integrity is enabled. 2 1 0 JAM_COL FEF_EN RSVD R/W R/W R/W This bit is ORed with the CARIN_EN pin. Jam enable. If 1, it enables JAM associated with carrier integrity to be ORed with MCOLMCRS. Far-end fault enable. This bit is used to enable the far-end fault detection and transmission capability. This capability may only be used if autonegotiation is disabled. This capability is to be used only with media that does not support autonegotiation. Setting this bit to 1 enables farend fault detection, and logic 0 will disable the function. Default = 0. Reserved, should be programmed to 0. 12.5.17 MR30 Device-Specific Register 3 (10 Mbits/s Control) Bit Description Table 142. MR30 Device-Specific Register 3 (10 Mbits/s Control) Bit Description Bit # 15:14 13 Name RSVD JAB_DIS Type R/W R/W Description Reserved. Read as 0. Jabber disable. If 1, disables the jabber function of the 10Base-T receive. 12:6 5 RSVD HBT_EN R/W R/W Default = 0. Reserved. Read as 0. Heartbeat enable. If 1, the heartbeat function will be enabled. Valid in 10 Mbits/s mode only. Agere Systems Inc. 157 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) Table 142. MR30 Device-Specific Register 3 (10 Mbits/s Control) Bit Description (continued) Bit # 4 Name ELL_EN Type R/W Description Extended line length enable. If 1, the receive squelch levels are reduced from a nominal 435 mV to 350 mV, allowing reception of signals with a lower amplitude. 3 APF_EN Valid in 10 Mbits/s mode only. Autopolarity function disable. R/W If 0, and the 10/100 Ethernet transceiver macrocell is in 10 Mbits/s mode, the autopolarity function will determine if the TP link is wired with a polarity reversal. 2 1 RESERVED SERIAL _SEL R/W R/W 0 ENA_NO_LP R/W If 1, and the device is in 10 Mbits/s mode, the reversal will not be corrected. Reserved. Serial select. If set to a 1, the 10 Mbits/s serial mode will be selected. When the 10/100 Ethernet transceiver macrocell is in 100 Mbits/s mode, this bit will be ignored. This bit should be set to one when the repeater is used, and cleared to zero when the repeater is bypassed. No link pulse mode. Setting this bit to a 1 will allow 10 Mbits/s operation with link pulses disabled. If the 10/100 Ethernet transceiver macrocell is configured for 100 Mbits/s operation, setting this bit will not affect operation. 12.5.18 MR31 Device-Specific Register 4 (Quick Status) Bit Description Table 143. MR31 Device-Specific Register 4 (Quick Status) Bit Description Bit # 15 Name ERROR Type R Description Receiver error. If 1, it indicates that a receive error has been detected. This bit is valid in 100 Mbits/s only. This bit will remain set until cleared by reading the register. 14 RXERR_ST LINK_STAT_CHANGE R Default = 0. False carrier. When INT_CONF is set to 0 and this bit is a 1, it indicates that the carrier detect state machine has found a false carrier. This bit is valid in 100 Mbits/s only. This bit will remain set until cleared by reading the register. Default = 0. 13 REM_FLT R Link status change. When INT_CONF is set to a 1, this bit is redefined to become the LINK_STAT_CHANGE bit and goes high whenever there is a change in link status (LSTAT_OK changes state). Remote fault. If 1, it indicates that a remote fault has been detected. This bit will remain set until cleared by reading the register. Default = 0. 158 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 12 Ethernet 10/100 PHY(s) (continued) Table 143. MR31 Device-Specific Register 4 (Quick Status) Bit Description (continued) Bit # 12 Name UNLOCKED/JABBER Type R Description Unlocked/jabber. If this bit is set when operating in 100 Mbits/s mode, it indicates that the TX descrambler has lost lock. If this bit is set when operating in 10 Mbits/s mode, it indicates a jabber condition has been detected. 11 10 9 8 7 LSTAT_OK PAUSE SPEED100 FULL_DUP INT_CONF R This bit will remain set until cleared by reading the register. Link status. R If 1, it indicates that a valid link has been established. This bit has a latching low function as follows: a link failure will cause the bit to clear and stay cleared until it has been read via the management interface. Link partner pause. R If 1, it indicates that the external PHY wishes to exchange flow control information. Link speed. R If 1, it indicates that the link has negotiated to 100 Mbits/s. If 0, it indicates that the link is operating at 10 Mbits/s. Duplex mode. R/W If 1, it indicates that the link has negotiated to full-duplex mode. If 0, it indicates that the link has negotiated to half-duplex mode. Interrupt configuration. If 0, it defines RXERR_ST/LINK_STAT_CHANGE to be the RXERR_ST bit, and the interrupt pin MASK_STAT_INT goes high whenever any of bits [31.15:12] go high or LSAT_OK goes low. When this bit is set high, it redefines bit 14 to become the LINK_STAT_CHANGE bit, and the interrupt pin MASK_STAT_INT goes high only when the link status changes (bit 14 goes high). 6 INT_MASK R/W Defaults = 0. Interrupt mask. When set high, no interrupt is generated by this channel under any condition. When set low, interrupts are generated according to INT_CONF. Agere Systems Inc. 159 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 12 Ethernet 10/100 PHY(s) (continued) Table 143. MR31 Device-Specific Register 4 (Quick Status) Bit Description (continued) Bit # 5:3 2:0 160 Name LOW_AUTO_STATE HI_AUTO_STATE Type R R Description Lowest autonegotiation state. These 3 bits report the state of the lowest autonegotiation state reached since the last register read, in the priority order defined below: 000: Autonegotiation enable. 001: Transmit disable or ability detect. 010: Link status check. 011: Acknowledge detect. 100: Complete acknowledge. 101: FLP link good check. 110: Next page wait. 111: FLP link good. Highest autonegotiation state. These 3 bits report the state of the highest autonegotiation state reached since the last register read, as defined above for LOW_AUTO_STATE. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller ■ Full compliance with Universal Serial Bus Specification Revision 1.0. ■ OpenHCI open-host controller interface specification for USB release 1.0 compatible. ■ Integrated dual-speed USB transceiver. ■ Supports all USB compliant devices and hubs. ■ Integrated dual-speed USB transceivers enable a single-chip USB solution. Note: The legacy peripherals feature, as defined in OpenHCI specification version 1.0, is not supported. 13.1 Description The USB host controller provides a downstream USB port to connect to any USB compliant device on hub. Fullspeed or low-speed peripherals are supported along with all of the USB transfer types: control, interrupt, bulk, or isochronous. The USB host controllers OpenHCI compliance offers significant USB performance benefits and reduced ARM overhead. The USB APB interface requires that the system clock frequency be equal to or greater than the 48 MHz USB clock to function correctly. The USB host controller is a master on the IPT_ARM system bus (ASB). A complete explanation of the USB operation is beyond the scope of this document. The user should refer to the OpenHCI Specification version 1.0 for an explanation of how to set up and use the USB. Every device on the USB bus is specified to the USB host controller by one or more endpoint descriptors (ED). These endpoint descriptors are placed on the interrupt list, the control list, or the bulk list by software. Isochronous end points are placed on the interrupt list at the end of all interrupt endpoints. Each item placed on a list is linked to all the other items on that list. Interrupt endpoints, depending on where they are linked on the list, can be checked every 1, 2, 4, 8, 16, or 32 ms. Each endpoint descriptor can be linked to zero or more transfer descriptors. When an endpoint is checked, and if there is a valid transfer descriptor linked to it, the host controller will execute one transfer. The executed transfer has its descriptor removed from the endpoint list and moved to a done linked list. The Hc HCCA register points to a memory structure that defines the start and end of all interrupt endpoint lists. The control and bulk lists are pointed to by their own address pointer registers. Agere Systems Inc. 161 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) OHC (USB OpenHCI HOST CONTROLLER) HCI BUS INTERFACE TX FIFO DATA TX FIFO CONTROL DATA CONTROL ADDRESS REGISTER ADDRESS ARM ASB I/F OHCI ROOT HUB REGs DATA ADDRESS DATA USB INTERFACE HCI CONTROL LIST SLAVE CONTROL PROCESSOR BLOCK BLOCK OHCI REGs CONTROL USB STATE CONTROL CONTROL ROOT HUB AND HOST SIE TX CLOCK MUX 12/1.5 RX FIFO CONTROL DATA DATA 64 x 8 FIFO CONTROL DATA DATA RX HSIE S/M STATUS CONTROL FIFO STATUS RX FIFO STATUS HCI MASTER BLOCK CONTROL DATA DPLL U X C V R USB PORT S/M U X C V R USB U X C V R USB ROOT HUB CONFIG BLOCK PORT S/M DATA ASB MASTER S/M ADDRESS/ DATA ED & TD REGs ADDRESS HCI BUS DATA DATA PORT S/M DATA FIFO 64 x 8 APB REGISTER INTERFACE ARM APB I/F 5-5595 (F)a. Figure 21. USB Block Diagram 13.2 USB Registers The host controller (HC) contains a set of on-chip operational registers that are mapped into a noncachable portion of the system-addressable space. These registers are used by the host controller driver (HCD). According to the function of these registers, they are divided into four partitions, specifically for control and status, memory pointer, frame counter, and root hub. All of the registers should be read and written as 32-bit words. The OpenHCI specification may allocate reserve bits. To ensure interoperability, the host controller driver that does not use a reserved field should not assume that the reserved field contains a 0. Furthermore, the host controller driver should always preserve the value(s) of the reserved field(s). When an R/W register is modified, the host controller driver should first read the register, modify the bits desired, then write the register with the reserved bits still containing the read value. Alternatively, the host controller driver can maintain an in-memory copy of previously written values that can be modified and then written to the host controller register. When a write to set/clear register is written, bits written to reserved fields should be 0. 162 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) 13.2.1 USB Operational Registers Summary Table 144. USB Operational Register Map Register Hc revision (see Table 145 on page 163). Hc control (see Table 146 on page 164). Hc command status (see Table 147 on page 166). Hc interrupt status (see Table 148 on page 167). Hc interrupt enable (see Table 149 on page 169). Hc interrupt disable (see Table 150 on page 170). Hc HCCA (see Table 151 on page 171). Hc period current ED (see Table 152 on page 171). Hc control head ED (see Table 153 on page 172). Hc control current ED (see Table 154 on page 172). Hc bulkhead ED (see Table 155 on page 173). Hc bulk current ED (see Table 156 on page 173). Hc done head (see Table 157 on page 174). Hc Fm interval (see Table 158 on page 175). Hc Fm remaining (see Table 159 on page 175). Hc Fm number (see Table 160 on page 176). Hc periodic start (see Table 161 on page 176). Hc LS threshold (see Table 162 on page 177). Hc Rh descriptor A (see Table 163 on page 178). Hc Rh descriptor B (see Table 164 on page 180). Hc Rh status (see Table 165 on page 181). Hc Rh port status [1:NDP] (see Table 166 on page 182). Address 0XE000 7000 0XE000 7004 0XE000 7008 0XE000 700C 0XE000 7010 0XE000 7014 0XE000 7018 0XE000 701C 0XE000 7020 0XE000 7024 0XE000 7028 0XE000 702C 0XE000 7030 0XE000 7034 0XE000 7038 0XE000 703C 0XE000 7040 0XE000 7044 0XE000 7048 0XE000 704C 0XE000 7050 0XE000 7054 13.3 The Control and Status Partition 13.3.1 Hc Revision Register Table 145. Hc Revision Register Address 0xE000 7000 31:8 RSVD Bit # Name Bit # Key Reset 31:8 7:0 RSVD REV — 10H Agere Systems Inc. Read/Write HCD HC — — R R 7:0 REV Description Reserved. Revision. This read-only field contains the BCD representation of the version of the HCI specification that is implemented by this HC. For example, a value of 11h corresponds to version 1.1. All of the HC implementations that are compliant with this specification will have a value of 10h. 163 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.3.2 Hc Control Register The Hc Control register defines the operating modes for the host controller. Most of the fields in this register are modified only by the host controller driver, except host controller functional state and remote wake-up connected. Table 146. Hc Control Register 10 RWE 9 RWC 8 IR Address 0xE000 7004 7 6 5 HCFS BLE Bit # Name 31:11 RSVD Bit # Key Reset 31:11 10 RSVD RWE — 0b R/W HCD HC — — R/W R 9 RWC 0b R/W R/W 8 IR 0b R/W R 7:6 HCFS 00b R/W R/W 4 CLE 3 IE 2 PLE 1:0 CBSR Description Reserved. Remote wake-up enable. This bit is used by HCD to enable or disable the remote wake-up feature upon the detection of upstream resume signaling. When this bit is set and the RD bit in Hc interrupt status register (see Table 148 on page 167) is set, a remote wake-up is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt. Remote wake-up connected. This bit indicates whether HC supports remote wake-up signaling. If remote wake-up is supported and used by the system, it is the responsibility of system firmware to set this bit during post. HC clears the bit upon a hardware reset but does not alter it upon a software reset. Remote wake-up signaling of the host system is host-bus-specific, and is not described in this specification. Interrupt routing. This bit determines the routing of interrupts generated by events registered in Hc interrupt status register. If clear, all interrupts are routed to the normal host bus interrupt mechanism. If set, interrupts are routed to the system management interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC. Host controller functional state for USB. 00: USB 01: USB 10: USB 11: USB reset resume operational suspend A transition to USB operational from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the start of frame field of the Hc interrupt status register. This field may be changed by HC only when in the USB suspend state. HC may move from the USB suspend state to the USB resume state after detecting the resume signaling from a downstream port. HC enters USB suspend after a software reset, whereas it enters USB reset after a hardware reset. The latter also resets the root hub and asserts subsequent reset signaling to downstream ports. 164 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 146. Hc Control Register (continued) Bit # Key Reset 5 BLE 0b R/W HCD HC R/W R 4 CLE 0b R/W R 3 IE 0b R/W R 2 PLE 0b R/W R 1:0 CBSR 00b R/W R Description Bulk list enable. This bit is set to enable the processing of the bulk list in the next frame. If cleared by HCD, processing of the bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If the Hc bulk current ED register is pointing to an ED to be removed, HCD must advance the pointer by updating Hc bulk current ED register before re-enabling processing of the list. Control list enable. This bit is set to enable the processing of the control list in the next frame. If cleared by HCD, processing of the control list does not occur after the next start of frame (SOF). HC must check this bit whenever it determines to process the list. When disabled, HCD may modify the list. If the Hc Control current ED register is pointing to an ED to be removed, HCD must advance the pointer by updating the Hc Control current ED register before re-enabling processing of the list. Isochronous enable. This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a frame, HC checks the status of this bit when it finds an isochronous ED (F = 1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (that now contains only isochronous EDs) and begins processing the bulk/control lists. Setting this bit is guaranteed to take effect in the next frame (not the current frame). Periodic list enable. This bit is set to enable the processing of the periodic list in the next frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list. Control bulk service ratio. This specifies the service ratio between control and bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count to how many nonempty control EDs have been processed, to determine whether to continue serving another control ED or switching to bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value. CBSR 00 01 10 11 Agere Systems Inc. No. of Control EDs Over Bulk EDs Served 1:1 2:1 3:1 4:1 165 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.3.3 Hc Command Status Register The Hc command status register is used by the host controller to receive commands issued by the host controller driver, as well as reflecting the current status of the host controller. To the host controller driver, it appears to be a write to set the register. The host controller must ensure that bits written as 1 become set in the register, while bits written as 0 remain unchanged in the register. The host controller driver may issue multiple distinct commands to the host controller without concern for corrupting previously issued commands. The host controller driver has normal read access to all bits. The SOC field indicates the number of frames with that the host controller has detected the scheduling overrun error. This occurs when the periodic list does not complete before end of frame. When a scheduling overrun error is detected, the host controller increments the counter and sets the scheduling overrun field in the Hc interrupt status register (see Table 148 on page 167). Table 147. Hc Command Status Register Address 0xE000 7008 15:4 3 RSVD OCR Bit # Name 31:18 RSVD Bit # Key Reset 31:18 17:16 RSVD SOC — 00b Read/Write HCD HC — — R R/W 15:4 3 RSVD OCR — 0b — R/W — R/W 2 BLF 0b R/W R/W 166 17:16 SOC 2 BLF 1 CLF 0 HCR Description Reserved. Scheduling overrun count. These bits are incremented on each scheduling overrun error. It is initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if scheduling overrun in Hc interrupt status register (see Table 148 on page 167) has already been set. This is used by HCD to monitor any persistent scheduling problems. Reserved. Ownership change request. This bit is set by an OS HCD to request a change of control of the HC. When set, HC will set the ownership change field in the Hc interrupt status register. After the changeover, this bit is cleared and remains so until the next request from OS HCD. Bulk list filled. This bit is used to indicate whether there are any TDs on the bulk list. It is set by HCD whenever it adds a TD to an ED in the bulk list. When HC begins to process the head of the bulk list, it checks BLF. As long as BLF is 0, HC will not start processing the bulk list. If BLF is 1, HC will start processing the bulk list and will set BLF to 0. If HC finds a TD on the list, then HC will set BLF to 1, causing the bulk list processing to continue. If no TD is found on the bulk list, and if HCD does not set BLF, then BLF will still be 0 when HC completes processing the bulk list and bulk list processing will stop. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 147. Hc Command Status Register (continued) Bit # Key Reset 1 CLF 0b Read/Write HCD HC R/W R/W 0 HCR 0b R/W R/W Description Control list filled. This bit is used to indicate whether there are any TDs on the control list. It is set by HCD whenever it adds a TD to an ED in the control list. When HC begins to process the head of the control list, it checks CLF. As long as CLF is 0, HC will not start processing the control list. If CLF is 1, HC will start processing the control list and will set CLF to 0. If HC finds a TD on the list, then HC will set CLF to 1, causing the control list processing to continue. If no TD is found on the control list, and if the HCD does not set CLF, then CLF will still be 0 when HC completes processing the control list and control list processing will stop. Host controller reset. This bit is set by HCD to initiate a software reset of HC. Regardless of the functional state of HC, it moves to the USB suspend state in which most of the operational registers are reset except those stated otherwise; e.g., the IR field of Hc Control; no host bus accesses are allowed. This bit is cleared by HC upon the completion of the reset operation. The reset operation must be completed within 10 µs. This bit, when set, should not cause a reset to the root hub and no subsequent reset signaling should be asserted to its downstream ports. 13.3.4 Hc Interrupt Status Register This register provides status on various events that cause hardware interrupts. When an event occurs, the host controller sets the corresponding bit in this register. When a bit becomes set, a hardware interrupt is generated if the interrupt is enabled in the Hc interrupt enable register (see Table 149 on page 169) and the master interrupt enable bit is set. The host controller driver may clear specific bits in this register by writing 1 to bit positions to be cleared. The host controller driver may not set any of these bits. The host controller will never clear the bit. Table 148. Hc Interrupt Status Register Address 0xE000 700C 6 5 4 RHSC FNO UE 31 0 30 OC 29:7 RSVD Bit # Key Reset 31 30 — OC — 0b Read/Write HCD HC — — R/W R/W 29:7 RSVD — Bit # Name Agere Systems Inc. — — 3 RD 2 SF 1 WHD 0 SO Description — Ownership change. This bit is set by HC when HCD sets the ownership change request field in Hc command status register. This event, when unmasked, will immediately (always) generate a system management interrupt (SMI). This bit is tied to 0b when the SMI pin is not implemented. Reserved. 167 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) Table 148. Hc Interrupt Status Register (continued) Bit # Key Reset 6 RHSC 0b Read/Write HCD HC R/W R/W 5 FNO 0b R/W R/W 4 UE 0b R/W R/W 3 RD 0b R/W R/W 2 SF 0b R/W R/W 1 WDH 0b R/W R/W 0 SO 0b R/W R/W 168 Description Root hub status change. This bit is set when the content of Hc Rh status register or the content of any of Hc Rh port status register [number of downstream port] has changed. Frame number overflow. This bit is set when the MSB of the Hc Fm number register (bit 15) changes value, from 0 to 1 or from 1 to 0, and after the HC frame number register has been updated. Unrecoverable error. This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset. Resume detected. This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the USB resume state. Start of frame. This bit is set by HC at each start of a frame and after the update of the Hc Fm number register. HC also generates an SOF token at the same time. Write back done head. This bit is set immediately after HC has written Hc DoneHead to HccaDoneHead. Further updates of the Hcca done head register will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of HccaDoneHead. Scheduling overrun. This bit is set when the USB schedule for the current frame overruns and after the update of Hcca frame number register. A scheduling overrun will also cause the SOC of Hc command status register to be incremented. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) 13.3.5 Hc Interrupt Enable Register Each enable bit in the Hc interrupt enable register corresponds to an associated interrupt bit in the Hc interrupt status register. The Hc interrupt enable register is used to control which events generate a hardware interrupt. When a bit is set in the Hc interrupt status register and the corresponding bit in the Hc interrupt enable register is set and the MIE bit is set, then a hardware interrupt is requested on the host bus. Writing a 1 to a bit in this register sets the corresponding bit, whereas writing a 0 to a bit in this register leaves the corresponding bit unchanged. On read, the current value of this register is returned. Table 149. Hc Interrupt Enable Register Bit # Name 31 MIE 30 OC 29:7 RSVD Address 0xE000 7010 6 5 4 RHSC FNO UE Bit # Key Reset 31 MIE 0b Read/Write HCD HC R/W R 30 OC 0b R/W 29:7 6 5 4 3 2 1 0 RSVD RHSC FNO UE RD SF WDH SO — 0b 0b 0b 0b 0b 0b 0b — R/W R/W R/W R/W R/W R/W R/W 3 RD 2 SF 1 WDH 0 SO Description R Master interrupt enable. A 0 written to this field is ignored by HC. A 1 written to this field enables interrupt generation due to events specified in the other bits of this register. This is used by HCD as a master interrupt enable. Ownership change. — R If 0 = Ignore. If 1 = Enable interrupt generation due to ownership change. Reserved. Root hub status change. R 0 = Ignore. 1 = Enable interrupt generation due to root hub status change. Frame number overflow. R If 0 = Ignore. If 1 = Enable interrupt generation due to frame number overflow. Unrecoverable error. R If 0 = Ignore. If 1 = Enable interrupt generation due to unrecoverable error. Resume detect. R If 0 = Ignore. If 1 = Enable interrupt generation due to resume detect. Start of frame. R If 0 = Ignore. If 1 = Enable interrupt generation due to start of frame. Writeback done head. R If 0 = Ignore. If 1 = Enable interrupt generation due to HcDoneHead writeback. Scheduling overrun. If 0 = Ignore. If 1 = Enable interrupt generation due to scheduling overrun. Agere Systems Inc. 169 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.3.6 Hc Interrupt Disable Register Each disable bit in the Hc interrupt disable register corresponds to an associated interrupt bit in the Hc interrupt status register. The Hc interrupt disable register is coupled with the Hc Interrupt enable register. Thus, writing a 1 to a bit in this register clears the corresponding bit in the Hc interrupt enable register, whereas writing a 0 to a bit in this register leaves the corresponding bit in the Hc interrupt enable register unchanged. On read, the current value of the Hc interrupt enable register is returned. Table 150. Hc Interrupt Disable Register Bit # Name 31 MIE 30 OC Bit # Key Reset 31 MIE 0b 30 29:7 6 5 4 3 2 1 0 OC RSVD RHSC FNO UE RD SF WDH SO 0b — 0b 0b 0b 0b 0b 0b 0b Address 0xE000 7014 6 5 4 RHSC FNO UE 29:7 RSVD 3 RD 2 SF 1 WDH 0 SO Read/Write HCD HC R/W R Master interrupt enable. R/W R A 0 written to this field is ignored by HC. A 1 written to this field disables interrupt generation due to events specified in the other bits of this register. This field is set after a hardware or software reset. Ownership change. — R If 0 = Ignore. If 1 = Disable interrupt generation due to ownership change. Reserved. Root hub status change. R If 0 = Ignore. If 1 = Disable interrupt generation due to root hub status change. Frame number overflow. R If 0 = Ignore. If 1 = Disable interrupt generation due to frame number overflow. Unrecoverable error. R If 0 = Ignore. If 1 = Disable interrupt generation due to unrecoverable error. Resume detect. R If 0 = Ignore. If 1 = Disable interrupt generation due to resume detect. Start of frame. R If 0 = Ignore. If 1 = Disable interrupt generation due to start of frame. Writeback done head. R If 0 = Ignore. If 1 = Disable interrupt generation due to HcDoneHead writeback. Scheduling overrun. — R/W R/W R/W R/W R/W R/W R/W Description If 0 = Ignore. If 1 = Disable interrupt generation due to scheduling overrun. 170 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) 13.4 Memory Pointer Partition 13.4.1 Hc HCCA Register The Hc HCCA register contains the physical address of the host controller communication area. The host controller driver determines the alignment restrictions by writing all ones to the Hc HCCA register and reading the content of the Hc HCCA register. The alignment is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes; therefore, bits 0 through 7 must always return 0 when read. This area is used to hold the control structures and the interrupt table that are accessed by both the host controller and the host controller driver. Table 151. Hc HCCA Register Address 0xE000 7018 31:8 HCCA Bit # Name Bit # Key Reset 31:8 HCCA 0 7:0 RSVD — 7:0 RSVD Read/Write Description HCD HC R/W R Host controller communication area. This is the base address of the host controller communication area. — — Reserved. 13.4.2 Hc Period Current ED Register The Hc period current ED register contains the physical address of the current isochronous or interrupt endpoint descriptor. Table 152. Hc Period Current ED Register Address 0xE000 701C 31:4 PCED Bit # Name Bit # Key Reset 31:4 PCED 0 3:0 RSVD — Agere Systems Inc. 3:0 RSVD Read/Write HCD HC R R/W — — Description Period current ED. This is used by HC to point to the head of one of the periodic lists that will be processed in the current frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading. Reserved. 171 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.4.3 Hc Control Head ED Register The Hc Control head ED register contains the physical address of the first endpoint descriptor of the control list. Table 153. Hc Control Head ED Register Address 0xE000 7020 31:4 CHED Bit # Name Bit # Key Reset 31:4 CHED 0 3:0 RSVD — 3:0 RSVD Read/Write HCD HC R/W R — — Description Control head ED. HC traverses the control list starting with the Hc Control head ED pointer. The content is loaded from HCCA during the initialization of HC. Reserved. 13.4.4 Hc Control Current ED Register The Hc Control current ED register contains the physical address of the current endpoint descriptor of the control list. Table 154. Hc Control Current ED Register Address 0xE000 7024 31:4 CCED Bit # Name 172 Bit # Key Reset 31:4 CCED 0 3:0 RSVD — 3:0 RSVD Read/Write HCD HC R/W R/W — — Description Control current ED. This pointer is advanced to the next ED after serving the present one. HC will continue processing the list from where it left off in the last frame. When it reaches the end of the control list, HC checks the CLF of in the Hc command status register. If set, it copies the content of the Hc Control head ED register to the Hc Control current ED register and clears the bit. If not set, it does nothing. HCD is allowed to modify this register only when the CLE is cleared. When set, HCD only reads the instantaneous value of this register. Initially, this is set to 0 to indicate the end of the control list. Reserved. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) 13.4.5 Hc Bulk Head ED Register The Hc bulk head ED register contains the physical address of the first endpoint descriptor of the bulk list. Table 155. Hc Bulk Head ED Register Address 0xE000 7028 31:4 BHED Bit # Name Bit # Key Reset 31:4 BHED 0 3:0 RSVD — 3:0 RSVD Read/Write HCD HC R/W R — — Description Bulk head ED. HC traverses the bulk list starting with the Hc bulk head ED pointer. The content is loaded from HCCA during the initialization of HC. Reserved. 13.4.6 Hc Bulk Current ED Register The Hc bulk current ED register contains the physical address of the current endpoint of the bulk list. When the bulk list is served in a round-robin fashion, the endpoints will be ordered according to their insertion to the list. Table 156. Hc Bulk Current ED Register Address 0xE000 702C 31:4 BCED Bit # Name Bit # Key Reset 31:4 BCED 0 3:0 RSVD — Agere Systems Inc. 3:0 RSVD Read/Write HCD HC R/W R/W — — Description Bulk current ED. This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last frame. When it reaches the end of the bulk list, HC checks the CLF of the Hc Control register. If set, it copies the content of Hc bulk head ED register to Hc bulk current ED register and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the BLE of the Hc Control register is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to 0 to indicate the end of the bulk list. Reserved. 173 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.4.7 Hc Done Head Register The Hc done head register contains the physical address of the last completed transfer descriptor that was added to the done queue. In normal operation, the host controller driver should not need to read this register since its content is periodically written to the HCCA. Table 157. Hc Done Head Register Address 0xE000 7030 31:4 DH Bit # Name Bit # Key Reset 31:4 DH 0 3:0 RSVD — 3:0 RSVD Read/Write HCD HC R R/W — — Description Done head. When a TD is completed, HC writes the content of the Hc done head register to the next TD field of the TD. HC then overwrites the content of the Hc done head register with the address of this TD. This is set to 0 whenever HC writes the content of this register to HCCA. It also sets the WDH of the Hc interrupt status register. Reserved. 13.5 Frame Counter Partition 13.5.1 Hc Fm Interval Register The Hc Fm interval register contains a 14-bit value that indicates the bit time interval in a frame, (e.g., between two consecutive SOFs), and a 15-bit value indicating the full-speed maximum packet size that the host controller may transmit or receive without causing scheduling overrun. The host controller driver may carry out minor adjustment on the frame interval by writing a new value over the present one at each SOF. This provides the programmability necessary for the host controller to synchronize with an external clocking resource and to adjust any unknown local clock offset. 174 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 158. Hc Fm Interval Register Address 0xE000 7034 30:16 15 FSMPS RSVD 31 FI Bit # Name Bit # Key Reset 31 FI 2EDF Read/Write HCD HC R/W R 30:16 FSMPS TBD R/W R 15:14 13:0 RSVD FIT — 0b — R/W — R 14 13:0 FIT Description Frame interval. This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. Setting the HCR field of Hc command status register will cause the HC to reset this field to its nominal value. HCD may choose to restore the stored value upon the completion of the reset sequence. FS largest data packet. This field specifies a value that is loaded into the largest data packet counter at the beginning of each frame. The counter value represents the largest amount of data in bits that can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD. Reserved. Frame interval toggle. HCD toggles this bit whenever it loads a new value to FI. 13.5.2 Hc Fm Remaining Register The Hc Fm remaining register is a 14-bit down counter showing the bit time remaining in the current frame. Table 159. Hc Fm Remaining Register Address 0xE000 7038 30:14 RSVD 31 FRT Bit # Name Bit # Key Reset 31 FRT 0b 30:14 13:0 RSVD FR — 0h Agere Systems Inc. Read/Write HCD HC R R/W — R — R/W 13:0 FR Description Frame remaining toggle. This bit is loaded from the FIT field of the Hc Fm interval register whenever FR reaches 0. This bit is used by HCD for the synchronization between frame interval and frame remaining. Reserved. Frame remaining. This counter is decremented at each bit time. When it reaches 0, it is reset by loading the frame interval value specified in the Hc Fm interval register at the next bit time boundary. When entering the USB operational state, HC reloads the content with the FI of the Hc Fm interval register and uses the updated value from the next SOF. 175 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.5.3 Hc Fm Number Register The Hc Fm number register is a 16-bit counter. It provides a timing reference among events happening in the host controller and the host controller driver. The host controller driver may use the 16-bit value specified in this register and generate a 32-bit frame number without requiring frequent access to the register. Table 160. Hc Fm Number Register Address 0xE000 703C 31:16 RSVD Bit # Name Bit # Key Reset 31:16 15:0 RSVD FN — 0 Read/Write HCD HC — — R R/W 15:0 FN Description Reserved. Frame number. This is incremented when the Hc Fm remaining register is reloaded. It will be rolled over to 0H after FFFFH. When entering the USB operational state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the FN at each frame boundary and sent a SOF, but before HC reads the first ED in that frame. After writing to HCCA, HC will set the start of frame in the Hc interrupt status register. 13.5.4 Hc Periodic Start Register The Hc periodic start register has a 14-bit programmable value that determines the earliest time HC should start processing the periodic list. Table 161. Hc Periodic Start Register Address 0xE000 7040 31:14 RSVD Bit # Name Bit # Key Reset 31:14 13:0 RSVD PS — 0h Read/Write HCD HC — — R/W R 13:0 PS Description Reserved. Periodic start. After a hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from the Hc Fm interval register. A typical value will be 3E67h. When the Hc Fm remaining register reaches the value specified, processing of the periodic lists will have priority over control/bulk processing. HC will therefore start processing the interrupt list after completing the current control or bulk transaction that is in progress. 13.5.5 Hc LS Threshold Register The Hc LS threshold register contains an 11-bit value used by the host controller to determine whether to commit to the transfer of a maximum of 8-byte LS packet before EOF. Neither the host controller nor the host controller driver are allowed to change this value. 176 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 162. Hc LS Threshold Register Address 0xE000 7044 31:12 RSVD Bit # Name Bit # Key Reset 31:12 11:0 RSVD LST — 0628 Read/Write HCD HC — — R/W R 11:0 LST Description Reserved. LS threshold. This field contains a value that is compared to the FR field prior to initiating a low-speed transaction. The transaction is started only if FR ≥ this field. The value is calculated by HCD with the consideration of transmission and setup overhead. 13.6 Root Hub Partition All registers included in this partition are dedicated to the USB root hub, that is an integral part of the host controller though still a functionally separate entity. The HCD emulates USBD accesses to the root hub via a register interface. The HCD maintains many USB-defined hub features that are not required to be supported in hardware. For example, the hub's device, configuration, interface, and endpoint descriptors are maintained only in the HCD as well as some static fields of the class descriptor. The HCD also maintains and decodes the root hub's device address as well as other trivial operations that are better suited to software than hardware. The root hub register interface is otherwise developed to maintain similarity of bit organization and operation to typical hubs that are found in the system. The following four register definitions exist: ■ Hc Rh descriptor A register. ■ Hc Rh descriptor B register. ■ Hc Rh status register. ■ Hc Rh port status register [1:NDP], (NDP = number of data ports). Each register is read and written as a DWORD. These registers are only written during initialization to correspond with the system implementation. 13.6.1 Hc Rh Descriptor A Register The Hc Rh descriptor A register is the first register of two describing the characteristics of the root hub. Reset values are implementation-specific. The descriptor length (11), descriptor type (TBD), and hub controller current (0) fields of the hub class descriptor are emulated by the HCD. All other fields are located in the Hc Rh descriptor A register and Hc Rh descriptor B register. Agere Systems Inc. 177 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) Table 163. Hc Rh Descriptor A Register Bit # Name 31:24 POTPGT Address 0xE000 7048 11 10 OCPM DT 23:12 RSVD Bit # Field 31:24 POTPGT Root Hub Reset IS 23:12 11 RSVD OCPM — IS Read/Write HCD HC R/W R — R/W — R 10 DT 0b R R 9 PSM IS R/W R 9 NPS 8 PSM 7:0 NDP Description Power on to power good time. This byte specifies the duration HCD has to wait before accessing a powered-on port of the root hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT x 2 ms. Reserved. Overcurrent protection mode. This bit describes how the overcurrent status for the root hub ports are reported. At reset, this field should reflect the same mode as powerswitching mode. If 0, overcurrent status is reported collectively for all downstream ports. If 1, over-current status is reported on a per-port basis Device type. This bit specifies that the root hub is not a compound device. The root hub is not permitted to be a compound device. This field should always read/write 0. Power-switching mode. This bit is used to specify how the power switching of the root hub ports is controlled. It is implementation-specific. This field is only valid if the NPS field is cleared. If 0, all ports are powered at the same time. If 1, each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switch. If the PPCM bit is set, the port responds only to port power commands (set/clear port power). If the port mask is cleared, then the port is controlled only by the global power switch, set/clear global power. 178 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 163. Hc Rh Descriptor A Register (continued) Bit # Field 8 NPS Root Hub Reset IS Read/Write HCD HC R/W R Description No power switching. These bits are used to specify whether power switching is supported or port are always powered. It is implementation-specific. When this bit is cleared, the specifies global or per-port switching. If 0, ports are power switched. 7:0 NDP IS R R If 1, ports are always powered on when the HC is powered on. Number downstream ports. These bits specify the number of downstream ports supported by the root hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported by OpenHCI is 15. Note: IS denotes an implementation-specific reset value for that field. Agere Systems Inc. 179 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.6.2 Hc Rh Descriptor B Register The Hc Rh descriptor B register is the second register of two describing the characteristics of the root hub. These fields are written during initialization to correspond with the system implementation. Reset values are implementation-specific (IS). Table 164. Hc Rh Descriptor B Register Address 0xE000 704C 31:16 PPCM Bit # Name Bit # Field 31:16 PPCM 15:0 DR Root Hub Reset IS IS 15:0 DR Read/Write HCD HC R/W R R/W R Description Port power control mask. Each bit indicates if a port is affected by a global power control command when PSM is set. When set, the port's power state is only affected by per-port power control (set/clear port power). When cleared, the port is controlled by the global power switch (set/clear global power). If the device is configured to global switching mode (PSM = 0), this field is not valid. Bit 16: Reserved. Bit 17: Ganged-power mask on port #17. Bit 18: Ganged-power mask on port #18. . . . Bit 31: Ganged-power mask on port #31. Device removable. Each bit is dedicated to a port of the root hub. When cleared, the attached device is removable. When set, the attached device is not removable. Bit 0: Reserved. Bit 1: Device attached to port 1. Bit 2: Device attached to port 2. . . . bit 15: Device attached to port 15. 180 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) 13.6.3 Hc Rh Status Register The Hc Rh status register is divided into two parts. The lower word of a DWORD represents the hub status field and the upper word represents the hub status change field. Reserved bits should always be written 0. Table 165. Hc Rh Status Register Bit # Name 31 CRWE Bit # Field 31 CRWE 30:18 17 16 RSVD CCIC LPSC Address 0xE000 7050 17 16 15 OCIC LPSC DRWE 30:18 RSVD Root Hub Reset — — 0b 0b Read/Write HCD HC W R — R/W R/W — R/W R 14:2 RSVD 1 OCI 0 LPS Description Clear remote wake-up enable, (write). Writing a 1 clears DRWE. Writing a 0 has no effect. Reserved. Overcurrent indicator change. This bit is set by hardware when a change has occurred to the OCI field of this register. The HCD clears this bit by writing a 1. Writing a 0 has no effect. Local power status change, (write). The root hub does not support the local power status feature; thus, this bit is always read as 0. (Write) set global power: in global power mode (PSM = 0), this bit is written to 1 to turn on power to all ports (clear port power status). In per-port power mode, it sets PPS only on ports whose PPCM bit is not set. 15 DRWE 0b R/W R Writing a 0 has no effect. (Read) device remote wake-up enable. This bit enables a CSC bit as a resume event, causing a USB suspend to USB resume state transition and setting the resume detected interrupt. 0 = CSC is not a remote wake-up event. 1 = CSC is a remote wake-up event. (Write) set remote wake-up enable: writing a 1 sets DRWE. 14:2 1 0 RSVD OCI LPS — 0b 0b — R R/W — R/W R Writing a 0 has no effect. Reserved. Overcurrent indicator. This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal. If per-port overcurrent protection is implemented this bit is always 0. Local power status, (read). The root hub does not support the local power status feature; thus, this bit is always read as 0. (Write) clear global power: In global power mode (PSM = 0), This bit is written to 1 to turn off power to all ports (clear port power status). In per-port power mode, it clears port power status only on ports whose PPCM bit is not set. Writing a 0 has no effect. Agere Systems Inc. 181 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) 13.6.4 Hc Rh Port Status [1:NDP] Register The Hc Rh port status [1:NDP] register is used to control and report port events on a per-port basis. Number downstream ports (NDP) represents the number of Hc Rh port status registers that are implemented in hardware. The lower word is used to reflect the port status, whereas the upper word reflects the status change bits. Some status bits are implemented with special write behavior (see below). If a transaction (token through handshake) is in progress when a write to change port status occurs, the resulting port status change must be postponed until the transaction completes. Reserved bits should always be written 0. Table 166. Hc Rh Port Status Register [1:NDP] Bit # Name Bit # Name 31:21 RSVD 8 PPS Bit # Field 31:21 20 RSVD PRSC Address 0xE000 7054:0xE000 7058 19 18 17 OCIC PSSC PESC 4 3 2 PRS POCI PSS 20 PRSC 7:5 RSVD Root Hub Reset 0b Read/Write HCD HC R/W R/W 16 CSC 1 PES 15:10 RSVD 0 CCS 9 LSDA Description Reserved. Port reset status change. This bit is set at the end of the 10 ms port reset signal. The HCD writes a 1 to clear this bit. 0 = port reset is not complete. 1 = port reset is complete. 19 OCIC 0b R/W R/W Writing a 0 has no effect. Port overcurrent indicator change. This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when root hub changes the POCI bit. The HCD writes a 1 to clear this bit. 0 = no change in POCI. 1 = POCI has changed. 18 PSSC 0b R/W R/W Writing a 0 has no effect. Port suspend status change. This bit is set when the full resume sequence has been completed. This sequence includes the twentieth resume pulse, LS, EOP, and a 3 ms resynchronization delay. 0 = resume is not completed. 1 = resume completed. The HCD writes a 1 to clear this bit. This bit is also cleared when RCS is set. Writing a 0 has no effect. 182 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 166. Hc Rh Port Status Register [1:NDP] (continued) Bit # Field 17 PESC Root Hub Reset 0b Read/Write HCD HC R/W R/W Description Port enable status change. This bit is set when hardware events cause the PES bit to be cleared. Changes from HCD writes do not set this bit.The HCD writes a 1 to clear this bit. 0 = no change in PES. 1 = change in PES. 16 CSC 0b R/W R/W Writing a 0 has no effect. Connect status change. This bit is set whenever a connect or disconnect event occurs. The HCD writes a 1 to clear this bit. Writing a 0 has no effect. If CCS is cleared when a set port reset, set port enable, or set port suspend write occurs, this bit is set to force the driver to reevaluate the connection status since these writes should not occur if the port is disconnected. If 0 = no change in CCS. If 1 = change in CCS. 15:10 9 RSVD LSDA — XB — R/W — R/W Note: If the DR[NDP] bit is set, this bit is set only after a root hub reset to inform the system that the device is attached. Reserved. (Read) low-speed device attached. This bit indicates the speed of the device attached to this port. When set, a low-speed device is attached to this port. When clear, a full-speed device is attached to this port. This field is valid only when the CCS is set. If 0 = full-speed device attached. If 1 = low-speed device attached. (Write) CPP. The HCD clears the PPS bit by writing a 1 to this bit. Writing a 0 has no effect. Agere Systems Inc. 183 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) Table 166. Hc Rh Port Status Register [1:NDP] (continued) Bit # Field 8 PPS Root Hub Reset 0b Read/Write HCD HC R/W R/W Description (Read) port power status. This bit reflects the port’s power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing set port power or set global power. HCD clears this bit by writing clear port power or clear global power. Which power control switches are enabled is determined by PSM and PPCM[NDP]. In global-switching mode (PSM = 0), only set/clear global power controls this bit. In per-port power switching (PSM = 1), if the PPCM[NDP] bit for the port is set, only set/clear port power commands are enabled. If the mask is not set, only set/clear global power commands are enabled. When port power is disabled, CCS, PES, PSS, and PRS should be reset. 0 = port power is off. 1 = port power is on. (Write) SPP. The HCD writes a 1 to set the PPS bit. Writing a 0 has no effect. 7:5 4 RSVD PRS — 0b — R/W — R/W Note: This bit always reads 1b if power switching is not supported. Reserved. Port reset status, (read). When this bit is set by a write to set port reset, port reset signaling is asserted. When reset is completed, this bit is cleared when PRSC is set. This bit cannot be set if CCS is cleared. 0 = port reset signal is not active. 1 = port reset signal is active. Set port reset, (write). The HCD sets the port reset signaling by writing a 1 to this bit. Writing a 0 has no effect. If CCS is cleared, this write does not set PRS, but instead sets CSC. This informs the driver that it attempted to reset a disconnected port. 184 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 13 USB Host Controller (continued) Table 166. Hc Rh Port Status Register [1:NDP] (continued) Bit # Field 3 POCI Root Hub Reset 0b Read/Write HCD HC R/W R/W Description Port overcurrent indicator, (read). This bit is only valid when the root hub is configured in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent condition exists on this port. This bit always reflects the overcurrent input signal. 0 = no overcurrent condition. 1 = overcurrent condition detected. Clear suspend status, (write). The HCD writes a 1 to initiate a resume. A resume is initiated only if this bit is set. 2 PSS 0b R/W R/W Writing a 0 has no effect. Port suspend status, (read). This bit indicates the port is suspended or in the resume sequence. It is set by a write and cleared when it is set at the end of the resume interval. This bit cannot be set if it is cleared. This bit is also cleared when is set at the end of the port reset or when the HC is placed in the USB resume state. If an upstream resume is in progress, it should propagate to the HC. 0 = port is not suspended. 1 = port is suspended. Set port suspend, (Write). The HCD sets the bit by writing a 1 to this bit. If CCS is cleared, this write does not set PSS; instead, it sets CSC. This informs the driver that it attempted to suspend a disconnected port. 1 PES 0b R/W R/W Writing a 0 has no effect. Port enable status, (read). This bit indicates whether the port is enabled or disabled. The root hub may clear this bit when an overcurrent condition, disconnect event, switched-off power, or operational bus error such as babble is detected. This change also causes PESC to be set. HCD sets this bit by writing set port enable and clears it by writing clear port enable. This bit cannot be set when CCS is cleared. This bit is also set, if not already, at the completion of a port reset when reset status change is set or port suspended when suspend status change is set. 0 = port is disabled. 1 = port is enabled. Set port enable, (write). The HCD sets PES by writing a 1. If CCS is cleared, this write does not set PES, but instead sets CSC. This informs the driver that it attempted to enable a disconnected port. Writing a 0 has no effect. Agere Systems Inc. 185 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 13 USB Host Controller (continued) Table 166. Hc Rh Port Status Register [1:NDP] (continued) Bit # Field 0 CCS Root Hub Reset 0b Read/Write HCD HC R/W R/W Description Current connect status, (read). This bit reflects the current state of the downstream port. If 0 = no device connected. If 1 = device connected. Clear port enable (write). The HCD writes a 1 to this bit to clear the PES bit. The CCS is not affected by any write. Writing a 0 has no effect. Note: This bit is always read 1b when the attached device is not a removable (DR[NDP]) (see Table 164 on page 180). 186 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC There are two asynchronous communications controllers on the IPT_ARM. The IrDA_ACC provides an IrDA infrared channel and the UART_ACC provides a connection to the expansion UART unit. A list of features of the two ACC follows: ■ Full-duplex asynchronous communication. ■ Each ACC has 10 x 32 FIFOs for both receive and transmit. ■ One start bit, eight data bits, one optional ninth data bit, one optional parity bit, one stop bit. ■ Separate programmable baud rates. ■ Complete status reporting capabilities. ■ Support for DMA transfers. ■ IrDA input/output pulse formatter option (IrDA_ACC only). ■ Programmable IrDA output pulse to meet infrared transmitter and receiver timing requirements. (IrDA_ACC only.) 14.1 ACC Operation As shown in Figure 22 below, the function of the ACC is to convert incoming serial data on the receive line (IrDA_RX, the RX inputs for IrDA_ACC, UART_ACC, respectively) to parallel data for the ARM, and convert parallel data from the ARM to serial data on the transmit line (IrDA_TX, the TX outputs for IrDA_ACC, UART_ACC, respectively). For each ACC the baud rate used to transmit and receive serial data is separately programmable using the baud rate register (see Table 170 on page 190) and the sample mode field of the mode control register (see Table 176 on page 193). The status of the transmitter and receiver FIFOs are used to generate interrupts. The transmit and receive FIFOs are 10 bits wide by 32 entries deep. In 8-bit mode, data is stored in bit 7 through bit 0 (LSB). For 8-bit transfers, bits 9 (MSB) and 8 are always ignored on reads and written to 0. For 9-bit transfers, bit 9 is used to control the extended character support. IRQ INTERRUPT CONTROLLER PERIPHERAL BUS CONTROL Rx FIFO Rx SHIFT REGISTER Rx Tx SHIFT REGISTER Tx CLK BAUD RATE GENERATOR Tx FIFO 5-8221 (F) Figure 22. ACC Block Diagram Agere Systems Inc. 187 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) 14.1.1 Transmit and Receive Operation In order to transmit data on the transmit line Tx, the baud rate register (see Table 170 on page 190) is set, the sample mode field of the mode control register (see Table 176 on page 193) is set, the transmitter control register is set (see Table 175 on page 193), and then data is written into the transmitter FIFO. The data from the transmitter FIFO is transferred to the transmitter shift register. A start bit is generated and then the data is shifted to the output one bit at a time at the rate programmed in the baud rate register and the sample mode field of the mode control register. The data transmitted is synchronized to the baud rate generator so the width of the start bit does not vary. The optional parity bit is then generated, followed by stop bit(s). To receive serial data from the Rx input pin, set the baud rate and the receiver control register (see Table 173 on page 192). When a start bit is detected, the data on the Rx line is shifted into the receiver shift register. This is done by delaying one-half bit time and then sampling each data bit in the center of its ideal bit time. There is some error when data is sampled if the baud rate counter does not match the baud rate exactly. The error introduced is determined by the values programmed in the baud rate register and the sample mode field of the mode control register. After shifting one character and the optional parity bit into the receiver shift register, the data is tested for a parity error and the data is transferred to the receiver FIFO. If the controller detects receive errors, it sets appropriate error bits in the FIFO status register (see Table 172 on page 191) and generates an interrupt if the ACC interrupt enable register (see Table 180 on page 196) was set to enable the corresponding interrupt. A single interrupt line for each ACC is connected to the interrupt controller. When the ARM receives an interrupt from one of the ACCs, the interrupt type is read from the respective ACC’s interrupt register. 14.1.2 Transfer Operating Modes The ACC operates in several modes. There are 8 or 9 bits of data followed by optional parity bits. The receiver and transmitter can operate in different parity modes but use the same number of data bits. Table 167. ACC Transfer Modes Mode: Bit 0 of Mode Control Register 0 0 0 0 1 1 1 1 Parity Control: Bits[4:3] of Transmitter/Receiver Control Register 00 01 10 11 00 01 10 11 Resulting Transfer 1 start, 8 data, 1 stop bit. 1 start, 8 data, 2 stop bits. 1 start, 8 data, 1 even parity, 1 stop bit. 1 start, 8 data, 1 odd parity, 1 stop bit. 1 start, 9 data, 1 stop bit. 1 start, 9 data, 2 stop bits. 1 start, 9 data, 1 even parity, 1 stop bit. 1 start, 9 data, 1 odd parity, 1 stop bit. 14.1.3 Programming the Baud Rate The baud rate is programmed by setting values in two registers. Each bit period is divided into between 16 and 31 samples. This number is determined by adding 16 to the value set in SM of the mode control register (see Table 176 on page 193). The sample period is determined by multiplying the input clock period by the value in the baud rate register + 1. These two values, when multiplied together, are as close as possible to the ideal number of clocks per bit for the desired baud rate. The input clock for the ACCs on the IPT_ARM is the system clock. The maximum and default baud rate for the ACC (IrDA and UART) transmit and receive data is 115.2 kHz. The input clock is divided by 500 to achieve this exact baud rate. The number of sample clocks could be selected as 25, programmed as 9 (see bits 7:4 of the mode control register in Table 176 on page 193), and the baud rate register could be selected as 19, to set the clock divider to 20. 188 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) For example: system clock aud rate = -------------------------------------------------------( BRD + 1 ) ( SM + 16 ) 57.6 MHz 5.2 KHz = -----------------------------------------------( ( 19 + 1 ) ) ( 9 + 16 ) Where BRD is programmed as 0x13 and SM is programmed as 0x9. There is also an additional choice that reduces the error even more in some cases. If AL/CO of the mode control register is set to 1, alternate mode is entered. In this mode, the least significant bit of the sample count is toggled for every other bit. In alternate mode, for example, if the sample count is set to 23, then the first bit uses a sample count of 23, the next bit 22, then 23, and so on. Using this mode reduces the error for some baud rate choices. 14.1.4 Extended Characters The ACC can generate the following two types of special characters in 9-bit mode: ■ A break character. ■ An idle character. A break character consists of 11 start bits (zeros) and an idle character consists of 11 stop bits (ones). To use these extended characters, ECE of the mode control register is set to 1. To transmit these characters, write a data value to the transmit FIFO according to Table 168. Idle characters have no effect on the receiver. Table 168. Extended Characters Data Value Range 0x000:0x1FF 0x200 0x20:0x3FE 0x3FF Resulting Character Normal 9-bit character. Break character. Do not write these values. Idle character. 14.2 ACC Registers Table 169. IrDA_ACC and UART_ACC Communication Controller Register Map Register Baud rate register (see Table 170 on page 190). Baud rate counter register (see Table 171 on page 190). FIFO status register (see Table 172 on page 191). Receiver control register (see Table 173 on page 192). Transmitter control register (see Table 175 on page 193). Mode control register (see Table 176 on page 193). Tx/Rx FIFO register (see Table 177 on page 194). IrDA feature register (see Table 178 on page 194). ACC interrupt register (see Table 179 on page 195). ACC interrupt enable register (see Table 180 on page 196). Agere Systems Inc. IrDA_ACC Address 0xE000 8000 0xE000 8004 0xE000 8008 0xE000 8010 0xE000 8014 0xE000 8018 0xE000 801C 0xE000 8020 0xE000 8040 0xE000 8044 UART_ACC Address 0xE000 9000 0xE000 9004 0xE000 9008 0xE000 9010 0xE000 9014 0xE000 9018 0xE000 901C NA 0xE000 9040 0xE000 9044 189 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) 14.2.1 Baud Rate Register The baud rate register is used to divide the ACC clock to generate different baud rates. This divider is 16 bits wide, hence division factors of 1—65,536 are programmable. The actual divider count used is the value in the baud rate register + 1. The format of the baud rate register is shown below. Table 170. Baud Rate Register Address—IrDA 0xE000 8000, UART 0xE000 9000 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD BRD 15:0 BRD Description Reserved. Baud rate divisor. Specifies the baud rate divisor. For a value of 0x0000, the resulting baud rate divisor is 1. For a value of 0xFFFF, the resulting baud rate divisor is 65,536. 14.2.2 Baud Rate Counter Register The baud rate counter register is a read-only register that returns the current value of the baud rate counter. This counter is initialized with the value in the baud rate register after the counter counts down to 0, or if the baud rate counter register is written. Table 171. Baud Rate Counter Register Address—IrDA 0xE000 8004, UART 0xE000 9004 31:16 RSVD Bit # Name Bit # 31:16 15:0 190 Name RSVD BRC 15:0 BRC Description Reserved. Baud rate counter. Current value of the baud rate counter. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) 14.2.3 FIFO Status Register The FIFO status register informs the core of the status of the transmitter, receiver, and FIFOs. The FIFO status register is a read-only register. Writes to its address are ignored. Table 172 shows the format of the FIFO status register. Table 172. FIFO Status Register Bit # Name Bit # 31:8 7 6 5 4 3 2 1 0 31:8 RSVD Name RSVD RID 7 RID Address—IrDA 0xE000 8008, UART 0xE000 9008 6 5 4 3 2 TSE TFF TFHF TFE RFF Description TSE TFF If 1, the transmitter shift register is empty. If 0, the transmitter shift register is not empty. Transmitter FIFO full. If 1, the transmitter FIFO is full. If 0, the transmitter FIFO is not full. Transmitter FIFO half full. TFE If 1, the transmitter FIFO is at least half full. If 0, the transmitter FIFO is not at least half full. Transmitter FIFO empty. RFF If 1, the transmitter FIFO is empty. If 0, the transmitter FIFO is not empty. Receiver FIFO full. RFHF RFE 0 RFE Reserved. Receiver idle. If 1, the receiver is idle. If 0, the receiver is not idle. TSR empty. TFHF 1 RFHF If 1, the receiver FIFO is full. If 0, the receiver FIFO is not full. Receiver FIFO half full. If 1, the receiver FIFO is at least half full. If 0, the receiver FIFO is not at least half full. Receiver FIFO empty. If 1, the receiver FIFO is empty. If 0, the receiver FIFO is not empty. Agere Systems Inc. 191 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) 14.2.4 Receiver Control Register The receiver control register controls the receiver FIFO, interrupts, and parity generation. On any reset, the receiver control register is set to all zeros. Table 173. Receiver Control Register Bit # Name 31:8 RSVD Address—IrDA 0xE000 8010, UART 0xE000 9010 7 6:5 4:3 2:1 RD RSVD PC RSVD 0 FR Bit # Name Description 31:8 RSVD Reserved. 7 RD Receiver disable. Disables the receiver. Writing a 1 to this bit will disable the receiver. 6:5 RSVD Reserved. 4:3 PC Parity check. Controls receiver parity checking. Table 174 below shows the encoding for this field. 2:1 0 Parity checking is disabled upon any reset. RSVD Reserved. FR FIFO reset. Resets the receiver FIFO. Writing 1 (constantly) to this bit resets the receiver FIFO, discarding data still there and marking it empty. Writing 0 to this bit causes the FIFO to accept new data. The receiver FIFO is reset upon a reset to the IrDA_ACC. 14.2.5 ACC Parity Bit Encoding Table 174. ACC Parity Bit Encoding Bits 4:3 00 01 10 11 Parity No parity. Mark parity (always send a 1). Even parity. Odd parity. 14.2.6 Transmitter Control Register The transmitter control register controls the transmitter FIFO, interrupts, and parity generation. On any reset, the transmitter control register is set to all zeros. Table 175 shows the transmitter control register. 192 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) Table 175. Transmitter Control Register Bit # 31:6 5 Address—IrDA 0xE000 8014, UART 0xE000 9014 5 4:3 2 TOD PC RSVD 31:6 RSVD Bit # Name Name RSVD TOD 4:3 PC 2 1 RSVD TXON 0 FR 1 TXON 0 FR Description Reserved. Transmitter open drain. Puts the transmit output into open-drain mode. If 1, open-drain. If 0, normal. Parity control. Controls transmitter parity generation. Table 174 on page 192 shows the encoding for this field. Parity generation is disabled upon any reset. Reserved. Transmitter on. A 1 must be written to this bit before the transmitter loads data from the FIFO into the transmitter shift register and begins transmitting. This bit also serves as a single location where the interrupts from the transmitter empty FIFO or its shift register empty status bit can be disabled and masked when the transmitter is not in use. FIFO reset. Resets the transmitter FIFO. If 1, the transmitter FIFO is reset, discarding remaining data and marking it as empty. If 0, the FIFO can accept new data. The transmitter FIFO is reset upon resetting the ACC. 14.2.7 Mode Control Register The mode control register selects ACC mode options. On any reset, the mode control register is set to all zeros. The mode control register is shown below. Table 176. Mode Control Register Address—IrDA 0xE000 8018, UART 0xE000 9018 31:8 7:4 3 2 RSVD SM AL/CO ECE Bit # Name 1 RSVD 0 9BM Bit # 31:8 7:4 Name RSVD SM 3 AL/CO Description Reserved. Sample mode. Selects the input sample clock that is equal to the decimal equivalent of bits 7:4 plus 16. Alternate/constant. Controls the special alternate mode. ECE If 1, the least significant bit of the sample count is toggled for each new bit of a transfer. If 0, the sample count remains constant for each bit. Extended character enable. Enables the extended characters in 9-bit mode. 2 1 0 RSVD 9BM If 1, the extended characters are available. If 0, the extended characters are not available. Reserved. 9-bit mode. Indicates if the transfers are 8 or 9 bits. If 1, all transfers consist of 9 data bits. If 0, all transfers consist of 8 data bits. Agere Systems Inc. 193 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) 14.2.8 Tx/Rx FIFO Register The Tx/Rx FIFO register provides access to the transmitter and receiver FIFOs. A write to this register writes a character to the transmitter FIFO. A read from this register reads a character from the receiver FIFO. Both FIFOs are reset upon all system resets. The ACC loads the output shift register (see Figure 22 on page 187) with data from the FIFO prior to transmitting that character and stores the received character in the FIFO after it has been completely received, including its stop character. A read from an empty Rx FIFO returns the byte from the FIFO position just after the last Rx FIFO read, but it does not change the status of the Rx FIFO. Table 177. Tx/Rx FIFO Register Address—IrDA 0xE000 801C, UART 0xE000 901C 31:10 9 8 RSVD EXFI DB9 Bit # Name Bit # 31:10 9 Name RSVD EXFI 8 DB9 7:0 CHA 7:0 CHA Description Reserved. Extended FIFO character mode. In 9-bit data mode, the value of bit 9 in the transmit FIFO selects between the normal character mode (i.e., 1 start, 9 data bits, 1 optional parity, 1 stop), and the break/idle mode (i.e., synchronous transmission of a break or idle line conditions for 11 baud intervals). In 8-bit data mode, this bit is ignored on writes and always read as zeros. If 1, the character is an extended character. If 0, the character is a normal character. Data bit 9 mode. Bit 8 is the ninth data bit in 9-bit data mode. In 8-bit data mode, it is ignored on writes and always reads as zeros. Character. Character to transmit if written to. Character received if read from. 14.2.9 IrDA Feature Register The IrDA feature register is used to control the IrDA and the device MUX. The IrDA feature register is set to all zeros on any reset. Table 178. IrDA Feature Register 31:10 RSVD Bit # Name Address 0xE000 8020 9 SEL Bit # Name 31:10 RSVD Reserved. 9 SEL Select. Must be 0. 8 IDE IrDA enable. Enables the IrDA. 7:0 194 PWC 8 IDE 7:0 PWC Description If 1, the IrDA is active and the IrDATx and IrDARx pins are driven by the IrDA feature. If 0, the IrDA is disabled and the IrDATx and IrDARx pins are driven without the IrDA I/O formatter. Pulse width count. Pulse width count value. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) Table 179. ACC Interrupt Register Bit # Name Bit # Name Bit # 31:12 11 10 9 8 7 6 5 4 3 31:12 RSVD 5 RXNII Name RSVD TXNDI 11 TXNDI 4 RXPEI Address 0xE000 8040, 0xE000 9040 10 9 8 TXSREI TXFHI TXFEI 3 2 1 RXFEI RXOEI RXFHI 7 RSVD 0 RXFFI 6 RXFNEI — — Description Reserved. Transmitter no data interrupt. This bit is a 1 when the transmitter shift register is empty and the transmitter FIFO is empty and the TXON bit is set to 1. If the TXNDIE is set when this bit is 1, an interrupt will be generated. This bit is read-only. TXSREI Transmitter shift register empty interrupt. This bit is set when the transmitter shift register becomes empty. If the interrupt is enabled in the interrupt enable register and the TXON bit is set to 1, an interrupt will be generated. A new byte of data must be loaded into the transmit shift register to re-enable this bit to transition to 1 again. TXFHI Transmitter FIFO half-empty interrupt. This bit is a 1 when the transmit FIFO is less than half full. The FIFO condition, that causes the interrupt to occur must be removed, (i.e., by writing the FIFO) to remove this bit. This bit is read-only. This interrupt must be disabled if the processor does not have any more data to place in the transmitter to prevent an interrupt from always being asserted. TXFEI This bit is masked and will be a 0 if the TXON bit is not set to a 1. Transmitter FIFO empty interrupt. This bit is a 1 when the transmit FIFO is empty. The FIFO condition that caused the interrupt must be removed (i.e., by writing the FIFO) to remove this bit. This bit is read-only. This interrupt must be disabled if the processor does not have any more data to place in the transmitter to prevent an interrupt from always being asserted. This bit is masked and will be a 0 if the TXON bit is not set to a 1. RSVD Reserved. RXFNEI Receiver FIFO not empty interrupt. This bit is a 1 when the receive FIFO is not empty. The FIFO condition that caused the interrupt must be removed (i.e., by reading the FIFO) to remove this bit. RXNII RXPEI RXFEI This bit is read-only. Receiver not idle interrupt. This interrupt is set when the receiver becomes not idle. If the receiver not idle interrupt is enabled while this bit is 1, an interrupt to the processor will be generated. This bit is cleared by writing a 1 to this bit location. If the receiver is still not idle when this bit is cleared, it must go idle and then not idle again for a new interrupt to be generated. Note: RXNII does not indicate that an entire character has been received. It indicates that a character receipt is in progress. To verify that an entire character has been received, poll the RFE bit in the FIFO status register (see Table 172 on page 191). Receive data parity error. This bit is set when a parity error is detected in the received data. If the parity error interrupt enable bit is set while this bit is 1, an interrupt will be generated. This bit is cleared by writing a 1 to this bit location. Receive data framing error. This bit is set when a framing error is detected in the received data. If the framing error enable bit is set while this bit is 1, an interrupt will be generated. This bit is cleared by writing a 1 to this bit location. Agere Systems Inc. 195 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) Table 179. ACC Interrupt Register (continued) Bit # 2 1 0 Name Description RXOEI Receive data overrun error. This bit is set when a receive overrun error occurs. If the overrun interrupt enable bit is set while this bit is 1, an interrupt will be generated. RXFHI This bit is cleared by writing a 1 to this bit location. Receiver FIFO half-full interrupt. This bit is a 1 if the receiver FIFO is half full or more than half full. The receiver FIFO must be read or reset to remove this condition. RXFFI This bit is read-only. Receiver FIFO full interrupt. This bit is a 1 if the receiver FIFO is full. The FIFO condition that caused this interrupt must be removed (i.e., by writing the FIFO to remove this bit). This bit is read-only. Table 180. ACC Interrupt Enable Register Bit # Name Bit # Name Bit # 31:12 11 10 9 8 7 6 5 4 31:12 RSVD 5 RXNIE Name RSVD TXNDIE 11 TXNDIE 4 RXPEI Address 0xE000 8044, 0xE000 9044 10 9 8 TXSREE TXFHE TXFEI 3 2 1 RXFEI RXOEI RXFHI 7 RSVD 0 RXFFI 6 RXFNFEI — — Description Reserved. Transmitter no data interrupt enable. If 1, the transmitter no data interrupt is enabled. If 0, no transmitter no data interrupt will be generated. TXSREE Transmitter shift register empty interrupt enable. TXFHE If 1, the transmitter shift register empty interrupt is enabled. If 0, no transmitter shift register empty interrupt will be generated. Transmitter FIFO half-empty interrupt enable. TXFEI If 1, the transmitter FIFO half-empty interrupt is enabled. If 0, no transmitter FIFO half-empty interrupt will be generated. Transmitter FIFO empty interrupt enable. If 1, the transmitter FIFO empty interrupt is enabled. If 0, no transmitter FIFO empty interrupt will be generated. RSVD Reserved. RXFNFEI RXFNFEI receiver FIFO not empty interrupt enable. RXNIE If 1, the receiver FIFO not empty interrupt is enabled. If 0, the receiver FIFO not empty interrupt is disabled. Receiver not idle interrupt. RXPEI If 1, the receiver not idle interrupt is enabled. If 0, no receiver not idle interrupt will be generated. Received data parity error interrupt enable. If 1, the received data parity error interrupt is enabled. If 0, no received data parity error interrupt will be generated. 196 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) Table 180. ACC Interrupt Enable Register (continued) Bit # 3 2 1 0 Name RXFEI Description Received data framing error interrupt enable. RXOE If 1, the received data framing error interrupt is enabled. If 0, no received framing error interrupt will be generated. Received data overrun error interrupt enable. RXFHI If 1, the received data overrun error interrupt is enabled. If 0, no received overrun error interrupt will be generated. Receiver FIFO half-full interrupt enable. RXFFI If 1, the receiver FIFO half-full interrupt is enabled. If 0, no Receiver FIFO half-full interrupt will be generated. Receiver FIFO full interrupt enable. If 1, the receiver FIFO full interrupt is enabled. If 0, no receiver FIFO full interrupt will be generated. 14.3 IrDA Formatter The IrDA formatter is only supported in the IrDA_ACC. The UART_ACC does not have this feature. It works with the ACC to provide compatibility with the IrDA infrared serial data link standard. Features for the IrDA formatter follow: ■ Operates at speeds of up to 115.2 kbits/s. ■ Programmable pulse width to the IrDA transceiver. 14.3.1 IrDA Formatter Operation The IrDA formatter is enabled before it is used by setting IDE of the IrDA feature register (see Table 178 on page 194). Figure 23 shows how the output of the IrDA formatter follows the output of the IrDA_ACC channel. When the IrDA_ACC output is 0, the IrDA outputs a pulse high. When the IrDA_ACC output is 1, there is no pulse during that bit time. The width of the pulse is determined by the value programmed into the IrDA feature register using the following formula: IrDA Pulse-Width = 8 x [Clock Period x (PWC + 1)] The IrDA feature register (see Table 178 on page 194) is set to ensure that the pulse-width meets the minimum required by the transceiver being used. Agere Systems Inc. 197 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 14 IrDA_ACC and UART_ACC (continued) CLOCK CLOCK EDGE 1 SYSTEM CLOCK 57.6 MHz t1 t3 IRDATAX0 t2 PROGRAMMABLE PULSE WIDTH (PWC) PROGRAMMABLE BIT TIME/BAUD RATE INTERNAL Bit 0 ASYNC DATA Bit 1 COUNT = 2088 CLOCKS/20 kHz BAUD Reference t1 t2 t3 Parameter System Clock Cycle Time. IRDATAX0 Output Data Valid. IRDATAX0 Output Hold Time. Minimum 17.36 ns* — 0 ns Maximum — 12.85 ns — * Nominal clock period. Figure 23. IrDA Transmit Data Timing Diagram and Width Programmability Figure 24 shows how the IrDA formatting feature converts the IrDA pulse back into data compatible with ACC. When the IrDA formatter receives a pulse low, the data is converted to a low for the ACC receive line. When a pulse low is not seen, the data is held high. A pulse must be held for a minimum of two clock cycles of the baud rate counter clock output for it to be detected by the IrDA formatter. 198 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 14 IrDA_ACC and UART_ACC (continued) t1 t2 IRDARX0 HIGH SAMPLES t3 TWO CLOCK MINIMUM IrDA PULSE PROGRAMMABLE BAUD RATE Bit 1 Bit 0 Reference t1 t2 t3 Parameter System Clock Cycle Time. IRDARX0 Setup Time. IRDARX0 Hold Time (2 Clocks + Hold). Minimum 17.36 ns* 2.25 ns 37.7 ns Maximum — — — * Nominal clock period. Figure 24. IrDA Receive Data Timing Diagram, Minimum Pulse Width 14.4 DMA Support for ACC I/O Data The DMA controller transfers data to and from the Tx/Rx FIFO registers. By selecting the proper mode and device, the ACCs are accessed. When the ACC is in 8 bit mode, the lower 8 bits of the DMA transfer are valid. In 9-bit data bit mode, the lower 9 bits of the DMA transfer are valid. 14.5 Operation on Reset Upon any reset, the ACC performs the following: ■ All ongoing transfers are aborted. ■ Both transmitter and receiver FIFOs are reset. ■ The transmitter control register is reset to all zeros to disable transmitter parity generation. ■ The receiver control register is reset to all zeros to disable receiver parity checking. ■ The FIFO status register is set to reflect the current status of both transmitter and receiver FIFOs (empty). ■ The baud rate register is reset to all zeros. Agere Systems Inc. 199 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) The SSI unit is compatible with the SPI interface of the Motorola* 68HC11 microcontroller. The following features of the SPI interface are supported by the SSI interface: ■ Four-wire synchronous serial interface clock, data in, data out, slave select control. ■ Clock polarity selection. ■ Data phase selection. ■ Outputs can be programmed to be open-drain or direct-drive. ■ Four-wire full-duplex transfers. ■ Three-wire half-duplex or unidirectional transfers. ■ Detection of multiple-master bus contention faults and slave-mode write-collisions. ■ Support for DMA transfers. 15.1 Description The SSI unit operates in either the master mode or the slave mode. Figure 25 on page 202 shows a functional block diagram of the SSI. The master unit in an SSI cluster enables slave units to receive and transmit data, and initiates transmissions by broadcasting a clock signal, called SCK, to all other units. A data register in each unit operates as an 8-bit shift register clocked by SCK. The master unit configures a data path between its data register and the data register of one other slave unit, so that a 16-bit circular shift register is formed. Communication between the master and slave units then occurs if eight SCK cycles cause the data values, stored in each register, to be exchanged. This mode of operation is suitable for bidirectional communication between a master and slave unit. It utilizes the four-wire interface consisting of clock, data in, data out, and slave select control. Other possible modes of operation are as follows. ■ A master unit broadcasts a byte (or longer multibyte message) to several slave units simultaneously, provided that only one slave is enabled to drive data back to the master. ■ A multimaster, multislave network may be constructed where a software protocol allows all units to share the two data transmit/receive wires without data loss. ■ Slave units are capable of receiving data and returning data when only one data wire is connected in the system. Pins MDISDO and MDOSDI are tied together to form a single bidirectional data line. The MDISDO, MDOSDI, and SCK pins are configured as open-drain outputs to minimize contention from several drivers that is possible in some of these configurations. An external pull-up resistor is required on all open-drain pins. 15.1.1 Clocks SCK is provided by the master unit and in the SSI. Seven different SCK rates derived from the system clock are supported. If configured as a slave unit, SCK is obtained from outside of the device, and is assumed to be asynchronous with respect to the slave’s system clock. Consequently, data transfers and error conditions also occur asynchronously with respect to the slave’s system clock. A special register access sequence is defined for the ARM core to obtain data and status information from the slave SSI. Depending on the polarity of the shift clock and the phase of the data relative to the shift clock, the SSI interface supports four different modes of transfer. These modes are under program control, and master and slave units communicate in a common mode. * Motorola is a registered trademark of Motorola Inc. 200 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) The 8-bit data register shifts out a byte, one bit at a time (MSB first), synchronously with the shift clock SCK. If running as a master, the SSI derives SCK from its system clock using a prescaling value determined by the SCLK[2:0] bits of SSI control register 1 (see Table 183 on page 204). Before being output to the pin, the prescaled clock is conditioned in the clock control block in accordance with the SPOL and SPHA bits in SSI control register 1. As a slave, the shift clock is supplied by an external master through the SCK pin and is modified in accordance with the SPOL and SPHA bits in the slave’s SSI control register 1. 15.1.2 Date Transfer The data register loads data from the lower byte of the peripheral bus. The received data is double buffered and is read on the lower byte of the peripheral bus. The status and shift control logic directs the transfer of data and generates status flags for end-of-transfer (SDONE) and detectable error conditions (WCOLL and MODF). The bits from the SSI control registers are used by the clock divide, clock control, status/shift/control, and the I/O control logic for proper operation. The I/O control logic routes the data to and from the I/O pins as shown below. 15.1.3 Pin Configuration Because a master MDISDO is the data input, MDOSDI is the data output and SCK is the serial clock output. SSN is the slave select signal and is always an input to the SSI unit, whether the unit is a master or a slave. If a master, the SSN input pin detects bus contention with another master in a multimaster system. Because a slave MDISDO is the data output, MDOSDI is the data input, SCK is the serial clock input, and SSN is the slave select input. The I/O control logic is directly controlled by the MSTR bit of SSI control register 1. 15.1.4 SSN Input If SSN is low in a slave unit, the slave SSI is selected by the master for operation. If low in a master unit, this pin indicates that there is contention with another master in the system, and this will be detected as a mode fault error if SSNEN of SSI control register 1 is set to 1. The SSN pin is used by the SSI hardware (as long as SSNEN of SSI control register 1 is one) but can also be read by master or slave software from SSN of SSI control register 2. Bit 0 of SSI control register 2 reflects the state of the SSN pin, regardless of the state of SSNEN of SSI control register 1. 15.1.5 Configurations Multimaster: in a multiple-master system, all SCK pins are tied together, all MDOSDI pins are tied together, and all MDISDO pins are tied together. Master—slave: a single SSI device is configured as a master and all other SSI devices on the SSI bus are configured as slaves. The master drives data onto its SCK and MDOSDI pins to the SCK and MDOSDI pins of the slaves. The slave, whose SSN input pin is low, optionally drives data out onto its MDISDO pin to the MDISDO pin of the master. The SCK, MDOSDI, and MDISDO pins are configured to behave as open-drain drivers using bits in SSI control register 1. This prevents contention on these signals if more than one SSI device tries to simultaneously drive the line. An external pull-up resistor is required on all open-drain pins. Agere Systems Inc. 201 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.1.6 Slave Chip Select There is one signal associated with SSI operation that is not part of the SSI unit. This is the slave chip select output from the microcontroller. Software in the ARM processor uses one or more of the PPI general-purpose I/O pins as output pins for the slave select signals it sends to the SSI slaves. PERIPERAL BUS DATA REGISTER MSB LSB 2 A M DATA READ REGISTER SERIAL DATA IN 8-bit SHIFT REGISTER MDISDO S SERIAL DATA OUT SHIFT CLOCK B S ÷128 MDOSDI ÷64 TO/FROM ARM CORE M ÷32 CLOCK DIVIDE I/O CONTROL ÷16 SCK_OUT ÷8 M CLOCK CONTROL ÷4 SCK_IN ÷2 SCK S E C D F CONTROL REGISTER STATUS AND SHIFT CONTROL SSN S SSN IRQ14 PERIPHERAL BUS 5-6667 (F) Legend: A—SSI control register 1, bits MSTR, SPHA. B—SSI control register 1, bit MSTR. C—SSI control register 1, bits SCLK [2:0]. D—SSI control register 1, bits EN, MSTR, SPOL, SPHA. E—SSI control register 1, bits EN, MSTR, SPOL, SPHA, SDOEN, SSNEN. F—SSI interrupt register, bits SDONE, WCOLL, MODF. Figure 25. SSI Functional Block Diagram 202 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) 15.2 SSI Registers The SSI unit has five programmable registers. The SSI data register is used for writing the 8-bit byte to be transmitted and for reading the received 8-bit byte. SSI control registers 1 and 2 enable and configure the SSI for serial communication in the desired mode. The SSI interrupt register and the SSI interrupt enable register display and enable interrupts, respectively. Table 181 below shows the register map of the SSI. Table 181. SSI Register Map Register SSI data register (see Table 182 on page 203). SSI control register 1 (see Table 183 on page 204). SSI control register 2 (see Table 185 on page 206). SSI interrupt register (see Table 186 on page 206). SSI interrupt enable register (see Table 187 on page 207). Address 0xE000 4000 0xE000 4004 0xE000 4008 0xE000 4010 0xE000 4014 15.2.1 SSI Data Register The SSI data register contains the transmitted and received data bytes. The data byte that is transmitted is written in the low-order byte of the SSI data register. The SSI data register is single buffered on the transmit side and serves as the shift register for clocking out the bits with SCK. The SSI data register is double buffered on the receive side. If all 8 bits are shifted in, the received data is copied to a buffer register. The processor reads the contents of this register to determine the received word. Double buffering on the receive side allows a new data byte to be shifted in while the previous one is read. If in slave mode, the SSI uses the SCK pin to shift the SSI data register. While in master mode, it uses its internal version of SCK. For cases where SPHA = 1 and SSN is kept low between transfers, it is necessary to write bit SSNEN to 0 (in SSI control register 1) before writing the slave’s SSI data register. Table 182. SSI Data Register Address 0xE000 4000 31:8 RSVD Bit # Name Bit # 31:8 7:0 Name RSVD TDWR 7:0 TDWR Description Reserved. Must be written with zeros. Transmit/receive data. Transmit data on write, receive data on read. On reset, all SSI data register bits are set to 0. Agere Systems Inc. 203 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.2.2 SSI Control Register 1 SSI control register 1 is used to enable communication, set up the SSI in master/slave mode, report status, and configure the clock. Table 183. SSI Control Register 1 31:16 RSVD 11 SDOEN Bit # Name Bit # Name Bit # 31:16 15 14 13 12 11 15 EN 10 SSNEN Address 0xE000 4004 14 MSTR 9 MDOEN 13 SPOL 8:3 RSVD Name RSVD EN Reserved. Enable. Enables or disables the SSI. MSTR If 1, the SSI is enabled. If 0, it is disabled. Master mode. Configures the SSI in master or slave mode. SPOL If 1, the SSI is configured in master mode. If 0, it is configured in slave mode. Idle state. Determines the idle state of the SCK clock. SPHA If 1, the SCK clock is idle at logic 1. If 0, it is idle at logic 0. Data change. Determines when the data changes in each SCK cycle. 12 SPHA 2:0 SCLK Description If 1, output data is shifted at the leading transition of SCK and input data is sampled at the midpoint transition of SCK. If 0, output data is shifted at the midpoint transition of SCK and input data is sampled at the leading transition of SCK. SDOEN Output enable. Enables output from the MDISDO pin if the SSI is configured as a slave. If 1, output from the MDISDO pin is enabled if the SSI is configured as a slave. If 0, output is disabled. A master SSI device simultaneously broadcasts a message to several slaves as long as no more than one of the slaves tries to drive the MDISDO line. Also, SSI systems that tie MDOSDI and MDISDO together to form a single bidirectional data line also need to selectively disable the MDISDO output. SSN enable. 10 SSNEN 9 If 1 in master mode, the SSN input is enabled and causes a mode fault. If 0 in master mode, the SSN input is disabled. If 1 in slave mode, the slave uses the SSN input to determine if it is selected for operation. If 0 in slave mode, the slave is not selected for operation. MDOEN MDOSDI enable. Enables output from the MDOSDI pin if the SSI is configured as master. If 1, output from the MDOSDI pin is enabled if the SSI is configured as master. If 0, output is disabled. Bit 9 is 0 when the master SSI wants to receive a byte of data from a slave without transmitting a byte. 204 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) Table 183. SSI Control Register 1 (continued) Bit # 8:3 2:0 Name RSVD SCLK Description Reserved. Must be set to 1. Clock configuration. Defines the clock prescale factor. For the encoding of bits 2:0 refer to Table 184 below. Table 184. SSI Clock Divide Bit Encoding Bits [2:0] 000 001 010 011 100 101 110 111 Clock Divide 2 4 8 16 32 64 128 Reserved 15.2.3 SSI Control Register 2 Bit Descriptions SSI control register 2 configures the SSI in FASTCLEAR mode, reads the value of the SSN pin, and configures several outputs as open-drain. 15.2.3.1 SSN SSN reflects the value on the chip’s SSN pin. Software in both the master and slave SSI units read this register, but it is used only by the slave SSI software. By polling this register bit, the slave SSI software determines if the slave has been selected for operation. The slave is selected for operation if bit 0 (SSN) of SSI control register 2 is 0. However, note that monitoring the SSN pin is not a reliable indicator of a transfer in progress in the slave if SPHA = 1 since (in that case) the SSN pin stays low between bytes transferred. If SPHA = 0, monitoring of the SSN pin indicates whether a byte transfer is in progress since SSN is taken high between transfers. Since the SSN pin is synchronized with the SSI system clock before being read and made available in the register bit, the SSN pin must hold its level (0 or 1) a minimum of two system clocks to ensure that the level is recognized in bit 0 of SSI control register 2. 15.2.3.2 FASTCLEAR FASTCLEAR of SSI control register 2 is the FASTCLEAR bit. This bit clears to 0 after reset. If this bit is set, the SDONE and MODF bits of the SSI interrupt register are cleared upon a read/write of the SSI data register. FASTCLEAR is set when performing DMA transfers from the SSI so that the SDONE and MODF bits do not have to be written to be cleared. Slave units are capable of receiving data and returning data when only one data wire is connected in the system. 15.2.3.3 MDOD Bit 3 of SSI control register 2 is the MDOSDI/MDISDO open-drain (MDOD) bit. This bit selects open-drain or direct-drive output for MDOSDI and MDISDO when they are outputs. If bit 3 is 0, MDOSDI (master) or MDISDO (slave) is direct-drive. If bit 3 is 1, MDOSDI (master) or MDISDO (slave) is open-drain. Agere Systems Inc. 205 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.2.3.4 SCOD Bit 4 of SSI control register 2 is the SCK open-drain (SCOD) bit. This bit selects open-drain or direct-drive output from SCK when in master mode. If bit 4 is 0, SCK is direct-drive. If bit 4 is 1, SCK is open-drain. Table 185. SSI Control Register 2 Bit # Name 31:5 RSVD Bit # 31:5 4 Name RSVD SCOD 4 SCOD Address 0xE000 4008 3 2 MDOD RSVD 1 FASTCLEAR 0 SSN Description Reserved. SCOD bit. This is the SCK open-drain (SCOD) bit. This bit selects open-drain or directdrive output for SCK. If bit 4 is 0 when in master mode, SCK is direct-drive. If bit 4 is 1, SCK is open-drain. 3 MDOD When an open-drain I/O buffer is used, the SCK output will be open-drain, regardless of the state of bit 4. MDOSDI and MDISDO output. This bit selects open-drain or direct-drive output, for MDOSDI and MDISDO when they are outputs. If bit 3 is 0, MDOSDI (master) or MDISDO (slave) is direct-drive. If bit 3 is 1, MDOSDI or MDISDO are open-drain. 2 1 0 RSVD FASTCLEAR When an open-drain I/O buffer is used, the MDISDO/MDOSDI output will be opendrain, regardless of the state of bit 3. Reserved. Clear bit. This bit clears to 0 after reset. If this bit is set to 1, it is not necessary to write the MODF and SDONE bits of the interrupt register. This bit is set for DMA operations with the SSI. SSN state. SSN of SSI control register 2 always reflects the state of the SSN chip, regardless of whether SSNEN is 0 or 1. SSN Note: On all resets, bit 0 of SSI control register 2 is set to 1 all other bits are set to 0. Table 186. SSI Interrupt Register Bit # Name Bit # 31:8 7 6 31:8 RSVD 7 SDONE Address 0xE000 4010 6 5 WCOLL MODF Name RSVD SDONE Reserved. Serial transfer complete interrupt. WCOLL If 1, the serial transfer is completed. If 0, no transfer pending or a transfer is in progress. Cleared by writing a 1. Write collision error interrupt. 4 RD_ORUN 3:0 RSVD Description If 1, a write to the SSI data register occurred while a serial transfer was in progress. If 0, no error was detected. Cleared by writing a 1. 206 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) Table 186. SSI Interrupt Register (continued) Bit # 5 Name MODF Description Mode fault error interrupt. If 1, the SSN input was asserted while the unit was in master mode and SSNEN was enabled. If 0, no error is detected. Cleared by writing a 1. RD_ORUN Read overrun error interrupt. This bit can only be set if the SSI is in master mode. 4 3:0 RSVD If 1, a byte received from the slave was written to the master’s receive data buffer before the previous byte from the slave had been read from that buffer. Reserved. Table 187. SSI Interrupt Enable Register Bit # Name Bit # 31:8 7 6 5 4 3:0 31:8 RSVD 7 SDONEE Address 0xE000 4014 6 5 WCOLLE MODFE Name RSVD SDONEE Description Reserved. Serial transfer complete interrupt enable. WCOLLE If 1, the serial transfer interrupt is enabled. If 0, no serial transfer interrupt will occur. Write collision error interrupt enable. MODFE If 1, the write collision interrupt is enabled. If 0, no write collision interrupt will occur. Mode fault error interrupt enable. 4 RD_ORUNE 3:0 RSVD If 1, the mode fault interrupt is enabled. If 0, no mode fault interrupt will occur. RD_ORUNE Read overrun error interrupt enable. RSVD If 1, the read overrun interrupt is enabled. If 0, no read overrun interrupt will occur. Reserved. 15.3 SSI Operation The SPOL and SPHA bits in SSI control register 1 determine the mode of data transfer. Both of these bits control the type of shift clock (SCK) generated. SPOL controls the polarity of SCK and SPHA determines the phase at which the serial transfer begins. The latter leads to a fundamentally different type of transfer with implications in situations where back-to-back byte transfer is required. The transfer formats are different for different peripheral devices but remain unchanged during a transfer between the master and the slave device. The SSI is flexible enough to allow any desired configuration that conforms to the HC11 specifications. The different transfer formats are now considered in detail. Agere Systems Inc. 207 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.3.1 SPHA = 0 Format Figure 26 below shows the timing diagram of the serial byte transfer if SPHA = 0. SCK is shown for both cases of SPOL, i.e., SPOL = 0 and SPOL = 1. The MDOSDI signal is the output of the master and the input to the slave. The MDISDO signal is output from the slave and input to the master. The timing diagrams are interpreted either from the master’s or the slave’s side. The SSN line is the slave select line. On the slave side, the transfer begins when the SSN line is pulled low. For the master, transfer begins when data is written into its data register. (Such a write is necessary even if the master is only interested in receiving data from the slave.) SCK CYCLE (FOR REFERENCE) t1 t2 SCK (SPOL = 0) t4 SCK (SPOL = 1) t8 t5 t6 MDOSDI (FROM MASTER) MSB t9 MDISDO MDOSDO (FROM SLAVE (FROM SLAVE) t7 6 5 4 3 2 1 0 (LSB) 6 5 4 3 2 1 0 (LSB) t10 MSB t11 SSN (TO SLAVE) Reference t1 t2 t4 t5 t6 t7 t8 t9 t10 t11 Parameter SCK Cycle Time. SCK Output Fall Time. SCK Output Rise Time. Slave Enable Lead Time. Output Data Valid After Clock. Slave Input Data Setup Time. Input Data Hold Time. Slave Data Out Access Time. Output Data Hold Time After Clock. Slave Disable Idle Time (Hold). Minimum — — — 0 ns — 1.0 ns 1.0 ns — 0 ns 5 ns Maximum — 10%—90% 10%—90% — 17.55 ns — — 7.10 ns — — Figure 26. SSI Transfer Timing Diagram, (SPHA = 0) 208 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) 15.3.1.1 Master Operation In the master, the data is sampled from MDISDO at the rising edge of SCK and shifted onto MDOSDI at the falling edge if SPOL = 0. If SPOL = 1, the sampling and shifting edges are reversed. At the end of eight cycles, the transfer is completed for the master. On the eighth sampling SCK edge, the received byte is transferred to the read data buffer, the SDONE status flag is set, and an interrupt, if enabled, is generated. The MDOSDI line stays high before the transfer begins and after it ends. This is useful in multiple master systems where the MDOSDI line is always at a known state whenever the control of the bus is relinquished to another master. 15.3.1.2 Slave Operation On the slave side, data is sampled from MDOSDI at the rising edge of SCK and shifted onto MDISDO at the falling edge if SPOL = 0. If SPOL = 1, the sampling and shifting edges are reversed. The received data is buffered on the eighth sampling SCK edge, the SDONE flag is set, and the interrupt, if enabled, is generated. The end of transfer, however, is indicated only if the SSN signal is deasserted. At that time, the MDISDO output pin stops driving. Note: In multiple byte transfers, the SSN line is asserted and deasserted between successive bytes if SPHA = 0. If the master sends another byte before deasserting and reasserting the SSN line, then the transfer is not guaranteed to be correct. 15.3.2 SPHA = 1 Format Figure 27 shows the timing diagram of the serial byte transfer if SPHA = 1. SCK is shown for both cases of SPOL, i.e., SPOL = 0 and SPOL = 1. The MDOSDI signal is the output of the master and input to the slave. The MDISDO signal is the output from the slave and input to the master. The timing diagrams are interpreted either from the master’s or the slave’s side. The SSN line is the slave select line. The slave output is enabled as long as SSN is held low. Note: In multiple byte transfers, the SSN line is held asserted (low) between successive bytes if SPHA = 1. The SSN line can be tied low if SPHA = 1. Agere Systems Inc. 209 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) SCK CYCLE (FOR REFERENCE) t2 t1 SCK (SPOL = 0) t3 SCK (SPOL = 1) t4 MDOSDI (FROM MASTER) t6 t5 MSB t7 6 5 4 3 2 1 0 (LSB) t10 t8 MDISDO MDOSDO (FROM SLAVE (FROM SLAVE) t11 t9 MSB 6 5 4 3 2 1 0 (LSB) SSN (TO SLAVE) Reference t1 t2 t3 t4 t5 t6 t7 t8 t9 t10 t11 Parameter SCK Cycle Time. SCK Output Fall Time. SCK Output Rise Time. Slave Enable Lead Time. Output Data Valid After Clock. Slave Input Data Setup Time. Input Data Hold Time. Slave Data Out Access Time. Input Data Hold Time After Clock. Slave Disable Idle Time. Output Data Hold Time After Clock. Minimum — — — 0 ns — 1.0 ns 1.0 ns — 1.0 ns 5 ns 0 ns Maximum — 10%—90% 10%—90% — 17.55 ns — — 7.1 ns — — — Figure 27. SSI Transfer Timing Diagram, (SPHA = 1) 15.3.2.1 Master The data in the master is sampled from MDISDO at the falling edge of SCK and shifted onto MDOSDI at the rising edge if SPOL = 0. If SPOL = 1, the sampling and shifting edges are reversed. At the end of eight active levels of SCK, the transfer is completed for the master. In effect, this occurs at the end of seven and a half cycles of the shift clock. On the eighth sampling SCK edge, the received byte is transferred to the read data buffer, the SDONE status 210 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) flag is set, and an interrupt, if enabled, is generated. The MDOSDI line stays high before the transfer begins and after it ends. This is useful in multiple master systems where the MDOSDI line is always at a known state whenever the control of the bus is relinquished to another master. 15.3.2.2 Slave On the slave side, the data is sampled from MDOSDI at the falling edge of SCK and shifted onto MDISDO at the rising edge if SPOL = 0. If SPOL = 1, the sampling and shifting edges are reversed. The received data is buffered at the end of seven and a half shift clock cycles (i.e., on the eighth sampling SCK edge), the SDONE flag is set, the interrupt, if enabled, is generated, and the end of transfer is indicated. The output, however, remains valid until SSN is deasserted. At that time, the MDISDO pin stops driving. 15.3.3 Transfer Start Every SSI transfer consists of an initiation period, followed by eight SCK cycles if the 8-bit data transfer takes place, and finally the ending period. The details for the data transfer were considered in the previous section. Here the initiation period is discussed for each of the different formats selected for the master and slave modes of operation. If the SSI is configured as a master, all transfers are initiated by a write to the SSI data register. Such a write is necessary even if the master is only interested in receiving data from the slave. There is a delay of three system clock cycles after the write access before the start of the serial transfer. If SPHA = 0, SCK remains at its idle state for the first half of the cycle following the write to the SSI data register. If SPHA = 1, the transfer cycle begins immediately with the SCK going from its inactive level to the active level. If the SSI is configured as a slave and SPHA = 0, a transfer begins if the SSN line is pulled low. The MSB of the data written in the slave SSI data register initially appears on the MDISDO line. If the SSI is configured as a slave and SPHA = 1, a transfer begins with the first active edge of SCK, provided that the slave is selected (SSN asserted). 15.3.4 Transfer End A transfer is complete if all 8 bits are shifted in serially, the data is transferred to the read data buffer, and the SDONE flag is set. The interrupt signal (IRQ) will be active if SDONEE is set in the SSI interrupt enable register. 15.3.4.1 Master Operation If the SSI is configured as a master, the received byte is transferred to the read-buffer at the end of eight SCK clock cycles. The SDONE flag is set after a delay (independent of the SCK rate) of one system clock cycle. 15.3.4.2 Slave Operation If the SSI is configured as a slave, the ending period depends on the value of SPHA. If SPHA = 0, SDONE is set at the end of the eighth SCK cycle (one-half SCK cycle after the last bit is sampled by the slave). If SPHA = 1, SDONE is set in the middle of the eighth SCK cycle (at the time the last bit is sampled). Since the master always ends the transfer at the end of the eighth SCK cycle, the SDONE bit in the slave completes the transfer if SPHA = 1. Agere Systems Inc. 211 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.3.5 Interrupt Generation If the SSI interrupt is enabled in the interrupt controller’s SSI interrupt enable register, the SSI asserts its interrupt request whenever a byte is successfully shifted in and copied to the read data buffer (i.e., if the SDONE bit is true, or if a mode fault or read overrun occurs). The interrupt is cleared if SDONE, MODF, and RD_ORUN are cleared. 15.3.6 Status Flags and Error Conditions The SSI interrupt register contains four read-only status bits, SDONE, WCOLL, MODF, and RD_ORUN. There is another error condition that occurs if the SSI is configured as a slave and a transfer is aborted by the master unit pulling SSN high or the slave software writing SSI control register 1 bit 10:0 before the transfer is complete. This error condition is not indicated by the status flags and is detected by a software protocol. The status and error conditions are described below. 15.3.6.1 SDONE SDONE is a status flag that indicates the end of a transfer. At the end of a transfer, the SDONE bit of SSI interrupt register is set. If the FASTCLEAR bit of SSI control register 2 = 1, the SDONE flag is cleared by a read or write of the SSI data register. If FASTCLEAR of SSI control register 2 = 0, the SDONE flag is cleared by writing to the SDONE bit in the SSI interrupt register to clear the SSI interrupt. 15.3.6.2 WCOLL Flag The WCOLL bit of SSI interrupt register indicates that a write collision error occurred. A write collision error is detected if a write to the SSI data register is attempted while a transfer is in progress. The transfer continues but the data that caused the error may or may not be written to the transmit buffer. Because of this uncertainty, a transfer that experiences a write collision error is aborted and should be tried later. If the SSI is configured as a master, a transfer begins when data is written to the SSI data register and ends when the received data is transferred to the read data buffer, at which time SDONE is set. Note: A write collision error should not occur in master mode if the driver software is structured correctly. If the SSI is configured as a slave, it has no way to predict when the master will initiate a transfer. However, if SPHA = 0, the true end of the transfer does not occur until the SSN signal is deasserted. In this case, the user determines both the beginning and the end of transfer by polling the SSN line using bit 0 of SSI control register 2. The SPHA = 1 mode is more problematic since SSN is held low constantly or between transfers so SSN cannot always be used to tell whether a transfer is in progress. The end of transfer is determined via the SDONE flag in the SSI interrupt register, but there is no satisfactory way of determining the beginning of transfer. Therefore, write collisions are possible for this mode. However, these write collisions in the slave are avoided by writing SSNEN of SSI control register 1 to zero before writing the slave’s SSI data register. If SSNEN of SSI control register 1 is written to 0 during a transfer, the transfer terminates. The WCOLL flag, once set, is cleared by writing a 1 to the WCOLL field in the SSI interrupt register, followed by a read or write of the SSI data register. 15.3.6.3 MODF The MODF bit indicates a mode fault. A mode fault error occurs when the SSI is configured as a master and the SSN line is asserted. The SSNEN bit of SSI control register 1 (see Table 183 on page 204) is enabled for the SSN line to be recognized in master mode. If a mode fault is detected, the master SSI immediately disables its SCK clock and MDOSDI data output pins in order to eliminate any bus contention. 212 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 15 Synchronous Serial Interface (SSI) (continued) If the SSN signal is asserted by another master some considerable time after the master enables its SCK and MDOSDI drivers, the following events occur: ■ The SSI is disabled. The EN bit of SSI control register 1 is set to 0. ■ The SSI is reconfigured as a slave. The MSTR and SDONE bits are cleared to 0. ■ The master data output is disabled. ■ The SCK output pin is disabled. ■ MODF flag of SSI interrupt register is set to 1. Note: The MDOEN bit of SSI control register 1 remains set although this is harmless, since the SSI is reconfigured as a slave after the mode fault so the MDOEN bit has no effect. The MODF interrupt is asserted if MODFE is enabled in the SSI interrupt enable register. If the FASTCLEAR bit of SSI control register 2 is 1, the MODF flag is cleared by a read/write of the SSI data register. If the FASTCLEAR bit of SSI control register 2 is zero, the MODF flag is cleared by writing a 1 to the SSI interrupt register’s MODF. 15.3.6.4 RD_ORUN If the SSI is configured as a master, a read overrun error can occur if the RD_ORUN bit is set in the SSI interrupt enable register. The RD_ORUN bit in SSI interrupt register indicates the error. If RD_ORUN is 1 and the SSI is a master, a read overrun error occurs when the master’s SSI data register is overwritten with new data from the slave before the prior data from the slave is read from the register. The SSI data register is written with new data from the slave at the end of each byte transfer. It is anticipated that the read overrun error will be enabled (i.e., RD_ORUN will be 1) only when the DMA is being used to transfer data from the SSI data register to memory. A read overrun error can occur when the firmware writes a new data byte (e.g., byte number 2) to the SSI data register (that starts a new transfer) before the DMA reads the byte (e.g., byte number 1) previously received from the slave. The SSI data register is double-buffered on the read side, so byte number 1 is not overwritten in the SSI data register with the new data received from the slave (byte number 3) until the end of the transfer of byte number 2. This means that in order to avoid a read overrun error, the DMA must read byte number 1 from the SSI data register before the transfer of byte number 2 is complete. If a read overrun error does occur, the RD_ORUN bit will be set in SSI interrupt register and an interrupt will be generated from the SSI. The RD_ORUN bit and the interrupt are automatically cleared by writing a 1 to the RD_ORUN field in the SSI interrupt register. 15.3.7 SSI Transfer Abort An ongoing transfer to a slave is aborted by the master by deasserting the SSN signal to the slave or by the slave software writing a 0 to SSI control register 1 bit 10 in the slave. If the SSI is configured as a slave and the SSN line is pulled high, or SSI control register 1 bit 10 goes to 0 during transmission, all counters are reset. The state of the SSI data register is frozen at the time of the occurrence of the error. New data has to be written to the slave’s SSI data register to have a meaningful transmission following the error. There are no flags to indicate an aborted transfer. This condition is detected by software protocol. Agere Systems Inc. 213 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 15 Synchronous Serial Interface (SSI) (continued) 15.3.8 SSNEN Control Register Bit The SSNEN bit in SSI control register 1 enables the SSN signal in both the master and slave modes. SSI control register 1, bit 14, determines whether the SSI is a master or slave. When the SSI is a master, setting SSNEN allows a mode fault (SSI interrupt register, bit 5 MODF) to occur if the SSN input pin is asserted, meaning that some other unit in the SSI system is erroneously trying to select this master as a slave. When the SSI is a slave, setting SSNEN causes the slave to use the SSN input pin to determine whether it is selected. (If SSN is low, the slave is selected for operation, and if high, the slave is not selected for operation.) Clearing SSNEN prevents the slave from being selected for operation. It is sometimes necessary to write SSNEN to 0 before writing the slave’s SSI data register. For both master and slave SSI configurations, the status of the SSN input pin is always readable from bit 0 of SSI control register 2, regardless of the state of the SSNEN bit. 214 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 16 Parallel Peripheral Interface (PPI) The PPI consists of 16 programmable I/O pins. Features of the PPI are as follows: ■ Each bit is programmed as either an input or an output. ■ Inputs are programmed to be level-sensitive. ■ Outputs are programmed to be open-drain or direct-drive. ■ Programmable polarity (inverted or not) for inputs and outputs. ■ An interrupt request can be generated when a desired level occurs on any general purpose input pin. ■ Each I/O can be programmed to have an internal pull-up connected. 16.1 PPI Operation Figure 28 shows the PPI port. The PPI port controls 16 I/O pins. The functionality of each pin is programmed independently through the PPI data direction register, the PPI port sense register, the PPI port polarity register, the PPI port interrupt enable register, and the PPI port pull-up enable register. The PPI port data register (see Table 190 on page 219) is used to read input pins and to write output pins. The PPI data direction register controls whether a corresponding bit is an input or an output. The PPI port sense register (see Table 192 on page 220) configures outputs as open-drain or direct-drive. The PPI port polarity register (see Table 193 on page 220) allows both inputs and outputs to be inverted at the I/O pin. The PPI pull-up enable register (see Table 194 on page 221) allows an internal pull-up resistor to be connected to the pins. PERIPHERAL BUS DATA DIRECTION REGISTERS PORT SENSE REGISTERS PORT POLARITY REGISTERS P[15:0] DATA REGISTERS ARM CORE INTERRUPT ENABLE REGISTERS INPUT/DRIVE LOGIC INTERRUPT CONTROLLER IRQ 5-6665(F).b Figure 28. Parallel Peripheral Interface (PPI) Block Diagram Agere Systems Inc. 215 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 16 Parallel Peripheral Interface (PPI) (continued) 16.1.1 PPI Pin Configuration on Reset After reset, all PPI pins are configured as inverting inputs with pull-ups enabled. 16.1.2 Procedure for Writing to an Output Pin 1. Program the PPI data direction register for the pin as an output. 2. Program the PPI port sense register for the output as open-drain or direct-drive. 3. Program the PPI port polarity register for the output as inverted or noninverted (relative to the PPI port data register). 4. Write a value in the PPI port data register, PPI port data clear register, or PPI port data set register to specify the output level. If the corresponding PPI port polarity register bit is 1, a 1 in the PPI port data register causes the output pin to drive high if it is programmed as a direct-drive output or causes the output pin to go to high impedance if it is programmed as an open-drain output. Conversely, if the corresponding port polarity register bit is 0, a 1 in the PPI port data register causes both direct-drive and open-drain output pins to drive low. 16.1.3 Procedure for Reading from an Input Pin 1. Program the PPI port data direction register for the pin as an input. 2. Set the PPI port sense register to 0. 3. Program the PPI pull-up enable register if a pull-up resistor is desired on the I/O. 4. Program the PPI port polarity register to indicate whether the level on the pin is inverted before going to the PPI port data register. 5. Read the PPI port data register. Note: Reading the PPI port data clear register or the PPI port data set register has the same effect as reading the PPI port data register. 16.1.3.1 Additional Read/Write Notes ■ If the PPI bit is configured as an input, a high value on the pin is read as 1 in the PPI port data register if the corresponding bit of the PPI port polarity register is 1. Conversely, a low value on the input is read as 1 if the corresponding bit of the PPI port polarity register is 0. ■ When the PPI port data register is written, only the chip pins configured as outputs are modified; those configured as inputs are unaffected. ■ Input pins are asynchronous and are sampled at the system clock rate. In order for an input signal to be registered, it must have a minimum pulse-width of two system clock periods; see Figure 29 below. The CLK in this figure is the SYSTEM_CLK as defined by the clock selected in the reset/cock management section (see Reset/ Clock Management on page 29). 216 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 16 Parallel Peripheral Interface (PPI) (continued) CLK T MINIMUM INPUT HIGH WIDTH 2T MINIMUM INPUT LOW WIDTH 2T 5-8820(F) Figure 29. Minimum Data Input Pulse Width 16.1.4 PPI Port Interrupts The PPI port contains logic to generate a port interrupt request when a desired level occurs on general-purpose input pins associated with the port. Port bits that are configured as general-purpose outputs or pins that are not enabled in the PPI port interrupt enable register (see Table 191 on page 219) do not result in PPI interrupts. If the pin is configured as a general-purpose input, the corresponding bit in the PPI port interrupt enable register is set, and if the PPI interrupt request signal is enabled in the interrupt request enable register, then the input pin generates a PPI interrupt request. Note that an interrupt will be generated as long as the logic detects the programmed level. Note: The pin’s bit in the port’s data register always reflects the level on the pin if the corresponding bit in the PPI port polarity register is 1. If the corresponding bit in the PPI port polarity register is 0, the PPI port data register reflects the inverse of the level on the pin. An interrupt request from the PPI port is cleared by writing a 1 to the corresponding bit in the PPI port data register. However, if the interrupt activating level is present on the pin simultaneously with the write to the PPI port data register, the write to the register is ignored and the port’s interrupt request remains active. The generation of PPI interrupt requests on an 16-bit port basis has the following ramification: if the port interrupt request signal is generated by two or more of the 16 bits in the port, then it is possible that activity on one port input prevents activity on other port inputs from generating an interrupt request. This occurs if the activity on the other inputs occurs in the window between interrupt generation and clearing of the port’s interrupt request. Agere Systems Inc. 217 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 16 Parallel Peripheral Interface (PPI) (continued) 16.2 PPI Registers Table 188. PPI Parallel I/O Controller Register Map Register PPI port data direction register (see Table 189 on page 218). PPI port data register (see Table 190 on page 219). PPI port interrupt enable register (see Table 191 on page 219). PPI port sense register (see Table 192 on page 220). PPI port polarity register (see Table 193 on page 220). PPI port pull-up enable register (see Table 194 on page 221). Reserved. PPI port data clear register (see Table 195 on page 221). PPI port data set register (see Table 196 on page 222). Reserved. Address 0xE000 6000 0xE000 6004 0xE000 6008 0xE000 600C 0xE000 6010 0xE000 6014 0xE000 6018 0xE000 601C 0xE000 6020 0xE000 6024:0xE000 6036 16.2.1 PPI Data Direction Register The PPI port data direction register contains one bit for each of the general-purpose I/O pins. If a bit in the PPI port data direction register is a 1, the corresponding pin is an output; otherwise, it is an input. Table 189 below shows the format of the PPI port data direction register. On all resets, all bits in the PPI port data direction register are cleared to zeros, indicating inputs. Table 189. PPI Data Direction Register Address 0xE000 6000 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD PD[15:0] 15:0 PD[15:0] Description Reserved. Data direction bits. If 1, it indicates an output. If 0, it indicates an input. 16.3 PPI Port Data Register The PPI port data register reads general-purpose input pins and writes general-purpose output pins. When the PPI port data register is read, the bits configured as outputs reflect the value previously written to the register. The bits configured as inputs reflect the (possibly inverted) level on the input pin. When a new value is written to the PPI port data register, the corresponding pins that are programmed as general purpose outputs change to or stay at this value. Register bits configured as inputs do not respond to writes to the register. Table 190 below shows the format of the PPI port data register. On reset, all PPI port data register bits are cleared to zeros. 218 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 16 Parallel Peripheral Interface (PPI) (continued) Table 190. PPI Port Data Register Address 0xE000 6004 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD P[15:0] 15:0 P[15:0] Description Reserved. Port data bits. Bits configured as outputs reflect the value previously written to the register. Bits configured as inputs reflect the (possibly inverted) level on the input pin. The PPI port data register can be accessed in the following two methods: ■ Direct reads and writes of the PPI port data register. Note that to write selected bits, a read-modify-write operation must be performed on the PPI port data register in order to avoid changing other bits. ■ Reads and writes of the PPI port data clear register and PPI port data set register. A read of either of these registers has the same effect as a read of the PPI port data register. A write to the PPI port data set register writes a 1 to selected bits of the PPI port data register (those bits with a value of 1 during the write to the PPI port data set register). The other bits of the PPI port data register remain unchanged. A write to the PPI port data clear register writes a 0 to selected bits of the PPI port data register (those bits with a value of 1 during the write to the PPI port data clear register). The other bits of the PPI port data register remain unchanged. The use of the PPI port data set register and PPI port data clear register allows writing selected bits of the PPI port data register using only one operation. 16.3.1 PPI Interrupt Enable Register The PPI port interrupt enable register selects which bits of the port cause the port interrupt to be generated. If a bit in the register is 1 and the bit is configured as an input, the pin generates interrupts based on how it is configured in the PPI port polarity register. On reset, bits of this register are set to 0. Table 191. PPI Interrupt Enable Register Address 0xE000 6008 31:16 RSVD Bit # Name Bit # 31:16 15:0 15:0 PIE[15:0] Name Description RSVD Reserved. PIE[15:0] Interrupt enable bits. If a bit in the register is 1 and the bit is configured as an input, the pin generates interrupts based on how it is configured in the PPI port polarity register. 16.3.2 PPI Port Sense Register The PPI port sense register configures general purpose outputs as open-drain or direct-drive. If a bit in the register is 0, the corresponding output pin is direct-drive. If a bit in the register is 1, the output pin is open-drain. If a PPI bit is an input, the corresponding bit in the PPI port sense register must be set to 0. Table 192 shows the format of the PPI port sense register. On all resets, all bits in the register are cleared to 0. Agere Systems Inc. 219 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 16 Parallel Peripheral Interface (PPI) (continued) Table 192. PPI Port Sense Register Address 0xE000 600C 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD PS[15:0] 15:0 PS[15:0] Description Reserved. Port sense bits. If 0, the general purpose output pin is direct-drive. If 1, the general purpose output pin is open-drain. If a PPI bit is an input, the corresponding bit in the PPI port sense register must be set to 0. 16.3.3 PPI Port Polarity Register The PPI port polarity register specifies inversion of both input and output signals at general purpose pins. As a reference, logic signals in the PPI port data register are considered to be positive, or active-high. A value of 0 in the PPI port polarity register causes a signal entering or leaving the device on the pin to be inverted, thereby conforming to a negative, or active-low signal convention outside the device. Conversely, a value of 1 in the register causes a signal entering or leaving the device on the pin to be simply buffered, thereby conforming to a positive, or active-high, signal convention. The interpretation of the register bits differs somewhat for transition-detect inputs, as described in the following paragraphs. For an input, a value of 1 in the PPI port polarity register results in the value on the input pin being placed in the PPI port data register (noninverted, level-sensitive input), while a value of 0 in the PPI port polarity register results in the value on the pin being inverted before being placed in the PPI port data register (inverted, level-sensitive input). For a direct-drive output, a 1 in the appropriate bit of the PPI port polarity register results in the value in the PPI port data register being driven to the chip pin (noninverted, direct drive output), while a 0 in the appropriate bit of the PPI port polarity register results in the inverse of the PPI port data register value being driven to the pin (inverted, direct-drive output). For an open-drain output, a 1 in the appropriate bit of the PPI port polarity register results in the chip pin being driven to a 0 if there is a 0 in the corresponding PPI port data register, and results in the chip pin going to high impedance if there is a 1 in the PPI port data register (non-inverted, open-drain output). For an open-drain output, a 0 in the appropriate bit of the PPI port polarity register results in the chip pin being driven to high impedance if there is a 0 in the corresponding PPI port data register and results in the chip pin being driven to 0 if there is a 1 in the PPI port data register (inverted, open-drain output). On reset, all bits of the PPI port polarity register are cleared to 0, indicating inversion. Table 193. PPI Port Polarity Register Address 0xE000 6010 Bit # Name Bit # 31:16 15:0 220 31:16 RSVD 15:0 PP[15:0] Name Description RSVD Reserved. PP[15:0] Polarity bits. If the bit is set to 1, the corresponding input/output signal is not inverted. If the bit is set to 0, the corresponding input/output signal is inverted. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 16 Parallel Peripheral Interface (PPI) (continued) 16.3.4 PPI Pull-Up Enable Register The PPI port pull-up enable register is used to enable a pull-up resistor on the corresponding PPI I/O. If a bit in the register is 1, the corresponding pin is connected to an internal pull-up. Table 194 below shows the format of the PPI port pull-up enable register. On reset, all bits of this register are set to 1. For the case of multiplexed chip pins, the PPI pull-up enable register controls the connection of pull-up resistors to the I/O pins even if the pins are being used for non-PPI functions. When held in reset, the PPI pull-up bits in the PPI Port Pull-up Enable Register (Table 194) are configured to be inactive on all inputs. Immediately after reset, the pull-ups are active on all inputs. Table 194. PPI Pull-Up Enable Register Address 0xE000 6014 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD PPUE[15:0] 15:0 PPUE[15:0] Description Reserved. Port pull-up enable bits. If a bit in the register is 1, the corresponding pin is connected to an internal pull-up. 16.3.5 PPI Port Data Clear Register The PPI port data clear register is a 32-bit register containing 16 used bits, one for each of the general purpose PPI I/O pin. Each of the bits corresponds to a bit in the PPI port data register. The PPI port data clear register is not a real hardware register, but is instead an address used to clear bits in the PPI port data register. When a write is performed to the PPI port data clear register, each bit that is set to 1 results in the corresponding bit in the PPI port data register being cleared to 0. The other bits of the PPI port data register remain unchanged. A read of the PPI port data clear register address returns the data in the PPI port data register. Table 195. PPI Port Data Clear Register Address 0xE000 601C 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD PDC[15:0] 15:0 PDC[15:0] Description Reserved. Port data clear bits. When a write is performed to the PPI port data clear register, each bit that is set to 1 results in the corresponding bit in the PPI port data register being cleared to 0. The other bits of the PPI port data register remain unchanged. 16.3.6 PPI Port Data Set Register The PPI port data set register is a 32-bit register containing 16 used bits, one for each of the general purpose PPI I/O pin. Each of the 16 bits corresponds to a bit in the PPI port data register. The PPI port data set register is not a real hardware register, but is instead an address used to set bits in the PPI port data register. When a write is performed to the PPI port data set register, each bit that is set to 1 results in Agere Systems Inc. 221 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 16 Parallel Peripheral Interface (PPI) (continued) the corresponding bit in the PPI port data register being set to 1. The other bits of the PPI port data register remain unchanged. A read of the PPI port data set register address returns the data in the PPI port data register. Table 196. PPI Port Data Set Register Address 0xE000 6020 31:16 RSVD Bit # Name Bit # 31:16 15:0 Name RSVD PDS[15:0] 15:0 PDS[15:0] Description Reserved. Port data set bits. When a write is performed to the PPI port data set register, each bit that is set to 1 results in the corresponding bit in the PPI port data register being set to 1. The other bits of the PPI port data register remain unchanged. 16.4 Summary of Programming Modes Table 197. PPI Programming Modes Port Data Direction Register Port Sense Register 0 0 1 1 1 1 0 0 0 0 1 1 222 Port Polarity Register 0 1 0 1 0 1 Port Function Inverted, level sensitive input. Noninverted, level sensitive input. Inverted, direct drive output. Noninverted, direct drive output. Inverted, open drain output. Noninverted, open drain output. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 17 Key and Lamp Controller (KLC) The key and lamp controller (KLC) consists of 7 row outputs and 8 column inputs/outputs that are used to control up to 56 LEDs and scan up to 56 keys. The KLC also contains two direct LED connections for a total of 58 LEDs. There is also a switch sense input used to monitor the on/off hook status of the IP telephone. One additional output, the LCNTRL, is used to enable/disable the LED drive matrix during the key scan operations. This control also turns off LED power during the transition times while the row and column outputs are changing. The KLC can turn up to 58 LEDS on and off, and it provides timing for 6 flash rates. These flash rates are individually settable for each LED. The flash rates provided by the KLC are as follows: ■ OFF—default state All LEDs are placed in this state by a reset. ■ WINK—200 ms on then 50 ms off. ■ INVERSE WINK—200 ms off then 50 ms on. ■ FLASH—500 ms on then 500 ms off. ■ INVERSE FLASH—500 ms off then 500 ms on. ■ FLUTTER—50 ms on then 50 ms off. ■ BROKEN FLUTTER—500 ms of flutter then 500 ms off. ■ STEADY ON—continuously on. ROW STROBE BUS K_ROW[6:0] KEYBOARD MATRIX KLC INTERFACE ROW OUTPUT STROBES K_ROW[0] K_ROW[0] K_ROW[1] K_ROW[1] K_ROW[2] K_ROW[2] K_ROW[3] K_ROW[3] K_ROW[4] K_ROW[4] K_ROW[5] K_ROW[5] K_ROW[6] K_ROW[6] K_ROW[0] +VCC LED MATRIX K_ROW[1] K_ROW[2] K_ROW[3] K_ROW[4] COLUMN I/O K_COL[0] K_COL[0] K_COL[1] K_COL[1] K_COL[2] K_COL[2] K_COL[3] K_COL[3] K_COL[4] K_COL[4] K_COL[5] K_COL[5] K_COL[6] K_COL[6] K_COL[7] K_COL[7] K_ROW[5] K_ROW[6] LCNTRL K_COL[0] +VCC K_COL[1] K_COL[2] K_COL[3] MSGLED K_COL[4] +VCC SPKRLED SWHOOK SWITCHHOOK K_COL[5] K_COL[6] K_COL[7] 5-8217(F).a Figure 30. KLC Interface Matrix Agere Systems Inc. 223 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 17 Key and Lamp Controller (KLC) (continued) 17.1 KLC Operation A schematic of the KLC interface matrix is shown in Figure 30. The KLC uses a time-division multiplexed scheme for sampling the keyboard matrix and driving the LED matrix. The keyboard matrix is sampled once every 12.5 ms and the LED matrix is driven between key samples. The values stored in the lamp rate registers determine the flash patterns for all LED's in the matrix. The key scan status register contains information about what keys are pressed and the current state of the switch-hook at the end of the key scan cycle. The KLC noscan control register contains the reset bit for the KLC and allows control over the amount of time the KLC will wait to sample the key matrix after detecting a key press or release. Interrupts generated by key-presses, key releases, or the switch-hook will be noted in the KLC interrupt register if the specific type of KLC interrupt is enabled in the KLC interrupt enable register. 17.1.1 LED Drive Matrix Operation The KLC drives the LEDs in its matrix in a time division multiplexed scheme. Each LED row is activated (driven low) one at a time. While that row is activated, all LEDs in that row that are programmed to be on at that time will be illuminated by activating those LED’s columns (driving them high). LEDs that are not programmed to be illuminated will have their columns deactivated. In order for LEDs to be activated, the LCNTRL output must be high. While the KLC is transitioning between LED rows, the LCNTRL signal turns off power to the LED matrix for a short time. This allows time for the column outputs to change for the new row. Upon completion of the LED drive time for all rows LCNTRL will deactivate the LED matrix, and the key matrix will be sampled. Then the LED rows will be driven again in the same order starting with row 0 and ending with row 6. The KLC contains 29 LED rate registers. Each of these registers controls two LEDs. The first 28 registers control the LEDs in the LED matrix. The twenty-ninth register controls the message and speaker LED direct-drive output pins. All LED rate registers are set to all zeros (LEDs off) during reset. The KLC will generate the rate patterns for the LED drive from the 32.768 kHz input clock (RTC). Each of the LEDs will be driven by one of these patterns. This means that every LED, set to the same pattern, will turn on and off at the same time and will remain in synchronization with each other. The LED drive matrix elements must be designed to handle the current needed by the LED drive matrix. The external row PNP transistors must be capable of driving all LEDs in its respective row. At higher currents, the forward current gain of most transistors must be derated from their typical values. In addition, as these transistors are driven into saturation, the current gain is also reduced. The KLC row outputs are designed with an 8 mA output driver to provide adequate low-level current output capacity. The LCNTRL external NPN transistor must be able to handle as much current as any row transistor. Its output is designed with an 8 mA output driver that provides at least 8 mA of high-level current output capacity that will adequately drive a properly selected transistor into saturation. Each external column NPN transistor handles at most a single LED’s current at any one time. The column output pins are designed with 4 mA output buffers. These buffers can provide an output high-level current capacity of 4 mA that is more than sufficient to drive the external matrix transistors. The message and speaker LED output pins MSGLED and SPKRLED are designed with an 8 mA output buffer that will handle either a red or a green LED. 17.1.2 Key Scan Matrix Operation The KLC scans its key matrix by asserting the row outputs and checking for connections to any column inputs (indicating a pressed key). The KLC turns off all LEDs by driving its master LCNTRL output to an inactive state, disabling all LED columns. The KLC then 3-states the column inputs leaving their internal 50 kΩ pull-down resistor connected, asserting all row outputs simultaneously. Any key that is depressed will connect its column pin to its row pin via a low-impedance path and will pull the column pin high. If no keys are pressed, the column inputs remain low (due to their internal pull-down resistors) and the KLC precedes with its next LED drive cycle. 224 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 17 Key and Lamp Controller (KLC) (continued) However, if any column inputs are found to be high indicates that a key must be pressed and the KLC will determine its location. When a user depresses keys on the keypad, the keys often bounce before settling into the on state. To avoid this problem, a debounce interval has been incorporated into the design. The debounce interval is the period between detecting that a key has been pressed, and the time it scans the matrix to detect which specific key has been pressed. During this interval of roughly 2.5 ms, the KLC switches to LED drive mode and drives the first three rows of the LED matrix. After finishing the third LED row's time slice, the KLC disables the LED matrix and scans the key matrix to determine which key has been pressed. This process involves asserting each row output individually for roughly 125 ns and checking the column inputs. When a certain row causes a certain column to be asserted, the location of the key has been determined. At the end of this interval, the key scan status register is set with the row and column of the pressed key (see Table 204 on page 230) and any enabled interrupts corresponding to the key-press are asserted. The remaining four LED rows are driven after locating the key to finish the LED drive cycle that was interrupted by the key location process. The KLC provides a programmable delay interval after it detects a key transition. During this noscan interval the key matrix will not be scanned. The KLC will not scan the key matrix for 0, 1, 2, or 3 LED drive cycles depending on the programmed noscan code residing in the noscan control register, see Table 202 on page 229. After this noscan delay interval, the KLC begins waiting for the key to be released. During these key scan intervals, the KLC asserts the row containing the pressed key and checks the column containing the pressed key. If the column is still pulled high, the key is still depressed. If the column stays low, the key has been released and again the key scan status register and interrupt registers are updated. A noscan period is also inserted after the key is released before any new key presses can be noted. The process for detecting a key press and release is summarized in the following state description: ■ Ready to detect key depression: the KLC is looking for a key depression and upon completion of driving the last LED row (ROW8) it will sample all the rows of the key matrix. If it detects a key depression, it will enter the next state. ■ Detected key depression: the KLC detected a key depression during the last key sample cycle. It waits 2.5 ms as a key debounce time and then scans each row in the key matrix. The row/column address of the first key it finds depressed will be recorded in the key scan status register. The press bit will also be set to 1 on the following clock, setting the row/column address. This will generate an interrupt to the processor if the corresponding bit is enabled in the interrupt controller. After recording the key depression in the key scan status register, the KLC will enter the next state. ■ Detected key wait: after recording a key depression in its register, the KLC will not sample the key matrix at the end of the cycle during which it scanned the matrix. In addition, the KLC will not scan the key matrix again for the time set in the noscan control register. ■ Wait for key release: when the noscan interval has expired the KLC will enter this state. The KLC will sample the key matrix looking only for the key recorded in its key scan status register. When the KLC detects that key as not being depressed, it will reset the press bit in its key scan status register to 0. ■ Key released wait: the KLC detected that the key it recorded as pressed has now been released. The KLC will wait the number of LED drive cycles programmed into its noscan control register before acting on any new key depressions. When the noscan interval has expired, the KLC will enter the first state. The circuit interface to the KLC should be designed so that the red and green LEDs associated with a key are placed in the same row and adjacent columns. This would place both LEDs in the same register with the red LED in the low nibble and the green LED in the high nibble. If more than one key is depressed at a time, the KLC detects the first key that is registered as being pressed. If multiple keys are pressed in one column of the key matrix during the keyboard scanning cycle, one row will attempt to pull the column high while the other rows will pull the column low. To avoid a short in this situation, diodes have been placed in the KLC interface matrix, see Figure 30 on page 223. Agere Systems Inc. 225 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 17 Key and Lamp Controller (KLC) (continued) 17.1.3 KLC Interrupts The KLC will generate interrupts for key releases, key presses, and switch hook changes. The KLC interrupt enable register allows the processor to enable and disable each of the three types of KLC interrupts. If an enabled action occurs, the corresponding bits are set in the KLC interrupt register. Also, if the programmable interrupt controller (PIC) enable bits are set to allow KLC interrupts to propagate to the ARM, the KLC interrupt bit in the PIC will also be set. The interrupt bits will remain set until a 1 is written to the corresponding bit of the KLC interrupt register. This action will clear the KLC interrupt register bit and will remove the interrupt. 17.1.4 Timing and Reset The KLC supports both a hardware and software reset. The software reset is accomplished by setting the RESET bit of the noscan control register to 1. The KLC will resume operation when this bit is cleared to 0. These resets will set all LEDs to the off state and set all control registers to their default states. The exceptions to this are: for a software reset, the noscan control register's noscan interval bits remain unchanged, as do the interrupt registers. The reset input will set an internal reset latch and the reset will not be removed until a valid low to high clock transition is present. For both types of resets, the MSGLED and SPKRLED outputs are driven low to light the MSG and SPKR LEDs notifying the user of the reset. The KLC will derive all of its timing from the 32.768 kHz clock provided by the real-time clock SLOW_CLK. If the source of SLOW_CLK is EXT_PROG_CLK, the value in the RTC external divider register must be 0x2C0 to achieve proper KLC timing. Note: Changing the value in the RTC external divider register also changes the manner in which the RTC divider register, and hence the RTC seconds count register, count. Thus, to achieve proper RTC timing, an external crystal should be used. 17.2 KLC LED Drive and Key Scan Matrix Pins The following pins are associated with the LED drive matrix and the key scan matrix: ■ Seven row-output pins K_ROW6:0. ■ Eight column-output pins K_COL7:0. ■ The signal to enable or disable current in the LED drive matrix LCNTRL. ■ Two outputs used to drive the speaker and message LEDs. ■ Switch hook sampling input. . Table 198. KLC Matrix Pins Pin Name LCNTRL I/O Type Output Current IOH 8 mA Current IOL 8 mA Pull-up/Down None K_ROW[6:0] I/O 8 mA 8 mA None I/O Signal Description High active output used to enable LED drive matrix. 7 row input/output for the LED drive matrix and key scan matrix. Low active for LED drive matrix. High active for key scan matrix. 226 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 17 Key and Lamp Controller (KLC) (continued) Table 198. KLC Matrix Pins (continued) Pin Name I/O Type K_COL[7:0] I/O MSGLED, SPKRLED SWHOOK Current IOH 4 mA Current IOL 4 mA Pull-up/Down 50K pull-down O 8 mA 8 mA None I — — — I/O Signal Description 8 column input/output for LED drive matrix and inputs for key scan matrix. Message and speaker LED direct output. Active-low. — The seven row output pins are driven by an 8 mA type output driver. This will provide a minimum low-level current output of 8 mA and a minimum high-level current output of 8 mA. The 8 column output pins are driven by a 4 mA type output driver. This will provide a minimum low-level output current of 4 mA and a minimum high-level output current of 4 mA. Each column output pin also contains a 50 KΩ pull-down resistor. The LCNTRL output pin is driven by a 8 mA type output driver. This will provide a minimum low-level current output of 8 mA and a minimum high-level current output drive of 8.0 mA. The message and speaker LED output pins are driven by an 8 mA type output driver. This will provide a minimum low-level current output of 8 mA and a minimum high-level current output of 8 mA. The seven row output pins K_ROW[6:0] are driven active-low one at a time, each turning on a single row in the LED drive matrix. The other rows are 3-stated to turn off the respective transistor, disabling that row's power. Specific LEDs in the enabled row are turned on by driving the corresponding column pins active-high. LCNTRL is driven active-high to enable the entire LED drive matrix. The seven row output pins K_ROW[6:0] are driven active-high to sample the key scan matrix. The column pins are 3-stated during the key scan process but their pull-down resistor will keep them at a low logic level unless a key is depressed and that column pin is pulled high by the low impedance path created between that key's row and column pins. The message and speaker LEDs are connected to the MSGLED and SPKRLED pins. These pins are driven active-low to turn on the respective LEDs. These pins will also be driven active-low when the KLC is in a software or hardware reset state. This will enable a user to detect the presence of power on the set if the microprocessor is not working properly. These LEDs will be off after the KLC exits the reset state and each LED will be controlled by its lamp rate register. 17.3 KLC Register Table 199. KLC Register Map Register Lamp rate registers Noscan control register Key scan status register KLC interrupt register KLC interrupt enable register Address 0xE000 D000:0xE000 D070 0xE000 D100 0xE000 D140 0xE000 D180 0xE000 D1C0 17.3.1 Lamp Rate Registers Rate generation for the LED key matrix is provided by the lamp rate register for address 0xE000 D000:0xE000 D06C. In addition, one more register is provided (0xE000 D070) for programming rate generation to the speaker and message LEDs. There are 56 LEDs; one register for two LEDs. Agere Systems Inc. 227 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 17 Key and Lamp Controller (KLC) (continued) Table 200. Lamp Rate Registers Bit # Name Bit # Name 7 RSVD Address 0xE000 D000, 0xE000 D06C, Write Only 6 5 4 3 2 Lamp B Lamp B Lamp B R’SRVD Lamp A Rate Rate bit 2 Rate Bit 1 Rate bit 0 bit 2 (MSB) (MSB) (LSB) Address 0xE000 D070, Write Only 6:4 3 Speaker LED rate Reserved 31:7 Reserved 1 Lamp A Rate bit 1 0 Lamp A Rate bit 0 (LSB) 2:0 Message LED rate Table 201. Lamp Rate Bit Encoding Bit 2 0 0 0 0 1 1 1 1 Bit 1 0 0 1 1 0 0 1 1 Bit 0 0 1 0 1 0 1 0 1 Flash Rate Off. Wink (200 ms on, 50 ms off). Inverse wink (200 ms off, 50 ms on). Inverse flash (500 ms off, 500 ms on). Flash (500 ms on, 500 ms off). Flutter (50 ms on, 50 ms off). Broken flutter (500 ms of flutter, 500 ms off). Steady on. 17.3.2 KLC Noscan Control Register The noscan control register contains the software reset bit and the keyboard noscan interval code. This register is written to reset the KLC or to release the KLC from reset. If the reset bit is set to a 1, the KLC will reset, meaning it will stop scanning buttons, set all lamp rates to off, and drive the MSGLED and SPKRLED outputs low. If the reset bit is 0, then the KLC will start (or continue) operation. When the reset bit is changed from a 1 to a 0, the KLC will exit reset at the next low to high transition of its 32 kHz clock and start its lamp timing cycle from the beginning. During a reset the MSGLED and SPKRLED outputs will be driven active-low. The lamp rate register controlling these outputs will be cleared to the default off state. When the reset is deasserted, the KLC will deassert these outputs, turning off the two LEDs. Note: The KLC does not come out of a software reset state until the microprocessor writes a 0 into the reset bit of the noscan control register. A hardware reset will clear the KLC’s reset bit to 0 and will exit the reset state as soon as the reset pin is low and the clock is present. The microprocessor can change the noscan interval of the KLC through bits 0 and 1 of the noscan control register. These bits will be reset to 1 (for the default interval) by a hardware reset. The noscan delay interval specifies the amount of time the KLC will wait to scan the key matrix after detecting a key depression or release; see Section 17.1.2 on page 224. 228 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 17 Key and Lamp Controller (KLC) (continued) Table 202. Noscan Control Register Bit # Name 31:8 RSVD Bit # 31:8 7 6:2 1:0 7 RESET Name RSVD RESET 6:2 RSVD Address 0xE000 D100 1 Noscan interval bit 1 0 Noscan interval bit 0 Description Reserved. Reset bit. If 1, the KLC will reset. The KLC interrupt register and the KLC interrupt enable register are left unchanged. If 0, then the KLC will start (or continue) operation. RSVD Reserved. NOSCAN INTERVAL Noscan interval. The noscan interval of the KLC can be changed through bits 0 and 1 of the KLC control register. These bits will be reset to 1 (for the default interval) by a hardware reset. Table 203. Noscan Delay Interval Encoding Bit 1 0 0 1 1 Bit 0 0 1 0 1 Key Depression Noscan Interval 60 ms 22.5 ms 35 ms 47.5 ms (default) Key Release Noscan Interval 50 ms 12.5 ms 25 ms 37.5 ms (default) When a key is pressed, the KLC includes a debounce interval during which the beginning of an LED drive period is executed before the key is located. After the key is located, the KLC must finish the suspended LED drive period. This takes roughly 10 ms, that accounts for the difference in key depression and key release noscan intervals. 17.3.3 Key Scan Status Register The KLC updates the key scan status register to indicate the current status of the key scan matrix. The KLC samples the key matrix every 12.5 ms. When the KLC detects a key depression, it will wait for a 2.5 ms debounce interval and then scan each row in its key matrix. When it locates the specific key depressed, it will place that key’s row and column location into the key scan status register and set the key press bit to 1. The KLC will delay setting the press bit to 1 until the following clock cycle to ensure that an asynchronous read from the microprocessor will not read the press bit as 1 with an invalid code. After setting the key scan status register, the KLC will then wait its programmed noscan interval, before acting on any changes during its sampling interval. After the noscan interval has elapsed, the KLC will check that key once every 12.5 ms to determine if that key has been released. When the KLC detects that the key is no longer depressed, it will reset the press bit to 0. The KLC will wait its programmed noscan interval again before it will act on any new key depressions found during its sampling interval. Agere Systems Inc. 229 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 17 Key and Lamp Controller (KLC) (continued) Table 204. Key Scan Status Register Address 0xE000 D140, Read-Only 7 6 5 4 3 2 Bit # K_ROW K_ROW K_COL Name KEYPRESS SWHOOK K_ROW ON/OFF bit 2 (MSB) bit 1 bit 0 (LSB) bit 2 (MSB) Bit # 7 6 5 4 3 2 1 0 Name KEYPRESS SWHOOKON/OFF K_ROW bit 2 K_ROW bit 1 K_ROW bit 0 K_COL bit 2 K_COL bit 1 K_COL bit 0 1 K_COL bit 1 0 K_COL bit 0 (LSB) Description 1 = key press; 0 = no key press. Switch hook on/off. Press key row number (MSB). Press key row number. Press key row number (LSB). Press column row number (MSB). Press column row number. Press column row number (LSB). 17.3.4 KLC Interrupt Register The KLC interrupt register contains the interrupt bits for KLC events. Writing a 1 to the corresponding bit will clear the register. Writing a 0 will hold the current state. For a software reset (setting RESET in Table 202 on page 229), this register will be left unchanged. Table 205. KLC Interrupt Register Bit # Name 31:3 Reserved Bit # 31:3 2 1 0 Name Reserved SWHK KEYR KEYP Address 0xE000 D180 2 SWHK 1 KEYR 0 KEYP Description Reserved. Switch hook status change interrupt. Key release interrupt. Key press interrupt. 17.3.5 KLC Interrupt Enable Register The KLC interrupt enable register allows masking of the three types of KLC interrupts. Writing a 1 to the corresponding bit will clear the register. If an interrupt event occurs, the enable bit must be set to 1 in order for the interrupt to be asserted in the KLC interrupt register and the PIC interrupt request status register (see Table 26 on page 51). For a software reset (setting RESET in Table 202 on page 229), this register will be left unchanged. . Table 206. KLC Interrupt Enable Register Bit # Name 31:3 Reserved Bit # 31:3 2 1 0 Name Reserved SWHRE KEYRE KEYPE 230 Address 0xE000 D1C0 2 SWHRE 1 KEYRE 0 KEYPE Description Reserved. Switch hook status change interrupt enable. Key release interrupt enable. Key press interrupt enable. Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan Access to JTAG (joint test action group) and boundary-scan will be initially provided through a single set of JTAG pins. The pin definitions are as follows: Table 207. Boundary Scan Pin Functions Pin P1 N3 P3 P2 R1 Boundary-Scan JTRSTN (bscan) JTDO (bscan) JTCK (bscan) JTMS (bscan) JTDI (bscan) Debug JTRSTN (debug) JTDO (debug) JTCK (debug) JTMS (debug) JTDI (debug) Debug mode, or boundary scan mode is selected via the JMODE pin (V18) as shown below. Pin V18 ■ Name JMODE Description When 0 = boundary scan. When 1 = debug. Refer to the ARM 940T documentation for additional information about JTAG and TAP controller signals. 18.1 Debug Support Through the ARM 940T JTAG interface and embedded ICE macrocell, the ARM development tools will provide the user with the following hardware development capabilities: ■ Breakpointing on two watchpoints or breakpoints. ■ Single-stepping or step-by-N through code. ■ Inspection and modification of ARM accessible registers. ■ Inspection and modification of ARM memory. ■ Device reset through JTAG. JTAG support is provided directly from the ARM940T core. Documentation for JTAG can be found in the ARM940T technical reference. Part number: ARMDDI 0144A. 18.2 The Principle of Boundary Scan Architecture Each primary input signal and primary output signal is supplemented with a multipurpose memory element called a boundary scan cell. Cells on device primary inputs are referred to as input cells and cells on primary outputs are referred to as output cells. Input and output is relative to the core logic of the device. At any time, only one register can be connected from JTDI to JTDO; for example, instruction register (IR), BYPASS, boundary scan, IDENT, or even some appropriate register internal to the core logic; see Figure 31. The selected register is identified by the decoded output of the instruction register. Certain instructions are mandatory, such as EXTEST (boundary scan register selected), whereas others are optional, such as the IDCODE instruction (ident register selected). Agere Systems Inc. 231 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 18 JTAG/Boundary Scan (continued) INTERNAL CORE LOGIC JTDO JTDI BYPASS TEST DATA IN TEST DATA OUT IDENTIFICATION REGISTER INSTRUCTION REGISTER (IR) TEST MODE SELECT JTMS TAP TEST CLOCK JTCK CONTROLLER TEST RESET (JTRSTN) IEEE 1149.1 CHIP ARCHITECTURE Figure 31. Boundary Scan Architecture Figure 31 shows the following elements: ■ A set of four dedicated test pins, test data in (JTDI), test mode select (JTMS), test clock (JTCK), test data out (JTDO), and one optional test pin test reset (JTRSTN). These pins are collectively referred to as the test access port (TAP). ■ A boundary scan cell on each device’s primary input and primary output pin, connected internally to form a serial boundary scan register (boundary scan). ■ A finite-state machine TAP controller with inputs JTCK and JTMS. ■ An n-bit (n = 4) instruction register (IR), holding the current instruction. ■ A 1-bit bypass register (BYPASS). ■ An optional 32-bit identification register (Ident) capable of being loaded with a permanent device identification code. 232 Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan (continued) t1 t4 t2 JTCK0, JTCK1 t3 VIH VIL t6 t5 t7 JTMS0, JTMS1 VIH VIL t8 t9 JTDI0, JTDI1 VIH VIL t10 t11 JTDO0, JTD01 Reference t1 t2 t3 t4 t5 t6 t7 t8 t9 t10* t11* VOH VOL Description JTCK period (high to high). JTCK high time (high to low). JTCK low time (low to high). JTCK rise transition time (low to high). JTCK fall transition time (high to low). JTMS setup time (valid to high). JTMS hold time (high to invalid). JTDI setup time (valid to high). JTDI hold time (high to valid). JTDO delay (low to valid). JTDO hold (low to invalid). Minimum 40 ns 20 ns 20 ns 0.5 V/ns 0.5 V/ns 2.0 ns 0 ns 1.5 ns 0 ns — — Maximum — — — 10%—90% 10%—90% — — — — 9.8 ns 6.0 ns * Output all specified with 20 pF load. 5-4017F Figure 32. JTAG Interface Timing Diagram 18.2.1 Instruction Register The instruction register is 4 bits long and the capture value is 0001. Table 208. Instruction Register Instruction EXTEST SAMPLE IDCODE BYPASS Agere Systems Inc. Binary Code 0000 0010 1110 1111 Description Places the boundary scan register in EXTEST mode. Places the boundary scan register in sample mode. Identification code. Places the bypass register in the scan chain. 233 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 18 JTAG/Boundary Scan (continued) 18.3 Boundary Scan Register Note: The control column of the following table indicates the value for boundary scan control of this pin. Table 209. Boundary Scan Register Description Boundary Scan Register Bit Pin 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 234 Pin Name Ball DSP_D_E DSP_D(0) DSP_D(5) DSP_D(6) DSP_D(9) DSP_D(13) DSP_RWN_E DSP_RWN DSP_A_E DSP_A(0) DSP_A(4) DSP_A(7) DSP_A(8) RESETN T_REQB MDOSDI_E MDOSDI USBALTCK_E USBALTCK K_ROW_E(5) K_ROW(5) K_ROW_E(1) K_ROW(1) K_ROW_E(0) K_ROW(0) K_COL_E K_COL(5) K_COL(1) MSGLED_E MSGLED TMODE(0) SC_MODEN_E SC_MODEN TESTPT_E(16) TESTPT(16) TESTPT_E(13) TESTPT(13) TESTPT_E(11) — B1 C1 D1 E1 F1 — G1 — H1 J1 K1 L1 N1 U1 — W1 Y1 — Y2 — Y3 — Y4 — Y5 Y6 — Y7 Y8 — Y9 — Y13 — Y14 — Enabled State Controller I/O I/O I/O I/O I/O Controller I/O Controller I/O I/O I/O I/O I I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I/O Controller I/O I Controller I/O Controller I/O Controller I/O Controller Pin Grouping — DSP_D_E DSP_D_E DSP_D_E DSP_D_E DSP_D_E — DSP_RWN_E — DSP_A_E DSP_A_E DSP_A_E DSP_A_E — — — MDOSDI_E — BALTCK_E — K_ROW_E(5) — K_ROW_E(1) — K_ROW_E(0) — K_COL_E K_COL_E — MSGLED_E — — SC_MODEN_E — TESTPT_E(16) — TESTPT_E(13) — Control Disabled State 0 0 0 0 0 0 0 0 0 0 0 0 0 — — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 — 50 kW pull-up 50 kW pull-up 50 kW pull-up 50 kW pull-up 50 kW pull-up — High impedance — High impedance High impedance High impedance High impedance — 50 kΩ pull-down 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up High impedance — High impedance — High impedance — High impedance — 50 kΩ pull-down 50 kΩ pull-down — High impedance 50 kΩ pull-up — 50 kΩ pull-up — High impedance — High impedance — Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 Agere Systems Inc. Pin Name Ball TESTPT(11) TESTPT_E(8) TESTPT(8) TESTPT_E(4) TESTPT(4) TESTPT_E(1) TESTPT(1) OMUXSEL(2) XS_E(1) XS(1) LS10_OK_E(1) LS10_OK(1) PPI_E(12) PPI(12) PPI_E(9) PPI(9) PPI_E(7) PPI(7) PPI_E(4) PPI(4) PPI_E(0) PPI(0) TX1 RDARX0 A_E A(23) A(18) A(17) A(14) A(10) A(7) A(4) A(0) WRN_E WRN CS1_E CS1 EXWAIT_E EXWAIT SDCASN_E SDCASN Y15 — Y16 — Y17 — Y18 Y19 Y20 — J20 — H20 — G20 — F20 — E2 — D20 B20 A20 — A19 A18 A17 A16 A15 A14 A13 A12 — A11 — A10 — A9 — A8 Enabled State I/O Controller I/O Controller I/O Controller I/O I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Out2 I Controller I/O I/O I/O I/O I/O I/O I/O I/O Controller I/O Controller I/O Controller I/O Controller I/O Pin Grouping TESTPT_E(11) — TESTPT_E(8) — TESTPT_E(4) — TESTPT_E(1) — — XS_E(1) — LS10_OK_E(1) — PPI_E(12) — PPI_E(9) — PPI_E(7) — PPI_E(4) — PPI_E(0) — — — A_E A_E A_E A_E A_E A_E A_E A_E — WRN_E — CS1_E — EXWAIT_E — SDCASN_E Control Disabled State 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 High impedance — High impedance — High impedance — High impedance 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance — — — High impedance High impedance High impedance High impedance High impedance High impedance High impedance High impedance — High impedance — High impedance — High impedance — High impedance 235 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 236 Pin Name SDLDQM_E SDLDQM DH_E D(15) D(12) D(8) DL_E D(5) D(0) D(1) DSP_D(1) DSP_D(2) DSP_D(8) DSP_D(12) DSP_D(15) DSP_ICSN_E DSP_ICSN DSP_A(3) DSP_A(5) DSP_A(9) CLKREF_E CLKREF RSTON_E RSTON T_ACK_E T_ACK SCK_E SCK SSN_E SSN K_ROW_E(6) K_ROW(6) K_ROW_E(4) K_ROW(4) K_COL(6) K_COL(2) LCNTRL_E LCNTRL SWHOOK_E SWHOOK TMODE(3) Ball — A7 v A6 A5 A4 — A3 A2 B2 C2 D2 E2 F2 G2 — H2 J2 K2 L2 — M2 — N2 — T2 — V2 — W2 — W3 — W4 W5 W6 — W7 — W8 W9 Enabled State Controller I/O Controller I/O I/O I/O Controller I/O I/O I/O I/O I/O I/O I/O I/O Controller I/O I/O I/O I/O Controller Out3 Controller Out3 Controller Out3 Controller I/O Controller I/O Controller I/O Controller I/O I/O I/O Controller I/O Controller I/O I Pin Grouping — SDLDQM_E — DH_E DH_E DH_E — DL_E DL_E DL_E DSP_D_E DSP_D_E DSP_D_E DSP_D_E DSP_D_E — DSP_ICSN_E DSP_A_E DSP_A_E DSP_A_E — CLKREF_E — RSTON_E — T_ACK_E — SCK_E — SSN_E — K_ROW_E(6) — K_ROW_E(4) K_COL_E K_COL_E — LCNTRL_E — SWHOOK_E X Control Disabled State 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — — High impedance — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up High impedance High impedance High impedance High impedance High impedance — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance 50 kΩ pull-down 50 kΩ pull-down — High impedance — High impedance 50 kΩ pull-up Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 Agere Systems Inc. Pin Name SC_ENAN_E SC_ENAN TESTPT_E(19) TESTPT(19) TESTPT_E(15) TESTPT(15) TESTPT_E(12) TESTPT(12) TESTPT_E(9) TESTPT(9) TESTPT_E(5) TESTPT(5) TESTPT_E(2) TESTPT(2) OMUXSEL(1) XS_E(0) XS(0) LS100_OK_E(0) LS100_OK(0) PPI_E(15) PPI(15) PPI_E(11) PPI(11) PPI_E(8) PPI(8) PPI_E(5) PPI(5) PPI_E(1) PPI(1) PWRFLTN IRDATX0_E IRDATX0 A(22) A(21) A(15) A(11) A(8) A(5) A(1) FLASH_CS_E FLASH_CS Ball — W10 — W12 — W13 — W14 — W15 — W16 — W17 W18 — W19 — K19 — J19 — H19 — G19 — F19 — E19 D19 — B19 B18 B17 B16 B15 B14 B13 B12 — B11 Enabled State Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I Controller out3 I/O I/O I/O I/O I/O I/O I/O Controller I/O Pin Grouping — SC_ENAN_E — TESTPT_E(19) — TESTPT_E(15) — TESTPT_E(12) — TESTPT_E(9) — TESTPT_E(5) — TESTPT_E(2) X — XS_E(0) 0 LS100_OK_E(0) — PPI_E(15) — PPI_E(11) — PPI_E(8) — PPI_E(5) — PPI_E(1) X — IRDATX0_E A_E A_E A_E A_E A_E A_E A_E — FLASH_CS_E Control Disabled State 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 0 — 50 kΩ pull-up High impedance High impedance — High impedance — High impedance — High impedance — High impedance — High impedance 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance 50 kΩ pull-up — High impedance High impedance High impedance High impedance High impedance High impedance High impedance High impedance — High impedance 237 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 238 Pin Name Ball CS2_E CS2 EXINT SDWEN_E SDWEN SDUDQM_E SDUDQ D(13) D(9) D(6) D(2) DSP_D(3) DSP_D(7) DSP_D(10) DSP_D(14) DSP_MCSN_E DSP_MCSN DSP_A(2) DSP_A(6) DSP_A(10) T_REQA MDISDO_E MDISDO K_ROW_E(3) K_ROW(3) K_COL(7) K_COL(4) K_COL(0) SPKRLED_E SPKRLED TMODE(2) TESTPT_E(18) TESTPT(18) TESTPT_E(14) TESTPT(14) TESTPT_E(10) TESTPT(10) TESTPT_E(6) TESTPT(6) TESTPT_E(3) TESTPT(3) — B10 B9 — B8 — B7 B6 B5 B4 B3 D3 E3 F3 G3 — H3 J3 K3 L3 T3 — V3 — V4 V5 V6 V7 — V8 V9 — V12 — V13 — V14 — V15 — V16 Enabled State Controller I/O I Controller I/O Controller I/O I/O I/O I/O I/O I/O I/O I/O I/O Controller I/O I/O I/O I/O I Controller I/O Controller I/O I/O I/O I/O Controller I/O I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Pin Grouping — CS2_E — — SDWEN_E — SDUDQM_E DH_E DH_E DL_E DL_E DSP_D_E DSP_D_E DSP_D_E DSP_D_E — DSP_MCSN_E DSP_A_E DSP_A_E DSP_A_E X — MDISDO_E — K_ROW_E(3) K_COL_E K_COL_E K_COL_E — SPKRLED_E X — TESTPT_E(18) — TESTPT_E(14) — TESTPT_E(10) — TESTPT_E(6) — TESTPT_E(3) Control Disabled State 0 0 — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 — High impedance — — High impedance — High impedance 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up — High impedance High impedance High impedance High impedance 50 kΩ pull-down — High impedance — High impedance 50 kΩ pull-down 50 kΩ pull-down 50 kΩ pull-down — High impedance 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 Agere Systems Inc. Pin Name OMUXSEL(0) LS100_OK_E(1) LS100_OK(1) PPI_E(14) PPI(14) PPI_E(10) PPI(10) PPI_E(6) PPI(6) PPI_E(2) PPI(2) PRTPWR_E PRTPWR RX1 A(20) A(16) A(13) A(9) A(6) A(2) RDN_E RDN CS3_E CS3 EXINT2 SDRCK_E SDRCK SDRCK2_E Not used D(14) D(10) D(7) D(3) DSP_D(4) DSP_D(11) DSP_A(1) DSP_INTN0_E DSP_INTN0 K_ROW_E(2) K_ROW(2) K_COL(3) Ball V17 — K18 — J18 — H18 — G18 — F18 — E18 C18 C17 C16 C15 C14 C13 C12 — C11 — C10 C9 — C8 — — C7 C6 C5 C4 E4 G4 J4 — L4 — U5 U7 Enabled State I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I I/O I/O I I/O I/O I/O Controller I/O Controller I/O I Controller I/O Controller — I/O I/O I/O I/O I/O I/O I/O Controller I/O Controller I/O I/O Pin Grouping X — LS100_OK_E(1) — PPI_E(14) — PPI_E(10) — PPI_E(6) — PPI_E(2) — PRTPWR_E X A_E A_E A_E A_E A_E A_E — RDN_E — CS3_E — — SDRCK_E — — DH_E DH_E DL_E DL_E DSP_D_E DSP_D_E DSP_A_E — DSP_INTN0_E — K_ROW_E(2) K_COL_E Control Disabled State — 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 — 0 0 0 — 0 0 0 0 0 0 0 0 0 0 0 0 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance 50 kΩ pull-up High impedance High impedance High impedance High impedance High impedance High impedance — High impedance — High impedance — — High impedance — — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up High impedance — High impedance — High impedance 50 kΩ pull-down 239 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 240 Pin Name OMUXSEL(0) LS100_OK_E(1) LS100_OK(1) PPI_E(14) PPI(14) PPI_E(10) PPI(10) PPI_E(6) PPI(6) PPI_E(2) PPI(2) PRTPWR_E PRTPWR RX1 A(20) A(16) A(13) A(9) A(6) A(2) RDN_E RDN CS3_E CS3 EXINT2 SDRCK_E SDRCK SDRCK2_E Not used D(14) D(10) D(7) D(3) DSP_D(4) DSP_D(11) DSP_A(1) DSP_INTN0_E DSP_INTN0 K_ROW_E(2) K_ROW(2) K_COL(3) Ball V17 — K18 — J18 — H18 — G18 — F18 — E18 C18 C17 C16 C15 C14 C13 C12 — C11 — C10 C9 — C8 — — C7 C6 C5 C4 E4 G4 J4 — L4 — U5 U7 Enabled State I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I I/O I/O I I/O I/O I/O Controller I/O Controller I/O I Controller I/O Controller — I/O I/O I/O I/O I/O I/O I/O Controller I/O Controller I/O I/O Pin Grouping X — LS100_OK_E(1) — PPI_E(14) — PPI_E(10) — PPI_E(6) — PPI_E(2) — PRTPWR_E X A_E A_E A_E A_E A_E A_E — RDN_E — CS3_E — — SDRCK_E — — DH_E DH_E DL_E DL_E DSP_D_E DSP_D_E DSP_A_E — DSP_INTN0_E — K_ROW_E(2) K_COL_E Control Disabled State — 0 0 0 0 0 0 0 0 0 0 0 0 — 0 0 0 0 0 0 0 0 0 0 — 0 0 0 — 0 0 0 0 0 0 0 0 0 0 0 0 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance 50 kΩ pull-up High impedance High impedance High impedance High impedance High impedance High impedance — High impedance — High impedance — — High impedance — — 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up 50 kΩ pull-up High impedance — High impedance — High impedance 50 kΩ pull-down Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 18 JTAG/Boundary Scan (continued) Table 209. Boundary Scan Register Description (continued) Boundary Scan Register Bit Pin 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 Agere Systems Inc. Pin Name Ball TMODE(1) TESTPT_E(17) TESTPT(17) TESTPT_E(7) TESTPT(7) TESTPT_E(0) TESTPT(0) LS10_OK_E(0) LS10_OK(0) PPI_E(13) PPI(13) PPI_E(3) PPI(3) A(19) A(12) A(3) BE1N_E BE1N SDRASN_E SDRASN D(11) D(4) U9 — U12 — U13 — U16 — K17 — J17 — H17 D16 D14 D12 — D11 — D9 D7 D5 Enabled State I Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O Controller I/O I/O I/O I/O Controller I/O Controller I/O I/O I/O Pin Grouping 0 — TESTPT_E(17) — TESTPT_E(7) — TESTPT_E(0) — LS10_OK_E(0) — PPI_E(13) — PPI_E(3) A_E V A_E — BE1N_E — SDRASN_E DH_E DL_E Control Disabled State — 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 50 kΩ pull-up — High impedance — High impedance — High impedance — High impedance — High impedance — High impedance High impedance High impedance High impedance — High impedance — High impedance 50 kΩ pull-up 50 kΩ pull-up 241 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 19 Electrical Specifications 19.1 Absolute Maximum Ratings Stresses in excess of the absolute maximum ratings can cause permanent damage; these are absolute stress ratings only. Functional operation of the device is not implied at these or any other conditions in excess of those given in the operational sections of this data sheet. Exposure to absolute maximum ratings for extended periods can adversely affect device reliability. Table 210. Absolute Maximum Ratings Parameter Supply Voltage XRTC0, XRTC1, XTAL0, XTAL1, XLO, XHI Voltage Applied to I/O Pins Operating Temperature Storage Temperature Symbol VDD — — — — Min — VSS VDD–0.3 0 –40 Max 3.5 VDD 5.5 70 125 Unit V V V °C °C 19.2 Handling Precautions Although protection circuitry has been designed into this device, proper precautions should be taken to avoid exposure to electrostatic discharge (ESD) during handling and mounting. Agere employs a human-body model (HBM) and a charged-device model (CDM) for ESD-susceptibility testing and protection design evaluation. ESD voltage thresholds are dependent on the circuit parameters used to define the model. The following table shows voltage ratings for CDM and HBM. Note: In V5 of the T8302, silicon changes were implemented to improve ESD margins to within the limits specified below. Model Threshold Voltage Rating CDM 250 V to < 500 V HBM 1000 V to < 2000 V 19.3 Crystal Specifications 19.3.1 System Clock Crystal The T8302 requires an 11.52 MHz clock source (derived from an oscillator or a crystal) for the system clock source. If a crystal is used it must be connected between XTAL0 and XTAL1. The crystal specifications are shown below. Table 211. System Clock (XTAL0, XTAL1) Specifications Parameter Frequency. Oscillation Mode. Effective Series Resistance. Load Capacitance. Shunt Capacitance. Frequency Tolerance and Stability. 242 Value 11.52 MHz Fundamental, parallel resonance A discussion of crystal selection for the T8302 may be found in the application note Crystal Selection for the T8301/T8302 Chip Set. ±50 ppm Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 19 Electrical Specifications (continued) 19.4 PHY Clock Crystal The T8302 requires a 25 MHz clock source (derived from an oscillator or a crystal) for PHY timing. If a crystal s used, it must be connected between XLO and XHI. The crystal specifications are shown below. Table 212. PHY Clock (XLO, XHI) Crystal Specifications Parameter Value 25 MHz Fundamental, parallel resonance A discussion of crystal selection for the T8302 may be found in the application note Crystal Selection for the T8301/T8302 Chip Set. Frequency. Oscillation Mode. Effective Series Resistance. Load Capacitance. Shunt Capacitance. Frequency Tolerance and Stability. ±50 ppm 19.5 Real-Time Clock Crystal The T8302 may use an optional a 32.768 KHz clock source (derived from an oscillator or a crystal) for real-time clock timing. This crystal is only required if the internal RTC clock does not provide sufficient accuracy. If a crystal is used, it must be connected between XRTC0 and XRTC1. The crystal specifications are shown below. Table 213. Real-Time Clock (XRTC0, XRTC1) Specifications Parameter Value 32.768 KHz Fundamental, parallel resonance A discussion of crystal selection for the T8302 may be found in the application note Crystal Selection for the T8301/T8302 Chip Set. Frequency. Oscillation Mode. Effective Series Resistance. Load Capacitance. Shunt Capacitance. Frequency Tolerance and Stability. ±20 ppm Table 214. Reset Pulse Parameter RESET# Minimum Pulse Width. Min 200 Max — Unit ns 19.6 dc Electrical Characteristics VDD = 3.3 V and Vss = 0.0 V unless otherwise specified. Table 215. dc Electrical Characteristics Parameter Supply Current. Supply Voltage (3.3 V ± 5%). Input High-Voltage. Input Low-Voltage. Input Current. Agere Systems Inc. Symbol IDD VDD VIH VIL II Condition — — — — VA = 2.0 V Min — 3.135 2.0 — — Typ — — — — — Max 600 3.465 — 0.8 20 Unit mA V V V µA 243 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) Data Sheet July 2001 19 Electrical Specifications (continued) Table 215. dc Electrical Characteristics (continued) Parameter Input Capacitance (Input Only). Input Capacitance (I/O pins). Leakage Current (3-state): Output Input Output High-Voltage. Output Low-Voltage. Symbol CI CIO Condition — — Min — — Typ — — Max 5 10 Unit pF pF ILEAKO ILEAKI VOH VOL — VA* <VDD — — — — 2.4 — — — — — 10 1 — 0.4 µA µA V V * VA = Input voltage. 19.7 Power Consumption Table 216. Power Consumption Parameter Chip Out of Reset, Core Active. Condition T8302 reset released. Core is executing program instructions. System clock is 57.6 MHz. PHYs disabled. PHY Power Consumption. Per PHY. PPHYA Autonegotiation. PPHY10L 10 Mbits/s Link. PPHY10TR 10 Mbits/s Tx/Rx. PPHY100T 10 Mbits/s Tx. Active Core With Active PA Core is executing program instructions. Both PHYs. PHYs are in use. System clock is 57.6 MHz. 10 Mbits/s Tx/Rx. 244 Symbol PCORE Min — Typ Max 1010 1060 Unit mW — — — — — 40 50 90 100 370 400 440 500 1800 1860 mW mW mW mW mW Agere Systems Inc. Data Sheet July 2001 T8302 Internet Protocol Telephone Advanced RISC Machine (ARM ) 20 Change History Some of the data in this data sheet (DS01-213IPT) has changed. While the formatting has undergone minimal changes, the EQuB sections has been eliminated. Red change bars have been installed for all content-specific changes. Any additions and changes, have been highlighted in blue. Some change bars do not indicate any discernible changes, therefore, any meaningful change has been tabulated in the table below. Any references to tables, figures, sections, or pages have been highlighted in magenta. Navigating Through an Acrobat Document If the reader displays this document in Acrobat Reader, clicking on any magenta entry will bring the reader to that reference point. Clicking on the back arrow (Go to Previous View) in the toolbar of the Acrobat Reader, will bring the reader back to the starting point. For example: clicking on the 1 below, will bring the reader to page 1, which is the first change of this document. Clicking on the back arrow (in Acrobat Reader) will bring the reader back to this page (page 245). All changes from the previous version (DS01-338IPT) are listed in the table below: Table 217. Change History of DS01-213IPT Page Number 1 19 20 21 22 23 27 28 32 33 34 35 36 41 51 52 54 64 65 66 70 72 Page Number 74 75 77 78 79 82 83 84 87 88 90 92 93 101 142 145 146 148 178 188 199 200 Page Number 201 204 206 208 210 212 213 215 216 217 218 219 220 221 222 224 225 226 227 242 244 — 21 Contact Us For additional information regarding this data sheet, please consult the back page (page 246) of this document for contact information. Agere Systems Inc. 245 For additional information, contact your Agere Systems Account Manager or the following: INTERNET: http://www.agere.com E-MAIL: [email protected] N. AMERICA: Agere Systems Inc., 555 Union Boulevard, Room 30L-15P-BA, Allentown, PA 18109-3286 1-800-372-2447, FAX 610-712-4106 (In CANADA: 1-800-553-2448, FAX 610-712-4106) ASIA PACIFIC: Agere Systems Singapore Pte. Ltd., 77 Science Park Drive, #03-18 Cintech III, Singapore 118256 Tel. (65) 778 8833, FAX (65) 777 7495 CHINA: Agere Systems (Shanghai) Co., Ltd., 33/F Jin Mao Tower, 88 Century Boulevard Pudong, Shanghai 200121 PRC Tel. (86) 21 50471212, FAX (86) 21 50472266 JAPAN: Agere Systems Japan Ltd., 7-18, Higashi-Gotanda 2-chome, Shinagawa-ku, Tokyo 141, Japan Tel. (81) 3 5421 1600, FAX (81) 3 5421 1700 EUROPE: Data Requests: DATALINE: Tel. (44) 7000 582 368, FAX (44) 1189 328 148 Technical Inquiries: GERMANY: (49) 89 95086 0 (Munich), UNITED KINGDOM: (44) 1344 865 900 (Ascot), FRANCE: (33) 1 40 83 68 00 (Paris), SWEDEN: (46) 8 594 607 00 (Stockholm), FINLAND: (358) 9 3507670 (Helsinki), ITALY: (39) 02 6608131 (Milan), SPAIN: (34) 1 807 1441 (Madrid) Agere Systems Inc. reserves the right to make changes to the product(s) or information contained herein without notice. No liability is assumed as a result of their use or application. Phone-OnA-Chip is a trademark of Agere Systems Inc. Copyright © 2001 Agere Systems Inc. All Rights Reserved Printed in U.S.A. July 2001 DS01-213IPT (Replaces DS00-338IPT and DA01-008IPT and must accompany AY01-026IPT)