# Am486® DXL # High-Performance, 32-Bit Microprocessor with Integrated Power Management ## **DISTINCTIVE CHARACTERISTICS** - Operating voltage range 5.0 V ± 5% - 40-MHz operating frequencies - Wide range of chipsets and support available through the AMD<sup>®</sup> FusionPC<sup>SM</sup> Program ## ■ High Integration On-Chip - 8-Kbyte code and data cache - Floating-point unit - Paged, virtual memory management ## **■** High-performance Design - Frequent instructions execute in one clock - 128-Million bytes/second burst bus at 40 MHz - 0.7-micron CMOS process technology - Dynamic bus sizing for 8-, 16-, and 32-bit buses ## ■ Complete 32-bit Architecture - Address and data buses - All registers - 8-, 16-, and 32-bit data types - Standard 168-Pin PGA Package ## Multiprocessor Support - Multiprocessor instructions - Cache consistency protocols - Support for second-level cache # System Management Mode (SMM) for system and power management - System Management Interrupt (SMI) for power management independent of processor operating mode and operating system - SMI is a non-maskable interrupt that has higher priority than NMI. - Automatic save and restore of microprocessor state - Wide range of chipsets supporting SMM available to allow product differentiation # Environmental Protection Agency's 'Energy Star' program compliant - Energy management capability provides excellent base for energy-efficient design - Works with a variety of energy-efficient power management devices #### **GENERAL DESCRIPTION** The Am486DXL microprocessor is an implementation of the 486DX with integrated SMM power management. The operating voltage range is $5.0~V\pm5\%$ . The price/performance of the full 32-bit processor and floating-point unit provides the best value for designing high-volume, mainstream 486 low-powered desktop PCs. The Am486DXL CPU operates with a 1X clock input. This 1X clock simplifies system design by cutting in half the clock frequency required by external devices. The 1X clock also reduces RF emission and simplifies clock generation. The phases of the core clock are provided by an internal Phase Lock Loop (PLL) circuit. SMM is provided as a mechanism to interrupt the microprocessor operation and resume the interrupted operation transparent to the operating system or application running on the system. The Am486DXL microprocessor supports the Microsoft® Advanced Power Management specification for new "power managed" applications. ## **BLOCK DIAGRAM** #### Am486DXL Microprocessor Pipelined 32-bit Microarchitecture 10344D-001 ## CONNECTION DIAGRAMS Am486DXL CPU Pin Side View ## 168-Pin PGA (Pin Grid Array) Package | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | _ | |-----|-----------------|-----------------|----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|---------------------|-----------------|-----------------|---------------------|-----------|---------------------|-----------------|---| | s | A27 | A26 | A23 | NC<br>O | A14<br>O | V <sub>ss</sub> | A12<br>O | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | A10<br><b>O</b> | V <sub>ss</sub> | A6<br>O | A4<br>O | ADS<br>O | s | | R | A28 | A25<br>O | V <sub>∞</sub><br>O | V <sub>ss</sub> | A18<br>O | V <sub>cc</sub> | A15<br>O | V <sub>cc</sub> | v∞<br>O | V <sub>cc</sub> | v∞<br>O | A11<br>O | A8<br>O | v <sub>∞</sub><br>O | A3 Ē | O | SMIADS | R | | Q | A31 | V <sub>ss</sub> | A17<br>O | A19 | A21<br>O | A24<br>O | A22 | A20<br>O | A16 | A13<br>O | A9<br><b>O</b> | A5<br><b>O</b> | A7<br>O | A2<br>O | BREQ | PLOCK | PCHK<br>O | a | | Р | 00 | A29 | A30 | | | | | | | | | | | | HLDA<br>O | V <sub>cc</sub> | V <sub>ss</sub> | Р | | N | O <sup>2</sup> | O<br>O | OP0 | | | | | | | | | | | | LOCK | M/IŌ | W/R | N | | М | V <sub>ss</sub> | v <sub>cc</sub> | O <sup>4</sup> | | | | | | | | | | | | D/C<br>O | v <sub>∞</sub> | V <sub>ss</sub> | м | | L | V <sub>ss</sub> | O<br>D6 | O<br>O | | | | | | | | | | | | PWT | v <sub>∞</sub><br>O | V <sub>ss</sub> | L | | к | V <sub>ss</sub> | V <sub>ss</sub> | O<br>O | | | | | | | | | | | | BEO | V <sub>cc</sub> | V <sub>ss</sub> | ĸ | | j | V <sub>cc</sub> | O <sub>5</sub> | D16 | | | | | | | | | | | | BE2 | BE1 | PCD | J | | н | V <sub>ss</sub> | O<br>D3 | OP2 | | | | | | | | | | | | BRDY | v <sub>∞</sub> | v <sub>ss</sub> | Н | | G | V <sub>ss</sub> | v | O12 | | | | | | | | | | | | SMIRDY | 7 V∞<br><b>O</b> | V <sub>ss</sub> | G | | F | OP1 | D8<br>O | D15 | | | | | | | | | | | | KEN<br>O | RDY<br>O | BE3 | F | | Е | V <sub>ss</sub> | V <sub>cc</sub> | D10 | | | | | | | | | | | | HOLD | V <sub>∞</sub> | V <sub>ss</sub> | Ε | | D | D9<br>O | D13 | D17 | | | | | | | | | | | | A20M | BS8<br>O | BOFF | D | | С | D11 | D18 | OLK<br>O | V <sub>∞</sub> | v <sub>∞</sub> | D27 | D26 | D28 | D30 | NC<br>O | NC<br>O | NC<br>O | O<br>NC | 0 | O | 0 | 0 | C | | В | D19 | D21 | V <sub>ss</sub><br>O | V <sub>ss</sub> | V <sub>ss</sub> | D25 | v<br>O | D31 | v<br>O | NC<br>O | ν <sub>∞</sub><br>Ο | NC<br>O | O | TMS | О | 0 | EADS<br>O | В | | ا ۸ | O D20 | D22 | TCK<br>O | D23 | OP3 | O<br>O | V <sub>ss</sub> | D29 | V <sub>ss</sub> | O<br>NC | V <sub>ss</sub> | O | SMI | O | O | O | AHOLD<br>O | A | | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | • | Note: 17852A-002 NC = Not connected. To guarantee functionality with future revisions, these pins must not be connected. ## CONNECTION DIAGRAMS Am486DXL CPU Top Side View ## 168-Pin PGA (Pin Grid Array) Package | | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | _ | |---|-----------------|-----------------|-----------|-------------------------|----------------|-----------------|-----------------|-----------------|---------------------|-----------------|---------------------|-----------------|-----------------|------------------|-----------------|-----------------|----------------------|---| | s | ADS<br>O | A4<br>O | A6<br>O | ${\overset{V_{ss}}{O}}$ | A10<br>O | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | A12<br>O | V <sub>ss</sub> | A14<br>O | NC<br>O | A23 | A26<br>O | A27<br><b>O</b> | s | | R | SMIADS<br>O | BLAS | T A3 | V <sub>cc</sub> | 88<br><b>O</b> | A11<br>O | V <sub>cc</sub> | v <sub>∞</sub> | v <sub>∞</sub><br>O | V <sub>cc</sub> | A15<br>O | v∞<br>O | A18<br>O | V <sub>ss</sub> | v∞<br>O | A25<br>O | A28 | R | | Q | PCHK | PLOCE<br>O | REQ<br>O | A2<br>O | A7<br>O | A5<br><b>O</b> | A9<br><b>O</b> | A13 | A <sub>16</sub> | A20<br>O | A22<br>O | A24<br>O | A21<br>O | A19 | A17<br>O | V <sub>ss</sub> | A31 | Q | | Р | V <sub>ss</sub> | v <sub>∞</sub> | HLDA<br>O | | | | | | | | | | | | A30 | A29 | 00 | P | | N | W/R | M/Iō | O | | | | | | | | | | | | OP0 | D1<br>O | O<br>O | N | | М | V <sub>ss</sub> | v <sub>cc</sub> | D/C | | | | | | | | | | | | O<br>O | v∞<br>O | V <sub>ss</sub> | м | | L | V <sub>ss</sub> | v∞<br>O | PWT | | | | | | | | | | | | D7<br>O | O<br>D6 | V <sub>ss</sub> | L | | κ | V <sub>ss</sub> | v <sub>cc</sub> | BEO | | | | | | | | | | | | D14 | v∞<br>O | V <sub>ss</sub> | к | | J | PCD | BE1 | BE2 | | | | | | | | | | | | D16 | O <sup>5</sup> | v <sub>∞</sub> | J | | Н | V <sub>ss</sub> | 0 | BRDY | | | | | | | | | | | | OP2 | D3<br>O | v <sub>ss</sub><br>O | н | | G | V <sub>ss</sub> | Ö | O | | | | | | | | | | | | D12 | V <sub>cc</sub> | v <sub>ss</sub> | G | | F | BE3 | RDY<br>O | KEN | | | | | | | | | | | | D15 | D8<br>O | OP1 | F | | E | V <sub>ss</sub> | Ö | HOLD | | | | | | | | | | | | O<br>0 | v <sub>∞</sub> | V <sub>ss</sub> | E | | D | O | BS8<br>O | A20M<br>O | | | | | | | | | | | | D17 | D13 | O<br>O | D | | С | 0 | 0 | O | O | 0 | O<br>NC | NC<br>O | NC<br>O | D30 | D28 | D26 | D27 | V | V <sub>o</sub> , | CLK<br>O | D18 | D11 | Ç | | В | 0 | O | O | TMS<br>O | NC<br>O | NC<br>O | V <sub>oc</sub> | NC<br>O | v<br>O | D31 | ν <sub>∞</sub><br>Ο | D25 | V <sub>ss</sub> | V <sub>ss</sub> | V <sub>ss</sub> | D21 | D19 | В | | Α | AHOLD<br>O | O | O | O | SMI<br>O | O | V <sub>ss</sub> | O | V <sub>ss</sub> | D29 | V <sub>ss</sub> | O<br>O | O<br>DP3 | D23 | TCK<br>O | D22 | D20<br>O | A | | • | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 . | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | Note: NC = Not connected. To guarantee functionality with future revisions, these pins must not be connected. ## PIN DESIGNATIONS (Functional Grouping) | Add | ress | Da | nta | Cor | ntrol | Te | st | NC | 5-V V <sub>ec</sub> | Vss | |-------------|------------|-------------|------------|-------------|------------|-------------|------------|------------|---------------------|-------------| | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>Name | Pin<br>No. | Pin<br>No. | Pin<br>No. | Pin<br>No. | | A2 | Q-14 | D0 | P-1 | A20M | D-15 | TCK | A-3 | A-10 | B-7 | <b>A</b> -7 | | A3 | R-15 | D1 | N-2 | ADS | S-17 | TDI | A-14 | A-12 | B-9 | A-9 | | A4 | S-16 | D2 | N-1 | AHOLD | A-17 | TDO | B-16 | B-10 | B-11 | A-11 | | A5 | Q-12 | D3 | H-2 | BE0 | K-15 | TMS | B-14 | B-12 | C-4 | B-3 | | A6 | S-15 | D4 | M-3 | BE1 | J-16 | | | B-13 | C-5 | B-4 | | A7 | Q-13 | D5 | J-2 | BE2 | J-15 | | | C-10 | E-2 | B-5 | | A8 | R-13 | D6 | L-2 | BE3 | F-17 | | | C-11 | E-16 | E-1 | | A9 | Q-11 | D7 | L-3 | BLAST | R-16 | İ | | C-12 | G-2 | E-17 | | A10 | S-13 | D8 | F-2 | BOFF | D-17 | | | C-13 | G-16 | G-1 | | A11 | R-12 | D9 | D-1 | BRDY | H-15 | | | S-4 | H-16 | G-17 | | A12 | S-7 | D10 | E-3 | BREQ | Q-15 | | | | J-1 | H-1 | | A13 | Q-10 | D11 | C-1 | BS8 | D-16 | | | | K-2 | H-17 | | A14 | S-5 | D12 | G-3 | BS16 | C-17 | | | | K-16 | K-1 | | A15 | R-7 | D13 | D-2 | CLK | C-3 | | | | L-16 | K-17 | | A16 | Q-9 | D14 | K-3 | D/C | M-15 | ĺ | | ŀ | M-2 | L-1 | | A17 | Q-3 | D15 | F-3 | DP0 | N-3 | | | | M-16 | L-17 | | A18 | R-5 | D16 | J-3 | DP1 | F-1 | | | | P-16 | M-1 | | A19 | Q-4 | D17 | D-3 | DP2 | H-3 | | | | R-3 | M-17 | | A20 | Q-8 | D18 | C-2 | DP3 | A-5 | | | | R-6 | P-17 | | A21 | Q-5 | D19 | B-1 | EADS | B-17 | | | | R-8 | Q-2 | | A22 | Q-7 | D20 | A-1 | FERR | C-14 | | | | R-9 | R-4 | | A23 | S-3 | D21 | B-2 | FLUSH | C-15 | | | | R-10 | S-6 | | A24 | Q-6 | D22 | A-2 | HLDA | P-15 | | | | R-11 | S-8 | | A25 | R-2 | D23 | A-4 | HOLD | E-15 | | | | R-14 | S-9 | | A26 | S-2 | D24 | A-6 | IGNNE | A-15 | | | | : | S-10 | | A27 | S-1 | D25 | B-6 | INTR | A-16 | | | | | S-11 | | A28 | R-1 | D26 | C-7 | KEN | F-15 | | | | | S-12 | | A29 | P-2 | D27 | C-6 | LOCK | N-15 | | | | | S-14 | | A30 | P-3 | D28 | C-8 | M/IO | N-16 | | | | | | | A31 | Q-1 | D29 | <b>A-8</b> | NMI | B-15 | | | | | | | | | D30 | C-9 | PCD | J-17 | | | | | | | | | D31 | B-8 | PCHK | Q-17 | | | | | | | | | | | PWT | L-15 | ĺ | | | | | | | | | | PLOCK | Q-16 | | | | | | | | | | | RDY | F-16 | | | | | | | | | | | RESET | C-16 | | | | | | | | | | | W/R | N-17 | | | | | | ## **Superset Pins** | Pin<br>Name | Pin<br>No. | |-------------|------------| | SMI | A-13 | | SMIADS | R-17 | | SMIRDY | G-15 | ## **LOGIC SYMBOL** # ORDERING INFORMATION Standard Products AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of the elements below. | Valid Combinations | | | | | | | | | |--------------------|----------|----------------|--|--|--|--|--|--| | A | 80486DXL | <del>4</del> 0 | | | | | | | ## **Valid Combinations** 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. ## PIN DESCRIPTIONS A31-A4/A3-A2 ## Address Lines (Inputs/Outputs)/(Outputs) A31–A2, together with the byte enables $\overline{\text{BE3}}$ – $\overline{\text{BE0}}$ , define the physical area of memory or input/output space accessed. Address lines A31–A4 are used to drive addresses into the microprocessor to perform cache line invalidations. Input signals must meet setup and hold times $t_{22}$ and $t_{23}$ . A31–A2 are not driven during bus or address hold. ## **A20M** ## Address Bit 20 Mask (Active Low; Input) When asserted, the Am486DXL microprocessor masks physical address bit 20 (A20) before performing a lookup to the internal cache or driving a memory cycle on the bus. $\overline{A20M}$ emulates the address wraparound at 1 Mbyte, which occurs on the 8086. $\overline{A20M}$ is active Low and should be asserted only when the processor is in Real Mode. This pin is asynchronous but should meet setup and hold times $t_{20}$ and $t_{21}$ for recognition in any specific clock. For proper operation, $\overline{A20M}$ should be sampled High at the falling edge of RESET. All SMM address space cycles made by the Am486DXL microprocessor are 32-bit accesses. The Am486DXL CPU effectively ignores the state of \$\overline{A20M}\$ while performing transfers to and from SMM memory space, but recognizes \$\overline{A20M}\$ during UMOV instruction accesses between SMM and the normal address space. ## **ADS** ## Address Status (Active Low; Output) ADS indicates that a valid bus cycle definition and address are available on the cycle definition lines and address bus. ADS is driven active in the same clock as the addresses are driven. ADS is active Low and is not driven during bus hold. #### AHOLD ## Address Hold (Input) This request allows another bus master access to the Am486DXL microprocessor's address bus for a cache invalidation cycle. The Am486DXL microprocessor stops driving its address bus in the clock following AHOLD going active. Only the address bus is floated during address hold; the remainder of the bus remains active. AHOLD is active High and is provided with a small internal pull-down resistor. For proper operation, AHOLD must meet setup and hold times $t_{18}$ and $t_{19}$ . #### BE3-BE0 ## Byte Enables (Active Low; Outputs) These pins indicate active bytes during read and write cycles. During the first cycle of a cache fill, the external system should assume that all byte enables are active. BE3 applies to D31–D24, BE2 applies to D23–D16, BE1 applies to D15–D8, and BE0 applies to D7–D0. BE3–BE0 are active Low and are not driven during bus hold. ## **BS8/BS16** Bus Size 8 (Active Low; Input)/ Bus Size 16 (Active Low; Input) These pins cause the Am486DXL microprocessor to run multiple bus cycles to complete a request from devices that cannot provide or accept 32 bits of data in a single cycle. The bus sizing pins are sampled every clock. The state of these pins in the clock before $\overline{RDY}$ is used by the Am486DXL microprocessor to determine the bus size. These signals are active Low and are provided with internal pull-up resistors. These inputs must satisfy setup and hold times $t_{14}$ and $t_{15}$ for proper operation. All SMM address space cycles made by the Am486DXL microprocessor are 32-bit accesses. The Am486DXL CPU ignores \$\overline{BS}\$16 and \$\overline{BS}\$8 during cycles directed to the SMM address space, but recognizes \$\overline{BS}\$16 during UMOV instruction accesses between SMM and the normal address space. #### **BLAST** ## **Burst Last (Active Low; Output)** BLAST indicates that the next time BRDY is returned, then the burst bus cycle is complete. BLAST is active for both burst and non-burst bus cycles. BLAST is active Low and is not driven during bus hold. #### **BOFF** ## **Backoff (Active Low; Input)** This input pin forces the Am486DXL microprocessor to float its bus in the next clock. The microprocessor floats all pins normally floated during bus hold, but HLDA is not asserted in response to $\overline{BOFF}$ . $\overline{BOFF}$ has higher priority than $\overline{RDY}$ or $\overline{BRDY}$ ; if both are returned in the same clock, $\overline{BOFF}$ takes effect. The microprocessor remains in bus hold until $\overline{BOFF}$ is negated. If a bus cycle was in progress when $\overline{BOFF}$ was asserted, the cycle is restarted. $\overline{BOFF}$ is active Low and must meet setup and hold times $t_{18}$ and $t_{19}$ for proper operation. #### BRDY #### **Burst Ready Input (Active Low; Input)** This input pin performs the same cycle during a burst cycle that $\overline{\text{RDY}}$ performs during a non-burst cycle. $\overline{\text{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. $\overline{\text{BRDY}}$ 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 burst cycle is prematurely aborted. $\overline{\text{BRDY}}$ is active Low and is provided with a small pull-up resistor. $\overline{\text{BRDY}}$ must satisfy the setup and hold times $t_{16}$ and $t_{17}$ . ## **BREQ** ## Internal Cycle Pending (Output) BREQ indicates that the Am486DXL microprocessor has internally generated a bus request. BREQ is generated whether or not the Am486DXL microprocessor is driving the bus. BREQ is active High and is never floated, except during three-state test mode (see FLUSH). ## **CLK** #### Clock (input) CLK is a 1X clock providing the fundamental timing and the internal operating frequency for the Am486DXL microprocessor. All external timing parameters are specified with respect to the rising edge of CLK. #### D31-D0 ## **Data Lines (Inputs/Outputs)** Lines D7–D0 define the least significant byte of the bus while lines D31–D24 define the most significant byte of the data bus. These signals must meet setup and hold times $t_{22}$ and $t_{23}$ for proper operation on reads. These pins are driven during the second and subsequent clocks of write cycles. #### D/C #### **Data/Control (Output)** This bus cycle definition pin distinguishes data cycles, either memory or I/O, from control cycles. These control cycles are: interrupt acknowledge, halt, and instruction fetching. ## 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 Am486DXL 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 correct parity check status is indicated by the Am486DXL microprocessor. The signals read on these pins do not affect program execution. Input signals must meet setup and hold times $t_{22}$ and $t_{23}$ . DP3–DP0 should be connected to $V_{cc}$ 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. ## **EADS** #### Valid External Address (Active Low; Input) This pin indicates a valid external address has been driven onto the Am486DXL microprocessor address pins. This address is used to perform an internal cache invalidation cycle. EADS is active Low and is provided with an internal pull-up resistor. EADS must satisfy setup and hold times t<sub>12</sub> and t<sub>13</sub> for proper operation. ## **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** ## Cache Flush (Active Low; Input) FLUSH forces the Am486DXL microprocessor to flush its entire internal cache. FLUSH is active Low and need only be asserted for one clock. FLUSH is asynchronous, but setup and hold times t<sub>20</sub> and t<sub>21</sub> must be met for recognition in any specific clock. FLUSH being sampled Low in the clock before the falling edge of RESET causes the Am486DXL microprocessor to enter the three-state test mode. ## **HLDA** ## Hold Acknowledge (Output) HLDA goes active in response to a hold request presented on the HOLD pin. HLDA indicates that the Am486DXL microprocessor has given the bus to another local bus master. HLDA is driven active in the same clock that the Am486DXL microprocessor floats its bus. HLDA is driven inactive when leaving bus hold. HLDA is active High and remains driven during bus hold. HLDA is never floated, except during three-state test mode (see FLUSH). #### HOLD ## **Bus Hold Request (Input)** This input pin allows another bus master complete control of the Am486DXL microprocessor bus. In response to HOLD going active, the Am486DXL 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 Am486DXL microprocessor remains in this state until HOLD is deasserted. HOLD is active High and is not provided with an internal pull-down resistor. HOLD must satisfy setup and hold times t<sub>18</sub> and t<sub>19</sub> for proper operation. #### **IGNNE** ## Ignore Numeric Error (Active Low; Input) When this pin is asserted, the Am486DXL microprocessor will ignore a numeric error and continue executing non-control floating-point instructions. When $\overline{\text{IGNNE}}$ is deasserted, the Am486DXL microprocessor will freeze on a non-control floating-point instruction if a previous floating-point instruction caused an error. $\overline{\text{IGNNE}}$ has no effect when the NE bit in Control Register 0 is set. $\overline{\text{IGNNE}}$ is active Low and is provided with a small internal pull-up resistor. $\overline{\text{IGNNE}}$ is asynchronous but setup and hold times $t_{20}$ and $t_{21}$ must be met to ensure recognition on any specific clock. #### INTR ## Maskable Interrupt (Input) INTR indicates an external interrupt has been generated. If the internal interrupt flag is set in EFLAGS, active interrupt processing is initiated. The Am486DXL 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 $t_{20}$ and $t_{21}$ for recognition in any specific clock. #### **KEN** #### Cache Enable (Active Low; Input) KEN is used to determine whether the current cycle is cacheable. When the Am486DXL microprocessor generates a cacheable cycle and $\overline{\text{KEN}}$ is active, the cycle becomes a cache line fill cycle. Returning $\overline{\text{KEN}}$ active one clock before $\overline{\text{RDY}}$ during the last read in the cache line fill causes the line to be placed in the on-chip cache. $\overline{\text{KEN}}$ is active Low and is provided with a small internal pull-up resistor. $\overline{\text{KEN}}$ must satisfy setup and hold times $t_{14}$ and $t_{15}$ for proper operation. All SMM address space cycles made by the Am486DXL CPU are 32-bit accesses. The Am486DXL CPU effectively ignores the state of KEN while performing transfers to and from SMM memory space, but recognizes KEN during UMOV instruction accesses between SMM and the normal address space. #### **LOCK** ## **Bus Lock (Active Low; Output)** LOCK indicates the current bus cycle is locked. The Am486DXL microprocessor does not allow a bus hold when LOCK is asserted (but address holds are allowed). LOCK goes active in the first clock of the first locked bus cycle and goes inactive after the 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 returned active. #### M/IO #### Memory/Input Output (Output) This bus cycle definition pin distinguishes memory cycles from input/output cycles. ## **NMI** #### Non-maskable Interrupt (Input) This request signal indicates that an external non-maskable interrupt has been generated. NMI is rising edge sensitive. NMI must be held Low for at least four CLK periods before this rising edge. NMI is not provided with an internal pull-down resistor. NMI is asynchronous, but must meet setup and hold times $t_{20}$ and $t_{21}$ for recognition in any specific clock. ## PCD/PWT #### Page Cache Disable/Page Write-Through (Outputs) These reflect the state of the page attribute bits, PWT and PCD, in the page table entry or page directory entry. If paging is disabled or for unpaged cycles, PWT and PCD reflect the state of the PWT and PCD bits in Control Register 3. PWT and PCD have the same timing as the cycle definition pins $(M/\overline{IO}, D/\overline{C}, \text{ and } W/\overline{R})$ . PWT and PCD are active High and are not driven during bus hold. PCD is masked by the Cache Disable Bit (CD) in Control Register 0. #### **PCHK** #### Parity Status (Active Low; Output) Parity status is driven on the PCHK pin the clock after RDY for read operations. The parity status is for data sampled at the end of the previous clock. A parity error is indicated by PCHK being Low. Parity status is only checked for enabled bytes as 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 never floated except during three-state test mode (see FLUSH). #### **PLOCK** #### Pseudo-lock (Active Low; Output) PLOCK indicates that the current bus transaction requires more than one bus cycle to complete. Examples of such operations are floating-point long reads and writes (64 bits), segment table descriptor reads (64 bits) and cache line fills (128 bits). The Am486DXL microprocessor drives PLOCK active until the addresses for the last bus cycle of the transaction have been driven, regardless of whether RDY or BRDY has been returned. Normally PLOCK and BLAST are inverse of each other. However, during the first bus cycle of a 64-bit floating-point write, both PLOCK and BLAST will be asserted. PLOCK is a function of the BS8, BS16, and KEN inputs. PLOCK should be sampled only if the clock RDY is returned. PLOCK is active Low and is not driven during bus hold. ## RESET ## Reset (input) This pin forces the Am486DXL microprocessor to begin execution at a known state. The microprocessor cannot begin execution of instructions until at least 1 ms after $V_{cc}$ and CLK have reached their proper DC and AC specifications. The RESET pin should remain active during this time to ensure proper microprocessor operation. RESET is active High. RESET is asynchronous but must meet setup and hold times $t_{20}$ and $t_{21}$ for recognition in any specific clock. #### **RDY** ## Non-burst Ready (Active Low; Input) This input pin indicates that the current bus cycle is complete. $\overline{RDY}$ indicates that the external system has presented valid data on the data pins in response to a read, or that the external system has accepted data from the Am486DXL microprocessor in response to a write. $\overline{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. $\overline{RDY}$ is active Low and is not provided with an internal pull-up resistor. $\overline{RDY}$ must satisfy setup and hold times $t_{16}$ and $t_{17}$ for proper chip operation. #### <u>SMI</u> # System Management Interrupt (Active Low; Synchronous Input/Output) This pin is the highest level, non-maskable interrupt to the Am486DXL CPU. To initiate a System Management Interrupt, an external source must pull the input signal Low synchronously to CLK and hold it Low until the Am486DXL microprocessor suspends normal execution and enters SMM. When the CPU generates an active SMIADS pulse, it also takes control of SMI and drives SMI active Low. The CPU then continues to drive SMI Low until it exits SMM via a RESET or RES4 instruction (when the system asserts RESET, it must also release SMI to prevent buffer contention). When exiting SMM, the CPU drives SMI High for two clocks, and then releases SMI to a weak internal pull-up resistor. The SMI pull-up is active during RESET and whenever the CPU is not driving SMI active Low. The CPU disables the pullup when it drives SMI active to minimize CPU power consumption. SMI is not three-stated during HLDA bus cycles. Note: SMI should not be used to qualify SMM accesses. ## **SMIADS** ## SMI Address Status (Active Low; Three-State; Output) The Am486 CPU activates this pin to initiate a valid bus cycle to the separate SMM memory space. The function of SMIADS is analogous to ADS. This signal validates the address and control lines for SMM memory, just as ADS validates address and control for non-SMM memory cycles. The system must terminate SMIADS initiated bus cycles with SMIRDY. The Am486 CPU ignores both RDY and BRDY on SMIADS initiated cycles. This three-state output is floated during HLDA bus cycles. #### **SMIRDY** ## SMI Ready (Active Low; Synchronous Input) This input terminates the current bus cycle that \$\overline{SMIADS}\$ initiated in the same manner as \$\overline{RDY}\$ terminates \$\overline{ADS}\$ initiated bus cycles. The system must assert and deassert \$\overline{SMIRDY}\$ synchronously to CLK. The \$\overline{Am486}\$ CPU ignores \$\overline{SMIRDY}\$ on \$\overline{ADS}\$ initiated cycles. \$\overline{SMIRDY}\$ has an internal pull-down resistor. This is different from the \$\overline{Am386}^{\text{\textit{B}}}\$ CPU \$\overline{SMIRDY}\$ which has an internal pull-up resistor. \$\overline{SMIRDY}\$ should not be physically connected to \$\overline{RDY}\$. #### **TCK** #### Test Clock (input) Test Clock is an input to the Am486 CPU and provides the clocking function required by the JTAG boundary scan feature. TCK is used to clock state information and data into and out of the component. State select information and data are clocked 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. ## TDI #### Test Data Input (Input) TDI is the serial input used to shift JTAG instructions and data into the component. TDI is sampled on the rising edge of TCK during the SHIFT-IR and the SHIFT-DR TAP controller states. During all other tap controller states, TDI is a "don't care." #### TDO ## **Test Data Output (Output)** TDO is the serial output used to shift JTAG instructions and data out of the component. TDO is driven on the fal- ling edge of TCK during the SHIFT-IR and SHIFT-DR TAP controller states. At all other times, TDO is driven to the high impedance state. #### **TMS** ## **Test Mode Select (Input)** TMS is decoded by the JTAG TAP (Tap Access Port) 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, TMS is provided with an internal pull-up resistor. ## W/R ## Write/Read (Output)Write/Read (Output) This bus definition pin distinguishes write cycles from read cycles. Table 1. Output Pins | Name | Active<br>Level | Floated At | |----------------|-----------------|-------------------| | BREQ | High | | | HLDA | High | | | BE3-BE0 | Low | Bus Hold | | PCD/PWT | High | Bus Hold | | W/R, D/C, M/IO | High | Bus Hold | | LOCK | Low | Bus Hold | | PLOCK | Low | Bus Hold | | ADS | Low | Bus Hold | | BLAST | Low | Bus Hold | | PCHK | Low | | | A3-A2 | High | Bus, Address Hold | | SMIADS | Low | Hold Acknowledge | Table 2. Input Pins | Name | Active<br>Level | Synchronous/<br>Asynchronous | |-----------|-----------------|------------------------------| | CLK | | | | RESET | High | Asynchronous | | HOLD | High | Synchronous | | AHOLD | High | Synchronous | | EADS | Low | Synchronous | | BOFF | Low | Synchronous | | FLUSH | Low | Asynchronous | | A20M | Low | Asynchronous | | BS16, BS8 | Low | Synchronous | | KEN | Low | Synchronous | | RDY | Low | Synchronous | | BRDY | Low | Synchronous | | INTR | High | Asynchronous | | _NMI_ | High | Asynchronous | | SMIRDY | Low | Synchronous | Table 3. Input/Output Pins | Name | Active<br>Level | Floated At | |---------|-----------------|-------------------| | D31-D0 | High | Bus Hold | | DP3-DP0 | High | Bus Hold | | A31-A4 | High | Bus, Address Hold | | SMI | Low | Hold Acknowledge | Table 4. Bus Cycle Definition | M/IO | D/C | W/R | Bus Cycle Initiated | |------|-----|-----|-----------------------| | 0 | 0 | 0 | Interrupt Acknowledge | | 0 | 0 | 1 | Halt/Special Cycle | | 0 | 1 | 0 | I/O Read | | 0 | 1 | 1 | I/O Write | | 1 | 0 | 0 | Code Read | | 1 | 0 | 1 | Reserved | | 1 | 1 | 0 | Memory Read | | 1 | 1 | 1 | Memory Write | Table 5. Test Pins | Name | Input or Output | Sampled/Driven On | |------|-----------------|---------------------| | TCK | Input | N/A | | TDI | Input | Rising Edge of TCK | | TDO | Output | Falling Edge of TCK | | TMS | Input | Rising Edge of TCK | ## **CPU IDENTIFICATION CODES** The DX register always contains a component identification at the conclusion of RESET. The upper byte of DX (DH) will contain 04 and the lower byte of DX (DL) will contain a CPU type/stepping identifier. Table 6. CPU ID | Component ID | Component ID | |--------------|--------------| | (DH) | (DL) | | 04 | 22 | Table 7. JTAG ID Code | Version Code | Part Number<br>Code | Manufacturer Identity | |--------------|---------------------|-----------------------| | 00h | 0422 | 01 | #### **ELECTRICAL DATA** The following sections describe recommended electrical connections for the Am486DXL microprocessor and its electrical specifications. ## **Power and Grounding** #### **Power Connections** The Am486DXL microprocessor is implemented in CS14 technology and has modest power requirements. However, its 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, 24 $V_{\rm cc}$ and 28 $V_{\rm ss}$ pins feed the Am486DXL microprocessor. Power and ground connections must be made to all external $V_{\rm cc}$ and GND pins of the Am486DXL microprocessor. On the circuit board, all $V_{\rm cc}$ pins must be connected on a $V_{\rm cc}$ plane. All $V_{\rm ss}$ pins must likewise be connected on a GND plane. ## **Power Decoupling Recommendations** Liberal decoupling capacitance should be placed near the Am486DXL microprocessor. The Am486DXL microprocessor, driving its 32-bit 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 Am486DXL microprocessor, and decoupling capacitors as much as possible. Capacitors specifically for PGA packages are also commercially available. #### Other Connection Recommendations NC pins should always remain unconnected. For reliable operation, always connect unused inputs to an appropriate signal level. Active Low inputs should be connected to $V_{cc}$ through a pull-up resistor. Pull-ups in the range of 20 $K\Omega$ are recommended. Active High inputs should be connected to GND. ## ABSOLUTE MAXIMUM RATINGS Case Temperature under Bias .... $-65^{\circ}$ C to $+110^{\circ}$ C Storage Temperature .... $-65^{\circ}$ C to $+150^{\circ}$ C Voltage on any pin with respect to ground .... -0.5 V to $V_{cc}$ +0.5 V Supply voltage with respect to $V_{ss}$ .... -0.5 V to +6.5 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 Operating ranges define those limits between which the functionality of the device is guaranteed. ## DC CHARACTERISTICS over COMMERCIAL operating ranges $T_{CASE} = 0^{\circ}C$ to +85°C | | | | PRELIMINARY | | | |------------------|---------------------------|---------------------------------------------------------|-----------------------------|-----------------------|------| | Symbol | Parameter Description | Notes | Min | Max | Unit | | V <sub>IL</sub> | Input Low Voltage | | -0.3 | + 0.8 | ٧ | | V <sub>IH</sub> | Input High Voltage | | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | V <sub>OL</sub> | Output Low Voltage | I <sub>OL</sub> = (Note 1)<br>I <sub>OL</sub> = 0.1 mA | | 0.45<br>0.2 | ٧ | | V <sub>OH</sub> | Output High Voltage | I <sub>OH</sub> = (Note 2)<br>I <sub>OH</sub> = -0.1 mA | 2.4<br>V <sub>CC</sub> -0.2 | | ٧ | | lcc | Power Supply Current | V <sub>CC</sub> = 5.0 V (Note 3) | | 850 | mA | | ILI | Input Leakage Current | (Note 4) | | ±15 | μΑ | | J <sub>IH</sub> | Input Leakage Current | (Note 5) | | 200 | μΑ | | I <sub>ĮŁ</sub> | Input Leakage Current | (Note 6) | | -400 | μА | | I <sub>LO</sub> | Output Leakage Current | | | ±15 | μА | | C <sub>IN</sub> | Input Capacitance | F <sub>C</sub> = 1 MHz (Note 7) | | 13 | pF | | Co | I/O or Output Capacitance | F <sub>C</sub> = 1 MHz (Note 7) | | 17 | pF | | C <sub>CLK</sub> | CLK Capacitance | F <sub>C</sub> = 1 MHz (Note 7) | | 15 | pF | #### Notes: 1. This parameter is measured at: Address, Data, BE3-BE0 4.0 mA Definition, Control 5.0 mA 2. This parameter is measured at: Address, Data, BE3-BE0 J.U 1117 Definition, Control −1.0 mA −0.9 mA - 3. Typical supply current: 700 mA @ 40 MHz - 4. This parameter is for inputs without pull-ups or pull-downs and $0 \le V_{IN} \le V_{CC}$ . - 5. This parameter is for inputs with pull-downs and $V_{IH} = 2.4 \text{ V}$ . - 6. This parameter is for inputs with pull-ups and $V_{IL} = 0.45 \text{ V}$ . - 7. Not 100% tested ## **SWITCHING CHARACTERISTICS** The switching characteristics consist of output delays, input set-up requirements, and input hold requirements. All switching characteristics are relative to the rising edge of the CLK signal. Switching characteristics measurement is defined by Figure 2 through Figure 8. Inputs must be driven to the voltage levels indicated by Figure 1 when switching characteristics are measured. Am486DXL microprocessor output delays are specified with minimum and maximum limits, measured as shown. The minimum Am486DXL microprocessor delay times are hold times provided to external circuitry. Am486DXL microprocessor input setup and hold times are specified as minimums, defining the smallest acceptable sampling windows. Within the sampling windows, a synchronous input signal must be stable for correct Am486DXL microprocessor operation. ## **SWITCHING CHARACTERISTICS over COMMERCIAL operating ranges** Switching Characteristics at 40 MHz; T<sub>CASE</sub> = 0°C to +85°C; C<sub>L</sub> = 50 pF unless otherwise specified. | | | | | PRELIMINARY | | | |------------------|------------------------------------------------------------------------------------------|------------------------|--------|-------------|------|------| | Symbol | Parameter Description | Notes | Figure | Min | Max | Unit | | | Operating Frequency | | | 0 | 40 | MHz | | t <sub>1</sub> | CLK Period | | 1 | 25 | | ns | | t <sub>ia</sub> | CLK Period Stability | Adjacent Clocks | | | 0.1% | Δ | | t <sub>2</sub> | CLK High Time | @ 2.0 V | 1 | 9 | | ns | | t <sub>3</sub> | CLK Low Time | @ 0.8 V | 1 | 9 | | ns | | t <sub>4</sub> | CLK Fall Time | | 1 | | 3 | ns | | t <sub>5</sub> | CLK Rise Time | | 1 | | 3 | ns | | t <sub>6</sub> | A31-A2, PWT, PCD, M/TO, BE3-BE0, D/C,<br>W/R, ADS, LOCK, FERR, BREQ, HLDA<br>Valid Delay | | 6 | 3 | 16 | ns | | t <sub>6s</sub> | SMIADS Valid Delay | C <sub>L</sub> = 50 pF | 6 | 3 | 16 | ns | | t <sub>7</sub> | A31-A2, PWT, PCD, M/IO, BE3-BE0, D/C,<br>W/R, ADS, LOCK Float Delay | (Note 1) | 7 | 3 | 20 | ns | | t <sub>7s</sub> | SMIADS Float Delay | (Note 1) | 7 | 3 | 20 | ns | | t <sub>B</sub> | PCHK Valid Delay | | 5 | 3 | 20 | ns | | t <sub>8a</sub> | BLAST, PLOCK Valid Delay | | 6 | 3 | 16 | ns | | t <sub>9</sub> | BLAST, PLOCK Float Delay | (Note 1) | 7 | 3 | 20 | ns | | t <sub>10</sub> | D31-D0, DP3-DP0 Write Data Valid Delay | | 6 | 3 | 18 | ns | | t <sub>11</sub> | D31-D0, DP3-DP0 Write Data Float Delay | (Note 1) | 7 | 3 | 20 | ns | | t <sub>12</sub> | EADS Setup Time | | 3 | 5 | | ns | | t <sub>13</sub> | EADS Hold Time | | 3 | 3 | | ns | | t <sub>14</sub> | KEN, BS16, BS8 Setup Time | | 3 | 5 | | ns | | t <sub>15</sub> | KEN, BS16, BS8 Hold Time | | 3 | 3 | | ns | | t <sub>16</sub> | RDY, BRDY Setup Time | | 4 | 5 | | ns | | t <sub>16s</sub> | SMIRDY Setup Time | | 4 | 5 | | ns | | t <sub>17</sub> | RDY, BRDY Hold Time | | 4 | 3 | | ns | | t <sub>17s</sub> | SMIRDY Hold Time | | 4 | 3 | | ns | | t <sub>18</sub> | HOLD, AHOLD Setup Time | | 3 | 6 | | ns | | t <sub>18a</sub> | BOFF Setup Time | | 3 | 8 | | ns | | t <sub>19</sub> | HOLD, AHOLD, BOFF Hold Time | | 3 | 3 | | ns | | t <sub>20</sub> | RESET, FLUSH, A20M, NMI, INTR , IGNNE<br>Setup Time | | 2, 3 | 5 | | ns | | t <sub>20s</sub> | SMI Setup Time | | 2, 3 | 5 | | ns | | t <sub>21</sub> | RESET, FLUSH, A20M, NMI, INTR, IGNNE<br>Hold Time | | 2, 3 | 3 | | ns | | t <sub>21s</sub> | SMI Hold Time | | 2, 3 | 3 | | ns | | t <sub>22</sub> | D31-D0, DP3-DP0, A31-A4 Read Setup Time | | 3, 4 | 5 | | ns | | t <sub>23</sub> | D31-D0, DP3-DP0, A31-A4 Read Hold Time | | 3, 4 | 4 | | ns | ## Note: 1. Not 100% tested. Guaranteed by design characterization. # Am486DXL Microprocessor AC Characteristics for Boundary Scan Test Signals at 25 MHz $V_{cc}$ = 5 V ±5%; $T_{case}$ = 0°C to +85°C; $C_L$ = 0 pF. All inputs and outputs are TTL Level. | Symbol | Parameter | Min | Max | Unit | Figure | Notes | |-----------------|------------------------------------|-----|-----|------|--------|----------| | t <sub>24</sub> | TCK Frequency | | 25 | MHz | | 1X Clock | | t <sub>25</sub> | TCK Period | 40 | | ns | | Note 2 | | t <sub>26</sub> | TCK High Time | 10 | | ns | | at 2.0 V | | t <sub>27</sub> | TCK Low Time | 10 | | ns | | at 0.8 V | | t <sub>28</sub> | TCK Rise Time | | 4 | ns | | Note 1 | | t <sub>29</sub> | TCK Fall Time | | 4 | ns | | Note 1 | | t <sub>30</sub> | TDI, TMS Setup Time | 8 | | ns | 8 | Note 3 | | t <sub>31</sub> | TDI, TMS Hold Time | 7 | | ns | 8 | Note 3 | | t <sub>32</sub> | TDO Valid Delay | 3 | 25 | ns | 8 | Note 3 | | t <sub>33</sub> | TDO Float Delay | | 36 | ns | 8 | Note 3 | | t <sub>34</sub> | All Outputs (Non-Test) Valid Delay | 3 | 25 | ns | 8 | Note 3 | | t <sub>35</sub> | All Outputs (Non-Test) Float Delay | | 36 | ns | 8 | Note 3 | | t <sub>36</sub> | All Inputs (Non-Test) Setup Time | 8 | | ns | 8 | Note 3 | | t <sub>37</sub> | All Inputs (Non-Test) Hold Time | 7 | | ns | 8 | Note 3 | #### Notes: <sup>1.</sup> Rise/Fall times are measured between 0.8 V and 2.0 V. Rise/Fall times can be relaxed by 1 ns per 10-ns increase in TCK period. <sup>2.</sup> TCK period ≥ CLK period. <sup>3.</sup> Parameter measured from TCK. ## **KEY TO SWITCHING WAVEFORMS** | WAVEFORM | INPUTS | OUTPUTS | | | |-----------------|----------------------------------------|-----------------------------------------------------|--|--| | | Must be<br>Steady | Will be<br>Steady | | | | | May<br>Change<br>from H to L | Will be<br>Changing<br>from H to L | | | | | May<br>Change<br>from L to H | Will be<br>Changing<br>from L to H | | | | | Don't Care,<br>Any Change<br>Permitted | Changing,<br>State<br>Unknown | | | | <b>&gt;&gt;</b> | Does Not<br>Apply | Center<br>Line is High-<br>Impedance<br>"Off" State | | | KS000010 Figure 1. CLK Waveforms Figure 2. RESET Setup and Hold Timing Figure 3. Input Setup and Hold Timing Figure 4. RDY and BRDY Input Setup and Hold Timing Figure 5. PCHK Valid Delay Timing 17852A-101 Figure 6. Output Valid Delay Timing Figure 7. Maximum Float Delay Timing Figure 8. Test Signal Timing Diagram ## PHYSICAL DIMENSIONS ## CGM 168 (measured in inches) #### **Trademarks** AMD, Am486, and Am386 are registered trademarks, and FusionPC is a service mark of Advanced Micro Devices, Inc. Microsoft is a registered trademark of the Microsoft Corp. Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.