## IBM PS/2<sup>®</sup> Model P70 Supplement for the Hardware Interface and BIOS Interface Technical References March 20, 1990 Part Number 15F2150 Form Number S15F-2150-00 #### instructions - 1. Use the Personal System/2® Model P70 Technical Reference with the IBM Personal System/2 Hardware Interface Technical Reference. - 2. Use the PS/2 Model P70 BIOS Supplement, located at the back of this package, with the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference. Nodel Pro Technical Reference ### Second Edition (March, 1990) The following paragraph does not apply to the United Kingdom or any country where such provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or implied warranties in certain transactions, therefore, this statement may not apply to you. This publication could include technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this publication at any time. It is possible that this publication may contain reference to, or information about, IBM products (machines and programs), programming, or services that are not announced in your country. Such references or information must not be construed to mean that IBM intends to announce such IBM products, programming, or services in your country. THE PUBLICATION OF THE INFORMATION CONTAINED HEREIN IS NOT INTENDED TO AND DOES NOT CONVEY ANY RIGHTS OR LICENSES, EXPRESS OR IMPLIED, UNDER ANY IBM PATENTS, COPYRIGHTS, TRADEMARKS, MASK WORKS OR ANY OTHER INTELLECTUAL PROPERTY RIGHTS. Requests for copies of this publication and for technical information about IBM products should be made to your IBM Authorized Dealer or your IBM Marketing Representative. Personal System/2 is a registered trademark of the International Business Machines Corporation. © Copyright International Business Machines Corporation 1988, 1990. All rights reserved. No part of this work may be reproduced or distributed in any form or by any means without prior permission in writing from the IBM Corporation. ## **Preface** The Technical Reference library is intended for those who develop hardware and software products for IBM Personal Computers and IBM Personal System/2. Users should understand computer architecture and programming concepts. This technical reference provides hardware and software interface information for the IBM Personal System/2 Model P70 and should be used with the following publications: IBM Personal System/2 Hardware Interface Technical Reference IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference This manual consists of the following sections: Section 1, "System Overview," describes the system, features, and specifications. Section 2, "Programmable Option Select," describes the registers used for configuration. Section 3, "System Board," describes the system-specific hardware implementations. Section 4, "Video Subsystem," describes the function of the plasma display and the display adapter card. Warning: The term "Reserved" describes certain signals, bits, and registers that should not be changed. Use of reserved areas can cause compatibility problems, loss of data, or permanent damage to the hardware. When the contents of a register are changed, the state of the reserved bits must be preserved. When possible, read the register first and change only the bits that must be changed. For information about components or devices not described in this manual, refer to the *Hardware Interface Technical Reference*. Information about diskette drives, fixed disk drives, adapters, and external options are in separate option technical references. ## **Notes:** # Contents | Section 1. System Overview | 1-1 | |---------------------------------------------------------|------| | Description | 1-3 | | System Board Features | 1-3 | | System Board Block Diagram | | | System Board I/O Address Map | 1-6 | | Specifications | 1-7 | | Dimensions for Micro Channel Adapter | 1-11 | | Section 2. Programmable Option Select | 2-1 | | Description | 2-3 | | POS Address Map | 2-5 | | Card Selected Feedback | 2-6 | | System Board Setup | | | System Board Enable/Setup Register (Hex 0094) | 2-7 | | System Board POS Register 2 (Hex 0102) | | | System Board POS Register 3 (Hex 0103) | 2-9 | | System Board POS Register 4 (Hex 0104) | 2-11 | | Memory Presence Detect | 2-12 | | Adapter Enable/Setup Register (Hex 0096) | 2-13 | | Section 3. System Board | 3-1 | | Description | 3-3 | | 80387 Math Coprocessor | 3-3 | | Micro Channel | | | Matched-Memory Cycles | 3-3 | | Central Arbiter | 3-4 | | Diskette Drive and Fixed Disk Connectors | 3-7 | | Memory | 3-11 | | Read-Only Memory Subsystem | 3-11 | | Random Access Memory Subsystem | 3-12 | | Error Recovery | 3-13 | | Memory Subsystem Control | 3-14 | | System Memory Maps | 3-17 | | System Board Memory Connectors | | | Real-Time Clock/Complementary Metal-Oxide Semiconductor | | | RAM | 3-24 | | Miscellaneous System Functions | 3-36 | | Nonmaskable Interrupt | | | System Control Port B (Hex 0061) | 3-36 | | System Control Port A (Hex 0092 | 2) | <br> | | | | | | 3-38 | |---------------------------------|----|------|------|--|--|--|--|-------| | Power-On Password | | | | | | | | | | Hardware Compatibility | | <br> | | | | | | 3-41 | | Error Codes | | | | | | | | | | Section 4. Video Subsystem | | <br> | <br> | | | | | 4-1 | | Description | | <br> | <br> | | | | | . 4-3 | | Plasma Display | | | | | | | | | | Plasma Display Adapter | | | | | | | | | | Overview | | | | | | | | | | Video Mode | | | | | | | | | | Programming Considerations . | | | | | | | | | | Auto-dim function | | | | | | | | | | Distinctive-mapping | | | | | | | | | | Half-toning (Dithering) | | | | | | | | | | Connectors and Signals | | | | | | | | | | Index | | <br> | <br> | | | | | . X-1 | ## Figures | 1-1. | Model and Submodel Bytes | 1-3 | |---------------|-----------------------------------------------|--------| | 1-2. | System Board Devices and Features | 1-4 | | 1-3. | System Board | | | 1-4. | System Board I/O Address Map | 1-6 | | 1-5. | Performance Specifications - Type 1 | 1-7 | | 1 <b>-</b> 6. | Performance Specifications - Type 2 | 1-8 | | 1-7. | Physical Specifications | 1-9 | | 1-8. | Acoustical Readings | . 1-10 | | 1-9. | Adapter Dimensions (Half-Length) | . 1-12 | | 1-10. | Adapter Retainer | . 1-13 | | 1-11. | Typical Adapter Assembly | . 1-15 | | 1-12. | Permissive Areas (Full-Length Adapter) | . 1-16 | | 1-13. | Permissive Areas (Half-Length Adapter) | . 1-17 | | 2-1. | POS I/O Address Map | | | 2-2. | Card Selected Feedback Register (Hex 0091) | 2-6 | | 2-3. | System Board Enable/Setup Register (Hex 0094) | | | 2-4. | System Board POS Register 2 (Hex 0102) | 2-7 | | 2-5. | Parallel Port Select Bits | 2-8 | | 2-6. | System Board POS Register 3 (Read-Only) | 2-9 | | 2-7. | System Board POS Register 3 (Write-Access) | . 2-10 | | 2-8. | Read Port with Bit 2 Set to 0 | . 2-10 | | 2-9. | Read Port with Bit 2 Set to 1 | . 2-10 | | 2-10. | System Board POS Register 4 (Hex 0104) | . 2-11 | | 2-11. | Presence Detect Bits | . 2-12 | | 2-12. | Adapter Enable/Setup Register (Hex 0096) | . 2-13 | | 3-1. | Arbitration Bus Priority Assignments | 3-4 | | 3-2. | Arbitration Register (Hex 0090)-Write | 3-5 | | 3-3. | Arbitration Register (Hex 0090)-Read | 3-5 | | 3-4. | Internal Diskette Drive Connector | 3-8 | | 3-5. | External Storage Device Connector | 3-9 | | 3-6. | Fixed Disk Connector | . 3-10 | | 3-7. | Memory Error Address Reassignment | . 3-13 | | 3-8. | Memory Encoding Register 1 (Hex 00E1) | . 3-14 | | 3-9. | Memory Encoding Register 2 (Hex 00E0) | . 3-16 | | 3-10. | System Memory Map 1 | . 3-17 | | 3-11. | System Memory Map 2 | . 3-18 | | 3-12. | System Memory Map 3 | . 3-18 | | 3-13. | System Memory Map 4 | . 3-19 | | 3-14. | System Memory Map 5 | . 3-19 | | 3-15. | System Memory Map 6 | 3-20 | |-------|--------------------------------------------------|-------| | 3-16. | System Memory Map 7 | 3-20 | | 3-17. | System Memory Map 8 | 3-21 | | 3-18. | System Board Memory Connector | 3-22 | | 3-19. | Presence Detect Encoding | 3-23 | | 3-20. | RT/CMOS RAM Address Map | 3-24 | | 3-21. | RT/CMOS Address Register and NMI Mask (Hex 0070) | 3-25 | | 3-22. | RT/CMOS Data Register (Hex 0071) | 3-25 | | 3-23. | Real-Time Clock Bytes | 3-27 | | 3-24. | Status Register A | 3-28 | | 3-25. | Status Register B | 3-28 | | 3-26. | Status Register C | 3-30 | | 3-27. | Status Register D | 3-30 | | 3-28. | Diagnostic Status Byte | 3-31 | | 3-29. | Diskette Drive Type Byte | 3-32 | | 3-30. | Diskette Drive Type Byte (Bits 7 - 4) | 3-32 | | 3-31. | Diskette Drive Type Byte (Bits 3 - 0) | 3-33 | | 3-32. | Equipment Byte | 3-34 | | 3-33. | Equipment Byte (Bits 7, 6) | 3-34 | | 3-34. | Equipment Byte (Bits 5, 4) | 3-34 | | 3-35. | System Control Port B (Write) | 3-37 | | 3-36. | System Control Port B (Read) | 3-37 | | 3-37. | System Control Port A | 3-38 | | 3-38. | POST Error Message Table | 3-43 | | 4-1. | Block Diagram | . 4-4 | | 4-2. | BIOS Video Modes | . 4-5 | | 4-3. | Auto-Dim Block Diagram | . 4-6 | | 4-4. | Plasma Display Adapter Connector | . 4-8 | | 4.5 | Plaema Dienlay Connector | 4-10 | ## Section 1. System Overview | Description | | | | | | | - | | 1-3 | |--------------------------------------|--|--|--|--|------|--|---|--|-----| | System Board Features | | | | | <br> | | | | 1-3 | | System Board Block Diagram | | | | | | | | | | | System Board I/O Address Map | | | | | | | | | | | Specifications | | | | | | | | | | | Dimensions for Micro Channel Adapter | | | | | | | | | | ## **Notes:** ### **Description** The IBM Personal System/2 Model P70 is a self-contained, portable computer system with a built-in keyboard and a built-in plasma display. It is equipped with one diskette drive and one fixed disk drive. And it can support one external storage device additionally. A system can have either a Type 1 or Type 2 system board. The major difference between the system boards is system clock speed. Programs identify the type by reading the model and submodel bytes. Interrupt hex 15, function code (AH) = hex C0, returns the model and submodel bytes. The following shows these bytes, system board type, and system clock speeds. | Figure | 1-1. Model a | nd Submodel B | ytes | | |---------------|------------------|------------------|--------------|--------------| | Model<br>Byte | Submodel<br>Byte | Revision<br>Code | System Board | System Clock | | F8 | 50 | 00 | Type 1 | 16 MHz | | F8 | 0B | 00 | Type 2 | 20 MHz | Refer to the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference for a listing of other systems, and check the supplements section for updates to that listing. ## **System Board Features** The following figure lists the system board devices and features. The Hardware Interface Technical Reference describes devices common to PS/2 products by type number. | Device | Туре | Features | |--------------------------------------|------|---------------------------------------------------------------------------------| | Microprocessor | | 80386 | | | | 32-bit address and 32-bit data interface | | System Timers | 1 | Channel 0 - System timer | | | | Channel 2 - Tone generation for speaker | | | | Channel 3 - Watchdog timer | | ROM Subsystem | | 128KB (KB = 1024 bytes) | | RAM Subsystem | | System board, 2 to 8MB (Type 1) | | | | 4 to 8MB (Type 2) | | | | (MB = 1,048,576 bytes) | | | | Expandable on the channel | | CMOS RAM Subsystem | | 64-byte CMOS RAM with | | • | | real-time clock/calendar | | | | 2KB CMOS RAM extension | | | | Battery backup | | Audio Subsystem | 1 | Driven by: | | | | e. Custom times about of 0 | | | | <ul> <li>System-timer channel 2</li> <li>The 'audio sum node' signal</li> </ul> | | DMA Controller | 1 | Eight independent DMA channels | | DMA Controller | ' | • | | | | Single or burst transfers and read<br>verification | | Interrupt Controller | 1 | 16 levels of system interrupts | | interrupt Controller | • | Interrupts are level-sensitive | | Kashaard/Auxilians | 1 | Keyboard connector | | Keyboard/Auxiliary Device Controller | ' | Auxiliary device connector | | Device Controller | | Password security | | Diskette Drive | 1 | Supports: | | Controller | ' | Supports. | | CORPONE | | <ul> <li>720KB formatted diskette density</li> </ul> | | | | <ul> <li>1.44MB formatted diskette density</li> </ul> | | | | Auxiliary connector for an external storage | | | | device | | Serial Controller | 2 | RS-232C interface | | | _ | Programmable as serial port 1 or 2 | | | | FIFO mode and character mode | | Parallel Controller | 1 | Programmable as parallel port 1, 2, or 3 | | | • | Supports bidirectional input and output | | Micro Channel | | Two channel connectors: | | | | | | | | One 16-bit connector for half-length | | | | adapter card | | | | One 32-bit connector with | | | | matched-memory extension | | Math Coprocessor | | Supports 80387 math coprocessor | | Socket | | Same clock speed as the system | | | | microprocessor | | Power Supply | 1 | 110 and 220 Vac support | ## **System Board Block Diagram** Figure 1-3. System Board Note: Additional memory can be added in the 32-bit Micro Channel connectors. However, the total amount of memory installed should not exceed the 16MB addressing limit of the DMA controller. ## System Board I/O Address Map | Figure 1-4. System Board I/O Address Map | | | | | | | | |------------------------------------------|------------------------------------|--|--|--|--|--|--| | Hex Addresses | Device | | | | | | | | 0000 - 001F | DMA Controller (0-3) | | | | | | | | 0020, 0021 | Interrupt Controller (Master) | | | | | | | | 0040, 0042 - 0044, 0047 | System Timers | | | | | | | | 0060 | Keyboard, Auxiliary Device | | | | | | | | 0061 | System Control Port B | | | | | | | | 0064 | Keyboard, Auxiliary Device | | | | | | | | 0070, 0071 | RT/CMOS and NMI Mask | | | | | | | | 0081 - 0083, 0087 | DMA Page Registers (0-3) | | | | | | | | 0089 - 008B, 008F | DMA Page Registers (4-7) | | | | | | | | 0090 | Central Arbitration Control Point | | | | | | | | 0091 | Card Selected Feedback Register | | | | | | | | 0092 | System Control Port A | | | | | | | | 0094 | System Board Enable/Setup Register | | | | | | | | 0096 | Adapter Enable/Setup Register | | | | | | | | 00A0 - 00A1 | Interrupt Controller (Slave) | | | | | | | | 00C0 - 00DF | DMA Controller (4-7) | | | | | | | | 00E0, 00E1 | Memory Encoding Registers | | | | | | | | 00F0 - 00FF | Math Coprocessor | | | | | | | | 0100 - 0107 | Programmable Option Select | | | | | | | | 0278 - 027B | Parallel Port 3 | | | | | | | | 02F8 - 02FF | Serial Port 2 (RS-232C) | | | | | | | | 0378 - 037B | Parallet Port 2 | | | | | | | | 03B4, 03B5, 03BA | Video Subsystem | | | | | | | | 03BC - 03BF | Parallel Port 1 | | | | | | | | 03C0 - 03C5 | Video Subsystem | | | | | | | | 03C6 - 03C9 | Video DAC | | | | | | | | 03CA, 03CC, 03CE, 03CF | Video Subsystem | | | | | | | | 03D4, 03D5, 03DA | Video Subsystem | | | | | | | | 03F0 - 03F7 | Diskette Drive Controller | | | | | | | | 03F8 - 03FF | Serial Port 1 (RS-232C) | | | | | | | | 3510 - 3518 | Fixed Disk Drive Controller | | | | | | | ## Specifications | | Number | | |-----------------------------------------------|-------------|--------------------| | Device | of<br>Waits | Cycle<br>Time (ns) | | Microprocessor (16 MHz - 62.5 ns Clock): | | | | Access to System Board RAM: * | | | | Memory Read (Page Hit) | 0 | 125 | | Memory Read (Page Miss) | 2 | 250 | | Memory Write (Page Hit) | 1 | 187.5 | | Memory Write (Page Miss) | 2 | 250 | | Access to Channel: | _ | | | Default Transfer Cycle | 2 | 250 | | Extended Transfer Cycle | 4 | 375 | | Refresh Rate | | 625 (min) | | (Typically performed every 15.1 μs) | | | | Bus Master Access to System Board RAM | | 300 (min) | | DMA Controller (8 MHz - 125 ns Clock): | | | | Single Transfer: 300 + I/O Access + Memory | Access | | | Burst Transfers: 300 + (I/O Access + Memory | Access)N ** | | | System Board Memory Access | | 375 | | Default Transfer Cycle | | 250 | | Extended Transfer Cycle | | 375 | | Adapters installed in the channel should no | t rely | | | on monitoring system board memory acces | ses | | | because channel memory control signals m | ay not | | | be present during these accesses. | | | | ** N is the number of transfers in the burst. | | | | Figure 1-6. Performance Specifications | Type 2 | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--------------------| | Device | Number<br>of<br>Waits | Cycle<br>Time (ns) | | Microprocessor (20 MHz - 50 ns Clock): | | | | Access to System Board RAM: * | | | | Memory Read (Page Hit) | 0 | 100 | | Memory Read (Page Miss) | 2 | 200 | | Memory Write (Page Hit) | 1 | 150 | | Memory Write (Page Miss) | 2 | 200 | | Access to Channel: | | | | Default Transfer Cycle | 2 | 200 | | Extended Transfer Cycle | 4 | 300 | | Refresh Rate | | 500 (min) | | (Typically performed every 15.1 $\mu$ s) | | | | Bus Master Access to System Board RAM | | 300 (min) | | DMA Controller (10 MHz - 100 ns Clock): | | | | Single Transfer: 300 + 1/O Access + Memor | y Access | | | Burst Transfers: 300 + (I/O Access + Memo | ry Access)N * * | | | System Board Memory Access | | 300 | | Default Transfer Cycle | | 200 | | Extended Transfer Cycle | | 300 | | <ul> <li>Adapters installed in the channel should not<br/>memory accesses because channel memory<br/>present during these accesses.</li> <li>N is the number of transfers in the burst.</li> </ul> | | | | Figure | 1-7. | <b>Physical</b> | Specifications | |--------|------|-----------------|----------------| |--------|------|-----------------|----------------| Size: Width 465 mm (18.3 in) Depth 126 mm ( 5.0 in) Height 305 mm (12.0 in) Air Temperature: System On 10.0 to 35.0°C (50 to 95°F) System Off 5.0 to 60.0°C (41 to 140°F) **Humidity:** System On 8% to 80% System Off 5% to 95% Maximum Attitude 2133.6 m (7000 ft) Heat Output 150 W **Acoustical Readings** See Figure 1-8 on page 1-10 Electrical: Power Supply Input: Low Range 90 (min) - 137 (max) Vac High Range 180 (min) - 264 (max) Vac Maximum Current Draw: Low Range 2.4 A High Range 1.2 A Frequency 50 ±3Hz/60 ±3 Hz Maximum Current Allowable: Keyboard Port 275 mA Auxiliary Device Port 300 mA Electromagnetic Compatibility FCC Class B / VCCI Class 2 / VDE GOP | Descripti | ion | L <sub>WAd</sub> in t | | L <sub>pAm</sub> in o | iB<br>Idle | <l<sub>pA&gt;<sub>m</sub><br/>Operate</l<sub> | in dB<br>kdle | | | | |-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|----------|-----------------------|------------|-----------------------------------------------|-----------------------------|--|--|--| | Model P7 | 70 | 5.2 | 5.0 | 45 | 40 | 39 | 37 | | | | | Notes: | | | | | | | | | | | | L <sub>WAd</sub> | is | the declar | red sour | nd power le | evel for | the randor | n sample of machines. | | | | | L <sub>pAm</sub> | L <sub>pAm</sub> is the mean value of the A-weighted sound pressure levels at the operator position (if any) for the random sample of machines. | | | | | | | | | | | <l<sub>pA&gt;<sub>m</sub></l<sub> | | | | | • | sound press<br>ample of m | sure levels at the achines. | | | | | These me | asu | rements a | re preli | minary dat | a and s | subject to cl | nange. | | | | Figure 1-8. Acoustical Readings ## **Dimensions for Micro Channel Adapter** The system board provides channel connectors to support the following types of adapters. - 16 bit adapter (half-length) - 32 bit adapter (full-length) The following figures show the dimensions of the half-length adapter card and it's retainer. The other dimensions (ie. connector dimensions, holder dimensions) are as same as the standard size (full-length) adapter card's dimensions which are described in the "Hardware Interface Technical Reference". Figure 1-9. Adapter Dimensions (Half-Length) Figure 1-10 (Part 1 of 2). Adapter Retainer Figure 1-10 (Part 2 of 2). Adapter Retainer MATERIALS: HOLDER AND RETAINER-POLYCARBONATE UL 94 V-0 BRACKET-ANSI TYPE 302 1/4 HARD STAINLESS STEEL Figure 1-11. Typical Adapter Assembly Figure 1-12. Permissive Areas (Full-Length Adapter) - Permissible Retainer height to be 17mm max, on the component side. - [2] Plug Cable to be bent by 90" in the shaded area. Figure 1-13. Permissive Areas (Half-Length Adapter) # Section 2. Programmable Option Select | Description | 2-3 | |-----------------------------------------------|------| | POS Address Map | 2-5 | | Card Selected Feedback | 2-6 | | System Board Setup | | | System Board Enable/Setup Register (Hex 0094) | | | System Board POS Register 2 (Hex 0102) | | | System Board POS Register 3 (Hex 0103) | | | POS Register 3 as a Read-Only Port | | | POS Register 3 as a Read/Write Port | | | System Board POS Register 4 (Hex 0104) | | | Memory Presence Detect | 2-12 | | Adapter Enable/Setup Register (Hex 0096) | 2-13 | ## **Notes:** ## **Description** Programmable Option Select (POS) eliminates the need for switches by replacing their function with programmable registers. This section describes the POS information used on the Model P70 system boards. For additional POS information, refer to the *Hardware Interface Technical Reference*. ### Warning: - IBM recommends that programmable options be set only through the System Configuration utilities. Directly setting the POS registers or CMOS RAM POS parameters can result in multiple assignment of the same system resource, improper operation of the feature, loss of data, or possible damage to the hardware. - Application programs should not use the adapter identification (ID) unless absolutely necessary. Compatibility problems can result. - If an adapter and the system board are in setup mode at the same time, bus contention will occur, no useful programming can take place, and damage to the hardware can occur. - After setup operations are complete, the Adapter Enable/Setup register (hex 0096) should be set to hex 00, and the System Board Enable/Setup register (hex 0094) should be set to hex FF. - The channel reset bit (bit 7) in the Adapter Enable/Setup register must be 0 to program the adapters. - The system board does not support 32-bit or 16-bit I/O operations on 8-bit POS registers. Only 8-bit transfers are supported for setup operations. - Using 32-bit or 16-bit I/O instructions on 8-bit POS registers will cause erroneous data to be written or read. Setup functions respond to I/O addresses hex 0100 through 0107 only when their unique setup signal is active. The following precautions must be taken before setting individual bits in the POS registers. #### Video Subsystem Setup: - The Adapter Enable/Setup register (hex 0096) must be set to hex 0B to setup the Video Subsystem. - Bit 7 in the System Board Enable/Setup register (hex 0094) must be set to 1 to avoid driving a 'setup' signal to system board functions. #### Adapter Setup: - Bit 3 in the Adapter Enable/Setup register must be set to 1 to allow adapter setup. - Bit 7 in the System Board Enable/Setup register must be set to 1 to avoid driving a 'setup' signal to a system board function. ### System Board Setup: - Bit 7 in the System Board Enable/Setup register must be set to 0 to allow setup of other system board functions. - Bit 3 in the Adapter Enable/Setup register must be set to 0 to avoid driving a 'setup' signal to an adapter. ## **POS Address Map** The following figure shows the organization of the I/O address space used by POS. Bit 0 of POS Register 2 and bits 6 and 7 of POS Register 5 are fixed. All other bits in POS Registers 2 through 5 are free-form. | Figure 2-1. POS I/O Address Map | | | | | |---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Address<br>(Hex) | Function | | | | | 0094 | System Board Enable/Setup Register | | | | | 0096 | Adapter Enable/Setup Register | | | | | 0100 | POS Register 0—Adapter Identification Byte (Low Byte) | | | | | 0101 | POS Register 1—Adapter Identification Byte (High Byte) | | | | | 0102 | POS Register 2—Option Select Data Byte 1 Bit 0 is Card Enable. | | | | | 0103 | POS Register 3—Option Select Data Byte 2 | | | | | 0104 | POS Register 4—Option Select Data Byte 3 | | | | | 0105 | POS Register 5—Option Select Data Byte 4 Bit 7 is the channel check active indicator Bit 6 is the channel check status-available indicator | | | | | 0106 | POS Register 6—Subaddress Extension (Low Byte) | | | | | 0107 | POS Register 7—Subaddress Extension (High Byte) | | | | ### **Card Selected Feedback** When an adapter is addressed, it responds by setting the '-card selected feedback' signal (-CD SFDBK) to active. -CD SFDBK is derived from the address decode and driven by a totem pole driver. It is latched by the system board and can be read through the Card Selected Feedback register at address hex 0091. Diagnostic and automatic configuration programs use this signal to verify the operation of an adapter at a given address or DMA port. This signal must not be active during a setup cycle. The Card Selected Feedback register is a read-only register at address hex 0091. It allows programs to monitor —CD SFDBK and thereby determine if the video subsystem, system board I/O, or an adapter is addressed and functioning. | Figure 2-2. C | ard Selected Feedback Register (Hex 0091) | | |---------------|-------------------------------------------|--| | Bit | Function | | | 7 - 1 | Reserved | | | 0 | -Card Selected Feedback | | | | | | #### Bits 7 - 1 Reserved. Bit 0 This bit is set to 1 whenever -CD SFDBK was active on a previous cycle or whenever the system board I/O functions (diskette drive, serial, or parallel interfaces) are accessed by an I/O cycle. Reading this register resets the bit to 0. ## **System Board Setup** The integrated I/O functions on the system board use POS information during setup. The diskette drive controller, serial port, and parallel port are treated as a single device. The video subsystem is also an integrated part of the system board, however, POS treats it as a separate device. The System Board Enable/Setup register is used to place the system board or the video subsystem into the setup mode. ### System Board Enable/Setup Register (Hex 0094) This is a read/write register; all bits in this register default to 1 (enabled). | Figure 2-3. S | ystem Board Enable/Setup Register (Hex 0094) | |---------------|----------------------------------------------| | Bit | Function | | 7 | Enable/-Setup System Board Functions | | 6 - 0 | Reserved | Bit 7 When this bit is set to 0, various system board I/O functions are placed in the setup mode. The diskette drive controller, serial port, and parallel port are controlled through System Board POS Register 2 (hex 0102). When this bit is set to 1, the system board function is enabled. Bits 6 - 0 Reserved. ### System Board POS Register 2 (Hex 0102) When the system board is in the setup mode, the diskette drive controller, serial port, and parallel port are controlled by this read/write register. Reading this register returns the current state of these system board functions. | Bit | Function | | |------|-------------------------------------|--| | 7 | Disable Parallel Port Extended Mode | | | 6, 5 | Parallel Port Select | | | 4 | Enable Parallel Port | | | 3 | Serial Port Select | | | 2 | Enable Serial Port | | | 1 | Enable Diskette Drive Interface | | | 0 | Enable System Board | | Bit 7 When set to 0, this bit allows the parallel port to be configured as an 8-bit, parallel, bidirectional interface. When set to 1, this bit disables the bidirectional mode. This bit is set to 0 at power-on and POST sets it to 1. Bits 6, 5 These bits select the configuration of the system board parallel port. | Figure | 2-5. Pa | arallel Port Select I | Bits | | |--------|-------------|-----------------------|-------------|-----------------| | | Bits<br>6 5 | Assignment | Hex Address | Interrupt Level | | | 00 | Parallel 1 | 03BC - 03BF | 7 | | | 0 1 | Parallel 2 | 0378 - 037B | 7 | | | 10 | Parallet 3 | 0278 - 027B | 7 | | | 11 | Reserved | | - | - Bit 4 When this bit and bit 0 are set to 1, the system board parallel port is enabled. - Bit 3 When set to 1, this bit sets the system board serial port as Serial 1 (addresses hex 03F8 through 03FF), which uses interrupt level 4. When set to 0, this bit sets the serial port as Serial 2 (addresses hex 02F8 through 02FF), which uses interrupt level 3. - Bit 2 When this bit and bit 0 are set to 1, the system board serial port is enabled. - Bit 1 When this bit and bit 0 are set to 1, the diskette drive interface is enabled. - Bit 0 When set to 1, this bit allows bits 4, 2, and 1 to enable and disable their respective devices. When set to 0, this bit disables the diskette drive interface, system board serial port, and system board parallel port, regardless of the state of bits 4, 2, and 1. # System Board POS Register 3 (Hex 0103) This read-only register is accessed while the system board is in the setup mode. It contains information about the presence and type of memory card installed in each system board connector. The memory connectors are numbered 1-2-3-4 from top to bottom as viewed from the rear of the system. How this information is stored and retrieved depends on whether the port is read-only or read/write. To determine the type of port, with a memory card in connector 1, set bit 2 of port hex 103 to 1, and then read port hex 103. If bit 0 of this byte is 0, the port is read-only (card present in connector 1); if bit 0 is 1, the port is read/write. #### POS Register 3 as a Read-Only Port | Bit | Function | |-----|----------------------------| | 7 | Reserved | | 6 | 2MB Card, Connector 3 | | 5 | -Card Present, Connector 3 | | 4 | Reserved | | 3 | 2MB Card, Connector 2 | | 2 | -Card Present, Connector 2 | | 1 | 2MB Card, Connector 1 | | 0 | -Card Present, Connector 1 | - Bits 7, 4 These bits are reserved. - Bits 6, 3, 1 Each bit indicates the type of memory card installed in the connector indicated. When set to 1, the bit indicates that the card installed is a 2MB memory card. - Bits 5, 2, 0 When set to 0, each bit indicates that a memory card is installed in the connector indicated. #### POS Register 3 as a Read/Write Port | Figure 2-7. System Board POS Register 3 (Write-Access) | | | | |--------------------------------------------------------|--------------------|--|--| | Bit | Function | | | | 7 - 3 | Reserved | | | | 2 | -Connector 1 and 2 | | | | 1, 0 | Reserved | | | #### Bits 7 - 3 These bits are reserved. Bits 2 This bit selects the connector information returned when port hex 0103 is read. When this bit is set to 0, the information for connectors 1 and 2 is shown. This bit is write only. Bits 1, 0 These bits are reserved. | Function | | |------------------------------------|---| | Presence Detect 3 - 0, Connector 1 | | | Presence Detect 3 - 0, Connector 2 | | | | • | When bit 2 is set to 1, connector 3 information is shown. | Figure | igure 2-9. Read Port with Bit 2 Set to 1 | | |--------|------------------------------------------|------------------------------------| | 8 | sit | Function | | 7 | - 4 | Presence Detect 3 - 0, Connector 3 | | 3 | - 0 | Presence Detect 3 - 0, Connector 4 | | 3 | - 0 | Fresence Detect 5 - 0, Connector 4 | Each set of four bits shows the state of the presence detect signals for that connector (see "Memory Presence Detect" on page 2-12). # System Board POS Register 4 (Hex 0104) This read-only register is used in the same way as the POS register 3 (hex 0103). | Figure 2-10. System Board POS Register 4 (Hex 0104) | | | |-----------------------------------------------------|----------------------------|--| | Bit | Function | | | 7 - 4 | Reserved | | | 3 | 2MB Card, Connector 4 | | | 2 | -Card Present, Connector 4 | | | 1 - 0 | Reserved | | - Bits 7 4 These bits are reserved, and must be 1. - Bit 3 This bit indicates the type of memory installed in connector 4. When set to 1, this bit indicates that the card installed is the 2MB memory card. - Bit 2 When set to 0, this bit indicates that a memory card is installed in connector 4. - Bits 1 0 These bits are reserved, and must be 1. #### Note: The above bit definitions (Bits 0 through 7) are in effect only when the system board POS register 3 (hex 0103) is a read-only port (see "System Board POS Register 3 (Hex 0103)" on page 2-9). If the system board POS register 3 (hex 0103) is a read/write port, all bits are reserved. # **Memory Presence Detect** The presence detect signals are used by the system to determine size and speed of memory on the memory card. The pins are either connected to ground or not connected. A set of four bits shows the state of all presence detect signals for a specific memory connector; the bit is 0 when the signal is ground. The following table shows the information indicated by these bits. All combinations other than the following are reserved. | Figure | 2-11. Presence Detect Bits | | | tect Bits | | | |--------|----------------------------|---|----------|----------------|------------------|--| | | | | enc<br>1 | ce Detect<br>0 | Function | | | | 0 | 1 | 0 | 1 | 2MB 85-ns Memory | | # Adapter Enable/Setup Register (Hex 0096) The Adapter Enable/Setup register selects the connector to be configured. | Bit | Symbol | |-------|----------------------| | 7 | Channel Reset | | 6 - 4 | Reserved | | 3 | Card Setup Enable | | 2 - 0 | Channel Select 2 - 0 | - Bit 7 When set to 1, this bit activates the 'channel reset' signal to all connectors. - Bits 6 4 These bits are reserved. - Bit 3 When set to 1, this bit enables the '-card setup' signal selected by bits 2 through 0. - Bits 2 0 These bits are the address bits for the '—card setup' signal. Connectors 1 through 2 are addressed as 0 through 1, respectively. The fixed disk connector is addressed as 2, and the plasma display adapter connector is addressed as 3. When bit 3 is set to 1, these bits select the connector that is put into setup mode. Each channel connector has a unique '—card setup' signal (—CD SETUP) associated with it. This signal is used to put the adapters in the setup mode, which allows access to the POS registers. The individual connectors are selected through the Adapter Enable/Setup register. Setup information is then read from or written to the selected adapter through I/O addresses hex 0100 through 0107. #### Notes: - -CD SETUP only goes active when an operation is performed in the I/O address range hex 0100 through 0107. - 2. The status of port hex 0096 can be read by software. However, when the port is read, bits 6, 5, and 4 are set to 1. # Section 3. System Board | Description | | |---------------------------------------------------------|-------| | 80387 Math Coprocessor | 3-3 | | Micro Channel | 3-3 | | Matched-Memory Cycles | 3-3 | | Central Arbiter | 3-4 | | Arbitration Bus Priority Assignments | . 3-4 | | Central Arbiter Programming | 3-5 | | Diskette Drive and Fixed Disk Connectors | 3-7 | | Internal Diskette Drive Connector | 3-8 | | External Storage Device Connector | 3-9 | | Fixed Disk Drive Connector | | | Memory | 3-11 | | Read-Only Memory Subsystem | 3-11 | | Random Access Memory Subsystem | | | Error Recovery | | | Memory Subsystem Control | 3-14 | | Memory Encoding Register 1 (Hex 00E1) | 3-14 | | Memory Encoding Register 2 (Hex 00E0) | 3-16 | | System Memory Maps | 3-17 | | System Board Memory Connectors | 3-22 | | Real-Time Clock/Complementary Metal-Oxide Semiconductor | | | RAM | 3-24 | | RT/CMOS Address Register and NMI Mask (Hex 0070) | | | RT/CMOS Data Register (Hex 0071) | 3-25 | | RT/CMOS RAM I/O Operations | 3-26 | | Real-Time Clock Bytes (Hex 000-00D) | 3-27 | | CMOS RAM Configuration | 3-31 | | Miscellaneous System Functions | 3-36 | | Nonmaskable Interrupt | 3-36 | | System Control Port B (Hex 0061) | 3-36 | | System Control Port A (Hex 0092) | | | Power-On Password | | | Hardware Compatibility | | | Error Codes | 3-43 | | | | # **Notes:** # **Description** This section describes the math coprocessor, channel differences, memory subsystems, and miscellaneous system ports and connectors for the Model P70. For additional information about these and other topics, refer to the *Hardware Interface Technical Reference*. # 80387 Math Coprocessor The 16 MHz 80387 Math Coprocessor is matched to the speed of the Type 1 system microprocessor and operate in the synchronous mode. The 20 MHz 80387 is matched to the Type 2 system. # **Micro Channel** This section describes the implementation of the Micro Channel architecture on Model P70 systems. For general Micro Channel information, refer to the *Hardware Interface Technical Reference*. # **Matched-Memory Cycles** The 32-bit channel connector has a matched-memory extension. The system microprocessor activates the '--matched memory cycle' signal (-MMC) when it does a memory access. This allows the Model P70 to support the same memory adapter design as the PS/2 Model 80 system board. Although a memory adapter can respond to -MMC active by driving the '-matched memory cycle request' signal (-MMCR) active, the Model P70 system board ignores -MMCR and performs a default cycle if the 'channel ready' signal (CD CHRDY) is active, or a synchronous-extended cycle if CD CHRDY is inactive. The Model P70 also drives the '-matched memory cycle command' signal active at the same time as the '-command' signal. #### **Central Arbiter** The central arbitration control point gives intelligent subsystems on the channel the ability to share and control the system. It allows burst data transfers and prioritization of control between devices. This arbiter supports up to 16 arbitrating devices. #### **Arbitration Bus Priority Assignments** The following figure shows the assignment of arbitration levels. The functions with the lowest arbitration level have the highest priority. | ARB<br>Level | Primary<br>Assignment | | | |--------------|--------------------------------------------------------|--|--| | -2 | Memory Refresh | | | | -1 | NMI | | | | 0 | DMA Channel 0 (Programmable to any arbitration level ) | | | | 1 | DMA Channel 1 | | | | 2 | DMA Channel 2 | | | | 3 | DMA Channel 3 | | | | 4 | DMA Channel 4 (Programmable to any arbitration level) | | | | 5 | DMA Channel 5 | | | | 6 | DMA Channel 6 | | | | 7 | DMA Channel 7 | | | | 8 - E | Available | | | | F | System Microprocessor | | | Note: Devices designed for arbitration level 0 or 1 should have limited bandwidth or short bursts so diskette overruns can be prevented or recovered by retry operations. The diskette drive controller, on arbitration level 2, can be held inactive by devices on levels 0 and 1, by a refresh operation, and by the previous controlling master. The diskette drive controller should not be held inactive for more than 12 microseconds to prevent overrun. NMI service is executed at a priority level higher than 0, called -1. Memory refresh is prioritized at -2, two levels higher than 0. Levels -1 and -2 are reached on the system board only, while the 'arbitrate/-grant' signal is in the arbitrate state. When the central arbitration control point receives a level -1 request (NMI, a system-board internal signal), it activates \_PREEMPT, waits for the end of transfer, and then places ARB/\_GNT in the arbitrate state, which denies channel activity to arbitrating devices. The central arbitration control point gives the grant to the level -1 request, and holds ARB/\_GNT in the arbitrate state until the operation is complete and the NMI is reset. #### Central Arbiter Programming The central arbitration control point provides access to programmable options through the Arbitration register, which is accessed at I/O address hex 0090. The bits are defined differently for read and write operations, as shown in the following figures. | Figure 3-2. Al | oitration Register (Hex 0090)-Write | | | |----------------|-------------------------------------|--|--| | Bit | Definition | | | | 7 | Enable System Microprocessor Cycle | | | | 6 | Arbitration Mask | | | | 5 | Enable Extended Arbitration | | | | 4 - 0 | Reserved | | | | Figure 3-3. A | Arbitration Register (Hex 0090)-Read | | | |---------------|-------------------------------------------------------|--|--| | Bit | Definition | | | | 7 | Enable System Microprocessor Cycle | | | | 6 | Arbitration Masked by NMI | | | | 5 | Bus Time-out | | | | 4 | Reserved | | | | 3 - 0 | Value of Arbitration Bus During Previous Grant State. | | | Bit 7 Setting this bit to 1 enables system microprocessor cycles during arbitration cycles. This bit can be set to 0 if an arbitrating device requires total control of the channel bandwidth. This bit is set to 0 by a system reset. Reading this bit as a 1 indicates system microprocessor cycles are enabled during arbitration. Bit 6 Setting this bit to 1 causes the central arbitration control point to enter the arbitration state. The system microprocessor controls the channel until this bit is reset to 0. This bit is set to 0 by a system reset. Reading this bit as a 1 indicates that an NMI has occurred and has masked arbitration. Warning: This bit should be set to 1 only by diagnostic routines and system error-recovery routines. Setting this bit to 1 enables extended arbitration. The Bit 5 minimum arbitration cycle is 300 nanoseconds; this bit extends that minimum cycle to 600 nanoseconds. This bit is set to 0 during a system reset. > Reading this bit as a 1 indicates that a bus time-out has occurred, and resets bit 6 in this register to 0. - This bit is reserved and should be 0. Rit 4 - These bits are undefined for a write operation and should Bits 3 - 0 be set to 0. Reading these bits returns the arbitration level of the arbiter controlling the channel during the most recent grant state. This information allows the system microprocessor to determine the arbitration level of the device that caused a bus time-out. # **Diskette Drive and Fixed Disk Connectors** The system board has a 2- by 17-pin connector for one internal diskette drive, a 30-pin connector for external diskette drive, and a 2-by 36-pin connector for internal fixed disk drive. The internal diskette drive connector passes control and data signals between the internal diskette drive and the diskette drive controller on the system board. Micro Channel signals necessary for fixed disk operations are present on the fixed disk connector. The external diskette drive attaches to the 30-pin connector, which passes the necessary signals from the diskette drive controller. When in the setup mode, the fixed disk is addressed as channel connector 3 through the Adapter Enable/Setup register. For more information about this register, see "POS Information" in the *Hardware Interface Technical Reference*. For more POS information about the fixed disk drive, refer to the technical reference for that drive. #### Internal Diskette Drive Connector The following figure shows the signal assignment and pin numbering for the internal diskette drive connector on the system board. The internal diskette drive connector is a 2- by 17-pin connector that is numbered with the odd numbers on the top. | Pin | 1/0 | Signal | Pin | 1/0 | Signal | |-----|-----|----------------------|-----|-----|----------------------| | 1 | 1 | -2nd Drive Installed | 2 | 0 | -High Density Select | | 3 | 0 | +5 Vdc | 4 | N/A | Reserved | | 5 | N/A | Ground | 6 | 0 | +12 Vdc | | 7 | N/A | Signal Ground | 8 | 1 | -Index | | 9 | N/A | Signal Ground | 10 | N/A | Reserved | | 11 | N/A | Signal Ground | 12 | 0 | -Drive Select | | 13 | N/A | Ground | 14 | N/A | Reserved | | 15 | N/A | Signal Ground | 16 | 0 | -Motor Enable | | 17 | N/A | Signal Ground | 18 | 0 | -Direction In | | 19 | N/A | Signal Ground | 20 | 0 | -Step | | 21 | N/A | Signal Ground | 22 | 0 | -Write Data | | 23 | N/A | Signal Ground | 24 | 0 | -Write Enable | | 25 | N/A | Signal Ground | 26 | 1 | -Track 0 | | 27 | N/A | Signal Ground | 28 | 1 | -Write Protect | | 29 | N/A | Signal Ground | 30 | 1 | -Read Data | | 31 | N/A | Signal Ground | 32 | 0 | Head 1 Select | | 33 | N/A | Signal Ground | 34 | 1 | -Diskette Change | ## **External Storage Device Connector** The following figure shows the signal assignment and pin numbering for the external storage device connector on the system board. This external storage device connector is a 30-pin connector located at the rear of the system unit. The system can support an external diskette drive through this connector. | Pin | 1/0 | Signal | Pin | 1/0 | Signal | |-----|-----|-------------|-----|-----|-------------------------| | 1 | N/A | Ground | 2 | 1 | -Second Drive Installed | | 3 | N/A | Ground | 4 | 0 | -Reduced Write Curren | | 5 | N/A | Ground | 6 | N/A | Reserved | | 7 | N/A | Ground | 8 | 1 | -Index | | 9 | 0 | -Motor On 1 | 10 | 0 | -Drive Select 1 | | 11 | N/A | Reserved | 12 | N/A | Reserved | | 13 | N/A | Ground | 14 | 0 | -Direction | | 15 | N/A | Ground | 16 | 0 | –Step | | 17 | N/A | Ground | 18 | 0 | -Write Data | | 19 | N/A | Ground | 20 | 0 | –Write Gate | | 21 | N/A | Ground | 22 | I | -Track 00 | | 23 | N/A | Ground | 24 | 1 | -Write Protect | | 25 | N/A | Ground | 26 | 1 | -Read Data | | 27 | N/A | Ground | 28 | 0 | -Side 1 Select | | 29 | N/A | Ground | 30 | ı | –Diskette Change | #### **Fixed Disk Drive Connector** The following figure shows the signal assignment and pin numbering for the fixed disk drive connector on the adapter. The fixed disk drive connector is a 2- by 36-pin connector. Side A of the connector is the top and Side B is the bottom. | Side A | | | • | Sic | de B | |--------|-----|-------------|-----|-----|-----------| | Pin | 1/0 | Signal | Pin | I/O | Signal | | 1 | 0 | -CD SETUP | 1 | 0 | A15 | | 2 | 0 | A13 | 2 | 0 | A14 | | 3 | N/A | Ground | 3 | N/A | Ground | | 4 | 0 | A11 | 4 | N/A | Reserved | | 5 | 0 | A10 | 5 | N/A | Ground | | 6 | 0 | A09 | 6 | 0 | A12 | | 7 | 0 | +5 Vdc | 7 | 0 | -CMD | | 8 | 0 | A08 | 8 | Ī | -CD SFDBK | | 9 | 0 | A07 | 9 | N/A | Ground | | 10 | 0 | A06 | 10 | 1/0 | D01 | | 11 | N/A | Ground | 11 | I/O | D03 | | 12 | 0 | A05 | 12 | 1/0 | D04 | | 13 | 0 | A04 | 13 | N/A | Ground | | 14 | 0 | A03 | 14 | 0 | CHRESET | | 15 | 0 | +5 Vdc | 15 | 1/0 | D08 | | 16 | 0 | A02 | 16 | 1/0 | D09 | | 17 | 0 | A01 | 17 | N/A | Ground | | 18 | 0 | A00 | 18 | 1/0 | D12 | | 19 | 0 | +12 Vdc | 19 | 1/0 | D14 | | 20 | 0 | -ADL | 20 | 1/0 | D15 | | 21 | 1 | -PREEMPT | 21 | N/A | Ground | | 22 | 1 | -BURST | 22 | 1/0 | D00 | | 23 | 0 | +5 Vdc | 23 | 1/0 | D02 | | 24 | 1 | ARB 00 | 24 | 1/0 | D05 | | 25 | 1 | ARB 01 | 25 | N/A | Ground | | 26 | 1 | ARB 02 | 26 | I/O | D06 | | 27 | N/A | +12 Vdc | 27 | 1/0 | D07 | | 28 | I | ARB 03 | 28 | I/O | D10 | | 29 | 0 | ARB/-GNT | 29 | N/A | Ground | | 30 | 0 | -TC | 30 | I/O | D11 | | 31 | N/A | +5 Vdc | 31 | 1/0 | D13 | | 32 | 0 | -S0 | 32 | 0 | -SBHE | | 33 | 0 | <b>-\$1</b> | 33 | N/A | Ground | | 34 | 0 | M/10 | 34 | I | -CD DS 16 | | 35 | N/A | Ground | 35 | İ | -IRQ 14 | | 36 | 1 | CD CHRDY | 36 | N/A | Ground | # **Memory** Model P70 systems use the following types of memory: - Read-only memory (ROM) - Random access memory (RAM) - Real-time Clock and CMOS RAM. # **Read-Only Memory Subsystem** The ROM subsystem consists of 128KB. ROM is active at power-on at address space hex 000E0000 to 000FFFFF and hex FFFE0000 to FFFFFFFF. After POST ensures the proper operation of system memory, the ROM code is copied to RAM at the same address space, and ROM is disabled. ROM is assigned the top of the first and last 1MB of address space (000E0000 and FFFE0000). ROM or RAM access at address space hex 000E0000 to 000FFFFF is controlled by the ROMEN bit in Memory Encoding Register 1 (hex 00E1). When enabled, ROM is not parity-checked and operates with four wait states. One wait state takes 62.5 nanosecond in the Type 1 system and 50 nanosecond in the Type 2 system. # **Random Access Memory Subsystem** The RAM subsystem on the system board starts at address hex 00000000 of the address space. Memory is attached to the system board by four connectors. The RAM subsystem is 36 bits wide: 32 data bits and 4 parity bits. One parity bit is generated for each byte of data written. During a read operation, one parity bit is checked for each byte of data read by the device controlling the bus. The Model P70 enables and disables memory in 1MB blocks. Each 1MB block must start on a 1MB boundary. Because 128KB of I/O ROM, and 128KB of video memory are mapped within the first 1MB address space, an overflow is created from the first 1MB of RAM installed in the system. The first 1MB of RAM can be split at either 512KB or 640KB; the memory from the split to the start of the RAM that contains the ROM code is called the *split memory block*. This split memory block can be disabled, or it can be remapped to the first address following the last 1MB of memory. Split memory block remapping and disabling are controlled by the memory encoding registers. Note: Additional memory can be added in either of the 32-bit Micro Channel connectors. The total amount of memory installed should not exceed the 16MB addressing limit of the DMA controller. # **Error Recovery** If POST detects a memory error in the first 512KB of memory, the first physical 1MB block of memory is deactivated. The addresses assigned to the deactivated block are reassigned to the second physical block of system board memory (the first 1MB of system memory must reside in connector 1 or 2). If 1MB of valid memory cannot be allocated from connector 1 or 2, the system cannot recover from the error. The first 1MB of memory address space cannot be assigned to memory on the channel. POST does not deactivate a memory block if an error is detected in the second 512KB of that block. If an error is detected in that area of memory, the 1MB block containing the error can be deactivated and have its addresses reassigned by running the customer-level memory diagnostics program on the Reference Diskette supplied with the system. Once a block of memory is deactivated, it is ignored by POST on subsequent power-ons. Figure 3-7. Memory Error Address Reassignment # **Memory Subsystem Control** These read/write registers define and control the ROM and RAM subsystems. #### Memory Encoding Register 1 (Hex 00E1) This register determines how the first 1MB of memory is addressed and is used with Memory Encoding Register 2 to determine the amount of system board memory enabled. | Bit | Function | | |-----|-------------|--| | 7 | -Card 2 EN2 | | | 6 | -Card 2 EN1 | | | 5 | -Card 1 EN2 | | | 4 | -Card 1 EN1 | | | 3 | -ENSPLIT | | | 2 | -640 | | | 1 | ROMEN | | | 0 | ENPLRPCH | | - Bits 7, 6 These bits define system board memory in connector 2. When they are set to 0, bit 6 enables the first 1MB block and bit 7 enables the second 1MB block. - Bits 5, 4 These bits define system board memory in connector 1. When they are set to 0, bit 4 enables the first 1MB block and bit 5 enables the second 1MB block. - Bit 3 This bit determines whether the split-memory block is assigned addresses or is disabled. The top 128KB of the first 1MB is always mapped into the ROM address space and the code in ROM is copied into this space. When this bit is set to 0, the split-memory block is enabled. The split-memory block size is dependent on the value of the 640 bit. Its address is determined in Memory Encoding Register 2. When this bit is set to 1, the split-memory block is disabled. Note: If the total system memory is equal to or greater than 16MB, the split-memory block cannot be used. Bit 2 This bit determines where the first active 1MB of memory is split. When this bit is set to 0, the system maps 640KB of the first 1MB to address hex 00000000 to 0009FFFF. The split-memory block, 256KB, is mapped to the address specified in Memory Encoding register 2. When this bit is set to 1, the system maps 512KB of the first 1MB to address hex 00000000 to 0007FFFF. The split-memory block, 384KB, is mapped to the address specified in the Memory Encoding register 2. The addresses hex 00080000 to 0009FFFF are unassigned. Bit 1 This bit determines how addresses hex 000E0000 to 000FFFFF are assigned. When this bit is set to 1, ROM is enabled and the read-access addresses are assigned to ROM; the write-access addresses are assigned to RAM. When this bit is set to 0, ROM is disabled and read addresses are assigned to RAM; the write addresses are disabled while ROM is disabled. **Note:** When this bit is set to 1, system performance will be substantially slower because of 16-bit accesses to ROM and a longer cycle. Bit 0 When set to 0, this bit enables parity checking of system board memory. For compatibility with other systems, enabling and disabling of parity checking should be done through System Control B at address hex 0061 (see "System Control Port B (Hex 0061)" on page 3-36). #### Memory Encoding Register 2 (Hex 00E0) This register is used with Memory Encoding Register 1 to determine the amount of system board memory that is enabled. It also contains the address for the split-memory block. | Figure 3-9. Memory Encoding Register 2 (Hex 00E0) | | | |---------------------------------------------------|-------------|--| | Bit | Function | | | 7 | -Card 4 EN2 | | | 6 | -Card 4 EN1 | | | 5 | -Card 3 EN2 | | | 4 | Card 3 EN1 | | | 3 | SPA23 | | | 2 | SPA22 | | | 1 | SPA21 | | | 0 | SPA20 | | - Bits 7, 6 These bits define the system board memory in connector 4. When they are set to 0, bit 6 enables the first 1MB block and bit 7 enables the second 1MB block. - Bits 5, 4 These bits define the system board memory in connector 3. When they are set to 0, bit 4 enables the first 1MB block and bit 5 enables the second 1MB block. - Bits 3 0 These bits define the starting address of the split-memory block. When split memory is enabled, these bits determine its starting address. The starting location can be at any 1MB boundary from 1MB to 15MB. # **System Memory Maps** Memory is mapped by the Memory Encoding registers. The mapping results in either 512KB or 640KB of system board RAM starting at address hex 00000000. A 256-byte and 1KB portion and of this RAM is reserved as BIOS data areas. See the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference for details. In the following figures, the variable X represents the number of 1MB blocks of system board memory starting at or above the hex 00100000 boundary. The variable Y represents the number of 1MB blocks of memory installed in the channel starting at or above the hex 00100000 boundary (Y = 0 to 15). The following figure shows the memory mapping when: Enable Split bit = 1 640 bit = 1 ROM enable bit = 1 | Hex Range | Function | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00000000 to 0007FFFF 00080000 to 0009FFFF 000A0000 to 000BFFFF 000C0000 to 000DFFFFF 00100000 to (00100000 + XMB) (00100000 + XMB) to (00100000 + X MB + YMB) (00100000 + XMB + YMB) to FFFDFFFF FFFE0000 to FFFFFFFFF | 512KB System Board RAM Not Used 128KB Video RAM Channel ROM 128KB System Board ROM X MB System Board RAM YMB Channel RAM Not Used 128KB System Board ROM (Same as 000E0000 to 000FFFFF) | Enable Split bit = 1 640 bit = 0ROM enable bit = 1 | Hex Range | Function | | |----------------------------------------------|------------------------|--| | 00000000 to 0009FFFF | 640KB System Board RAM | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to $(00100000 + XMB + YMB)$ | YMB Channel RAM | | | (00100000 + XMB + YMB) to FFFDFFFF | Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | | | (Same as 000E0000 to | | | | 000FFFFF) | | ### The following figure shows the memory mapping when: Enable Split bit = 0 640 bit = 1 ROM enable bit = 1Split address bits = 1 + X + Y (Total Range = 1 to 15). | Figure 3-12. System Memory Map 3 | | | |-----------------------------------------------------------------|--------------------------------|--| | Hex Range | Function | | | 00000000 to 0007FFFF | 512KB System Board RAM | | | 00080000 to 0009FFFF | Not Used | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to<br>(00100000 + XMB + YMB + 384KB - 1) | 384KB System Board RAM | | | (00100000 + XMB + YMB + 384KB) to FFFDFFFF | Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | | | (Same as 000E0000 to 000FFFFF) | | Enable Split bit = 0 640 bit = 0 ROM enable bit = 1 Split address bits = 1 + X + Y (Total Range = 1 to 15). | Figure 3-13. System Memory Map 4 | | | |-----------------------------------------------------------------|-------------------------------------------------------------|--| | Hex Range | Function | | | 00000000 to 0009FFFF | 640KB System Board RAM | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to<br>(00100000 + XMB + YMB + 256KB - 1) | 256KB System Board RAM | | | (00100000 + XMB + YMB + 256KB) to FFFDFFF | Not Used | | | FFFE0000 to FFFFFFFF | 128KB System Board ROM<br>(Same as 000E0000 to<br>000FFFFF) | | # The following figure shows the memory mapping when: Enable Split bit = 1 640 bit = 1 ROM enable bit = 0 | Figure 3-14. System Memory Map 5 | | | |---------------------------------------------|-----------------------------------------|--| | Hex Range | Function | | | 00000000 to 0007FFFF | 512KB System Board RAM | | | 00008000 to 0009FFFF | Not Used | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM<br>mapped to RAM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to FFFDFFFF | Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | Enable Split bit = 1 640 bit = 0ROM enable bit = 0 | Hex Range | Function | | |---------------------------------------------|-----------------------------------------|--| | 00000000 to 0009FFFF | 640KB System Board RAM | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM<br>mapped to RAM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to FFFDFFF | Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | #### The following figure shows the memory mapping when: Enable Split bit = 0 640 bit = 1 ROM enable bit = 0 Split address bits = 1 + X + Y (Total Range = 1 to 15). | Hex Range | Function | | |--------------------------------------------------------------|-----------------------------------------|--| | 00000000 to 0007FFFF | 512KB System Board RAM | | | 00080000 to 0009FFFF | Not Used | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128KB System Board ROM<br>mapped to RAM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to (00100000 + XMB + YMB + 384KB - 1) | 384KB of First 1MB at Split<br>Address | | | (00100000 + XMB + YMB + 384KB) to FFFDFFFF | Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | Enable Split bit = 0640 bit = 0ROM enable bit = 0 Split address bits = 1 + X + Y (Total Range = 1 to 15). | Figure 3-17. System Memory Map 8 | | | |----------------------------------------------------------------------------------------------------------|----------------------------------------------------|--| | Hex Range | Function | | | 00000000 to 0009FFFF | 640KB System Board RAM | | | 000A0000 to 000BFFFF | 128KB Video RAM | | | 000C0000 to 000DFFFF | Channel ROM | | | 000E0000 to 000FFFFF | 128K System Board ROM<br>mapped to RAM | | | 00100000 to (00100000 + XMB) | X MB System Board RAM | | | (00100000 + XMB) to (00100000 + X MB + YMB) | YMB Channel RAM | | | (00100000 + XMB + YMB) to (00100000 + XMB + YMB + 256KB-1)<br>(00100000 + XMB + YMB + 256KB) to FFFDFFFF | 256KB of First 1MB at<br>Split Address<br>Not Used | | | FFFE0000 to FFFFFFF | 128KB System Board ROM | | | PPPEOUVO LO PPPPEPEPE | (Same as 000E0000 to 000FFFFF) | | # **System Board Memory Connectors** The system board has four 72-pin memory connectors that support the 2MB memory cards. The four connectors are numbered 1-2-3-4 from the top of the system. Memory-refresh requests typically occur once every 15 microseconds. Both Type 1 and Type 2 system boards support only 2MB memory card. The following figure shows the pin assignments for the 1- by 72-pin memory connectors. | Figure | 3-18 | (Page 1 of 2). Syst | em Board | d Memo | ory Connector | |--------|------|-----------------------------|----------|--------|----------------------------| | Pin | 1/0 | Signal | Pin | 1/0 | Signal | | 1 | N/A | Ground | 37 | 1/0 | Parity Data 1 | | 2 | I/O | Data 0 | 38 | 1/0 | Parity Data 3 | | 3 | I/O | Data 16 | 39 | N/A | Ground | | 4 | I/O | Data 1 | 40 | 0 | Column Address<br>Strobe 0 | | 5 | I/O | Data 17 | 41 | 0 | Column Address<br>Strobe 2 | | 6 | 1/0 | Data 2 | 42 | 0 | Column Address<br>Strobe 3 | | 7 | 1/0 | Data 18 | 43 | 0 | Column Address<br>Strobe 1 | | 8 | 1/0 | Data 3 | 44 | 0 | Row Address<br>Strobe 0 | | 9 | 1/0 | Data 19 | 45 | 0 | Row Address<br>Strobe 1 | | 10 | 0 | +5 Vdc | 46 | 0 | Block Select 1 | | 11 | 0 | -Column Address<br>Strobe P | 47 | 0 | Write Enable | | 12 | 0 | Address 0 | 48 | N/A | Reserved | | 13 | 0 | Address 1 | 49 | 1/0 | Data 8 | | 14 | 0 | Address 2 | 50 | I/O | Data 24 | | 15 | 0 | Address 3 | 51 | 1/0 | Data 9 | | 16 | 0 | Address 4 | 52 | I/O | Data 25 | | 17 | 0 | Address 5 | 53 | 1/0 | Data 10 | | 18 | 0 | Address 6 | 54 | 1/0 | Data 26 | | 19 | N/A | Reserved | 55 | 1/0 | Data 11 | | 20 | 1/0 | Data 4 | 56 | 1/0 | Data 27 | | 21 | 1/0 | Data 20 | 57 | 1/0 | Data 12 | | 22 | I/O | Data 5 | 58 | 1/0 | Data 28 | | 23 | I/O | Data 21 | 59 | 0 | +5 Vdc | | 24 | 1/0 | Data 6 | 60 | 1/0 | Data 29 | | 25 | I/O | Data 22 | 61 | 1/0 | Data 13 | | 26 | 1/0 | Data 7 | 62 | I/O | Data 30 | | 27 | 1/0 | Data 23 | 63 | I/O | Data 14 | | Pin | I/O | Signal | Pin | 1/0 | Signal | |-----|-----|-------------------------|-----|-----|-------------------| | 28 | 0 | Address 7 | 64 | 1/0 | Data 31 | | 29 | 0 | Block Select 0 | 65 | 1/0 | Data 15 | | 30 | 0 | +5 Vdc | 66 | 0 | Block Select 2 | | 31 | 0 | Address 8 | 67 | 1 | Presence Detect 0 | | 32 | N/A | Reserved | 68 | 1 | Presence Detect 1 | | 33 | 0 | Row Address<br>Strobe 3 | 69 | ı | Presence Detect 2 | | 34 | 0 | Row Address<br>Strobe 2 | 70 | I | Presence Detect 3 | | 35 | 1/0 | Parity Data 2 | 71 | 0 | Block Select 3 | | 36 | 1/0 | Parity Data 0 | 72 | N/A | Ground | The 'presence detect' signals are used by the system to determine memory card size and memory speed. The pins are either connected to ground (G) or not connected (N). The following table shows those combinations supported by Model P70. | Figure 3-19. Presence Detect Encoding | | | | | | |---------------------------------------|-------------------------|---|---|---|--| | A-47 | Presence Detect Signals | | | | | | Card Type | 0 | 1 | 2 | 3 | | | 2MB Memory at 85 ns | N | G | N | G | | # Real-Time Clock/Complementary Metal-Oxide Semiconductor RAM The real-time clock/complementary metal-oxide semiconductor RAM (RT/CMOS) chip contains the real-time clock and 64 bytes of CMOS RAM. The internal clock circuitry uses 14 bytes of this memory, and the rest is allocated to configuration and system status information. In addition to the 64 bytes of CMOS RAM, a 2KB CMOS RAM extension is provided for configuration and other system information. A 6-Vdc lithium battery maintains voltage to the RT/CMOS RAM and 2KB CMOS RAM extension when the power supply is not in operation. The following figure shows the RT/CMOS RAM bytes and their addresses. | Figure 3-20. | RT/CMOS RAM Address Map | | |---------------|-------------------------------------|--| | Address (Hex) | RT/CMOS RAM Bytes | | | 000 - 00D | Real-Time Clock Bytes | | | 00E | Diagnostic Status Byte | | | 00F | Shutdown Status Byte | | | 010 | Diskette Drive Type Byte | | | 011 | First Fixed Disk Drive Type Byte | | | 012 | Reserved | | | 013 | Reserved | | | 014 | Equipment Byte | | | 015 - 016 | Low and High Base Memory Bytes | | | 017 - 018 | Low and High Expansion Memory Bytes | | | 019 - 031 | Reserved | | | 032 - 033 | Configuration CRC Bytes | | | 034 - 036 | Reserved | | | 037 | Date Century Byte | | | 038 - 03F | Reserved | | #### RT/CMOS Address Register and NMI Mask (Hex 0070) This register is used in conjunction with the port at hex 0071 to read and write the RT/CMOS RAM bytes. | Figure 3 | 1. RT/CMOS Address Register and NMI Mask (Hex 0070) | |----------|-----------------------------------------------------| | Bit | Function | | 7 | NMI Mask | | 6 | Reserved | | 5 - 0 | RT/CMOS RAM Address | **Warning:** The operation following a write to hex 0070 should access port hex 0071; otherwise intermittent malfunctions and unreliable operation of the RT/CMOS RAM can occur. - Bit 7 When this bit is set to 1, the NMI is masked off (the NMI is disabled). This bit is set to 1 by a power-on reset. This is a write-only bit. - Bit 6 Reserved. - Bits 5 0 These bits are used to select RT/CMOS RAM addresses. ### RT/CMOS Data Register (Hex 0071) This port is used in conjunction with the address register at hex 0070 to read and write the RT/CMOS RAM bytes. | Figure 3-22. | RT/CMOS Data Register (Hex 0071) | |--------------|----------------------------------| | Bit | Function | | 7 - 0 | RT/CMOS Data | #### RT/CMOS RAM I/O Operations During I/O operations to the RT/CMOS RAM addresses, interrupts should be masked to prevent other interrupt routines from changing the CMOS Address register before data is read or written. After I/O operations, the RT/CMOS and NMI Mask register (hex 0070) should be left pointing to Status Register D (hex 00D). Warning: The operation following a write to hex 0070 should access hex 0071; otherwise intermittent malfunctions and unreliable operation of the RT/CMOS RAM can occur. The following steps are required to perform I/O operations to the RT/CMOS RAM addresses: - Write the RT/CMOS RAM address to the RT/CMOS and NMI Mask register (hex 0070). - 2. Write the data to address hex 0071. #### Reading RT/CMOS RAM requires the following steps: - Write the RT/CMOS RAM address to the RT/CMOS and NMI Mask register (hex 0070). - 2. Read the data from address hex 0071. # Real-Time Clock Bytes (Hex 000-00D) Bit definitions and addresses for the real-time clock bytes are shown in the following figure. | Figure 3-23. Real-Time Clock Bytes | | | | |------------------------------------|-------------------|----------------|--| | Address (Hex) | Function | Byte<br>Number | | | 000 | Seconds | 0 | | | 001 | Second Alarm | 1 | | | 002 | Minutes | 2 | | | 003 | Minute Alarm | 3 | | | 004 | Hours | 4 | | | 005 | Hour Alarm | 5 | | | 006 | Day of Week | 6 | | | 007 | Date of Month | 7 | | | 008 | Month | 8 | | | 009 | Year | 9 | | | 00A | Status Register A | 10 | | | 00B | Status Register B | 11 | | | 00C | Status Register C | 12 | | | 00D | Status Register D | 13 | | **Note:** The Setup program initializes status registers A, B, C, and D when the time and date are set. Interrupt hex 1A is the BIOS interface to read and set the time and date and it initializes the register the same way as the Setup program. #### Status Register A (Hex 00A) | Figure 3-2- | . Status Register A | |-------------|---------------------------------------| | Bit | Function | | 7 | Update in Progress | | 6 - 4 | 22-Stage Divider | | 3 - 0 | Rate Selection Bits | | • | · · · · · · · · · · · · · · · · · · · | - Bit 7 When set to 1, this bit indicates the time-update cycle is in progress. When set to 0, it indicates the current date and time can be read. - Bits 6 4 These three divider-selection bits identify which time-base frequency is being used. The system initializes these bits to binary 010, which selects a 32.768 kHz time base. This is the only value supported by the system for proper time-keeping. - Bits 3 0 These bits allow the selection of a divider output frequency. The system initializes the rate selection bits to a binary 0110, which selects a 1.024 kHz square-wave output frequency and a 976.562-microsecond periodic interrupt rate. #### Status Register B (Hex 00B) | Bit | Function | |-----|--------------------------------| | 7 | Set | | 6 | Periodic Interrupt Enable | | 5 | Alarm Interrupt Enable | | 4 | Update-Ended Interrupt Enabled | | 3 | Square Wave Enabled | | 2 | Date Mode | | 1 | 24-Hour Mode | | 0 | Daylight Savings Enabled | Bit 7 When set to 0, this bit updates the cycle, normally by advancing the counts at a rate of one per second. When set to 1, this bit immediately ends any update cycle in progress, and the program can initialize the 14 time bytes without any further updates occurring until this bit is set to 0. - Bit 6 This bit is a read/write bit that allows an interrupt to occur at a rate specified by the rate and divider bits in Status Register A. When set to 1, this bit enables the interrupt. The system initializes this bit to 0. - Bit 5 When set to 1, this bit enables the alarm interrupt. The system initializes this bit to 0. - Bit 4 When set to 1, this bit enables the update-ended interrupt. The system initializes this bit to 0. - Bit 3 When set to 1, this bit enables the square-wave frequency as set by the rate-selection bits in Status Register A. The system initializes this bit to 0. - Bit 2 This bit indicates if the time-and-date calendar updates use binary or binary-coded-decimal (BCD) formats. When set to 1, this bit indicates a binary format. The system initializes this bit to 0. - Bit 1 This bit establishes if the hours byte is in the 24-hour or 12-hour mode. When set to 1, this bit indicates the 24-hour mode. The system initializes this bit to 1. - When set to 1, this bit enables the daylight savings time mode. When set to 0, it disables the mode, and the clock reverts to standard time. The system initializes this bit to 0. #### Status Register C (Hex 00C) | unction | |-----------------------------| | | | nterrupt Request Flag | | Periodic Interrupt Flag | | Alarm Interrupt Flag | | Jpdate-Ended Interrupt Flag | | Reserved | | ļ | Note: Interrupts are enabled by bits 6, 5, and 4 in Status Register B. Bit 7 This bit is used in conjunction with bits 6, 5, and 4. When set to 1, this bit indicates that an interrupt has occurred; bits 6, 5, and 4 indicate the type of interrupt. Bit 6 When set to 1, this bit indicates that a periodic interrupt occurred. Bit 5 When set to 1, this bit indicates that an alarm interrupt occurred. Bit 4 When set to 1, this bit indicates that an update-ended interrupt occurred. Bits 3 - 0 Reserved. #### Status Register D (Hex 00D) | Figure 3-27 | . Status Register D | | |-------------|---------------------|--| | Bit | Function | | | 7 | Valid RAM | | | 6 - 0 | Reserved | | | 6-0 | Reserved | | Bit 7 This read-only bit monitors the power-sense pin. A low state of this pin indicates a loss of power to the real-time clock (dead battery). When set to 1, this bit indicates that the real-time clock has power. When set to 0, it indicates that the real-time clock has lost power. Bits 6 - 0 Reserved. #### **CMOS RAM Configuration** Bit 7 The following shows the bit definitions for the CMOS RAM configuration bytes. #### Diagnostic Status Byte (Hex 00E) lost power. | Bit | Function | |-----|-----------------------------------------------------| | 7 | Real-Time Clock Chip Power | | 6 | Configuration Record and Checksum Status | | 5 | Incorrect Configuration | | 4 | Memory Size Miscompare | | 3 | Fixed Disk Controller/Drive C Initialization Status | | 2 | Time Status Indicator | | 1 | Adapter Configuration Miscompare | | 0 | Adapter ID Time-Out | When set to 1, this bit indicates the real-time clock chip When this bit is set to 1, the checksum is incorrect. BIt 6 This is a check, at power-on time, of the Equipment byte. Bit 5 When set to 1, the configuration information is incorrect. Power-on checks require that at least one diskette drive be installed (bit 0 of the Equipment byte, hex 014, is set to 1). When set to 1, this bit indicates the power-on check Blt 4 determined that the memory size is not the same as in the configuration record. When set to 1, this bit indicates that the controller or drive Bit 3 C failed initialization, which prevents the system from attempting a power-on reset. When set to 0, this bit indicates the time is valid. When Bit 2 set to 1, this bit indicates the time is invalid. This bit indicates if the installed adapters match the Bit 1 configuration information. When this bit is set to 1, the adapters do not match the configuration information. When set to 1, this bit indicates a time-out occurred while Bit 0 an adapter ID was being read. Shutdown Status Byte (Hex 00F): This byte is defined by the power-on diagnostic programs. Diskette Drive Type Byte (Hex 010): This byte indicates the type of diskette drive installed. | Figure 3-29. Diskette Drive Type Byte | | |---------------------------------------|------------------------------------------------------| | Bit | Function | | 7 - 4 | First Diskette Drive Type | | 3 - 0 | Second Diskette Drive Type (External storage device) | Bits 7 - 4 These bits indicate the first diskette drive type, as shown in the following figure. | Bits | | |------|---------------------------------------------------------| | 7654 | Function | | 0000 | No drive present | | 0001 | Double-sided diskette drive (48 tracks per inch, 360KB) | | 0011 | High-capacity diskette drive (720KB) | | 0100 | High-density diskette drive (1.44MB) | Bits 3 - 0 These bits indicate the second diskette drive type, as shown in the following figure. | Bits | | |------|---------------------------------------------------------| | 3210 | Function | | 0000 | No drive present | | 0001 | Double-sided diskette drive (48 tracks per inch, 360KB) | | 0011 | High-capacity diskette drive (720KB) | | 0100 | High-density diskette drive (1.44MB) | First Fixed Disk Drive Type Byte (Hex 011): This byte defines the type of the first fixed disk drive (drive C). Hex 00 indicates that a fixed disk drive is *not* installed. Note: For more information about fixed disk drive types, refer to the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference. Reserved Bytes (Hex 012 and 013): These bytes are reserved. **Equipment Byte (Hex 014):** The equipment byte defines the basic equipment in the system for the power-on diagnostic tests. | Bit | Function | | |------|---------------------------|--| | 7, 6 | Number of Diskette Drives | | | 5, 4 | Display Operating Mode | | | 3, 2 | Reserved | | | 1 | Math Coprocessor Presence | | | 0 | Diskette Drive Presence | | Bits 7, 6 These bits indicate the number of diskette drives installed, as shown in the following figure. | Figure 3-33. Equipment Byte (Bits 7, 6) | | | |-----------------------------------------|---------------------------------------------------------|--| | Number of<br>Diskette Drives | | | | One Drive | | | | Two Drives | | | | Reserved | | | | Reserved | | | | | Number of Diskette Drives One Drive Two Drives Reserved | | Bits 5, 4 These bits indicate the operating mode of the display attached to the video port, as shown in the following figure. | Figure 3-34. Equipment Byte (Bits 5, 4) | | | |-----------------------------------------|-----------------|--| | Bits | Display | | | 5 4 | Operating Mode | | | 0.0 | Reserved | | | 01 | 40-Column Mode | | | 10 | 80-Column Mode | | | 11 | Monochrome Mode | | | | | | - Bits 3, 2 Reserved. - Bit 1 When set to 1, this bit indicates that a math coprocessor is installed. - Bit 0 When set to 1, this bit indicates that a diskette drive is installed. Low and High Base Memory Bytes (Hex 015 and 016): These bytes define the amount of memory below the 640KB address space. The value from these bytes represents the number of 1KB blocks of base memory. For example, hex 0280 is equal to 640KB. The low byte is hex 15; the high byte is hex 16. Low and High Expansion Memory Bytes (Hex 017 and 018): These bytes define the amount of memory above the 1MB address space. The hexadecimal values in these bytes represent the number of 1KB blocks of expansion memory. For example, hex 0800 is equal to 2048KB. The low byte is hex 17; the high byte is hex 18. Reserved Bytes (Hex 019 through 031): These bytes are reserved. Configuration CRC Bytes (Hex 032 and 033): These bytes contain the cyclic-redundancy-check data for bytes hex 010 through hex 031 of the 64-byte CMOS RAM. The low byte is hex 33; the high byte is hex 32. Reserved Bytes (Hex 034 through 036): These bytes are reserved. Date Century Byte (Hex 037): Bits 7 through 0 of this byte contain the BCD value for the century. Refer to the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference for information about reading and setting this byte. Reserved Bytes (Hex 038 through 03F): These bytes are reserved. # **Miscellaneous System Functions** #### Nonmaskable Interrupt The nonmaskable interrupt (NMI) signals the system microprocessor that a parity error, a channel check, a system channel time-out, or a system Watchdog time-out has occurred. The NMI stops all arbitration on the bus until bit 6 of the Arbitration register (I/O address hex 0090) is set to 0. This can result in lost data or an overrun error on some I/O devices. The NMI masks all other interrupts and the IRET instruction restores the interrupt flag to the state it was in prior to the interrupt. A system reset causes a reset of the NMI. Nonmaskable interrupt requests from system board parity and channel check are subject to mask control with the NMI mask bit in the RT/CMOS Address register. The Watchdog Timer and system channel time-out are not masked by this bit. (See "RT/CMOS Address Register and NMI Mask (Hex 0070)" on page 3-25). The power-on default of the NMI mask is 1 (NMI disabled). Prior to enabling the NMI after a power-on reset, the parity check and channel check state are initialized by the POST. **Warning:** The operation following a write to hex 0070 should access port hex 0071; otherwise intermittent malfunctions and unreliable operation of the RT/CMOS RAM can occur. ### System Control Port B (Hex 0061) Bit definitions for the read and write functions of this port are shown in the following figures. | igure 3-35. System Control Port B (Write) | | | |-------------------------------------------|-----------------------------------|--| | Bit | Function | | | 7 | Reset Timer 0 Output Latch (IRQ0) | | | 6 - 4 | Reserved | | | 3 | Enable Channel Check | | | 2 | Enable Parity Check | | | 1 | Speaker Data Enable | | | 0 | Timer 2 Gate to Speaker | | | Figure 3-36. System Control Port B (Read) | | | |-------------------------------------------|-----------------------------------|--| | Bit | Function | | | 7 | Parity Check | | | 6 | Channel Check | | | 5 | Timer 2 Output | | | 4 | Toggles with Each Refresh Request | | | 3 | Enable Channel Check | | | 2 | Enable Parity Check | | | 1 | Speaker Data Enable | | | 0 | Timer 2 Gate to Speaker | | | Bit 7 | Setting this bit to 1 resets IRQ0. Reading this bit as a 1 indicate; a parity check has occurred. | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 6 | Readir $\mathfrak J$ this bit as a 1 indicates a channel check has occurred. | | Bit 5 | This bit indicates the condition of the timer/counter 2 'output' signal. | | Bit 4 | This bit toggles for each refresh request. | | Bit 3 | Setting this bit to 0 enables channel check. This bit is set to 1 during a power-on reset. Setting this bit to 1 disables channel check and clears the channel check latch. | | Bit 2 | Setting this bit to 0 enables parity check. This bit is set to 1 during a power-on reset. To clear a parity error, set this bit to 1 and then to 0. | | Bit 1 | Setting this bit to 1 enables speaker data. | | Bit 0 | Setting this bit to 1 enables the timer 2 gate. | | | | ### System Control Port A (Hex 0092) | Figure 3-37. System Control Port A | | | |------------------------------------|---------------------------|---| | Bit | Function | | | 7, 6 | Fixed-Disk Activity Light | • | | 5 | Reserved | | | 4 | Watchdog Timer Status | | | 3 | Security Lock Latch | | | 2 | Reserved = 0 | | | 1 | Alternate Gate A20 | | | 0 | Alternate Hot Reset | | - Bits 7, 6 These bits control the fixed-disk activity light. Setting either bit to 1 turns the fixed-disk activity light on. Setting both bits to 0 turns the light off. The power-on reset condition of each bit is 0. - Bit 5 Reserved. - Bit 4 This read-only bit indicates the Watchdog Timer status. When this bit is set to 1, a Watchdog time-out has occurred. For more information about the Watchdog Timer, refer to the Hardware Interface Technical Reference. - Bit 3 This bit provides the security lock for the secured area of RT/CMOS. Setting this bit to 1 electrically locks the 8-byte, power-on password. Once this bit is set by POST, it can only be cleared by turning the system off. - Blt 2 Reserved. - Bit 1 This bit is ORed with bit 1 in the keyboard output port to enable the 'address 20' signal (A20). when both bits are set to 0, A20 is disabled and set to 0. This bit is set to 0 during a system reset. Bit 0 This bit provides an alternate method of resetting the system microprocessor. This alternate method supports operating systems requiring faster operation than was provided on the IBM Personal Computer AT®. Resetting the system microprocessor is used to switch the microprocessor from the protected mode to the real address mode. The alternate reset takes 13.4 microseconds. This bit is set to 0 either by a system reset or a Write operation. When a Write operation changes this bit from 0 to 1, the alternate reset pin is pulsed high for 100 to 125 nanoseconds. The reset occurs after a minimum delay of 6.72 microseconds. While the reset is occurring, the latch remains set so that POST can read this bit. If the bit is 0, POST assumes the system was just powered on. If the bit is 1, POST assumes a switch from the protected mode to the real mode has taken place. IBM Personal Computer AT is a registered trademark of the International Business Machines Corporation. #### Power-On Password RT/CMOS RAM has 8 bytes reserved for the power-on password and its check character. The 8 bytes are initialized to hex 00. The microprocessor can only access these bytes during power-on self-test (POST). After POST is completed, if a power-on password is installed, the password bytes are locked and cannot be accessed by a program. A power-on password can be from 1 to 7 characters. During power-on password installation, the password (1 to 7 keyboard scan codes), is stored in the security space. Power-on password installation is a function of a program contained on the Reference diskette. Once the power-on password utility has been installed, the password can be changed only during the POST. When the new power-on password is installed, changed, or removed, the password is not visible on the display. The system unit cover can be physically locked to prevent unauthorized access to the battery. This helps prevent unauthorized battery removal and loss of power-on password and configuration information. For information about the keyboard password, see the "Keyboard and Auxiliary Device Controller" section in the *Hardware Interface*Technical Reference. # **Hardware Compatibility** The Model P70 maintains many of the interfaces used by the IBM Personal Computer AT. In most cases command and status organization of these interfaces is maintained. The functional interfaces for the Model P70 are compatible with the following interfaces: - The Intel<sup>1</sup> 8259 interrupt controllers (without edge triggering). - The Intel 8253 timers driven from 1.193 MHz (timer 0 and 2 only). - The Intel 8237 DMA controller-address/transfer counters, page registers and status fields only. The Command and Request registers are not supported. The rotate and mask functions are not supported. The Mode register is partially supported. - The NS16450 serial port. - The Intel 8088, 8086, 80286, and 80386SX microprocessors. - The Intel 8272 or equivalent diskette-drive controller. - The Motorola<sup>2</sup> MC146818 Time of Day Clock command and status (CMOS reorganized). - · The keyboard port at address hex 0060. - Display modes supported by the IBM Monochrome Display and Printer Adapter, the IBM Color/Graphics Monitor Adapter, and the IBM Enhanced Graphics Adapter. <sup>1</sup> Intel is a trademark of the Intel Corporation. <sup>2</sup> Motorola is a trademark of Motorola, Inc. - The parallel printer ports (Parallel 1, Parallel 2, and Parallel 3) in compatibility mode. - Generally compatible with the Intel 8087, 80287, and 80387SX math coprocessors. - The plasma display operates identically to IBM 8503 Monochrome Display, with the following exception. 9-PEL wide fonts are not supported on the plasma display because the display is limited to 640 total PELs. #### **Error Codes** POST returns a message in the form of a number to indicate the type of test that failed. The following figure gives the failure indicated with the associated error code. For information on unlisted error codes, contact Developer Assistance at 1-800-IBM-7763 (this number is for developers who are registered with IBM). | Figure 3-38 (Page | a 1 of 2). POST Error Message Table | |-------------------|---------------------------------------------------| | Error<br>Number | Error Description | | 101 | Interrupt failure | | 102 | Timer failure | | 103 | Timer interrupt failure | | 104 | Protected mode failure | | 105 | Keyboard controller command failure | | 107 | Hot NMI test | | 108 | Timer bus test | | 109 | Memory select | | 110 | System board parity | | 111 | I/O parity | | 112 | Watchdog timeout | | 113 | DMA arbitration timeout | | 114 | External ROM checksum | | 160 | System board ID not recognized | | 161 | Bad battery or configuration | | 162 | CMOS checksum or adapter ID mismatch | | 163 | Date and time not set | | 164 | Memory size mismatch | | 165 | Adapter ID mismatch | | 166 | Card busy | | 167 | System clock not updating | | 201 | Memory miscompare or parity | | 202 | Memory address line error (address line: 00 - 15) | | 203 | Memory address line error (address line: 16 - 31) | | 211 | Memory Base 64K on system board failed | | 215 | Memory Base 64K on daughter/SIP 2 failed | | 216 | Memory Base 64K on daughter/SIP 1 failed | | 221 | ROM to RAM copy | | 225 | Wrong speed memory on system board | | 301 | Keyboard interface | | 303 | Keyboard or system board | | 304 | Keyboard clock failure | | 305 | Keyboard +5V error | | 601 | Diskette drive or controller | | 602 | Diskette boot record | | 1101 | Async error | | 8601 | Mouse timeout | | 8602 | Mouse interface | | Error | | |--------|----------------------------------------------------------| | Number | Error Description | | 8603 | Mouse interrupt | | 10480 | Drive C seek failure | | 10481 | Drive D seek failure | | 10482 | Drive failed controller test | | 10483 | Drive controller failed to reset | | 10490 | Drive C read failure | | 10491 | Drive D read failure | | 12901 | Failed-processor portion of processor board test (Type 3 | | 12902 | Failed-cache portion of processor board test (Type 3) | | 14901 | Plasma-display adapter failure | | 14902 | Plasma-display adapter failure | | 14922 | Plasma display failure | | 14932 | External display failure | # Section 4. Video Subsystem | Description | 4-3 | |----------------------------------|-----| | Plasma Display | 4-3 | | Plasma Display Adapter | 4-4 | | Overview | 4-4 | | Video Mode | 4-5 | | Programming Considerations | 4-5 | | Auto-dim function | 4-6 | | Distinctive-mapping | 4-7 | | Half-toning (Dithering) | | | Connectors and Signals | | | Plasma display adapter connector | 4-8 | | Plasma display connector | -10 | | Display connector | | # **Notes:** # **Description** Model P70 is equipped with a plasma display which is controlled by the plasma display adapter. The plasma display works as a monochrome display. In addition, the plasma display adapter also has the VGA and DAC section so that a PS/2 display can be attached to the Model P70 without any other additional adapter. Note: When an external PS/2 display is attached, the plasma display does not display unless the Reference Diskette is in use. # **Plasma Display** The plasma display is a flat panel monochrome display. Each PEL can display 16 gray scales. The specification is the following. Screen size: 211.2 x 158.4 mm (8.31 x 6.24 inch) Resolution: 640 x 480 PEL # Plasma Display Adapter #### Overview The plasma display adapter card is plugged in the 16-bit channel connecter on the system board. This 16-bit channel connecter contains all signals on the 16-bit micro channel plus some additional signals necessary for the plasma display adapter. Notice that the connecter does not have the video extension. The plasma display controller (PDC) emulates the PS/2 8503 monochrome display. Half-toning technology is used to implement mode hex 13, and distinctive-mapping is used on the remaining modes. This adapter has the following three sections. - VGA: Video Graphics Array - DAC: Digital-to-Analog Converter PDC: Plasma Display Controller Following is the block diagram of the plasma display adapter. Figure 4-1. Block Diagram #### Video Mode The plasma display adapter supports the following modes. A/N modes (0+,1+,2+,3+,7,7+) with 9-dot width font are supported only for the external PS/2 display. A/N modes $(0\#,1\#,2\#,3\#,7^*,7\#)$ are used only for the plasma display. | Mode<br>(Hex) | Туре | Colors | Alpha<br>Format | Buffer<br>Start | Box<br>Size | Max.<br>Pgs. | Vert.<br>Freq. | PELs | |---------------|------|--------|-----------------|-----------------|-------------|--------------|----------------|-----------| | 0, 1 | A/N | 16 | 40 x 25 | B8000 | 8 x 8 | 8 | 70 Hz | 320 x 200 | | 0*, 1* | A/N | 16 | 40 x 25 | B8000 | 8 x 14 | 8 | 70 Hz | 320 x 350 | | 0+,1+ | A/N | 16 | 40 x 25 | B8000 | 9 x 16 | 8 | 70 Hz | 360 x 400 | | 0#, 1# | A/N | 16 | 40 x 25 | B8000 | 8 x 16 | 8 | 70 Hz | 320 x 400 | | 2, 3 | A/N | 16 | 80 x 25 | B8000 | 8 x 8 | 8 | 70 Hz | 640 x 200 | | 2*, 3* | A/N | 16 | 80 x 25 | B8000 | 8 x 14 | 8 | 70 Hz | 640 x 350 | | 2+,3+ | A/N | 16 | 80 x 25 | B8000 | 9 x 16 | 8 | 70 Hz | 720 x 400 | | 2#, 3# | A/N | 16 | 80 x 25 | B8000 | 8 x 16 | 8 | 70 Hz | 640 x 400 | | 4, 5 | APA | 4 | 40 x 25 | B8000 | 8 x 8 | 1 | 70 Hz | 320 x 200 | | 6 | APA | 2 | 80 x 25 | B8000 | 8 x 8 | 1 | 70 Hz | 640 x 200 | | 7 | A/N | - | 80 x 25 | B0000 | 9 x 14 | 8 | 70 Hz | 720 x 350 | | 7* | A/N | - | 80 x 25 | B0000 | 8 x 14 | 8 | 70 Hz | 640 x 350 | | 7+ | A/N | - | 80 x 25 | B0000 | 9 x 16 | 8 | 70 Hz | 720 x 400 | | 7# | A/N | - | 80 x 25 | B0000 | 8 x 16 | 8 | 70 Hz | 640 x 400 | | D | APA | 16 | 40 x 25 | A0000 | 8 x 8 | 8 | 70 Hz | 320 x 200 | | E | APA | 16 | 80 x 25 | A0000 | 8 x 8 | 4 | 70 Hz | 640 x 200 | | F | APA | - | 80 x 25 | A0000 | 8 x 14 | 2 | 70 Hz | 640 x 350 | | 10 | APA | 16 | 80 x 25 | A0000 | 8 x 14 | 2 | 70 Hz | 640 x 350 | | 11 | APA | 2 | 80 x 30 | A0000 | 8 x 16 | 1 | 60 Hz | 640 x 480 | | 12 | APA | 16 | 80 x 30 | A0000 | 8 x 16 | 1 | 60 Hz | 640 x 480 | | 13 | APA | 256 | 40 x 25 | A0000 | 8 x 8 | 1 | 70 Hz | 320 x 200 | Figure 4-2. BIOS Video Modes Note: The border screen is not supported for the plasma display. ### **Programming Considerations** To prevent "tearing" of the screen image, an application reading data from or writing data to the DAC color registers should ensure that the BLANK input to the DAC is only asserted during the retrace intervals. This can be accomplished by restricting data transfers to 20 DAC entries during the retrace interval. Use VGA Input Status Register 1 to determine when retrace is occurring. For more information about the DAC and the registers, refer to the "Video Subsystem" section of the IBM Personal System/2 Hardware Interface Technical Reference. #### **Auto-dim function** The plasma display has an auto-dim function. It automatically turns the plasma display off after the specified period since the last keystroke. Any keystroke returns the plasma display on. A desired value for the period can be specified in the range 1 to 120 minutes during the system configuration by the backup copy of the reference diskette. Note: For German models, the background intensity of the screen is selectable. The background intensity does not affect the auto-dim function. The auto-dim logic is integrated in the PDC on the adapter card. (See Figure 4-3.) Figure 4-3. Auto-Dim Block Diagram The sequence of auto-dim operation is as follows. (See Figure 4-3.) - During the system configuration, plasma display may be enabled (PDP ENABLE bit is set) and a value corresponding to the specified period is stored. - 2. When the auto-dim function is enabled, the AUTO-DIM ENABLE bit is set by POST (Power-on Self Test). - 3. The up-counter increases each minute with a interval pulse derived from the VSYNC (Vertical Synchronization) signal. - 4. The comparator compares the count and the value specified for the period, then the result is latched. - 5. The result is gated twice into the plasma display. If the AUTO-DIM ENABLE bit is set and the count has reached the matching value, the plasma display is disabled and the up-counter is reset. Otherwise, nothing is performed. - 6. Go to step 3. #### **Distinctive-mapping** The plasma display controller has unique distinctive-mapping hardware for use in video modes hex 0 to hex 12. This is a transparent technique to ensure that the plasma display will correctly show the shades requested from an application. This mapping hardware will take the output of the color registers and identify which 16 shades are currently in use by the application. It then assigns a corresponding brightness level for the plasma display and also makes sure each application color will have 1 of 16 distinct plasma display brightness levels. Colors that would be very similar on a CRT will be adjusted to a unique brightness level on the plasma display. The relative brightness positions are maintained during this process. The result is a better image on the plasma display even when applications adjust the palette and color registers. The distinctive-mapping operation occurs during the vertical retrace interval and is automatic and transparent to the application. If applications adjust the color registers, BIOS is recommended. The IBM PS/2 Monochrome Display 8503 and the plasma display use the DAC color registers for only the green output. BIOS will make the appropriate weighted sum from the red, green, and blue register values for use with any IBM PS/2 display. For more information, refer to the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference. #### Half-toning (Dithering) The plasma display can display 16 gray scales in each PEL, but the PS/2 8503 monochrome display identifies up to 64 gray scales in mode hex 13. The plasma display emulates 64 gray patterns with half-toning technology. In the half-toning method, contiguous 2 x 2 PELs are treated as one logical dot because the resolution in mode hex 13 is 320 x 200 dots while the physical resolution is 640 x 400 PELs. The four PELs of 16 gray scales result in 64 gray patterns. #### **Connectors and Signals** The plasma display adapter has three connectors. - Plasma display adapter connector to the system board - Plasma Display connector to the plasma display - Display connector to the external PS/2 display #### Plasma display adapter connector The following figure shows the signal assignment of the plasma display adapter connector. The connector contains the same signal set as of the 16-bit micro channel connector except two pins; the pin B04 does not provide the signal 14.3MHz OSC and the pin B45 is assigned with the signal -KEYSTROKE for the plasma display. | Figure | 4-4 (Page 1 of 2). | Plasma Display Ad | apter Connector | | |--------|--------------------|-------------------|-----------------|---| | Pin | Signal | Pin | Signal | , | | B01 | AUDIO GND | A01 | -CD SETUP | | | B02 | AUDIO | A02 | MADE 24 | | | B03 | GND | A03 | GND | | | B04 | Reserved | A04 | A 11 | | | B05 | GND | A05 | A 10 | | | B06 | A 23 | A06 | A 09 | | | B07 | A 22 | A07 | +5Vdc | | | B08 | A 21 | 80A | 80 A | | | B09 | GND | A09 | A 07 | | | B10 | A 20 | A10 | A 06 | | | B11 | A 19 | A11 | +5Vdc | | | B12 | A 18 | A12 | A 05 | | | B13 | GND | A13 | A 04 | | | B14 | A 17 | A14 | A 03 | | | B15 | A 16 | A15 | +5Vdc | | | in | Signal | Pin | Signal | |--------|-----------|-----|--------------| | 16 | A 15 | A16 | A 02 | | 17 | GND | A17 | A 01 | | 18 | A 14 | A18 | A 00 | | 9 | A 13 | A19 | +12Vdc | | 0 | A 12 | A20 | -ADL | | 21 | GND | A21 | -PREEMPT | | 22 | -IRQ 09 | A22 | BURST | | 3 | -IRQ 03 | A23 | 12Vdc | | 4 | -IRQ 04 | A24 | ARB 00 | | 5 | GND | A25 | ARB 01 | | 6 | -IRQ 05 | A26 | ARB 02 | | 7 | -IRQ 06 | A27 | -12Vdc | | 3 | -IRQ 07 | A28 | ARB 03 | | } | GND | A29 | ARB/-GNT | | ) | Reserved | A30 | -TC | | 1 | Reserved | A31 | +5Vdc | | 2 | -CHCK | A32 | -S0 | | 3 | GND | A33 | <b>-</b> \$1 | | , | -CMD | A34 | M/IQ | | ,<br>, | CHRDYRTN | A35 | +12Vdc | | 3 | -CD SFDBK | A36 | CD CHRDY | | 7 | GND | A37 | D 00 | | 3 | D 01 | A38 | D 02 | | | D 03 | A39 | +5Vdc | | 9 | D 04 | A40 | D 05 | | 1 | GND | A41 | D 06 | | 2 | CHRESET | A42 | D 07 | | 3 | Reserved | A43 | GND | | | Reserved | A44 | -DS 16 RTN | | 5 | KEYSTROKE | A45 | -REFRESH | | 6 | KEY | A46 | KEY | | 7 | KEY | A47 | KEY | | 8 | D 08 | A48 | +5Vdc | | 9 | D 09 | A49 | D 10 | | 0 | GND | A50 | D 11 | | 51 | D 12 | A51 | D 13 | | 2 | D 14 | A52 | +12Vdc | | 3 | D 15 | A53 | Reserved | | 4 | GND | A54 | -SBHE | | 55 | -IRQ 10 | A55 | -CD DS 16 | | 6 | -IRQ 11 | A56 | +5Vdc | | 7 | -IRQ 12 | A57 | -IRQ 14 | | 8 | GND | A58 | -IRQ 15 | #### Plasma display connector The hardware interface to the plasma display uses a 26-pin connector. The following figure shows the signal assignment. | Pin | 1/0 | Signal | Pin | 1/0 | Signal | |-----|-----|---------------------|-----|-----|-----------------------| | 1 | 0 | -Vsync | 2 | N/A | Ground | | 3 | 0 | -Hsync | 4 | N/A | Ground | | 5 | 0 | -Data 0 | 6 | N/A | Ground | | 7 | 0 | -Data 1 | 8 | N/A | Ground | | 9 | 0 | Data 2 | 10 | N/A | Ground | | 11 | 0 | -Data 3 | 12 | N/A | Ground | | 13 | 0 | —Display Timing | 14 | N/A | Ground | | 15 | 0 | Dot Clock | 16 | N/A | Ground | | 17 | 0 | +Disable | 18 | N/A | Ground | | 19 | 0 | -Blanking | 20 | N/A | Ground | | 21 | 0 | -Gamma Compensation | 22 | 0 | -Background Intensity | | 23 | N/A | Ground | 24 | N/A | Ground | | 25 | N/A | Ground | 26 | N/A | Ground | #### **Display connector** The hardware interface to the external display uses the standard PS/2 display connector. For more information, refer to "Hardware Interface Technical Reference". # Index | A | central arbitration control | |----------------------------------------|----------------------------------------------| | acoustic readings 1-10 | point 3-4 | | activity light 3-38 | channel 1-4, 3-3 | | adapter setup register 2-13 | channel check enable 3-37 | | adapter, fixed disk and diskette | channel check latch 3-37 | | drive 3-7 | CMOS RAM 3-24 | | address maps | configuration CRC bytes 3-35 | | memory 3-17 | configuration, RT/CMOS 3-31 | | POS 2-5 | connectors 4-8 | | reassignment 3-13 | connectors, fixed disk and diskette | | system 1-6 | drive 3-7 | | address 20 gate 3-38 | connector, display 4-10 | | address, split memory 3-16 | connector, memory 3-22 | | alternate reset 3-39 | connector, plasma display 4-10 | | arbiter programming 3-5 | connector, plasma display | | arbitration control point 3-4 | adapter 4-4, 4-8 | | arbitration level 3-4 | | | arbitration register 3-5 | n | | arbitration, central control | D | | point 3-5 | DAC 4-4 | | auto-dim | date century byte 3-35 | | block diagram 4-6 | description | | function 4-6 | math coprocessor 3-3 | | | memory 3-11 | | В | NMI 3-36 | | <del>_</del> | password 3-40 programmable option select 2-3 | | base memory bytes 3-35<br>battery 3-24 | programmatic opinion | | block diagram, system board 1-5 | real-time clock 3-24 | | block, split memory 3-12 | system 1-3 | | border screen 4-5 | system board 1-3 diagnostic status byte | | bus contention 2-3 | (RT/CMOS) 3-31 | | bus priority assignments 3-4 | diagram, system board 1-5 | | bus priority acaigminants o | diskette drive type byte 3-32 | | _ | diskette overruns 3-4 | | C | distinctive-mapping 4-4, 4-7 | | card present bits 2-9, 2-10 | DMA channels 3-4 | | card selected feedback 2-6 | Dian chambis o 4 | | | | | E | M | |--------------------------------------|----------------------------------| | enable error checking 3-15 | matched memory 3-3 | | enable NMI 3-25 | math coprocessor 3-3 | | enable, memory 3-14 | maximum current 1-9 | | equipment byte 3-34 | measurements 1-9 | | error recovery 3-13 | memory | | extended arbitration 3-6 | connectors 3-22 | | external storage device | description 3-11 | | connector 3-9 | enable bits 3-14 | | | error recovery 3-13 | | F | performance 1-7, 1-8 | | Г | reassigning 3-13 | | feedback, card selected 2-6 | refresh 3-4 | | fixed disk activity light 3-38 | split block 3-14 | | fixed disk connector 3-10 | system memory maps 3-17 | | fixed disk drive initialization 3-31 | memory card definition 2-9 | | fixed disk type byte 3-33 | memory encoding registers 3-14 | | | memory size miscompare 3-31 | | G | micro channel 1-4, 3-3 | | gate A20 3-38 | microprocessor | | gray patterns 4-8 | alternate reset 3-39 | | gray scales 4-8 | mode switch compatibility 3-39 | | gray scales 4-0 | performance 1-7, 1-8 | | | real address mode 3-38 | | H | mode switching 3-39 | | half-toning 4-4, 4-8 | model/submodel bytes 1-3 | | | | | 1 | N | | | NMI mask 3-25 | | identifier, model 1-3 | NMI service 3-4 | | internal diskette drive | NMI signal 3-4 | | connector 3-8 | noise readings 1-10 | | interrupts | nonmaskable interrupt (NMI) 3-36 | | IRQ0 reset 3-37 | , | | NMI reset 3-36 | _ | | I/O address map 1-6 | P | | | parallel port select 2-7 | | L | parity check 3-15 | | list of features 1-4 | parity check enable 3-37 | | 101 01 10210100 1-7 | password, power-on 3-40 | | | PDC 4-4 | | PEL, plasma display 4-3 performance 1-7, 1-8, 3-3 plasma display 4-3 plasma display adapter 4-4 ports, system 3-36 POS register 2 2-7 | ROM enable 3-15<br>RT/CMOS address register 3-25<br>RT/CMOS RAM 3-24<br>password 3-40<br>secured area 3-38 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | POS register 2 2-7 POS register 3 2-9 power specifications 1-9 power supply 1-4 programmable option select (POS) 2-3 address decode 2-6 address map 2-5 registers 2-5 setup procedures 2-4 setup register 2-7 system board 2-6 system board 1/O 2-7 system configuration utilities 2-3 system memory maps 3-17 warning 2-3 programming, arbiter 3-5 protected mode switch 3-39 | setup bus contention 2-3 registers 2-7 system board 2-6 system board 1/O 2-7 system memory maps 3-17 shutdown status byte 3-32 signals 4-8 size 1-9 size determine, memory 2-9, 2-10 sound specifications 1-10 speaker data enable 3-37 specifications, system unit 1-9 split address 3-16 split memory block 3-12, 3-14 status registers (RT/CMOS) 3-28 subsystems, memory 3-11 switch to real 3-39 system address map 1-6 system board 1-3 | | read-only memory (ROM) 3-11 real mode switch 3-39 real-time clock bytes 3-27 refresh 3-4 refresh request 3-37 registers adapter setup 2-13 card feedback 2-6 memory encoding 3-14 miscellaneous system 3-36 RT/CMOS and NMI mask 3-25 RT/CMOS status registers 3-28 system board POS 2-7 system control 3-36 resolution, plasma display 4-3 | block diagram 1-5 features 1-3 I/O register 2-7 memory connector 3-22 memory registers 3-14 model identifier 1-3 POS registers 2-7 setup 2-6 system configuration utilities 2-3 system control port A 3-38 system control ports 3-36 system description 1-3 system performance 1-7, 1-8 system ports, miscellaneous 3-36 system reset 3-36 | time status indicator 3-31 type identifier 1-3 # V valid RAM bit 3-30 VGA 4-4 video mode 4-5 # W warnings arbitration 3-4 central arbiter 3-6 NMI mask 3-36 POS 2-3 real-time clock 3-25 reserved areas iii watchdog status 3-38 # **Numerics** 80386 performance 1-7, 1-8 80387 math coprocessor 3-3 # IBM Personal System/2 Model P70 Supplement This supplement contains programming considerations that apply to the BIOS section of the IBM Personal System/2 and IBM Personal Computer BIOS Interface Technical Reference. This information should be used in addition to the material covered in the above manual. File this page behind the "Supplements" tab in the IBM Personal System/2 and Personal Computer BIOS Interface Technical Reference. #### System identification The IBM Personal System/2 Model P70 can have either a Type 1 and Type 2 system board. Each type has its own unique model and submodel byte which can be identified by programs. The following shows these bytes, system board types, and system clock speeds. | Figure 1. System Identification | | | | | | | |---------------------------------|------------------|-----------------------------|--------------------------------------------------------|--|--|--| | Submodel<br>Byte | Revision<br>Code | System Board | System Clock | | | | | 50 | 00 | Type 1 | 16 MHz | | | | | 0B | 00 | Туре 2 | 20 MHz | | | | | | Submodel<br>Byte | Submodel Revision Byte Code | Submodel Revision Byte Code System Board 50 00 Type 1 | | | | #### **Programming Considerations for BIOS** The model P70 is fully compatible with the BIOS and ABIOS in other Personal System/2 products. Changes and enhancements are noted below. **Warning:** To prevent "tearing" of the screen image, an application reading data from or writing data to the DAC color registers should ensure that the BLANK input to the DAC is only asserted during the retrace intervals. This can be accomplished by restricting data transfers to 20 DAC entries during the retrace interval. Use VGA Input Status Register 1 to determine when retrace is occurring. For more information about the DAC and the registers, refer to the "Video Subsystem" section of the IBM Personal System/2 Hardware Interface Technical Reference. #### Interrupt 10H - Video (AH) = 00H - Set Mode: (AL) - Requested video mode The following table lists hardware specific video mode characteristics: | Mode<br>(Hex) | Туре | Colors | Alpha<br>Format | Suffer<br>Start | Box<br>Size | Max.<br>Pgs. | Vert.<br>Freq. | PELs | |-----------------|------|--------|-----------------|-----------------|-------------|--------------|----------------|-----------| | 0, 1 | A/N | 16 | 40 x 25 | B8000 | 8 x 8 | 8 | 70 Hz | 320 x 200 | | 0*, 1* | A/N | 16 | 40 x 25 | B8000 | 8 x 14 | 8 | 70 Hz | 320 x 350 | | 0+,1+ | A/N | 16 | 40 x 25 | B8000 | 9 x 16 | 8 | 70 Hz | 360 x 400 | | 0#, 1# | A/N | 16 | 40 x 25 | B8000 | 8 x 16 | 8 | 70 Hz | 320 x 400 | | 2, 3 | A/N | 16 | 80 x 25 | B8000 | 8 x 8 | 8 | 70 Hz | 640 x 200 | | 2*, 3* | A/N | 16 | 80 x 25 | B8000 | 8 x 14 | 8 | 70 Hz | 640 x 350 | | 2+,3+ | A/N | 16 | 80 x 25 | B8000 | 9 x 16 | 8 | 70 Hz | 720 x 400 | | 2#, 3# | A/N | 16 | 80 x 25 | B8000 | 8 x 16 | 8 | 70 Hz | 640 x 400 | | 4, 5 | APA | 4 | 40 x 25 | B8000 | 8 x 8 | 1 | 70 Hz | 320 x 200 | | 6 | APA | 2 | 80 x 25 | B8000 | 8 x 8 | 1 | 70 Hz | 640 x 200 | | 7 | A/N | - | 80 x 25 | B0000 | 9 x 14 | 8 | 70 Hz | 720 x 350 | | 7* | A/N | - | 80 x 25 | B0000 | 8 x 14 | 8 | 70 Hz | 640 x 350 | | 7+ | A/N | - | 80 x 25 | B0000 | 9 x 16 | 8 | 70 Hz | 720 x 400 | | 7# | A/N | - | 80 x 25 | B0000 | 8 x 16 | 8 | 70 Hz | 640 x 400 | | D <sup>''</sup> | APA | 16 | 40 x 25 | A0000 | 8 x 8 | 8 | 70 Hz | 320 x 200 | | E | APA | 16 | 80 x 25 | A0000 | 8 x 8 | 4 | 70 Hz | 640 x 200 | | F | APA | - | 80 x 25 | A0000 | 8 x 14 | 2 | 70 Hz | 640 x 350 | | 10 | APA | 16 | 80 x 25 | A0000 | 8 x 14 | 2 | 70 Hz | 640 x 350 | | 11 | APA | 2 | 80 x 30 | A0000 | 8 x 16 | 1 | 60 Hz | 640 x 480 | | 12 | APA | 16 | 80 x 30 | A0000 | 8 x 16 | 1 | 60 Hz | 640 x 480 | | 13 | APA | 256 | 40 x 25 | A0000 | 8 x 8 | 1 | 70 Hz | 320 x 200 | Figure 2. Hardware Specific Video Mode Characteristics #### Notes: - 1. Personal System/2 Model P70 - a. The Plasma Display Panel works as an analog monochrome display. - b. When an external display is not attached, A/N 8 bit fonts only are available in modes 0#, 1#, 2#, 3#, 7#, and 7\*. - c. The power-on default mode is 7# when an external PS/2 color display is not attached. - d. The power-on default mode is 3+ when an external PS/2 color display is attached. # (AH) = 1BH - Return Functionality/State information: For the Personal System/2 Model P70: On Return: (DI+2DH) byte - Miscellaneous state information Bit 7 - Reserved Bit 6 = 1 - Plasma display active (Without 9 dot width font) Bit 5 = 0 - Background intensity = 1 - Blinking Bit 4 = 1 - Cursor emulation active (Always 0 for Personal System/2 Model Bit 3 = 1 - Mode set default palette loading disabled Bit 2 = 1 - Monochrome display attached Bit 1 = 1 - Summing active Bit 0 = 1 - All modes on all displays active (Always 0 for Personal System/2 Model 30) #### Notes: - 1. When the bit 6 is set to 1, the screen modes with 9-dot width font are not available. They are 0+, 1+, 2+, 3+, 7 and 7+. - 2. If one of those modes is requested, BIOS automatically sets it to a mode with 8-dot width font. They are 0#, 1#, 2#, 3#, 7#, and 7\*. # **Video Supplement** This supplement contains programming considerations that apply to the Advanced BIOS section of the *IBM Personal System/2 and IBM* Personal Computer BIOS Interface Technical Reference. This information should be used in addition to the material covered in the Advanced BIOS (ABIOS) section of the above manual. ## **Changes to Video ABIOS** The following are the model P70 video functions. #### 03H - Read Device Parameters This function returns parameters that indicate the current video state. #### Service Specific Output | SIZE | OFFSET | DESCRIPTION | |------|--------|------------------------------------------------------------------------------------| | Byte | +1B | Reserved | | Byte | +10 | Number of scan lines on the screen<br>00H - 200 scan lines<br>01H - 350 scan lines | | | | 02H - 400 scan lines | | | | 03H - 480 scan lines | | | | 04H to FFH - Reserved | | Word | +1E | Video mode setting | | Word | +20 | Type of monitor attached | | | | Bits 15 to 2 - Reserved | | | | Bit 1 - Plasma display | | | | 0 - Inactive | | | | 1 - Active | | | | Bit 0 - Color vs Monochrome | | | | 0 - Color display | | | | 1 - Monochrome display | | Word | +22 | Character height (bytes/character) | | Word | +24 | Character block specifier | | | | Bits 15 to 12 - Reserved | | | | Bits 11 to 8 - Character block select A | | | | Bits 7 to 4 - Reserved | | | | Bits 3 to 0 - Character block select B | | Word | +2A | Size of data buffer required | | | | for the Return ROM Fonts function in bytes. | | Word | +2E | Size of save/restore buffer header in bytes. | | Word | +30 | Size of save/restore hardware state in bytes. | | Word | +32 | Size of save/restore device block state in bytes. | | Word | +34 | Size of save/restore DAC state in bytes. | #### Notes: - 1. When offset $\pm 20$ bit 1 is set to 1, the screen modes with 9-dot width font are not available. They are 0+, 1+, 2+, 3+, 7 and 7+. - 2. If one of those modes is requested, BIOS automatically sets it to a mode with 8-dot width font. They are 0#, 1#, 2#, 3#, 7#, and 7\*. # **Notes:**