# **OKI** Semiconductor # MSM60802 #### **PCMCIA Host Interface Controller** #### DESCRIPTION The MSM60802 is OKI's first single-chip, highly integrated PC Card (PCMCIA) HostSide™ interface controller, offering compliancy with the PCMCIA 2.1, JEIDA 4.1, and ATA 1.01 industry standards. This device is optimized for usage in notebook and hand-held computers that require low-cost, single-socket support with extremely low power consumption for enhancing battery life. For small-form-factor designs, OKI delivers a minimum board-area solution by eliminating external buffers. The HostSide<sup>™</sup> controller is unique in several aspects, but most importantly regarding its register and software compatibility to the Intel 82365SL B step IC. Software compatibility significantly simplifies the design process and shortens time-to-market. Plug-and-play compatibility is becoming more popular with PC Cards. The HostSide™ controller offers seamless transitions through full ExCA™ (QuickSwap) extensions. Another benefit of internal buffers is hot insertion capability. All necessary registers, decoders, and buffers are integrated to reduce the system form factor and to eliminate discrete components. A comprehensive interface allows device configuration, software setup, and firmware parameter setup by a host (PC) system. The MSM60802 is manufactured on OKI's high-quality CMOS process, providing unrivaled low-power performance with a 3-V or 5-V operating range. Power-management circuitry further reduces power consumption through active monitoring techniques. In an effort to further reduce board space usage, the HostSide<sup>TM IC</sup> is offered in a 176-pin TQFP package. #### **FEATURES** - Single-chip PCMCIA host controller for reduced board space. - Register- and software-compatible with Intel 82365SL B step PCMCIA controller for simplified design - Mixed-voltage (3-V and 5-V) support, providing easy transition path - Direct connection between ISA bus and PCMCIA socket for enhanced performance - Compliant with PCMCIA 2.1, JEIDA 4.1, and ATA 1.01, facilitating compatibility - ExCA<sup>™</sup> compatible with hot-insertion compatibility - Five independent, programmable memory windows per slot, meeting user requirements - Two independent, programmable I/O windows per slot, simplifying partitioning - Programmable access cycle timing, enhancing throughput - Pulse- or level-mode interrupts, providing flexibility - Execute-in-place (XIP) operation - Programmable sleep modes for increased power savings - 8-bit or 16-bit PCMCIA and CPU interface support for most architecture variations - PCMCIA RESET compatibility, reducing design overhead - 176-pin TQFP package, minimizing board space #### **PIN CONFIGURATION** ### **PIN LAYOUT** | Pin | Pin Name | Pin | Pin Name | Pin | Pin Name | Pin | Pin Name | Pin | Pin Name | Pin | Pin Name | |-----|----------|-----|----------|-----|----------|-----|----------|-----|----------|-----|----------| | 1 | NC | 31 | VSS | 61 | SA8 | 91 | CDB7 | 121 | CA12 | 151 | WP | | 2 | NC | 32 | SD8 | 62 | SA9 | 92 | CDB14 | 122 | CA24 | 152 | CD2 | | 3 | RI_OUT | 33 | SD9 | 63 | SA10 | 93 | VSS | 123 | VSS | 153 | VDD | | 4 | SPKR_OUT | 34 | SD10 | 64 | SA11 | 94 | CE1 | 124 | CA7 | 154 | VCC_EN1 | | 5 | VSS | 35 | SD11 | 65 | SA12 | 95 | CDB15 | 125 | CA25 | 155 | VCC_EN2 | | 6 | SYSCLK | 36 | VDD | 66 | SA13 | 96 | CA10 | 126 | CA6 | 156 | VPP1_EN1 | | 7 | VDD | 37 | SD12 | 67 | SA14 | 97 | CE2 | 127 | AUX | 157 | VPP1_EN2 | | 8 | CS1 | 38 | SD13 | 68 | SA15 | 98 | ŌĒ | 128 | CA5 | 158 | VPP2_EN1 | | 9 | CS0 | 39 | SD14 | 69 | VSS | 99 | GPI | 129 | RESET | 159 | VPP2_EN2 | | 10 | MODE | 40 | SD15 | 70 | SA16 | 100 | CA11 | 130 | CA4 | 160 | OVER_C | | 11 | OFFSET 0 | 41 | AEN | 71 | LA17 | 101 | IORD | 131 | NC | 161 | VDD | | 12 | OFFSET 1 | 42 | BALE | 72 | LA18 | 102 | CA9 | 132 | NC | 162 | VSS | | 13 | BUSEN | 43 | NC | 73 | LA19 | 103 | TOWR | 133 | NC | 163 | INTR | | 14 | PWRGD | 44 | NC | 74 | LA20 | 104 | CA8 | 134 | NC | 164 | IRQ3 | | 15 | RSTDRV | 45 | NC | 75 | LA21 | 105 | CA17 | 135 | WAIT | 165 | IRQ4 | | 16 | MEMW | 46 | NC | 76 | LA22 | 106 | VSS | 136 | CA3 | 166 | IRQ5 | | 17 | MEMR | 47 | VSS | 77 | LA23 | 107 | CA13 | 137 | VDD | 167 | VDD | | 18 | IOWC | 48 | ows | 78 | VDD | 108 | CA18 | 138 | CA2 | 168 | IRQ7 | | 19 | IORC | 49 | IOCHRDY | 79 | CBD3 | 109 | CA14 | 139 | REG | 169 | IRQ9 | | 20 | SBHE | 50 | MEMCS16 | 80 | CD1 | 110 | CA19 | 140 | CA1 | 170 | IRQ10 | | 21 | VSS | 51 | 10CS16 | 81 | CDB4 | 111 | WE | 141 | BVO2 | 171 | IRQ11 | | 22 | SD0 | 52 | SA0 | 82 | CDB11 | 112 | CA20 | 142 | CA0 | 172 | IRQ12 | | 23 | SD1 | 53 | SA1 | 83 | CDB5 | 113 | VDD | 143 | BVD1 | 173 | IRQ14 | | 24 | SD2 | 54 | SA2 | 84 | CDB12 | 114 | RDY/BSY | 144 | CDB0 | 174 | IRQ15 | | 25 | SD3 | 55 | SA3 | 85 | CDB6 | 115 | CA21 | 145 | CDB8 | 175 | NC | | 26 | VSS | 56 | SA4 | 86 | CDB13 | 116 | CA16 | 146 | CDB1 | 176 | NC | | 27 | SD4 | 57 | SA5 | 87 | NC | 117 | CA22 | 147 | CDB9 | | | | 28 | SD5 | 58 | SA6 | 88 | NC | 118 | CA15 | 148 | VSS | | | | 29 | SD6 | 59 | SA7 | 89 | NC | 119 | VSS | 149 | CDB2 | | | | 30 | SD7 | 60 | VDD | 90 | NC | 120 | CA23 | 150 | CDB10 | | | ### **PACKAGE DIAGRAM** ### **BLOCK DIAGRAM** ### **PIN DESCRIPTIONS** | Pin Name | Direction and<br>Strength | | | Descri | rtion | | | | |---------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|--| | AEN | Input | System Address Enable. This active-HIGH input signal should be connected to the AEN signal on the ISA bus. If the system asserts this signal HIGH, access to I/O and the internal MSM60802 registers is disabled, CE1 and CE2 are asserted LOW, and memory access is enabled. If the system deasserts this signal LOW, access to I/O and internal registers is also enabled. | | | | | | | | AUX | I/O<br>4 mA | Auxiliary. | Auxiliary. This is a multi-purpose I/O pin for user applications. | | | | | | | BALE | Input | bus. The s | Bus Address Latch Enable. This active-HIGH input signal should be connected to the BALE signal on the ISA bus. The system asserts this signal HIGH at the beginning of every bus cycle to latch the address from the system address bus, SA[23:17]. | | | | | | | BUSEN | Output<br>4 mA | Bus Enable | e. If the PCM | CIA bus is enabled, the MSM608 | 102 asserts this signal LOW. | | | | | BVD1 (STSCHG) | Input | Battery Sta<br>Card Status<br>bit in this n<br>'1' on the fa<br>Status Cha<br>the BVD1 b<br>selected by | This is a dual-function PCMCIA pin with different characteristics on memory and configured I/O cards. <b>Battery Status 1.</b> On memory cards, this signal indicates a low battery on the PC card. If the BVD1 bit in the Card Status Interrupt Configuration Register (see page 19) is set to '1' then the interrupt selected by the IRQ_SX bit in this register is requested. The BVD1_CH bit in the Card Status Flag Register (see page 18) is also set to '1' on the falling edge of BVD1. <b>Status Changed.</b> On configured I/O cards, the card signals a change of its status by setting this signal LOW. If the BVD1 bit in the Card Status Interrupt Configuration Register (see page 19) is set to '1' then the interrupt selected by the IRQ_Sx bit in this register is requested. The BVD1_CH bit in the Card Status Flag Register (see page 18) is also set to '1' on the falling edge of STSCHG, and the MSM60802 asserts the RI_OUT signal LOW | | | | | | | BVD2 (SPKR) | Input | Battery Sta<br>Card Status<br>bit in this re<br>'1' on the fa<br>Digital Aud<br>When confi | tus 2. On me<br>Interrupt Co.<br>egister is requalling edge of<br>io. On I/O car<br>gured for I/O | mory cards, this signal indicates<br>nfiguration Register (see page 19<br>uested. The BVD2_CH bit in the<br>BVD1.<br>rds, the PC card can use this sign | teristics on memory and configured I/O cards. a low battery on the PC card. If the BVD2 bit in ) is set to '1' then the interrupt selected by the IRC Card Status Flag Register (see page 18) is also so all to transmit digital audio signals to the host systemerated when the level of SPKR changes and the continuously. | Q_Sx<br>et to<br>tem. | | | | CA[25:0] | 3-state Output<br>4 mA | Card Addre | ss Bus. This | signal directly connects to the P | CMCIA socket's A[25:0] signals. | | | | | CDB[15:0] | I/O<br>4 mA | Card Data i | Bus. This sign | nal directly connects to the PCM | CIA socket's D[15:0] signals. | | | | | CD1, CD2 | Input<br>Schmitt Trigger<br>50 kΩ pull-up | | | ard is present, these signals are<br>er Index 04H and 05H for details | pulled HIGH. An inserted card pulls both of these | e | | | | CE1, CE2 | 3-state Output<br>4 mA | Card Enable. The MSM60802 asserts these signals LOW to enable the PC card for read and write accesses. | | | | | | | | CS1, CS0 | Input<br>50 kΩ pull-down | signals sele<br>Register. For<br>jumpers for | ct the system<br>our addresses<br>selection of | naddresses for the MSM60802 is are selectable via the CSO and ( | signal input is not asserted HIGH, the CS1 and CS<br>Register Select Register and the Data Transfer<br>CS1 pins, allowing users to hard-wire or configuinate also the<br>hat avoid potential address conflicts. See also the | re | | | | | | CSO | CS1 | Address | (Hex) | | | | | | | | | Register Select Register | Data Transfer Register | | | | | | | 0 | 0 | 3E0 | 3E1 | | | | | | | 0 | 1 | 3E2 | 3E3 | | | | | | | 1 | 0 | 240 | 241 | | | | | | | 1 | 1 | 100 | 101 | | | | ## PIN DESCRIPTIONS (Continued) | Pin Name | Direction and<br>Strength | _Description | |-----------------------------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | GPI | Input | General Purpose Input. The MSM60802 images the inverted state of this input pin in bit D7 of the Card Status Register (see page 15). If the GPI_EN bit in the Card Detect and General Control Register (see page 28) is set to '1,' then a transition on this input can generate a card status-change interrupt. The GPI_TC bit in the same register controls the direction of signal change that causes an interrupt. | | INTR | 3-state Output<br>8 mA | Interrupt Request. This active-LOW output should be connected to a system interrupt signal, i.e., the system signal ETSMI. The INTR signal is used to require a maskable interrupt from the system CPU. If the MSM60802 asserts INTR LOW, all other status interrupt requests (IRO's) are disabled. | | IOCHRDY | 3-state Output<br>16 mA | I/O Channel Ready. This active-HIGH output should be connected to the host signal IOCHRDY. When asserted HIGH, this output indicates that the current I/O read or write cycle is completed. If the PCMCIA signal WAIT signal is active, or the MSM60802 is programmed to insert WAIT states, the MSM60802 will reflect this by deasserting the IOCHRDY signal LOW. | | IOCS16 | 3-state Output<br>16 mA | I/O Chip Select.16. This active-LOW output signal should be connected to the host signal IOCS16. The IOCS16 signal is generated either by the MSM60802 or by the PC card. When asserted LOW, this signal indicates that 16-bit I/O cycles can be performed. | | TORC | Input | I/O Read Cycle. This active-LOW input signal should be connected to the host signal IORC. If the accessed address is in the configured and enabled I/O window, the MSM60802 performs a PCMCIA I/O read cycle to the PC I/O card when this signal is asserted LOW. | | IORD | 3-state Output<br>4 mA | 1/O Read. This active-LOW signal indicates that the MSM60802 is performing an VO read access to the PC card. | | IOWC | Input | I/O Write Cycle. This input signal should be connected to the host signal $\overline{10WC}$ . If the accessed address is in the configured and enabled I/O window, the MSM60802 performs a PCMCIA I/O write cycle to the PC I/O card when this signal is asserted LOW. | | IOWR | 3-state Output<br>4 mA | I/O Write. This active-LOW signal indicates that the MSM60802 is performing an I/O write access to the PC card. | | IREQ | input | Interrupt Request. See the signal description for RDY/ BSY (IREQ). | | IRQ[15:14]<br>IRQ[12:9]<br>IRQ[7]<br>IRQ[5:3] | 3-state Output<br>8 mA | Interrupt Request. These output signals should be connected to the equivalent signals of the host system. The PCMCIA interrupt request is routed to one of these interrupt signals. The system can choose the interrupt signal by writing a configuration into IRQ_Cx bits in the Interrupt and General Control Register (see page 17). A status change of the PC card might also force a system interrupt, if this function is enabled in the Card Status Interrupt Configuration Register (see page 19). | | LA[23:17]<br>SA[16:0] | Input | Local Address Bus and System Address Bus. These signals should be connected to the system address bus, SA[16:0] and LA[23:17]. LA23 is the most-significant and SA0 is the least-significant bit. If connected to an 8-bit ISA bus, LA[19:17] should be connected to SA[19:17] of the ISA bus and LA[23:20] must be pulled down. | | MEMCS16 | 3-state Output<br>16 mA | Memory Chip Select 16-Bit. This output signal should be connected to the host signal MEMCS16. The MSM60802 asserts this signal LOW to indicate that a 16-bit memory cycle can be performed. The signal is decoded from the system address and is controlled by the MCS bit in the Address Window Enable Register (see page 20). | | MEMR | Input | System Memory Read. This input signal should be connected to the host signal MEMR. If the accessed address is in the configured and enabled memory window, the MSM60802 performs a PCMCIA memory read cycle to the PC card attribute or common memory when this signal is asserted LOW. | | MEMW | Input | System Memory Write. This input signal should be connected to the host signal MEMW. If the accessed address is in the configured and enabled memory window, the MSM60802 performs a PCMCIA memory write cycle to the PC card attribute or common memory when this signal is asserted LOW. | ## PIN DESCRIPTIONS (Continued) | Pin Name | Direction and<br>Strength | | | Description | | | | |-----------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--| | MODE | Input<br>50 kΩ puil-up | Mode Select. When asserted HIGH, this input makes the $\overline{CSO}$ and $\overline{CSO}$ inputs select addresses for the Registe Select Register and Data Transfer Register. When deasserted LOW, the system addresses for the Register Select Register and the Data Transfer Register are decoded externally. For external decoding, the CS1 input must be tied LOW. See the table below. | | | | | | | | | Mode ( | CSO CS1 | Register Select Re | egister | Data Transfer Register | | | | | 1 | x x | See Sign | nal Description | o for CSO and CS1 | | | | | 0 | 0 1 | A0 = 0 | | A0 = 1 | | | İ | | 0 | 1 1 | Not selected | | Not selected | | | ŌĒ | 3-state Output<br>4 mA | Output Enable. T | his active-LOW sign<br>nemory or attribute | al indicates that the MSN memory. | /160802 is perf | orming a read access to the PC | | | OFFSET [1:0] | input<br>50 kΩ pull-down | Control Registers | s. The table below sl | nals allow four different a<br>nows available offset valu<br>sters' on page 12 for more | es for the regi | s for the MSM60802 Status and ster addresses. Refer to the | | | | | OFFSET1 | OFFSETO | Offset | | | | | | | 0 | Ö | 0 | | | | | | | 0 | 1 | 40 Hex | | | | | | | 1 | 0 | 80 Hex | | | | | | | 1 | 1 | C0 Hex | | | | | OVER_C | Input<br>Schmitt Trigger<br>50 kΩ pull-up | page 28) are set<br>and forces a stat | to '1,' then a failing e<br>us change interrupt | dge at this input switches | off the power | and General Control Register (see supply via the power control pins | | | PWRGD | Input<br>Schmitt Trigger<br>50 kΩ pull-up | supply voltage. It<br>Register (see pa | the system is asser<br>ge 16) is set to '1,' t | ting PWRGD HIGH and the<br>hen the reset signal RSTE | e bit DIS_RES i<br>DRV is ignored | | | | RDY/ BSY (IREQ) | Input | Ready/Busy. On has been forced. When the RDY/B RDY/BSY bit is s Interrupt Reque: | memory cards, the Putling the RDY/BS SY bit in the Card S tet to '1' continuous to On I/O cards, the in the Interrupt and | PC card pulls this signal<br>Y signal clears the RDY/Bi<br>atus Register is set to '1,'<br>by if the socket is configur<br>PC card can request a hos | LOW to indica<br>SY bit in the Ca<br>the PC card is<br>red for I/O ope<br>st system interi<br>see page 17) s | rupt by asserting this signal LOW<br>elect the generated interrupt level | | | REG | 3-state Output<br>4 mA | operations and o<br>signal is general | Irives this signal act<br>ed by the MSM6080 | ve LOW for I/O and attrib | ute memory o<br>bute memory a | t active) for common memory<br>perations. For I/O operations, thi<br>access, the REG bit in the Card | | | RESET | 3-state Output<br>4 mA | Card Reset. The MSM60802 asserts this signal HIGH level to force a hardware reset on the PC card. If the C_RESET bit in the Interrupt and General Control Register (see page 17) is cleared to '0,' then the RESET output is asserted HIGH. Setting the C_RESET bit to '1' deasserts the RESET signal. | | | | | | | RI_OUT | 3-state Output<br>8 mA | signal to the hos | t system that it shou<br>SCHG signal receive | ild switch from sleep mod<br>d from a configured I/O P | le to active mo<br>C card via the | | | | RSTDRV | Input<br>Schmitt Trigger | the MSM60802 | by asserting this sig | nal HIGH. If the Power Go | od signal, PWI | al RSTDRV. The system can rese<br>RGD, is HIGH and the DIS_RES b<br>MSM60802 will ignore RSTDRV. | | ## PIN DESCRIPTIONS (Continued) | Pin Name | Direction and<br>Strength | Description | |----------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SBHE | input | System Bus High Enable. This input signal should be connected to the host signal SBHE. The system drives this signal LOW to indicate that the upper byte of data on the data bus is valid. If this signal is deasserted HIGH, the MSM60802 will only perform 8-bit cycles to the PCMCIA socket. | | SA[16:0] | Input | System Address Bus. See the signal description for LA[23:17]. | | SD[15:0] | I/O<br>8 mA | System Data Bus. These bidirectional signals should be connected to the system data bus, SD[15:0]. | | SPKR | Input | Speaker In. See the signal description for BVD2 (SPKR). | | SPKR_OUT | 3-state Output<br>8 mA | <b>Speaker Out.</b> To perform digital audio functions, this output passes through the signal received at the SPKR input from a configured PC I/O card. The output can be disabled with the D2 bit of the Extension Register (Index OFFH). | | STSCHG | Input | Status Changed. For information, see the signal description for BVD1 (STSCHG). | | SYSCLK | Input | System Clock. This input signal should be connected to the host system's CLOCK signal. The MSM60802 supports clock frequencies in the 4.77-MHz to 8.33-MHz range. The clock frequency effects the timings by changing the pulse width of INTR (three SYSCLK cycles), and the delays for 16-bit MEMR and 16-bit MEMW operations. | | VCC_EN1<br>VCC_EN2 | Output<br>8 mA | V <sub>CC</sub> Power Enable. The MSM60802 asserts this LOW to activate PC card V <sub>CC</sub> power. | | VPP1_EN1<br>VPP1_EN2 | Output<br>8 mA | V <sub>PP1</sub> Power Enable. This signal is active HIGH. | | VPP2_EN1<br>VPP2_EN2 | Output<br>8 mA | V <sub>PP2</sub> Power Enable. This signal is active HIGH | | WAIT | Input | Extend Bus Cycle. The PC card can activate this active-LOW signal to extend a memory or I/O cycle. | | WE | 3-state Output<br>4 mA | Write Enable. This active-low signal indicates a write access to the common memory or attribute memory of the PC card. | | WP<br>(IOIS16) | Input | Write Protect. By pulling this signal high, the PC card indicates that the card is write protected. The MSM60802 will not qualify this signal. To prevent write access, the WP_EN bit in the Card Memory Offset Address High Byte Register has to be set. I/O port is 16-bit. The PC card indicates if a addressed I/O port is capable of 16-bit accesses by asserting this signal LOW. | | <u> </u> | 3-state Output<br>16 mA | Zero WAIT State. This signal (active low) should be connected to the host system signal OWS. It indicates that the system should execute cycles with no extra WAIT states. It is controlled by Ix_ZWS (I/O Control Register) and ZWS (Memory Window x Start Address High Byte Register). | #### **FUNCTIONAL DESCRIPTION** The following information describes the MSM60802 main function blocks. #### **MEM/IO MMU** The Memory Management Unit (MMU) is controlled by the Memory Map Register and decodes the system addresses LA[23:17] and SA[16:0]. If addresses are accessed within a configured memory or I/O window, the memory management unit transfers the access to the PCMCIA socket. For memory address operations, the MMU adds the configured address offset to the system address. #### **Memory Map Register** The Memory Map Registers control MEM/IO MMU. The system address windows must be defined by writing to these registers. Five memory windows and two I/O windows can be defined simultaneously. #### **Control Registers** Control Registers interface between the internal function blocks of the MSM60802 and the host system. By reading or writing the Control Registers, the MSM60802 and the PCMCIA Interface can be configured. To access a control register, the system must at first select this register by writing the register's index number into the Register Select Register. To read or write the selected register, the system must access the Data Transfer Register. Both system addresses of the Register Select Register and the Data Transfer Register are adjustable by two chip select signals. #### **Card Control and Buffers** If the MEM/IO MMU detects a valid memory or I/O cycle to the PC card, the card control and buffers function block generates all necessary control signals, such as card enables, and then connects the data bus to the PC card. This function block also drives signals for switching the PCMCIA socket power supply. #### **Card Status Detect** The Card Status Detect function block monitors the PCMCIA interface status signals state, similar to STSCHG, and automatically sets flags in the control register if a status has change. The interface and card status is imaged in the Card Status Register and in the Card Status Flag Register. #### **Interrupt Routing Control** If a PCMCIA I/O card requests a system interrupt, the Interrupt Routing Control function block transfers this request to a system interrupt signal. The same system interrupt signal must be selected and enabled from the MSM60802 control register. If a PCMCIA status signal changes and Interrupt Routing Control is configured, the function block activates a system interrupt signal. Interrupt routing is controlled by the Interrupt and General Control Register and the Card Status Interrupt Configuration Register. By using control bits in the Global Control Register, the active level and mode (pulse or level interrupt) are selectable. #### **WAIT State Control** The WAIT State Control function block can generate additional WAIT states, if this function is enabled by the system and if the PC card so requests. The WAIT state generator is clocked by the signal SYSCLK. The WAIT State Control functions can be configured in the I/O Control Register and in the Memory Window Start Address High Byte. The PC card memory access signals ( $\overline{OE}$ , $\overline{WE}$ ) can be synchronously delayed by the SYSCLK or the inverted SYSCLK. #### **PC Card Addressing** #### **Memory Operations** The PCMCIA interface can address a total address space of 64 Mbytes of common memory and/or attribute memory. The ISA bus system is capable of addressing a 16-Mbyte memory space. The MSM60802 can map parts of the PCMCIA memory space into the host system's address space. The system can define memory windows by writing the start and the stop address (system address) of the required memory window and an offset into MSM60802 registers. The start address is the first system address of the memory window that the system uses to access the PC card. The stop address is the last system address of the same memory window. The PCMCIA address is calculated by the MSM60802 by adding the offset to the actual system address. If the system address is greater or equal to the window start address and lower or equal to the window stop address, the MSM60802 performs a memory access to the PC card. Figure 1. PC Card Memory Window Addressing Each 4-Kbyte boundary above 64 Kbyte can be used as a memory window start address. The start address must be configured in the Memory Window x Start Address Low Byte and Memory Window x Start Address High Byte register. The stop address must be written to the Memory Window x Stop Address Low Byte and Memory Window x Stop Address High Byte register. The offset must be written into the Card Memory Offset Address x High Byte and Card Memory Offset Address x Low Byte register. Using the MSM60802, the system can configure five of these memory windows simultaneously. Each window can be enabled separately. The card address is calculated as the two's complement of the system address and the offset. Refer to the following table for an example. | lemory Start Address | Memory Stop Address | Offset | PC Card Start Address | PC Card Slop Address | |----------------------|---------------------|--------------|-----------------------|----------------------| | 1Exxx Hex | 1Fxxx Hex | 0xxx Hex | 1Exxx Hex | 1Fxxx Hex | | 1Exxx Hex | 1Fxxx Hex | 1xxx Hex | 1Fxxx Hex | 20xxx Hex | | 1Exxx Hex | 1Fxxx Hex | 3FFE2xxx Hex | 00xxx Hex | 01xxx Hex | When a system memory window is defined by start address and stop address, the whole PC card address space can be addressed by changing the offset. It is not necessary to define the start and stop address again. To access the attribute memory of a PC card, the system must set the $\overline{\text{REG}}$ bit inside the Card Memory Offset Address x High Byte register. Memory windows should not be overlapped. #### I/O Operations For I/O operations, the system is allowed to use each address within the first 64 Kbytes of the system address space. The system must also define a system start address and a system stop address; for I/O operations, however, the MSM60802 adds no offset to the system address. If the system indicates a valid I/O cycle, and if the system address is greater or equal to the defined start address and lower or equal to the defined stop address, the MSM60802 transfers the system address to the PCMCIA socket. The system must write the start address into the I/O Window x Start Address Low Byte and I/O Window x Start Address High Byte Register and the stop address into the I/O Window x Stop Address Low Byte and I/O Window x Stop Address High Byte register. Using the MSM60802, the system can handle two I/O address windows simultaneously. Both windows can be enabled separately. It is possible to open both types of address windows (I/O windows and memory windows) simultaneously. ### REGISTERS ## MSM60802 Control Register Addressing The host system can control the functions and the status of the MSM60802 and connected PCMCIA socked via 50 eight-bit-wide control registers. These control registers inside the MSM60802 are addressed indirectly. To address a register, the register's index must be written into the Register Select Register. By reading or writing the Data Transfer Register, the system can read or change the contents of the selected register. The system addresses of the Register Select Register and of the Data Transfer Register can be determined by the MSM60802 CS1 and CS0 input signals and the MODE signal. | Mode | C80 | CS1 | Register-Select-Register | - Date-Transfer-Register | |------|-----|-----|--------------------------|--------------------------| | 1 | 0 | 0 | 3EO Hex | 3E1 Hex | | 1 | 0 | 1 | 3E2 Hex | 3E3 Hex | | 1 | 1 | 0 | 240 Hex | 241 Hex | | 1 | 1 | 1 | 100 Hex | 101 Hex | | 0 | 0 | 1 | A0 = 0 (external mode) | A0 = 1 (external decode) | | 0 | 1 | 1 | Not selected | Not selected | ### Status and Control Registers The table on the next page shows all status and control registers, and the index that the host must write into the Register Select Register to access them. The OFFSET[1:0] input pins define the offset that must be added to the index address to access the control registers, as shown in the table below. | OFFSET1 | OFFSETO - | Offset | |---------|-----------|--------| | 0 | 0 | 0 | | 0 | 1 | 40 Hex | | 1 | 0 | 80 Hex | | 1 | 1 | C0 Hex | ## **Status and Control Registers** | Index | Direction | Register Name | |--------------|------------|-----------------------------------------| | 00h + Offset | Read only | Revision Number | | Oth + Offset | Read only | Card Status | | 02h + Offset | Read/Write | Card Bus and Power Control | | 03h + Offset | Read/Write | Interrupt and General Control | | O4h + Offset | Read only | Card Status Flag | | O5h + Offset | Read/Write | Card Status Interrupt Configuration | | 06h + Offset | Read/Write | Address Window Enable | | 07h + Offset | Read/Write | I/O Control | | 08h + Offset | Read/Write | I/O Window 0 Start Address Low Byte | | 09h + Offset | Read/Write | I/O Window 0 Start Address High Byte | | OAh + Offset | Read/Write | I/O Window O Stop Address Low Byte | | OBh + Offset | Read/Write | I/O Window O Stop Address High Byte | | OCh + Offset | Read/Write | I/O Window 1 Start Address Low Byte | | 0Dh + Offset | Read/Write | 1/0 Window 1 Start Address High Byte | | OEh + Offset | Read/Write | I/O Window 1 Stop Address Low Byte | | 0Fh + Offset | Read/Write | I/O Window 1 Stop Address High Byte | | 10h + Offset | Read/Write | Memory Window 0 Start Address Low Byte | | 11h + Offset | Read/Write | Memory Window 0 Start Address High Byte | | 12h + Offset | Read/Write | Memory Window 0 Stop Address Low Byte | | 13h + Offset | Read/Write | Memory Window O Stop Address High Byte | | 14h + Offset | Read/Write | Card Memory Offset Address 0 Low Byte | | 15h + Offset | Read/Write | Card Memory Offset Address D High Byte | | 16h + Offset | Read/Write | Card Detect and General Control | | 17h + Offset | Read/Write | Reserved | | 18h + Offset | Read/Write | Memory Window 1 Start Address Low Byte | | 19h + Offset | Read/Write | Memory Window 1 Start Address High Byte | | 1Ah + Offset | Read/Write | Memory Window 1 Stop Address Low Byte | | 1Bh + Offset | Read/Write | Memory Window 1 Stop Address High Byte | | 1Ch + Offset | Read/Write | Card Memory Offset Address 1 Low Byte | | 1Dh + Offset | Read/Write | Card Memory Offset Address 1 High Byte | | 1Eh + Offset | Read/Write | Global Control Register | | 1Fh + Offset | Read/Write | Reserved | | 20h + Offset | Read/Write | Memory Window 2 Start Address Low Byte | | 21h + Offset | Read/Write | Memory Window 2 Start Address High Byte | | 22h + Offset | Read/Write | Memory Window 2 Stop Address Low Byte | | 23h + Offset | Read/Write | Memory Window 2 Stop Address High Byte | | 24h + Offset | Read/Write | Card Memory Offset Address 2 Low Byte | | 25h + Offset | Read/Write | Card Memory Offset Address 2 High Byte | | 26h + Offset | Read/Write | Reserved | ### Status and Control Registers (Continued) | Index | Direction | Register Name | |--------------|------------|-----------------------------------------| | 27h + Offset | Read/Write | Reserved | | 28h + Offset | Read/Write | Memory Window 3 Start Address Low Byte | | 29h + Offset | Read/Write | Memory Window 3 Start Address High Byte | | 2Ah + Offset | Read/Write | Memory Window 3 Stop Address Low Byte | | 2Bh + Offset | Read/Write | Memory Window 3 Stop Address High Byte | | 2Ch + Offset | Read/Write | Card Memory Offset Address 3 Low Byte | | 2Dh + Offset | Read/Write | Card Memory Offset Address 3 High Byte | | 2Eh + Offset | Read/Write | Reserved | | 2Fh + Offset | Read/Write | Reserved | | 30h + Offset | Read/Write | Memory Window 4 Start Address Low Byte | | 31h + Offset | Read/Write | Memory Window 4 Start Address High Byte | | 32h + Offset | Read/Write | Memory Window 4 Stop Address Low Byte | | 33h + Offset | Read/Write | Memory Window 4 Stop Address High Byte | | 34h + Offset | Read/Write | Card Memory Offset Address 4 Low Byte | | 35h + Offset | Read/Write | Card Memory Offset Address 4 High Byte | | 36h + Offset | Read/Write | Reserved | | 37h + Offset | Read/Write | Reserved | | 38h + Offset | Read/Write | Reserved | | 39h + Offset | Read/Write | Reserved | | 3Ah + Offset | Read/Write | Reserved | | 3Bh + Offset | Read/Write | Reserved | | 3Ch + Offset | Read/Write | Reserved | | 3Dh + Offset | Read/Write | Reserved | | 3Eh + Offset | Read/Write | Clock Register | | 3Fh + Offset | Read/Write | Extension Register | ### **CONTROL AND STATUS REGISTERS** This section contains descriptions of the Control and Status Registers. ### **Revision Number Register** Index: 00 Hex The Revision Number Register indicates the release of the MSM60802 (93 Hex). ## **Card Status Register** Index: 01 Hex | Bit(s) | Card Status Register Description | | | | | | |--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | D7<br>GPI | General Purpose Input. This bit images the inverted state of the input signal GPI. | | | | | | | D6<br>V <sub>CC</sub> _S | $V_{CC}$ Power Control. $V_{CC}$ S = 0 indicates that the supply and programming voltages $V_{CC}$ , $V_{PP1}$ and $V_{PP2}$ of the PCMCIA socket are turned off. $V_{CC}$ S = 1 indicates that $V_{CC}$ , $V_{PP1}$ or $V_{PP2}$ are turned on. The value of the voltage is defined in the Card Bus and Power Control Register. | | | | | | | D5<br>RDY/BSY | Ready / Busy. RDY/BSY = 0 indicates that the socket is not ready; access to the PC card is not allowed. RDY/BSY = 1 indicates the PC card is ready and be accessible. If the socket is configured for I/O operations, RDY/BSY is permanently set to '1.' | | | | | | | D4<br>WP | Write Protect. WP = 0 indicates that the inserted memory card is not write protected. WP = 1 indicates that the inserted memory card is write protected. If the socket is configured for I/O operations, the signal is permanently set at '0.' | | | | | | | 03, D2<br>CDx | Card Detect. Card Detect 2 (CD2), Card Detect 1 (CD1). CD1 = 0 indicates that the PCMCIA socket is empty. CD2, CD1 = 1 indicates that a PC card has been inserted into the socket. | | | | | | | D1, D0<br>BVDx | Battery Status. BVD2 (Battery Status 2) and BVD1 (Battery Status 1) indicate the memory card battery state, as shown in the example below. If the PCMCIA interface is configured for I/O operations, BVD2 is permanently set at '1', with BVD1 reflecting the state of STSCHG. | | | | | | | | BVD1 = 0; BVD2 = 0 → Battery Dead<br>BVD1 = 0; BVD2 = 1 → Battery Dead<br>BVD1 = 1; BVD2 = 0 → Battery Low | | | | | | | | BVD1 = 1; BVD2 = 1 → Battery Good | | | | | | ## **Card Bus and Power Control Register** Index: 02 Hex | Bit(s) | Card Bus and Power Control Description | |----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D7<br>BUS_EN | Bus Enable. Set this bit to '0' to switch all control signals, address signals, and data signals to the PCMCIA socket into 3-state mode. If this bit is set to '1,' the bus from the MSM60802 to the PCMCIA socket switches into active mode. | | D6<br>DIS_RES | Disable Reset. The system sets this bit to '0' to force a reset by RSTDRV and to reset all resettable registers. The system sets this bit to '1' for the MSM60802 to ignore the RSTDRV signal, as long as PWRGD is '1.' | | 05<br>V <sub>CC</sub> _AEN | System Address Enable. The system sets this bit to '0' if the supply voltage $V_{CC}$ of the socket must be switched on, by setting $V_{CC}$ _EN = '1'. The system sets this bit to '1' if the socket supply voltage $V_{CC}$ will be automatically switched on after detection of the PC card. | | D4<br>V <sub>CC</sub> _EN1 | V <sub>CC</sub> Power Control. The system sets this bit to '0' to turn off the socket's supply voltage, V <sub>CC</sub> . The system sets this bit to '1' to turn on the socket supply voltage V <sub>CC</sub> . If a card is not detected or the card is removed (CD1, CD2), the power control signals are not active, although VCC_EN1 is not set to '0'. | | 03, 02, D1, D0<br>V <sub>PPx</sub> _Cy | $V_{PPx}$ Power Control. These four register bits are imaged at the PCMCIA power control pins $V_{PPx}$ ENy. The system can control the programming voltage by setting these bits. If both $V_{PPx}$ Cy signals are set, $V_{PPx}$ is turned 'Off.' | ## **Interrupt and General Control Register** Index: 03 Hex | Blt(s) | Interrupt and General Control Description | | | | | | | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---|---|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--| | D7<br>RI_EN | Ring Indicate Enable. Set this bit to '0' to permanently 3-state the output signal $\overline{RI\_OUT}$ . Set this bit to '1' for the STSCHG signal of an I/O card to pass through to the $\overline{RI\_OUT}$ pin (3-state $\rightarrow$ low). | | | | | | | | D6<br>C_RESET | Card Reset. Set this bit to '0' to activate the RESET signal; the PCMCIA socket is then reset continuously. This bit is '0' after a reset of the MSM60802. Set this bit to '1' to disable the PCMCIA socket reset. | | | | | | | | D5<br>C_TYPE | Card Type. If the system sets this bit to '0', the MSM60802 only supports memory cards without any I/O functions. If the system sets this bit to '1', the MSM60802 supports I/O cards. | | | | | | | | D4<br>Intr_en | Interrupt Request Enable. If the system sets this bit to '1', a status change is indicated at the output signal INTR by switching the output from 3-state to 'low' for a minimum of three SYSCLK cycles. | | | | | | | | IRQ_Cx | | nals drive | - | | - • | the <i>"Global Control Register Index: 1E Hex"</i> ) or CIPM (Clock Register), lge-trigger interrupts. Refer to the IRQ_Cx Interrupt Configuration table | | | | 0 | 0 | 0 | 0 | Inactive | | | | | 0 | 0 | 1 | 1 | IRQ3 enabled | | | | | 0 | 1 | 0 | 0 | IRQ4 enabled | | | | | 0 | 1 | 0 | 1 | IRQ5 enabled | | | | | 0 | 1 | 1 | 1 | IRQ7 enabled | | | | | 1 | 0 | 0 | 1 | IRQ9 enabled | | | | | 11 | 0 | 1 | 0 | IRQ10 enabled | | | | | 11 | 0 | 1 | 1 | IRQ11 enabled | | | | | | 1 | 0 | 0 | IRQ12 enabled | | | | | 1 1 | 1 1 | 1 | G | IRQ14 enabled | | | | | l — — | | | | INCHA EHADIEG | | | ## **Card Status Flag Register** Index: 04 Hex Note: If EX\_WB in the Global Control Register is not set to '1', the contents are erased once the system has read the register. The only exception is that OVER\_CH must be erased by explicit write back. | Bit(s) | Card Status Flag Description | | |---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | D5<br>Over_ch | Overcurrent Input. The state of the OVER_C signal has been changed from '1' to '0'. | | | D4<br>GPI_CH | General Purpose Input. The state of the GPI signal has been changed. Refer to the Card Detect and General Control Register on page 28 for details. | | | D3<br>CD_CH | Card Detect. This bit will be set if both card-detect signals CD1 and CD2 are being asserted LOW or if one or both card signals are being asserted HIGH. | | | <b>D2</b><br>ROY_CH | Ready/Busy. The state of the RDY/BSY signal has been changed (rising edge). If the PCMCIA interface is configured for I/O operations, RDY_CH is permanently '0'. | | | D1, D0<br>BVDx_CH | Battery Status. Battery Status 1 (BVD1), Battery Status 2 (BVD2). The state of the BVD2 signal has been changed (falling edge). If the PCMCIA interface is configured for I/O operations, BVD2_CH is permanently '0'. The state of the BVD1 (STSCHG) signal has been changed (falling edge). | | Note: These bits are 'low' until they are enabled in the Card Status Interrupt Configuration Register. ## Card Status Interrupt Configuration Register Index: 05 Hex | Bit(s) | Card Status Interrupt Configuration Description | | | | | | | | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------------------------------|-------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 17, D6, D5, D4<br> IRQ_Sx | Refer to the C<br>the state of LE<br>edge-trigger i | D_EN, RDY<br>EV_EN (refer<br>nterrupts. If | _EN, BVDx_E<br>to the <i>'Globa</i><br>INTR_EN in t | N, OVER_CH,<br>I Control Regi<br>he Interrupt a | and GPI_CH signa<br>"ster Index: 1E Hex | sterrupt signal, which should react on card status changes<br>ils, as well as the configuration table below. Depending on<br>), all IROx signals drive active low interrupts or low to high<br>Register is set, a status change will always be indicated a | | | | | IRQ_\$3 | IRQ_S2 | IRQ_S1 | IRQ_SO | Interrupt Level | _ | | | | | 0 | 0 | 0 | 0 | Inactive | _ | | | | | 0 | 0 | 1 | 1 | IRQ3 enabled | - | | | | | 0 | 1 | 0 | 0 | IRQ4 enabled | - | | | | | 0 | 1 | 0 | 1 | IRQ5 enabled | _ | | | | | 0 | 1 | 1 | 1 | IRQ7 enabled | _ | | | | | 1 1 | 0 | 0 | 1 | IRQ9 enabled | - | | | | | 1 | 0 | 1 | 0 | IRQ10 enabled | _ | | | | | 1 | 0 | 1 | 1 | IRQ11 enabled | <del>-</del> | | | | | 1 | 1 | 0 | 0 | IRQ12 enabled | <del>~</del> | | | | | 1 | 1 | 1 | 0 | IRQ14 enabled | - | | | | | 1 | 1 | 1 | 1 | IRQ15 enabled | <u>-</u> | | | | D3<br>CD_EN | Card Detect Enable. If the level of a card-detect signal changes, the selected interrupt will be requested. | | | | | | | | | <b>D2</b><br>RDY_EN | Ready/Busy. The state of the RDY/BSY signal has been changed (rising edge). If the PCMCIA interface is configured for I/O operations, RDY_CH is permanently '0'. If the level of the RDY/BSY signal changes, the selected interrupt (refer to IRQ_Sx) will be requested. If configured for I/O operations, no interrupt will be requested. | | | | | | | | | D1, DQ<br>BVDx_CH | MSM60802 is | s configured<br>er to <i>IRQ_Sx</i> | for I/O cards<br>) will be requ | , an interrupt<br>ested. If the s | will not be generate | the selected interrupt (refer to <i>IRQ_Sx</i> ) is requested. If the level of the signal BVD1 changes, the selected for I/O card operations, a change of the STSCHG signal | | | ## Address Window Enable Register Index: 06 Hex | Bit(s) | Address Window Enable Description | | | | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | D7<br>IW1_EN | Enable I/O Window 1. Set this bit to '1' for the system to enable I/O window 1 for I/O operations. | | | | | D6<br>IWO_EN | Enable I/O Window 0. Set this bit to '1' for the system to enable I/O window 0 for I/O operations. | | | | | D5<br>MCS | Memory Chip Select. Set this bit to '1' for to generate MEMCS16 by decoding the system address signals LA[23:17] or SA[1 otherwise, the signal is generated by decoding signals LA[23:17]. | | | | | D4<br>MW4_EN | Enable Memory Window 4. Set this bit to '1' for the system to enable memory window 4 which accesses the PC card's comm or attribute memory. | | | | | D3<br>MW3_EN | Enable Memory Window 3. Set this bit to '1' for the system to enable memory window 3 which accesses the PC card's commor attribute memory. | | | | | D2<br>MW2_EN | Enable Memory Window 2. Set this bit to '1' for the system to enable memory window 2 which access the PC card's commattribute memory. | | | | | D1<br>MW1_EN | Enable Memory Window 1. Set this bit to '1' for the system to enable memory window 1 which accesses the PC card's common or attribute memory. | | | | | DO<br>MWO_EN | Enable Memory Window 0. Set this bit to '1' for the system to enable memory window 0 which accesses the PC card's common or attribute memory. | | | | ## I/O Control Register Index: 07 Hex | Bit(s) | I/O Control Description | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D7, D3<br>lx_WAIT | Extend I/O Cycle. If the system sets this bit to '1', the MSM60802 WAIT state generator inserts one extra WAIT state during 16-bit I/O cycles for I/O window x. | | D6, D2<br> x_ZWS | Zero WAIT State. If the system sets this bit to '1', no extra WAIT state is inserted during 8-bit I/O cycles to I/O window x. Output signal OWS will be set active. If SBHE is '0' and SAO is '0' during 8-bit I/O cycles, OWS is not active. | | D5, D1<br>lx_CS16 | Chip Select 16. If the system sets this bit to '0', the output signal 10CS16 images the state of the lx_16BIT in this register. If the system sets this bit to '1', the output signal 10CS16 is generated by the PC card signal 10IS16. | | D4, D0<br>lx_16BIT | 16 Bit I/O. If the system sets this bit to '0', the PC card is accessed as a 8-bit I/O card. If the system sets this bit to '1', the PC card is accessed as a 16-bit I/O card. | # 1/0 Mindow w Start Address Low Byte Indov. 00 Hav (Mindow 1) | BH(s) | i/O Control Description | |---------------------------|----------------------------------------------------------------------------------------| | D7 - D <b>0</b><br>IWS_Ax | I/O Window Low Byte Start. IWS_Ax contains bits [7:0] of the I/O window start address. | ### I/O Window x Start Address High Byte Index: 09 Hex (Window 0) Index: 0D Hex (Window 1) | Bit(s) | I/O Control Description | |---------|------------------------------------------------------------------------------------------| | D7 - D0 | I/O Window High Byte Start. IWS_Ax contains bits [15:8] of the I/O window start address. | | IWS_Ax | | ### I/O Window x Stop Address Low Byte Index: 0A Hex (Window 0) Index: 0E Hex (Window 1) | IWE Ax | | |---------|-------------------------------------------------------------------------------------| | D7 - D0 | I/O Window Low Byte End. IWE_Ax contains bits (7:0) of the I/O window stop address. | | Bit(s) | I/O Centrel Description | ### I/O Window x Stop Address High Byte Index: 0B Hex (Window 0) Index: 0F Hex (Window 1) | Bil(s) | I/O Control Description | |-------------------|---------------------------------------------------------------------------------------| | 07 - D0<br>IWE_Ax | I/O Window High Byte End. IWE_Ax contains bits [15:8] of the I/O window stop address. | ### Memory Window x Start Address Low Byte Index: 10 Hex (Window 1) Index: 18 Hex (Window 2) Index: 20 Hex (Window 3) Index: 28 Hex (Window 4) Index: 30 Hex (Window 5) | Bit(s) | VO Control Description | |--------------------------|---------------------------------------------------------------------------------------| | <b>D7 - D0</b><br>MWS_Ax | Memory Window Start. MWS_Ax contains bits [19:12] of the memory window start address. | ### Memory Window x Start Address High Byte Index: #1 Hex (Window 1) Index: #9 Hex (Window 2) Index: 21 Hex (Window 3) Index: 29 Hex (Window 4) Index: 31 Hex (Window 5) | Bit | Description . | |-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D7<br>MEM16 | Memory Chip Select 16. Set this bit to '0' for 8-bit memory access; MEMCS16 will not be active. Set this bit to '1' for 16-bit memory access; MEMCS16 will be active as in AWE_REG. | | D6<br>ZWS | Zero WAIT State. Set this bit to '0' for the output signal OWS to not be inserted during memory cycles. Set this bit to '1' to activate OWS. If the PC card does not activate the WAIT signal, no extra WAIT state will be inserted. | | D5, D4<br>Scratch | Scratch. For personal use. | | 03 - D0<br>MWS_Ax | Memory Window Start. Contains bits [23:20] of the memory window start address. | ### Memory Window x Stop Address High Byte Index: 13 Hex (Window 1) Index: 1B Hex (Window 2) Index: 23 Hex (Window 3) Index: 2B Hex (Window 4) Index: 33 Hex (Window 5) | Bit | | | Description | | | | |-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------|------------------------------------------------------------|--|--| | D7, D6<br>WSx | WAIT State (WS1, WS0). WS0. Refer to the WSx Co | | | VAIT states during 16-bit memory cycles by setting WS1 and | | | | | WS1 | WSO | WAIT States | | | | | | 0 | 0 | 0 | <del></del> | | | | | 0 | 1 | 1 | <del></del> | | | | | 1 | 0 | 2 | <del>_</del> | | | | | 1 | 1 | 3 | <del></del> | | | | | Note that if the PC card supports WAIT, the PC card inserts WAIT states by itself. The internal WAIT state generator must then be disall by setting WS1 and WS0 to '0'. | | | | | | | D5, D4<br>Scratch | Scratch. For personal use. | | | | | | | D3 - D0<br>MWE_Ax | Memory Window End. Contains bits [23:20] of the memory window stop address. | | | | | | ## **Card Memory Offset Address Low Byte** Index: 14 Hex (Window 1) Index: 1C Hex (Window 2) Index: 24 Hex (Window 3) Index: 2C Hex (Window 4) Index: 34 Hex (Window 5) CO\_Ax contains bits [19:12] of the offset that is added to the system address for memory operations | Bit(s) | I/O Control Description | |-------------------------|-------------------------------------------------------------------------------------------------------------------| | <b>D7 - D0</b><br>CO_Ax | Card Offset. CO_Ax contains bits [19:12] of the offset that is added to the system address for memory operations. | ### **Card Memory Offset Address High Byte** Index: 15 Hex (Window 1) Index: 1D Hex (Window 2) Index: 25 Hex (Window 3) Index: 2D Hex (Window 4) Index: 35 Hex (Window 5) | Bit | Description | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D7<br>WP_EN | Write Protect Enable. Set this bit to '1' to disable write cycles to the PC card. | | D6<br>REG | Register Select. Set this bit to '0' for the system to access the PC card common memory. Set this bit to '1' for the system to access the PC cards attribute memory. | | 05 - D0<br>CO_Ax | Card Offset. CO_Ax contains bits [25:20] of the offset that are added to the system address for memory operations. | ## **Card Detect and General Control Register** Index: 16 Hex | Bit(s) | | Card Detect and | l General Control Register De | scription | | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--| | D7<br>Over_cs | Overcurrent input. If this bit is set to '1' and OVER_EN is also set to '1', a transition at the input pin OVER_C from '1' to '0' will shut down the power supply, via the power control signals. The power supply can be switched on again by resetting the interrupt flag (explicit write back). | | | | | | D6<br>OVER_EN | Overcurrent Enable of this bit is '0.' | . If this bit is set to '1', an OVER_ | Etransition from '1' to '0' will fo | orce a card status change interrupt. The defaul | | | <b>D5</b><br>SWCDI | Card Detect Status Change Interrupt. Setting this bit to '1' causes a card detect status change interrupt. If bit CD_EN is set to '1' before, the SWCDI bit will always be read back as a '0.' | | | | | | D4<br>CDR_EN | Enable Card Detect. If this bit is set to '1' and the MSM60802 sees a card detect change on the CD1 and CD2 inputs, then the MSM60802 clears the RI_OUT output to '0'. The bit CD_CH in the Card Status Flag Register is also set to '1.' An interrupt is not performed. After setting this bit to '1', the MSM60802 asserts the RI_OUT signal LOW until a read access or write access of '1' (explicit write back) to the bit CD_CH in the Card Status Flag Register has been performed. | | | | | | D3<br>GPI_TC | General Purpose Input Transition Control. If this bit is set to '0' and bit D2 in this register, GPI_EN, is set to '1,' then a falling edge at the GPI signal input forces a card status change interrupt. If this bit is set to '1' and GPI_EN is set to '1', a rising edge at the input GPI forces a card status change interrupt. The default is '0.' | | | | | | <b>D2</b><br>GPI_EN | General Purpose Input Enable. If this bit is set to '0', a GPI transition does not force a card status change interrupt. The default is '0.' | | | | | | D1<br>CR_EN | Card Detect Enable. If this bit is set to '1' and the CD1 and CD2 signals are rising, the MSM60802 generates a reset pulse that forces the configuration registers to their default states. SYSCLK does not need to be active to generate an internal reset pulse. Refer to the CR_EN table below, which contains the register defaults after reset. Note that all configuration registers are set to '00 hex' except for those listed in the table. | | | | | | | Index | Register Name | Status | <del></del> | | | | 00h + Offset | Revision Number | No reset | <del></del> | | | | 01h + Offset | Card Status | Not reset | <del></del> | | | | 02h + Offset | Card Bus and Power Control | Not reset except bits VPPxCy | <del></del> | | | | 03h + Offset | Interrupt and General Control | Reset except bit INTR_EN | <del></del> | | | | 06h + Offset | Address Write Enable | Reset except bit MEMCS16 | <del>_</del> | | | | 16h + Offset | Card Detect and General Control | Not reset | | | | | 1Eh + Offset | Global Control Register | Not reset | <del></del> | | | | 3Eh + Offset | Clock Register | Not reset | | | | | 3Fh + Offset | Extension Register | Not reset | | | | <b>DO</b><br>16BD_IN | then SYSCLK does control signals $\overline{OE}$ : | not synchronously delay the card | control signals WE and OF. If t | t Address High Byte Register is also set to '1',<br>his bit is set to '0' and MEM16 is set to '1', the<br>lifter the falling edge of MEMW or MEMR. The | | ## **Global Control Register** Index: 1E Hex ## **Global Control Register Description** | Bit | Description | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D3<br>IRQ14PM | Interrupt Request. If this bit is set to '1' and the bit LEV_EN is set to '0', then the MSM60802 supports a pulsed PC card interrupt request on the IRQ14 output. All other IRQ outputs still support edge-trigger interrupts. If this bit is set to '1' and the bit LEV_EN is set to '1', then all IRQ's will perform level interrupts and can support pulsed PC card interrupt requests. In this case, the IRQ14PM doesn't care. If this bit is set to '0', then IRQ14 performs the same interrupt mode as all the other interrupt lines. Refer to 'PCMCIA Interrupt Request Handling' for details. | | D2<br>EX_WB | Extension Register Write Back. If this bit is set to '1', an active flag in the Card Status Flag Register is reset by writing a '1' into the active bit. If it is set to '0', reading the Card Status Flag Register will set the flag non-active, except OVER_CH that always must be written back. | | D1<br>Lev_en | Low Level Interrupt. If this bit is set to '1', all IRQx outputs perform low-level interrupts. If the interrupt is not active, the interrupt output is in 3-state condition. If this bit is set to '0', the IRQx outputs requests a host interrupt by switching from '0' to '1'. If the interrupt lines are not enabled, the outputs are in a 3-state condition. After the outputs are enabled, they drive '0'. The interrupts are active while the card interrupt request signal is active, or a card status change interrupt is served. The default state of the bit is '0'. | | <b>DO</b><br>POWDW | Power Down Mode. If this bit is set to '1', the internal clock and the memory and I/O windows are disabled. Refer to 'Power-Down Mode' for details. | # Clock Register Index: 3E Hex ## **Clock Register Description** | Bit | Description | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D5, D4<br>WCDx | WAIT State Configuration. Configuration for WAIT state period: WCD1 = 0; WCD0 = 0: WAIT state timing is generated form SYSCLK; WCD1 = 0; WCD0 = 1: WAIT state timing is generated form SYSCLK / 2; WCD1 = 1; WCD0 = 0; WAIT state timing is generated form SYSCLK / 4; WCD1 = 1; WCD0 = 1; WAIT state timing is generated form SYSCLK / 8; | | D3, D2, D1 | Reserved | | DO<br>CIPM | If this bit is set, all IRQ's of MSM60802 are able to transfer a pulse-mode PCMCIA interrupt to the ISA bus without inverter. | ### **Extension Register** Index: 3F Hex | Bit | Extension Register Description | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <b>D7</b><br>ATA_FD | ATA Floppy Disk. If this bit is set to '1', during read cycles to the addresses 3F7h and 377h the MSM60802 only drives the data bus signal SD7. The MSM60802 signals SD[6:0] switch into a 3-state condition (for ATA floppy disk drives) during the cycle. | | D6<br>ATA_HD | ATA Hard Disk. If this bit is set to '1', then the MSM60802 only drive the data bus signals SD[6:0] during read cycles to the addresses 3F7h and 377h. SD7 is switched into a 3-state condition (for ATA hard disk drives). | | D5<br>CLK_INV | Clock Invert. If this bit is set to '0', 16-bit memory cycles are synchronized to the next falling edge of SYSCLK. If the bit is set to '1', 16-bit memory cycles are synchronized to the rising edge of SYSCLK. | | <b>D4</b><br>AUX_DIR | Auxiliary Direction. If this bit is set to '0', AUX is configured as an input. If this bit is set to '1' then the pin is configured as an output. | | D3<br>AUX | Auxiliary. If this bit is read, it indicates the state of the AUX pin. If written and configured as an output, this bit sets the state of the AUX pin. | | D2<br>SPKR_DIS | Speaker Disable. If the PCMCIA interface is configured for I/O operations, a '1' written to this bit disables the SPKR output of the MSM60802. | | D1<br>C_WAIT_<br>DIS | Wait Disable. If this bit is set to '1', the PCMCIA Interface WAIT signal is ignored. | | DO<br>VCC_EN2 | This bit controls the state of V <sub>CC</sub> _EN2 (see the V <sub>CC</sub> _EN1 bit in the Card Bus and Power Control Register at index 02H). | #### **PCMCIA Interrupt Request Handling** Figure 2. PCMCIA Interrupt Request at IRQ[15, 12, 9, 7, 5, 3] and IRQ14 (IRQ14PM = 0) Figure 3. PCMCIA Interrupt Request at IRQ14 (IRQ14PM = 1) #### **Status Interrupt Request Handling** Figure 4. Status Interrupt at IRQ[15, 12, 9, 7, 5, 3] and IRQ14 (IRQ14PM = don't care) #### **Defaults after Reset** After resetting the MSM60802 by the signal RESET, all registers are set to 00 Hex, except the Revision Number Register that is not resettable. #### **Memory Cycle Synchronization** | 16 BQ_IN | GEK_INV | DE or WE at 16-bit Cycles are Synchronized To | |----------|---------|-----------------------------------------------| | 0 | 0 | The next falling edge of SYSCLK | | 0 | 1 | The next falling edge of SYSCLK | | 1 | 0 | The falling edge of MEMWR or MEMRD | | 1 | 1 | The falling edge of MEMWR or MEMRD | #### **Power-Down Mode** Setting the PWRDN bit (in the Global Control Register) to '1' switches the MSM60802 into a power down mode: - All I/O and memory windows are disabled but not reset. - All address and data signals to the PCMCIA socket hold their last driven state before initialization of power-down mode. - All adders and comparators are disabled. - · All registers are available for read and write cycles. - INTR performs a falling edge, but not a pulse, when indicated by status interrupts. - The WAIT state generator and PCMCIA control signals are disabled. ## TIMING CHARACTERISTICS | Parameter | <b>4.</b> | Rated Value | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|--------------|--| | Parameter SYSCLK cycle period | Symbol | Min<br>50 | Max | | | LA(23:17) setup to BALE falling | T1 | 45 | | | | SA[16:0] SHBE setup to BALE falling | T2 | | | | | BALE pulse width | T3 | 20 | | | | LA[23:17] hold from BALE falling | T4 | 50 | | | | CA[25:0] valid from SA[16:0], memory cycle | | 15 | | | | MEMCS16 valid from LA[23:17] | T5 | | 56 | | | MEMCS16 valid from SA[16:0] | T6 | | 40 | | | | T7 | | 32 | | | MEMCS16 hold from LA[23:17] | T8 | 0 | <u> </u> | | | SA[16:0] setup to 16-bit memory command<br>SA[16:0] setup to other commands | Т9 | 25<br>80 | | | | SA[16:0] hold from memory command | T10 | 25 | | | | CA[25:0] from SA[16:0] | T11 | 0 | | | | IOCHRDY low from command | T12 | | 30 | | | IRDY active from falling edge of SYSCLK | T13 | | 30 | | | IOCHRDY valid from WAIT | T14 | | 20 | | | OWS active from command | T15 | | 30 | | | OWS inactive from command | T16 | | 30 | | | OE, WE active from command, active for 8-bit and 16-bit memory cycles if the bit 16BD_IN in the Card Detect and General Control Register is set. Otherwise, OE AND WE for 16-bit memory cycles are synchronized with SYSCLK | T17 | | 25 | | | OE, WE inactive from command inactive | T18 | | 25 | | | CE, REG valid from SA[16:0] | T19 | | 40 | | | CE, REG hold from SA[16:0] | T20 | 0 | | | | SD[15:0] active from read command active | T21 | 0 | | | | SD[15:0] hold from read command inactive | T22 | 0 | | | | SD[15:0] delay from SD[15:0] | T23 | | 30 | | | CD[15:0] 3-state from read command active | T24 | | 25 | | | CD[15:0] delay from SD[15:0] | T25 | | 30 | | | CD[15:0] hold from write command inactive | T26 | 35 | | | | SD[15:0] hold from write command inactive | T27 | 20 | | | | CD[15:0] driving from read command inactive | T28 | 150 | | | | AEN setup to command active | T38 | 45 | | | | AEN hold from command inactive | T39 | 25 | | | | SA[16:0] setup to I/O command | T40 | 80 | | | | SA[16:0] hold from I/O command | T41 | 25 | <del>-</del> | | | CA[25:0] valid from SA[16:0] I/O cycle | T42 | 25 | | | | IORD, IOWR active from command active | T43 | | 25 | | | IORD, IOWR inactive from command inactive | T44 | | 25 | | ## TIMING CHARACTERISTICS (Continued) | | | Rated Value | | | |-------------------------------------------------------------------------------|--------|-------------|-----|------| | Parameter | Symbol | Min | Max | Unit | | IOCS16 valid from SA[16:0] | T45 | | 35 | | | IOCS16 hold from SA[16:0] | T46 | 0 | | | | IOCS16 delay from IOIS16 | T47 | | 20 | | | SD[7:0] valid from read command to internal register of the MSM60802 | T50 | | 80 | | | SD[7:0] hold from read command inactive | T51 | 0 | | | | SD[7:0] setup to write command to internal register of the MSM60802 | T52 | 50 | | | | SD[7:0] hold from write command inactive to internal register of the MSM60802 | T53 | 20 | | | | CSO active to internal register access | T54 | 30 | | | | CSO hold from internal register access | T55 | 0 | | - | | RI_OUT delay from STSCHG | T60 | | 30 | | | Card power supply switched off after OVER_C, when OVER_EN and OVER_CS are set | T61 | | 50 | | | IROx delay from REQ | T62 | | 30 | | | INTR delay from card status change | T63 | | 50 | | | INTR pulse width | T64 | 3*SYSCLK | | | | ROx delay from card status change | T65 | | | 50 | | SPKR_OUT delay from SPKR | T66 | | | 30 | ## **TIMING WAVEFORMS** Figure 5. 8/16 Bit I/O Cycles Figure 6. 8-Bit Access to MSM60802 Internal Registers Figure 7. SPKR, STCHG, OVER\_C and Interrupt Timing