FINAL
Am486®DE2
8-Kbyte Write-Through Embedded Microprocessor
DISTINCTIVE CHARACTERISTICS
s High-Performance Design — 66-MHz operating frequency — Frequent instructions execute in one clock — 105.6-million bytes/second burst bus at 33 MHz — Flexible write-through address control — Dynamic bus sizing for 8-, 16-, and 32-bit buses — Soft reset capability s High On-Chip Integration — 8-Kbyte unified code and data cache — Floating-point unit — Paged, virtual memory management s Enhanced System and Power Management — Stop clock control for reduced power consumption — Industry-standard, two-pin System Management Interrupt (SMI) for power management independent of processor operating mode and operating system — Static design with Auto Halt Power-Down support — Wide range of chipsets supporting SMM available to allow product differentiation s Complete 32-Bit Architecture — Address and data buses — All registers — 8-, 16-, and 32-bit data types s Standard Features — 3-V core with 5-V-tolerant I/O — Binary compatible with all Am486® DX and Am486DX2 microprocessors — Wide range of support available through the AMD® FusionE86SM Program s IEEE 1149.1 JTAG Boundary-Scan Compatibility s Supports Environmental Protection Agency's Energy Star program — 3-V operation reduces power consumption up to 40% — Energy management capability provides an excellent base for energy-efficient design — Works with a variety of energy-efficient, powermanaged devices s 208-Lead SQFP or 168-Pin PGA Package
GENERAL DESCRIPTION
The Am486DE2 microprocessor is an addition to the AMD Am486 microprocessor family. The Am486DE2 enhances system performance by incorporating flexible clock control and enhanced SMM. The Am486DE2 CPU clock control feature permits the CPU to be stopped under controlled conditions, allowing reduced power consumption during system inactivity. The SMM function is implemented with an industry-standard, two-pin interface.
Publication ID 20037
Revision A
Amendment /0
Issue Date April 1996
BLOCK DIAGRAM
Power Plane Clock Interface
32-Bit Data Bus 32-Bit Data Bus 32-Bit Linear Address PCD, PWT
VOLDET VCC, VSS
Clock Generator
CLK STPCLK
Bus Interface Cache Unit 32 Address Drivers
Write Buffers 4x32 Copyback Buffers 4x32 Writeback Buffers 4x32
Barrel Shifter Register File ALU 24
Segmentation Unit Descriptor Registers Limit and Attribute PLA
Paging Unit 24 Translation Lookaside Buffer
2
A31–A2 BE3–BE0
Physical Address
Physical Address
8-Kbyte Cache
128
Displacement Bus Micro-instruction
Prefetcher 32
Code 32-Byte Stream Code Queue
32
Data Bus Transceivers
D31–D0 ADS, W/R, D/C, M/IO, PCD, PWT, RDY, LOCK, PLOCK, BOFF, A20M, BREQ, HOLD, HLDA, RESET, INTR, NMI, FERR, UP, IGNNE, SMI, SMIACT, SRESET BRDY, BLAST BS16, BS8
FloatingPoint Unit FloatingPoint Register File
Central and Protection Test Unit
Decoded Instruction Path
2x16 Bytes Instruction Decode 24
Bus Control Request Sequencer
Control ROM
Burst Bus Control Bus Size Control
Cache Control
KEN, FLUSH, AHOLD, CACHE, EADS, INV, WB/WT, HITM
Parity Generation and Control JTAG
PCHK, DP3–DP0 TDI, TCK, TDO, TMS
2
Am486DE2 Microprocessor
ORDERING INFORMATION Standard Product
AMD standard products are available in several packages and operating ranges. Valid order numbers are formed by a combination of the elements below.
Am486 DE2 –66 V
8
T
HC TEMPERATURE RANGE C = Commercial PACKAGE TYPE H = 208-Lead SQFP G= 168-Pin PGA CACHE TYPE T = Write-through CACHE SIZE 8 = 8 Kbyte VOLTAGE V = VCC is 3 V with 5-V tolerance SPEED OPTION –66 = 66 MHz VERSION DE2 = Clock-doubled with FPU DEVICE NUMBER/DESCRIPTION Am486 high-performance CPU
Valid Combinations
Valid Combination Am486DE2-66V8THC Am486DE2-66V8TGC Comment SQFP package PGA package
Valid combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations and to check on newly released combinations.
Am486DE2 Microprocessor
3
Table of Contents
Distinctive Characteristics ............................................................................................................................ 1 General Description...................................................................................................................................... 1 Block Diagram .............................................................................................................................................. 2 Ordering Information .................................................................................................................................... 3 Connection Diagrams and Pin Designations................................................................................................ 7 168-Pin Grid Array (PGA) Package ....................................................................................................... 7 168-Pin PGA Designations (Functional Grouping) ................................................................................ 8 208-Lead Shrink Quad Flat Pack (SQFP) Package............................................................................... 9 208-Lead SQFP Designations (Functional Grouping) ......................................................................... 10 Logic Symbol.............................................................................................................................................. 11 Pin Descriptions ......................................................................................................................................... 12 A20M.................................................................................................................................................... 12 A31–A2 ................................................................................................................................................ 12 ADS...................................................................................................................................................... 12 AHOLD (Modified)................................................................................................................................ 12 BE3–BE0 ............................................................................................................................................. 12 BLAST (Modified)................................................................................................................................. 12 BOFF ................................................................................................................................................... 12 BRDY ................................................................................................................................................... 12 BREQ................................................................................................................................................... 13 BS8/BS16 ............................................................................................................................................ 13 CACHE (New)...................................................................................................................................... 13 CLK (Modified) ..................................................................................................................................... 13 D31–D0................................................................................................................................................ 13 D/C ....................................................................................................................................................... 13 DP3–DP0 ............................................................................................................................................. 13 EADS (Modified) .................................................................................................................................. 13 FERR ................................................................................................................................................... 14 FLUSH (Modified) ................................................................................................................................ 14 HITM (New).......................................................................................................................................... 14 HLDA ................................................................................................................................................... 14 HOLD ................................................................................................................................................... 14 IGNNE.................................................................................................................................................. 14 INTR..................................................................................................................................................... 14 INV (New) ............................................................................................................................................ 14 KEN...................................................................................................................................................... 14 LOCK ................................................................................................................................................... 14 M/IO ..................................................................................................................................................... 15 NMI ...................................................................................................................................................... 15 PCD ..................................................................................................................................................... 15 PCHK ................................................................................................................................................... 15 PLOCK (Modified)................................................................................................................................ 15 PWT ..................................................................................................................................................... 15 RDY ..................................................................................................................................................... 15 RESET ................................................................................................................................................. 15 SMI (New) ............................................................................................................................................ 15 SMIACT (New)..................................................................................................................................... 16 SRESET (New) .................................................................................................................................... 16 STPCLK (New) .................................................................................................................................... 16 TCK...................................................................................................................................................... 16 TDI ....................................................................................................................................................... 16 TDO ..................................................................................................................................................... 16 TMS ..................................................................................................................................................... 16 UP ........................................................................................................................................................ 16 VOLDET (New, 168-Pin PGA Package only) ...................................................................................... 16
4
Am486DE2 Microprocessor
WB/WT (New) ...................................................................................................................................... 16 W/R ...................................................................................................................................................... 16 Functional Description................................................................................................................................ 17 Overview .............................................................................................................................................. 17 Memory ................................................................................................................................................ 17 Modes of Operation ............................................................................................................................. 17 Write-Through Cache Architecture ...................................................................................................... 17 Cache Replacement Description ......................................................................................................... 17 Memory Configuration ......................................................................................................................... 17 Clock Control.............................................................................................................................................. 18 Clock Generation ................................................................................................................................. 18 Stop Clock ........................................................................................................................................... 18 Stop Grant Bus Cycle .......................................................................................................................... 19 Pin State During Stop Grant ................................................................................................................ 19 Clock Control State Diagram ............................................................................................................... 20 SRESET Function ...................................................................................................................................... 20 System Management Mode ....................................................................................................................... 22 Overview .............................................................................................................................................. 22 Terminology ......................................................................................................................................... 22 System Management Interrupt Processing.......................................................................................... 22 Entering System Management Mode .................................................................................................. 26 Exiting System Management Mode ..................................................................................................... 27 Processor Environment ....................................................................................................................... 27 Executing System Management Mode Handler .................................................................................. 28 SMM System Design Considerations .................................................................................................. 31 SMM Software Considerations ............................................................................................................ 34 Test Registers 4 and 5 Modifications ......................................................................................................... 36 TR4 Definition ...................................................................................................................................... 36 TR5 Definition ...................................................................................................................................... 36 Am486DE2 Microprocessor Functional Differences................................................................................... 37 Am486DE2 Microprocessor Identification .................................................................................................. 37 DX Register at RESET ........................................................................................................................ 37 CPUID Instruction ................................................................................................................................ 37 Electrical Data ............................................................................................................................................ 39 Power Connections.............................................................................................................................. 39 Power Decoupling Recommendations................................................................................................. 39 Other Connection Recommendations.................................................................................................. 39 Absolute Maximum Ratings........................................................................................................................ 40 Operating Ranges ...................................................................................................................................... 40 DC Characteristics over Commercial Operating Ranges ........................................................................... 40 Switching Characteristics over Commercial Operating Ranges................................................................. 41 Switching Characteristics for 33-MHz Bus (66-MHz Microprocessor) ................................................. 42 Switching Waveforms .......................................................................................................................... 43 Package Thermal Specifications ................................................................................................................ 48 Physical Dimensions .................................................................................................................................. 50 168-Pin PGA ........................................................................................................................................ 50 208-Lead SQFP ................................................................................................................................... 51
Am486DE2 Microprocessor
5
FIGURES
Figure 1 Figure 2 Figure 3 Figure 4 Figure 5 Figure 6 Figure 7 Figure 8 Figure 9 Figure 10 Figure 11 Figure 12 Figure 13 Figure 14 Figure 15 Figure 16 Figure 17 Figure 18 Figure 19 Figure 20 Figure 21 Figure 22 Figure 23 Figure 24 Figure 25 Figure 26 Entering Stop Grant State ........................................................................................................ 19 Stop Clock State Machine ........................................................................................................ 21 Recognition of Inputs when Exiting Stop Grant State .............................................................. 21 Basic SMI Interrupt Service...................................................................................................... 23 Basic SMI Hardware Interface ................................................................................................. 23 SMI Timing for Servicing an I/O Trap ....................................................................................... 24 SMIACT Timing ........................................................................................................................ 25 Redirecting System Memory Address to SMRAM ................................................................... 25 Transition to and from SMM ..................................................................................................... 27 Auto Halt Restart Register Offset ............................................................................................. 30 I/O Instruction Restart Register Offset ..................................................................................... 30 SMM Base Slot Offset .............................................................................................................. 31 SRAM Usage ........................................................................................................................... 31 SMRAM Location ..................................................................................................................... 32 SMM Timing in Systems Using Non-Overlaid Memory Space and Write-Through Mode with Caching Enabled During SMM ................................................................................................. 32 SMM Timing in Systems Using Overlaid Memory Space and Write-Through Mode with Caching Enabled During SMM ................................................................................................. 33 SMM Timing in Systems Using Overlaid Memory Space and Write-Through Mode with Caching Disabled During SMM ................................................................................................ 33 CLK Waveforms ....................................................................................................................... 43 Output Valid Delay Timing ....................................................................................................... 44 Maximum Float Delay Timing................................................................................................... 44 PCHK Valid Delay Timing ........................................................................................................ 45 Input Setup and Hold Timing.................................................................................................... 46 RDY and BRDY Input Setup and Hold Timing ......................................................................... 47 TCK Waveforms ....................................................................................................................... 47 Test Signal Timing Diagram ..................................................................................................... 48 Heat Sink Dimensions .............................................................................................................. 49
TABLES
Table 1 Table 2 Table 3 Table 4 Table 5 Table 6 Table 7 Table 8 Table 9 Table 10 Table 11 Table 12 Table 13 Table 14 Table 15 Table 16 EADS Sample Time ................................................................................................................. 13 Pin State During Stop Grant Bus State .................................................................................... 19 SMRAM State Save Map ......................................................................................................... 26 SMM Initial CPU Core Register Settings.................................................................................. 28 Segment Register Initial States ................................................................................................ 28 System Management Mode Revision Identifier........................................................................ 29 SMM Revision Identifier Bit Definitions .................................................................................... 29 Auto Halt Restart Configuration ............................................................................................... 30 I/O Trap Word Configuration .................................................................................................... 30 Test Register (TR4).................................................................................................................. 36 Test Register (TR5).................................................................................................................. 36 Am486DE2 Microprocessor Functional Differences ................................................................ 37 CPU ID Codes.......................................................................................................................... 37 CPUID Instruction Description ................................................................................................. 38 Thermal Resistance (°C/W) θJC and θJA for the Am486DE2 in 168-Pin PGA Package .......... 49 Maximum TA at Various Airflows in °C ..................................................................................... 49
6
Am486DE2 Microprocessor
CONNECTION DIAGRAMS AND PIN DESIGNATIONS 168-Pin Grid Array (PGA) Package
A
D20
B
D19 D21
C
D11 D18
D
D9 D13
E
VSS VCC
F
DP1 D8
G
VSS VCC
H
VSS D3
J
INC D5
K
VSS VCC
L
VSS D6
M
VSS VCC
N
D2 D1
P
D0 A29
Q
A31 VSS
R
A28 A25
S
A27
1
D22 A26
1 2
TCK VSS CLK D17 D10 D15 D12 DP2 D16 D14 D7 D4 DP0 A30 A17 VCC A23
2 3
D23 VSS VSS D25 VCC VCC VCC D27 D26 D13 D13 D13 VCC VCC VCC D8 D8 D8 VCC VCC VCC D3 D3 D3 D5 D5 D5 VCC VCC VCC D6 D6 D6 VCC VCC VCC D1 D1 D1 A29 A29 A29 A19 A21 A24 A22 VSS A18 VCC A15 VOLDET
3 4
DP3 A14
4 5
D24 VSS
5 6
VSS A12
6 7
D29 D31 VCC D28 D30 D13 D13 VCC VCC D8 D8 VCC VCC D3 D3 D5 D5 VCC VCC D6 D6 VCC VCC D1 D1 A29 A29 A20 A16 VCC VCC VSS
7 8
VSS
8
VSS
Pin Side View
9
INV SMI SRESET VCC D8 VCC D3 D5 VCC D6 VCC D1 A29 A13 VCC VSS
9 10
VSS VCC UP D13 VCC D8 VCC D3 D5 VCC D6 VCC D1 A29 A9 VCC VSS
10 11
HITM CACHE SMIACT A5 A7 A2 A11 A8 VCC VSS
11 12
INC WB/WT INC TMS FERR A10
12 13
TDI VSS
13 14
IGNNE NMI FLUSH A20M HOLD KEN STPCLK BRDY BE2 BE0 VCC VSS PWT VCC VSS D/C VCC VSS LOCK HLDA BREQ M/IO W/R VCC A3 A6
14 15
INTR TDO RESET BS8 VCC VSS RDY BE3 VCC VSS VCC VSS BE1 PCD PLOCK BLAST A4
15 16
AHOLD EADS BS16 BOFF VSS PCH K INC L ADS
16 17 A B C D E F G H J K L M N P Q R S
17
Am486DE2 Microprocessor
7
168-Pin PGA Designations (Functional Grouping)
Address Pin Name A2 A3 A4 A5 A6 A7 A8 A9 A10 A11 A12 A13 A14 A15 A16 A17 A18 A19 A20 A21 A22 A23 A24 A25 A26 A27 A28 A29 A30 A31 Pin No. Q-14 R-15 S-16 Q-12 S-15 Q-13 R-13 Q-11 S-13 R-12 S-7 Q-10 S-5 R-7 Q-9 Q-3 R-5 Q-4 Q-8 Q-5 Q-7 S-3 Q-6 R-2 S-2 S-1 R-1 P-2 P-3 Q-1 Data Pin Name D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 D10 D11 D12 D13 D14 D15 D16 D17 D18 D19 D20 D21 D22 D23 D24 D25 D26 D27 D28 D29 D30 D31 Pin No. P-1 N-2 N-1 H-2 M-3 J-2 L-2 L-3 F-2 D-1 E-3 C-1 G-3 D-2 K-3 F-3 J-3 D-3 C-2 B-1 A-1 B-2 A-2 A-4 A-6 B-6 C-7 C-6 C-8 A-8 C-9 B-8 Control Pin Name A20M ADS AHOLD BE0 BE1 BE2 BE3 BLAST BOFF BRDY BREQ BS8 BS16 CACHE CLK D/C DP0 DP1 DP2 DP3 EADS FERR FLUSH HITM HLDA HOLD IGNNE INTR INV KEN LOCK M/IO NMI PCD PCHK PLOCK PWT RDY RESET SMI SMIACT SRESET STPCLK UP VOLDET WB/WT W/R Pin No. D-15 S-17 A-17 K-15 J-16 J-15 F-17 R-16 D-17 H-15 Q-15 D-16 C-17 B-12 C-3 M-15 N-3 F-1 H-3 A-5 B-17 C-14 C-15 A-12 P-15 E-15 A-15 A-16 A-10 F-15 N-15 N-16 B-15 J-17 Q-17 Q-16 L-15 F-16 C-16 B-10 C-12 C-10 G-15 C-11 S-4 B-13 N-17 Pin Name TCK TDI TDO TMS Test Pin No. A-3 A-14 B-16 B-14 INC Pin No. A-13 C-13 J-1 R-17 Vcc Pin No. B-7 B-9 B-11 C-4 C-5 E-2 E-16 G-2 G-16 H-16 K-2 K-16 L-16 M-2 M-16 P-16 R-3 R-6 R-8 R-9 R-10 R-11 R-14 Vss Pin No. A-7 A-9 A-11 B-3 B-4 B-5 E-1 E-17 G-1 G-17 H-1 H-17 K-1 K-17 L-1 L-17 M-1 M-17 P-17 Q-2 R-4 S-6 S-8 S-9 S-10 S-11 S-12 S-14
Notes: VOLDET is connected internally to VSS. INC = Internal No Connect
8
Am486DE2 Microprocessor
208-Lead Shrink Quad Flat Pack (SQFP) Package
208 207 206 205 204 203 202 201 200 199 198 197 196 195 194 193 192 191 190 189 188 187 186 185 184 183 182 181 180 179 178 177 176 175 174 173 172 171 170 169 168 167 166 165 164 163 162 161 160 159 158 157
VSS LOCK PLOCK VCC BLAST ADS A2 VSS VCC VSS VCC A3 A4 A5 UP A6 A7 VCC A8 VSS VCC A9 A10 VCC VSS VCC A11 VSS A12 VCC A13 A14 VCC VSS A15 A16 VCC A17 VSS VCC TDI TMS A18 A19 A20 VCC VCC A21 A22 A23 A24 VSS
VSS VCC VSS VCC VSS SRESET SMIACT VCC VSS VCC HITM WB/WT SMI FERR INC TDO VCC CACHE INV IGNNE STPCLK D31 D30 VSS VCC D29 D28 VCC VSS VCC D27 D26 D25 VCC D24 VSS VCC DP3 D23 D22 D21 VSS VCC INC VSS VCC D20 D19 D18 VCC D17 VSS
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 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
VSS VCC INC PCHK BRDY BOFF BS16 BS8 VCC VSS INC RDY KEN VCC VSS HOLD AHOLD TCK VCC VCC VSS VCC VCC CLK VCC HLDA W/R VSS VCC BREQ BE0 BE1 BE2 BE3 VCC VSS M/IO VCC D/C PWT PCD VCC VSS VCC VCC EADS A20M RESET FLUSH INTR NMI VSS
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 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
Top View
156 155 154 153 152 151 150 149 148 147 146 145 144 143 142 141 140 139 138 137 136 135 134 133 132 131 130 129 128 127 126 125 124 123 122 121 120 119 118 117 116 115 114 113 112 111 110 109 108 107 106 105
VSS VCC A25 A26 A27 A28 VCC A29 A30 A31 VSS DP0 D0 D1 D2 D3 D4 VCC VSS VCC VCC VSS VCC VCC VSS VCC D5 D6 VCC INC D7 DP1 D8 D9 VSS VCC VSS D10 D11 D12 D13 VSS VCC D14 D15 VCC VSS DP2 D16 VSS VCC VSS
Am486DE2 Microprocessor
9
208-Lead SQFP Designations (Functional Grouping)
Address Pin Name A2 A3 A4 A5 A6 A7 A8 A9 A10 A11 A12 A13 A14 A15 A16 A17 A18 A19 A20 A21 A22 A23 A24 A25 A26 A27 A28 A29 A30 A31 No. 202 197 196 195 193 192 190 187 186 182 180 178 177 174 173 171 166 165 164 161 160 159 158 154 153 152 151 149 148 147 Data Pin Name D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 D10 D11 D12 D13 D14 D15 D16 D17 D18 D19 D20 D21 D22 D23 D24 D25 D26 D27 D28 D29 D30 D31 No. 144 143 142 141 140 130 129 126 124 123 119 118 117 116 113 112 108 103 101 100 99 93 92 91 87 85 84 83 79 78 75 74 Control Pin Name No. 47 203 17 31 32 33 34 204 6 5 30 8 7 70 24 39 145 125 109 90 46 66 49 63 26 16 72 50 71 13 207 37 51 41 4 206 40 12 48 65 59 58 73 194 64 27 Test Pin Name TCK TDI TDO TMS No. 18 168 68 167 INC Pin No. 3 11 67 96 127 Vcc Pin No. 2 9 14 19 20 22 23 25 29 35 38 42 44 45 54 56 60 62 69 77 80 82 86 89 95 98 102 106 111 114 121 128 131 133 134 136 137 139 150 155 162 163 169 172 176 179 183 185 188 191 198 200 205 Vss Pin No. 1 10 15 21 28 36 43 52 53 55 57 61 76 81 88 94 97 104 105 107 110 115 120 122 132 135 138 146 156 157 170 175 181 184 189 199 201 208
A20M ADS AHOLD BE0 BE1 BE2 BE3 BLAST BOFF BRDY BREQ BS8 BS16 CACHE CLK D/C DP0 DP1 DP2 DP3 EADS FERR FLUSH HITM HLDA HOLD IGNNE INTR INV KEN LOCK M/IO NMI PCD PCHK PLOCK PWT RDY RESET SMI SMIACT SRESET STPCLK UP WB/WT W/R
Note: INC = Internal No Connect
10
Am486DE2 Microprocessor
LOGIC SYMBOL
Clock Stop Clock Address Mask Upgrade Present Voltage Detect
28 2
CLK STPCLK A20M UP
D31–D0
32
Data Bus
VOLDET
A31–A4 A3–A2 BE3–BE0 BS8
DP3–DP0 PCHK BRDY BLAST CACHE SMI SMIACT
4
Data Parity
Address Bus
Burst Control
4
SMM
Bus Cycle Control
BS16 ADS RDY M/IO D/C W/R LOCK PLOCK
Am486DE2 CPU
PWT PCD
Page Cacheability
Bus Cycle Definition
WB/WT INV
KEN FLUSH AHOLD EADS HITM Cache Control/ Invalidation
Interrupts
INTR NMI RESET SRESET HOLD BOFF BREQ HLDA TCK TMS
IGNNE
FERR
TDI TDO
Bus Arbitration
Numeric Error Reporting
IEEE Test Port Access
Am486DE2 Microprocessor
11
PIN DESCRIPTIONS
The Am486DE2 microprocessor is a new member of the AMD Am486 family, which also includes the Enhanced Am486 and the Am486DX microprocessors. Like the AMD Enhanced Am486 family, the Am486DE2 adds new signals to those used by the Am486DX processors. These added signals support new processor features and are indicated as new in the pin description titles. Although the Am486DE2 processor is based on and compatible with the Enhanced Am486 microprocessors, it has no support for write-back cache. Because of this, some Am486DE2 signals are supported differently than the signals in either the Enhanced Am486 or the Am486DX microprocessors. These signals are indicated as modified in the pin descriptions below. All other processor signals provide the same functionality as the standard Am486DX processor.
AHOLD (Modified)
Address Hold (Input) The external system may assert AHOLD to perform a cache snoop. In response to the assertion of AHOLD, the microprocessor stops driving the address bus A31– A2 in the next clock. The data bus remains active and data can be transferred for previously issued read or write bus cycles during address hold. AHOLD is recognized even during RESET and LOCK. The earliest that AHOLD can be deasserted is two clock cycles after EADS is asserted to start a cache snoop.
BE3–BE0
Byte Enable (Active-Low Outputs) The byte enable pins indicate which bytes are enabled and active during read or write cycles. During the first cache fill cycle, however, an external system should ignore these signals and assume that all bytes are active. s BE3 for D31–D24 s BE2 for D23–D16 s BE1 for D15–D8 s BE0 for D7–D0 BE3–BE0 are active Low and are not driven during bus hold.
A20M
Address Bit 20 Mask (Active-Low Input) A Low signal on the A20M pin causes the microprocessor to mask address line A20 before performing a lookup to the internal cache, or driving a memory cycle on the bus. Asserting A20M causes the processor to wrap the address at 1 Mbyte, emulating Real mode operation. The signal is asynchronous, but must meet setup and hold times t20 and t21 for recognition during a specific clock. During normal operation, A20M should be sampled High at the falling edge of RESET.
BLAST (Modified)
Burst Last (Active-Low Output) Burst Last goes Low to tell the CPU that the next BRDY signal completes the burst bus cycle. BLAST is active for both burst and non-burst cycles. BLAST is active Low and is not driven during a bus hold.
A31–A2
Address Lines A31-A4 (Inputs/Outputs) Address Lines A3-A2 (Outputs) Pins A31–A2 define a physical area in memory or indicate an input/output (I/O) device. Address lines A31–A4 drive addresses into the microprocessor to perform cache line invalidations. Input signals must meet setup and hold times t22 and t23. A31–A2 are not driven during bus or address hold.
BOFF
Back Off (Active-Low Input) This input signal forces the microprocessor to float all pins normally floated during hold, but HLDA is not asserted in response to BOFF. BOFF has higher priority than RDY or BRDY; if both are returned in the same clock, BOFF takes effect. The microprocessor remains in bus hold until BOFF goes High. If a bus cycle is in progress when BOFF is asserted, the cycle restarts. BOFF must meet setup and hold times t18 and t19 for proper operation. BOFF has an internal weak pull-up.
ADS
Address Status (Active-Low Output) A Low output from this pin indicates that a valid bus cycle definition and address are available on the cycle definition lines and address bus. ADS is driven active by the same clock as the addresses. ADS is active Low and is not driven during bus hold.
BRDY
Burst Ready Input (Active-Low Input) The BRDY signal performs the same function during a burst cycle that RDY performs during a non-burst cycle. BRDY indicates that the external system has presented valid data in response to a read, or that the external system has accepted data in response to write. BRDY
12
Am486DE2 Microprocessor
is ignored when the bus is idle and at the end of the first clock in a bus cycle. BRDY is sampled in the second and subsequent clocks of a burst cycle. The data presented on the data bus is strobed into the microprocessor when BRDY is sampled active. If RDY is returned simultaneously with BRDY, BRDY is ignored and the cycle is converted to a non-burst cycle. BRDY is active Low and has a small pull-up resistor, and must satisfy the setup and hold times t16 and t17.
D/C
Data/Control (Output) This bus cycle definition pin distinguishes memory and I/O data cycles from control cycles. The control cycles are: s Interrupt Acknowledge s Halt/Special Cycle s Code Read (instruction fetching)
BREQ
Internal Cycle Pending (Output) BREQ indicates that the microprocessor has generated a bus request internally, whether or not the microprocessor is driving the bus. BREQ is active High and is floated only during Three-state Test mode. (See FLUSH.)
DP3–DP0
Data Parity (Inputs/Outputs) Data parity is generated on all write data cycles with the same timing as the data driven by the microprocessor. Even parity information must be driven back into the microprocessor on the data parity pins with the same timing as read information to ensure that the processor uses the correct parity check. The signals read on these pins do not affect program execution. Input signals must meet setup and hold times t22 and t23. DP3–DP0 should be connected to VCC through a pull-up resistor in systems not using parity. DP3–DP0 are active High and are driven during the second and subsequent clocks of write cycles.
BS8/BS16
Bus Size 8 (Active-Low Input) Bus Size 16 (Active-Low Input) The BS8 and BS16 signals allow the processor to operate with 8-bit and 16-bit I/O devices by running multiple bus cycles to respond to data requests: four for 8-bit devices, and two for 16-bit devices. The bus sizing pins are sampled every clock. The microprocessor samples the pins every clock before RDY to determine the appropriate bus size for the requesting device. The signals are active Low input with internal pull-up resistors, and must satisfy setup and hold times t14 and t15 for correct operation. Bus sizing is not permitted during copy-back or write-back operation. BS8 and BS16 are ignored during copy-back or write-back cycles.
EADS (Modified)
External Address Strobe (Active-Low Input) This signal indicates that a valid external address has been driven on the address pins A31–A4 of the microprocessor to be used for a cache snoop. This signal is recognized while the processor is in hold (HLDA is driven active), while forced off the bus with the BOFF input, or while AHOLD is asserted. The microprocessor ignores EADS at all other times. EADS is not recognized during the clock after ADS, nor during the clock after a valid assertion of EADS. Snoops to the on-chip cache must be completed before another snoop cycle is initiated. Table 1 describes EADS when first sampled. EADS can be asserted every other clock cycle as long as the hold remains active and HITM remains inactive. INV is sampled in the same clock period that EADS is asserted. EADS has an internal weak pull-up.
CACHE (New)
Internal Cacheability (Active-Low Output) In Write-through mode, this signal always floats.
CLK (Modified)
Clock (Input) The CLK input provides the basic microprocessor timing signal. All external timing parameters are specified with respect to the rising edge of CLK. The clock signal passes through an internal Phase-Lock Loop (PLL). The CLK input is multiplied by two by an internal phase lock loop (PLL) to generate the internal operating frequency.
Table 1. EADS Sample Time
Trigger AHOLD HOLD BOFF EADS First Sampled Second clock after AHOLD asserted First clock after HLDA asserted Second clock after BOFF asserted
D31–D0
Data Lines (Inputs/Outputs) Lines D31–D0 define the data bus. The signals must meet setup and hold times t22 and t23 for proper read operations. These pins are driven during the second and subsequent clocks of write cycles.
Note: The triggering signal (AHOLD, HOLD, or BOFF) must remain active for at least 1 clock after EADS to ensure proper operation.
Am486DE2 Microprocessor
13
This signal is used in cache snooping. The Am486DE2 processor does not support write-back cache. EADS has a weak internal pull-up, which disables this pin.
IGNNE
Ignore Numeric Error (Active-Low Input) When this pin is asserted, the Am486DE2 microprocessor will ignore a numeric error and continue executing non-control floating-point instructions. When IGNNE is deasserted, the Am486DE2 microprocessor will freeze on a non-control floating-point instruction if a previous floating-point instruction caused an error. IGNNE has no effect when the NE bit in Control Register 0 is set. IGNNE is active Low and is provided with a small internal pull-up resistor. IGNNE is asynchronous but must meet setup and hold times t20 and t21 to ensure recognition in any specific clock.
FERR
Floating-Point Error (Active-Low Output) Driven active when a floating-point error occurs, FERR is similar to the ERROR pin on a 387 math coprocessor. FERR is included for compatibility with systems using DOS-type floating-point error reporting. FERR is active Low and is not floated during bus hold, except during Three-state Test mode (see FLUSH).
FLUSH (Modified)
Cache Flush (Active-Low Input) In Write-through mode, FLUSH invalidates the cache without issuing a special bus cycle. FLUSH is an active Low input that needs to be asserted only for one clock. FLUSH is asynchronous, but setup and hold times t20 and t21 must be met for recognition in any specific clock. Sampling FLUSH Low in the clock before the falling edge of RESET causes the microprocessor to enter Three-state Test mode.
INTR
Maskable Interrupt (Input) When asserted, this signal indicates that an external interrupt has been generated. If the internal interrupt flag is set in EFLAGS, active interrupt processing is initiated. The microprocessor generates two locked interrupt acknowledge bus cycles in response to the INTR pin going active. INTR must remain active until the interrupt acknowledges have been performed to ensure that the interrupt is recognized. INTR is active High and is not provided with an internal pull-down resistor. INTR is asynchronous, but must meet setup and hold times t20 and t21 for recognition in any specific clock.
HITM (New)
Hit Modified Line (Active-Low Output) In Write-through mode, HITM floats at all times.
HLDA
Hold Acknowledge (Output) The HLDA signal is activated in response to a hold request presented on the HOLD pin. HLDA indicates that the microprocessor has given the bus to another local bus master. HLDA is driven active in the same clock in which the microprocessor floats its bus. HLDA is driven inactive when leaving bus hold. HLDA is active High and remains driven during bus hold. HLDA is floated only during Three-state Test mode. (See FLUSH.)
INV (New)
Invalidate (Input) The external system asserts INV to invalidate the cacheline state when an external bus master proposes a write. It is sampled together with A31–A4 during the clock in which EADS is active. INV has an internal weak pull-up. INV is ignored in Write-through mode.
KEN
Cache Enable (Active-Low Input) KEN determines whether the current cycle is cacheable. When the microprocessor generates a cacheable cycle and KEN is active one clock before RDY or BRDY during the first transfer of the cycle, the cycle becomes a cacheline-fill cycle. Returning KEN active one clock before RDY during the last read in the cache line fill causes the line to be placed in the on-chip cache. KEN is active Low and is provided with a small internal pull-up resistor. KEN must satisfy setup and hold times t14 and t15 for proper operation.
HOLD
Bus Hold Request (Input) HOLD gives control of the microprocessor bus to another bus master. In response to HOLD going active, the microprocessor floats most of its output and input/output pins. HLDA is asserted after completing the current bus cycle, burst cycle, or sequence of locked cycles. The microprocessor remains in this state until HOLD is deasserted. HOLD is active High and does not have an internal pull-down resistor. HOLD must satisfy setup and hold times t18 and t19 for proper operation.
LOCK
Bus Lock (Active-Low Output) A Low output on this pin indicates that the current bus cycle is locked. The microprocessor ignores HOLD when LOCK is asserted (although it does acknowledge AHOLD and BOFF). LOCK goes active in the first clock of the first locked bus cycle and goes inactive after the
14
Am486DE2 Microprocessor
last clock of the last locked bus cycle. The last locked cycle ends when RDY is returned. LOCK is active Low and is not driven during bus hold. Locked read cycles are not transformed into cache fill cycles if KEN is active.
PWT
Page Write-Through (Output) This pin reflects the state of the PWT bit in the page table entry or page directory entry (programmable through the PWT bit in CR3). If paging is disabled, the CPU ignores the PWT bit and drives the PWT output Low. PWT has the same timing as the cycle definition pins (M/IO, D/C, and W/R). PWT is active High and is not driven during bus hold.
M/IO
Memory/IO (Output) A High output indicates a memory cycle. A Low output indicates an I/O cycle.
NMI
Non-Maskable Interrupt (Input) A High NMI input signal indicates that an external nonmaskable interrupt has occurred. NMI is rising-edge sensitive. NMI must be held Low for at least four CLK periods before this rising edge. The NMI input does not have an internal pull-down resistor. The NMI input is asynchronous, but must meet setup and hold times t20 and t21 for recognition in any specific clock.
RDY
Non-Burst Ready (Active-Low Input) A Low input on this pin indicates that the current bus cycle is complete, that is, either the external system has presented valid data on the data pins in response to a read, or the external system has accepted data from the microprocessor in response to a write. RDY is ignored when the bus is idle and at the end of the bus cycle’s first clock. RDY is active during address hold. Data can be returned to the processor while AHOLD is active. RDY is active Low and does not have an internal pullup resistor. RDY must satisfy setup and hold times t16 and t17 for proper chip operation.
PCD
Page Cache Disable (Output) This pin reflects the state of the PCD bit in the page table entry or page directory entry (programmable through the PCD bit in CR3). If paging is disabled, the CPU ignores the PCD bit and drives the PCD output Low. PCD has the same timing as the cycle definition pins (M/IO, D/C, and W/R). PCD is active High and is not driven during bus hold. PCD is masked by the Cache Disable Bit (CD) in Control Register 0 (CR0).
RESET
Reset (Input) RESET forces the microprocessor to initialize. The microprocessor cannot begin instruction execution of instructions until at least 1 ms after VCC and CLK have reached their proper DC and AC specifications. To ensure proper microprocessor operation, the RESET pin should remain active during this time. RESET is active High. RESET is asynchronous, but must meet setup and hold times t20 and t21 to ensure recognition on any specific clock.
PCHK
Parity Status (Active-Low Output) Parity status is driven on the PCHK pin the clock after RDY for read operations. The parity status reflects data sampled at the end of the previous clock. A Low PCHK indicates a parity error. Parity status is checked only for enabled bytes as is indicated by the byte enable and bus size signals. PCHK is valid only in the clock immediately after read data is returned to the microprocessor; at all other times PCHK is inactive High. PCHK is floated only during Three-state Test mode. (See FLUSH.)
SMI (New)
SMM Interrupt (Active-Low Input) A Low signal on the SMI pin signals the processor to enter System Management Mode (SMM). SMI is the highest-level processor interrupt. The SMI signal is recognized on an instruction boundary, similar to the NMI and INTR signals. SMI is sampled on every rising clock edge. SMI is a falling-edge sensitive input. Recognition of SMI is guaranteed in a specific clock if it is asserted synchronously and meets the setup and hold times. If SMI is asserted asynchronously, it must go High for a minimum of two clocks before going Low, and it must remain Low for at least two clocks to guarantee recognition. When the CPU recognizes SMI, it enters SMM before executing the next instruction and saves internal registers in SMM space.
PLOCK (Modified)
Pseudo-Lock (Active-Low Output) When PLOCK is asserted in Write-through mode, it indicates that the current bus transaction requires more than one bus cycle. Examples of such operations are segment table descriptor reads (8 bytes) and cache line fills (16 bytes). The microprocessor drives PLOCK active until the addresses for the last bus cycle of the transaction have been driven, whether or not RDY or BRDY is returned. PLOCK is a function of the BS8, BS16, and KEN inputs. PLOCK should be sampled on the clock when RDY is returned. PLOCK is active Low and is not driven during bus hold.
Am486DE2 Microprocessor
15
SMIACT (New)
SMM Interrupt Active (Active-Low Output) SMIACT goes Low in response to SMI. It indicates that the processor is operating under SMM control. SMIACT remains Low until the processor receives a RESET signal or executes the Resume instruction (RSM) to leave SMM. This signal is always driven. It does not float during bus HOLD or BOFF.
TDI
Test Data Input (Input) TDI is the serial input that shifts JTAG instructions and data into the tested component. TDI is sampled on the rising edge of TCK during the SHIFT-IR and the SHIFTDR TAP (Test Access Port) controller states. During all other TAP controller states, TDI is ignored. TDI uses an internal weak pull-up.
Note: Do not use SRESET to exit from SMM. The system should block SRESET during SMM.
TDO
Test Data Output (Output) TDO is the serial output that shifts JTAG instructions and data out of the component. TDO is driven on the falling edge of TCK during the SHIFT-IR and SHIFT-DR TAP controller states. Otherwise, TDO is three-stated.
SRESET (New)
Soft Reset (Input) The CPU samples SRESET on every rising clock edge. If SRESET is sampled active, the SRESET sequence begins on the next instruction boundary. SRESET resets the processor, but, unlike RESET, does not cause it to sample UP or WB/WT, or affect the FPU, cache, CD and NW bits in CR0, and SMBASE. SRESET is asynchronous and must meet the same timing as RESET.
TMS
Test Mode Select (Input) TMS is decoded by the JTAG TAP to select the operation of the test logic. TMS is sampled on the rising edge of TCK. To guarantee deterministic behavior of the TAP controller, the TMS pin has an internal pull-up resistor.
STPCLK (New)
Stop Clock (Active-Low Input) A Low input signal indicates a request has been made to turn off the CLK input. When the CPU recognizes a STPCLK, the processor: s stops execution on the next instruction boundary (unless superseded by a higher priority interrupt) s empties all internal pipelines and write buffers s generates a Stop Grant acknowledge bus cycle STPCLK is active Low and has an internal pull-up resistor. STPCLK is asynchronous, but it must meet setup and hold times t20 and t21 to ensure recognition in any specific clock. STPCLK must remain active until the Stop Clock special bus cycle is issued and the system returns either RDY or BRDY.
UP
Upgrade Present (Input) The processor samples the Upgrade Present (UP) pin in the clock before the falling edge of RESET. If it is Low, the processor three-states its outputs immediately. UP must remain asserted to keep the processor inactive. The pin uses an internal pull-up resistor.
VOLDET (New, 168-Pin PGA Package only)
Voltage Detect (Output) VOLDET provides an external signal to allow the system to determine the CPU input power level (3 V or 5 V). For the Am486DE2, the pin ties internally to VSS.
WB/WT (New)
Write-Back/Write-Through (Input) WB/WT is sampled Low at RESET, and all cache-line fills are write-through. WB/WT has an internal weak pulldown. This pin should be tied Low for the Am486DE2 microprocessor.
TCK
Test Clock (Input) Test Clock provides the clocking function for the JTAG boundary scan feature. TCK clocks state information and data into the component on the rising edge of TCK on TMS and TDI, respectively. Data is clocked out of the component on the falling edge of TCK on TDO.
W/R
Write/Read (Output) A High output indicates a write cycle. A Low output indicates a read cycle.
Note: The Am486DE2 microprocessor does not use the VCC5 pin used by some 3-V, clock-tripled, 486-based processors. The corresponding pin on the Am486DE2 microprocessor is an Internal No Connect (INC).
16
Am486DE2 Microprocessor
FUNCTIONAL DESCRIPTION
Note: This Am486DE microprocessor does not support Write-back mode. If you are designing in a shared-memory system or using cache coherency (including snooping and locked accesses), use one of the Am486DE products that supports write back.
Virtual Mode In Virtual mode, the processor appears to be in Real mode, but can use the extended memory accessing of Protected mode. Protected Mode Protected mode provides access to the sophisticated memory management paging and privilege capabilities of the processor. System Management Mode SMM is a special operating mode described in detail in “System Management Mode” on page 22.
Overview
The Am486DE2 microprocessor uses a 32-bit architecture with on-chip memory management and cache memory units. The instruction set includes the complete 486 microprocessor instruction set, along with extensions to serve the new extended applications. All software written for the 486 microprocessor and previous members of the x86 architectural family can run on the Am486DE2 microprocessor without modification. The on-chip Memory Management Unit (MMU) is completely compatible with the 486 MMU. The MMU includes a segmentation unit and a paging unit. Segmentation allows management of the logical address space by providing easy data and code relocatability and efficient sharing of global resources. The paging mechanism operates beneath segmentation and is transparent to the segmentation process. Paging is optional and can be disabled by system software. Each segment can be divided into one or more 4-Kbyte segments. To implement a virtual memory system, the Am486DE2 microprocessor supports full restartability for all page and segment faults.
Write-Through Cache Architecture
The Am486DE2 microprocessor supports the standard 486DX-type write-through cache architecture, which is characterized by the following: s External read accesses are placed in the cache if they meet proper caching requirements. s Subsequent reads to the data in the cache are made if the address is stored in the cache tag array. s Write operations to a valid address in the cache are updated in the cache and to external memory. This data writing technique is called write-through. The write-through cache implementation forces all writes to flow through to the external bus and back to main memory. Consequently, the write-through cache generates a large amount of bus traffic on the external data bus.
Memory
Memory is organized into one or more variable length segments, each up to 4 Gbyte (232 bytes). A segment can have attributes associated with it, including its location, size, type (e.g., stack, code, or data), and protection characteristics. Each task on a microprocessor can have a maximum of 16,381 segments, each up to 4 Gbyte. Thus, each task has a maximum of 64 Tbyte of virtual memory. The segmentation unit provides four levels of protection for isolating and protecting applications and the operating system from each other. The hardware-enforced protection allows high-integrity system designs.
Cache Replacement Description
The cache-line-replacement algorithm uses the standard Am486 CPU pseudo LRU (least recently used) strategy. When a line must be placed in the internal cache, the microprocessor first checks to see if there is an invalid line available in the set. If no invalid line is available, the LRU algorithm replaces the least-recently used cache line in the four-way set with the new cache line. If the cache line for replacement is modified, the modified cache line is placed into the copy-back buffer for copying back to external memory, and the new cache line is placed into the cache. This copy-back ensures that the external memory is updated with the modified data upon replacement.
Modes of Operation
The Am486DE2 microprocessor has four modes of operation: Real Address mode (Real mode), Virtual 8086 Address mode (Virtual mode), Protected Address mode (Protected mode), and System Management mode (SMM). Real Mode In Real mode, the Am486DE2 microprocessor operates as a fast 8086. Real mode is required primarily to set up the processor for Protected mode operation.
Memory Configuration
In computer systems, memory regions require specific caching and memory write methods. For example, some memory regions are noncacheable while others are cacheable but are write-through. To allow maximum memory configuration, the microprocessor supports
Am486DE2 Microprocessor
17
specific memory region requirements. All bus masters, such as DMA controllers, must reflect all data transfers on the microprocessor local bus so that the microprocessor can respond appropriately. Cacheability The Am486DE2 processor caches data based on the state of the CD and NW bits in CR0, in conjunction with the KEN signal, at the time of a burst read access from memory. When the WB/WT signal is Low during the first BRDY, KEN meets the standard setup and hold requirements, and the four 32-bit doublewords are placed in the cache. However, all cacheable accesses in this mode are considered write-through.
Note: The CD bit in CR0 enables (0) or disables (1) the internal cache. The NW bit in CR0 enables (0) or disables (1) write-through and snooping cycles. RESET sets CD and NW to 1. Unlike RESET, however, SRESET does not invalidate the cache nor does it modify the values of CD and NW in CR0.
Write-Through When the WB/WT signal is Low during the first BRDY of the cache line read access, the cache line is considered a write-through access. Therefore, all writes to this location in the cache are reflected on the external bus, even if the cache line is write protected.
CLOCK CONTROL Clock Generation
The Am486DE2 CPU is driven by a 1X clock that relies on phased-lock loop (PLL) to generate the two internal clock phases: phase one and phase two. The rising edge of CLK corresponds to the start of phase one (ph1). All external timing parameters are specified relative to the rising edge of CLK. gram execution at the instruction following the interrupted instruction. Unlike the normal interrupts (INTR and NMI), STPCLK does not initiate interrupt acknowledge cycles or interrupt table reads. External Interrupts in Order of Priority In Write-through mode, the priority order of external interrupts is: 1. RESET/SRESET 2. FLUSH 3. SMI 4. NMI 5. INTR 6. STPCLK STPCLK is active Low and has an internal pull-up resistor. STPCLK is asynchronous, but setup and hold times must be met to ensure recognition in any specific clock. STPCLK must remain active until the Stop Grant special bus cycle is asserted and the system responds with either RDY or BRDY. When the CPU enters the Stop Grant state, the internal pull-up resistor is disabled, reducing the CPU power consumption. The STPCLK input must be driven High (not floated) to exit the Stop Grant state. STPCLK must be deasserted for a minimum of five clocks after RDY or BRDY is returned active for the Stop Grant bus cycle before being asserted again. There are two regions for the Low-Power-mode supply current: 1. Low Power: Stop Grant state (fast wake-up, frequency- and voltage-dependent) 2. Lowest Power: Stop Clock state (slow wake-up, voltage-dependent)
Stop Clock
The Am486DE2 CPU also provides an interrupt mechanism, STPCLK, that allows system hardware to control the power consumption of the CPU by stopping the internal clock to the CPU core in a sequenced manner. The first low-power state is called the Stop Grant state. If the CLK input is completely stopped, the CPU enters into the Stop Clock state (the lowest power state). When the CPU recognizes a STPCLK interrupt, the processor: s stops execution on the next instruction boundary (unless superseded by a higher priority interrupt) s waits for completion of cache flush s stops the pre-fetch unit s empties all internal pipelines and write buffers s generates a Stop Grant bus cycle s stops the internal clock At this point the CPU is in the Stop Grant state The CPU cannot respond to a STPCLK request from an HLDA state because it cannot empty the write buffers and, therefore, cannot generate a Stop Grant cycle. The rising edge of STPCLK signals the CPU to return to pro-
18
Am486DE2 Microprocessor
Stop Grant Bus Cycle
The processor drives a special Stop Grant bus cycle to the bus after recognizing the STPCLK interrupt. This bus cycle is the same as the HALT cycle used by a standard Am486 microprocessor, with the exception that the Stop Grant bus cycle drives the value 0000 0010h on the address pins. s M/lO = 0 s D/C = 0 s W/R =1 s Address Bus = 0000 0010h (A4 = 1) s BE3–BE0 = 1011 s Data bus = undefined The system hardware must acknowledge this cycle by returning RDY or BRDY, or the processor will not enter the Stop Grant state (see Figure 1). The latency between a STPCLK request and the Stop Grant bus cycle depends on the current instruction, the amount of data in the CPU write buffers, and the system memory performance.
To achieve the lowest possible power consumption during the Stop Grant state, the system designer must ensure the input signals with pull-up resistors are not driven Low, and the input signals with pull-down resistors are not driven High. All inputs except data bus pins must be driven to the power supply rails to ensure the lowest possible current consumption during Stop Grant or Stop Clock modes. For compatibility, data pins must be driven Low to achieve the lowest possible power consumption. Table 2. Pin State During Stop Grant Bus State
Signal A3–A2 A31–A4 D31–D0 BE3–BE0 DP3–DP0 W/R, D/C, M/IO, CACHE ADS LOCK, PLOCK BREQ HLDA BLAST FERR PCHK SMIACT HITM Type State O I/O I/O O I/O O O O O O O O O O O Previous State Previous State Floated Previous State Floated Previous State Inactive Inactive Previous State As per HOLD Previous State Previous State Previous State Previous State Previous State
Pin State During Stop Grant
Table 2 shows the pin states during Stop Grant bus states. During the Stop Grant state, most output and input/output signals of the microprocessor maintain the level they held when entering the Stop Grant state. The data and data parity signals are three-stated. In response to HOLD being driven active during the Stop Grant state (when the CLK input is running), the CPU generates HLDA and three-states all output and input/output signals that are three-stated during the HOLD/HLDA state. After HOLD is deasserted, all signals return to the same state they were before the HOLD/HLDA sequence.
CLK
STPCLK
t20
ADDR
t21
Stop Grant Bus cycle
RDY
Figure 1. Entering Stop Grant State
Am486DE2 Microprocessor
19
Clock Control State Diagram
Figure 2 shows the state transitions during a Stop Clock cycle. Normal State This is the normal operating state of the CPU. While in the normal state, the CLK input can be dynamically changed within the specified CLK period stability limits. Stop Grant State The Stop Grant state provides a low-power state that can be entered by simply asserting the external STPCLK interrupt pin. When the Stop Grant bus cycle has been placed on the bus, and either RDY or BRDY is returned, the CPU is in this state. The CPU returns to the normal execution state 10–20 clock periods after STPCLK has been deasserted. While in the Stop Grant state, the pull-up resistors on STPCLK and UP are disabled internally. The system must continue to drive these inputs to the state they were in immediately before the CPU entered the Stop Grant state. For minimum CPU power consumption, all other input pins should be driven to their inactive level while the CPU is in the Stop Grant state. A RESET or SRESET brings the CPU from the Stop Grant state to the Normal state. The CPU recognizes the inputs required for cache invalidations (HOLD, AHOLD, BOFF, and EADS), as explained later. The CPU does not recognize any other inputs while in the Stop Grant state. Input signals to the CPU are not recognized until 1 clock after STPCLK is deasserted (see Figure 3). While in the Stop Grant state, the CPU does not recognize transitions on the interrupt signals (SMI, NMI, and INTR). Driving an active edge on either SMI or NMI does not guarantee recognition and service of the interrupt request following exit from the Stop Grant state. However, if one of the interrupt signals (SMI, NMI or INTR) is driven active while the CPU is in the Stop Grant state, and held active for at least one CLK after STPCLK is deasserted, the corresponding interrupt will be ser-
viced. The Am486DE2 processor requires INTR to be held active until the CPU issues an interrupt acknowledge cycle to guarantee recognition. This condition also applies to the existing Am486 CPUs. In the Stop Grant state, the system can stop or change the CLK input. When the clock stops, the CPU enters the Stop Clock state. The CPU returns to the Stop Grant state immediately when the CLK input is restarted. You must hold the STPCLK input Low until a stabilized frequency has been maintained for at least 1 ms to ensure that the PLL has had sufficient time to stabilize. The CPU generates a Stop Grant bus cycle when entering the state from the Normal or the Auto Halt PowerDown state. When the CPU enters the Stop Grant state from the Stop Clock state or the Stop Clock Snoop state, the CPU does not generate a Stop Grant bus cycle. Stop Clock State Stop Clock state is entered from the Stop Grant state by stopping the CLK input (either logic High or logic Low). None of the CPU input signals should change state while the CLK input is stopped. Any transition on an input signal (except INTR) before the CPU has returned to the Stop Grant state may result in unpredictable behavior. If INTR goes active while the CLK input is stopped, and stays active until the CPU issues an interrupt acknowledge bus cycle, it is serviced in the normal manner. System design must ensure the CPU is in the correct state prior to asserting cache invalidation or interrupt signals to the CPU. Auto Halt Power-Down State A HALT instruction causes the CPU to enter the Auto Halt Power-Down state. The CPU issues a normal HALT bus cycle, and only transitions to the Normal state when INTR, NMI, SMI, RESET, or SRESET occurs. The system can generate a STPCLK while the CPU is in the Auto Halt Power-Down state. The CPU generates a Stop Grant bus cycle when it enters the Stop Grant state from the HALT state. When the system deasserts the STPCLK interrupt, the CPU returns execution to the HALT state. The CPU generates a new HALT bus cycle when it reenters the HALT state from the Stop Grant state.
SRESET FUNCTION
The Am486DE2 microprocessor supports a soft reset function through the SRESET pin. SRESET forces the processor to begin execution in a known state. The processor state after SRESET is the same as after RESET except that the internal caches, CD and NW in CR0, write buffers, SMBASE registers, and floating-point registers retain the values they had prior to SRESET, and cache snooping is allowed. The processor starts execution at physical address FFFFFFF0h. SRESET can be used to help performance for DOS extenders written for the 80286 processor. SRESET provides a method to switch from Protected to Real mode while maintaining the internal caches, CR0, and the FPU state. SRESET may not be used in place of RESET after power-up.
20
Am486DE2 Microprocessor
HLT instruction executed and Halt bus cycle generated
Auto HALT Power Down State CLK Running
Normal State
INTR, NMI, SMI, RESET, SRESET
CLK Running
STPCLK asserted and Stop Grant bus cycle
STPCLK deasserted and Halt bus cycle STPCLK asserted and Stop Grant bus cycle
STPCLK deasserted or RESET, SRESET
Stop Grant State CLK Running
Stop CLK Start CLK and PLL latency
Stop Clock State CLK Changed
Figure 2. Stop Clock State Machine
CLK
STPCLK Sampled
STPCLK
t20 t21 A
NMI SMI
Note: A = Earliest time at which NMI or SMI is recognized.
Figure 3. Recognition of Inputs when Exiting Stop Grant State
Am486DE2 Microprocessor
21
SYSTEM MANAGEMENT MODE Overview
The Am486DE2 microprocessor supports four modes: Real, Virtual, Protected, and System Management Mode (SMM). As an operating mode, SMM has a distinct processor environment, interface, and hardware/software features. SMM lets the system designer add new software-controlled features to the computer products that always operate transparent to the operating system (OS) and software applications. SMM is intended for use only by system firmware, not by applications software or general-purpose systems software. The SMM architectural extension consists of the following elements: 1. System Management Interrupt (SMI) hardware interface 2. Dedicated and secure memory space (SMRAM) for SMI handler code and CPU state (context) data with a status signal for the system to decode access to that memory space, SMIACT 3. Resume (RSM) instruction, for exiting SMM 4. Special features, such as I/O Restart and I/O instruction information, for transparent power management of I/O peripherals, and Auto Halt Restart s SMRAM: This is the physical memory dedicated to SMM. The SMI handler code and related data reside in this memory. The processor also uses this memory to store its context before executing the SMI handler. The operating system and applications should not have access to this memory space. s SMBASE: This is a control register that contains the base address that defines the SMRAM space. s Context: This term refers to the processor state. The SMM discussion refers to the context, or processor state, just before the processor invokes SMM. The context normally consists of the CPU registers that fully represent the processor state. s Context Switch: A context switch is the process of either saving or restoring the context. The SMM discussion refers to the context switch as the process of saving/restoring the context while invoking/exiting SMM, respectively. s SMSAVE: A mechanism that saves and restores all internal registers to and from SMRAM.
System Management Interrupt Processing
The system interrupts the normal program execution and invokes SMM by generating a System Management Interrupt (SMI) to the CPU. The CPU services the SMI by executing the following sequence (see Figure 4). 1. The CPU asserts the SMIACT signal, instructing the system to enable the SMRAM. 2. The CPU saves its state (internal register) to SMRAM. It starts at the SMBASE relative address location (see “SMRAM” on page 24), and proceeds downward in a stack-like fashion. 3. The CPU switches to the SMM processor environment (an external pseudo-Real mode). 4. The CPU then jumps to the absolute address of SMBASE + 8000h in SMRAM to execute the SMI handler. This SMI handler performs the system management activities.
Terminology
The following terms are used throughout the discussion of System Management Mode. s SMM: System Management Mode. This is the operating environment that the processor (system) enters when servicing a System Management Interrupt. s SMI: System Management Interrupt. This is the trigger mechanism for the SMM interface. When SMI is asserted (SMI pin asserted Low), it causes the processor to invoke SMM. The SMI pin is the only means of entering SMM. s SMI handler: System Management Mode handler. This is the code that is executed when the processor is in SMM. An example application that this code might implement is a power-management-control or a system-control function. s RSM: Resume instruction. This instruction is used by the SMI handler to exit the SMM and return to the interrupted OS or application process.
Note: If the SMRAM shares the same physical address location with part of the system RAM, it is “overlaid” SMRAM. To preserved cache consistency and correct SMM operation in systems using overlaid SMRAM, the cache must be flushed via the FLUSH pin when entering SMM.
5. The SMI handler then executes the RSM instruction, which restores the CPU’s context from SMRAM, deasserts the SMIACT signal, and then returns control to the previously interrupted program execution.
22
Am486DE2 Microprocessor
SMI
Instr #1 Instr #2 Instr Instr #3 #4 State Save SMI Handler RSM State Restore #5 Instr
SMI SMIACT
Figure 4. Basic SMI Interrupt Service
For uses such as fast enabling of external I/O devices, the SMSAVE mode permits the restarting of the I/O instructions and the HALT instruction. This is accomplished through I/O Trap Restart and Halt/Auto Halt Restart slots. Only I/O and HALT opcodes are restartable. Attempts to restart any other opcode may result in unpredictable behavior. The System Management Interrupt hardware interface consists of the SMI request input and the SMIACT output used by the system to decode the SMRAM (see Figure 5).
input needs to remain active for only a single clock if the required setup and hold times are met. SMI also works correctly if it is held active for an arbitrary number of clocks (see Figure 6). The SMI input must be held inactive for at least four clocks after it is asserted to reset the edge-triggered logic. A subsequent SMI may not be recognized if the SMI input is not held inactive for at least four clocks after being asserted. SMI, like NMI, is not affected by the IF bit in the EFLAGS register and is recognized on an instruction boundary. SMI does not break locked bus cycles. SMI has a higher priority than NMI and is not masked during an NMI. After SMI is recognized, the SMI signal is masked internally until the RSM instruction is executed and the interrupt service routine is complete. Masking SMI prevents recursive calls. If another SMI occurs while SMI is masked, the pending SMI is recognized and executed on the next instruction boundary after the current SMI completes. This instruction boundary occurs before execution of the next instruction in the interrupted application code, resulting in back-to-back SMI handlers. Only one SMI signal can be pending while SMI is masked. The SMI signal is synchronized internally and must be asserted at least three clock periods prior to asserting the RDY signal to guarantee recognition on a specific instruction boundary. This is important for servicing an I/O trap with an SMI handler. SMI Active (SMIACT) SMIACT indicates that the CPU is operating in SMM. The CPU asserts SMIACT in response to an SMI interrupt request on the SMI pin. SMIACT is driven active after the CPU has completed all pending write cycles
SMIACT CPU SMI
}
SMI Interface
Figure 5. Basic SMI Hardware Interface
System Management Interrupt Processing SMI is a falling-edge-triggered, non-maskable interruptrequest signal. SMI is an asynchronous signal, but setup and hold times must be met to guarantee recognition in a specific clock. The SMI input does not have to remain active until the interrupt is actually serviced. The SMI
Am486DE2 Microprocessor
23
(including emptying the write buffers), and before the first access to SMRAM when the CPU saves (writes) its state (or context) to SMRAM. SMIACT remains active until the last access to SMRAM when the CPU restores (reads) its state from SMRAM. The SMIACT signal does not float in response to HOLD. The SMIACT signal is used by the system logic to decode SMRAM. The number of clocks required to complete the SMM state save and restore is dependent on system memory performance. The values shown in Figure 7 assume 0 waitstate memory writes (two clock cycles), 2 – 1 – 1 – 1 burst read cycles, and 0 wait-state non-burst reads (two clock cycles). Additionally, it is assumed that the data read during the SMM-state-restore sequence is not cacheable. The minimum time required to enter an SMSAVE SMI handler routine for the CPU (from the completion of the interrupted instruction) is given by:
Latency to start of SMl handler = A + B + C = 161 clocks
SMI handler can use the SMRAM for system management information such as the system configuration, configuration of a powered-down device, and system designer-specific information.
Note: Access to SMRAM is through the CPU internal cache. To ensure cache consistency and correct operation, always assert the FLUSH pin in the same clock as SMI for systems using overlaid SMRAM.
The CPU asserts SMIACT to indicate to the memory controller that it is operating in System Management Mode. The system logic should ensure that only the CPU and SMI handler have access to this area. Alternate bus masters or DMA devices trying to access the SMRAM space when SMIACT is active should be directed to system RAM in the respective area. The system logic is minimally required to decode the physical memory address range from 38000h–3FFFFh as SMRAM area. The CPU saves its state to the state-save area from 3FFFFh downward to 3FE00h. After saving its state, the CPU jumps to the address location 38000h to begin executing the SMI handler. The system logic can choose to decode a larger area of SMRAM as needed. The size of this SMRAM can be between 32 Kbyte and 4 Gbyte.The system logic should provide a manual method for switching the SMRAM into system memory space when the CPU is not in SMM. This enables initialization of the SMRAM space (i.e., loading SMI handler) before executing the SMI handler during SMM (see Figure 8).
and the minimum time required to return to the interrupted application (following the final SMM instruction before RSM) is given by:
Latency to continue application = E + F + G = 258 clocks
SMRAM The CPU uses the SMRAM space for state-save and state-restore operations during an SMI. The SMI handler, which also resides in SMRAM, uses the SMRAM space to store code, data, and stacks. In addition, the
CLK CLK2
SMI Sampled
SMI tsu thd
RDY
Figure 6. SMI Timing for Servicing an I/O Trap
24
Am486DE2 Microprocessor
T1 CLK CLK2
T2
SMI ADS
B
G
SS
SS SS
SS SS
SS
RDY
SMIACT
SS SS
A Normal State C D E F
State Save
SMM Handler
State Restore
Normal State
Clock-Doubled CPU
A: Last RDY from non-SMM transfer to SMIACT assertion B: SMIACT assertion to first ADS for SMM state save C: SMM state save (dependent on memory performance) D: SMI handler E: SMM state restore (dependent on memory performance) F: Last RDY from SMM transfer to deassertion of SMIACT G: SMIACT deassertion of first non-SMM ADS 2 CLKs minimum 20 CLKs minimum 139 CLKs User-determined 236 CLKs 2 CLKs minimum 20 CLKs minimum
Figure 7. SMIACT Timing
SMRAM State Save Map When SMI is recognized on an instruction boundary, the CPU core first sets the SMIACT signal Low, indicating to the system logic that accesses are now being made to the system-defined SMRAM areas. The CPU then writes its state to the state save area in the SMRAM. The state save area starts at SMBASE + [8000h + 7FFFh]. The default CS Base is 30000h; therefore, the default state save area is at 3FFFFh. In this case, the CS Base is also referred to as the SMBASE. If the SMBASE relocation feature is enabled, the SMRAM addresses can change. The following formula is used to determine the relocated addresses where the context is saved: SMBASE + [8000h + Register Offset], where the default initial SMBASE is 30000h and the Register Offset is listed in Table 3. Reserved spaces are for new registers in future CPUs. Some registers in the SMRAM state save area may be read and changed by
System memory accesses redirected to SMRAM CPU accesses to system address space used for loading SMRAM
SMRAM
System memory accesses not redirected to SMRAM Normal Memory Space
Figure 8. Redirecting System Memory Address to SMRAM
Am486DE2 Microprocessor
25
the SMI handler, with the changed values restored to the processor register by the RSM instruction. Some register images are read-only, and must not be modified. (Modifying these registers results in unpredictable behavior.) The values stored in the reserved areas may change in future CPUs. An SMI handler should not rely on values stored in a reserved area. The following registers are written out during SMSAVE mode to the RESERVED memory locations (7FA7h– 7F98h, 7F93h–7F8Ch, and 7F87h–7F08h), but are not visible to the system software programmer: s DR3–DR0 s CR2 s CS, DS, ES, FS, GS, and SS hidden descriptor registers s EIP_Previous s GDT Attributes and Limits s IDT Attributes and Limits s LDT Attributes, Base, and Limits s TSS Attributes, Base, and Limits If an SMI request is issued to power down the CPU, the values of all reserved locations in the SMM state save must be saved to nonvolatile memory. The following registers are not automatically saved and restored by SMI and RSM: s TR7–TR3 s FPU registers: — STn — FCS — FSW — Tag Word — FP instruction pointer — FP opcode — Operand pointer
Table 3. SMRAM State Save Map
Register Offset*
7FFCh 7FF8h 7FF4h 7FF0h 7FECh 7FE8h 7FE4h 7FE0h 7FDCh 7FD8h 7FD4h 7FD0h 7FCCh 7FC8h 7FC4h 7FC0h 7FBCh 7FB8h 7FB4h 7FB0h 7FACh 7FA8h 7F94h 7F88h 7F04h 7F02h 7F00h 7EFCh 7EF8h CRO CR3 EFLAGS EIP EDI ESI EBP ESP EBX EDX ECX EAX DR6 DR7 TR* LDTR* GS* FS* DS* SS* CS* ES* IDT Base GDT Base I/O Trap Word Auto Halt Restart I/O Trap Restart SMM Revision Identifier State Dump Base
Register
Writable?
No No Yes Yes Yes Yes Yes Yes Yes Yes Yes Yes No No No No No No No No No No No No No No No No Yes Yes Yes Yes No
7FA7h–7F98h Reserved 7F93h–7F8Ch Reserved 7F87h–7F08h Reserved
7EF7h–7E00h Reserved
Note: *Upper 2 bytes are not modified.
Note: You can save the FPU state by using an FSAVE or FNSAVE instruction.
For all SMI requests except for power-down suspend/ resume, these registers do not have to be saved because their contents will not change. During a powerdown suspend/resume, however, a resume reset clears these registers back to their default values. In this case, the suspend SMI handler should read these registers directly to save them and restore them during the powerup resume. Anytime the SMI handler changes these registers in the CPU, it must also save and restore them. 26
Entering System Management Mode
SMM is one of the major operating modes, along with Protected mode, Real mode, and Virtual mode. Figure 9 shows how the processor can enter SMM from any of the three modes and then return. The external signal SMI causes the processor to switch to SMM. The RSM instruction exits SMM. SMM is transparent to applications programs and operating systems for the following reasons:
Am486DE2 Microprocessor
s The only way to enter SMM is via a type of nonmaskable interrupt triggered by an external signal. s The processor begins executing SMM code from a separate address space, referred to earlier as system management RAM (SMRAM). s Upon entry into SMM, the processor saves the register state of the interrupted program (depending on the save mode) in a part of SMRAM called the SMM context save space. s All interrupts normally handled by the operating system or applications are disabled upon SMM entry. s A special instruction, RSM, restores processor registers from the SMM context save space and returns control to the interrupted program. Similar to Real mode, SMM has no privilege levels or address mapping. SMM programs can execute all I/O and other system instructions and can address up to 4 Gbyte of memory.
Real Mode Reset or PE=0 Reset PE=1 SMI Reset or RSM SMI RSM System Management Mode
Protected Mode VM=0 VM=1
Virtual Mode
RSM
SMI
Figure 9. Transition to and from SMM
Exiting System Management Mode
The RSM instruction (opcode 0F AAh) leaves SMM and returns control to the interrupted program. The RSM instruction can be executed only in SMM. An attempt to execute the RSM instruction outside of SMM generates an invalid opcode exception. When the RSM instruction is executed and the processor detects invalid state information during the reloading of the save state, the processor enters the shutdown state. This occurs in the following situations: s The value in the State Dump base field is not a 32-Kbyte aligned address. s A combination of bits in CR0 is illegal: PG=1 and PE=0, or NW=1 and CD=0. In shutdown mode, the processor stops executing instructions until an NMI interrupt is received or reset initialization is invoked. The processor generates a shutdown bus cycle. Three SMM features can be enabled by writing to control slots in the SMRAM state save area: 1. Auto Halt Restart. It is possible for the SMI request to interrupt the HALT state. The SMI handler can tell the RSM instruction to return control to the HALT instruction or to return control to the instruction following the HALT instruction by appropriately setting the Auto Halt Restart slot. The default operation is to restart the HALT instruction.
2. I/O Trap Restart. If the SMI was generated on an I/O access to a powered-down device, the SMI handler can instruct the RSM instruction to re-execute that I/O instruction by setting the I/O Trap Restart slot. 3. SMBASE Relocation. The system can relocate the SMRAM by setting the SMBASE Relocation slot in the state save area. The RSM instruction sets SMBASE in the processor based on the value in the SMBASE relocation slot. The SMBASE must be aligned on 32-Kbyte boundaries. A RESET also causes execution to exit from SMM.
Processor Environment
When an SMI signal is recognized on an instruction execution boundary, the processor waits for all stores to complete, including emptying the write buffers. The final write cycle is complete when the system returns RDY or BRDY. The processor then drives SMIACT active, saves its register state to SMRAM space, and begins to execute the SMI handler. SMI has greater priority than debug exceptions and external interrupts. This means that if more than one of these conditions occur at an instruction boundary, only the SMI processing occurs. Subsequent SMI requests are not acknowledged while the processor is in SMM. The first SMI request that occurs while the processor is in SMM is latched, and serviced when the processor exits SMM with the RSM instruction. Only one SMI signal is latched by the CPU while it is in SMM. When the CPU invokes SMM, the CPU core registers are initialized as indicated in Table 4.
Am486DE2 Microprocessor
27
Table 4. SMM Initial CPU Core Register Settings
Register General Purpose Registers EFLAGS CR0 DR6 DR7 GDTR, LDTR, IDTR, TSSR SMM Initial State Unmodified
Table 5. Segment Register Initial States
Segment Selector Register CS2 DS 3000h 0000h 0000h 0000h 0000h 0000h Base 30000h Attributes Limit1 4 Gbyte 4 Gbyte 4 Gbyte 4 Gbyte 4 Gbyte 4 Gbyte
0000 0002h Bits 0, 2, 3, and 31 cleared (PE, EM, TS, and PG); remainder unmodified Unpredictable state 0000 0400h Unmodified
ES FS GS SS
EIP 0000 8000h Note: Interrupts from INT and NMI are disabled on SMM entry.
1. The segment limit the usual 64K. 2. The Selector value for CS remains at 3000h even if the SMBASE is changed.
16-bit, expand up 16-bit, 00000000h expand up 16-bit, 00000000h expand up 16-bit, 00000000h expand up 16-bit, 00000000h expand up 16-bit, 00000000h expand up check is 4 Gbyte instead of
The following is a summary of the key features in the SMM environment: s Real mode style address calculation s 4-Gbyte limit checking s IF flag is cleared s NMI is disabled s TF flag in EFLAGS is cleared; single step traps are disabled s DR7 is cleared; debug traps are disabled s The RSM instruction no longer generates an invalid op code error s Default 16-bit op code, register, and stack use s All bus arbitration (HOLD, AHOLD, BOFF) inputs and bus sizing (BS8, BS16) inputs operate normally while the CPU is in SMM.
The CS Base can be changed using the SMM Base relocation feature. When the SMI handler is invoked, the CPU’s PE and PG bits in CR0 are reset to 0. The processor is in an environment similar to Real mode, but without the 64-Kbyte limit checking. However, the default operand size and the default address size are set to 16 bits. The EM bit is cleared so that no exceptions are generated. (If the SMM was entered from Protected mode, the Real mode interrupt and exception support is not available.) The SMI handler should not use floatingpoint unit instructions until the FPU is properly detected (within the SMI handler) and the exception support is initialized. Because the segment bases (other than CS) are cleared to 0 and the segment limits are set to 4 Gbyte, the address space may be treated as a single, flat 4-Gbyte linear space that is unsegmented. The CPU is still in Real mode and when a segment selector is loaded with a 16-bit value, that value is then shifted left by 4 bits and loaded into the segment base cache. In SMM, the CPU can access or jump anywhere within the 4-Gbyte logical address space. The CPU can also indirectly access or perform a near jump anywhere within the 4-Gbyte logical address space. Exceptions and Interrupts with System Management Mode When the CPU enters SMM, it disables INTR interrupts, debug, and single-step traps by clearing the EFLAGS, DR6, and DR7 registers. This prevents a debug application from accidentally breaking into an SMI handler.
Executing System Management Mode Handler
The processor begins execution of the SMI handler at offset 8000h in the CS segment. The CS Base is initially 30000h, as shown in Table 5.
28
Am486DE2 Microprocessor
This is necessary because the SMI handler operates from a distinct address space (SMRAM) and the debug trap does not represent the normal system memory space. For an SMI handler to use the debug trap feature of the processor to debug SMI handler code, it must first ensure that an SMM-compliant debug handler is available. The SMI handler must also ensure DR3–DR0 is saved to be restored later. The debug registers DR3–DR0 and DR7 must then be initialized with the appropriate values. For the processor to use the single-step feature of the processor, it must ensure that an SMM-compliant single-step handler is available and then set the trap flag in the EFLAGS register. If the system design requires the processor to respond to hardware INTR requests while in SMM, it must ensure that an SMM-compliant interrupt handler is available, and then set the interrupt flag in the EFLAGS register (using the STI instruction). Software interrupts are not blocked on entry to SMM, and the system software designer must provide an SMM-compliant interrupt handler before attempting to execute any software interrupt instructions. Note that in SMM mode the interrupt vector table has the same properties and location as the Real mode vector table.
NMI interrupts are blocked on entry to the SMI handler. If an NMI request occurs during the SMI handler, it is latched and serviced after the processor exits SMM. Only one NMI request is latched during the SMI handler. If an NMI request is pending when the processor executes the RSM instruction, the NMI is serviced before the next instruction of the interrupted code sequence. Although NMI requests are blocked when the CPU enters SMM, they may be enabled through software by executing an IRET instruction. If the SMI handler requires the use of NMI interrupts, it should invoke a dummy interrupt service routine to execute an IRET instruction. When an IRET instruction is executed, NMI interrupt requests are serviced in the same Real mode manner in which they are handled outside of SMM. SMM Revisions Identifier The 32-bit SMM Revision Identifier specifies the version of SMM and the extensions that are available on the processor. The fields of the SMM Revision Identifiers and bit definitions are shown in Table 6 and Table 7. Bit 17 or 16 indicates whether the feature is supported (1=supported, 0=not supported). The processor always reads the SMM Revision Identifier at the time of a restore. The I/O Trap Extension and SMM Base Relocation bits are fixed. The processor writes these bits out at the time it performs a save state.
Note: Changing the state of the reserved bits may result in unpredictable processor behavior.
Table 6. System Management Mode Revision Identifier
31–18 Reserved 00000000000000 17 SMM Base Relocation 1 16 I/O Trap Extension 1 15–0 SMM Revision Level 0000h
Table 7. SMM Revision Identifier Bit Definitions
Bit Name SMM Base Relocation I/O Trap Extension Description 1=SMM Base Relocation Available 0=SMM Base Relocation Unavailable 1=I/O Trapping Available 0=I/O Trapping Unavailable Default State 1 State at SMM State at Entry SMM Exit 1 0 1 0 1 0 1 0 Notes No Change in State No Change in State No Change in State No Change in State
1
Am486DE2 Microprocessor
29
Auto Halt Restart The Auto Halt Restart slot at register offset (word location) 7F02h in SMRAM indicates to the SMI handler that the SMI interrupted the CPU during a HALT state; bit 0 of slot 7F02h is set to 1 if the previous instruction was a HALT (see Figure 10). If the SMI did not interrupt the CPU in a HALT state, then the SMI microcode sets bit 0 of the Auto Halt Restart slot to 0. If the previous instruction was a HALT, the SMI handler can choose to either set or reset bit 0. If this bit is set to 1, the RSM microcode execution forces the processor to reenter the HALT state. If this bit is set to 0 when the RSM instruction is executed, the processor continues execution with the instruction just after the interrupted HALT instruction. If the HALT instruction is restarted, the CPU will generate a memory access to fetch the HALT instruction (if it is not in the internal cache), and execute a HALT bus cycle.
15 0
Register offset 7F00h
I/O instruction restart slot
Figure 11. I/O Instruction Restart Register Offset
15 Reserved
1
0 Register Offset 7F02h Auto Halt Restart
When the RSM instruction is executed, if the I/O instruction restart slot contains the value 0FFh, then the CPU automatically reexecutes the l/O instruction that the SMI signal trapped. If the I/O instruction restart slot contains the value 00h when the RSM instruction is executed, then the CPU does not reexecute the I/O instruction. The CPU automatically initializes the I/O instruction restart slot to 00h during SMM entry. The I/O instruction restart slot should be written only when the processor has generated an SMI on an I/O instruction boundary. Processor operation is unpredictable when the I/O instruction restart slot is set when the processor is servicing an SMI that originated on a non-I/O instruction boundary. If the system executes back-to-back SMI requests, the second SMI handler must not set the I/O instruction restart slot. The second back-to-back SMI signal will not have the I/O Trap Word set. I/O Trap Word The I/O Trap Word contains the address of the I/O access that forced the external chipset to assert SMI, whether it was a read or write access, and whether the instruction that caused the access to the I/O address was a valid I/O instruction. Table 9 shows the layout.
Figure 10. Auto Halt Restart Register Offset
Table 8 shows the possible restart configurations. If the interrupted instruction was not a HALT instruction (bit 0 is set to 0 in the Auto Halt Restart slot upon SMM entry), setting bit 0 to 1 will cause unpredictable behavior when the RSM instruction is executed.
Table 8. Auto Halt Restart Configuration
Value at Entry 0 0 1 1 Value at Exit 0 1 0 1 Processor Action on Exit Return to next instruction in interrupted program Unpredictable Returns to instruction after HALT Returns to interrupted HALT instruction
Table 9. I/O Trap Word Configuration
31–16 15–2 1 0
I/O Address
Reserved Valid I/O Instruction R/W
Bits 31–16 contain the I/O address that was being accessed at the time SMI became active. Bits 15–2 are reserved. If the instruction that caused the I/O trap to occur was a valid I/O instruction (IN, OUT, INS, OUTS, REP INS, or REP OUTS), the Valid I/O Instruction bit is set. If it was not a valid I/O instruction, the bit is saved as a 0. For REP instructions, the external chip set should return a valid SMI within the first access.
I/O Trap Restart The I/O instruction restart slot (register offset 7F00h in SMRAM) gives the SMI handler the option of causing the RSM instruction to automatically reexecute the interrupted I/O instruction (see Figure 11).
30
Am486DE2 Microprocessor
Bit 0 indicates whether the opcode that was accessing the I/O location was performing either a read (1) or a write (0) operation as indicated by the R/W bit. If an SMI occurs and it does not trap an I/O instruction, the contents of the I/O address and R/W bit are unpredictable and should not be used. SMM Base Relocation The Am486DE2 processor provides a control register not in the standard Am486DX processor: SMBASE. The SMRAM address space can be modified by changing the SMBASE register before exiting an SMI handler routine. SMBASE can be changed to any 32K-aligned value. (Values that are not 32K-aligned cause the CPU to enter the Shutdown state when executing the RSM instruction.) SMBASE is set to the default value of 30000h on RESET. If SMBASE is changed by an SMI handler, all subsequent SMI requests initiate a state save at the new SMBASE. The SMBASE slot in the SMM state-save area indicates and changes the SMI jump-vector location and SMRAMsave area. When bit 17 of the SMM Revision Identifier is set, then this feature exists and the SMRAM base and consequently, the jump vector, are as indicated by the SMM Base slot (see Table 7). During the execution of the RSM instruction, the CPU reads this slot and initializes the CPU to use the new SMBASE during the next SMI. During an SMI, the CPU does its context save to the new SMRAM area pointed to by the SMBASE, stores the current SMBASE in the SMM Base slot (offset 7EF8h), and then starts execution of the new jump vector based on the current SMBASE (see Figure 12).
SMBASE + 8000h + 7FFFh
SMRAM Start of State Save SMI Handler Entry Point SMBASE + 8000h
SMBASE
Figure 13. SRAM Usage
The starting address for the SMRAM state-save area is calculated by:
SMBASE + [8000h + 7FFFh]
When this feature is enabled, the SMRAM register map is addressed according to the above formula. To change the SMRAM base address and SMI jump vector location, the SMI handler modifies the SMBASE slot. Upon executing an RSM instruction, the processor reads the SMBASE slot and stores it internally. Upon recognition of the next SMI request, the processor uses the new SMBASE slot for the SMRAM dump and SMI jump vector. If the modified SMBASE slot does not contain a 32-Kbyte aligned value, the RSM microcode causes the CPU to enter the Shutdown state.
SMM System Design Considerations
SMRAM Interface The hardware designed to control the SMRAM space must follow these guidelines:
31
0 Register Offset 7EF8h
SMM Base
Figure 12. SMM Base Slot Offset
s Initialize SMRAM space during system boot up. Initialization must occur before the first SMI occurs. Initialization of SMRAM space must include installation of an SMI handler and may include installation of related data structures necessary for particular SMM applications. The memory controller interfacing SMRAM should provide a means for the initialization code to open the SMRAM space manually. s The memory controller must decode a minimum initial SMRAM address space of 38000h–3FFFFh. s Alternate bus masters (such as DMA controllers) must not be able to access SMRAM space. The system should allow only the CPU, either through SMI or during initialization, to access SMRAM.
The SMBASE must be a 32-Kbyte aligned, 32-bit integer that indicates a base address for the SMRAM context save area and the SMI jump vector. For example, when the processor first powers up, the minimum SMRAM area is from 38000h–3FFFFh. The default SMBASE is 30000h. As illustrated in Figure 13, the starting address of the jump vector is calculated by:
SMBASE + 8000h
Am486DE2 Microprocessor
31
s To implement a 0-V suspend function, the system must have access to all normal system memory from within an SMI handler routine. If the SMRAM overlays normal system memory (see Figure 14), there must be a method to access overlaid system memory independently.
SMRAM
Normal memory
another overlaid address range. However, in this case the system control circuitry must use SMIACT to distinguish between SMRAM and main system memory, and must restrict SMRAM space access to the CPU only. To maintain cache coherency and to ensure proper system operation in systems configured in Write-through mode, the system must flush both the CPU internal cache and any second-level caches in response to SMIACT going Low. A system that uses cache during SMM must flush the cache a second time in response to SMIACT going High (see Figure 16). If KEN is driven High when FLUSH is asserted, the cache is disabled and a second flush is not required (see Figure 17). Cache Flushes The CPU does not unconditionally flush its cache before entering SMM. Therefore, the designer must ensure that, for systems using overlaid SMRAM, the cache is flushed upon SMM entry, and SMM exit if caching is enabled. If the flush at SMM entry is not done, the first SMM read could hit in a cache that contains normal memory space code/data instead of the required SMI handler and the handler could not be executed. If the cache is not disabled and cache is not flushed at SMM exit, the normal read cycles after SMM may hit in a cache that may contain SMM code/data instead of the normal system memory contents. In Write-through mode, assert the FLUSH signal in response to the assertion of SMIACT at SMM entry, and if required because the cache is enabled, assert FLUSH again in response to the deassertion of SMIACT at SMM exit (see Figure 16 and Figure 17). Reloading the state registers at the end of SMM restores cache functionality to its pre-SMM state.
SMRAM
Normal memory Overlaid region
Normal memory
Non-overlaid (no need to flush caches)
Overlaid (caches must be flushed)
Figure 14. SMRAM Location
The recommended configuration is to use a separate (nonoverlaid) physical address for SMRAM. This nonoverlaid scheme prevents the CPU from improperly accessing the SMRAM or system RAM directly or through the cache. Figure 15 shows the relative SMM timing for nonoverlaid SMRAM for systems configured in Writethrough mode. When the default SMRAM location is used, however, SMRAM is overlaid with system main memory (at 38000h–3FFFFh). For simplicity, system designers may want to use this default address, or they may select
State Save
SMI Handler
State Resume
Normal Cycle
SMI
RSM
SMIACT
Figure 15. SMM Timing in Systems Using Non-Overlaid Memory Space and Write-Through Mode with Caching Enabled During SMM
32
Am486DE2 Microprocessor
SMI State Save State Resume
Instruction x+1 Normal Cycle
Instruction x
SMI Handler
SMI
RSM
SMIACT
FLUSH
Cache contents invalidated
Cache contents invalidated
Figure 16. SMM Timing in Systems Using Overlaid Memory Space and Write-Through Mode with Caching Enabled During SMM
SMI Instruction x+1 State Save State Resume Normal Cycle
Instruction x
SMI Handler
SMI
RSM
SMIACT
FLUSH KEN
Cache contents invalidated
Figure 17. SMM Timing in Systems Using Overlaid Memory Space and Write-Through Mode with Caching Disabled During SMM
A20M Pin Systems based on the MS-DOS operating system contain a feature that enables the CPU address bit A20 to be forced to 0. This limits physical memory to a maximum of 1 Mbyte, and is provided to ensure compatibility with those programs that relied on the physical address wraparound functionality of the original IBM PC. The A20M pin on Am486DE2 CPUs provides this function. When A20M is active, all external bus cycles drive A20 Low, and all internal cache accesses are performed with A20 Low.
The A20M pin is recognized while the CPU is in SMM. The functionality of the A20M input must be recognized in two instances: 1. If the SMI handler needs to access system memory space above 1 Mbyte (for example, when saving memory to disk for a zero-volt suspend), the A20M pin must be deasserted before the memory above 1 Mbyte is addressed. 2. If SMRAM has been relocated to address space above 1 Mbyte and A20M is active upon entering SMM, the CPU attempts to access SMRAM at the relocated address, but with A20 Low. This could cause the system to crash, because there would be no valid SMM interrupt handler at the accessed location.
Am486DE2 Microprocessor
33
To account for these two situations, the system designer must ensure that A20M is deasserted on entry to SMM. A20M must be driven inactive before the first cycle of the SMM state save, and must be returned to its original level after the last cycle of the SMM state restore. This can be done by blocking the assertion of A20M when SMIACT is active. CPU Reset During SMM The system designer should take into account the following restrictions while implementing the CPU Reset logic: s When running software written for the 80286 CPU, a CPU RESET switches the CPU from Protected mode to Real mode. RESET and SRESET have a higher priority than SMI. When the CPU is in SMM, the SRESET to the CPU during SMM should be blocked until the CPU exits SMM. SRESET must be blocked beginning from the time when SMI is driven active. Care should be taken not to block the global system RESET, which may be necessary to recover from a system crash. s During execution of the RSM instruction to exit SMM, there is a small time window between the deassertion of SMIACT and the completion of the RSM microcode. If a Protected mode to Real mode SRESET is asserted during this window, it is possible that the SMRAM space will be violated. The system designer must guarantee that SRESET is blocked until at least 20 CPU clock cycles after SMIACT has been driven inactive or until the start of a bus cycle. s Any request for a CPU RESET for the purpose of switching the CPU from Protected mode to Real mode must be acknowledged after the CPU has exited SMM. To maintain software transparency, the system logic must latch any SRESET signals that are blocked during SMM. For these reasons, the SRESET signal should be used for any soft resets, and the RESET signal should be used for all hard resets. SMM and Second-Level Write Buffers Before the processor enters SMM, it empties its internal write buffers. This is to ensure that the data in the write buffers is written to normal memory space, not SMM space. When the CPU is ready to begin writing an SMM state save to SMRAM, it asserts SMIACT. SMIACT may be driven active by the CPU before the system memory controller has had an opportunity to empty the secondlevel write buffers.
To prevent the data from these second-level write buffers from being written to the wrong location, the system memory controller needs to direct the memory write cycles to either SMM space or normal memory space. This can be accomplished by saving the status of SMIACT with the address for each word in the write buffers. Nested SMI and I/O Restart Special care must be taken when executing an SMI handler for the purpose of restarting an l/O instruction. When the CPU executes a Resume (RSM) instruction with the l/O restart slot set, the restored EIP is modified to point to the instruction immediately preceding the SMI request, so that the l/O instruction can be reexecuted. If a new SMI request is received while the CPU is executing an SMI handler, the CPU services this SMI request before restarting the original I/O instruction. If the I/O restart slot is set when the CPU executes the RSM instruction for the second SMI handler, the RSM microcode decrements the restored EIP again. EIP then points to an address different from the originally interrupted instruction, and the CPU begins execution at an incorrect entry point. To prevent this from occurring, the SMI handler routine must not set the I/O restart slot during the second of two consecutive SMI handlers.
SMM Software Considerations
SMM Code Considerations The default operand size and the default address size are 16 bits; however, operand-size override and address-size override prefixes can be used as needed to directly access data anywhere within the 4-Gbyte logical address space. With operand-size override prefixes, the SMI handler can use jumps, calls and returns to transfer a control to any location within the 4-Gbyte space. Note, however, the following restrictions: s Any control transfer that does not have an operandsize override prefix truncates EIP to 16 Low-order bits. s Due to the Real mode style of base-address formation, a long jump or call cannot transfer control segment with a base address of more than 20 bits (1 Mbyte). Exception Handling Upon entry into SMM, external interrupts that require handlers are disabled (the IF in EFLAGS is cleared). This is necessary because, while the processor is in SMM, it is running in a separate memory space. Consequently, the vectors stored in the interrupt descriptor table (IDT) for the prior mode are not applicable. Before allowing exception handling (or software interrupts), the SMM program must initialize new interrupt and excep-
34
Am486DE2 Microprocessor
tion vectors. The interrupt vector table for SMM has the same format as for Real mode. Until the interrupt vector table is correctly initialized, the SMI handler must not generate an exception (or software interrupt). Even though hardware interrupts are disabled, exceptions and software interrupts can still occur. Only a correctly written SMI handler can prevent internal exceptions. When new exception vectors are initialized, internal exceptions can be serviced. The restrictions follow: s Due to the Real mode style of base address formation, an interrupt or exception cannot transfer control to a segment with a base address of more than 20 bits. s An interrupt or exception cannot transfer control to a segment offset of more than 16 bits. s If exceptions or interrupts are allowed to occur, only the Low order 16 bits of the return address are pushed onto the stack. If the offset of the interrupted procedure is greater than 64 Kbytes, it is not possible for the interrupt/exception handler to return control to that procedure. (One workaround is to perform software adjustment of the return address on the stack.) s The SMBASE Relocation feature affects the way the CPU returns from an interrupt or exception during an SMI handler.
HALT during SMM HALT should not be executed during SMM, unless interrupts have been enabled. Interrupts are disabled on entry to SMM. INTR and NMI are the only events that take the CPU out of HALT within SMM. Relocating SMRAM to an Address above 1 Mbyte Within SMM (or Real mode), the segment base registers can be updated only by changing the segment register. The segment registers contain only 16 bits, which allows only 20 bits to be used for a segment base address (the segment register is shifted left 4 bits to determine the segment base address). If SMRAM is relocated to an address above 1 Mbyte, the segment registers can no longer be initialized to point to SMRAM. These areas can still be accessed by using address override prefixes to generate an offset to the correct address. For example, if the SMBASE has been relocated immediately below 16M, the DS and ES registers are still initialized to 0000 0000h. Data in SMRAM can still be accessed by using 32-bit displacement registers:
move esi,OOFFxxxxh;64K segment immediately below 16M move ax,ds:[esi]
Note: The execution of an IRET instruction enables Non-Maskable Interrupt (NMI) processing.
Am486DE2 Microprocessor
35
TEST REGISTERS 4 AND 5 MODIFICATIONS
The Cache Test Registers for the Am486DE2 microprocessor are the same test registers (TR3, TR4, and TR5) provided in earlier Am486DX and DX2 microprocessors. TR3 is the cache test data register. TR4, the cache test status register, and TR5, the cache test control register, operate together with TR3. When WB/WT meets the necessary setup timing and is sampled Low on the falling edge of RESET, the processor is placed in Write-through mode and the test register function is identical to the earlier Am486 microprocessors. Table 10 and Table 11 show the individual bit functions of these registers. “TR4 Definition” on page 36 and “TR5 Definition” on page 36 provide a detailed description of the field functions.
Table 10. Test Register (TR4)
31
EXT = 0
30–29
28
27–26
25–24
23–22 Tag
21–20
19
18
17
16
15– 11
10 Valid
9–7 LRU
6–3 Valid (rd)
2–0 Not used
Table 11. Test Register (TR5)
31–20 Write-Through 19 18–17 Not used 16 15–11 10–4 Index 3–2 Entry 1–0 Control
TR4 Definition
This section includes a detailed description of the bit fields defined for TR4.
TR5 Definition
This section includes a detailed description of the bit fields in TR5.
Note: Bits listed in Table 10 as Not used are not included in these descriptions.
s Tag (bits 31–11): Read/Write, always available in Write-through mode. For a cache write, this is the tag that specifies the address in memory. On a cache lookup, this is the tag for the selected entry in the cache. s Valid (bit 10): Read/Write. This is the Valid bit for the accessed entry. On a cache look-up, Valid is a copy of one of the bits reported in bits 6–3. On a cachewrite in Write-through mode, Valid becomes the new valid bit for the selected entry and set. s LRU (bits 9–7): Read Only, independent of the Ext bit in TR5. On a cache look-up, these are the three LRU bits of the accessed set. On a cache write, these bits are ignored; the LRU bits in the cache are updated by the pseudo-LRU cache replacement algorithm. Write operations to these locations have no effect on the device. s Valid (bits 6–3): Read Only. On a cache look-up, these are the four Valid bits of the accessed set. Write operations to these locations have no effect on the device.
Note: Bits listed in Table 11 as Not used are not included in the descriptions.
s Index (bits 10–4): Read/Write. Index selects one of the 128 sets. s Entry (bits 3–2): Read/Write. Entry selects between one of the four entries in the set addressed by the Set Select during a cache read or write. During cache-fill buffer writes or cache-read buffer reads, the value in the Entry field selects one of the four doublewords in a cache line. s Control (bits 1–0): Read/Write. The control bits determine which operation is to be performed. The following is a definition of the control operations: — 00 = Write to cache fill buffer, or read from cache read buffer. — 01 = Perform cache write. — 10 = Perform cache read. — 11 = Flush the cache (mark all entries invalid)
36
Am486DE2 Microprocessor
Am486DE2 MICROPROCESSOR FUNCTIONAL DIFFERENCES
The Am486DE2 microprocessor is a new member of the AMD Am486 family, which also includes the Enhanced Am486 and the Am486DX microprocessors. Although the Am486DE2 is based on and compatible with the Enhanced Am486 microprocessors, it has no support for write-back cache. Several important differences exist between the Am486DE2 and the Am486DX processors: s The Am486DE2 ID register contains a different version signature than the Am486DX. It has the same ID register as the Enhanced Am486DX2 in Write-through mode. s A burst write feature is available for copy-backs. The FLUSH pin and WBINVD instruction copy-back all modified data to external memory prior to issuing the special bus cycle or reset. s The RESET state is invoked either after power up or after the RESET signal is applied according to the standard Am486DX microprocessor specification. s After reset, the STATUS bits of all lines are set to 0. The LRU bits of each set are placed in a starting state. In addition, the differences in the processors are highlighted in Table 12.
Table 12. Am486DE2 Microprocessor Functional Differences
Processor Am486DX2-66 Enhanced Am486DX2-66 Am486DE2-66 Cache 8 Kbyte, Write-through 8-Kbyte, Write-through/ Write-back 8-Kbyte, Write-through Clock 1x, 2x 2x, 3x SMI, write-back Major Enhancements Package 168-Pin PGA 168-Pin PGA
2x
SMI
168-Pin PGA, 208-Lead SQFP
Am486DE2 MICROPROCESSOR IDENTIFICATION The Am486DE2 microprocessor supports two standard CPUID Instruction
methods for identifying the CPU in a system. The reported values are dynamically assigned based on the CPU type and the status of the WB/WT pin input at RESET. The Am486DE2 implements a new instruction that makes information available to software about the family, model, and stepping of the microprocessor on which it is executing. Support of this instruction is indicated by the presence of a user-modifiable bit in position EFLAGS.21, referred to as the EFLAGS.ID bit. This bit is reset to zero at device reset (RESET or SRESET) for compatibility with existing processor designs. CPUID Timing Table 13. CPU ID Codes
CPU Type and Cache Mode DE2 in Write-through mode Component Revision ID (DH) ID (DL) 04 3x
DX Register at RESET
The DX register always contains a component identifier at the conclusion of RESET. The upper byte of DX (DH) contains 04 and the lower byte of DX (DL) contains a CPU type/stepping identifier (see Table 13).
CPUID execution timing depends on the selected EAX parameter values (see Table 14).
Am486DE2 Microprocessor
37
Table 14. CPUID Instruction Description
EAX OP Input Code Instruction Value 0 1 0F A2 CPUID >1 CPU Core Clocks 41 14 9
When the parameter passed in EAX is 1, the register values returned are: EAX[3:0] EAX[7:4] Stepping ID* Model: Am486DE2CPU— Write-through mode = 3h Family Am486 CPU = 4h 0000 RESERVED 00000000h 00000000h 00000001h = all versions The 1 in bit 0 indicates that the FPU is present
Description AMD string CPU ID Register null registers
EAX[11:8] EAX[15:12] EAX[31:16] EBX[31:0] ECX[31:0] EDX[31:0]
CPUID Operation The CPUID instruction requires the user to pass an input parameter to the CPU in the EAX register. The CPU response is returned to the user in registers EAX, EBX, ECX, and EDX. When the parameter passed in EAX is zero, the register values returned upon instruction execution are: 00000001h EAX[31:0] 68747541h EBX[31:0] 444D4163h ECX[31:0] 69746E65h EDX[31:0] The values in EBX, ECX, and EDX indicate an AMD microprocessor. When taken in the proper order: s EBX (least significant bit to most significant bit) s EDX (least significant bit to most significant bit) s ECD (least significant bit to most significant bit) they decode to:
‘AuthenticAMD’
Note: *Please contact AMD for stepping ID details.
The value returned in EAX after CPUID instruction execution is identical to the value loaded into EDX upon device reset. Software must avoid any dependency upon the state of reserved processor bits. When the parameter passed in EAX is greater than one, register values returned upon instruction execution are: EAX[31:0] EBX[31:0] ECX[31:0] EDX[31:0] 00000000h 00000000h 00000000h 00000000h
Flags affected: No flags are affected. Exceptions: None
38
Am486DE2 Microprocessor
ELECTRICAL DATA
The following sections describe recommended electrical connections for the Am486DE2 microprocessor, and electrical specifications. the system motherboard. For socket compatibility, this pin is INC (Internal No Connect), allowing the Am486DE2 CPU to operate in 3-V sockets in systems that use 5-V I/O.
Power Connections
The Am486DE2 microprocessor has modest power requirements. However, the high clock-frequency output buffers can cause power surges as multiple output buffers drive new signal levels simultaneously. For clean, on-chip power distribution at high frequency, 23 VCC pins and 28 VSS pins feed the microprocessor in the 168-pin PGA package. The 208-lead SQFP package includes 53 VCC pins and 38 VSS pins. Power and ground connections must be made to all external VCC and VSS pins of the microprocessors. On a circuit board, all VCC pins must connect to a VCC plane. Likewise, all VSS pins must connect to a common GND plane. The Am486DE2 microprocessor requires only 3.3 V as input power. Unlike other 3-V 486 processors, the Am486DE2 microprocessor does not require a VCC5 input of 5 V to indicate the presence of 5-V I/O devices on
Power Decoupling Recommendations
Liberal decoupling capacitance should be placed near the microprocessor. The microprocessor, driving its 32bit parallel address and data buses at high frequencies, can cause transient power surges, particularly when driving large capacitive loads. Low-inductance capacitors and interconnects are recommended for best high-frequency electrical performance. Inductance can be reduced by shortening circuit board traces between the microprocessor and the decoupling capacitors. Capacitors designed specifically for use with PGA packages are commercially available.
Other Connection Recommendations
For reliable operation, always connect unused inputs to an appropriate signal level. Active Low inputs should be connected to VCC through a pull-up resistor. Pull-ups in the range of 20 kΩ are recommended. Active High inputs should be connected to GND.
Am486DE2 Microprocessor
39
ABSOLUTE MAXIMUM RATINGS
Case Temperature under Bias. . . . . – 65°C to +110°C Storage Temperature . . . . . . . . . . . – 65°C to +150°C Voltage on any pin with respect to ground . . . . . . – 0.5 V to Vcc +2.6 V Supply voltage with respect to VSS . . . . . . . . . . . . . . . . – 0.5 V to +4.6 V
Stresses above those listed under Absolute Maximum Ratings may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to Absolute Maximum Ratings for extended periods may affect device reliability.
OPERATING RANGES
Commercial (C) Devices TCASE . . . . . . . . . . . . . . . . . . . . . . . . . . . . 0°C to 85°C VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3.3 V ± 0.3 V
Operating Ranges define those limits between which the functionality of the device is guaranteed.
DC CHARACTERISTICS OVER COMMERCIAL OPERATING RANGES
VCC = 3.3 V ± 0.3 V; TCASE = 0°C to + 85°C
Symbol VIL VIH VOL VOH ICC Input Current in Stop Grant or ICCSTOPGRANT Auto Halt mode: or ICCAUTOHALT 66 MHz Input Current in Stop Clock mode Input Leakage Current Input Leakage Current Input Leakage Current Output Leakage Current Input Capacitance I/O or Output Capacitance CLK Capacitance 66 mA Parameter Input Low Voltage Input High Voltage Output Low Voltage Output High Voltage Power Supply Current: 66 MHz 2.4 V 660 mA Min – 0.3 V 2.0 V Max +0.8 V VCC + 2.4 V 0.45 V Note 1 Note 2 Typical supply current: 528 mA @ 66 MHz Inputs at rails, outputs unloaded. Typical supply current for Stop Grant or Auto Halt mode: 20 mA @ 66 MHz and 75 MHz, 30 mA @ 80 MHz, 50 mA @ 100 MHz, and 60 mA @ 120 MHz. Typical supply current in Stop Clock mode is 600 µA. Note 3 Note 4 Note 5 Notes
ICCSTPCLK ILI IIH IIL ILO CIN CO CCLK
5 mA ± 15 µA 200 µA – 400 µA ± 15 µA 10 pF 14 pF 12 pF
FC = 1 MHz (Note 6) FC = 1 MHz (Note 6) FC = 1 MHz (Note 6)
Notes: 1. This parameter is measured at: Address, Data, BEn = 4.0 mA; Definition, Control = 5.0 mA 2. This parameter is measured at: Address, Data, BEn = - 1.0 mA; Definition, Control = - 0.9 mA 3. This parameter is for inputs without internal pull-ups or pull-downs and 0 ≤ VIN ≤ VCC. 4. This parameter is for inputs with internal pull-downs and VIH = 2.4 V. 5. This parameter is for inputs with internal pull-ups and VIL = 0.45 V. 6. Not 100% tested.
40
Am486DE2 Microprocessor
SWITCHING CHARACTERISTICS OVER COMMERCIAL OPERATING RANGES
The AC specifications, provided in the AC characteristics table, consist of output delays, input setup requirements, and input hold requirements. All AC specifications are relative to the rising edge of the CLK signal. AC specifications measurement is defined by Figure 36. All timings are referenced to 1.5 V unless otherwise specified. Am486DE2 microprocessor output delays are specified with minimum and maximum limits, measured as shown. The minimum microprocessor delay times are hold times provided to external circuitry. Input setup and hold times are specified as minimums, defining the smallest acceptable sampling window. Within the sampling window, a synchronous input signal must be stable for correct microprocessor operation.
Am486DE2 Microprocessor
41
Switching Characteristics for 33-MHz Bus (66-MHz Microprocessor)
VCC = 3.3 V ±0.3 V; TCASE = 0°C to + 85°C; CL = 50 pF unless otherwise specified1
Symbol Frequency t1 t1a t2 t3 t4 t5 t6 t7 t8 t8a t9 t10 t11 t12 t13 t14 t15 t16 t17 t18 t18a t19 t20 t21 t22 t23 CLK Period CLK Period Stability CLK High Time at 2 V CLK Low Time at 0.8 V CLK Fall Time (2 V–0.8 V) CLK Rise Time (0.8 V–2 V) A31–A2, PWT, PCD, BE3–BE0, M/IO, D/C, CACHE, W/R, ADS, LOCK, FERR, BREQ, HLDA, SMIACT, HITM Valid Delay A31–A2, PWT, PCD, BE3–BE0, M/IO, D/C, CACHE, W/R, ADS, LOCK Float Delay PCHK Valid Delay BLAST, PLOCK, Valid Delay BLAST, PLOCK, Float Delay D31–D0, DP3–DP0 Write Data Valid Delay D31–D0, DP3–DP0 Write Data Float Delay EADS, INV, WB/WT Setup Time EADS, INV, WB/WT Hold Time KEN, BS16, BS8 Setup Time KEN, BS16, BS8 Hold Time RDY, BRDY Setup Time RDY, BRDY Hold Time HOLD, AHOLD Setup Time BOFF Setup Time HOLD, AHOLD, BOFF Hold Time RESET, FLUSH, A20M, NMI, INTR, IGNNE, STPCLK, SRESET, SMI Setup Time RESET, FLUSH, A20M, NMI, INTR, IGNNE, STPCLK, SRESET, SMI Hold Time D31–D0, DP3–DP0, A31–A4 Read Setup Time 3 3 3 3 3 3 3 5 3 5 3 5 3 6 7 3 5 3 5 11 11 3 3 Parameter Min 8 30 Max 33 125 0.1% Unit MHz ns ∆ ns ns ns ns 39 39 39 39 Figure 39 Adjacent Clocks Notes 3 and 4 Note 3 Note 3 Note 3 Note 3 Note 5 14 20 14 14 20 14 20 ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns 40 41 42 40 41 40 41 43 43 43 43 44 44 43 43 43 43 43 43, 44 Note 5 Note 5 Note 3 Note 3 Note 3 Notes Note 2
Notes:
3 ns 43, 44 D32–D0, DP3–DP0, A31–A4 Read Hold Time 1. Specifications assume CL = 50 pF. I/O Buffer model must be used to determine delays due to loading (trace and component). First-order I/O buffer models for the processor are available. 2. 0-MHz operation guaranteed during stop clock operation or 1x Static Clock mode. 3. Not 100% tested. Guaranteed by design characterization. 4. For faster transitions (>0.1% between adjacent clocks), use the Stop Clock protocol to switch operating frequency. 5. All timings are referenced at 1.5 V (as illustrated in the listed figures) unless otherwise noted.
42
Am486DE2 Microprocessor
Switching Waveforms
Key to Switching Waveforms Waveform Inputs Must be steady May change from H to L May change from L to H Don’t care; any change permitted Does not apply Outputs Will be steady Will change from H to L Will change from L to H Changing; state unknown Center line is High-impedance “Off” state
Figure 18. CLK Waveforms
Am486DE2 Microprocessor
43
Figure 19. Output Valid Delay Timing
Figure 20. Maximum Float Delay Timing
44
Am486DE2 Microprocessor
Figure 21. PCHK Valid Delay Timing
Am486DE2 Microprocessor
45
Figure 22. Input Setup and Hold Timing
46
Am486DE2 Microprocessor
Figure 23. RDY and BRDY Input Setup and Hold Timing
Figure 24. TCK Waveforms
Am486DE2 Microprocessor
47
Figure 25. Test Signal Timing Diagram
PACKAGE THERMAL SPECIFICATIONS
The Am486 microprocessor is specified for operation when TCASE (the case temperature) is within the range of 0°C to +85°C. TCASE can be measured in any environment to determine whether the Am486DE2 microprocessor is within the specified operating range. The case temperature should be measured at the center of the top surface opposite the pins. The ambient temperature (TA) is guaranteed as long as TCASE is not violated. The ambient temperature can be calculated from θJC and θJA and from the following equations:
TJ = TCASE + P ⋅ θJC TA = TJ – P ⋅ θJA TCASE = TA + P ⋅ [θJA – θJC]
TJ, TA, TCASE = Junction, Ambient, and Case Temperature. θJC, θJA = Junction-to-Case and Junction-to-Ambient Thermal Resistance, respectively P = Maximum Power Consumption The values for θJA and θJC are given in Table 15 for the 1.75 sq. in., 168-pin, ceramic PGA. For the 208-lead SQFP plastic package, θJA = 14.0 and θJC = 1.5. Table 16 shows the TA allowable (without exceeding TCASE) at various airflows and operating frequencies (Clock). Note that TA is greatly improved by attaching fins or a heat sink to the package. Heat sink dimensions are shown in Figure 47. P (the maximum power consumption) is calculated by using the maximum ICC at 3.3 V as tabulated in the DC Characteristics.
where:
48
Am486DE2 Microprocessor
Table 15. Thermal Resistance (°C/W) θJC and θJA for the Am486DE2 in 168-Pin PGA Package
Cooling Mechanism No Heat Sink Heat Sink* Heat Sink* and fan θJA vs. Airflow-ft/min. (m/sec) θJC 1.5 2.0 2.0 0 (0) 16.5 12.0 5.0 200 (1.01) 14.0 7.0 4.6 400 (2.03) 12.0 5.0 4.2 600 (3.04) 10.5 4.0 3.8 800 (4.06) 9.5 3.5 3.5 1000 (5.07) 9.0 3.25 3.25
*0.350″ high unidirectional heat sink (Al alloy 6063-T5, 40 mil fin width, 155 mil center-to-center fin spacing).
0.040″
0.115″
0.290″ 0.060″ 0.350″ 0.100″ 1.53″
17852B-113
Figure 26. . Heat Sink Dimensions
Table 16. Maximum TA at Various Airflows in °C TA by Cooling Type
TA without Heat Sink TA with Heat Sink TA with Heat Sink and fan
Clock
66 MHz 66 MHz 66 MHz
Airflow-ft/min. (m/sec) 200 400 0 (0) (1.01) (2.03)
49.0 61.0 77.8 55.0 73.0 78.8 59.8 77.8 79.7
600 (3.04)
63.4 80.2 80.7
800 (4.06)
65.8 81.4 81.4
1000 (5.07)
67.0 82.0 82.0
Am486DE2 Microprocessor
49
PHYSICAL DIMENSIONS 168-Pin PGA
Ceramic Pin Grid Array, CGM 168
Index Corner
1.735 1.765 1.595 1.605
Base Plane Seating Plane
1.595 1.605
0.017 0.020
1.735 1.765
0.090 0.110
0.105 0.125 0.140 0.180 0.110 0.140
Bottom View (Pins Facing Up)
0.025 0.045
Side View
Notes: 1. All measurements are in inches. 2. Not to scale. For reference only. 3. BSC is an ANSI standard for Basic Space Centering.
50
Am486DE2 Microprocessor
208-Lead SQFP
Shrink Quad Flat Pack, PDE 208
6 3 Pin 208
30.40 30.80 27.90 28.10 25.50 REF 18.00 Pin 156
Pin 1 Pin One I.D.
25.50 REF 3.0 R Ref. Typ. –A– 18.00 –B– 3 27.90 28.10 30.40 30.80 6
Pin 52
–D–
Pin 104
3.25 3.45
0.50 Basic S 4.00 2 –A– –C– Seating Plane
0.25 0.42
S See Detail H
Am486DE2 Microprocessor
51
0.40 Min. Flat Shoulder 12~ 16° 0° Min. 0.20± 0.10 4.00
Gage Plane
0.25 12~ 16° 0.50 0.75 1.30 Nom. Detail H 0°-7° 10 0.17 0.27 4
11 0.08
0.17 0.27
0.10 0.20
Section S-S
Notes: 1. All dimensions and tolerances conform to ANSI Y14.5M-1982. 2. DATUM Plane -A- is located at the mold parting line, and is coincedent with the bottom of the lead where the lead exits the plastic body. 3. Dimensions “D1" and ”E1" do not include mold protrusions. Allowable protrusion is 0.25mm per side. Dimensions “D1" and ”E1" include mold mismatch, and are determined at DATUM plane -A-. 4. Dimension “b” does not include DAMBAR protrusion. 5. Controlling dimensions: Millimeter. 6. Dimensions “D” and “E” are measured from outermost points. 7. Pin No. 1 ID may be inside top ejector mark, or separate. 8. Heatsink centerline to be aligned with package centerline ±0.30. 9. Half span (Center of package to lead tip) shall be 15.30±0.165[0.602"±0.0065"] 10. No lead distortion (bent leads etc...) shall cause deviation from true position greater than ±0.04[0.0016"] at “b max”. 11. Lead coplanarity with respect to the seating plane shall not exeed 0.08[0.0031"].
AMD, the AMD logo, and combinations thereof are trademarks of Advanced Micro Devices, Inc. Am386, and Am486 are registered trademarks of Advanced Micro Devices, Inc. FusionE86 is a service mark of Advanced Micro Devices, Inc. Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.
52
Am486DE2 Microprocessor