Phoenix

CBIOS

tor IBM® PS/2® Computers and Compatibles

Rhoenif Technical Reference Series

# CBIOS for IBM® PS/2® Computers and Compatibles

# The Complete Guide to ROM-Based System Software for DOS



**Phoenix Technologies Ltd.** 

Addison Wesley

51804

*Phoenip* Technical Reference Series

CBIOS for IBM<sup>®</sup> PS/2<sup>®</sup> Computers and Compatibles

> The Complete Guide to ROM-based System Software for DOS

Phoenix Technologies Ltd.

## **X**

Addison-Wesley Publishing Company, Inc. Reading, Massachusetts Menlo Park, California New York Don Mills, Ontario Wokingham, England Amsterdam Bonn Sydney Singapore Tokyo Madrid San Juan Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book and Addison-Wesley was aware of a trademark claim, the designations have been printed in initial capital letters.

#### Limitation of Liability

While every reasonable precaution has been taken in the preparation of this book, the author and the publishers assume no responsibility for errors or omissions, or for the uses made of the material contained herein or the decisions based on such use. No warranties are made, express or implied, with regard to the contents of this work, its merchantability, or fitness for a particular purpose. Neither the author nor the publishers shall be liable for direct, special, incidental, or consequential damages arising out of the use or inability to use the contents of this book.

#### Library of Congress Cataloging-in-Publication Data

CBIOS for IBM PS/2 computers and compatibles : the complete guide to ROM-based system software for DOS / Phoenix Technologies, Ltd.

p. cm. -- (The Phoenix technical reference series) Includes index. ISBN 0-201-51804-X
1. IBM Personal System/2 (Computer system) 2. Systems software.
3. Read-only storage. 4. Computer input-output equipment.
I. Phoenix Technologies, Ltd. II. Title: CBIOS. III. Series.

QA76.8.I25963C35 1989 005.4'469--dc19 89-6448

Copyright © 1989, 1988, 1987 by Phoenix Technologies Ltd.

All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. Printed in the United States of America. Published simultaneously in Canada.

Cover design by Hannus Design Associates Text design by Phoenix Technologies Ltd. Set in 10-point Modern by Phoenix Technologies Ltd.

ABCDEFGHIJ-AL-89 First printing, June, 1989

## Trademarks

This manual acknowledges the following trademarks:

Ashton-Tate and Framework are registered trademarks of Ashton-Tate Corporation

AST is a registered trademark of AST Research, Inc.

CHIPS/250 and CHIPS/280 are trademarks of Chips and Technologies, Inc.

AT, IBM, Personal Systems/2, PS/2, and PC/AT are registered trademarks of the International Business Machines Corporation. PC–DOS, PC/XT, VGA, CGA, MCA, MDA, EGA, OS/2, and Micro Channel are trademarks of the International Business Machines Corporation.

Intel is a registered trademark of Intel Corporation.

1-2-3, Lotus, and Symphony are registered trademarks of Lotus Development Corp.

Motorola is a registered trademark of Motorola Semiconductor Products, Inc.

MS, MS-DOS, and Microsoft are registered trademarks of the Microsoft Corporation.

NEC and Multisync are registered trademarks of Nippon Electric Corporation.

Quadram is a registered trademark of Quadram Corporation.

To Eric Enge, Stan Lyness, Paula Bishop, and the rest of the Phoenix Technologies Ltd. BIOS Engineering Department. Their tireless efforts have defined compatibility for the PC industry.

## **Table of Contents**

## About This Book

| About | This Book | <br>xix |
|-------|-----------|---------|
| About | THIS DOOK | <br>/   |

## Acronyms and Abbreviations

Acronyms and Abbreviations ..... xxiii

## Chapter 1 — The CBIOS

|     |     |             | 1                                                               |
|-----|-----|-------------|-----------------------------------------------------------------|
| • • | •   | . 3         | 3                                                               |
|     |     | . 4         | ŧ                                                               |
|     |     | . 6         | 3                                                               |
|     |     | 10          | )                                                               |
|     |     | 11          | I                                                               |
| •   |     | 13          | 3                                                               |
|     | ••• | ••••<br>••• | · · · · 3<br>· · · · 4<br>· · · 6<br>· · 10<br>· · 11<br>· · 13 |

## Chapter 2 — Hardware Environment

| Overview         23           80286/80386/80386SX         Microprocessors         25           Math         Coprocessors         26 |
|-------------------------------------------------------------------------------------------------------------------------------------|
| Micro Channel                                                                                                                       |
|                                                                                                                                     |
| I/O Devices: Introduction                                                                                                           |
| I/O Devices: Diskette and Disk Hardware 29                                                                                          |
| I/O Devices: Video Hardware 30                                                                                                      |
| I/O Devices: Keyboard Hardware 32                                                                                                   |
| I/O Devices: Parallel Port Hardware                                                                                                 |
| I/O Devices: Serial Port Hardware 34                                                                                                |
| System Time-Related Devices: Introduction                                                                                           |
| System Time-Related Devices: 82284 Clock Generator                                                                                  |
| System Time-Related Devices: 8254A PIT Chip 37                                                                                      |
| System Time-Related Devices: MC146818A RTC Chip 39                                                                                  |

## Chapter 2 — Hardware Environment, Cont'd

| CMOS RAM Service 4                               | 10 |
|--------------------------------------------------|----|
| DMA Controller 4                                 |    |
| Programmable Option Select (POS) 4               | 19 |
| Intel 8259A Programmable Interrupt Controllers 5 | 50 |
| System Control Port Definitions 5                | 52 |
| Power-On Password 5                              | 54 |
| NMI Mask                                         | 54 |
| Hardware I/O Port List 5                         | 55 |

## Chapter 3 — System RAM Data

| Overview                 | 75 |
|--------------------------|----|
| Interrupt Vectors        | 76 |
| CBIOS Data Area          | 78 |
| CBIOS Extended Data Area | 85 |

## Chapter 4 — CMOS RAM Data

| Overview               |   |
|------------------------|---|
| CMOS RAM I/O Ports     | 9 |
| CMOS RAM Data          |   |
| Extended CMOS RAM Data | 5 |

## Chapter 5 — ROM BIOS Data

| Overview       99         ROM Address Compatibility Table       100 |   |
|---------------------------------------------------------------------|---|
| System Configuration Data Table 102                                 |   |
| Feature Control                                                     |   |
| Diskette Parameters Table 105                                       |   |
| Fixed Disk Parameters Table 107                                     | 7 |
| Baud Rate Initialization                                            | ) |

## Chapter 6 — Power-On Self Tests (POST)

| Overview                                | 111 |
|-----------------------------------------|-----|
| POST Procedures                         | 113 |
| Rules for Positioning I/O Expansion ROM | 115 |
| Re-entering Real Mode                   | 116 |
| INT 19h, INT 18h, and System Boot       | 117 |
| POST Error Handling                     | 118 |

## Chapter 7 — INT 02h Nonmaskable Interrupt

| Overview                        | 119 |
|---------------------------------|-----|
| Nonmaskable Interrupt I/O Ports | 121 |
| Parity Error NMI Handling       | 123 |
| Time-Out Error Handling         | 125 |
| 80x87 Coprocessor Exceptions    | 127 |

## Chapter 8 - INT 09h and INT 16h Keyboard Services

| Overview                                                                                       |
|------------------------------------------------------------------------------------------------|
| Hardware Environment                                                                           |
| Keyboard-to-System Communication 132                                                           |
| Keyboard I/O Ports                                                                             |
| System RAM Data 134                                                                            |
| INT 09h: Internal Function Requests 136                                                        |
| INT 09h: System Reset ( <ctrl> <alt> <del>)</del></alt></ctrl>                                 |
| INT 09h: Break ( <ctrl> <break> or <ctrl> <scroll lock="">) 137</scroll></ctrl></break></ctrl> |
| INT 09h: Pause ( <ctrl> <num lock="">) 138</num></ctrl>                                        |
| INT 09h: Print Screen ( <prtsc> or <shift> <prtsc>) 140</prtsc></shift></prtsc>                |
| INT 09h: System Request ( <sysreq>) 141</sysreq>                                               |
| INT 16h: Keyboard Services 142                                                                 |
| INT 16h: AH = 00h Read Keyboard Input 143                                                      |
| INT 16h: AH = 01h Return Keyboard Status 144                                                   |
| INT 16h: AH = 02h Return Shift Flag Status 145                                                 |
| Int 16: AH = 03h Set Typematic Rate and Delay 146                                              |
| INT 16h: AH = 04h Reserved 146                                                                 |
| Function: AH = 05h Store Key Data 147                                                          |
| INT 16h: AH = 06h - 09h Reserved 147                                                           |

## Chapter 8 - INT 09h and INT 16h Keyboard Services, Cont'd

| INT 16h: AH = 10h Read Extended Keyboard Input      | 148 |
|-----------------------------------------------------|-----|
| INT 16h: AH = 11h Return Extended Keyboard Status   | 149 |
| INT 16h: AH = 12 Return Extended Shift Flags Status | 150 |
| INT 16h: AH = 13 - FFh Reserved                     | 150 |
| How to Read Character Code Tables                   | 151 |
| Character Codes: AH = 00h/01h                       | 153 |
| Character Codes: AH = 10h/11h                       | 158 |

## Chapter 9 – INT 10h Video Service

| Overview                                                    |
|-------------------------------------------------------------|
| Hardware Environment                                        |
| Video I/O Ports                                             |
| Video Modes                                                 |
| Mode/Monitor Support                                        |
| ROM Character Generators 178                                |
| System RAM Data                                             |
| Function: AH = 00h Set Video Mode 187                       |
| Function: AH = 01h Set Cursor Type 188                      |
| Function: AH = 02h Set Cursor Position                      |
| Function: AH = 03h Read Current Cursor Position             |
| Function: AH = 04h Read Light Pen Position                  |
| Function: AH = 05h Select New Video Page 192                |
| Function: AH = 06h Scroll Current Page Up                   |
| Function: AH = 07h Scroll Current Page Down                 |
| Function: AH = 08h Read Character/Attribute from Screen 194 |
| Function: AH = 09h Write Character/Attribute to Screen 195  |
| Function: AH = 0Ah Write Character Only to Screen           |
| Function: AH = 0Bh Set Color Palette 198                    |
| Function: AH = 0Ch Write Pixel 199                          |
| Function: AH = 0Dh Read Pixel 200                           |
| Function: AH = 0Eh Write Teletype to Active Page            |
| Function: AH = 0Fh Return Video Status 203                  |
| Function: AH = 10h Set Palette/Color Registers 204          |
| Function: AH = 11h Character Generator 213                  |
| Function: AH = 12h Alternate Select 229                     |
| Function: AH = 13h Write String 235                         |

## Chapter 9 - INT 10h Video Service, Cont'd

| Functions: AH = 14h - 19h Reserved                        | 235 |
|-----------------------------------------------------------|-----|
| Function: AH = 1Ah Read/Write Display Combination Code    | 236 |
| Function: AH = 1Bh Return Functionality/State Information | 237 |
| Function: AH = 1Ch Save/Restore Video State               | 242 |
| Function: AH = 1Dh - FFh Reserved                         | 250 |

## Chapter 10 — INT 13h Diskette Service

| Overview                                              |
|-------------------------------------------------------|
| Hardware Environment 254                              |
| Diskette Service I/O Ports 257                        |
| System RAM Data 259                                   |
| CMOS RAM Data                                         |
| ROM BIOS Data                                         |
| Error Handling                                        |
| Rules for Using CBIOS and ABIOS Diskette Services 268 |
| Function: AH = 00h Reset Diskette System              |
| Function: AH = 01h Read Diskette Status 270           |
| Function: AH = 02h Read Diskette Sectors 271          |
| Function: AH = 03h Write Diskette Sectors 272         |
| Function: AH = 04h Verify Diskette Sectors 273        |
| Function: AH = 05h Format Diskette Track 274          |
| Functions: AH = 06h - 07h Reserved 276                |
| Function: AH = 08h Read Drive Parameters 276          |
| Functions: AH = 09h - 14h Reserved 277                |
| Function: AH = 15h Read Drive Type 278                |
| Function: AH = 16h Detect Media Change 279            |
| Function: AH = 17h Set Diskette Type 280              |
| Function: AH = 18h Set Media Type for Format 281      |
| Functions: AH = 19h - FFh Reserved 282                |
| INT 0Eh Diskette Hardware Interrupt 282               |

## Chapter 11 — INT 13h Fixed Disk Service

| Overview             | 285 |
|----------------------|-----|
| Hardware Environment | 288 |

## Chapter 11 - INT 13h Fixed Disk Service, Cont'd

| Fixed Disk Service I/O Ports 289                    |
|-----------------------------------------------------|
| System RAM Data                                     |
| CMOS RAM Data                                       |
| ROM BIOS Data                                       |
| Fixed Disk Service Error Handling 301               |
| Rules for Using CBIOS and ABIOS Fixed Disk Services |
| Function: AH = 00h Reset Diskette(s) and Fixed Disk |
| Function: AH = 01h Read Disk Status 305             |
| Function: AH = 02h Read Disk Sectors                |
| Function: AH = 03h Write Disk Sectors               |
| Function: AH = 04h Verify Disk Sectors              |
| Function: AH = 05h Format Disk Cylinder             |
| Functions: AH = 06h - 07h Reserved 311              |
| Function: AH = 08h Read Drive Parameters 311        |
| Function: AH = 09h Initialize Drive Parameters      |
| Function: AH = 0Ah Read Long Disk Sectors           |
| Function: AH = 0Bh Write Long Disk Sectors          |
| Function: AH = 0Ch Seek to Cylinder 317             |
| Function: AH = 0Dh Alternate Reset Fixed Disk 318   |
| Function: AH = 0Eh Diagnostics 1: Read Test Buffer  |
| Function: AH = 0Fh Diagnostics 2: Write Test Buffer |
| Function: AH = 10h Test for Drive Ready 322         |
| Function: AH = 11h Recalibrate Drive 323            |
| Function: AH = 12h - 14h Reserved 323               |
| Function: AH = 15h Read Disk Type 324               |
| Functions: AH = 06h - 07h Reserved 325              |
| Function: AH = 19h Park Heads 325                   |
| Function: AH = 1Ah Format ESDI Drive                |

## Chapter 12 - INT 14h Serial Communications Service

| Overview                                                 | J |
|----------------------------------------------------------|---|
| Hardware Environment                                     |   |
| Serial Communications I/O Ports 332                      |   |
| ROM BIOS Data                                            | 5 |
| Error Conditions                                         | ) |
| Function: AH = 00h Initialize Serial Communications Port | ) |

## Chapter 12 - INT 14h Serial Communications Service, Cont'd

| Function: | AH = | 01h | Send Character               | 342 |
|-----------|------|-----|------------------------------|-----|
| Function: | AH = | 02h | Receive Character            | 343 |
| Function: | AH = | 03h | Read Serial Port Status      | 344 |
| Function: | AH = | 04h | Extended Initialize          | 345 |
| Function: | AH = | 05h | Extended Serial Port Control | 347 |

## Chapter 13 — INT 15h System Services

| Overview                                                |
|---------------------------------------------------------|
| Hardware Environment                                    |
| System Services I/O Ports                               |
| System RAM Data                                         |
| Extended System RAM Data                                |
| CMOS RAM Data                                           |
| ROM BIOS Data                                           |
| Functions: AH = 00h - 03h Reserved                      |
| Function: AH = 04h Build System Parameters Table        |
| Function: AH = 05h Build Initialization Table           |
| Functions: AH = 06h-0Eh Reserved                        |
| Function: AH = 0Fh Format ESDI Drive Periodic Interrupt |
| Function: AH = 10h - 20h Reserved                       |
| Function: AH = 21h Power-On Self Test Error Log         |
| Functions: AH = 22h - 4Eh Reserved                      |
| Function: AH = 4Fh Keyboard Intercept                   |
| Functions: AH = 50h - 7Fh Reserved                      |
| Function: AH = 80h Device Open                          |
| Function: AH = 81h Device Close                         |
| Function: AH = 82h Program Termination                  |
| Function: AH = 83h Set Event Wait Interval              |
| Function: AH = 84h Joystick Support                     |
| Function: AH = 85h System Request Key                   |
| Function: AH = 86h Wait                                 |
| Function: AH = 87h Move Block                           |
| Function: AH = 88h Read Extended Memory Size            |
| Function: AH = 89h Switch Processor to Protected Mode   |
| Functions: AH = 8Ah - 8Fh Reserved                      |
| Function: AH = 90h Device Busy                          |

## Chapter 13 - INT 15h System Services, Cont'd

| Function: AH = 91h Interrupt Complete                     | 382 |
|-----------------------------------------------------------|-----|
| Functions: AH = 92h - BFh Reserved                        | 382 |
| Function: AH = C0h Return System Configuration Parameters | 383 |
| Function: AH = C1h Return Extended BIOS Data Area         |     |
| Segment Address                                           | 385 |
| Function: AH = C2h Pointing Device Interface              | 386 |
| Function: AH = C3h Watchdog Time-Out                      | 395 |
| Function: AH = C4h Programmable Option Select             | 396 |
| Functions: AH = C5h - FFh Reserved                        | 397 |

## Chapter 14 — INT 17h Parallel Printer Service

| Overview                                 | 399 |
|------------------------------------------|-----|
| Hardware Environment                     | 401 |
| Parallel Port I/O Addresses 4            | 401 |
| System RAM Data                          | 403 |
| Error Handling                           | 404 |
| Function: AH = 00h Print Character 4     | 404 |
| Function: AH = 01h Initialize Printer 4  | 405 |
| Function: AH = 02h Read Printer Status 4 | 406 |
| Functions: AH = 03h - FFh Reserved 4     | 406 |

## Chapter 15 — INT 1Ah Time-of-Day Service

| Overview                      | 107 |
|-------------------------------|-----|
| INT 1Ah Time-of-Day Service 4 | 109 |
| INT 08h System Timer ISR 4    | 120 |
| INT 70h Real Time Clock ISR 4 | 123 |

## **Chapter 16 — Single Function CBIOS Services**

| Overview                         | 27 |
|----------------------------------|----|
| INT 05h Print Screen Service 4   | 29 |
| INT 11h Equipment List Service 4 | 31 |

## Chapter 16 - Single Function CBIOS Services, Cont'd

| INT | 12h | Memory Size Service      | 432 |
|-----|-----|--------------------------|-----|
| INT | 19h | Bootstrap Loader Service | 433 |

## Appendix A — CBIOS Error Messages

| Overview                                 | 9 |
|------------------------------------------|---|
| POST: Error Handling 44                  | 0 |
| POST: Beep Codes (Phoenix CBIOS Only) 44 | 2 |
| POST: Boot Failure Messages 44           | 9 |
| POST: Informational Messages 45          | 0 |
| NMI: Run Time Messages 45                | 1 |
| INT 19h: Password Messages 45            | 3 |
| Model 25 and 30 Beep Codes 45            | 4 |
| Model 25 and 30 Error Messages 45        | 5 |

## Appendix B — Keyboard/Mouse Controller

| overview                       | 31 |
|--------------------------------|----|
| 042 Hardware                   | 32 |
| 042 Firmware                   | 36 |
| 0x86/8042 Device Interface 46  | 38 |
| ystem Commands to 8042 47      | 70 |
| 042-to-System Replies 47       | 73 |
| ystem Commands to Keyboard 47  | 74 |
| eyboard Replies to System 47   | 76 |
| ystem Commands to the Mouse 47 | 77 |
| louse-to-System Replies        | 30 |

## Appendix C — Hardware Environment for 8086–Based Systems

| Overview                     | 81  |
|------------------------------|-----|
| lardware Address Locations 4 | 82  |
| Лісгоргосеssor               | 99  |
| 3087 Math Coprocessor 5      | 500 |
| System Support Gate Array 5  | 501 |

## Appendix C — Hardware Environment for 8086-Based Systems, Cont'd

| I/O Support Gate Array                 | 502 |
|----------------------------------------|-----|
| System Time-Related Logic              | 507 |
| Interrupt Controller Extensions        | 508 |
| System Timer                           | 509 |
| DMA Controller                         | 511 |
| 8259 Programmable Interrupt Controller | 513 |
| Miscellaneous Additional Logic         | 515 |

## Glossary

| Glossary | •••• | • • • • | <br>• • • • | • • • • | • • • • • | •••• | <br>• • • • • | <br> | •••• | 517 |
|----------|------|---------|-------------|---------|-----------|------|---------------|------|------|-----|

## **Additional Resources**

| Additional Resources |   | 525 |
|----------------------|---|-----|
| Index                | : |     |
| Index                |   | 527 |

## CBIOS for IBM® PS/2® Computers and Compatibles

The Complete Guide to ROM-based System Software for DOS

# **About This Book**

#### What this book is about

*CBIOS for IBM PS/2 Computers and Compatibles* is a detailed technical reference that describes the CBIOS, the portion of the PS/2 ROM BIOS designed to support single-tasking operating systems such as MS-DOS. The information provided in this book is applicable to all Micro Channel Architecture-based (MCA) and non-MCA-based IBM PS/2 and compatible computers, ranging from Models 25 and 30 through Model 80.

#### Who should read this book

CBIOS for IBM PS/2 Computers and Compatibles provides the most comprehensive source of information about the IBM PS/2 and compatible CBIOS available today. It can be used by anyone interested in learning more about their PS/2 or compatible computer.

Applications programmers and device driver developers will find a thorough discussion of each CBIOS device service and function, including the CBIOS VGA-compatible video service. In addition, *CBIOS for IBM PS/2 Computers and Compatibles* defines, to the bit level, all IBM PS/2 and compatible I/O port addresses and CBIOS-related CMOS RAM and system RAM data.

Hardware technicians and other system troubleshooters will appreciate the complete list of all CBIOS-generated error messages, their likely causes, and suggested solutions.

#### What we assume you know

This book assumes a basic knowledge of 80x86 assembly language programming concepts, PC architecture, and operating system concepts. If you are new to these subjects, use this book along with some of the excellent introductory books listed at the end of this book.

#### How to find information

CBIOS for IBM PS/2 Computers and Compatibles is organized into two major parts. Chapters 1–6 provide a general introduction to CBIOS concepts and describe how to use CBIOS services. Chapters 7–16 describe the individual CBIOS services and serve as a technical reference. Appendix A provides a comprehensive list of potential error messages. Appendix B provides information on the 8042-based Keyboard/Mouse Controller. Appendix C describes the hardware environment needed to implement 8086-based systems. Most readers will want to read chapters 1–6 first to get a basic grasp of the CBIOS features before turning to the individual service descriptions.

Each service-specific chapter (7-16) is organized in a similar fashion. There is a description of the service and the hardware environment of this service, a discussion on how errors are handled for this service, and complete descriptions of each service function. The function descriptions include an explanation of what the function does, the function's required inputs and outputs, and any special programming considerations or hardware "gotcha's" associated with the function.

#### Other volumes in this series

CBIOS for IBM PS/2 Computers and Compatibles is one of several volumes about BIOS software in the Phoenix Technical Reference Series published by Addison-Wesley. Other volumes are:

ABIOS for IBM PS/2 Computers and Compatibles – a complete technical reference describing the portion of a PS/2 BIOS that supports multitasking operating systems such as OS/2.

System BIOS for IBM PC/XT/AT Computers and Compatibles — a complete technical reference for the BIOS in all standard architecture computers.

The volumes of this series are a natural companion for anyone who owns and programs an IBM PC, XT, AT, or PS/2 model, or any compatible system.

#### Acknowledgments

No writing project as large as this can be completed without significant contributions from many individuals. We would like to acknowledge the Phoenix employees whose time and effort helped make this book possible.

First and foremost, we gratefully acknowledge the vision and technical skill of Neil Colvin, founder, CEO, and Chief Scientist of Phoenix Technologies Ltd. We also gratefully acknowledge the expert guidance of Lance Hansche, President of Phoenix Technologies Ltd. Without Neil and Lance's leadership, Phoenix would not be in the position of technological preeminence it now enjoys.

In the marketing area, Phoenix Vice President Rich Levandov's foresight and support made this book possible. And Product Marketing Manager Henry Suwinsky's tactful and dauntless guidance shepherded this project through all phases of its existence.

On the technical side, we acknowledge the Phoenix engineers who developed the Phoenix PS/2 BIOS. Specifically, we gratefully acknowledge the efforts of Eric Enge, Director of PC Product Engineering, Paula Bishop, and Stan Lyness, who have been endlessly patient with us and tireless in their efforts to ensure quality PS/2-compatible BIOS products and documentation. We also must acknowledge the efforts expended by other Phoenix engineers, including Bruce Cairns, Paul Chicoine, Greg Honsa, Suzanne Laferriere, Malcolm Pordes, Debbie Schultz, and Trevor Western.

In the production of this volume, many people contributed significantly. Chief among these were Kathy Schiff, Manager of Technical Communications, who provided editorial guidance and direction. Writers Marianne Adams and Dr. George Elliott Tucker contributed critical and essential writing, editing, and production assistance. And last but not least, a special thanks goes to Sandie Zierak, Chief Production Coordinator, for her invaluable contributions in the fields of graphics, document design, and document production.

The Authors

Mike Boston Paul Narushoff

Phoenix Technologies Ltd. Norwood, MA March, 1989

## Acronyms and Abbreviations

| The following | abbreviations and acronyms are used in this manual: |
|---------------|-----------------------------------------------------|
| ASCII         | American Standard Code for Information Interchange  |
| ASIC          | Application-Specific Integrated Circuit             |
| b             | Binary                                              |
| BCD           | Binary coded decimal                                |
| BIOS          | Basic input/output system                           |
| bps           | Bits per second                                     |
| CDA           | Common data area                                    |
| CGA           | Color graphics adapter                              |
| CRC           | Cyclic redundancy check                             |
| CMOS          | Complementary metal oxide semiconductor             |
| DMA           | Direct memory access                                |
| DSR           | Device service routine                              |
| ECC           | Error checking and correction                       |
| EGA           | Enhanced graphics adapter                           |
| EOI           | End of interrupt                                    |
| ESDI          | Enhanced small device interface                     |
| FTT           | Function transfer table                             |
| h             | Hexadecimal                                         |
| INT           | Interrupt                                           |
| I/O           | Input/Output                                        |
| IRQ           | Interrupt request line                              |
| ISR           | Interrupt service routine                           |
| К             | Kilobytes                                           |
| Kbs           | Kilobits per second                                 |
| LID           | Logical ID                                          |
| LSB           | Least significant byte                              |
| LSI           | Large scale integration                             |
| M, MB         | Megabytes                                           |
| MCGA          | Multicolor graphics array                           |
| MDA           | Monochrome Display Adapter                          |
| MFM           | Modified frequency modulation                       |
| MHz           | Megahertz                                           |
| <br>          |                                                     |

The following abbreviations and acronyms are used in this manual:

## Acronyms and Abbreviations, Continued

| MSB  | Most significant byte         |
|------|-------------------------------|
| NMI  | Nonmaskable interrupt         |
| OS/2 | Operating System/2            |
| PGA  | Professional graphics adapter |
| POST | Power-on self test            |
| PTL  | Phoenix Technologies Ltd.     |
| RAM  | Random access memory          |
| RB   | Request block                 |
| RLL  | Run length limited            |
| ROM  | Read-only memory              |
| RTC  | Real time clock               |
| VGA  | Video graphics array          |
| VLSI | Very large scale integration  |

# Chapter 1 The CBIOS

#### Overview

#### What is the PS/2 BIOS?

The ROM BIOS contained in Micro Channel Architecture-based IBM PS/2 and compatible computers performs the same function that all basic input/ output systems do: it isolates the operating system and application programs from direct manipulation of the hardware.

When compared with the ROM BIOS contained in IBM PC XT/AT and compatible computers, however, the PS/2 ROM BIOS has one critical difference it is designed to support two kinds of operating systems. The PS/2 ROM BIOS is divided into two discrete parts: the Advanced BIOS (ABIOS) and the Compatibility BIOS (CBIOS).

#### The CBIOS

The CBIOS portion of the PS/2 ROM BIOS provides IBM PS/2 and compatible computers backward compatibility with single-tasking, Intel 80x86 real address mode operating systems such as PC- or MS-DOS. As a result, the CBIOS consists of a superset of the services and functions available in the IBM PC/XT/AT ROM BIOS, and it interfaces with the operating system in the same well understood way.

continued

The CBIOS

#### **Overview**, Continued

#### The ABIOS

The ABIOS portion of the PS/2 ROM BIOS provides IBM PS/2 and compatible computers with "forward" compatibility with multitasking, bimodal (real mode, protected mode, or both) operating systems, such as IBM OS/2. The ABIOS supports the same hardware devices that are supported by the CBIOS, but its interface and data structures are specifically constructed to facilitate the multitasking, bimodal nature of its design.

#### For more information on the ABIOS

For a complete treatment of the ABIOS, see ABIOS for IBM PS/2 Computers and Compatibles in this series.

#### In this chapter

This chapter presents a general introduction to the major concepts and design features of the CBIOS.

The following topics are discussed:

- CBIOS Compatibility
- CBIOS Memory Usage
- Interrupts
- CBIOS Software Interrupt Handlers
- Summary: The CBIOS Services

#### Introduction

In addition to those BIOS routines responsible for testing/initializing system hardware, all BIOSs are essentially made up of a group of ROM-based input/output device services. Each of these routines services one subsystem of system hardware. Individual BIOS routines service the display, diskette drives, fixed disk drives, the keyboard, and so on.

Operating systems and applications programs written to the BIOS device service routines instead of directly to hardware I/O ports and control words are assured a high degree of hardware independence.

#### CBIOS, BIOS, and application program compatibility

The CBIOS contains a superset of the service routines contained in all versions of the ROM BIOS written for PC/AT-compatible computers.

Because of this, the CBIOS ensures that operating systems (e.g. MS-DOS) and applications programs written to these older BIOS versions will be compatible with the newer IBM PS/2-compatible MCA-based hardware.

#### CBIOS and PS/2

Besides service routines contained in previous IBM-compatible BIOSs, the CBIOS also contains all the added functionality required of the single-tasking component of the IBM PS/2 MCA-compatible BIOS.

The CBIOS device service routines support:

- All IBM VGA video modes and video functions
- Color and monochrome direct drive analog monitors
- A "mouse" or other pointing device
- Any of 32 IBM-defined fixed disk types
- 360K and 1.2 MB 5.25-inch diskette drives
- 720K and 1.44 MB 3.5-inch diskette drives
- Micro Channel Architecture-compatible adapter boards
- All PS/2-compatible system board components
- Programmable Option Select
- Password
- Reference Diskette

## **CBIOS Memory Usage**

#### Introduction

Although the CBIOS routines reside in system Read-Only Memory (ROM), they also make use of information stored in CMOS RAM and System RAM.

The illustration on the following page outlines the location and use of CBIOS ROM, System RAM, and CMOS RAM.



#### ROM BIOS DATA

The CBIOS contains routines that test and initialize system hardware and boot the operating system. It also contains routines that service the microprocessor, the fixed disk, keyboard, display, and other peripheral devices with which the microprocessor must communicate. Each of the routines is stored in system Read-Only Memory (ROM). The CBIOS (and the ABIOS) are stored at address E0000h to FFFFFh in ROM.



#### SYSTEM RAM DATA

The CBIOS uses system RAM to store data that it needs to reference or update in the course of executing its device service routines. The CBIOS also uses system RAM to store the interrupt vectors.

- Interrupt Vector Table An interrupt vector is the segment:offset address of a routine invoked by issuing the assembly language "INT" mnemonic. Interrupt vectors are stored in a "Table of Interrupt Vectors" in low memory beginning at 00:00h and ending at 00:3FFh. The CBIOS initializes those table entries that are reserved for BIOS use during POST. Each entry points to one ROM BIOS service routine. Other interrupt vector table entries are reserved for use by the operating system, the microprocessor, and by end users.
- BIOS Data Area At POST, the CBIOS stores a set of data definitions in system RAM in absolute memory location 400h-500h. In the process of executing device service routines, the CBIOS refers to and updates this data. For example, the CBIOS updates 40:50h, the location of the cursor on the video page, each time the CBIOS routine "Set Cursor Position" is executed.
- Extended BIOS Data Area The CBIOS uses the top 1K of system RAM to store additional data. The segment of this extended BIOS data area is located at 40:0Eh in the standard BIOS Data Area. The data located in this area is concerned with the functions that are CBIOS enhancements over the historical PC XT/AT BIOSs. For example, data definitions concerned with the "mouse" or other pointing devices are stored in the extended BIOS Data Area.



#### CMOS RAM DATA

The CBIOS uses nonvolatile CMOS RAM to store real time clock, system configuration, and system diagnostic information. Depending on the system configuration, the CBIOS can use up to two CMOS RAM storage areas.

- CMOS Data Area 64 bytes (32 Words) of time-of-day and configuration data are located on the system real time clock chip. All implementations of the CBIOS make use of this information.
- Extended CMOS Data Area On systems that incorporate more than four adapter slots, the CBIOS requires an additional 2K of CMOS RAM storage. This area is mainly used for configuration information associated with the additional adapter slots.

#### For more information

To get more information on:

- System RAM Data, turn to Chapter 3 of this volume.
- CMOS RAM Data, turn to Chapter 4 of this volume.

#### Interrupts

#### Introduction

Computer systems based on the Intel 80x86 microprocessors are controlled mainly through the use of interrupts. Interrupts can be generated by the microprocessor, by system hardware, or by software.

When an interrupt occurs, control of the computer is transferred to an interrupt handling routine. Once the routine has executed, the processor's program counter and flag register are returned to their previous state.

#### Interrupt numbers

Every interrupt is assigned its own unique interrupt number, ranging from 00h to FFh.

By convention, certain ranges of interrupt numbers are reserved for special use. The interrupts numbers ranging from 20h–3Fh, for example, are reserved for DOS. The numbers from 60h–67h and F1h–FFh are reserved for user–created interrupt routines.

#### Interrupt vectors

An interrupt vector is the double word, segment:offset address of the routine assigned to a given interrupt number. Interrupt vectors are stored in a table in memory beginning at address 00:00h. The vector for INT 00h is stored at location 00:00h to 00:03h; the address for INT 02h is stored at address 00:04h to 00:07h, and so forth.

#### How interrupt vectors are initialized

The CBIOS writes the Interrupt Vector Table to low memory as part of the power-on self test (POST) process, and it initializes the vector address of all those interrupts concerned with the BIOS. When DOS is booted, it, in turn, initializes all those interrupt vectors concerned with DOS. End users must take care to initialize the vectors concerned with their own interrupts.

#### How interrupts are invoked

How a given interrupt is invoked depends on what type it is.

The table below defines the range of interrupt numbers reserved for each interrupt type. It also summarizes how the various types of interrupts are invoked.

| Туре      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Processor | <ul> <li>Microprocessor, or logical, interrupts are invoked by the processor as a result of some unusual program result, such as a program attempt to divide by zero.</li> <li>INTs 00h-04h are reserved for the processor.</li> </ul>                                                                                                                                                                                                                                                                                                                    |
| Hardware  | <ul> <li>Hardware interrupts are invoked by peripheral devices by setting their respective Interrupt Request Line (IRQ). Each time a key is pressed, for example, the keyboard hardware generates a hardware interrupt. Hardware interrupts are vectored to Interrupt Service Routines (ISR) that generally reside in the BIOS.</li> <li>INTs 08h-0Fh and 70h-77h are reserved by the CBIOS.</li> </ul>                                                                                                                                                   |
| Software  | <ul> <li>Software interrupts are invoked via the assembly language "INT" mnemonic. Most software interrupts are vectored to device service routines (DSR) located in the ROM BIOS or in DOS. There are three exceptions to this rule, however.</li> <li>CBIOS software INTs 1Dh, 1Eh, and 46h do not service a particular device, but act instead to return various ROM-resident hardware parameter tables.</li> <li>INTs 20h-3Fh are reserved for DOS.</li> <li>INTs 05h, 10h-1Ah, 1Dh-1Fh, 40h, 41h, 43h, and 46h are reserved for the BIOS.</li> </ul> |
| User      | User interrupts are a special class of software interrupt. They are invoked in the same way as software interrupts are. That is, through the INT mnemonic.<br>INTs 60h-67h and INTs F1h-FFh are reserved for user interrupt routines.                                                                                                                                                                                                                                                                                                                     |

## Interrupts, Continued

#### Interrupt vector table

The table below identifies each interrupt by function and type. Where applicable, it lists the interrupt vector address initialized by the CBIOS at POST.

Note: Further discussion of interrupts is limited to those interrupts directly related to the CBIOS. The column labeled "Ref. Chapter" tells where to turn for a full description of these interrupts.

| INT | Function                     | Туре     | Vector | Ref.<br>Chap. |
|-----|------------------------------|----------|--------|---------------|
| 00h | Divide by Zero               | Logical  |        |               |
| 01h | Single Step                  | Logical  |        |               |
| 02h | Nonmaskable Interrupt (NMI)  | Logical  | FE2C3h | 7             |
| 03h | Breakpoint                   | Logical  |        |               |
| 04h | Overflow                     | Logical  |        | ,             |
| 05h | Print Screen                 | Software | FFF54h | 16            |
| 06h | Invalid Op Code              | Hardware |        |               |
| 07h | Math Coprocessor Not Present | Hardware |        |               |
| 08h | System Timer                 | Hardware | FFEA5h | 15            |
| 09h | Keyboard                     | Hardware | FE987h | 8             |
| 0Ah | Invalid Task Segment State   | Hardware |        |               |
| 0Bh | Serial Communications (COM2) | Hardware |        |               |
| 0Ch | Serial Communications (COM1) | Hardware |        |               |
| 0Dh | Parallel Printer (LPT2)      | Hardware |        |               |
| 0Eh | Diskette                     | Hardware | FEF57h | 8             |
| 0Fh | Parallel Printer (LPT1)      | Hardware |        |               |
| 10h | Video                        | Software | FF065h | 9             |
| 11h | Equipment List               | Software | FF84Dh | 16            |
| 12h | Memory Size                  | Software | FF841h | 16            |
| 13h | Fixed Disk/Diskette          | Software | FE3FEh | 11            |
| 14h | Serial Communication         | Software | FE739h | 12            |
| 15h | System Services              | Software | FF859h | 13            |
| 16h | Keyboard                     | Software | FE84Eh | 8             |
| 17h | Parallel Printer             | Software | FEFD2h | 14            |
| 18h | Load ROM BASIC               | Software | F1C90h | 16            |

## Interrupts, Continued

## Interrupt vector table, cont'd

| INT     | Function                             | Туре       | Vector | Ref.<br>Chap. |
|---------|--------------------------------------|------------|--------|---------------|
| 19h     | Bootstrap Loader                     | Software   | FE6F2h | 16            |
| 1Ah     | System Timer & Real-Time Clock       | Software   | FFE6Eh | 15            |
| 1Bh     | Keyboard Break                       | Software   | FFF53h | 8             |
| 1Ch     | User Timer Tick                      | User       | FFF53h | 15            |
| 1Dh     | Video Parameters Table               | BIOS Table | FF0A4h | 9             |
| 1Eh     | Diskette Parameters Table            | BIOS Table | FEFC7h | 10            |
| 1Fh     | Video Graphics Characters            | User       | F7F67h | 9             |
| 20h-3Fh | Reserved for DOS                     |            |        |               |
| 40h     | Diskette BIOS Revector               | Software   | FEC59h | 10            |
| 41h     | Fixed Disk Parameter Table           | BIOS Table | FE401h | 11            |
| 42h     | EGA Default Video Driver             | BIOS Table |        |               |
| 43h     | Video Graphics Characters            | User       |        | 9             |
| 44h-45h | Reserved                             |            |        |               |
| 46h     | Fixed Disk Parameter Table           | BIOS Table | FE401h | 11            |
| 47h-49h | Reserved                             |            |        |               |
| 4Ah     | User Alarm                           | User       |        | 15            |
| 4Bh-5Fh | Reserved                             |            |        |               |
| 60h-66h | Reserved for User Program Interrupts | User       |        | 1             |
| 67h     | LIM EMS Driver                       |            |        |               |
| 68h-6Fh | Reserved                             |            |        |               |
| 70h     | Real Time Clock                      | Hardware   | F5124h | 15            |
| 71h     | Redirect Cascade                     | Hardware   | F5266h |               |
| 72h-73h | Reserved                             |            |        |               |
| 74h     | Pointing Device (Mouse)              | Hardware   | F4910h | 13            |
| 75h     | 80287 Exception                      | User       | F5257h | 7             |
| 76h     | Fixed Disk                           | Hardware   | FE2C3h | 11            |
| 77h-7Fh | Reserved                             |            |        |               |
| 80h-F0h | Reserved for BASIC                   | BASIC      |        | 16            |
| F1h-FFh | Reserved for User Program Interrupts | User       |        |               |

#### **CBIOS Software Interrupt Handlers**

#### Software DSRs, functions, and parameters

Most of the CBIOS software interrupt handlers are capable of executing more than one device related routine, or function.

Individual functions within a given software interrupt handler are identified by a hex number, and they are selected by specifying that number in the AH register when the interrupt is invoked.

Note: Some software DSRs also contain subfunctions. Subfunctions are usually selected via the AL or the BL register.

#### Parameter passing

In addition to function numbers, all other parameters are passed to and from the CBIOS routines via the microprocessor registers. All CBIOS software interrupt handlers save the program counter registers, the flag register, and all other registers except the AX register and those registers that return a value to the caller.

#### How functions are described

Throughout this manual, the functions performed by the CBIOS software interrupt handlers are described in terms of their input and output parameters. The sample description below is excerpted from Chapter 9, which describes the CBIOS Video Service functions.

#### Example of a function description

## Function: AH = 02h Set Cursor Position

#### Description

The Set Cursor Position function sets the cursor position (in terms of row-by-column coordinates) for the display page indicated in BL. It saves the position as a two-byte row-by-column table entry in the cursor coordinates byte at 40:50h. Row and column coordinates are indicated in registers DH and DL respectively.

The Set Cursor Position function applies to both text and graphics video modes. In text modes, if the display page selected in BH is the active display page, the on-screen cursor will move to the coordinates indicated in registers DH and DL. In graphics modes, the cursor is invisible, but it is used to define a position on the screen.

#### Input/output

| AH | =              | 02h                                         |
|----|----------------|---------------------------------------------|
| BH | =              | Display page number (see function AH = 05h) |
| DH | =              | Row (0 is top row of screen)                |
| DL | =              | Column (0 is leftmost column)               |
| AX | =              | 00h                                         |
|    | BH<br>DH<br>DL | AH =<br>BH =<br>DH =<br>DL =<br>AX =        |

# Example program

This assembly language program uses INT 10h Video Service function AH = 02h Set Cursor Position to move the cursor on video page 0 to row 3, column 14.

| MOV AH, 2  | ;Select "Set Cursor Position" function   |
|------------|------------------------------------------|
| MOV DH, 3  | ;Input row parameter into DH register    |
| MOV DL, 14 | ;Input column parameter into DL register |
| INT 10H    | ;Invoke INT 10h, CBIOS Video Service     |

## Introduction

Each CBIOS service executes at least one function. When a given CBIOS service is capable of executing more than one function, functions are selected by placing the proper function number in the AH register. Subfunctions are selected via either the AL register or the BL register.

The tables below briefly define each CBIOS service and list each CBIOS function and subfunction.

| Print Screen<br>Service |           | The CBIOS Print Screen Service prints the contents of the current video screen to printer number 0. |  |
|-------------------------|-----------|-----------------------------------------------------------------------------------------------------|--|
| INT                     | PARAMETER | FUNCTION                                                                                            |  |
| 05h                     | None      | Print Screen                                                                                        |  |

| Video<br>Service |                                  | The CBIOS Video Service provides I/O support for<br>both color and monochrome analog monitors.<br>They allow the display of all 17 IBM PS/2 video<br>modes. |
|------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT              | PARAMETER                        | FUNCTION                                                                                                                                                    |
| 10h              | AH = 00h                         | Set Mode                                                                                                                                                    |
|                  | AH = 01h                         | Set Cursor Type                                                                                                                                             |
|                  | AH = 02h                         | Set Cursor Position                                                                                                                                         |
|                  | AH = 03h                         | Read Cursor Position                                                                                                                                        |
|                  | AH = 04h                         | Read Light Pen Position                                                                                                                                     |
|                  | AH = 05h                         | Select Active Display Page                                                                                                                                  |
|                  | AH = 06h                         | Scroll Active Page Up                                                                                                                                       |
|                  | AH = 07h Scroll Active Page Down |                                                                                                                                                             |
|                  | AH = 08h                         | Read Attribute/Character at Current Cursor Position                                                                                                         |
|                  | AH = 09h                         | Write Attribute/Character at Current Cursor Position                                                                                                        |

# Introduction, cont'd

| Video<br>Service,<br>cont'd |           | The CBIOS Video Service provides I/O support for<br>both color and monochrome analog monitors.<br>They allow the display of all 17 IBM PS/2 video<br>modes.                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT                         | PARAMETER | FUNCTION                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10h                         | AH = 0Ah  | Write Character A                                                                                                                                                                     | t Current Position                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                             | AH = 0Bh  | Set Color Palette                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                             | AH = 0Ch  | Write Dot                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                             | AH = 0Dh  | Read Dot                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                             | AH = 0Eh  | Write Teletype To                                                                                                                                                                     | Active Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                             | AH = 0Fh  | Read Current Vide                                                                                                                                                                     | eo State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                             | AH = 10h  | SET PALETTE RE                                                                                                                                                                        | GISTERS:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                             |           | Parameter                                                                                                                                                                             | Subfunction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                             |           | AL = 00h $AL = 01h$ $AL = 02h$ $AL = 03h$ $AL = 04h-06h$ $AL = 07h$ $AL = 09h$ $AL = 10h$ $AL = 11h$ $AL = 12h$ $AL = 12h$ $AL = 13h$ $AL = 15h$ $AL = 16h$ $AL = 17h$ $AL = 18h-19h$ | Set individual palette register<br>Set overscan register<br>Set all palette registers and overscan<br>Toggle intensify/blinking bit<br>Reserved<br>Read individual palette register<br>Read overscan register<br>Read all palette registers and<br>overscan<br>Set individual color register<br>Reserved<br>Set block of color registers<br>Select color page (not valid for<br>mode 13h)<br>BL = 00h Select paging mode<br>BL = 01h Select page<br>Reserved<br>Read individual color register<br>Reserved<br>Read block of color registers<br>Reserved<br>Read block of color registers<br>Reserved<br>Read block of color registers<br>Reserved<br>Read color paging status<br>Sum color values to gray shades |

## Introduction, cont'd

|     | Video<br>Service<br>cont'd | both color and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | eo Service provides I/O support for<br>monochrome analog monitors.<br>display of all 17 IBM PS/2 video                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT | PARAMETER                  | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10h | AH = 11h                   | CHARACTER GE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | NERATOR:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |                            | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Subfunction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |                            | $AL = 00h \\ AL = 01h \\ AL = 02h \\ AL = 03h \\ AL = 04h \\ AL = 10h \\ AL = 11h \\ AL = 12h \\ AL = 12h \\ AL = 12h \\ AL = 20h \\ AL = 21h \\ AL = 22h \\ AL = 23h \\ AL = 24h $ | User alpha load<br>ROM 8x16 font<br>ROM 8x8 double dot font<br>Set block specifier (valid in alpha<br>modes)<br>ROM 8x16 font<br>User alpha load (cali after mode<br>set)<br>ROM 8x14 font (cali after mode set)<br>ROM 8x16 font (cali after mode set)<br>ROM 8x16 font (cali after mode set)<br>Set user graphics characters<br>pointer at INT 1Fh<br>Set user graphics characters<br>pointer at INT 43h<br>ROM 8x14 font<br>ROM 8x8 double dot font<br>ROM 8x8 double dot font<br>ROM 8x16 font |
| 10h | AH = 12h                   | AL = 30h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Get font Information                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |                            | Parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Subfunction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |                            | BL = 10h<br>BL = 20h<br>BL = 30h<br>BL = 31h<br>BL = 32h<br>BL = 33h<br>BL = 34h<br>BL = 35h<br>BL = 36h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Return EGA information<br>Select alternate print screen routine<br>Select scan lines for alphanumeric<br>modes<br>Default palette loading during<br>set mode<br>Video<br>Summing to gray shades<br>Cursor emulation<br>Display switch<br>Video screen off/on                                                                                                                                                                                                                                       |

# Introduction, cont'd

|     | Video<br>Service<br>cont'd | The CBIOS Video Service provides I/O support for<br>both color and monochrome analog monitors.<br>They allow the display of all 17 IBM PS/2 video<br>modes. |                                                                                                                |
|-----|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| INT | PARAMETER                  | FUNCTION                                                                                                                                                    |                                                                                                                |
| 10h | AH = 13h                   | ALTERNATE SEL                                                                                                                                               | ECT:                                                                                                           |
|     |                            | Parameter                                                                                                                                                   | Subfunction                                                                                                    |
|     |                            | AL = 00h<br>AL = 01h<br>AL = 02h<br>AL = 03h                                                                                                                | Cursor not moved<br>Cursor is moved<br>Cursor not moved (text modes only)<br>Cursor is moved (text modes only) |
|     | AH = 14h-19h               | Reserved                                                                                                                                                    |                                                                                                                |
|     | AH = 13h                   | READ/WRITE DIS                                                                                                                                              | PLAY COMBINATION CODE:                                                                                         |
|     |                            | Parameter                                                                                                                                                   | Subfunction                                                                                                    |
|     |                            | AL = 00h<br>AL = 01h                                                                                                                                        | Read display combination code<br>Write display combination code                                                |
|     | AH = 1Bh                   | Read/Write Display Combination Code                                                                                                                         |                                                                                                                |
|     | AH = 1Ch                   | Save/Restore Video State                                                                                                                                    |                                                                                                                |
|     | AH = 1Dh-FFh               | Reserved                                                                                                                                                    |                                                                                                                |

| Equipment List<br>Service |           | The CBIOS Equipment List Service returns the system equipment list, as determined by the CBIOS POST routine. |  |
|---------------------------|-----------|--------------------------------------------------------------------------------------------------------------|--|
| INT                       | PARAMETER | FUNCTION                                                                                                     |  |
| 11h                       | None      | Read Equipment List                                                                                          |  |

# Introduction, cont'd

| Memory Size<br>Service |           | The CBIOS Memory Size Service returns the amount of available base memory (in Kilobytes), as determined by the POST routine. |  |
|------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------|--|
| INT                    | PARAMETER | FUNCTION                                                                                                                     |  |
| 12h                    | None      | Read Memory Size                                                                                                             |  |

| Diskette<br>Service |              | <ul> <li>The CBIOS Diskette Service performs BIOS-level read, write, format, initialization, and diagnostic support for up to two internal diskette drives.</li> <li>Note: If a fixed disk is installed, the CBIOS automatically revectors all 13h Diskette Service requests to INT 40h. This revectoring is transparent to end users. End users should continue to use INT 13h for both fixed disk and diskette service requests.</li> </ul> |  |
|---------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| INT                 | PARAMETER    | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 13h                 | AH = 00h     | Reset Diskette System                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                     | AH = 01h     | Read Diskette Status                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                     | AH = 02h     | Read Diskette Sectors                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                     | AH = 03h     | Write Diskette Sectors                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|                     | AH = 04h     | Verify Diskette Sectors                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
|                     | AH = 05h     | Format Diskette Track                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                     | AH = 06h-07h | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                     | AH = 08h     | Read Drive Parameters                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                     | AH = 09h-14h | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                     | AH = 15h     | Read Drive Type                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                     | AH = 16h     | Detect Media Change                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|                     | AH = 17h     | Set Diskette Type                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|                     | AH = 18h     | Set Media Type for Format                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                     | AH = 19h-FFh | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |

# Introduction, cont'd

| Fixed Disk<br>Service |              | The CBIOS Fixed Disk Service performs BIOS level read, write, format, initialization, and diagnostic functions for up to two fixed disk drives. |  |
|-----------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|
| INT                   | PARAMETER    | FUNCTION                                                                                                                                        |  |
| 13h                   | AH = 00h     | Reset Disk System                                                                                                                               |  |
|                       | AH = 01h     | Read Disk Status                                                                                                                                |  |
|                       | AH = 02h     | Read Disk Sectors                                                                                                                               |  |
|                       | AH = 03h     | Write Disk Sectors                                                                                                                              |  |
|                       | AH = 04h     | Verify Disk Sectors                                                                                                                             |  |
|                       | AH = 05h     | Format Disk Cylinder                                                                                                                            |  |
|                       | AH = 06h-07h | Reserved                                                                                                                                        |  |
|                       | AH = 08h     | Read Drive Parameters                                                                                                                           |  |
|                       | AH = 09h     | Initialize Drive Parameters                                                                                                                     |  |
|                       | AH = 0Ah     | Read Long Disk Sectors                                                                                                                          |  |
|                       | AH = 0Bh     | Write Long Disk Sectors                                                                                                                         |  |
|                       | AH = 0Ch     | Seek to Cylinder                                                                                                                                |  |
|                       | AH = 0Dh     | Alternate Disk Select                                                                                                                           |  |
|                       | AH = 0Eh     | Diagnostics                                                                                                                                     |  |
|                       | AH = 0Fh     | Diagnostics                                                                                                                                     |  |
|                       | AH = 10h     | Test Drive Ready                                                                                                                                |  |
|                       | AH = 11h     | Recalibrate                                                                                                                                     |  |
|                       | AH = 12h-14h | Reserved                                                                                                                                        |  |
|                       | AH = 15h     | Read Disk Type                                                                                                                                  |  |
| AH = 16h-18h Reserved |              | Reserved                                                                                                                                        |  |
|                       | AH = 19h     | Park Heads                                                                                                                                      |  |
| · ·                   | AH = 1Ah-FFh | Reserved                                                                                                                                        |  |

# Introduction, cont'd

| Serial<br>Communication<br>Service |              | The CBIOS Serial Communication Service per-<br>forms RS-232-C character I/O for IBM-compatible serial port adapters. |
|------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------|
| INT                                | PARAMETER    | FUNCTION                                                                                                             |
| 14h                                | AH = 00h     | Initialize the Communications Port                                                                                   |
|                                    | AH = 01h     | Send Character                                                                                                       |
|                                    | AH = 02h     | Receive Character                                                                                                    |
|                                    | AH = 03h     | Read Status                                                                                                          |
|                                    | AH = 04h     | Extended Initialize                                                                                                  |
|                                    | AH = 05h     | Extended Communications Port Control                                                                                 |
|                                    | AH = 06h-FFh | Reserved                                                                                                             |

| System<br>Services |                | several miscell               | tem Services is composed of<br>aneous system-level subservices,<br>invoked via the INT 15h |
|--------------------|----------------|-------------------------------|--------------------------------------------------------------------------------------------|
| INT                | PARAMETER      | FUNCTION                      |                                                                                            |
| 15h                | AH = 00h-03h   | Reserved                      |                                                                                            |
|                    | AH = 04h       | Build ABIOS Syste             | em Parameters Table                                                                        |
|                    | AH = 05h       | Build ABIOS Initial           | ization Table                                                                              |
|                    | AH = 06h - 20h | Reserved                      |                                                                                            |
|                    | AH = 21h       | POWER-ON SELF TEST ERROR LOG: |                                                                                            |
|                    |                | Parameter Subfunction         |                                                                                            |
|                    |                | AL = 00h<br>AL = 01h          | Read POST error log<br>Write error code to POST error log                                  |
|                    | AH = 22h-4Eh   | Reserved                      |                                                                                            |
|                    | AH = 4Fh       | Keyboard Intercept            |                                                                                            |
|                    | AH = 50h-7Fh   | Reserved                      |                                                                                            |
| Т.                 | AH = 80h       | Device Open                   |                                                                                            |
|                    | AH = 81h       | Device Close                  |                                                                                            |

# Introduction, cont'd

| System<br>Services,<br>cont'd |              | The CBIOS System Services is composed of several miscellaneous system-level subservices, all of which are invoked via the INT 15h mnemonic. |                                                                                                                                                                                                                                                                                           |  |
|-------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| INT                           | PARAMETER    | FUNCTION                                                                                                                                    |                                                                                                                                                                                                                                                                                           |  |
| 15h                           | AH = 82h     | Program Termina                                                                                                                             | tion                                                                                                                                                                                                                                                                                      |  |
|                               | AH = 83h     | Set Event Wait Int                                                                                                                          | terval                                                                                                                                                                                                                                                                                    |  |
|                               | AH = 84h     | Joystick Support                                                                                                                            |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 85h     | System Request I                                                                                                                            | Көу                                                                                                                                                                                                                                                                                       |  |
|                               | AH = 86h     | Wait                                                                                                                                        |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 87h     | Move Block                                                                                                                                  |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 88h     | Read Extended M                                                                                                                             | emory Size                                                                                                                                                                                                                                                                                |  |
|                               | AH = 89h     | Set Protected Mo                                                                                                                            | de                                                                                                                                                                                                                                                                                        |  |
|                               | AH = 8Ah-8Fh | Reserved                                                                                                                                    |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 90h     | Device Busy Loop                                                                                                                            |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 91h     | Interrupt Complete                                                                                                                          |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = 92h-BFh | Reserved                                                                                                                                    |                                                                                                                                                                                                                                                                                           |  |
|                               | AH = C0h     | Return System Co                                                                                                                            | onfiguration Parameters                                                                                                                                                                                                                                                                   |  |
|                               | AH = C1h     | Return Extended                                                                                                                             | BIOS Data Area Segment Address                                                                                                                                                                                                                                                            |  |
|                               | AH = C2h     | POINTING DEVIC                                                                                                                              | E INTERFACE                                                                                                                                                                                                                                                                               |  |
|                               |              | Parameter                                                                                                                                   | Subfunction                                                                                                                                                                                                                                                                               |  |
|                               |              | AL = 00h<br>AL = 01h<br>AL = 02h<br>AL = 03h<br>AL = 04h<br>AL = 05h<br>AL = 06h                                                            | Enable/Disable pointing device<br>Reset pointing device<br>Set sample rate<br>Set resolution<br>Read device type<br>Pointing device initialization<br>Extended commands<br>BH = 00h Return status<br>BH = 01h Set scaling to 1:1<br>BH = 02h Set scaling to 2:1<br>Device driver far call |  |

# Introduction, cont'd

| System<br>Services,<br>cont'd |              | The CBIOS System Services is composed of several miscellaneous system-level subservices, all of which are invoked via the INT 15h mnemonic. |                                                       |  |
|-------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--|
| INT                           | PARAMETER    | FUNCTION                                                                                                                                    |                                                       |  |
| 15h                           | AH = C3h     | ENABLE/DISABLE WATCHDOG TIME-OUT                                                                                                            |                                                       |  |
|                               |              | Parameter                                                                                                                                   | Subfunction                                           |  |
|                               |              | AL = 00h<br>AL = 01h                                                                                                                        | Disable watchdog time-out<br>Enable watchdog time-out |  |
|                               | AH = C4h     | PROGRAMMABLE OPTION SELECT                                                                                                                  |                                                       |  |
|                               |              | Parameter                                                                                                                                   | Subfunction                                           |  |
|                               |              | AL = 00h<br>AL = 01h                                                                                                                        | Enable cursor for setup<br>Adapter enable             |  |
|                               | AH = C5h-FFh | Reserved                                                                                                                                    |                                                       |  |

| Keyboard<br>Service |               | The CBIOS Keyboard Service interfaces the operating system and application programs with the keyboard. |
|---------------------|---------------|--------------------------------------------------------------------------------------------------------|
| INT                 | PARAMETER     | FUNCTION                                                                                               |
| 16h                 | AH = 00h      | Read Next Keyboard Character                                                                           |
|                     | AH = 01h      | Return Keyboard Status                                                                                 |
|                     | AH = 02h      | Return Shift Flag Status                                                                               |
|                     | AH = 03h      | Set Typematic Rate And Delay                                                                           |
|                     | AH = 05h      | Store Key Data                                                                                         |
|                     | AH = 06h-0Fh  | Reserved                                                                                               |
|                     | AH = 010h     | Return Extended Key Values                                                                             |
|                     | AH = 011h     | Return Extended Key Status                                                                             |
|                     | AH = 012h     | Return Extended Shift Flags                                                                            |
|                     | AH = 013h-FFh | Reserved                                                                                               |

continued

r

# Introduction, cont'd

| Parallel Printer<br>Service |              | The CBIOS Printer Service provides I/O support for parallel printer ports. |
|-----------------------------|--------------|----------------------------------------------------------------------------|
| INT                         | PARAMETER    | FUNCTION                                                                   |
| 17h                         | AH = 00h     | Print Character                                                            |
|                             | AH = 01h     | Initialize Printer                                                         |
|                             | AH = 02h     | Read Status                                                                |
|                             | AH = 03h-FFh | Reserved                                                                   |

| Time–of–Day<br>Service |           | The CBIOS Time-of-Day Service contains func-<br>tions that support and maintain the time-of-day<br>portion of the Motorola MC 146818A (or<br>equivalent) CMOS clock chip. |  |
|------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| INT                    | PARAMETER | FUNCTION                                                                                                                                                                  |  |
| 1Ah                    | AH = 00h  | Read System Timer Counter                                                                                                                                                 |  |
|                        | AH = 01h  | Set System Timer Counter                                                                                                                                                  |  |
|                        | AH = 02h  | Read Real Time Clock Time                                                                                                                                                 |  |
|                        | AH = 03h  | Set Real Time Clock Time                                                                                                                                                  |  |
|                        | AH = 04h  | Read Real Time Clock Date                                                                                                                                                 |  |
|                        | AH = 05h  | Set Real Time Clock Date                                                                                                                                                  |  |
|                        | AH = 06h  | Set Real Time Clock Alarm                                                                                                                                                 |  |
|                        | AH = 07h  | Reset Real Time Clock Alarm                                                                                                                                               |  |
|                        | AH = 08h  | Set Real Time Clock Activated Power-On Mode                                                                                                                               |  |
|                        | AH = 09h  | Read Real Time Clock Alarm Time and Status                                                                                                                                |  |
|                        | AH = 0Ah  | Read System Timer Day Counter                                                                                                                                             |  |
|                        | AH = 0Bh  | Set System Timer Day Counter                                                                                                                                              |  |

# Chapter 2 Hardware Environment

## **Overview**

#### Introduction

This chapter describes the hardware environment supported by the CBIOS.

Note: The hardware environment described here also applies to the ABIOS portion of PS/2-compatible ROM BIOSs.

#### Hardware overview only

The hardware contained in IBM PS/2 and compatible systems provides the user with a rich and powerful computing environment. A precise description of each IBM PS/2 hardware component, however, is beyond the scope of this book. The material presented here is intended to give CBIOS users a general survey of the PS/2 hardware and is not intended to substitute for the hardware data sheet or documentation available from individual hardware manufacturers.

continued

Hardware Environment

## **Overview**, Continued

#### **CBIOS benefits**

By its very nature, the CBIOS is designed to isolate the user from direct manipulation of hardware I/O ports, registers, and control words. As such, the CBIOS provides a high level interface to hardware that is guaranteed to remain the same when hardware components change.

This has a number of benefits:

- If programs use CBIOS calls instead of reads and writes to hardware, they will be more portable across differing hardware environments.
- Using the CBIOS services spares the programmer from having to master many details about hardware that may change.

#### Additional information

Two appendices are included in this reference with additional hardware information.

- Appendix B provides a detailed look at the 8042 controller chip.
- Appendix C describes the Model 25/30 and compatibles hardware environment.

#### In this chapter

The following hardware information is presented:

- 80286/80386/80386SX Microprocessors
- Math Coprocessors
- Micro Channel
- I/O Devices
- System Time-Related Devices
- CMOS RAM Service
- DMA Controller
- Programmable Option Select (POS)
- Intel 8259A Programmable Interrupt Controllers
- System Control Port Definitions
- Power-On Password
- NMI Mask
- Hardware I/O Port List

# 80286/80386/80386SX Microprocessors

#### Introduction

The CBIOS must be implemented in systems that employ the Intel 80286, 80386, or 80386SX microprocessor, an equivalent, or a superset.

| The table | below li | sts the | CBIOS | microprocessor | support. |
|-----------|----------|---------|-------|----------------|----------|
|           |          |         | -     |                |          |

| ltem             | Support                                                                                                     |
|------------------|-------------------------------------------------------------------------------------------------------------|
| Processor Speeds | 6 to 20 MHz (80286); 6 to 33 MHz (80386 and 80386SX)<br>Note: Currently verified range of supported speeds. |
| Wait States      | 0 or 1 wait states                                                                                          |
| Address Modes    | Real and protected address modes<br>Note: See "Address mode support" below.                                 |

#### Address mode support

The ROM BIOS for IBM PS/2 and compatible systems can be addressed in both the real and the protected address modes of the microprocessor.

This statement holds true for both the CBIOS and the ABIOS portions of the ROM BIOS. The difference between the CBIOS and the ABIOS portions of the ROM BIOS lies not in the modes under which they can be addressed but in the kind of operating systems each is designed to support.

- The ABIOS is designed specifically to support multitasking operating systems (e.g. IBM OS/2) that execute exclusively in the microprocessor's real mode, exclusively in protected mode, or bimodally switching between real and protected modes.
- CBIOS is primarily designed to support single-tasking operating systems (e.g. MS-DOS) that execute exclusively in the microprocessor's real mode.

## Math Coprocessors

#### Introduction

The CBIOS can be implemented in systems that include an Intel 80287 or 80387 math coprocessor (80387SX for 80386SX processors) or an equivalent math coprocessor.

#### Description

The math coprocessor performs high speed arithmetic, logarithmic, and trigonometric floating point arithmetic calculations, permitting much speedier processing for mathematically intensive processes.

The math coprocessor works in parallel with the microprocessor, allowing both to process instructions separately. See the user manual for the coprocessor for details about the extended data types, registers, and instructions available with this chip.

#### Math coprocessor hardware interface

The coprocessor operates in an asynchronous mode and can use the same clock generator as the microprocessor. It functions as an I/O device and can be accessed through I/O ports 00F8h, 00FAh, and 00FCh.

The coprocessor BUSY signal tells the microprocessor that the coprocessor is operating. The WAIT signal means that it is executing, and forces the microprocessor to wait until the coprocessor is done.

The coprocessor can operate in either the real or protected address mode. It is in real address mode after a power-on, a reset, or when returning from protected address mode.

The math coprocessor generates an error signal which sets IRQ 13, and the BUSY signal from the coprocessor is then held in the BUSY state. The BUSY signal can be cleared by an I/O Write to I/O port 00F0h or by a write of zero to I/O port address 00F0h with bits 0-7 set to zeros, which also clears IRQ 13.

#### **CBIOS: INT 75h Numeric exception error handling**

IRQ 13 (which is generated by a math coprocessor numeric exception error) is vectored to INT 75h hardware interrupt service routine as part of the CBIOS initialization. When IRQ 13 goes high, INT 75h clears the BUSY signal and issues a software interrupt, INT 02h.

**Note:** User programs which enable numeric exceptions must provide a method for intercepting and processing either INT 75h or INT 02h.

# **Micro Channel**

#### Introduction

The CBIOS supports such IBM Micro Channel-compatible features as Programmable Option Select (POS) and configurable Direct Memory Access (DMA) arbitration levels.

The following table lists the Micro Channel hardware supported by the CBIOS:

| Feature                                   | Description                                                                                       |
|-------------------------------------------|---------------------------------------------------------------------------------------------------|
| I/O address width is 8-bit<br>or 16-bits. | Allows either 8-bit or 16-bit I/O transfers.                                                      |
| Central arbitration control point.        | Arbitrates among as many as 15 devices.                                                           |
| 8 DMA channels.                           | Serial DMA protocol for 8 channels; either 8-bit or 16-bit DMA transfer.                          |
| Level-sensitive interrupts.               | Interrupt controller operated in level-triggered mode to allow devices to share interrupt levels. |
| Programmable option select                | Eliminates need for jumpers and configuration switches.                                           |
| Channel extension<br>connectors           | Support future growth and additional channel features.                                            |
| No support for PC-type adapters.          | Supports only adapters designed for the Micro Channel.                                            |

#### **Micro Channel connectors**

The CBIOS supports three types of channel connectors:

- 16-bit, made up of an 8-bit section, and a 16-bit extension,
- 16-bit with auxiliary video extensions, and
- 32-bit connectors in Intel 80386-based systems.

#### Programmable option select (POS)

POS data is accumulated in adapter description files (ADFs) which are created by adapter manufacturers for each adapter. The reference diskette supplied with MCA-compatible systems reads .ADF files and stores configuration information in CMOS RAM. The CBIOS power-on self test (POST) reads CMOS RAM and writes the configuration information to the POS registers of the adapters.

The POS I/O addresses are 0094h - 0097h and 0100h - 0107h.

# I/O Devices: Introduction

The CBIOS supports the following I/O devices:

- a diskette controller,
- a fixed disk controller,
- a VGA video controller,
- an Intel 8042/8242 or equivalent keyboard controller,
- a serial port, and
- a parallel port.

Each of these capabilities is discussed below.

## I/O Devices: Diskette and Disk Hardware

#### **Diskette controller**

The CBIOS supports an NEC 765 or equivalent diskette controller. Four types of diskette drives are supported:

- 720K 3.5-inch,
- 1.44 MB 3.5-inch,
- 360K 5.25-inch, and
- 1.2 MB 5.25-inch drives.

#### **Diskette drive configuration**

The ROM BIOS supports a maximum of two diskette drives.

#### Fixed disk controller

The ROM BIOS supports up to two fixed disks. The CBIOS supports an ST506 fixed disk adapter or equivalent. This adapter should be PS/2-compatible. The ST506 adapter is single-tasking and must complete one operation before starting another, even though the next operation may be for the other fixed disk. The hardware interrupt request for fixed disk is 14.

RLL and ESDI fixed disk controllers are also supported by the CBIOS.

# I/O Devices: Video Hardware

#### Introduction

The CBIOS video service supports IBM VGA-compatible hardware, including:

- a VGA-compatible chip or chip set that includes a:
  - CRT Controller
  - Sequencer
  - Graphics Controller, and
  - Attribute Controller
- DAC chip INMOS G171 or compatible Digital-to-Analog Converter
- Video RAM 256K of dynamic read/write RAM configured as four 64K maps
- Monochrome or color direct drive analog monitor
- Monochrome or color multiple sync frequency monitors

#### VGA-compatible chip (or chip set)

The VGA chip (or chip set) provides all CRT control signals. It consists of four components: CRT Controller, Sequencer, Graphics Controller, and Attribute Controller.

The function of each VGA component is summarized in the table below.

| Component            | Function CRT Controller                                                                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRT Controller       | Generates horizontal and vertical CRT sync timings, cursor<br>and underline timings, video buffer addressing, and refresh<br>addressing.                                |
| Sequencer            | Arbitrates system access to display RAM and fonts. The sequencer allows up to eight fonts with two fonts displayable at any one time.                                   |
| Graphics Controller  | Handles read/write operation on 4 parallel bit planes. Outputs data to Attribute Controller.                                                                            |
| Attribute Controller | Converts incoming text mode attribute data or graphics<br>mode pixel data into 8-bit indices into the Digital-to-Analog<br>Converter (DAC) color registers (see below). |

**Note:** For a complete description of VGA-compatible components, I/O ports, and registers, refer to the hardware documentation accompanying your particular VGA-compatible chip or chip set.

#### DAC

The video DAC contains 256 individual color registers which can be accessed by the BIOS as either four 64-color registers or sixteen 16-color registers.

Each DAC color register contains one 18-bit RGB analog value. Six bits of each register are allocated to each primary color. Thus, the color represented in each DAC color register may be any of 256K possible colors (i.e.  $2^{3*6} = 256$ K).

#### Video RAM

The ROM BIOS Video Services require 256K of read/write video RAM formatted into four banks (or maps) of 64K.

To maintain compatibility, display memory for each of the historical MDA, CGA, and EGA-compatible modes is mapped exactly as it was in the original display adapter. The display memory organization for the new VGA modes is outlined in the CBIOS Video Services chapter.

#### Analog monitor support

To display all modes, the Video Service requires either a monochrome or a color direct drive analog monitor with a 31.5 KHz horizontal scan frequency.

The display's vertical gain is adjusted automatically by the VGA-compatible circuitry. Thus, video modes with 350, 400, and 480 horizontal scan lines can be displayed without requiring manual adjustment.

#### Multiscan monitor support

In addition to 31.5 KHz direct drive analog monitors, the Video Service also supports multiscan rate monitors capable of operating in analog modes (e.g. NEC Multisync monitor). Monitors of this type require an adapter cable that matches the signal assignments and monitor ID circuitry of the DAC external video controller.

# I/O Devices: Keyboard Hardware

#### Introduction

The CBIOS supports an intelligent keyboard subsystem based on the Intel 8042 or equivalent keyboard controller.

The hardware interrupt level associated with the CBIOS Keyboard Service is IRQ 1.

#### The 8042 controller chip

The Intel 8042 peripheral controller (or compatible) is a single chip microcomputer that can be programmed to allow bidirectional communication between the master microprocessor and up to two auxiliary serial input devices. The 8042 chip, generally, is mounted on the system motherboard. 8042 programs reside as firmware in the 8042 chip itself.

#### **Device support**

The kind of devices a given 8042 chip supports are dependent on how the 8042 is programmed.

On IBM PS/2-compatible systems, the 8042 is programmed to allow bidirectional communication between the system and the keyboard, as well as between the system and one other auxiliary serial device, such as a mouse, joystick, or trackball.

#### Pointing device interface

The pointing device in PS/2-compatible systems is controlled by the 8042. INT 74h handles interrupts from the pointing device. The INT 15h Pointing Device Service controls the device operations.

#### Reference

For more information on the 8042 Keyboard Controller Chip, refer to Appendix B.

#### Introduction

The CBIOS Parallel Port Service is associated with hardware interrupt request 7. The CBIOS supports a parallel port that can transfer eight bits of data at standard TTL levels. The parallel port can be called port 1 through 8, must be IBM PS/2-compatible, and must have a bidirectional mode, supporting both input and output. The parallel port also supports level-sensitive interrupts and a readable interrupt pending status.

#### Parallel port addresses

| Parallel<br>Port Number | Data Address | Status Address | Control Address |
|-------------------------|--------------|----------------|-----------------|
| 1                       | 03BCh        | 03BDh          | 03BEh           |
| 2                       | 0378h        | 0379h          | 037Ah           |
| 3                       | 0278h        | 0279h          | 027Ah           |

The following table lists the most common parallel port addresses. Up to 8 parallel ports are supported.

#### Parallel port extended mode

The extended mode of the parallel port can be selected through the port system-based POS registers. The extended mode adds a bidirectional interface.

# I/O Devices: Serial Port Hardware

#### Introduction

The CBIOS supports a National Semiconductor 16550 serial port controller or equivalent logic. The serial ports can be addressed as Serial 1–8. See the equipment list at 40:10h to find out how many serial ports are available. Serial 1 and 3 interrupts are on IRQ 4; Serial 2 and 4 interrupts are on IRQ 3.

#### Serial port addresses/interrupt levels

The serial port addresses and interrupt levels are listed in the table below.

| Serial Port Number | Base Address | Interrupt Level |
|--------------------|--------------|-----------------|
| 1                  | 03F8h        | 4               |
| 2                  | 02F8h        | 3               |
| 3                  | 3220h        | 3               |
| 4                  | 3228h        | 3               |
| 5                  | 4220h        | 3               |
| 6                  | 4228h        | 3               |
| 7                  | 5220h        | 3               |
| 8                  | 5228h        | 3               |

#### NS 16550 characteristics

The NS 16550, which is functionally compatible with the NS 16450 and the NS 8250, supports:

- Characters of 5, 6, 7, or 8 bits,
- 1, 1.5, or 2 stop bits, and
- even, odd, or no parity modes.

#### NS 16550 Serial Communications Controller

The NS 16550 does serial-to-parallel conversions on data received from a peripheral device or a modem, and parallel-to-serial conversion on data received from the system processor. The system processor can read the status of the NS 16550 at any time during its operation. The information furnished includes the type and condition of transfer operations in progress, as well as any error conditions (parity, overrun, framing, or break interrupt) present. The NS 16550 provides complete modem control, and has a user programmable processor-interrupt system.

#### NS 16550 Serial Controller Registers

The NS 16550 has 12 accessible registers:

- Receiver Buffer Register (Read Only)
- Transmitter Holding Register (Write Only)
- Interrupt Enable Register (Read/Write)
- Interrupt Identification Register (Read Only)
- FIFO (First in/First out) Control Register (Write Only)
- Line Control Register (Read/Write)
- Modem Control Register (Read/Write)
- Line Status Register (Read Only)
- Modem Status Register (Read Only)
- Scratch Register (Read/Write)
- Divisor Latch (LSB) (Read/Write)
- Divisor Latch (MSB) (Read/Write)

Information on the operation of these registers is contained in the National Semiconductor NS 16550 Data Sheet. However, to avoid any incompatibility problems introduced by direct hardware programming, use the access to the serial controller provided through the BIOS services.

#### Programmable baud rate generator

The serial port controller can operate at speeds of from 110 to 19,200 bps.

# System Time-Related Devices: Introduction

#### System time-related components

The CBIOS supports that the following time-handling chips, or their equivalents:

- Intel 82284 Clock Generator
- Intel 8254A Programmable Interval Timer (PIT)
- Motorola MC146818A Real Time Clock

# System Time-Related Devices: 82284 Clock Generator

#### Description

The Intel 82284 (or compatible) Clock Generator chip interfaces directly to the system microprocessor (CPU). The 82284 chip:

- Provides the CPU with two clock inputs
- Generates the READY input to the CPU
- Synchronizes the system RESET input to the CPU.

#### Introduction

The 8254A Programmable Interval Timer (PIT) is a counter and timer that provides three channel timers. All channels are driven by a 1.19 MHz oscillator signal. Each "tick" of the PIT generates hardware interrupt request 0.

The BIOS supports the Intel 8254A programmable counter chip or its equivalent. The timer chip need not include a timer/counter 1 but should provide a limited-function timer/counter 3.

#### Timer channel differences

There are some differences between the three timer channels.

Counters 0 and 2:

- are independent 16-bit counters,
- can be preset, and
- can count in BCD (binary coded decimal) or in binary.

Counter 3:

- is only 8 bits,
- can be preset,
- counts in binary only, and
- can only count downward.

#### System Timer Modes

The system timer has six modes:

| Mode | Name                            |  |
|------|---------------------------------|--|
| 0    | Interrupt on Terminal Count     |  |
| 1    | Hardware Retriggerable One-Shot |  |
| 2    | Rate Generator                  |  |
| 3    | Square Wave                     |  |
| 4    | Software Triggered Strobe       |  |
| 5    | Hardware Retriggerable Strobe   |  |

#### Common timer mode operations

All modes have the following operations in common:

- All control logic resets when control bytes are written to a counter.
- Counters do not stop when they reach zero.
- In Modes 0, 1, 4, and 5 the counter wraps to the highest possible count, and continues to count.
- In Modes 2 and 3, the counter reloads the initial count and continues to count.

#### **Timer Channels**

The following table describes the functions of the timer channels. The system timer is treated as a series of I/O ports. Three are count registers, and two are control registers.

| Channel                       | I/O Port | Read/Write<br>Status |
|-------------------------------|----------|----------------------|
| 0 System Timer                | 0040h    | R/W                  |
| 2 Tone Generation for Speaker | 0042h    | R/W                  |
| 3 Watchdog Timer              | 0044h    | R/W                  |
| Control Register 3            | 0047h    | w                    |
| Control Register 0, 2         | 0043h    | w                    |

#### Watchdog Timer

The Watchdog Timer is used to find out if IRQ 0 is not being serviced, which can be used to detect a user program in a tight loop.

The Watchdog Timer is enabled or disabled by the CBIOS INT 15h, System Services, function C3h.

#### Introduction

The BIOS supports a Motorola MC146818A Real Time Clock, or equivalent. This chip is assumed to have at least 64 bytes of nonvolatile CMOS RAM available to store configuration data.

#### **RTC CMOS RAM Addresses**

The following table lists the CMOS RAM addresses:

| I/O Address | Length | Description                                                                         |
|-------------|--------|-------------------------------------------------------------------------------------|
| 0070h       | 1 Byte | CMOS RAM address, where:<br>Bit 7 = 1 NMI disabled<br>Bits 6-0 = 0 CMOS RAM address |
| 0071h       | 1 Byte | CMOS RAM data port                                                                  |

#### ■ To write to CMOS RAM:

- Inhibit interrupts.
- Write the CMOS RAM address to which the data is to be written to I/O port 0070h.
- Write the data to be written to I/O port 0071h.

#### ■ To read from CMOS RAM:

- Inhibit interrupts.
- Write the CMOS RAM address from which the data is to be read to I/O Port 0070h.
- Read from I/O port 0071h.

# **CMOS RAM Service**

#### Introduction

Information may be stored in up to two areas of CMOS RAM. The table below describes the CMOS RAM areas available to the ROM BIOS.

#### Table of CMOS RAM areas

| Data Area                         | I/O<br>Location            | Size     | Description                                                                                                                                                                                                                                  |
|-----------------------------------|----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMOS RAM<br>Data Area             | 0070h and<br>0071h         | 64 bytes | These bytes are located on the Motorola<br>MC146818A Real Time Clock CMOS RAM<br>chip (or its equivalent). All implementa-<br>tions of the BIOS make use of this area<br>to store real time clock, POST, and sys-<br>tem configuration data. |
| Extended<br>CMOS RAM<br>Data Area | 0074h, 0075h,<br>and 0076h | 2K       | When implemented on systems that em-<br>ploy more than four adapter slots, the<br>BIOS requires an additional 2K of CMOS<br>RAM. This extended CMOS RAM is pri-<br>marily used to store POS data.                                            |

CBIOS for IBM PS/2 Computers and Compatibles

#### DMA functionality

The hardware environment for DMA transfers is described here in order to explain the background against which the DMA CBIOS functions operate. The CBIOS, however, serves as a shield between underlying hardware and requests of the operating system, obviating the need for the caller to directly access the DMA controller.

Direct Memory Access (DMA) allows large amounts of data to be transferred from a physical device to system memory or vice versa without microprocessor involvement. A program may initiate a DMA transfer and have no need to copy each byte or word individually, freeing the processor for more complex tasks. DMA transfers are typically from/to a fixed I/O port address to/from a continually incremented memory address.

DMA functionality in Micro Channel systems is a superset of the functionality of two Intel 8237 DMA Controllers, one addressed at every port, starting with Port 0000h, and one addressed at every other port, starting at port 00C0h. Access to 8237-compatible DMA functions and to additional functions *for all channels* is provided at I/O ports 0018h and 001Ah. Data output to port 0018h selects the channel and function, and data output to or input from 001Ah goes to or from the selected internal register.

#### **Bus sharing**

The system microprocessor and any currently-transferring DMA users can share the bus by taking turns directing bus cycles (driving the Micro Channel's address lines and certain control signals). An arbitration process determines which of these possible bus masters are ready to direct a cycle. Competing bus masters (DMA devices) are assigned varying priorities, which are weighed during arbitration. Each bus master gets control of the bus for a number of cycles as determined by the arbitration process.

#### DMA device

A DMA device (or bus master) is one that enters into arbitration for the channel. If it wins, it receives addresses and control signals from the DMA controller so it can read or write data.

# DMA Controller, Continued

#### **DMA Controller functions**

A DMA controller is a device which monitors the arbitration process and gives addresses and control signals to the device that has won the bus through arbitration. The controller does not enter into the arbitration itself. PS/2-compatible Micro Channel-based systems provide a DMA controller that supports DMA transfers to/from up to eight devices at once.

#### DMA hardware registers

The DMA controller maintains several hardware registers for each DMA channel. The key registers are:

- a memory address where the next byte or word will be transferred to or from
- a count of the remaining bytes to transfer ((transfer count))
- a flag (mode) controlling the transfer direction (to memory or to the device), and
- transfer status flags for each channel (status)

#### DMA hardware registers

The DMA Controller has ten sets of registers, summarized below:

| Register          | Size (bits) | Number of<br>Registers | How Allocated                            |
|-------------------|-------------|------------------------|------------------------------------------|
| Memory Address    | 24          | 8                      | 1 per Channel                            |
| I/O Address       | 16          | 8                      | 1 Per Channel                            |
| Transfer Count    | 16          | 8                      | 1 Per Channel                            |
| Temporary Holding | 16          | 1                      | All Channels                             |
| Mask              | 4           | 2                      | 1 for Channels 7-4<br>1 for Channels 3-0 |
| Arbus             | 4           | 2                      | 1 for Channel 4<br>1 for Channel 0       |
| Mode              | 8           | 8                      | 1 per Channel                            |
| Status            | 8           | 2                      | 1 for Channel 7-4<br>1 for Channel 3-0   |
| Function          | 8           | 1                      | All Channels                             |
| Refresh           | 9           | 1                      | Independent of DMA                       |

#### Mode Control Field

The Mode Control field provides an opportunity for the caller to use the Autoinitialization and Programmed I/O (PIO) features of the DMA Controller.

Autoinitialization

Specifies if the DMA Controller will initialize automatically when the transfer reaches the terminal count.

Programmed I/O

Specifies that the I/O address is to be programmed to the DMA Controller, driving the I/O address on the bus during the DMA cycles.

# DMA Controller, Continued

#### **Transfer Control Bytes**

These fields provide an opportunity for the caller to specify the physical address of the memory and I/O fields for CBIOS DMA Service functions 10h, 11h, and 12h.

#### Count Control

Specifies if the physical address is decremented or incremented during a transfer.

#### Device Size

Specifies whether this is an 8-bit or 16-bit transfer.

#### DMA controlled by microprocessor

The microprocessor can address the DMA controller and access the DMA registers. The microprocessor can control the DMA modes, transfer addresses, transfer counts, channel masks, and page registers.

#### **Direct DMA Controller access**

Reading directly from or writing directly to any DMA Controller port may cause unpredictable results.

#### DMA data transfer

After a DMA device has won the arbitration bus and the DMA controller is programmed to service the request, a transfer can take place.

DMA transfers can be:

- single transfer,
- multiple transfer (burst mode), or
- read verification.

#### Burst mode

Burst mode is a method of DMA transfer that allows a device to remain inactive for long periods and then send large amounts of data in a short time. Some peripheral devices, e.g. a fixed disk, transfer their data in bursts that are frequently separated by long periods of inactivity. Burst mode is a way of making these devices more efficient. The device asks to be serviced only when it has data to transfer and then does so in large quantities.

#### Arbitration levels

Arbitration is a process through which devices compete for control of the Micro Channel on a prioritized basis. Arbitration levels are predefined or programmable levels of priority assigned to devices that compete for possession of the channel.

Central Arbitration Control is a hardware function that allows intelligent peripherals to share and control access to the system. Arbitration is organized in levels of priority, and on each level there can be a number of competing devices.

Arbitration Levels are numbered from 00h to 0Fh. In addition, there are Arbitration Levels -1 and -2, which exist only on the system board. Of the former set, Arbitration Level 00h has the highest priority; Level 0Eh has the lowest. All arbitration level priorities are assigned sequentially; 00h through 0Eh are the highest through lowest priorities. Level 0Fh is reserved.

# DMA Controller, Continued

## Arbitration levels, cont'd

The following table summarizes the arbitration levels:

| Memory Refresh<br>NMI |  |
|-----------------------|--|
| NMI                   |  |
|                       |  |
| DMA Channel 0*        |  |
| DMA Channel 1         |  |
| DMA Channel 2         |  |
| DMA Channel 3         |  |
| DMA Channel 4*        |  |
| DMA Channel 5         |  |
| DMA Channel 6         |  |
| DMA Channel 7         |  |
| Reserved              |  |
| System Microprocessor |  |
|                       |  |

## DMA Controller, Continued

#### DMA channel flags

Additional channel flags control whether

- a transfer is to be repeated forever,
- the memory address is to be decremented or incremented after each cycle,
- the DMA controller maintains I/O address (this is hardwired in most devices that use DMA), or
- a byte or a word is transferred at each cycle.

#### Physical and Virtual DMA channels

DMA channels can be either physical or virtual. A physical channel can only have one arbitration level, but a virtual channel can be programmed to own any arbitration level not currently assigned to a different channel. Thus, a virtual DMA channel can have many arbitration levels.

Functionally, there is no difference between physical and virtual channels. Priority is determined by the arbitration level only, where level 00h is the highest priority and level 0Eh the lowest.

#### Virtual DMA Channels and the Arbus register

The arbitration level assignment for channels 0 and 4 can be programmed using the two 4-bit Arbus registers. The Arbus registers permit dynamic reassignment of the arbitration ID value by which the DMA controller responds to DMA requests for bus arbitration. Channels 0 and 4 can then service devices at any arbitration level.

# DMA Controller, Continued

#### DMA Channels

The DMA channel I/O addresses are defined in the I/O Port Address section later in this chapter. They range from 0000h - 000Fh, 0018h, 001Ah, 0081h - 008Fh, and 00C0h - 00DEh.

#### DMA extended mode

An extended mode register is available for each programmable DMA channel and is used when a DMA channel requests a DMA data transfer. DMA channels must match the transfer size of the DMA slave, which is programmed by Bit 6 of the extended mode register. DMA read transfers of 16 bits from 8-bit memory or 8-bit memory-mapped I/O devices are not supported.

| Bit Number | Description                                              |
|------------|----------------------------------------------------------|
| 7          | = 0 Reserved                                             |
| 6          | = 0 8-bit transfer<br>= 1 16-bit transfer                |
| 5          | = 0 Reserved                                             |
| 4          | = 0 Reserved                                             |
| 3          | = 0 Read memory transfer<br>= 1 Write memory transfer    |
| 2          | = 0 Verify<br>= 1 Transfer data                          |
| 1          | = 0 Reserved                                             |
| 0          | = 0 I/O address 00h<br>= 1 User programs the I/O address |

The following table describes the DMA extended mode register:

#### Introduction

Because it is an integral part of the Micro Channel Architecture (MCA), Programmable Option Select support is assumed.

#### Adapter slots

The CBIOS supports up to eight adapter cards (or more on systems with a customized BIOS). The CBIOS will work with any system regardless of the number of adapter slots available.

#### Adapter card identification

Each adapter card must have a unique 2-byte identifier.

#### Adapter description files

POS data is accumulated in adapter description files (ADFs) that are created by adapter manufacturers for each adapter. The reference diskette supplied with MCA-compatible systems reads the .ADF files and stores the configuration information in CMOS RAM. This information is read by the BIOS poweron self test (POST), which writes it to the POS registers of the adapters and the system board.

# Intel 8259A Programmable Interrupt Controllers

#### Introduction

The CBIOS supports two cascaded Intel 8259A Programmable Interrupt Controller (PIC) chips, or their functional equivalent.

#### Description

The PIC handles all maskable hardware interrupts. The CBIOS insures compatibility with hardware interrupts expected by existing software. Formerly reserved, IRQ2 is now associated with the 8042 Auxiliary Device (mouse) controller.

#### Levels of interrupt

There are 16 levels of interrupts. Interrupts are level-sensitive, allowing several devices to share the same hardware interrupt. This reduces the interrupt controller's sensitivity to a transient signal on the Micro Channel bus.

#### Programmable Interrupt Controller addresses

The following table lists all PIC addresses:

| l/O<br>Address | Functional<br>Equivalents | IRQs Routed    | Read/Write<br>Status | Description |
|----------------|---------------------------|----------------|----------------------|-------------|
| 20h            | master 8259A              | IRQ 0 - IRQ 7  | R/W                  | Base        |
| 21h            | master 8259A              | IRQ 0 - IRQ 7  | w                    | Mask        |
| A0h            | slave 8259A               | IRQ 8 – IRQ 15 | R/W                  | Base        |
| A1h            | slave 8259A               | IRQ 8 - IRQ 15 | w                    | Mask        |

# Table of IRQ assignments

The following table shows the assignment of interrupt requests to commonly interrupting devices, listed from highest to lowest priority. Other devices not listed may use interrupt requests and may share requests with these devices.

| Request | Device                              |  |
|---------|-------------------------------------|--|
| IRQ 0   | Timer tick                          |  |
| IRQ 1   | Keyboard                            |  |
| IRQ 2   | IRQ 8-15 are cascaded through IRQ 2 |  |
| IRQ 8   | Real time clock                     |  |
| IRQ 9   | Redirect cascade                    |  |
| IRQ 10  | Reserved                            |  |
| IRQ 11  | Reserved                            |  |
| IRQ 12  | Mouse                               |  |
| IRQ 13  | 80x87 math coprocessor exception    |  |
| IRQ 14  | Fixed disk controllers              |  |
| IRQ 15  | Reserved                            |  |
| IRQ 3   | Serial port 2                       |  |
| IRQ 4   | Serial port 1                       |  |
| IRQ 5   | Parallel port 2                     |  |
| IRQ 6   | Diskette                            |  |
| IRQ 7   | Parallel port 1                     |  |

# **System Control Port Definitions**

## Introduction

The CBIOS supports certain system control functions at I/O Port addresses 0061h and 0092h.

#### Port 61h: System Control Port B

The read/write definitions for I/O port address 0061h, System Control Port B, are:

|     | Port 61h: Write Operations             |  |
|-----|----------------------------------------|--|
| Bit | Description                            |  |
| 7   | = 1 Reset timer 0 output latch (IRQ 0) |  |
| 6-4 | = 0 Reserved                           |  |
| 3   | = 0 Enable channel check               |  |
| 2   | = 0 Enable parity check                |  |
| 1   | = 1 Speaker data enable                |  |
| 0   | = 1 Enable Timer 2 gate to speaker     |  |
|     | Port 61h: Read Operations              |  |
| Bit | Description                            |  |
| 7   | = 1 Parity check                       |  |
| 6   | = 1 Channel check                      |  |
| 5   | = 1 Timer 2 output                     |  |
| 4   | = 1 Toggles with each refresh request  |  |
| 3   | = 0 Channel check enabled              |  |
| 2   | = 0 Parity check enabled               |  |
| 1   | = 1 Speaker data enabled               |  |
| 0   | = 1 Timer 2 gate to speaker enabled    |  |

continued

.

# System Control Port Definitions, Continued

# Port 92h: System Control Port A

I/O port 92h (R/W), System Control Port A, contains system control flag data. System control Port A is defined below:

| Bit | Description                        |  |
|-----|------------------------------------|--|
| 7   | 1 = Fixed disk activity light A on |  |
| 6   | 1 = Fixed disk activity light B on |  |
| 5   | 0 = Reserved (must be zero)        |  |
| 4   | 1 = Watchdog time-out occurred     |  |
| 3   | 1 = Security lock latch is locked  |  |
| 2   | 0 = Reserved (must be zero)        |  |
| 1   | 1 = Alternate gate A20 line active |  |
| 0   | 1 = Alternate hot CPU reset        |  |

There are eight bytes in CMOS RAM reserved for a 1–7 byte password and a check character for that password. The microprocessor accesses these bytes during POST. These bytes cannot be accessed by a user program.

These eight bytes are initialized to zeros and are changed to the password during password installation. Passwords can only be changed during POST via the program on the reference diskette which is supplied with MCA-compatible systems.

Models 25 and 30: Power-on password is not supported in IBM PS/2 Models 25 and 30, and compatibles. For a complete description of the Model 25/30 hardware environment turn to Appendix C.

## **NMI Mask**

The NMI (nonmaskable interrupt) input to the microprocessor is masked off at power-on reset. Bit 7 of I/O address 0070h is set to zero to enable the NMI. A power-on reset sets this bit to one.

# Hardware I/O Port List

## Table: Hardware I/O Port Definitions

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000h       | R/W                  | DMA channel 0, memory address register                                                                                                                                                                                                                                                                                                                                              |
| 0001h       | R/W                  | DMA channel 0, transfer count register                                                                                                                                                                                                                                                                                                                                              |
| 0002h       | R/W                  | DMA channel 1, memory address register                                                                                                                                                                                                                                                                                                                                              |
| 0003h       | R/W                  | DMA channel 1, transfer count register                                                                                                                                                                                                                                                                                                                                              |
| 0004h       | R/W                  | DMA channel 2, memory address register                                                                                                                                                                                                                                                                                                                                              |
| 0005h       | R/W                  | DMA channel 2, transfer count register                                                                                                                                                                                                                                                                                                                                              |
| 0006h       | R/W                  | DMA channel 3, memory address register                                                                                                                                                                                                                                                                                                                                              |
| 0007h       | R/W                  | DMA channel 3, transfer count register                                                                                                                                                                                                                                                                                                                                              |
| 0008h       | R                    | DMA channel 0-3, status register, where:<br>Bit 7 = 1 Channel 3 request<br>Bit 6 = 1 Channel 2 request<br>Bit 5 = 1 Channel 1 request<br>Bit 4 = 1 Channel 0 request<br>Bit 3 = 1 Terminal count on channel 3<br>Bit 2 = 1 Terminal count on channel 2<br>Bit 1 = 1 Terminal count on channel 1<br>Bit 0 = 1 Terminal count on channel 0                                            |
| 000Ah       | R/W                  | DMA channel 0-3, mask register, where:<br>Bits 7-3 = 0 Reserved<br>Bit 2 = 0 Clear mask Bit<br>= 1 Set mask Bit<br>Bits 1-0 = 00b Select channel 0<br>= 01b Select channel 1<br>= 10b Select channel 2<br>= 11b Select channel 3                                                                                                                                                    |
| 000Bh       | W                    | DMA channel 0-3, mode register, where:<br>Bits 7-6 = 00b Demand mode<br>= 01b Signal mode<br>= 10b Block mode<br>= 11b Cascade mode<br>Bits 5-4 = 0 Reserved<br>Bits 3-2 = 00b Verify operation<br>= 01b Write operation<br>= 10b Read operation<br>= 11b Reserved<br>Bits 1-0 = 00b Select channel 0<br>= 01b Select channel 1<br>= 10b Select channel 2<br>= 11b Select channel 3 |
| 000Ch       | w                    | DMA Clear Byte Pointer                                                                                                                                                                                                                                                                                                                                                              |
| 000Dh       | w                    | DMA Master Clear Byte                                                                                                                                                                                                                                                                                                                                                               |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000Eh       | W                    | DMA Channel 0-3 Clear Mask Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 000Fh       | W                    | DMA channel 0-3, write mask register, where:<br>Bits 7-4 = 0 reserved<br>Bit 3 = 0 unmask channel 3 mask bit<br>= 1 set channel 3 mask bit<br>Bit 2 = 0 unmask channel 2 mask bit<br>= 1 set channel 2 mask bit<br>Bit 1 = 0 unmask channel 1 mask bit<br>= 1 set channel 1 mask bit<br>Bit 0 = 0 unmask channel 0 mask bit<br>= 1 set channel 0 mask bit                                                                                                                                                                                                                             |
| 0018h       | W                    | DMA extended function register, where:<br>Bits 7-4 = Progress command, where:<br>00h I/O address register<br>01h Reserved<br>02h Memory address register write<br>03h Memory address register write<br>03h Transfer count register write<br>05h Transfer count register read<br>06h Status register read<br>06h Status register read<br>07h Mode register<br>08h Arbus register<br>08h Arbus register set single bit<br>0Ah Mask register reset single bit<br>0Ah Mask register reset single bit<br>0Bh-0Ch Reserved<br>0Dh Master clear<br>0Eh-0Fh Reserved<br>Bits 3-0 = 0 Reserved |
| 001Ah       | R/W                  | DMA extended function execute register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0020h       | R                    | <ul> <li>PIC, Interrupt request/In-service registers programmed by Operation Command Word 3 (OCW3):</li> <li>Interrupt request register, where:</li> <li>Bits 7-0= 0 No active request for the corresponding interrupt line</li> <li>= 1 Active request for the correspond- ing interrupt line</li> <li>Interrupt in-service register, where:</li> <li>Bits 7-0= 0 The corresponding interrupt line is not currently being serviced</li> <li>= 1 The corresponding interrupt line is currently being serviced</li> </ul>                                                              |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0020h       | Ŵ                    | PIC, Initialization Command Word 1 (ICW1) (Bit         4 is one), where:         Bits 7-5 = 000 Only used in 80/85 mode         Bit 4 = 1 Reserved         Bit 3 = 0 Edge triggered mode         = 1 Level triggered mode         Bit 2 = 0 Successive interrupt vectors are separated by eight bytes         = 1 Successive interrupt vectors are separated by four bytes         Bit 1 = 0 Cascade mode         = 1 Single mode — no ICW3 needed         Bit 0 = 0 No ICW4 needed                                                                                                                                                                                                                                                                                                                                                            |
| 0021h       | W                    | <ul> <li>PIC, ICW2, ICW3, or ICW4 in sequential order<br/>after ICW1 written to Port 0020h</li> <li>ICW2, where:</li> <li>Bits 7-3 = Address lines A0-A3 of base vector<br/>address for interrupt controller</li> <li>Bits 2-0 = 000 Reserved</li> <li>ICW3, where:</li> <li>Bits 7-0 = 0 Slave controller not attached to<br/>corresponding interrupt pin<br/>= 0 Slave controller attached to<br/>corresponding interrupt pin</li> <li>ICW4, where:</li> <li>Bits 7-5 = 000 Reserved</li> <li>Bit 7-5 = 000 Reserved</li> <li>Bit 4 = 0 No special fully-nested mode<br/>= 1 Special fully-nested mode</li> <li>Bits 3-2 = 00 Non-buffered mode</li> <li>a 01 Non-buffered mode</li> <li>a 10 Buffered mode/slave</li> <li>a 11 Buffered mode/master</li> <li>Bit 1 = 0 Normal EOI<br/>= 1 Auto EOI</li> <li>Bit 0 = 0 80/85 mode</li> </ul> |
| 0021h       | R/W                  | PIC, Interrupt mask register (OCW1), where:Bit 7= 0 Enable parallel printer interruptBit 6= 0 Enable diskette interruptBit 5= 0 Enable fixed disk interruptBit 4= 0 Enable serial port 1 interruptBit 3= 0 Enable serial port 2 interruptBit 2= 0 Enable video interruptBit 1= 0 Enable keyboard interruptBit 0= 0 Enable timer interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0021h       | W                    | PIC, OCW2 (Bit 4 is zero, Bit 3 is zero), where:<br>Bits 7-5 = 000 Rotate in automatic EOI mode<br>(clear)<br>= 001 Non-specific EOI<br>= 010 No operation<br>= 011 Specific EOI<br>= 100 Rotate in automatic EOI mode<br>(set)<br>= 101 Rotate on non-specific EOI<br>command<br>= 110 Set priority command<br>= 111 Rotate on specific EOI<br>command<br>Bit 4 = 0 Reserved<br>Bit 3 = 0 Reserved<br>Bit 3 = 0 Reserved<br>Bits 2-0 = Interrupt request to which the<br>command applies                                                          |
| 0020h       | W                    | PIC, OCW3 (Bit 4 is zero, Bit 3 is one), where:         Bit 7       = 0 Reserved         Bits 6-5= 00 No operation         = 01 No operation         = 10 Reset special mask         = 11 Set special mask         Bit 4       = 0 Reserved         Bit 3       = 1 Reserved         Bit 2       = 0 No poll command         = 1 Poll command         Bits 1-0= 00 No operation         = 10 Read interrupt request register         on next read at Port 0020h         = 11 Read interrupt in-service register         on next read at Port 0020h |
| 0040h       | R/W                  | Programmable Interrupt Timer – Read/write<br>counter 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0042h       | R/W                  | Programmable Interrupt Timer - Read/write counter 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0043h       | W                    | PIT, control word register for counters 0 and         2, where:         Bits 7-6 = 00b Select counter 0         = 01b Reserved         = 10b Select counter 2         Bits 5-4 = 00b Counter latch command         = 01b Read/write counter bits 0-7         only         = 10b Read/write counter bits 8-15         only         = 10b Read/write counter bits 0-7         only         = 10b Read/write counter bits 0-7         only         = 10b Read/write counter bits 0-7         first, then bits 8-15         Bits 3-0 = 000b Mode 0 select         = 001b Mode 1 select         = X10b Mode 2 select         = X11b Mode 3 select         = 101b Mode 4 select         = 101b Mode 5 select         Bit 0 = 0 Binary counter 16 bits         = 1 Binary coded decimal counter |
| 0044h       | w                    | PIT, read/write counter 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0047h       | W                    | PIT, control word register for counter 3, where:<br>Bits 7-6 = 00b Select counter 3<br>= 01b Reserved<br>= 10b Reserved<br>= 11b Reserved<br>Bits 5-4 = 00b Counter latch command<br>select counter 0<br>= 01b Read/write counter bits 0-7<br>only<br>= 10b Reserved<br>= 11b Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0060h       | R/W                  | Keyboard/auxiliary data port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0061h       | R                    | System control port B, where:Bit 7= 1 Parity checkBit 6= 1 Channel checkBit 5= 1 Timer 2 outputBit 4= 1 Toggle with each refresh requestBit 3= 0 Channel check enabledBit 2= 0 Parity check enabledBit 1= 1 Speaker data enabledBit 0= 1 Timer 2 gate to speaker enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                               |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0061h       | W                    | System control port B, where:Bit 7= 1 Reset timer 0 output latch (IRQ 0)Bits 6-4= ReservedBit 3= 0 Enable channel checkBit 2= 0 Enable parity checkBit 1= 1 Speaker data enableBit 0= 1 Enable timer 2 gate to speaker    |
| 0064h       | w                    | 8042 Commands                                                                                                                                                                                                             |
| 0064h       | R                    | 8042 Status, where:Bit 7= 1 Parity errorBit 6= 1 General time outBit 5= 1 Auxiliary output buffer fullBit 4= 1 Inhibit switchBit 3= 1 Command/dataBit 2= System flagBit 1= 1 Input buffer fullBit 0= 1 Output buffer full |
| 0070h       | w                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0 = 0 CMOS RAM address                                                                                                       |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                               |
| 0074h       | w                    | Extended CMOS RAM address register port, least significant byte                                                                                                                                                           |
| 0075h       | w                    | Extended CMOS RAM address register port, most significant byte                                                                                                                                                            |
| 0076h       | R/W                  | Extended CMOS RAM data register port                                                                                                                                                                                      |
| 0080h       | R                    | DMA access                                                                                                                                                                                                                |
| 0081h       | R/W                  | DMA channel 2, page table address register                                                                                                                                                                                |
| 0082h       | R/W                  | DMA channel 3, page table address register                                                                                                                                                                                |
| 0083h       | R/W                  | DMA channel 1, page table address register                                                                                                                                                                                |
| 0087h       | R/W                  | DMA channel 0, page table address register                                                                                                                                                                                |
| 0089h       | R/W                  | DMA channel 6, page table address register                                                                                                                                                                                |
| 008Ah       | R/W                  | DMA channel 7, page table address register                                                                                                                                                                                |
| 008Bh       | R/W                  | DMA channel 5, page table address register                                                                                                                                                                                |
| 008Fh       | R/W                  | DMA channel 4, page table address register                                                                                                                                                                                |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0090h       | R                    | DMA arbitration register, where:<br>Bit 7 = 1 System microprocessor cycles<br>enabled<br>Bit 6 = 1 Arbitration mask by NMI<br>Bit 5 = 1 Bus timeout<br>Bit 4 = 0 Reserved<br>Bits 3-0 = Arbitration level                                                                                                                        |
| 0090h       | W                    | DMA arbitration register, where:<br>Bit 7 = 1 Enable system microprocessor<br>cycle<br>Bit 6 = 1 Arbitration mask<br>Bit 5 = 1 Enable extended arbitration<br>Bits 4-0 = 0 Reserved                                                                                                                                              |
| 0091h       | W                    | DMA card selected feedback register, where:<br>Bits 7-1 = Reserved<br>Bit 0 = 1 Card selected feedback signal<br>active on previous cycle or<br>system board I/O functions<br>accessed by an I/O cycle                                                                                                                           |
| 0092h       | R/W                  | System control port A, where:<br>Bit 7 = 1 Fixed disk activity light bit A on<br>Bit 6 = 1 Fixed disk activity light bit B on<br>Bit 5 = X Reserved<br>Bit 4 = 1 Watchdog timeout occurred<br>Bit 3 = 1 Security lock latch locked<br>Bit 2 = X Reserved<br>Bit 1 = 1 Alternate gate A20 active<br>Bit 0 = 1 Alternate hot reset |
| 0094h       | R/W                  | System board setup enable register, where:<br>Bit 7 = 0 Enable system board setup<br>= 1 Disable system board setup<br>Bit 6 = 1 Reserved<br>Bit 5 = 0 Enable VGA setup<br>= 1 Disable VGA setup<br>Bits 4-0 = 1 Reserved                                                                                                        |
| 0096h       | R/W                  | POS channel position select register, where:<br>Bit 7 = 1 Channel 1 reset<br>Bits 6-4 = Reserved (written as 0, read as 1)<br>Bit 3 = 1 Channel select<br>Bits 2-0 = 0 Channel number                                                                                                                                            |
| 00A0h       | R/W                  | Programmable Interrupt Controller 2                                                                                                                                                                                                                                                                                              |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                              |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00A1h       | R/W                  | Programmable Interrupt Controller 2 mask, where:                                                                                                                                                                                                                                                                                         |
|             |                      | Bit 7 = 0 Reserved<br>Bit 6 = 0 Enable fixed disk Interrupt<br>Bit 5 = 0 Enable 80387 exception Interrupt<br>Bit 4 = 0 Enable mouse Interrupt<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Reserved<br>Bit 1 = 0 Enable redirect cascade<br>Bit 0 = 0 Enable real time clock Interrupt                                                             |
| 00C0h       | R/W                  | DMA channel 4, memory address register                                                                                                                                                                                                                                                                                                   |
| 00C2h       | R/W                  | DMA channel 4, transfer count register                                                                                                                                                                                                                                                                                                   |
| 00C4h       | R/W                  | DMA channel 5, memory address register                                                                                                                                                                                                                                                                                                   |
| 00C6h       | R/W                  | DMA channel 5, transfer count register                                                                                                                                                                                                                                                                                                   |
| 00C8h       | R/W                  | DMA channel 6, memory address register                                                                                                                                                                                                                                                                                                   |
| 00CAh       | R/W                  | DMA channel 6, transfer count register                                                                                                                                                                                                                                                                                                   |
| 00CCh       | R/W                  | DMA channel 7, memory address register                                                                                                                                                                                                                                                                                                   |
| 00CEh       | R/W                  | DMA channel 7, transfer address register                                                                                                                                                                                                                                                                                                 |
| 00D0h       | R                    | DMA channel 4-7, status register, where:<br>Bit 7 = 1 Channel 7 request<br>Bit 6 = 1 Channel 6 request<br>Bit 5 = 1 Channel 5 request<br>Bit 4 = 1 Channel 4 request<br>Bit 3 = 1 Terminal count on channel 7<br>Bit 2 = 1 Terminal count on channel 6<br>Bit 1 = 1 Terminal count on channel 5<br>Bit 0 = 1 Terminal count on channel 4 |
| 00D4h       | R/W                  | DMA channel 4-7, mask register, where:<br>Bits 7-3 = 0 Reserved<br>Bit 2 = 0 Clear mask bit<br>= 1 Set mask bit<br>Bits 1-0 = 00b Select channel 4<br>= 01b Select channel 5<br>= 10b Select channel 6<br>= 11b Select channel 7                                                                                                         |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00D6h       | R/W                  | DMA channel 4-7, Mode Register, where:<br>Bits 7-6 = 00b Demand mode<br>= 01b Single mode<br>= 10b Block mode<br>= 11b Cascade mode<br>Bit 5 = 0 Reserved<br>Bit 4 = 0 Reserved<br>Bits 3-2 = 00b Verify operation<br>= 01b Write operation<br>= 10b Read operation<br>= 11b Reserved<br>Bits 1-0 = 00b Select channel 4<br>= 01b Select channel 5<br>= 10b Select channel 6<br>= 11b Select channel 7 |
| 00D8h       | w                    | DMA Clear Byte Pointer                                                                                                                                                                                                                                                                                                                                                                                 |
| 00DAh       | w                    | DMA Master Clear                                                                                                                                                                                                                                                                                                                                                                                       |
| 00DCh       | w                    | DMA Channel 4-7, Clear Mask Register                                                                                                                                                                                                                                                                                                                                                                   |
| 00DEh       | W                    | DMA Channel 4-7, Write Mask Register, where:<br>Bits 7-4 = 0 Reserved<br>Bit 3 = 0 Unmask channel 7 mask bit<br>= 1 Set channel 7 mask bit<br>Bit 2 = 0 Unmask channel 6 mask bit<br>= 1 Set channel 6 mask bit<br>Bit 1 = 0 Unmask channel 5 mask bit<br>= 1 Set channel 5 mask bit<br>Bit 0 = 0 Unmask channel 4 mask bit<br>= 1 Set channel 4 mask bit                                              |
| F0-FFh      | R/W                  | Math Coprocessor                                                                                                                                                                                                                                                                                                                                                                                       |
| 0100h       | R                    | POS Adapter Identification (least significant byte)                                                                                                                                                                                                                                                                                                                                                    |
| 0101h       | R                    | POS Adapter Identification (most significant byte)                                                                                                                                                                                                                                                                                                                                                     |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0102h       | R/W                  | <ul> <li>POS register 2 for the system board setup, where:</li> <li>Bit 7 = 0 Enable parallel port extended mode <ul> <li>a 1 Disable parallel port extended mode</li> <li>Bits 6, 5 = Parallel port select, where:</li> <li>a 00 Parallel 1 3BC-3BE</li> <li>a 01 Parallel 2 278-37A</li> <li>a 10 Parallel 3 278-27A</li> <li>a 11 Reserved</li> </ul> </li> <li>Bit 4 = 1 Enable parallel port, if bit 0 = 1 <ul> <li>a 0 Disable parallel port</li> <li>Bit 3 = 1 System board serial is serial 1</li> <li>a 0 System board serial is serial 2</li> </ul> </li> <li>Bit 2 = 1 Enable serial port, if bit 1 = 1 <ul> <li>a 0 Disable serial port</li> </ul> </li> <li>Bit 1 = 1 Enable diskette, if bit 0 = 1</li> <li>a 0 Disable diskette</li> <li>Bit 0 = 1 Allows bits 4, 2, and 1 to enable/disable devices</li> <li>a 0 Disables system board devices</li> </ul> For an adapter card, the following bit is defined: |
| 0103h       | R/W                  | POS register 3, where:<br>Bits 7-2 = Reserved<br>Bit 1 = 0 Password disable<br>Bit 0 = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0104h       | R/W                  | POS register 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0105h       | R/W                  | POS register 5 for an adapter card, where:Bit 7= 0 Channel check condition occurred= 1 Channel resetBit 60 Channel check exception status<br>available                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0106h       | R/W                  | POS subaddress extension (least significant byte)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0107h       | R/W                  | POS subaddress extension (most significant byte)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1F0-1F8h    | R/W                  | Fixed disk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 200–20Fh    | R/W                  | Game port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0278h       | R/W                  | Parallel 3, Data Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0279h       | R/W                  | Parallel 3, Status Port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1-0 = Reserved                                                                                                    |
| 027Ah       | R/W                  | Parallel 3, Control Port, where:<br>Bits 7-6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe                                      |
| 02F8h       | w                    | Serial 2, transmitter holding register, where:<br>Bits 7-0 Data bits 7-0, respectively, when<br>Divisor Latch Access Bit = 0                                                                                                                                                                                     |
| 02F8h       | R                    | Serial 2, receiver buffer register, where:<br>Bits 7-0 = Data bits 7-0, respectively, when<br>DLAB = 0                                                                                                                                                                                                           |
| 02F8h       | R/W                  | Serial 2, divisor latch, low byte, where:<br>Bits 7-0 = Bits 7-0 of divisor, when DLAB = 1                                                                                                                                                                                                                       |
| 02F9h       | R/W                  | Serial 2, divisor latch, high byte<br>Bits 7-0 = Bits 15-8 of divisor, when DLAB = 1                                                                                                                                                                                                                             |
| 02F9h       | R/W                  | Serial 2, interrupt enable register, where:<br>Bits 7-4 = 0 Reserved<br>Bit 3 = 1 Modem status interrupt enable<br>Bit 2 = 1 Receiver line status interrupt<br>enable<br>Bit 1 = 1 Transmitter holding register<br>empty interrupt enable<br>Bit 0 = 1 Received data available interrupt<br>enable when DLAB = 0 |
| 02FAh       | R                    | Serial 2, interrupt identification register, where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00b Modern status interrupt<br>= 01b Transmitter holding register<br>empty interrupt<br>= 10b Received data available register<br>interrupt<br>= 11b Receiver line status interrupt<br>Bit 0 = 0 Interrupt pending    |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02FAh       | W                    | Serial 2, FIFO control register, where:<br>Bits 7-6 = Receiver FIFO register trigger<br>00b = 1 byte<br>01b = 4 bytes<br>10b = 8 bytes<br>11b = 14 bytes<br>Bits 5-3 = 0 Reserved<br>Bit 2 = Transmitter FIFO register reset<br>1 = transmit FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 1 = Receiver FIFO register reset<br>1 = receiver FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 0 = FIFO enable<br>1 = receiver and transmitter FIFOs<br>enabled, must be 1 to program<br>FIFO registers<br>0 = clears receive and transmit<br>FIFO registers, enters charac-<br>ter mode |
| 02FBh       | R/W                  | Serial 2, line control register, where:<br>Bit 7 = 1 Divisor latch access<br>= 0 Receiver buffer, transmitter<br>holding, or interrupt enable<br>registers access<br>Bit 6 = 1 Set break enable<br>Bit 5 = Stick parity<br>Bit 4 = Even parity select<br>Bit 3 = Parity enable<br>Bit 2 = Number of stop bits<br>Bits 1-0 = 00b Word length is 5 bits<br>= 01b Word length is 6 bits<br>= 10b Word length is 7 bits<br>= 11b Word length is 8 bits                                                                                                                                                                                            |
| 02FCh       | R/W                  | Serial 2, modem control register, where:<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 1 Loopback mode<br>Bit 3 = 1 Enable OUT2 interrupt<br>Bit 2 = 1 Force OUT1 active<br>Bit 1 = 1 Force request-to-send active<br>Bit 0 = 1 Force data-terminal-ready<br>active                                                                                                                                                                                                                                                                                                                                                                                     |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02FDh       | R                    | Serial 2, line status register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter shift and holding<br>registers empty<br>Bit 5 = 1 Transmitter holding register<br>empty<br>Bit 4 = 1 Break Interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready                                                                                                                                                                   |
| 02FEh       | R                    | Serial 2, modern status register, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta to carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                                                                                                                                                       |
| 02FFh       | R/W                  | Serial 2, scratch register                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0320h       | R/W                  | Fixed Disk Adapter Register (8 or 16 bit)                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0322h       | W                    | Fixed Disk Adapter Control Register, where:<br>Bit 7 = 1 Reset<br>Bit 6 = 1 Reserved (except during reset)<br>Bit 5 = 1 16-bit mode (must match bit 2)<br>= 0 8-bit mode<br>Bit 4-3 = 0 Reserved<br>Bit 2 = 1 16-bit mode (must match bit 5)<br>= 0 8-bit mode<br>Bit 1 = 1 Enable interrupt through Program-<br>mable Interrupt Controller (hard-<br>ware interrupt)<br>= 0 enable interrupt through Interrupt<br>Status Register (port 324h)<br>Bit 0 = 1 DMA mode<br>= 0 PIO mode |
| 0322h       | R                    | Fixed Disk Adapter Status Register, where:<br>Bit 7-6 = 0 Reserved<br>Bit 5 = 1 16-bit mode<br>= 0 8-bit mode<br>Bit 4 = 1 Data transfer requested by adapter<br>Bit 3 = 1 Direction is adapter to system<br>= 0 Direction is system to adapter<br>Bit 2 = 1 Busy<br>Bit 1 = 1 Interrupt request (notification)<br>Bit 0 = 1 Transfer in progress                                                                                                                                    |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                       |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0324h       | W                    | Fixed Disk Adapter Attention Register, where:<br>Bit 7 = 1 Command control block<br>Bit 6 = 1 Command specify block<br>Bit 5 = 1 Sense summary block<br>Bit 4 = 1 Data transfer requested by system<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Drive 0 select<br>= 1 drive 1 select<br>Bit 1 = 0 Reserved<br>Bit 0 = 1 Abort current command              |
| 0324h       | R                    | Fixed Disk Adapter Interrupt Status Register<br>where:<br>Bit 7 = 1 Termination error, bits 0-6 indi-<br>cate what the error is<br>Bit 6 = 1 Invalid command<br>Bit 5 = 1 Command reject<br>Bit 4-3 = 0 Reserved<br>Bit 2 = 0 Drive 0 selected<br>= 1 Drive 1 selected<br>Bit 1 = 1 Error recovery procedure invoked<br>Bit 0 = 1 Equipment check |
| 0378h       | R/W                  | Parallel 2, data port                                                                                                                                                                                                                                                                                                                             |
| 0379h       | R/W                  | Parallel 2, status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1, 0 = Reserved                                                                                                                                    |
| 037Ah       | R/W                  | Parallel 2, control port, where:<br>Bit 7-6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe                                                                        |
| 03B4h       | R/W                  | VGA CRT controller index register (mono)                                                                                                                                                                                                                                                                                                          |
| 03B5h       | R/W                  | Other VGA CRT controller registers (mono)                                                                                                                                                                                                                                                                                                         |
| 03BAh       | R                    | VGA input status register 1 (mono)                                                                                                                                                                                                                                                                                                                |
| 03BAh       | w                    | VGA feature control register (mono)                                                                                                                                                                                                                                                                                                               |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                              |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03BCh       | R/W                  | Parallel 1, data port                                                                                                                                                                                                                                                    |
| 03BDh       | R/W                  | Parallel 1, status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1, 0 = Reserved                                                           |
| 03BEh       | R/W                  | Parallel 1, control port, where:<br>Bit 6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe |
| 03C0h       | R/W                  | VGA attribute address register                                                                                                                                                                                                                                           |
| 03C0h       | w                    | Other VGA attribute registers                                                                                                                                                                                                                                            |
| 03C1h       | R                    | Other VGA attribute registers                                                                                                                                                                                                                                            |
| 03C2h       | w                    | VGA miscellaneous output register                                                                                                                                                                                                                                        |
| 03C2h       | R                    | VGA input status register 0                                                                                                                                                                                                                                              |
| 03C3h       | R/W                  | VGA video subsystem enable                                                                                                                                                                                                                                               |
| 03C4h       | R/W                  | VGA sequencer address register                                                                                                                                                                                                                                           |
| 03C5h       | R/W                  | Other VGA sequencer registers                                                                                                                                                                                                                                            |
| 03C6h       | R/W                  | Video DAC PEL mask                                                                                                                                                                                                                                                       |
| 03C7h       | w                    | Video DAC PEL address, read mode                                                                                                                                                                                                                                         |
| 03C7h       | R                    | Video DAC state register                                                                                                                                                                                                                                                 |
| 03C8h       | R/W                  | Video DAC PEL address, write mode                                                                                                                                                                                                                                        |
| 03C9h       | R/W                  | Video DAC PEL data register                                                                                                                                                                                                                                              |
| 03CAh       | R                    | VGA feature control register                                                                                                                                                                                                                                             |
| 03CCh       | R                    | VGA miscellaneous output register                                                                                                                                                                                                                                        |
| 03CEh       | R/W                  | VGA graphics registers, address register                                                                                                                                                                                                                                 |
| 03CFh       | R/W                  | VGA and other graphics registers                                                                                                                                                                                                                                         |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03D4h       | R/W                  | VGA CRT controller index register (color)                                                                                                                                                                                                                                                                                       |
| 03D5h       | R/W                  | Other VGA CRT controller registers (color)                                                                                                                                                                                                                                                                                      |
| 03DAh       | R                    | VGA input status register 1 (color)                                                                                                                                                                                                                                                                                             |
| 03DAh       | w                    | VGA feature control register (color)                                                                                                                                                                                                                                                                                            |
| 03F0h       | R                    | Diskette controller status register A, where:<br>Bit 7 = 1 Interrupt pending<br>Bit 6 = 0 Second drive installed<br>Bit 5 = 1 Step<br>Bit 4 = 1 Track 0<br>Bit 3 = 1 Head 1 select<br>Bit 2 = 0 Index<br>Bit 1 = 0 Write protect<br>Bit 0 = 0 Data received by controller                                                       |
| 03F1h       | R                    | Diskette controller status register B, where:<br>Bit 7-6 = 0 Reserved<br>Bit 5 = Drive select<br>Bit 4 = Write data<br>Bit 3 = Read data<br>Bit 2 = Write enable<br>Bit 1 = 1 Motor enable 1<br>Bit 0 = 1 Motor enable 0                                                                                                        |
| 03F2h       | W                    | Diskette controller digital output register, where:<br>Bit 7-6 = 0 Reserved<br>Bit 5 = 1 Motor enable 1<br>Bit 4 = 1 Motor enable 0<br>Bit 3 = 0 Allow interrupts<br>Bit 2 = 0 Controller reset<br>Bit 1 = 0 Reserved<br>Bit 0 = 0 Drive select 0<br>= 1 Drive select 1                                                         |
| 03F4h       | R                    | Diskette controller status register, where:<br>Bit 7 = 1 Data register is ready<br>Bit 6 = 1 Transfer is from controller to<br>system<br>= 0 Transfer is from system to<br>controller<br>Bit 5 = 1 Non-DMA mode<br>Bit 4 = 1 Diskette controller busy<br>Bit 3-2 = Reserved<br>Bit 1 = 1 Drive 1 busy<br>Bit 0 = 0 Drive 0 busy |
| 03F5h       | R/W                  | Diskette controller data registers                                                                                                                                                                                                                                                                                              |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03F7h       | R                    | Diskette controller digital input register where:<br>Bit 7 = Diskette change<br>Bits 6-1 = Reserved<br>Bit 0 = 0 High density select                                                                                                                                                                             |
| 03F7h       | w                    | Diskette controller configuration control<br>register, where:<br>Bits 7-2 = Reserved<br>Bits 1-0 = 00b 500 kbs mode<br>= 01b Reserved<br>= 10b 250 kbs mode<br>= 11b Reserved                                                                                                                                    |
| 03F8h       | W                    | Serial 1, transmitter holding register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when Divisor Latch Access Bit<br>(DLAB) = 0                                                                                                                                                                         |
| 03F8h       | R                    | Serial 1, receiver buffer register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when DLAB = 0                                                                                                                                                                                                           |
| 03F8h       | R/W                  | Serial 1, divisor latch, low byte, where:<br>Bits 7-0 = Bits 7-0 of divisor, when DLAB = 1                                                                                                                                                                                                                       |
| 03F9h       | R/W                  | Serial 1, divisor latch, high byte, where:<br>Bits 7-0 = Bits 15-8 of divisor, when<br>DLAB = 1                                                                                                                                                                                                                  |
| 03F9h       | R/W                  | Serial 1, interrupt enable register, where:<br>Bits 7-4 = 0 Reserved<br>Bit 3 = 1 Modem status interrupt enable<br>Bit 2 = 1 Receiver line status interrupt<br>enable<br>Bit 1 = 1 Transmitter holding register<br>empty interrupt enable<br>Bit 0 = 1 Received data available interrupt<br>enable when DLAB = 0 |
| 03FAh       | R                    | Serial 1 Interrupt ID Register, where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00b Modem status interrupt<br>01b Transmitter holding register<br>empty interrupt<br>10b Received data available<br>register interrupt<br>11b Receiver line status interrupt<br>Bit 0 = 0 Interrupt pending                        |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03FAh       | W                    | Serial 1, FIFO Control Register, where:<br>Bits 7-6 = Receiver FIFO register trigger<br>00b = 1 byte<br>01b = 4 bytes<br>10b = 8 bytes<br>11b = 14 bytes<br>Bits 5-3 = 0 Reserved<br>Bit 2 = Transmitter FIFO register reset                                                                                                                                                                                                              |
|             |                      | 1 = transmit FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 1 = Receiver FIFO register reset<br>1 = receiver FIFO register cleared,<br>counter cleared, bit is self-<br>clearing                                                                                                                                                                                                                              |
|             |                      | Bit 0 = FIFO enable<br>1 = receiver and transmitter FIFOs<br>enabled, must be 1 to program<br>FIFO registers<br>0 = clears receive and transmit<br>FIFO registers, enters<br>character mode                                                                                                                                                                                                                                               |
| 03FBh       | R/W                  | Serial 1, Line Control Register, where:<br>Bit 7 = 0 Receiver Buffer, Transmitter<br>Holding, or Interrupt Enable<br>Registers Access<br>= 1 Divisor Latch Access<br>Bit 6 = 1 Set Break Enabled<br>Bit 5 = Stick Parity<br>Bit 4 = Even Parity Select<br>Bit 3 = Parity Enable<br>Bit 2 = 0 1 Stop Bit<br>= 1 0 Stop Bits<br>Bits 1-0 = 00b 5 Bit Word Length<br>01b 6 Bit Word Length<br>10b 7 Bit Word Length<br>11b 8 Bit Word Length |
| 03FCh       | R/W                  | Serial 1, Modem Control Register, where:<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 1 Loopback mode<br>Bit 3 = 1 Enable OUT2 interrupt<br>Bit 2 = 1 Force OUT1 active<br>Bit 1 = 1 Force request to send active<br>Bit 0 = 1 Force data terminal ready active                                                                                                                                                                                    |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03FDh       | R/W                  | <ul> <li>Serial 1, Line Status Register, where:</li> <li>Bit 7 = 0 Reserved</li> <li>Bit 6 = 1 Transmitter shift and holding regis-<br/>ters empty</li> <li>Bit 5 = 1 Transmitter holding register empty</li> <li>Bit 4 = 1 Break interrupt</li> <li>Bit 3 = 1 Framing error</li> <li>Bit 2 = 1 Trailing edge ring indicator</li> <li>Bit 1 = 1 Overrun error</li> <li>Bit 0 = 1 Data ready</li> </ul> |
| 03FEh       | R                    | Serial 1 Modem Status Register, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta data carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                                                                         |
| 03FFh       | R                    | Serial 1, Scratch register                                                                                                                                                                                                                                                                                                                                                                             |
| 0680h       | w                    | Manufacturing checkpoint port                                                                                                                                                                                                                                                                                                                                                                          |
| 3220–3227h  | See<br>03F8h-03FFh   | Serial Port 3 (see description for addresses 03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                                 |
| 3228-322Fh  | See<br>03F8h-03FFh   | Serial Port 4 (see description for addresses 03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                                 |
| 4220–4227h  | See<br>03F8h-03FFh   | Serial Port 5 (see description for addresses 03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                                 |
| 4228–422Fh  | See<br>03F8h-03FFh   | Serial Port 6 (see description for addresses 03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                                 |
| 5220–5228h  | See<br>03F8h-03FFh   | Serial Port 7 (see description for addresses<br>03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                              |
| 5228-522Fh  | See<br>03F8h-03FFh   | Serial Port 8 (see description for addresses 03F8h-03FFh for details).                                                                                                                                                                                                                                                                                                                                 |

# Chapter 3 System RAM Data

# Overview

#### Introduction

The CBIOS makes use of information stored in system RAM. The table below characterizes each of these areas.

| Data Area                   | Location                       | Description                                                                                                                                          |
|-----------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt Vector<br>Table   | 00h to 3FFh                    | Interrupt vectors stored as offset/segment format.                                                                                                   |
| CBIOS Data Area             | 400h to 4FFh                   | CBIOS work area. Contains data definitions<br>related to CBIOS fixed disk, diskette, key-<br>board, video, and other BIOS features and<br>functions. |
| Extended CBIOS<br>Data Area | Varies: See<br>INT 15h, AH=C1h | Extended CBIOS work area. Contains point-<br>ing device (mouse) data definitions and fixed<br>disk parameters.                                       |

#### In this chapter

This chapter presents the following information:

- Interrupt Vectors
- CBIOS Data Area
- CBIOS Extended Data Area

System RAM Data

# **Interrupt Vectors**

#### Interrupt vector table

The table below identifies each interrupt by function and type. Where applicable, it lists the interrupt vector address initialized by the CBIOS at POST.

**Note:** Further discussion of interrupts is limited to those interrupts directly related to the CBIOS. The column labeled "Ref. Chapter" tells where to turn for more information on a particular interrupt.

| INT | Function                     | Туре     | Vector | Ref.<br>Chap. |
|-----|------------------------------|----------|--------|---------------|
| 00h | Divide by Zero               | Logical  |        |               |
| 01h | Single Step                  | Logical  |        |               |
| 02h | Nonmaskable Interrupt (NMI)  | Logical  | FE2C3h | 7             |
| 03h | Breakpoint                   | Logical  |        |               |
| 04h | Overflow                     | Logical  |        |               |
| 05h | Print Screen                 | Software | FFF54h | 16            |
| 06h | Invalid Op Code              | Hardware |        |               |
| 07h | Math Coprocessor Not Present | Hardware |        |               |
| 08h | System Timer                 | Hardware | FFEA5h | 15            |
| 09h | Keyboard                     | Hardware | FE987h | 8             |
| 0Ah | Invalid Task Segment State   | Hardware |        |               |
| 0Bh | Serial Communications (COM2) | Hardware |        |               |
| 0Ch | Serial Communications (COM1) | Hardware |        |               |
| 0Dh | Parallel Printer (LPT2)      | Hardware |        |               |
| 0Eh | Diskette                     | Hardware | FEF57h | 8             |
| 0Fh | Parallel Printer (LPT1)      | Hardware |        |               |
| 10h | Video                        | Software | FF065h | 9             |
| 11h | Equipment List               | Software | FF84Dh | 16            |
| 12h | Memory Size                  | Software | FF841h | 16            |
| 13h | Fixed Disk/Diskette          | Software | FE3FEh | 11            |
| 14h | Serial Communication         | Software | FE739h | 12            |
| 15h | System Services              | Software | FF859h | 13            |
| 16h | Keyboard                     | Software | FE84Eh | 8             |
| 17h | Parallel Printer             | Software | FEFD2h | 14            |
| 18h | Load ROM BASIC               | Software | F1C90h | 16            |

# Interrupt vector table, cont'd

| INT     | Function                             | Туре       | Vector | Ref.<br>Chap. |
|---------|--------------------------------------|------------|--------|---------------|
| 19h     | Bootstrap Loader                     | Software   | FE6F2h | 16            |
| 1Ah     | System Timer & Real-Time Clock       | Software   | FFE6Eh | 15            |
| 1Bh     | Keyboard Break                       | Software   | FFF53h | 8             |
| 1Ch     | User Timer Tick                      | User       | FFF53h | 15            |
| 1Dh     | Video Parameters Table               | BIOS Table | FF0A4h | 9             |
| 1Eh     | Diskette Parameters Table            | BIOS Table | FEFC7h | 10            |
| 1Fh     | Video Graphics Characters            | User       | F7F67h | 9             |
| 20h-3Fh | Reserved for DOS                     |            |        |               |
| 40h     | Diskette BIOS Revector               | Software   | FEC59h | 10            |
| 41h     | Fixed Disk Parameter Table           | BIOS Table | FE401h | 11            |
| 42h     | EGA Default Video Driver             | BIOS Table |        |               |
| 43h     | Video Graphics Characters            | User       |        | 9             |
| 44h-45h | Reserved                             |            |        |               |
| 46h     | Fixed Disk Parameter Table           | BIOS Table | FE401h | 11            |
| 47h-49h | Reserved                             |            |        |               |
| 4Ah     | User Alarm                           | User       |        | 15            |
| 4Bh-5Fh | Reserved                             |            |        |               |
| 60h-66h | Reserved for User Program Interrupts | User       |        | 1             |
| 67h     | LIM EMS Driver                       |            |        |               |
| 68h-6Fh | Reserved                             |            |        |               |
| 70h     | Real Time Clock                      | Hardware   | F5124h | 15            |
| 71h     | Redirect Cascade                     | Hardware   | F5266h |               |
| 72h–73h | Reserved                             |            |        |               |
| 74h     | Pointing Device (Mouse)              | Hardware   | F4910h | 13            |
| 75h     | 80287 Exception                      | User       | F5257h | 7             |
| 76h     | Fixed Disk                           | Hardware   | FE2C3h | 11            |
| 77h-7Fh | Reserved                             |            |        |               |
| 80h-F0h | Reserved for BASIC                   | BASIC      |        | 16            |
| F1h-FFh | Reserved for User Program Interrupts | User       |        |               |

# **CBIOS Data Area**

#### Introduction

The CBIOS uses system RAM for storage of data definitions specific to the CBIOS.

## System RAM summary

The table below lists the system RAM data definitions in offset order. Offsets are from segment address 40:0h.

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h      | INT 14h         | I/O address of up to 4 asynchronous communica-<br>tions adapters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 08h      | INT 17h         | I/O address of up to 3 printer adapters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0Eh      |                 | Extended CBIOS data area segment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10h      | INT 11h         | Number of devices installed, where:<br>Bits 15-14 = Number of printer adapters<br>Bits 13-12 = Reserved<br>Bits 11-9 = Number of asynchronous<br>adapters (RS232)<br>Bits 8 = Reserved<br>Bits 7-6 = Number of disk drives, where:<br>00b = 1 Disk drive<br>01b = 2 Disk drives<br>Bits 5-4 = Initial video mode, where:<br>00b = EGA/VGA or PGA<br>01b = 40x25 color<br>10b = 80x25 color<br>11b = 80x25 color<br>11b = 80x25 black and white<br>Bit 3 = Reserved<br>Bit 2 = Pointing device<br>Bit 1 = 1 If math coprocessor<br>Bit 0 = Diskette available for boot |
| 12h      | POST            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 13h      | INT 12h         | Installed memory in Kilobytes minus 1K used by the extended BIOS data area                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15h      | POST            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

# System RAM summary, cont'd

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                       |
|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17h      | INT 16h         | Keyboard shift flags, where:Bit 7= 1 Insert activeBit 6= 1 Caps Lock activeBit 5= 1 Num Lock activeBit 4= 1 Scroll Lock activeBit 3= 1 Alt pressedBit 2= 1 Ctrl pressedBit 1= 1 Left Shift pressedBit 0= 1 Right Shift pressed                                                                                                                    |
| 18h      | INT 16h         | More keyboard shift flags, where:Bit 7= 1 Insert pressedBit 6= 1 Caps Lock pressedBit 5= 1 Num Lock pressedBit 4= 1 Scroll Lock pressedBit 3= 1 Ctrl-Num Lock state activeBit 2= 1 Sys Req pressedBit 1= 1 Left Alt pressedBit 0= 1 Left Ctrl pressed                                                                                             |
| 19h      | INT 16h         | Work area for Alt key and numeric keypad input                                                                                                                                                                                                                                                                                                    |
| 1Ah      | INT 16h         | Pointer to next character in keyboard buffer                                                                                                                                                                                                                                                                                                      |
| 1Ch      | INT 16h         | Pointer to first available spot in keyboard buffer                                                                                                                                                                                                                                                                                                |
| 1Eh      | INT 16h         | Keyboard buffer of 16 word entries                                                                                                                                                                                                                                                                                                                |
| 3Eh      | INT 13h         | Diskette drive recalibrate status, where:<br>Bit 7 = 1 Diskette hardware interrupt has<br>occurred<br>Bits 6-4 = Not used<br>Bits 3,2 = Reserved<br>Bit 1 = Recalibrate drive 1<br>Bit 0 = Recalibrate drive 0                                                                                                                                    |
| 3Fh      | INT 13h         | Diskette motor status, where:<br>Bit 7 = 1 Current operation is a write or format<br>= 0 Current operation is a read or verify<br>Bit 6 = Reserved<br>Bits 5,4 = Drive select states where:<br>00 = Drive 0 selected<br>01 = Drive 1 selected<br>10 = Reserved<br>11 = Reserved<br>Bit 1 = 1 Drive 1 motor is on<br>Bit 0 = 1 Drive 0 motor is on |
| 40h      | INT 13h         | Diskette motor time-out count                                                                                                                                                                                                                                                                                                                     |

| System | RAM | summary, | cont'd |
|--------|-----|----------|--------|
|--------|-----|----------|--------|

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 41h      | INT 13h         | Diskette status return code, where:<br>Bit 7 = 1 Drive not ready<br>Bit 6 = 1 Seek error occurred<br>Bit 5 = 1 Diskette controller failed<br>Bits 4-0 = Error codes, where:<br>= 00h No error<br>= 01h Illegal function was requested<br>= 02h Address mark not found<br>= 03h Write protect error<br>= 04h Sector not found<br>= 06h Drive door was opened<br>= 08h DMA overrun error<br>= 09h DMA boundary error<br>= 00h Media type unknown<br>= 10h CRC failed on disk read |  |
| 42h-48h  | INT 13h         | Diskette controller status bytes and command bytes for fixed disk controller                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 49h      | INT 10h         | Video mode setting                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 4Ah      | INT 10h         | Number of columns on screen                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 4Ch      | INT 10h         | Current page size                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 4Eh      | INT 10h         | Current page address                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 50h      | INT 10h         | Cursor position on each page. Two bytes/page.<br>First byte of each pair is column; second byte is<br>row. 0,0 is upper left corner of screen.                                                                                                                                                                                                                                                                                                                                  |  |
| 60h      | INT 10h         | Cursor type defined as 6845 video chip-compatible starting and ending scan lines. High byte is starting scan line; low is ending scan line.                                                                                                                                                                                                                                                                                                                                     |  |
| 62h      | INT 10h         | Current page number                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 63h      | INT 10h         | 6845-compatible I/O port number for current mode<br>(Port 03D4h or 03B4h)                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 65h      | INT 10h         | Current mode select register                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 66h      | INT 10h         | Current palette value                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 67h-6Ah  | POST            | Pointer to reset code upon system reset for real mode re-entry                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| 6Bh      | POST            | Last unexpected interrupt that occurred                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 6Ch      | INT 1Ah         | Least significant timer count                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 6Eh      | INT 1Ah         | Most significant timer count                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 70h      | INT 1Ah         | 24 hour roll over flag                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |

# System RAM summary, cont'd

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 71h      | INT 16h         | Ctrl-Break flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 72h      | POST            | System Reset Flag, where:<br>1234h = Bypass memory test<br>4321h = Reserved for ABIOS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 74h      | INT 13h         | Status from last fixed disk operation, where:         00h = No error         01h = Invalid function request         02h = Address mark not found         03h = Write protect error         04h = Sector not found         05h = Reset failed         07h = Drive parameter activity failed         08h = DMA overrun on operation         09h = Data boundary error         0Ah = Bad sector flag detected         0Bh = Bad track detected         0Dh = Invalid number of sectors on format         0Eh = Control data address mark detected         0Fh = DMA arbitration level out of range         10h = Uncorrectable ECC or CRC error         11h = ECC corrected data error         20h = General controller failure         40h = Seek operation failed         80h = Time-out         AAh = Drive not ready         BBh = Undefined error occurred         CCh = Write fault on selected drive         EOh = Status error/error register is 0         FFh = Sense operation failed |
| 75h      | INT 13h         | Number of fixed disks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 76h      | INT 13h         | Fixed disk control byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 77h      | INT 17h         | Fixed disk port offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 78h      | INT 14h         | Printer time-out table (ports 1-3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7Ch      | INT 16h         | Serial time-out table (ports 0-3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 80h      | INT 16h         | Offset to start of keyboard buffer (from segment 40h)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 82h      | INT 10h         | Offset to end of keyboard buffer (from segment 40h)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 84h      | INT 10h         | Number of rows on screen (24/25)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 85h      | INT 10h         | Character height (bytes/character)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| System RAM | summary, | cont'd |
|------------|----------|--------|
|------------|----------|--------|

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 87h      | INT 10h         | Video control bits, where:<br>Bit 7 = Clear RAM<br>Bit 6,5 = Memory on adapter as follows:<br>00b = 64K<br>01b = 128K<br>10b = 192K<br>11b = 256K<br>Bit 4 = Not used<br>Bit 3 = 0 EGA/VGA-compatible adapter active<br>Bit 2 = Wait for display enable<br>Bit 1 = 0 Color or ECD monitor is attached to<br>EGA/VGA-compatible adapter<br>= 1 Monochrome monitor is attached to<br>EGA/VGA-compatible adapter<br>Bit 0 = 0 Translate cursor video modes 0-3<br>when using ECD monitor in 350 line<br>mode<br>= 1 Inhibit cursor translation |
| 88h      | INT 10h         | EGA/VGA switch data where:<br>Bits 7-4 = Feature connector bits 3-0, respectively<br>Bits 3-0 = Option switches 3-0, respectively                                                                                                                                                                                                                                                                                                                                                                                                           |
| 89h      | INT 10h         | EGA/VGA control bits, where:<br>Bit 7 = 200 lines<br>Bits 6-5 = Reserved<br>Bit 4 = 400 lines<br>Bit 3 = No palette load<br>Bit 2 = Mono Monitor<br>Bit 1 = Gray Scalling<br>Bit 0 = Reserved                                                                                                                                                                                                                                                                                                                                               |
| 8Ah      | INT 13h         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8Bh      | INT 13h         | Diskette data rate information<br>Bits 7,6 = Last data rate set by controller, where:<br>00b = 500 Kilobytes/second (Kbs)<br>01b = 300 Kbs<br>10b = 250 Kbs<br>11b = Reserved<br>Bits 5,4 = Last diskette drive step rate selected<br>Bits 3,2 = Data transfer rate at operation start,<br>where:<br>00b = 500 Kbs<br>01b = 300 Kbs<br>10b = 250 Kbs<br>11b = Reserved<br>Bits 1,0 = Reserved                                                                                                                                               |
| 8Ch      | INT 13h         | Fixed disk status register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8Dh      | INT 13h         | Fixed disk error register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8Eh      | INT 13h         | Fixed disk interrupt flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

# System RAM summary, cont'd

| Location | BIOS<br>Service | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8Fh      | INT 13h         | Diskette controller information, where:Bit 7= ReservedBit 6= 1 Drive determined for drive 1Bit 5= 1 Drive 1 is multirateBit 4= 1 Drive 1 supports change lineBit 3= ReservedBit 2= 1 Drive determined for drive 0Bit 1= 1 Drive 0 is multirateBit 0= 1 Drive 0 supports change line                                                                                                                                                                                                                                                                                                                                                                                                |
| 90h-91h  | INT 13h         | Media type of both drives:<br>(One byte per drive. drive 0 at 40:90h; drive 1 at<br>40:91h)<br>Bits 7,6 = Data Transfer Rate, where:<br>00b = 500 Kbs<br>01b = 300 Kbs<br>10b = 250 Kbs<br>Bit 5 = 1 Double stepping required<br>(360K media/1.2 MB drive)<br>Bit 4 = 1 Known media in drive<br>Bit 3 = Reserved<br>Bits 2-0 = Definitions on return to user:<br>111b = 720K media in 720K or 1.44 MB<br>drive; or 1.44 MB media in<br>1.44 MB drive<br>101b = Known 1.2 MB media in 1.2 MB<br>drive<br>100b = Known 360K media in 360K drive<br>011b = Trying 1.2 MB media in 1.2 MB<br>drive<br>001b = Trying 360K media in 360K drive<br>000b = Trying 360K media in 360K drive |
| 92h      | INT 13h         | Diskette device service work area. Each entry is<br>first diskette device service value tried. One byte<br>per drive. Drive 0 at 92h, Drive 1 at 93h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 94h      | INT 13h         | Current track number for both drives. One byte per<br>drive. Drive 0 at 94h, drive 1 at 95h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 96h      | INT 16h         | Status byte:Bit 7= 1 Read ID in progressBit 6= 1 Last code was first IDBit 5= 1 Forced Num LockBit 4= 1 101/102 keyboard usedBit 3= 1 Right Alt activeBit 2= 1 Right Ctri activeBit 1= 1 Last code was E0hBit 0= 1 Last code was E1h                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Location  | BIOS<br>Service | Description                                                                                                                                                                                                                                                                            |  |
|-----------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 97h       | INT 16h         | Status byte:Bit 7= Error flag for keyboard commandBit 6= LED update in progressBit 5= RESEND received from keyboardBit 4= ACK received from keyboardBit 3= ReservedBit 2= Current status of Caps Lock LEDBit 1= Current status of Num Lock LEDBit 0= Current status of Scroll Lock LED |  |
| 98h       | INT 15h         | User wait flag offset address                                                                                                                                                                                                                                                          |  |
| 9Ah       | INT 15h         | User wait flag segment address                                                                                                                                                                                                                                                         |  |
| 9Ch       | INT 15h         | Least significant wait count                                                                                                                                                                                                                                                           |  |
| 9Eh       | INT 15h         | Most significant wait count                                                                                                                                                                                                                                                            |  |
| A0h       | INT 15h         | Wait active flag, where:<br>Bit 7 = 1 Wait time elapsed<br>Bits 6-1 = Reserved<br>Bit 0 = 1 INT 15h, AH = 86h occurred                                                                                                                                                                 |  |
| A8h       | INT 10h         | Pointer to video parameters and overrides (in<br>segment:offset format)                                                                                                                                                                                                                |  |
| B0h-B5h   |                 | Reserved                                                                                                                                                                                                                                                                               |  |
| B6h-B8h   | POST            | Reserved for POST                                                                                                                                                                                                                                                                      |  |
| 0C0h-0CDh |                 | Reserved                                                                                                                                                                                                                                                                               |  |
| CEh       | INT 15h         | Count of days since 1-1-80                                                                                                                                                                                                                                                             |  |
| CFh-FFh   |                 | Reserved                                                                                                                                                                                                                                                                               |  |
| 100h      | INT 05h         | Print screen status byte                                                                                                                                                                                                                                                               |  |

# System RAM summary, cont'd

# **CBIOS Extended Data Area**

The following table lists the definitions for the extended data area located at the top 1K of system RAM. The segment of the extended data area is defined at location 40:0Eh of the BIOS data area.

| Location | Length   | Description                                                                                                                                                                      |
|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h      | 1 Byte   | Number of bytes allocated in multiples of Kilobytes                                                                                                                              |
| 01h-16h  | 16 Words | Reserved                                                                                                                                                                         |
| 17h      | 1 Byte   | Number of POST error codes                                                                                                                                                       |
| 18h      | 5 Words  | POST error log                                                                                                                                                                   |
| 19h–21h  |          | Reserved                                                                                                                                                                         |
| 22h      | 1 Word   | Device driver far call offset                                                                                                                                                    |
| 24h      | 1 Word   | Device driver far call segment                                                                                                                                                   |
| 26h      | 1 Byte   | Pointing device flag (1st byte)<br>Bit 7 = 1 Command in Progress<br>Bit 6 = 1 Resend<br>Bit 5 = 1 Acknowledge<br>Bit 4 = 1 Error<br>Bit 3 = 0 Reserved<br>Bits 2-0 = Index count |
| 27h      | 1 Byte   | Pointing device flag (2nd byte)<br>Bit 7 = 1 Device driver far call flag<br>Bits 6-3 = 0 Reserved<br>Bits 2-0 = Package Size                                                     |
| 28h      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 29h      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 2Ah      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 2Bh      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 2Ch      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 2Dh      | 1 Byte   | Auxiliary device data                                                                                                                                                            |
| 2Eh      | 1 Word   | Auxiliary device data                                                                                                                                                            |
| 2Fh      |          | Reserved                                                                                                                                                                         |
| 30h      | 2 Words  | The interrupt vector for INT 07h is stored here during 80387 interrupt code                                                                                                      |
| 34h      | 2 Words  | The interrupt vector for INT 01h is stored here during INT 07h emulation code                                                                                                    |

# CBIOS Extended Data Area, Continued

| Location | Length   | Description                                                                                                                                                                                                                                                                                   |
|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38h      | 1 Byte   | Where the low byte of the MSW is stored by the 80287/80387 interrupt code                                                                                                                                                                                                                     |
| 39h      | 1 Word   | Watchdog Timer (Counter 3) initial count                                                                                                                                                                                                                                                      |
| 3Dh      | 16 Bytes | Fixed disk parameter table for drive 0, where:                                                                                                                                                                                                                                                |
|          | -        | Offset Size Description                                                                                                                                                                                                                                                                       |
|          |          | 00hWordMax number of cylinders02hByteMax. number of heads03hWordReserved05hWordStarting write precompensation<br>cylinder07hByteNot used08hByteControl byte09hByteReserved0AhByteReserved0BhByteReserved0ChWordLanding zone0EhByteReserved                                                    |
| 4Dh      | 16 Bytes | Fixed disk parameter table for drive 1, where:                                                                                                                                                                                                                                                |
|          |          | OffsetSizeDescription00hWordMax number of cylinders02hByteMax. number of heads03hWordReserved05hWordStarting write precompensation<br>cylinder07hByteReserved08hByteControl byte09hByteReserved0AhByteReserved0AhByteReserved0AhByteReserved0ChWordLanding zone0EhByteNumber of sectors/track |
| 6Ch      | 1 Byte   | Fixed Disk arbitration level and channel<br>number, where:<br>Bits 7-4 = Channel number (00h-0Fh)<br>Bits 3-0 = DMA arbitration level (00h-0Eh)                                                                                                                                               |
| 3F0h     | 1 Byte   | Fixed disk buffer                                                                                                                                                                                                                                                                             |

# Chapter 4 CMOS RAM Data

# Overview

#### Introduction

The ROM uses nonvolatile CMOS RAM to store real time clock, system configuration, system diagnostic, and other information.

Note: The information contained in CMOS is referenced by both the CBIOS and the ABIOS portions of the BIOS. CMOS RAM information is included here for the convenience of CBIOS users. ABIOS users will find this information repeated in *ABIOS for IBM PS/2 Computers and Compatibles.* 

#### Where CMOS RAM data is located

Information may be stored in up to two areas of CMOS RAM. The table below describes the CMOS RAM areas available to the CBIOS.

| Data Area                      | I/O<br>Location         | Size     | Description                                                                                                                                                                                                                          |
|--------------------------------|-------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CMOS RAM<br>Data Area          | 070h & 071h             | 64 bytes | These bytes are located on the Motorola<br>MC146818A Real Time Clock CMOS chip<br>(or its equivalent). All implementations<br>of the BIOS make use of this area to<br>store real time clock, POST, and system<br>configuration data. |
| Extended CMOS<br>RAM Data Area | 074h, 075h,<br>and 076h | 2K bytes | When implemented on systems that em-<br>ploy more than four adapter slots, the<br>BIOS requires an additional 2K of CMOS<br>RAM. This extended CMOS RAM is pri-<br>marily used to store POS data.                                    |

#### In this chapter

This chapter defines the contents of the CMOS RAM data areas. The following topics are presented:

- CMOS RAM I/O Ports
- CMOS RAM Data
- Extended CMOS RAM Data

# CMOS RAM I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                         |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------|
| 0070h       | w                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0 = 0 CMOS RAM address |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                         |
| 0074h       | W                    | Extended CMOS RAM address register port,<br>least significant byte                                                  |
| 0075h       | W                    | Extended CMOS RAM address register port,<br>most significant byte                                                   |
| 0076h       | R/W                  | Extended CMOS RAM data register port                                                                                |

The CBIOS accesses the CMOS RAM data areas through the following  $\ensuremath{\mathrm{I/O}}$  ports.

# **CMOS RAM Data**

#### Introduction

The CBIOS uses 64 bytes of CMOS RAM located in the Motorola MC146818A Real Time Clock CMOS chip to store real time clock and configuration data. The tables below present the following CMOS RAM data definitions:

- Real time clock
- Real time clock status registers
- Configuration

#### Real time clock data definitions

Real time clock information uses CMOS RAM addresses 00h-09h. These data definitions are presented below in offset order.

| Location | Size   | Description in binary coded decimal |
|----------|--------|-------------------------------------|
| 00h      | 1 Byte | Current second                      |
| 01h      | 1 Byte | Second alarm                        |
| 02h      | 1 Byte | Current minute                      |
| 03h      | 1 Byte | Minute alarm                        |
| 04h      | 1 Byte | Current hour                        |
| 05h      | 1 Byte | Hour alarm                          |
| 06h      | 1 Byte | Current day of week                 |
| 07h      | 1 Byte | Current date                        |
| 08h      | 1 Byte | Current month                       |
| 09h      | 1 Byte | Current year                        |

#### Status registers data definitions

The real time status registers use CMOS RAM addresses 0Ah-0Dh. These data definitions are presented below in offset order.

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                       |
|----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Ah      | 1 Byte | Status register A, where:<br>Bit 7 = 1 Update in progress<br>Bits 6-4 = Divider identifying the time-based<br>frequency to use<br>Bits 3-0 = Rate selection bits that define output<br>frequency and periodic interrupt rate                                                                                                                      |
| 0Bh      | 1 Byte | Status register B, where:Bit 7= 0 Run<br>= 1 HaltBit 6= 1 Enable periodic interruptBit 5= 1 Enable alarm interruptBit 4= 1 Enable update-ended interruptBit 3= 1 Enable square wave interruptBit 2= 1 Calendar is in binary format<br>= 0 Calendar is in BCD formatBit 1= 1 24-hour mode<br>= 0 12-hour modeBit 0= 1 Enable Daylight Savings Time |
| 0Ch      | 1 Byte | Status register C, where:<br>Bits 7-4 = IRQF, PF, AF, and UF flags,<br>respectively<br>Bits 3-0 = Reserved                                                                                                                                                                                                                                        |
| 0Dh      | 1 Byte | Status register D, where:<br>Bit 7 = 1 Real time clock has power<br>Bits 6-0 = Reserved                                                                                                                                                                                                                                                           |

# CMOS RAM Data, Continued

#### Configuration data definitions

The system configuration information data definitions use CMOS RAM addresses 0Eh-3Fh. These data definitions are presented below in offset order.

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Eh      | 1 Byte | Diagnostic status, where:Bit 7= 1 Real time clock lost powerBit 6= 1 CMOS RAM checksum is badBit 5= 1 Invalid configuration information found<br>at POSTBit 4= 1 Memory size compare error at POSTBit 3= 1 Fixed disk or adapter fails initializationBit 2= 1 CMOS RAM time found invalidBit 1= 1 Adapters do not match configurationBit 0= 1 Time-out reading an adapter ID                                                                                                                                                                               |
| 0Fh      | 1 Byte | Reason for shutdown, where:         00h       = Power on or soft reset         01h       = Memory size pass         02h       = Memory test pass         03h       = Memory test fail         04h       = POST end; boot system         05h       = JMP DWord pointer with end-of-interrupt         06h       = Protected tests pass         07h       = Protected tests fail         08h       = Memory size fail         09h       = INT 15h Block Move         0Ah       = JMP DWord pointer without end-of-interrupt         0Bh       = Used by ABIOS |
| 10h      | 1 Byte | Type of diskette drives:<br>Bits 7-4 = Drive type of drive 0, where:<br>0000b = No drive<br>0001b = $360$ K drive<br>0010b = $1.2$ MB drive<br>0011b = $720$ K<br>0100b = $1.44$ MB<br>Bits 3-0 = Drive type of drive 1, where:<br>0000b = No drive<br>0001b = $360$ K drive<br>0010b = $1.2$ MB drive<br>0010b = $1.2$ MB drive<br>0011b = $720$ K<br>0100b = $1.44$ MB                                                                                                                                                                                   |
| 11h      | 1 Byte | Type of fixed disk drive 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12h      | 1 Byte | Type of fixed disk drive 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Configuration | data | definitions, | cont'd |
|---------------|------|--------------|--------|
|---------------|------|--------------|--------|

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                      |
|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13h      | 1 Byte | Password Configuration<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 0 BIOS initializes keyboard to normal<br>speed<br>1 BIOS initializes keyboard to fast speed<br>Bits 3-2 = Reserved<br>Bit 1 = 1 Network password installed<br>= 0 Network password not installed<br>Bit 0 = 1 Power-on password installed<br>= 0 Power-on password not installed                                      |
| 14h      | 1 Byte | Equipment installed, where:<br>Bits 7-6 = Number of diskette drives, where:<br>00b = 1 Diskette drive<br>01b = 2 Diskette drives<br>Bits 5-4 = Primary display, where:<br>00b = Reserved<br>01b = VGA in 40-column mode<br>10b = VGA in 80-column mode<br>11b = VGA in monochrome mode<br>Bits 3-2 = Reserved<br>Bit 1 = 1 80387 installed<br>Bit 0 = 0 Diskette drive installed |
| 15h      | 1 Byte | Base memory in 1K, low byte                                                                                                                                                                                                                                                                                                                                                      |
| 16h      | 1 Byte | Base memory in 1K, high byte                                                                                                                                                                                                                                                                                                                                                     |
| 17h      | 1 Byte | Expansion memory in 1K, low byte                                                                                                                                                                                                                                                                                                                                                 |
| 18h      | 1 Byte | Expansion memory in 1K, high byte                                                                                                                                                                                                                                                                                                                                                |
| 19h      | 1 Byte | Adapter ID for channel 0, low byte                                                                                                                                                                                                                                                                                                                                               |
| 1Ah      | 1 Byte | Adapter ID for channel 0, high byte                                                                                                                                                                                                                                                                                                                                              |
| 1Bh      | 1 Byte | Adapter ID for channel 1, low byte                                                                                                                                                                                                                                                                                                                                               |
| 1Ch      | 1 Byte | Adapter ID for channel 1, high byte                                                                                                                                                                                                                                                                                                                                              |
| 1Dh      | 1 Byte | Adapter ID for channel 2, low byte                                                                                                                                                                                                                                                                                                                                               |
| 1Eh      | 1 Byte | Adapter ID for channel 2, high byte                                                                                                                                                                                                                                                                                                                                              |
| 1Fh      | 1 Byte | Adapter ID for channel 3, low byte                                                                                                                                                                                                                                                                                                                                               |
| 20h      | 1 Byte | Adapter ID for channel 3, high byte                                                                                                                                                                                                                                                                                                                                              |
| 21h      | 1 Byte | POS 2 configuration byte for channel 0                                                                                                                                                                                                                                                                                                                                           |
|          | 1 Byte | POS 3 configuration byte for channel 0                                                                                                                                                                                                                                                                                                                                           |

| Location | Size   | Description                                                                                                                                  |
|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 23h      | 1 Byte | POS 4 configuration byte for channel 0                                                                                                       |
| 24h      | 1 Byte | POS 5 configuration byte for channel 0                                                                                                       |
| 25h      | 1 Byte | POS 2 configuration byte for channel 1                                                                                                       |
| 26h      | 1 Byte | POS 3 configuration byte for channel 1                                                                                                       |
| 27h      | 1 Byte | POS 4 configuration byte for channel 1                                                                                                       |
| 28h      | 1 Byte | POS 5 configuration byte for channel 1                                                                                                       |
| 29h      | 1 Byte | POS 2 configuration byte for channel 2                                                                                                       |
| 2Ah      | 1 Byte | POS 3 configuration byte for channel 2                                                                                                       |
| 2Bh      | 1 Byte | POS 4 configuration byte for channel 2                                                                                                       |
| 2Ch      | 1 Byte | POS 5 configuration byte for channel 2                                                                                                       |
| 2Dh      | 1 Byte | POS 2 configuration byte for channel 3                                                                                                       |
| 2Eh      | 1 Byte | POS 3 configuration byte for channel 3                                                                                                       |
| 2Fh      | 1 Byte | POS 4 configuration byte for channel 3                                                                                                       |
| 30h      | 1 Byte | POS 5 configuration byte for channel 3                                                                                                       |
| 31h      | 1 Byte | Copy of system board POS 2                                                                                                                   |
| 32h      | 1 Byte | CRC for offsets 10-31, high byte                                                                                                             |
| 33h      | 1 Byte | CRC for offsets 10-31, low byte                                                                                                              |
| 34h      | 1 Byte | Miscellaneous information<br>Bits 7-4 = Actual number of RS-232 ports installed<br>Bits 3-0 = Block move status before reset to real<br>mode |
| 35h      | 1 Byte | Low byte of actual expansion memory size                                                                                                     |
| 36h      | 1 Byte | High byte of actual expansion memory size                                                                                                    |
| 37h      | 1 Byte | Century in BCD                                                                                                                               |
| 38h-3Eh  | 1 Byte | Power-on password                                                                                                                            |
| 39h      | 1 Byte | Power-on password checksum                                                                                                                   |

# Configuration data definitions, cont'd

#### Introduction

The BIOS uses an additional 2K of CMOS RAM to store Programmable Option Select (POS) data for MCA-compatible computer systems that include more than four expansion slots. Fixed disk parameter data for fixed disks other than those listed in the ROM BIOS Fixed Disk Parameter Table are also stored in this extra CMOS RAM.

#### **Extended CMOS RAM data definitions**

CMOS RAM Offset Size Description 0000h 1 Byte LSB of adapter ID for channel 0 0001h MSB of adapter ID for channel 0 1 Byte 0002h 1 Byte Number of POS values used 0003h POS 2 for channel 0 1 Byte 0004h POS 3 for channel 0 1 Byte 0005h 1 Byte POS 4 for channel 0 POS 5 for channel 0 0006h 1 Byte 0007-0022h Reserved 0023h LSB of adapter ID for channel 1 1 Byte 0024h 1 Byte MSB of adapter ID for channel 1 0025h Number of POS values used 1 Byte 0026h 1 Byte POS 2 for channel 1 POS 3 for channel 1 0027h 1 Byte 0028h POS 4 for channel 1 1 Byte 0029h 1 Byte POS 5 for channel 1 002A-0045h Reserved 0046h 1 Byte LSB of adapter ID for channel 2 0047h 1 Byte MSB of adapter ID for channel 2 1 Byte 0048h Number of POS values used 0049h 1 Byte POS 2 for channel 2 004Ah 1 Byte POS 3 for channel 2

The table below outlines the contents of the extended CMOS RAM data area.

# Extended CMOS RAM Data, Continued

| CMOS RAM<br>Offset | Size   | Description                     |
|--------------------|--------|---------------------------------|
| 004Bh              | 1 Byte | POS 4 for channel 2             |
| 004Ch              | 1 Byte | POS 5 for channel 2             |
| 0040-0068h         |        | Reserved                        |
| 0069h              | 1 Byte | LSB of adapter ID for channel 3 |
| 006Ah              | 1 Byte | MSB of adapter ID for channel 3 |
| 006Bh              | 1 Byte | Number of POS values used       |
| 006Ch              | 1 Byte | POS 2 for channel 3             |
| 006Dh              | 1 Byte | POS 3 for channel 3             |
| 006Eh              | 1 Byte | POS 4 for channel 3             |
| 006Fh              | 1 Byte | POS 5 for channel 3             |
| 0070-008Bh         |        | Reserved                        |
| 008Ch              | 1 Byte | LSB of adapter ID for channel 4 |
| 008Dh              | 1 Byte | MSB of adapter ID for channel 4 |
| 008Eh              | 1 Byte | Number of POS values used       |
| 008Fh              | 1 Byte | POS 2 for channel 4             |
| 0090h              | 1 Byte | POS 3 for channel 4             |
| 0091h              | 1 Byte | POS 4 for channel 4             |
| 0092h              | 1 Byte | POS 5 for channel 4             |
| 0093-00AEh         |        | Reserved                        |
| 00AFh              | 1 Byte | LSB of adapter ID for channel 5 |
| 00B0h              | 1 Byte | MSB of adapter ID for channel 5 |
| 00B1h              | 1 Byte | Number of POS values used       |
| 00B2h              | 1 Byte | POS 2 for channel 5             |
| 00B3h              | 1 Byte | POS 3 for channel 5             |
| 00B4h              | 1 Byte | POS 4 for channel 5             |
| 00B5h              | 1 Byte | POS 5 for channel 5             |
| 00B6-00D1h         |        | Reserved                        |
| 00D2h              | 1 Byte | LSB of adapter ID for channel 6 |
| 00D3h              | 1 Byte | MSB of adapter ID for channel 6 |

# Extended CMOS RAM data definitions, cont'd

continued

CBIOS for IBM PS/2 Computers and Compatibles

# Extended CMOS RAM Data, Continued

| CMOS RAM<br>Offset | Size     | Description                                                                                                                    |  |  |  |
|--------------------|----------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 00D4h              | 1 Byte   | Number of POS values used                                                                                                      |  |  |  |
| 00D5h              | 1 Byte   | POS 2 for channel 6                                                                                                            |  |  |  |
| 00D6h              | 1 Byte   | POS 3 for channel 6                                                                                                            |  |  |  |
| 00D7h              | 1 Byte   | POS 4 for channel 6                                                                                                            |  |  |  |
| 00D8h              | 1 Byte   | POS 5 for channel 6                                                                                                            |  |  |  |
| 00D9-00F4h         |          | Reserved                                                                                                                       |  |  |  |
| 00F5h              | 1 Byte   | LSB of adapter ID for channel 7                                                                                                |  |  |  |
| 00F6h              | 1 Byte   | MSB of adapter ID for channel 7                                                                                                |  |  |  |
| 00F7h              | 1 Byte   | Number of POS values used                                                                                                      |  |  |  |
| 00F8h              | 1 Byte   | POS 2 for channel 7                                                                                                            |  |  |  |
| 00F9h              | 1 Byte   | POS 3 for channel 7                                                                                                            |  |  |  |
| 00FAh              | 1 Byte   | POS 4 for channel 7                                                                                                            |  |  |  |
| 00FBh              | 1 Byte   | POS 5 for channel 7                                                                                                            |  |  |  |
| 00FC-0160h         |          | Reserved                                                                                                                       |  |  |  |
| 0161–0162h         | 1 Word   | Set to a value to make POST's CRC for extended CMOS RAM locations 0-162 equal zero. Main-<br>tained by the Reference Diskette. |  |  |  |
| 0163–0165h         | 3 Bytes  | Actual extended memory size when over 65 MB                                                                                    |  |  |  |
| 0166–0175h         | 16 Bytes | Fixed Disk Parameter Table for drive 0                                                                                         |  |  |  |
| 0176–0185h         | 16 Bytes | Fixed Disk Parameter Table for drive 1                                                                                         |  |  |  |
| 0186h              | 1 Byte   | POST uses this offset to test whether extended CMOS RAM can be accessed correctly.                                             |  |  |  |
| 0187h-0188h        |          | Reserved                                                                                                                       |  |  |  |
| 0189h-018Dh        |          | Reserved for Reference Diskette POST use                                                                                       |  |  |  |
| 018Eh              | 1 Byte   | Number of Micro Channel slots.                                                                                                 |  |  |  |
| 018Fh-0388h        |          | Reserved                                                                                                                       |  |  |  |
| 0389h              | 1 Byte   | Error Log Number (0-5)                                                                                                         |  |  |  |
| 038Ah              | 20 Bytes | Error Log Block 0                                                                                                              |  |  |  |
| 039Eh              | 20 Bytes | Error Log Block 1                                                                                                              |  |  |  |
| 03B2h              | 20 Bytes | Error Log Block 2                                                                                                              |  |  |  |

# Extended CMOS RAM data definitions, cont'd

| CMOS RAM<br>Offset | Size     | Description       |
|--------------------|----------|-------------------|
| 03C6h              | 20 Bytes | Error Log Block 3 |
| 03DAh              | 20 Bytes | Error Log Block 4 |
| 03EEh              | 20 Bytes | Error Log Block 5 |
| 0402h-06FFh        | 20 Bytes | Reserved          |
| 0700h-07FFh        | 20 Bytes | Reserved          |

# Extended CMOS RAM data definitions, cont'd

# 5

# Chapter 5 ROM BIOS Data

# Overview

#### Introduction

In addition to the code for the various CBIOS services, the ROM BIOS also contains tabular data that is used to initialize devices and to insure IBM family compatibility.

#### In this chapter

This chapter defines the contents of the ROM BIOS data areas. The following topics are presented:

- ROM Address Compatibility Table
- System Configuration Data Table
- Feature Control
- Diskette Parameters Table
- Fixed Disk Parameters Table
- Baud Rate Initialization

# **ROM Address Compatibility Table**

# Description

The Phoenix CBIOS maintains compatibility by providing a list of jump instructions that insure that both table information and calls to specific CBIOS services are located at the IBM-compatible entry points.

#### **Compatible ROM Addresses**

| Address | Description                                                            |
|---------|------------------------------------------------------------------------|
| FE05Bh  | Compatible POST Entry Point                                            |
| FE2C3h  | NMI Handler Entry Point                                                |
| FE3FEh  | Compatible INT 13h Fixed Disk Service Entry Point                      |
| FE401h  | Fixed Disk Parameters Table                                            |
| FE6F2h  | Compatible INT 19h Boot Load Service Entry Point                       |
| FE6F5h  | Configuration Data Table                                               |
| FE729h  | Baud Rate Generator Table                                              |
| FE739h  | Compatible INT 14h Serial Communications Service Entry Point           |
| FE82Eh  | Compatible INT 16h Keyboard Service Entry Point                        |
| FE987h  | Compatible INT 09h Keyboard Service Entry Point                        |
| FEC59h  | Compatible INT 13h Diskette Service Entry Point                        |
| FEF57h  | Compatible INT 0Eh Diskette Hardware ISR Entry Point                   |
| FEFC7h  | Diskette Controller Parameter Table                                    |
| FEFD2h  | Compatible INT 17h Printer Service Entry Point                         |
| FF045h  | Compatible INT 10 Functions 0-Fh Entry Point                           |
| FF065h  | Compatible INT 10h Video Support Service Entry Point                   |
| FF0A4h  | MDA/CGA Video Parameters Table (INT 1Dh)                               |
| FF841h  | Compatible INT 12h Memory Size Service Entry Point                     |
| FF84Dh  | Compatible INT 11h Equipment List Service Entry Point                  |
| FF859h  | Compatible INT 15h System Services Entry Point                         |
| FFA6Eh  | Character Font for 320X200 and 640X200 Graphics (lower 128 characters) |
| FFE6Eh  | Compatible INT 1Ah Time-of-day Service Entry Point                     |
| FFEA5h  | Compatible INT 08h System Timer ISR Entry Point                        |

# Compatible ROM Addresses, cont'd

| Address | Description                                         |  |
|---------|-----------------------------------------------------|--|
| FFEF3h  | Initial Interrupt Vector Offsets Loaded by POST     |  |
| FFF53h  | IRET Instruction for Dummy Interrupt Handler        |  |
| FFF54h  | Compatible INT 05h Print Screen Service Entry Point |  |
| FFFF0h  | Power-up Entry Point                                |  |
| FFFF5h  | ASCII Date ROM was built — 8 characters xx/xx/xx    |  |
| FFFFEh  | System Model ID (See System Services)               |  |

# System Configuration Data Table

# Description

The System Configuration Table is located in the CBIOS ROM at F000:E6F5h. This table can be called into RAM via INT 15h function AH = C0h Return System Configuration Parameters.

#### Parameter table structure

| Offset | Initial<br>value | Length | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h    | 0                | 1 Word | Number of bytes in this table (minimum = 8)                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 02h    | 1                | 1 Byte | Model byte, where:<br>Model 80 = F8h<br>Model 70 = F8h<br>Model 60 = FCh<br>Model 30 = FAh<br>Model 25 = FAh<br>Unknown system board = FFh                                                                                                                                                                                                                                                                                                                                            |
| 03h    | 1                | 1 Byte | Submodel byte, where:           Model 80         = 00h or 01h           Model 70         = 09h           Model 60         = 05h           Model 30         = 04h           Model 25         = 01h           Unknown system board = FFh                                                                                                                                                                                                                                                |
| 04h    | 1                | 1 Byte | BIOS revision level (first release = 00b)                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 05h    | 1                | 1 Byte | Feature information byte, where:<br>Bit 7 = 1 Fixed disk BIOS uses DMA channel 3<br>Bit 6 = 1 Second interrupt chip present<br>Bit 5 = 1 Real time clock present<br>Bit 4 = 1 Keyboard intercept (INT 15h, function<br>AH = 4Fh) called by keyboard interrupt<br>service (INT 09h)<br>Bit 3 = 1 Wait for external event supported<br>Bit 2 = 1 Extended BIOS data area is allocated<br>Bit 1 = 1 Micro Channel supported<br>= 0 PC-type I/O channel implemented<br>Bit 0 = 0 Reserved |
| 06h    | 0                | 1 Byte | Feature information byte 2 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 07h    | 1                | 1 Byte | Feature information byte 3 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 08h    | 1                | 1 Byte | Feature information byte 4 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 09h    | 0                | 1 Byte | Feature information byte 5 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### Description

The PS/2 BIOS is designed to use the configuration control information in the System Configuration Table, which is accessed using CBIOS INT 15h function C0h, Return System Configuration Parameters.

However, the System Configuration Table does not provide enough information for a PS/2 BIOS to operate properly. Additional data about the system configuration is stored at location F000:E97Fh, and is described below.

#### Using PS/2 model features as configuration parameters

There are several system features which can be used as system configuration parameters to define PS/2-compatible models. These features are:

- number of adapter slots,
- existence of extended CMOS RAM,
- position of the password disable bit, and
- the memory encoding and memory definition register implementation.

The features listed above are used as parameters by the BIOS to distinguish various PS/2–compatible system configurations.

#### Feature table

The following table describes how these features vary among several PS/2 models.

| Feature              | Model 50 | Model 60 | 16 MHz<br>Model 80 | 20 MHz<br>Model 80 |
|----------------------|----------|----------|--------------------|--------------------|
| Adapter slots        | 4        | 8        | 8                  | 8                  |
| Extended CMOS        | No       | Yes      | Yes                | Yes                |
| Password disable bit | Bit 1    | Bit 1    | Bit 4              | Bit 4              |
| Memory registers     | None     | None     | Definition 1       | Definition 2       |

# Feature Control, Continued

#### Setting the adapter board data

The number of adapter boards is described at address F000:E97Fh. This number can be 1 to n.

| lf                                                                            | Then                                                                        |
|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| four or fewer adapter slots<br>on the board and extended<br>CMOS is available | the PS/2 BIOS expects that all slot definitions are stored in extended CMOS |
| five or more adapter slots on the board                                       | extended CMOS RAM must be available.                                        |

Use a reference diskette utility to copy the adapter card definitions to CMOS RAM to ensure proper system operation.

#### Password disable bit

The password disable bit is in the POS 3 register of the system board at I/O address 0103h. This bit specifies whether the power-on password should be checked for or not. The password disable bit is described at address F000:E980h. A one is required to proceed normally to query the user for a password. A zero indicates that the password will be zeroed out.

If the memory registers are defined, the password disable bit cannot be in bits 0-3 of the system board POS slot 3, and must be in bits 4-7.

#### Memory register definition

There are three parts in each memory definition, each one byte long:

- memory card register,
- memory encoding register 1, and
- memory encoding register 2.

The memory registers for IBM Model 80-compatible systems are implemented differently in 16 MHz and 20 MHz versions. The memory registers start at address F000:E981h.

PS/2-compatible systems may implement memory register configuration on Model 50 or Model 60-compatible systems, since the Intel 80286 and 80386SX microprocessors support memory encoding.

#### Introduction

The diskette device service routine in older systems supplied a table of parameters used to manipulate diskette drives. For compatibility, the diskette device service routine must still provide the same table although some of its values are modified so that the table is more suited to the default 1.44 MB diskette drives. The default 11-byte table is located at F000:EFC7h and is pointed to by the interrupt 1Eh vector.

#### Parameter table structure

| Byte | Description                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h  | The format for the first data byte of the diskette specify<br>command is:<br>Bits 7-4 = Stepping rate<br>Bits 3-0 = Head unload time                                                                                                                                                                                                           |
|      | The default stepping rate is 0Ah for the 1.44 MB drive with a 1.44 MB diskette inserted. The default head unload time is the maximum value of 240 ms (0Fh).                                                                                                                                                                                    |
| 01h  | The format for the second data byte of the diskette specify<br>command is:<br>Bits 7-1 = Head load time<br>Bit 0 = Non-DMA mode flag                                                                                                                                                                                                           |
|      | The default head load delay time is set to the minimum value of<br>4 ms (01h). The heads are loaded at the same time as the mo-<br>tor is started, but the motor delay is much longer so the head<br>load time delay is not really needed. The non-DMA mode flag is<br>always set to zero to indicate that DMA is being used.                  |
| 02h  | Motor turn-off delay. This is the amount of time in timer ticks<br>that the diskette device service routine walts before turning off<br>an inactive diskette drive motor. Timer ticks occur 18.2 times<br>per second and the routine waits about two seconds; therefore<br>the default value for this field is 25h.                            |
| 03h  | Bytes per sector. This field is encoded in the following way to<br>match the encoding used by the diskette controller:<br>00 = 128 bytes per sector<br>01 = 256 bytes per sector<br>02 = 512 bytes per sector<br>03 = 1024 bytes per sector<br>The standard sector size is 512 bytes per sector so the default<br>value for this field is 02h. |

## Parameter table structure, cont'd

| Byte | Description                                                                                                                                                                                                                                                                                                     |  |  |  |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 04h  | End of track. Since the sector numbering is one relative, this field is actually the number of sectors per track. For the 1.44 MB diskette in the 1.44 MB drive, this field is 18 sectors per track.                                                                                                            |  |  |  |
| 05h  | Gap length. This field is the length of the gap between sectors.<br>The default value for this field is 1Bh for the 1.44 MB diskette.                                                                                                                                                                           |  |  |  |
| 06h  | Data length. Since the bytes per sector field is non-zero, this field is meaningless and is set to FFh.                                                                                                                                                                                                         |  |  |  |
| 07h  | Gap length for format. This field is the length of the gap be-<br>tween sectors to maintain when formatting. The default format<br>gap length for the 1.44 MB diskette is 6Ch.                                                                                                                                  |  |  |  |
| 08h  | Filler byte. This byte is the format filler byte and is F6h.                                                                                                                                                                                                                                                    |  |  |  |
| 09h  | Head seek delay time. This is the amount of time in milliseconds<br>the diskette device service routine must wait for the heads to<br>settle after doing a seek operation. For the 1.44 MB diskette<br>drive, this field is 0Fh.                                                                                |  |  |  |
| 0Ah  | Motor start time. This is the amount of time in eighths of a sec-<br>ond that the diskette device service routine must wait for the<br>motor to come up to speed before doing an I/O operation. The<br>1.44 MB drive has a motor start time of one second so the<br>default value for this field is set to 08h. |  |  |  |

#### Description

The Fixed Disk Parameters Table defines the types of fixed disk drives that can be used. As part of system configuration, the INT 41h vector is set up to point to the fixed disk parameters entry associated with drive 0. If fixed disk drive 1 is installed, INT 46h is initialized to point to its corresponding entry in the Fixed Disk Parameters table. To maintain compatibility, the Fixed Disk Parameters Table is based at F000:E401h.

#### Parameter table structure

Each entry in the Fixed Disk Parameters Table occupies 8 words as defined below.

| Offset | Size    | Description                                                                                                                                                                                                     |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h    | 2 Bytes | Maximum number of cylinders                                                                                                                                                                                     |
| 02h    | 1 Byte  | Maximum number of heads                                                                                                                                                                                         |
| 03h    | 2 Byte  | Reserved                                                                                                                                                                                                        |
| 05h    | 2 Bytes | Starting write precompensation cylinder                                                                                                                                                                         |
| 07h    | 1 Byte  | Reserved                                                                                                                                                                                                        |
| 08h    | 1 Byte  | Control byte, where:<br>Bit 7,6 = 1 Disable retries (either bit disables)<br>Bit 5 = 1 Defect map present at max,<br>cylinder + 1<br>Bit 4 = 0 Reserved<br>Bit 3 = 1 More than 8 heads<br>Bits 2-0 = 0 Reserved |
| 09h    | 3 Bytes | Reserved                                                                                                                                                                                                        |
| 0Ch    | 2 Bytes | Landing zone                                                                                                                                                                                                    |
| 0Eh    | 1 Byte  | Number of sectors per track                                                                                                                                                                                     |
| 0Fh    | 1 Byte  | Reserved                                                                                                                                                                                                        |

# Fixed Disk Parameters Table, Continued

#### Fixed disk parameter entries

The CBIOS portion of the ROM BIOS defines only the first 32 entries in the Fixed Disk Table. Fixed disk type 15 is not used. Definitions for fixed disk types 1–32 are located in a 16-byte table starting at F000:E401h.

#### Table of fixed disk definitions

The defined entries into the Fixed Disk Parameters table are listed below. Wherever possible, the manufacturer name and model number associated with a given drive type are listed in the column, "Manufacturer."

| Туре | Manufacturer                                                                          | Cyl. | Heads | Write<br>Precomp | Landing<br>Zone | Sectors/<br>Track | Defect<br>Map |
|------|---------------------------------------------------------------------------------------|------|-------|------------------|-----------------|-------------------|---------------|
| 1    | IBM 10 MB                                                                             | 306  | 4     | 128              | 305             | 17                | No            |
| 2    | IBM 20 MB<br>Seagate ST-225<br>CDC Wren II<br>9415-5-25<br>Miniscribe 8438F           | 615  | 4     | 300              | 615             | 17                | No            |
| 3    | IBM 30 MB                                                                             | 615  | 6     | 300              | 615             | 17                | No            |
| 4    | IBM 62 MB                                                                             | 940  | 8     | 512              | 940             | 17                | No            |
| 5    | IBM 46 MB                                                                             | 940  | 6     | 512              | 940             | 17                | No            |
| 6    | IBM 20 MB<br>Miniscribe MS 8425<br>Seagate ST4026<br>Tandon TM 262<br>Tandon TM 702AT | 615  | 4     | 0FFFFh           | 615             | 17                | No            |
| 7    | IBM 30 MB                                                                             | 462  | 8     | 256              | 511             | 17                | No            |
| 8    | IBM 30 MB<br>Seagate ST-4038<br>CDC Wren II<br>9415-5-38<br>Tandon TM 703AT           | 733  | 5     | OFFFFh           | 733             | 17                | No            |
| 9    | IBM 112 MB                                                                            | 900  | 15    | 0FFFFh           | 901             | 17                | No            |
| 10   | IBM 20 MB                                                                             | 820  | 3     | 0FFFFh           | 820             | 17                | No            |
| 11   | IBM 35 MB                                                                             | 855  | 5     | 0FFFFh           | 855             | 17                | No            |
| 12   | IBM 49 MB                                                                             | 855  | 7     | 0FFFFh           | 855             | 17                | No            |
| 13   | IBM 20 MB                                                                             | 306  | 8     | 128              | 319             | 17                | No            |

write precompensation for all cylinders.

# Fixed Disk Parameters Table, Continued

| Туре | Manufacturer                                                                    | Cyl.       | Heads     | Write<br>Precomp       | Landing<br>Zone               | Sectors/<br>Track             | Defect<br>Map     |
|------|---------------------------------------------------------------------------------|------------|-----------|------------------------|-------------------------------|-------------------------------|-------------------|
| 14   | IBM 42 MB                                                                       | 733        | 7         | 0FFFFh                 | 733                           | 17                            | No                |
| 15   |                                                                                 |            | Not u     | lsed                   |                               |                               |                   |
| 16   | IBM 20 MB                                                                       | 612        | 4         | 0                      | 663                           | 17                            | No                |
| 17   | IBM 40 MB                                                                       | 977        | 5         | 300                    | 977                           | 17                            | No                |
| 18   | IBM 56 MB                                                                       | 977        | 7         | 0FFFFh                 | 977                           | 17                            | No                |
| 19   | IBM 59 MB                                                                       | 1024       | 7         | 512                    | 1023                          | 17                            | No                |
| 20   | IBM 30 MB                                                                       | 733        | 5         | 300                    | 732                           | 17                            | No                |
| 21   | IBM 42 MB                                                                       | 733        | 7         | 300                    | 732                           | 17                            | No                |
| 22   | IBM 30 MB                                                                       | 733        | 5         | 300                    | 733                           | 17                            | No                |
| 23   | IBM 10 MB                                                                       | 306        | 4         | 0                      | 336                           | 17                            | No                |
| 24   | IBM 20 MB                                                                       | 612        | 4         | 305                    | 663                           | 17                            | No                |
| 25   | IBM 10 MB                                                                       | 306        | 4         | 0FFFFh                 | 340                           | 17                            | No                |
| 26   | IBM 20 MB                                                                       | 612        | 4         | 0FFFFh                 | 670                           | 17                            | No                |
| 27   | IBM 40.5 MB                                                                     | 698        | 7         | 300                    | 732                           | 17                            | Yes               |
| 28   | IBM 40.5 MB                                                                     | 976        | 5         | 488                    | 977                           | 17                            | Yes               |
| 29   | IBM 10 MB                                                                       | 306        | 4         | 0FFFFh                 | 340                           | 17                            | No                |
| 30   | IBM 20 MB                                                                       | 611        | 4         | 306                    | 663                           | 17                            | Yes               |
| 31   | IBM 42.5 MB                                                                     | 732        | 7         | 300                    | 732                           | 17                            | Yes               |
| 32   | IBM 42.5 MB                                                                     | 1023       | 5         | 0FFFFh                 | 1023                          | 17                            | Yes               |
| Note | : If a table entry contains<br>precompensation for thi<br>write precompensation | s disk. If | the write | Precomper<br>precomper | nsation, the<br>Isation is ze | n there is n<br>ero, then the | o write<br>ere is |

#### Table of fixed disk definitions, cont'd

#### Baud rate initialization table

The baud rate initialization table is located at F000:E729h in the ROM BIOS.

| Baud Rate | Divisor |
|-----------|---------|
| 110       | 0417h   |
| 150       | 0300h   |
| 300       | 0180h   |
| 600       | 00C0h   |
| 1200      | 0060h   |
| 2400      | 0030h   |
| 4800      | 0018h   |
| 9600      | 000Ch   |
| 19200     | 0006h   |

#### How baud rate divisor is calculated

The input frequency to the device is 1.8432 MHz. The values in the table are calculated as follows:

1,843,200 / 16 = 115200 / Baud Rate = Divisor

For example, a baud rate of 2400 has a divisor of 115200/2400, which equals 48 decimal, 30 hex.

# Chapter 6 Power-On Self Tests (POST)

#### Overview

#### Introduction

Before a computer system can be used, all system components must be tested and initialized, and the operating system must be bootstrapped into memory. The process of system test and initialization is generally under the control of the computer system's ROM BIOS. It is commonly referred to by the acronym POST, for power-on self test and initialization procedure.

#### ABIOS and POST

The POST procedure is contained in the CBIOS portion of the BIOS code. The ABIOS is not in any way associated with POST.

#### Model 25/30 POST

Error messages and POST procedures that are specific to the PS/2 Model 25 and Model 30 are documented in Appendix C.

continued

Power-On Self Tests (POST)

#### How POST is started

The CBIOS POST process can be started in any of the ways described in the table below:

| Start Method                                                | CBIOS Behavior                                                                                                                                                                                                                                                                                   |  |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Apply power to system<br>(i.e. turn system on.)             | Jump to entry point indicated by the processor reset vec-<br>tor. All POST tests and initializations are executed. POST<br>invokes CBIOS INT 19h, Operating System Bootstrap<br>Loader.                                                                                                          |  |
| Reset system via op-<br>tional hardware reset<br>button.    | Jump to entry point indicated by the processor reset vec-<br>tor. All POST tests and initializations are executed. POST<br>invokes CBIOS INT 19h, Operating System Bootstrap<br>Loader.                                                                                                          |  |
| Press <ctrl> <alt> <del><br/>(warm boot)</del></alt></ctrl> | INT 09h keyboard hardware interrupt service routine trans-<br>fers control to CBIOS POST. The POST test and initializa-<br>tion of memory above 64K is not executed. All other POST<br>tests and initializations are executed. POST invokes CBIOS<br>INT 19h, Operating System Bootstrap Loader. |  |

# Processor reset vector location

To maintain compatibility, the processor reset vector points to address F000:0000h. This vector is also dual mapped by external address selection logic to point to FFFF:00000h — the 80286/80386 reset vector address.

#### In this chapter

This chapter presents the following information:

- POST Procedures
- Rules for Positioning I/O Expansion ROM
- Re-entering Real Mode
- INT 19h, INT 18h, and System Boot
- POST Error Handling

#### Introduction

The initialization and self test functions of the POST process are tightly interwoven. The processes can be generally thought of, however, as falling into two categories:

- Processes related to the central system hardware
- Processes related to configuration and nonsystem board hardware

#### How POST handles errors

If POST finds errors on its first pass through the boot procedure, it looks for the Reference Diskette in Diskette Drive A:. If the Reference Diskette is not in Drive A:, POST generates a message, **Press F1 to Retry.** 

If the Reference Diskette is in Diskette Drive A:, POST causes it to load so the error message can be handled by the end user.

**Note:** See the POST Error Handling information in this chapter.

#### Central hardware POST tests

Because the proper functioning of the central hardware is required before further POST tests can occur, the most central hardware is first tested, then initialized.

POST tests and initializes the following central system components in the order listed below:

- The Central Processing Unit (CPU)
- ROM BIOS (checksum)
- CMOS RAM
- Intel 8237 Direct Memory Access (DMA) Controller
- Intel 8042/8742 Keyboard Controller
- Base 64K System RAM
- Intel 8259A Programmable Interrupt Controller
- Intel 8254A Programmable Timer
- Intel 82385 Cache Controller, if present

## POST Procedures, Continued

#### Nonsystem hardware POST tests

Once the central hardware has been tested and initialized, POST verifies that the system configuration specified in CMOS matches the actual hardware present. The remaining POST procedures test and initialize memory above 64K, the keyboard, the diskette and fixed disk drives, the CRT controller, and any nonsystem board hardware.

POST tests and initializes the following configuration and nonsystem board components in the order listed below:

- CMOS RAM Configuration data
- CRT controllers
- RAM memory above 64K
- Keyboard
- Pointing device (mouse, etc.)
- Diskette drive A availability
- Serial interface circuitry
- Diskette controllers
- Fixed disk controllers

#### Introduction

An I/O expansion ROM is an optional extension of the BIOS which is inserted into the machine environment as part of an added I/O subsystem. I/O ROMs often replace part of the BIOS for a certain function. (e.g. ESDI fixed disk ROM BIOS.)

I/O expansion ROMs are detected by POST and are given an opportunity to initialize themselves and their hardware environment.

#### Predefined address ranges

POST searches for expansion ROM over two predefined address ranges. The predefined address ranges are listed in the table below.

| Address Range  | Description                                                                                                                                                                                              |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C0000 - C7FFFh | VIDEO EXPANSION ROM<br>POST searches the address range beginning at C0000h and<br>up to but not including C8000h for the existence of Video<br>Expansion ROM. This search proceeds in 2K increments.     |
| C8000 - DFFFFh | GENERAL EXPANSION ROM<br>POST searches the address range beginning at C8000h and<br>up to but not including E0000h for the existence of General<br>Expansion ROM. This search proceeds in 2K increments. |

#### **Rules for detecting ROM**

For POST to detect an expansion ROM, the first two words of each expansion ROM area must be set up as described below.

| I/O ROM Byte | Value                                             |  |
|--------------|---------------------------------------------------|--|
| 0            | 55h                                               |  |
| 1            | AAh                                               |  |
| 2            | ROM length in 512-byte blocks                     |  |
| 3            | Entry point for ROM initialization (via FAR CALL) |  |

Note: POST calculates the checksum of the area indicated by I/O ROM Byte 2. If the checksum is zero, POST will call the expansion ROM initialization code, which must begin at Byte 3.

# **Re-entering Real Mode**

#### Re-entry into real mode

Several POST processes require that the system be put into protected mode.

When returning to real mode from protected mode, the processor is reset, therefore POST is re-entered. In order to prevent re-initialization of the system, POST reads the shutdown code stored in location 0Fh in CMOS RAM. It then jumps around the initialization procedures to the appropriate entry point.

#### Table of shutdown code values

As POST proceeds, it will use the shutdown codes with values 01h, 02h, 03h, 04h, 06h, 07h, and 08h to return the processor to real mode.

Shutdown codes 05h and 0Ah are more flexible; they return control to the address stored in a double word pointer at 40:67h. These vectors are provided for use by operating system extensions such as I/O ROMs. Shutdown code 05h flushes the keyboard buffer and performs an end-of-interrupt (EOI) prior to vectoring. Shutdown code 0Ah simply vectors.

| CMOS RAM<br>Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|----------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0Fh                  | 1 Byte | SHUTDOWN CODE         00h =       Power-on or soft reset         01h =       Memory size pass         02h =       Memory test pass         03h =       Memory test fail         04h =       POST end; boot system         05h =       JMP dword pointer with end-of-interrupt         06h =       Protected tests pass         07h =       Protected tests fail         08h =       Memory size fail         09h =       INT 15h Block Move         0Ah =       JMP dword pointer without end-of-interrupt |  |

#### Introduction

Once the POST test and initialization procedures have been completed, POST boots the system by issuing an INT 19h.

#### INT 19h behavior

INT 19h behaves as described in the table below:

| lf                                         | And                                                      | Then                                                                                           |
|--------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------|
| a diskette drive is<br>configured          | a bootable diskette is in<br>place                       | INT 19h reads the diskette boot<br>sector and places its contents<br>at address 0000:7C00h     |
| a fixed disk is<br>configured              | there is no bootable disk-<br>ette in the diskette drive | INT 19h reads the fixed disk<br>boot sector and places its con-<br>tents at address 0000:7C00h |
| no boot sector is found<br>on the diskette | no boot sector is found on<br>the fixed disk             | INT 19h issues INT 18h. INT 18h<br>displays the message: "NO<br>BOOT DEVICE AVAILABLE"         |

Note: INT 19h performs password checking routines after the boot sector is loaded. For more information on INT 19h password checking, refer to Chapter 16.

#### INT 18h behavior

INT 18h can be vectored to a "no boot routine" which takes over the boot process. An example of such a routine would be one that allows the system to be booted over a network.

By default, the CBIOS initializes INT 18h to point to a routine that displays the message: "NO BOOT DEVICE AVAILABLE."

# **POST Error Handling**

#### Introduction

POST reports test or initialization failures in one of the following ways:

- Beep codes
- System failure messages
- Boot failure messages
- Informational messages

See Appendix A, CBIOS Error Messages, for a complete listing of POST messages.

# Chapter 7 INT 02h Nonmaskable Interrupt

# Overview

#### Introduction

When the system hardware activates the Nonmaskable Interrupt (NMI) pin on the microprocessor:

- the Central Arbitration Control Point is implicitly disabled and
- the CBIOS INT 02h NMI interrupt service routine (ISR) is invoked.

#### **CBIOS NMI Interrupt Service Routine (ISR)**

The CBIOS NMI ISR determines the reason for the NMI and takes appropriate action. In general, this involves:

- explicitly re-enabling the central arbitration control point,
- displaying a run time error message, and
- halting the processor.
- Note: NMIs can only be cleared by a system reboot. CBIOS supports NMI clearing by warm (<Ctrl> <Alt> <Del>) reboot or cold reboot (system reset button or power switch).

# Overview, Continued

# INT 02h vector

The CBIOS initializes the INT 02h vector to F000:E2C3h. The INT 02h vector resides at address 00:08h in the CBIOS Interrupt Vector Table.

#### In this chapter

This chapter describes the various NMI sources and tells how the CBIOS Nonmaskable Interrupt ISR handles them.

The following topics are presented:

- Nonmaskable Interrupt I/O Ports
- Parity Error NMI Handling
- Time-Out Error Handling
- 80X87 Coprocessor Exceptions

# Nonmaskable Interrupt I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0018h       | W                    | DMA extended function register, where:<br>Bits 7-4 = Progress command, where:<br>00h I/O address register<br>01h Reserved<br>02h Memory address register write<br>03h Memory address register write<br>03h Transfer count register write<br>05h Transfer count register write<br>05h Transfer count register read<br>06h Status register read<br>06h Status register read<br>07h Mode register<br>08h Arbus register set single bit<br>0Ah Mask register reset single bit<br>0Ah Mask register reset single bit<br>0Bh-0Ch Reserved<br>0Dh Master clear<br>0Eh-0Fh Reserved<br>Bits 3-0 = 0 Reserved |
| 0021h       | R/W                  | Interrupt controller 1 mask, where:Bit 7= 0 Enable parallel port 1 interruptBit 6= 0 Enable diskette interruptBit 5= 0 Enable fixed disk interruptBit 4= 0 Enable serial port 1 interruptBit 3= 0 Enable serial port 2 interruptBit 2= 0 Enable cascade interruptBit 1= 0 Enable keyboard interruptBit 0= 0 Enable timer channel 0                                                                                                                                                                                                                                                                   |
| 0047h       | W                    | Control word register for counter 3<br>Bits 7-6 = 00b Select counter 3<br>= 01b Reserved<br>= 10b Reserved<br>= 11b Reserved<br>Bits 5-4 = 00b Counter latch command select<br>counter 0<br>= 01b Read/write counter bits 0-7 only<br>= 10b Reserved<br>= 11b Reserved<br>Bits 3-0 = 00b                                                                                                                                                                                                                                                                                                             |
| 0061h       | R                    | System control port B, where:Bit 7= 1 Parity checkBit 6= 1 Channel checkBit 5= 1 Timer 2 outputBit 4= 1 Toggles with each refresh requestBit 3= 0 Channel check enabledBit 2= 0 Parity check enabledBit 1= 1 Speaker data enabledBit 0= 1 Timer 2 gate to speaker enabled                                                                                                                                                                                                                                                                                                                            |

| <b>INT 02</b> | i, Nonmaskable | Interrupt. | references | the | following I/O | ports: |
|---------------|----------------|------------|------------|-----|---------------|--------|
|---------------|----------------|------------|------------|-----|---------------|--------|

# Nonmaskable Interrupt I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                           |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0061h       | W                    | System control port B, where:<br>Bit 7 = 1 Reset timer 0 output latch (IRQ0)<br>Bits 6-4 = Reserved<br>Bit 3 = 0 Channel check enabled<br>Bit 2 = 0 Parity check enabled<br>Bit 1 = 1 Speaker data enabled<br>Bit 0 = 1 Timer 2 gate to speaker enabled                               |
| 0070h       | W                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0 = CMOS address                                                                                                                                                                         |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                           |
| 0090h       | W                    | Arbitration register, where:<br>Bit 7 = 1 Enable system microprocessor cycle<br>Bit 6 = 1 Arbitration mask<br>Bit 5 = 1 Enable extended arbitration<br>Bits 4-0 = 0 Reserved                                                                                                          |
| 0090h       | R                    | Arbitration register, where:<br>Bit 7 = 1 System microprocessor cycle enabled<br>Bit 6 = 1 Arbitration mask by NMI<br>Bit 5 = 1 Bus time-out<br>Bit 4 = 0 Reserved<br>Bits 3-0 = Arbitration level                                                                                    |
| 0092h       | R/W                  | System control port A, where:Bit 7= 1 Fixed disk activity light bit A onBit 6= 1 Fixed disk activity light bit B onBit 5= ReservedBit 4= 1 Watchdog time-out occurredBit 3= 1 Security lock latch lockedBit 2= ReservedBit 1= 1 Alternate gate A20 activeBit 0= 1 Alternate hot reset |
| 0096h       | R/W                  | Channel position select register, where:<br>Bit 7 = 1 Channel 1 reset<br>Bits 6-4 = Reserved (written as 0, read as 1)<br>Bit 3 = 1 Channel select<br>Bits 2-0 = 0 Channel number                                                                                                     |
| 0105h       | R/W                  | POS register 5 where:<br>Bit 7 = 0 Channel check condition occurred<br>= 1 Channel reset<br>Bit 6 = 0 Channel check exception status<br>available<br>= 1 No status available                                                                                                          |

### Introduction

Parity errors in system memory cause system hardware to activate the processor's NMI pin.

There are two types of memory parity errors:

- system board memory failure
- I/O board memory failure

### Parity error handling in the Phoenix CBIOS

The table below describes how parity errors are handled by the Phoenix CBIOS NMI service, and it suggests possible causes and solutions for each error type.

| Error<br>Code | Message                                 | Possible Cause                                                                                                                                                                                                                                                                    | Suggested Solution                                                                                    |
|---------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| 110           | Memory Parity Error<br>at <i>xxxxx</i>  | Memory is failing. If the<br>NMI handler can deter-<br>mine the address of the<br>failing memory, it will be<br>displayed in place of<br>xxxx. If the failing mem-<br>ory is not found, then the<br>message will read "Mem-<br>ory Parity Error ????".                            | Check the system board<br>and all installed devices<br>for proper operation.<br>Replace if necessary. |
| 111           | I/O Card Parity Error<br>at <i>xxxx</i> | The peripheral card has<br>failed. If the NMI handler<br>can determine the ad-<br>dress of the failing mem-<br>ory, it will be displayed in<br>place of <i>xxxxx</i> . If the fail-<br>ing memory is not found,<br>then the message will<br>read "I/O Card Parity<br>Error ????". | Check the system board<br>and all installed devices<br>for proper operation.<br>Replace if necessary. |

# Parity Error NMI Handling, Continued

# Parity error handling in IBM PS/2 systems

IBM PS/2 systems have a different set of error messages. The messages are followed by the segment address of the bad memory location or ????? if it cannot be found. These error codes and messages are listed in the following table.

| Error Code | Message                     |
|------------|-----------------------------|
| 110        | System Board Memory Failure |
| 111        | I/O Channel Check Activated |

Models 25 and 30: IBM PS/2 Models 25 and 30 (and compatibles) support memory parity error in the same way as other PS/2 systems but substitute the message PARITY CHECK1 for message 110 and PARITY CHECK2 for message 111.

### Introduction

Time-out errors cause the system hardware to set the processor's NMI pin. There are two kinds of NMI-related time-out errors:

- Watchdog time-out errors
- Direct Memory Access (DMA) bus time-out errors

### Watchdog time-out errors

The watchdog time-out function is enabled via INT 15h, AH = C3h, Watchdog Time-Out.

When enabled, the watchdog time-out function ensures that a program does not turn interrupts off for too long a period. It does this by "watching" for a missing timer interrupt IRQ 0. (Timer interrupts occur 1024 times per second.) Should a timer interrupt be missed, the watchdog time-out function generates an NMI.

#### DMA bus time-out errors

When a DMA driven device uses the bus longer that 7.8 microseconds, the Central Arbitration Control Point generates an NMI.

# Time-Out Error Handling, Continued

# Time-out and error handling in the Phoenix CBIOS

The table below describes how the CBIOS NMI ISR handles watchdog and DMA bus time-out errors and suggests possible causes and solutions for each error type.

| Error<br>Code | Message           | Possible Cause                                                                                                                                                                        | Suggested Solution                                                                                                                                                                                                                                            |
|---------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 112           | Watchdog Time-Out | The watchdog timer has<br>detected that the timer<br>0 interrupt has not been<br>serviced. A program or<br>device has probably<br>failed while interrupts<br>were off.                | Reboot the system. If<br>the problem persists,<br>check all installed de-<br>vices for proper opera-<br>tion. Replace if neces-<br>sary. If the problem still<br>occurs, examine all<br>programs for errors<br>which cause the inter-<br>rupts to remain off. |
| 113           | DMA Bus Time-Out  | A device has driven the<br>-BURST signal line for<br>more than 7.8 micro-<br>seconds, causing the<br>central arbiter device<br>(on the motherboard)<br>to generate a bus<br>time-out. | Check system board<br>and all installed devices<br>for proper operation.<br>Replace if necessary.                                                                                                                                                             |

# Time-out and error handling in IBM PS/2 systems

IBM PS/2 systems have a different set of time-out error messages. They are listed in the table below.

| Error Code | Message                                 |
|------------|-----------------------------------------|
| 112        | Watchdog Time-Out                       |
| 113        | Direct Memory Access (DMA) Bus Time-Out |

Models 25 and 30: Time-out error handling is not supported on IBM PS/2 Model 25 and 30 systems.

#### How CBIOS maintains compatibility

Unless it is revectored by a user program, the CBIOS INT 75h ISR is initialized to the same entry point as INT 02h. This insures that 8087 software running under CBIOS is given the opportunity to handle coprocessor exceptions by intercepting INT 02h.

#### 8087 coprocessor exceptions

Systems based on the Intel 8088 that incorporate the 8087 math coprocessor indicate math coprocessor exceptions by generating an NMI (i.e. INT 02h).

A coprocessor exception routine should be written to handle 8087 coprocessor exceptions by intercepting INT 02h. The coprocessor exception routine should determine if the NMI was generated by the 8087. If the NMI was not coprocessor-related, the routine should transfer control to the BIOS NMI ISR.

#### 80287/80387 coprocessor exceptions

Systems that incorporate the 80287 or 80387 math coprocessor indicate math coprocessor exceptions by setting IRQ 13. IRQ 13 invokes INT 75h, the CBIOS 80287/80387 Math Coprocessor Exception.

A software routine should be written to handle the coprocessor exceptions by intercepting INT 75h. The coprocessor exception routine determines if the NMI was generated by the coprocessor. If the NMI was not coprocessorrelated, this routine transfers control to the CBIOS NMI ISR.

# INT 75h vector

The CBIOS initializes the INT 75h vector to F000:E2C3h (i.e. the INT 02h entry point). The INT 75h vector resides at address 00:4Bh in the CBIOS Interrupt Vector Table.



# Chapter 8 INT 09h and INT 16h Keyboard Services

# Overview

# Introduction

The CBIOS contains two keyboard-related services:

# CBIOS keyboard hardware ISR

The CBIOS keyboard interrupt service routine (ISR) is invoked via hardware INT 09h each time a key is pressed. The CBIOS keyboard ISR translates System Scan Codes (provided by the 8042 keyboard controller at port 60h) into:

- Updates of the keyboard shift key and toggle key flags
- Requests for keyboard ISR internal functions (e.g. Break, Pause, Reset)
- Entries into the CBIOS keyboard buffer.

# CBIOS keyboard software DSR

The CBIOS keyboard device service routine (DSR) is invoked via software INT 16h. INT 16h is invoked by the operating system or by application programs running under the operating system. The CBIOS keyboard DSR contains functions that read the CBIOS keyboard buffer, write to the buffer, and return the status of the keyboard service flags.

continued

129

# Vector values

CBIOS initializes two vectors:

- INT 09h to point to ROM address F000:E987h, the IBM-compatible entry point. INT 09h resides at address 00:24h in the Interrupt Vector Table, and
- INT 16h to point to ROM address F000:E82Eh, the IBM-compatible entry point. INT 16h resides at address 00:58h in the Interrupt Vector Table.

# In this chapter

Because they are so closely interrelated, this chapter presents information on both INT 09h and INT 16h Keyboard Services. The following topics are discussed:

- Hardware Environment
- Keyboard-to-System Communication
- Keyboard I/O Ports
- System RAM Data
- INT 09h: Internal Function Requests
- INT 16h: Keyboard Services
- How to Read Character Code Tables
- Character Codes: AH = 00h/01h
- Character Codes: AH = 10h/11h

### Introduction

The ROM BIOS supports an intelligent keyboard subsystem based on the Intel 8042.

The hardware interrupt level associated with the CBIOS Keyboard Service is IRQ 1.

#### The 8042 controller chip

The Intel 8042 peripheral controller (or compatible) is a single-chip microcomputer that can be programmed to allow bidirectional communication between the master microprocessor and up to two auxiliary serial input devices. The 8042 chip, generally, is mounted on the system motherboard. 8042 programs reside as firmware in the 8042 chip itself.

#### **Device support**

The kind of devices a given 8042 chip supports are dependent on how the 8042 is programmed.

On IBM PS/2-compatible systems, the 8042 is programmed to allow bidirectional communication between the system and the keyboard, as well as between the system and one other auxiliary serial device, such as a mouse, joystick, or trackball.

# Reference

For more information on the 8042 keyboard controller, refer to Appendix B.



The diagram below shows how the keyboard communicates with the system.

# Keyboard-to-System Communication, Continued

### Step I.

8042 Keyboard Controller translates keyboard make or break scan codes into make or break System Scan Codes. 8042 System Scan Codes are the only codes the INT 09h keyboard service can interpret.

#### Step II.

INT 09h accepts the System Scan Codes placed at Port 60h by the 8042 Keyboard Controller and processes each code as follows:

- System Scan Codes which correspond to the keyboard shift or toggle keys (Shift, Alt, Ctrl, Caps Lock, Num Lock or, Scroll Lock) cause INT 09h to update the Shift/Toggle data variables located in segment 40h of system RAM.
- 2. System Scan Codes corresponding to nonshift/toggle keys are first compared to the Shift/Toggle state data to see if the shift or toggle of the Character Code corresponding to that key should be generated. For example, the Character Code for a shifted "A" key is different from the one for an unshifted "a" key. If no shift/toggle state data applies, then INT 09h generates the unshifted Character Code for that key. All Character Codes occupy one word and are placed by INT 09h into a 16-word keyboard buffer.
- Some combinations of Shift and Toggle keys (such as Ctrl/Break) and of Shift keys and nonshift keys (such as Ctrl/Alt/Del) are interpreted by INT 09h as a request for internal function services.

#### Step III.

When invoked by the operating system or by a software application, INT 16h acts on the contents of the 16-word keyboard Character Code buffer. If desired, character codes can be filtered for compatibility with application software that accepts only those character codes generated by 84-key keyboards.

| I/O Address | Read/Write<br>Status | Description      |
|-------------|----------------------|------------------|
| 0060h       | R/W                  | 8042 Data port   |
| 0064h       | R                    | 8042 Status port |

INT 09h and 16h Keyboard Services reference the following I/O ports:

# System RAM Data

# Introduction

Throughout the course of operation, the CBIOS keyboard services monitor and maintain several status and buffer-control data definitions.

# Keyboard data definitions

The keyboard data definitions, which are stored in segment 40h of the system RAM, are presented below in offset order.

| Location | Size   | Description                                                                                                                                                                                                                                                            |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17h      | 1 Byte | Keyboard shift flags, where:<br>Bit 7 = 1 Insert active<br>Bit 6 = 1 Caps Lock active<br>Bit 5 = 1 Num Lock active<br>Bit 4 = 1 Scroll Lock active<br>Bit 3 = 1 Alt pressed<br>Bit 2 = 1 Ctrl pressed<br>Bit 1 = 1 Left Shift pressed<br>Bit 0 = 1 Right Shift pressed |

# System RAM Data, Continued

# Keyboard data definitions, cont'd

| Location | Size     | Description                                                                                                                                                                                                                                                                                                                    |
|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18h      | 1 Byte   | More keyboard shift flags, where:<br>Bit 7 = 1 Insert pressed<br>Bit 6 = 1 Caps Lock pressed<br>Bit 5 = 1 Num Lock pressed<br>Bit 4 = 1 Scroll Lock pressed<br>Bit 3 = 1 Ctrl-Num Lock state active<br>Bit 2 = 1 Sys Req pressed<br>Bit 1 = 1 Left Alt pressed<br>Bit 0 = 1 Left Ctrl pressed                                  |
| 19h      | 1 Byte   | Work area for Alt key and numeric keypad input                                                                                                                                                                                                                                                                                 |
| 1Ah      | 1 Byte   | Offset to next character in keyboard buffer                                                                                                                                                                                                                                                                                    |
| 1Ch      | 1 Word   | Offset to first available spot in keyboard buffer                                                                                                                                                                                                                                                                              |
| 1Eh      | 16 Words | Keyboard buffer of 16 word entries<br>(a maximum of 15 are used at a time)                                                                                                                                                                                                                                                     |
| 71h      | 1 Byte   | Bit 7 = 1 If <ctrl> <break> pressed</break></ctrl>                                                                                                                                                                                                                                                                             |
| 72h      | 1 Word   | Set to 1234h if <ctrl> <alt> <del> is pressed</del></alt></ctrl>                                                                                                                                                                                                                                                               |
| 80h      | 1 Word   | Address to start of keyboard buffer (from seg-<br>ment 40h)                                                                                                                                                                                                                                                                    |
| 82h      | 1 Word   | Address to end of keyboard buffer (from segment 40h)                                                                                                                                                                                                                                                                           |
| 96h      | 1 Byte   | Status byte:<br>Bit 7 = 1 Read ID in progress<br>Bit 6 = 1 Last code was first ID<br>Bit 5 = 1 Forced Num Lock<br>Bit 4 = 1 101/102 keyboard used<br>Bit 3 = 1 Right Alt active<br>Bit 2 = 1 Right Alt active<br>Bit 1 = 1 Last code was E0h<br>Bit 0 = 1 Last code was E1h                                                    |
| 97h      | 1 Byte   | Status byte:<br>Bit 7 = Error flag for keyboard command<br>Bit 6 = LED update in progress<br>Bit 5 = RESEND received from keyboard<br>Bit 4 = ACK received from keyboard<br>Bit 3 = Reserved<br>Bit 2 = Current status of Caps Lock LED<br>Bit 1 = Current status of Num Lock LED<br>Bit 0 = Current status of Scroll Lock LED |

•

# **INT 09h: Internal Function Requests**

### Introduction

The CBIOS INT 09h ISR is programmed to interpret certain predefined key combinations as requests for internal functions.

The key or key combinations which the INT 09h ISR interprets as internal function calls are listed below:

- Ctrl> <Alt> <Del>: SYSTEM RESET
- <Ctrl> <Break> (<Ctrl> <Scroll Lock>): BREAK
- <Ctrl> <Num Lock>: PAUSE
- Shift> <Print Screen>: PRINT SCREEN
- SysReq>: SYSTEM REQUEST

# INT 09h: System Reset (<Ctrl> <Alt> <Del>)

# Description

The CBIOS INT 09h ISR recognizes the <Ctrl> <Alt> <Del> key combination as an internal request for the system RESET routine.

The INT 09h ISR invokes the RESET operation with a direct call to the ROM BIOS code location where the system RESET routine resides.

#### Input/Output

| Input:  | Keyboard Shift Flags byte (40:17h)<br>Bit 3 = 1 (Alt pressed)<br>Bit 2 = 1 (Ctrl pressed)<br>System Scan Code = 53h (Del pressed) |
|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| Output: | Reset Flag word (40:72h)<br>(1 Word) = 1234h<br>INT 09h initiates system RESET routine                                            |

The CBIOS INT 09h ISR recognizes the <Ctrl> <Break> key combination as an internal function request for INT 1Bh. <Break> and <Scroll Lock> are equivalent keys on many keyboards.

INT 1Bh DSR is simply a vector which points to a body of programmercreated or application-program-resident code intended for execution when the <Ctrl> <Break> key combination is received from the keyboard.

### Input/Output

| Input:  | Keyboard Shift Flags byte (40:17h):                                                |
|---------|------------------------------------------------------------------------------------|
|         | Bit 2 = 1 (Ctrl pressed)                                                           |
|         | System Scan Code = 46h (Break pressed)                                             |
| Output: | INT 09h invokes INT 1Bh, a vector address which points to a break routine, if any. |

# INT 09h: Pause (<Ctrl> <Num Lock>)

# Description

The CBIOS INT 09h ISR recognizes the <Ctrl> <Num Lock> key combination as an internal function request for the INT 09h controlled PAUSE state. On a 101-key keyboard, the <PAUSE> key causes the INT 09h ISR to initiate the Pause State.

When the INT 09h ISR puts the computer system into the Pause State, the INT 09h ISR Pause-State routine loops until a valid key or key combination is received from the keyboard.

#### Input/Output

| Input:  | Keyboard Shift Flags byte (40:17h)                                                                 |
|---------|----------------------------------------------------------------------------------------------------|
|         | Bit 2 = 1 (Ctrl pressed)                                                                           |
|         | Keyboard Shift Flags byte 2 (40:18h)                                                               |
|         | Bit 5 = 1 (Num Lock pressed)                                                                       |
|         | Bit 3 = 1 (Ctrl/Num Lock in active state: suspend toggles)                                         |
|         | System Scan Code = 45h (Num Lock pressed)                                                          |
| Output: | INT 09h loops PAUSE routine until a valid key or key combination is received from 8042 controller. |

#### **Ending PAUSE state**

To end Pause State, Bit 3 of Keyboard Shift Flags byte 2 (40:18h) must be reset to 0.

The INT 09h ISR resets Bit 3 of Keyboard Shift Flags byte 2 to zero as soon as it receives:

- 1. The make System Scan Code for any non-shift key except the SYS REQ key, or
- 2. Any valid shift/toggle key combination.

The valid shift/toggle key combinations needed to reset Bit 3 of Keyboard Shift Flags Byte 2 to zero are shown on the following page.

# PAUSE state table

The table below outlines the behavior of the various shift/toggle key combinations during the INT 09h ISR pause state. The key combinations necessary to reset Bit 3 of Keyboard Shift Flags Byte 2 to zero (i.e. end Pause State) are in category #1.

| Shift Keys                 | ** Toggle Keys ** |           |          |    |  |  |  |  |  |  |  |  |
|----------------------------|-------------------|-----------|----------|----|--|--|--|--|--|--|--|--|
|                            | Ins               | Caps Lock | Num Lock |    |  |  |  |  |  |  |  |  |
| None<br>Shift (L or R)     | 2.                |           | 3.       |    |  |  |  |  |  |  |  |  |
| Alt<br>Alt/Shift           | 2.                | 3.        |          |    |  |  |  |  |  |  |  |  |
| Ctrl<br>Ctrl/Shift         |                   | 1.        |          | 4. |  |  |  |  |  |  |  |  |
| Alt/Ctrl<br>Alt/Ctrl/Shift | ]                 |           | Γ        | 5. |  |  |  |  |  |  |  |  |

### LEGEND

- 1. PAUSE STATE IS ENDED (Bit 3 of Keyboard Shift Flags Byte 2 is reset). The scan codes normally associated with these keys do not have their usual effect on the shift and toggle flags. They are interpreted instead as a request to reset Bit 3 of Keyboard Shift Flags Byte 2 to zero, thus ending the Pause State.
- PAUSE STATE IS NOT ENDED. The 8042 controller chip places the System Scan Code for (Ins) or (Shift Ins) into its internal buffer. The INT 09h ISR will act on these codes once Pause State is ended.
- 3. PAUSE STATE IS NOT ENDED. These key combinations are treated as valid requests to change Shift/Toggle states or update LEDs.
- PAUSE STATE IS NOT ENDED. The keys which initiate the Pause State can not be used to end Pause State. When in Pause State, these keys are ignored.
- 5. PAUSE STATE IS NOT ENDED. When in Pause State, these keys are ignored.

The CBIOS INT 09h ISR invokes INT 05h (the CBIOS Print Screen service) whenever it receives the combination of System Make Scan Codes corresponding to the left or the right Shift key and the Print Screen key.

The System Make Scan Codes necessary to cause INT 09h to invoke INT 05h can be generated in either of the ways listed below:

- 1. By pressing the Print Screen key alone, or
- 2. By pressing either of the Shift keys and the Print Screen key.

# input/Output

Input Case #1: <PrtSc> key only Input Case #2: <Shift> <PrtSc> keys System Scan Codes = E0h, 2Ah, E0h, 37h (Left Shift and Print Screen both depressed) Keyboard Shift Flags Byte (40:17h) Bit 1 = 1 (Left Shift pressed) or Bit 0 = 2 (Right Shift pressed) System Scan Codes = E0h, 37h Output for both Case #1 and Case #2:

INT 09h invokes INT 05h BIOS Print Screen Service

The CBIOS INT 09h ISR interprets the System Request key in either of two ways:

- When the System Request key is depressed, INT 09h interprets the resulting System Scan Code as an internal function request for INT 15h: function AH = 85h, subfunction AL 00h — Process System Request.
- When the System Request key is released, INT 09h interprets the resulting System Scan Code as an internal request for INT 15h, function AH = 85h, subfunction AL = 01h — Terminate System Request.

# Process SysReq input/output

The inputs and outputs that result when the System Request key is pressed are listed below:

| Input:  | Keyboard Shift Flags Byte 2 (40:18h)           |
|---------|------------------------------------------------|
|         | Bit 2 = 1 (System Request pressed)             |
| Output: | AH = 85h                                       |
|         | AL = 00h                                       |
|         | INT 09h invokes INT 15h Process System Request |

# Terminate SysReq input/output

The inputs and outputs that result when the System Request key is released are listed below:

| Input:  | - | ard Shift Flags Byte 2 (40:18h)<br>= 0 (System Request key released) |
|---------|---|----------------------------------------------------------------------|
| Output: |   | = 85h<br>= 01h INT 09h invokes INT 15h Terminate System Request      |

# **INT 16h: Keyboard Services**

# Introduction

The CBIOS keyboard services are invoked via software interrupt INT 16h. Individual function codes are selected via the AH register.

# Summary of INT 16h functions

A table of INT 16h AH register values and their corresponding function is shown below.

| Function | Description                        |
|----------|------------------------------------|
| 00h      | Read Keyboard Input                |
| 01h      | Return Keyboard Status             |
| 02h      | Return Shift Flag Status           |
| 03h      | Set Typematic Rate and Delay       |
| 04h      | Reserved                           |
| . 05h    | Store Key Data                     |
| 06h-09h  | Reserved                           |
| 10h      | Read Extended Key Input            |
| 11h      | Return Extended Keyboard Status    |
| 12h      | Return Extended Shift Flags Status |
| 13h-FFh  | Reserved                           |

The Read Keyboard Input function executes as follows:

- If a character code is available in the keyboard buffer, this function reads the character code and returns its value in AX.
- If the keyboard buffer is empty, this function suspends program execution until a character code is inserted into the buffer.
- If the keyboard LEDs do not match the current flag settings, this function updates the LEDs.

#### Input/Output

| Input:  | AH | = | 00h                                             |
|---------|----|---|-------------------------------------------------|
| Output: | AH | = | Scan code or character ID for special character |
|         | AL | = | ASCII code or other translation of character.   |

### 84-key "filtering"

The read keyboard input function acts as an 84-key keyboard filter, selectively editing the buffer contents for 84-key keyboard compatibility.

When a 101-key keyboard is in place, INT 16h function AH = 00h:

- Returns all standard 84-key keyboard Character Codes as is,
- Adjusts 101-key keyboard duplicates of 84-key keyboard characters so that they take on the same two-byte key code as their 84-key counterparts, and
- Destroys any 101-key Character Codes not compatible with the 84-key keyboard.

**Note:** The data table labeled "Character Codes: AH = 00h/01h" lists the codes returned when using INT 16h AH = 00h and AH = 01h.

# Reference

Function AH = 10h Read Extended Keyboard Input does not modify character codes for 84-key keyboard compatibility. For further details, see the Function: AH = 10h heading in this chapter.

This function is useful for allowing programs to check for keyboard input while continuing to run if there is none. It executes as follows:

- Checks to see if a two-byte character code is available in the keyboard buffer.
- If a key is waiting, a copy of the key is returned. The buffer is not incremented to the next key.
- If the keyboard buffer contains at least one key, the Zero Flag is cleared.
- If the keyboard buffer does not contain a key, the Zero Flag is set.
- If the keyboard LEDs do not match the current flag settings, this function updates the LEDs.

### Input/Output

| Input:  | AH |   | 01h                                             |
|---------|----|---|-------------------------------------------------|
| Output: |    |   | Scan code or character ID for special character |
|         | AL | = | ASCII code or other translation of character.   |
|         | ZF | = | 0 Character is ready                            |
|         |    |   | 1 No character is available                     |

# 84-key "filtering"

The read keyboard input function acts as an 84-key keyboard filter, selectively editing the buffer contents for 84-key keyboard compatibility.

When a 101-key keyboard is in place, INT 16h function AH = 01h:

- Returns all standard 84-key keyboard Character Codes as is,
- Adjusts 101-key keyboard duplicates of 84-key keyboard characters so that they take on the same two-byte key code as their 84-key counterparts, and
- Destroys any 101-key Character Codes not compatible with the 84-key keyboard.

**Note:** The data table labeled "Character Codes: AH = 00h/01h" lists the codes returned when using INT 16h AH = 00h and AH = 01h.

# Reference

Function AH = 11h Return Extended Keyboard Input does not modify character codes for 84-key keyboard compatibility. For further details, see the Function: AH = 11h heading in this chapter.

# INT 16h: AH = 02h Return Shift Flag Status

# Description

The Return Shift Flag Status function returns the current shift status from the Keyboard Shift Flags byte (40:17h). The LED status is not updated.

# Input/Output

Input: AH = 02h Output: AL = Current shift status, where: Bit 7 = 1 Insert active Bit 6 = 1 Caps Lock active Bit 5 = 1 Num Lock active Bit 4 = 1 Scroll Lock active Bit 3 = 1 Alt pressed Bit 2 = 1 Ctrl pressed Bit 1 = 1 Left Shift pressed Bit 0 = 1 Right Shift pressed

# Int 16: AH = 03h Set Typematic Rate and Delay

# Description

The Set Typematic Rate and Delay function changes the typematic rate (make code per second) and the delay.

# Input/Output

If the parameters are valid, the function transmits a Set Rate command (F3h) to the keyboard controller.

| Input:  | AH   | = | 03h                        |
|---------|------|---|----------------------------|
|         | AL   | = | 05h                        |
|         | BH   | = | Delay (00h - 03h)          |
|         | BL   | = | Typematic rate (00h - 1Fh) |
| Output: | None |   |                            |

# INT 16h: AH = 04h Reserved

The Store Key Data function stores program-generated data into the keyboard buffer just as if a key were pressed. The buffer pointer (40:1Ch) is adjusted to point to the next available location in the keyboard buffer.

If the keyboard buffer is full, AL is set to indicate a keyboard buffer full error.

#### Input/Output

| Input:  | AH | = | 05h                      |
|---------|----|---|--------------------------|
|         | СН | = | Scan code                |
|         | CL | = | ASCII character          |
| Output: | AL | = | 00h No error             |
|         |    | = | 01h Keyboard buffer full |
|         |    |   |                          |

**Note:** Keyboard enhancers and other utilities can use this function to interpolate keys into the data stream viewed by applications programs.

# INT 16h: AH = 06h - 09h Reserved

# INT 16h: AH = 10h Read Extended Keyboard Input

#### Description

The Read Extended Keyboard Input function reads the next two-byte character code in the keyboard buffer and returns the value in AX. It is designed for use with the 101/102-key keyboard. Unlike function AH = 00h, this function does not modify character codes for 84-key keyboard compatibility.

#### Input/Output

Input: AH = 10h
 Output: AH = Scan code or character ID for special character AL = ASCII code or other translation of character
 Note: The character codes returned by this function are found in the table "Character Codes: AH = 10h/11h" in this chapter.

### F0h low byte filter

INT 09h places the value F0h in the low byte character code position for some Alt/character key combinations. The Return Extended Keyboard Input function strips F0h from the keyboard buffer image before returning to the caller. Keys with F0h are returned to AX with their low order byte set to 00h.

All other keys are returned to AX unmodified by this function.

# Reference

Function AH = 00h Read Keyboard Input selectively filters keyboard buffer input for compatibility with 84-key keyboards. For details, see the Function: AH = 00h heading in this chapter.

This function is similar to function AH = 01h, except that it returns unique scan codes for all keys on the 101/102-key keyboard. It executes as follows:

- Checks to see if a character code is available in the keyboard buffer.
- If a key is waiting, a copy of the character code is returned in AX. The buffer is not incremented to the next key.
- If the keyboard buffer contains at least one key, the Zero Flag is cleared.
- If the keyboard buffer does not contain a key, the Zero Flag is set.
- If the keyboard LEDs do not match the current flag settings, this function updates the LEDs.

# Input/Output

| Input:  | AH | = | 11h                                                               |
|---------|----|---|-------------------------------------------------------------------|
| Output: | AH | = | Scan code or character ID for special character<br>(if ZF is set) |
|         | AL | = | ASCII code or other translation of character ID (ZF is set)       |
|         | ZF | = | 0 No key in buffer                                                |
|         |    | = | 1 Key waiting                                                     |

#### F0h low byte filter

INT 09h places the value F0h in the low byte character code position of some Alt/character combinations. The Return Extended Keyboard Status function strips F0h from the keyboard buffer image before returning to the caller. Keys with F0h are returned to AX with their low order byte set to 00h.

All other keys are returned to AX unmodified by this function.

**Note:** The character codes returned by this function are found in the table "Character Codes: AH = 10h/11h" in this chapter.

# Reference

Function AH = 01h Read Keyboard Status selectively filters keyboard buffer input for compatibility with 84-key keyboards. For details, see "Function: AH = 01h" in this chapter.

# INT 16h: AH = 12 Return Extended Shift Flags Status

# Description

This function is similar to function AH = 02h, except that it returns information on the shift keys provided on the 101/102-key keyboard. It also returns an additional byte of flags in the AH register.

The Return Extended Shift Flags Status function returns the shift flag status from Keyboard Shift Flags Byte (40:17) in the AL register, and returns the shift flag status from Keyboard Shift Flags Byte 2 (40:18) and 101-key Keyboard Status Byte (40:96) in the AH register.

# Input/Output

| Input:  | AH | = | 12h                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | АН | = | More keyboard shift flags, where:<br>Bit 7 = 1 Sys Req pressed (40:18h Bit 2)<br>Bit 6 = 1 Caps Lock active (40:18h Bit 6)<br>Bit 5 = 1 Num Lock active (40:18h Bit 5)<br>Bit 4 = 1 Scroll Lock active (40:18h Bit 4)<br>Bit 3 = 1 Right Alt active (40:96h Bit 3)<br>Bit 2 = 1 Right Ctrl active (40:96h Bit 2)<br>Bit 1 = 1 Left Alt active (40:18h Bit 1)<br>Bit 0 = 1 Left Ctrl active (40:18h Bit 0) |
|         | AL | = | Keyboard shift flags (copy of Keyboard Shift Flags Byte<br>40:17), where:<br>Bit 7 = 1 Insert active<br>Bit 6 = 1 Caps Lock active<br>Bit 5 = 1 Num Lock active<br>Bit 4 = 1 Scroll Lock active<br>Bit 3 = 1 Alt pressed<br>Bit 2 = 1 Ctrl pressed<br>Bit 1 = 1 Left Shift pressed<br>Bit 0 = 1 Right Shift pressed                                                                                       |

# INT 16h: AH = 13 - FFh Reserved

### Introduction

The tables on the following pages present data related to the IBM PS/2-compatible keyboard.

There are two character-code tables. They are labeled:

- Character Codes: AH = 00h/01h
- Character Codes: AH = 10h/11h

#### How to read the tables

- The data presented in each table is listed according to key number. These key numbers serve as a legend for identifying the keys. They have no relationship to Keyboard Scan Codes, System Scan Codes, or to Character Codes. See the keyboard layout figure on the next page for a map of these key numbers.
- The tables list Keyboard Scan and System Scan Codes by make code only. Break codes are found by adding a value of 80h to the make code in question.
- The two-byte number associated with each Character Code is listed in four-digit hex notation. The high order byte, which is placed by INT 16h into the AH register, is listed first. The low order byte, which is placed by INT 16h into the AL register, is listed second. The two bytes are separated with a slash. For example, the Character Code for the unshifted "n" key is listed on the table as 31/6E.
- Caps Lock plus any typewriter key yields the same character code as Shift plus any typewriter key.
- Num Lock plus any numeric keypad key yields the same character code as Shift plus any numeric keypad key.
- Alt plus the decimal value for an ASCII character input from the numeric keypad yields the ASCII character. Allowable values are 0 to 255. These instances are noted with "\*\*" in the Alt column.

# How to Read Character Code Tables, Continued

# Keyboard layout

The figure below depicts the key arrangement and key number system applied to the typical 101-key keyboard.

| Esc               | F1               | F     | 2      | F3      | F4  |        | Ľ       | F5  | F6     | Ι      | F7  | F8     |              | [        | F9  | F          | 10 | F1     | 1 F12     | PS | rint<br>creen | Scroll<br>Lock | Pause        | ] |             |               |           |         |
|-------------------|------------------|-------|--------|---------|-----|--------|---------|-----|--------|--------|-----|--------|--------------|----------|-----|------------|----|--------|-----------|----|---------------|----------------|--------------|---|-------------|---------------|-----------|---------|
| 7                 | 2                | 2     | #<br>3 | \$<br>4 | T   | %<br>5 | ê<br>6  | T   | &<br>7 | •<br>8 | Ι   | (<br>9 | }            | Τ        | =   | . +<br>. = | Ţ  | •<br>• | Backspace |    | Insert        | Home           | Page<br>Up   | ] | Num<br>Lock | 1             | •         | -       |
| <sup>Tab</sup> +→ | ٩                | W.    | F      |         | R   | Γ      |         | Y   | Ľ      | Ι      | 1   | C      | <sup>^</sup> | Р        | I   | {          | }  | l      | Į         |    | Delete        | End            | Page<br>Down | ] | 7<br>Home   | 8<br><b>▲</b> | 9<br>PgUp |         |
| Enter             | Ľ                | المر. | s      | D       |     | F      | G       |     | н      | J      |     | ĸ      | L            |          | :   | Ľ          |    | 4      | Enter     |    |               |                |              |   | 4<br>♣      | 5             | 6<br>➡    | .+      |
| Shift             | - <del>(</del> ) | Z     | Ľ      | Ц       | с   | Ľ      | <u></u> | в   | N      |        | м   | ,      |              | <u>.</u> |     | ?          | ¢  | Т      | Shift     | r  |               | 1              |              | 1 | 1<br>End    | 2<br>★        | 3<br>PgDn | ''Enter |
| Ctrl              |                  | Alt   |        |         |     |        |         |     |        |        |     |        |              |          |     | Alt        |    |        | Ctrl      |    | ←             | Ŧ              | ->           |   | 0<br>Ins    |               | ,<br>Del  |         |
| 110               | 112              | 11    | 3      | 114     | 115 | 5      | Ľ       | 116 | 117    | Ι      | 118 | 119    | ·            | [        | 120 | <b>I</b> 1 | 21 | 12:    | 2 123     | [  | 124           | 125            | 126          | ] | -           |               |           |         |
| 1                 | 2                | 3     | 4      | 5       | Ι   | 6      | 7       | Ι   | 8      | 9      | Ι   | 10     | 11           | Ι        | 12  | 1          | 3  |        | 15        |    | 75            | 80             | 85           |   | 90          | 95            | 100       | 105     |
| 16                | . 17             | 18    | L      | 19      | 20  | 2      | 21      | 22  | 2      | 3      | 24  | 2      | :5           | 26       |     | 27         | 28 |        | 29        |    | 76            | 81             | 86           |   | 91          | 96            | . 101     | 106     |
| 30                | 3                | 31    | 32     | 33      |     | 34     | 35      |     | 36     | 37     |     | 38     | 39           |          | 40  | L          | 1  |        | 42        |    | ,             |                | 1            |   | 92          | 97            | 102       |         |
| 44                | _                | 46    | Ľ      | 7       | 48  | 4      | 9       | 50  | L      | 51     | 52  | 5      | 3            | 54       |     | 55         |    | 7      | 57        | r  |               | 83             |              | 1 | 93          | 98            | 103       | ··· 108 |
| 59                |                  | 6     | 0      |         |     |        |         |     | 61     |        |     |        |              |          | 6   | 2          |    |        | 64        |    | 79            | 84             | 89           |   | 9           | 9             | 104       |         |

### Introduction

The read keyboard input function acts as an 84-key keyboard filter, selectively editing the buffer contents for 84-key keyboard compatibility.

When a 101-key keyboard is in place, INT 16h subservice AH = 00h:

- Returns all standard 84-key keyboard Character Codes "as is,"
- Adjusts 101-key keyboard duplicates of 84-key keyboard characters so that they take on the same two-byte key code as their 84-key counterparts, and
- Destroys any 101-key Character Codes not compatible with the 84-key keyboard.

# Table: AH = 00h/01h

The table below lists the character codes returned by functions AH = 00h and AH = 01h.

|       | U.S.               | Make Codes (hex) |        | Character Codes AH/AL (hex) |         |         |       |
|-------|--------------------|------------------|--------|-----------------------------|---------|---------|-------|
| Key # | Keyboard<br>Legend | Keyboard         | System | Normal                      | Shifted | Control | Alt   |
| 1     | '~                 | 0E               | 29     | 29/60                       | 29/7E   |         |       |
| 2     | 1!                 | 16               | 02     | 02/31                       | 02/21   |         | 78/00 |
| 3     | 2@                 | 1E               | 03     | 03/32                       | 03/40   | 03/00   | 79/00 |
| 4     | 3#                 | 26               | 04     | 04/33                       | 04/23   |         | 7A/00 |
| 5     | 4\$                | 25               | 05     | 05/34                       | 05/24   |         | 7B/00 |
| 6     | 5%                 | 2E               | 06     | 06/35                       | 06/25   |         | 7C/00 |
| 7     | 6                  | 36               | 07     | 07/36                       | 07/5E   | 07/1E   | 7D/00 |
| 8     | 7&                 | 3D               | 08     | 08/37                       | 08/26   |         | 7E/00 |
| 9     | 8*                 | 3E               | 09     | 09/38                       | 09/2A   |         | 7F/00 |
| 10    | 9(                 | 46               | 0A     | 0A/39                       | 0A/28   |         | 80/00 |
| 11    | 0)                 | 45               | 0B     | 0B/30                       | 0B/29   |         | 81/00 |
| 12    |                    | 4E               | 0C     | 0C/2D                       | 0C/5F   | 0C/1F   | 82/00 |
| 13    | =+                 | 55               | 0D     | 0D/3D                       | 0D/2B   |         | 83/00 |
| 15    | Backspace          | 66               | 0E     | 0E/08                       | 0E/08   | 0E/7F   |       |
| 16    | Tab                | 0D               | 0F     | 0F/09                       | 0F/00   | T       |       |

| Table: | AH = | 00h/01h, | cont'd |
|--------|------|----------|--------|
|--------|------|----------|--------|

| Key # | U.S.<br>Keyboard<br>Legend | Make Codes (hex) |        | Character Codes AH/AL (hex) |         |         |       |
|-------|----------------------------|------------------|--------|-----------------------------|---------|---------|-------|
|       |                            | Keyboard         | System | Normal                      | Shifted | Control | Alt   |
| 17    | Q                          | 15               | 10     | 10/71                       | 10/51   | 10/11   | 10/00 |
| 18    | w                          | 1D               | 11     | 11/77                       | 11/57   | 11/17   | 11/00 |
| 19    | Е                          | 24               | 12     | 12/65                       | 12/45   | 12/05   | 12/00 |
| 20    | R                          | 2D               | 13     | 13/72                       | 13/52   | 13/12   | 13/00 |
| 21    | т                          | 2C               | 14     | 14/74                       | 14/54   | 14/14   | 14/00 |
| 22    | Y                          | 35               | 15     | 15/79                       | 15/59   | 15/19   | 15/00 |
| 23    | U                          | 3C               | 16     | 16/75                       | 16/55   | 16/15   | 16/00 |
| 24    | I                          | 43               | 17     | 17/69                       | 17/49   | 17/09   | 17/00 |
| 25    | 0                          | 44               | 18     | 18/6F                       | 18/4F   | 18/0F   | 18/00 |
| 26    | Р                          | 4D               | 19     | 19/70                       | 19/50   | 19/10   | 19/00 |
| 27    | [{                         | 54               | 1A     | 1A/5B                       | 1A/7B   | 1A/1B   |       |
| 28    | 1}                         | 5B               | 1B     | 1B/5D                       | 1B/7D   | 1B/1D   |       |
| 29    | (101-key<br>only)          | 5D               | 2B     | 2B/5C                       | 2B/7C   | 2B/1C   |       |
| 30    | Caps Lock                  | 58               | 3A     |                             |         |         |       |
| 31    | A                          | 1C               | 1E     | 1E/61                       | 1E/41   | 1E/01   | 1E/00 |
| 32    | S                          | 1B               | 1F     | 1F/73                       | 1F/53   | 1F/13   | 1F/00 |
| 33    | D                          | 23               | 20     | 20/64                       | 20/44   | 20/04   | 20/00 |
| 34    | F                          | 2B               | 21     | 21/66                       | 21/46   | 21/06   | 21/00 |
| 35    | G                          | 34               | 22     | 22/67                       | 22/47   | 22/07   | 22/00 |
| 36    | н                          | 33               | 23     | 23/68                       | 23/48   | 23/08   | 23/00 |
| 37    | J                          | 3B               | 24     | 24/6A                       | 24/4A   | 24/0A   | 24/00 |
| 38    | к                          | 42               | 25     | 25/6B                       | 25/4B   | 25/0B   | 25/00 |
| 39    | L                          | 4B               | 26     | 26/6C                       | 26/4C   | 26/0C   | 26/00 |
| 40    | ;:                         | 4C               | 27     | 27/3B                       | 27/3A   |         |       |
| 41    | , ,                        | 52               | 28     | 28/27                       | 28/22   |         |       |
| 42    | (102-key<br>only)          | 5D               | 2B     | 2B/5C                       | 2B/7C   | 2B/1C   |       |
| 43    | Enter                      | 5A               | 1C     | 1C/0D                       | 1C/0D   | 1C/0A   |       |

| Key # | U.S.<br>Keyboard<br>Legend | Make Codes (hex) |        | Character Codes AH/AL (hex) |         |         |       |
|-------|----------------------------|------------------|--------|-----------------------------|---------|---------|-------|
|       |                            | Keyboard         | System | Normal                      | Shifted | Control | Alt   |
| 44    | L Shift                    | 12               | 2A     |                             |         |         |       |
| 45    | (102-Key<br>only)          | 61               | 56     |                             |         |         |       |
| 46    | Z                          | 1A               | 2C     | 2C/7A                       | 2C/5A   | 2C/1A   | 2C/00 |
| 47    | х                          | 22               | 2D     | 2D/78                       | 2D/58   | 2D/18   | 2D/00 |
| 48    | С                          | 21               | 2E     | 2E/63                       | 2E/43   | 2E/03   | 2E/00 |
| 49    | V                          | 2A               | 2F     | 2F/76                       | 2F/56   | 2F/16   | 2F/00 |
| 50    | В                          | 32               | 30     | 30/62                       | 30/42   | 30/02   | 30/00 |
| 51    | N                          | 31               | 31     | 31/6E                       | 31/4E   | 31/0E   | 31/00 |
| 52    | м                          | 3A               | 32     | 32/6D                       | 32/4D   | 32/0D   | 32/00 |
| 53    | , <                        | 41               | 33     | 33/2C                       | 33/3C   |         |       |
| 54    | . >                        | 49               | 34     | 34/2E                       | 34/3E   |         |       |
| 55    | /?                         | 4A               | 35     | 35/2F                       | 35/3F   |         |       |
| 57    | R Shift                    | 59               | 36     |                             |         |         |       |
| 58    | L Ctrl                     | 14               | 1D     |                             |         |         |       |
| 60    | L Alt                      | 11               | 38     |                             |         |         |       |
| 61    | Space                      | 29               | 39     | 39/20                       | 39/20   | 39/20   | 39/20 |
| 62    | R Alt                      | E0-11            | E0-38  |                             |         |         |       |
| 64    | R Ctrl                     | E0-14            | E0-1D  |                             |         |         |       |
| 75    | Insert                     | E0-70            | E0-52  | 52/00                       | 52/00   |         |       |
| 76    | Delete                     | E0-71            | E0-53  | 53/00                       | 53/00   |         |       |
| 79    | Left                       | E0-6B            | E0-4B  | 4B/00                       | 4B/00   | 73/00   |       |
| 80    | Home                       | E0-6C            | E0-47  | 47/00                       | 47/00   | 77/00   |       |
| 81    | End                        | E0-69            | E0-4F  | 4F/00                       | 4F/00   | 75/00   |       |
| 83    | Up                         | E0-75            | E0-48  | 48/00                       | 48/00   |         |       |
| 84    | Down                       | E0-72            | E0-50  | 50/00                       | 50/00   |         |       |
| 85    | Page Up                    | E0-7D            | E0-49  | 49/00                       | 49/00   | 84/00   | 1     |
| 86    | Page Down                  | E0-7A            | E0-51  | 51/00                       | 51/00   | 76/00   |       |

# Table: AH = 00h/01h, cont'd

| Table: | AH = | 00h/01h, | cont'd |
|--------|------|----------|--------|
|--------|------|----------|--------|

|       |                    | Make Coo | Make Codes (hex) |        | Character Codes AH/AL (hex) |         |       |
|-------|--------------------|----------|------------------|--------|-----------------------------|---------|-------|
| Key # | Keyboard<br>Legend | Keyboard | System           | Normal | Shifted                     | Control | Alt   |
| 89    | Right              | E0-74    | E0-4D            | 4D/00  | 4D/00                       | 74/00   |       |
| 90    | Num Lock           | 77       | 45               |        |                             |         |       |
| 91    | 7 Home             | 6C       | 47               | 47/00  | 47/37                       | 77/00   | **    |
| 92    | 4 Left             | 6B       | 4B               | 4B/00  | 47/34                       | 73/00   | **    |
| 93    | 1 End              | 69       | 4F               | 4F/00  | 47/31                       | 75/00   | **    |
| 95    | 1                  | E0-4A    | E0-35            | 35/2F  | 35/2F                       |         |       |
| 96    | 8 UP               | 75       | 48               | 48/00  | 58/38                       |         | **    |
| 97    | 5                  | 73       | 4C               | 4C/00  | 4C/35                       |         | **    |
| 98    | 2 Down             | 72       | 50               | 50/00  | 50/32                       | 91/00   | **    |
| 99    | 0 Ins              | 70       | 52               | 52/00  | 52/30                       |         |       |
| 100   | *                  | 7C       | 37               | 37/2A  | 37/2A                       |         |       |
| 101   | 9 PgUp             | 7D       | 49               | 49/00  | 49/39                       | 84/00   | **    |
| 102   | 6 Right            | 74       | 4D               | 4D/00  | 4D/36                       | 74/00   | **    |
| 103   | 3 PgDn             | 7A       | 51               | 51/00  | 51/33                       | 76/00   | **    |
| 104   | . Del              | 71       | 53               | 53/00  | 53/2E                       |         |       |
| 105   | -                  | 7B       | 4A               | 4A/2D  | 4A/2D                       |         |       |
| 106   | +                  | 79       | 4E               | 4E/2B  | 4E/2B                       |         |       |
| 108   | Enter              | E0-5A    | E0-1C            | 0D/1C  | 0D/1C                       | 0A/1C   |       |
| 110   | Esc                | 16       | 01               | 01/1B  | 01/1B                       | 01/1B   | [     |
| 112   | F1                 | 05       | 3B               | 3B/00  | 54/00                       | 5E/00   | 68/00 |
| 113   | F2                 | 06       | 3C               | 3C/00  | 55/00                       | 5F/00   | 69/00 |
| 114   | F3                 | 04       | 3D               | 3D/00  | 56/00                       | 60/00   | 6A/00 |
| 115   | F4                 | 0C       | 3E               | 3E/00  | 57/00                       | 61/00   | 6B/00 |
| 116   | F5                 | 03       | 3F               | 3F/00  | 58/00                       | 62/00   | 6C/00 |
| 117   | F6                 | 0B       | 40               | 40/00  | 59/00                       | 63/00   | 6D/00 |
| 118   | F7                 | 83       | 41               | 41/00  | 5A/00                       | 64/00   | 6E/00 |
| 119   | F8                 | 0A       | 42               | 42/00  | 5B/00                       | 65/00   | 6F/00 |

|       | U.S.               | Make Coo                            | les (hex)                | Char   | acter Codes | s AH/AL (h | ex)   |
|-------|--------------------|-------------------------------------|--------------------------|--------|-------------|------------|-------|
| Key # | Keyboard<br>Legend | Keyboard                            | System                   | Normal | Shifted     | Control    | Alt   |
| 120   | F9                 | 01                                  | 43                       | 43/00  | 5C/00       | 66/00      | 70/00 |
| 121   | F10                | 09                                  | 44                       | 44/00  | 5D/00       | 67/00      | 71/00 |
| 122   | F11                | 78                                  | 57                       |        |             |            |       |
| 123   | F12                | 07                                  | 58                       |        |             |            |       |
| 124   | Print<br>Screen    | E0-12/<br>E0-7C                     | E0-2A/<br>E0-37<br>E0-37 |        |             |            |       |
| 125   | Scroll Lock        | 7E                                  | 46                       |        |             |            |       |
| 126   | Pause              | E1-14/<br>77-E1/<br>F0-14/<br>F0-77 | E1-1D/<br>5-E1/<br>9D/C5 |        |             |            |       |

# Character Codes: AH = 10h/11h

#### Introduction

INT 09h places the value F0h in the low byte character code position for some Alt/character key combinations. The Return Extended Keyboard Input function strips F0h from the keyboard buffer image before returning to the caller. Keys with F0h are returned to AX with their low-order byte set to 00h.

All other keys are returned to AX unmodified by this function.

#### Table: AH = 10h/11h

The table below lists the character codes returned by functions AH = 10h and AH = 11h.

|       | U.S.               | Make Coo | Make Codes (hex) |        | Character Codes AH/AL (hex) |         |       |
|-------|--------------------|----------|------------------|--------|-----------------------------|---------|-------|
| Key # | Keyboard<br>Legend | Keyboard | System           | Normal | Shifted                     | Control | Alt   |
| 1     | '~                 | 0E       | 29               | 29/60  | 29/7E                       |         |       |
| 2     | 1!                 | 16       | 02               | 02/31  | 02/21                       |         | 78/00 |
| 3     | 2@                 | 1E       | 03               | 03/32  | 03/40                       | 03/00   | 79/00 |
| 4     | 3#                 | 26       | 04               | 04/33  | 04/23                       |         | 7A/00 |
| 5     | 4\$                | 25       | 05               | 05/34  | 05/24                       |         | 7B/00 |
| 6     | 5%                 | 2E       | 06               | 06/35  | 06/25                       |         | 7C/00 |
| 7     | 6                  | 36       | 07               | 07/36  | 07/5E                       | 07/1E   | 7D/00 |
| 8     | 7&                 | 3D       | 08               | 08/37  | 08/26                       |         | 7E/00 |
| 9     | 8*                 | 3E       | 09               | 09/38  | 09/2A                       |         | 7F/00 |
| 10    | 9(                 | 46       | 0A               | 0A/39  | 0A/28                       |         | 80/00 |
| 11    | 0)                 | 45       | 0B               | 0B/30  | 0B/29                       |         | 81/00 |
| 12    |                    | 4E       | 0C               | 0C/2D  | 0C/5F                       | 0C/1F   | 82/00 |
| 13    | =+                 | 55       | 0D               | 0D/3D  | 0D/2B                       |         | 83/00 |
| 15    | Backspace          | 66       | 0E               | 0E/08  | 0E/08                       | 0E/7F   |       |
| 16    | Tab                | 0D       | 0F               | 0F/09  | 0F/00                       |         |       |

|       | U.S. Make Codes (hex) |          | Character Codes AH/AL (hex) |        |         |         |       |
|-------|-----------------------|----------|-----------------------------|--------|---------|---------|-------|
| Key # | Keyboard<br>Legend    | Keyboard | System                      | Normal | Shifted | Control | Alt   |
| 17    | Q                     | 15       | 10                          | 10/71  | 10/51   | 10/11   | 10/00 |
| 18    | w                     | 1D       | 11                          | 11/77  | 11/57   | 11/17   | 11/00 |
| 19    | E                     | 24       | 12                          | 12/65  | 12/45   | 12/05   | 12/00 |
| 20    | R                     | 2D       | 13                          | 13/72  | 13/52   | 13/12   | 13/00 |
| 21    | т                     | 2C       | 14                          | 14/74  | 14/54   | 14/14   | 14/00 |
| 22    | Y                     | 35       | 15                          | 15/79  | 15/59   | 15/19   | 15/00 |
| 23    | U                     | 3C       | 16                          | 16/75  | 16/55   | 16/15   | 16/00 |
| 24    | I                     | 43       | 17                          | 17/69  | 17/49   | 17/09   | 17/00 |
| 25    | 0                     | 44       | 18                          | 18/6F  | 18/4F   | 18/0F   | 18/00 |
| 26    | Р                     | 4D       | 19                          | 19/70  | 19/50   | 19/10   | 19/00 |
| 27    | 1                     | 54       | 1A                          | 1A/5B  | 1A/7B   | 1A/1B   | 1A/00 |
| 28    | ] }                   | 5B       | 1B                          | 1B/5D  | 1B/7D   | 1B/1D   | 1B/00 |
| 29    | (101-key<br>only)     | 5D       | 2B                          | 2B/5C  | 2B/7C   | 2B/1C   | 2B/00 |
| 30    | Caps Lock             | 58       | 3A                          |        |         |         |       |
| 31    | A                     | 1C       | 1E                          | 1E/61  | 1E/41   | 1E/01   | 1E/00 |
| 32    | S                     | 1B       | 1F                          | 1F/73  | 1F/53   | 1F/13   | 1F/00 |
| 33    | D                     | 23       | 20                          | 20/64  | 20/44   | 20/04   | 20/00 |
| 34    | F                     | 2B       | 21                          | 21/66  | 21/46   | 21/06   | 21/00 |
| 35    | G                     | 34       | 22                          | 22/67  | 22/47   | 22/07   | 22/00 |
| 36    | н                     | 33       | 23                          | 23/68  | 23/48   | 23/08   | 23/00 |
| 37    | J                     | 3B       | 24                          | 24/6A  | 24/4A   | 24/0A   | 24/00 |
| 38    | к                     | 42       | 25                          | 25/6B  | 25/4B   | 25/0B   | 25/00 |
| 39    | L                     | 4B       | 26                          | 26/6C  | 26/4C   | 26/0C   | 26/00 |
| 40    | ;:                    | 4C       | 27                          | 27/3B  | 27/3A   |         | 27/00 |
| 41    | 3 <b>3</b> 9          | 52       | 28                          | 28/27  | 28/22   |         | 28/00 |
| 42    | (102-key<br>only)     | 5D       | 2B                          | 2B/5C  | 2B/7C   | 2B/1C   |       |
| 43    | Enter                 | 5A       | 1C                          | 1C/0D  | 1C/0D   | 1C/0A   | 1C/00 |

|       | U.S.               | Make Coo | les (hex) | Chai   | racter Codes | AH/AL (h | ex)   |
|-------|--------------------|----------|-----------|--------|--------------|----------|-------|
| Key # | Keyboard<br>Legend | Keyboard | System    | Normal | Shifted      | Control  | Alt   |
| 44    | L Shift            | 12       | 2A        |        |              |          |       |
| 45    | (102-Key<br>only)  | 61       | 56        |        |              |          |       |
| 46    | Z                  | 1A       | 2C        | 2C/7A  | 2C/5A        | 2C/1A    | 2C/00 |
| 47    | х                  | 22       | 2D        | 2D/78  | 2D/58        | 2D/18    | 2D/00 |
| 48    | С                  | 21       | 2E        | 2E/63  | 2E/43        | 2E/03    | 2E/00 |
| 49    | V                  | 2A       | 2F        | 2F/76  | 2F/56        | 2F/16    | 2F/00 |
| 50    | В                  | 32       | 30        | 30/62  | 30/42        | 30/02    | 30/00 |
| 51    | N                  | 31       | 31        | 31/6E  | 31/4E        | 31/0E    | 31/00 |
| 52    | М                  | 3A       | 32        | 32/6D  | 32/4D        | 32/0D    | 32/00 |
| 53    | , <                | 41       | 33        | 33/2C  | 33/3C        |          | 33/00 |
| 54    | . >                | 49       | 34        | 34/2E  | 34/3E        |          | 34/00 |
| 55    | /?                 | 4A       | 35        | 35/2F  | 35/3F        |          | 35/00 |
| 57    | R Shift            | 59       | 36        |        |              |          |       |
| 58    | L Ctrl             | 14       | 1D        |        |              |          |       |
| 60    | L Alt              | 11       | 38        |        |              |          |       |
| 61    | Space              | 29       | 39        | 39/20  | 39/20        | 39/20    | 39/20 |
| 62    | R Alt              | E0-11    | E0-38     |        | · · ·        |          |       |
| 64    | R Ctrl             | E0-14    | E0-1D     | 1      |              |          |       |
| 75    | Insert             | E0-70    | E0-52     | 52/00  | 52/00        | E0/92    | A2/00 |
| 76    | Delete             | E0-71    | E0-53     | 53/00  | 53/00        | E0/93    | A3/00 |
| 79    | Left               | E0-6B    | E0-4B     | 4B/00  | 4B/00        | 73/00    | 9B/00 |
| 80    | Home               | E0-6C    | E0-47     | 47/00  | 47/00        | 77/00    | 97/00 |
| 81    | End                | E0-69    | E0-4F     | 4F/00  | 4F/00        | 75/00    | 9F/00 |
| 83    | Up                 | E0-75    | E0-48     | 48/00  | 48/00        | E0/8D    | 98/00 |
| 84    | Down               | E0-72    | E0-50     | 50/00  | 50/00        | E0/91    | A0/00 |
| 85    | Page Up            | E0-7D    | E0-49     | 49/00  | 49/00        | 84/00    | 99/00 |
| 86    | Page Down          | E0-7A    | E0-51     | 51/00  | 51/00        | 76/00    | A1/00 |

|       | U.S.               | Make Coo | les (hex) | Character Codes AH/AL (hex) |         |         |       |  |
|-------|--------------------|----------|-----------|-----------------------------|---------|---------|-------|--|
| Key # | Keyboard<br>Legend | Keyboard | System    | Normal                      | Shifted | Control | Alt   |  |
| 89    | Right              | E0-74    | E0-4D     | 4D/00                       | 4D/00   | 74/00   | 9D/00 |  |
| 90    | Num Lock           | 77       | 45        |                             |         |         |       |  |
| 91    | 7 Home             | 6C       | 47        | 47/00                       | 47/37   | 77/00   | **    |  |
| 92    | 4 Left             | 6B       | 4B        | 4B/00                       | 47/34   | 73/00   | **    |  |
| 93    | 1 End              | 69       | 4F        | 4F/00                       | 47/31   | 75/00   | **    |  |
| 95    | 1                  | E0-4A    | E0-35     | 35/2F                       | 35/2F   | 95/00   | A4/00 |  |
| 96    | 8 UP               | 75       | 48        | 48/00                       | 58/38   | 8D/00   | **    |  |
| 97    | 5                  | 73       | 4C        | 4C/00                       | 4C/35   | 8F/00   | **    |  |
| 98    | 2 Down             | 72       | 50        | 50/00                       | 50/32   | 91/00   | **    |  |
| 99    | 0 Ins              | 70       | 52        | 52/00                       | 52/30   | 92/00   |       |  |
| 100   | *                  | 7C       | 37        | 37/2A                       | 37/2A   | 96/00   | 37/00 |  |
| 101   | 9 PgUp             | 7D       | 49        | 49/00                       | 49/39   | 84/00   | **    |  |
| 102   | 6 Right            | 74       | 4D        | 4D/00                       | 4D/36   | 74/00   | **    |  |
| 103   | 3 PgDn             | 7A       | 51        | 51/00                       | 51/33   | 76/00   | **    |  |
| 104   | . Del              | 71       | 53        | 53/00                       | 53/2E   | 93/00   |       |  |
| 105   | -                  | 7B       | 4A        | 4A/2D                       | 4A/2D   | 8E/00   | 4A/00 |  |
| 106   | +                  | 79       | 4E        | 4E/2B                       | 4E/2B   | 90/00   | 4E/00 |  |
| 108   | Enter              | E0-5A    | E0-1C     | 0D/1C                       | 0D/1C   | 0A/1C   | A6/00 |  |
| 110   | Esc                | 16       | 01        | 01/1B                       | 01/1B   | 01/1B   |       |  |
| 112   | F1                 | 05       | 3B        | 3B/00                       | 54/00   | 5E/00   | 68/00 |  |
| 113   | F2                 | 06       | 3C        | 3C/00                       | 55/00   | 5F/00   | 69/00 |  |
| 114   | F3                 | 04       | 3D        | 3D/00                       | 56/00   | 60/00   | 6A/00 |  |
| 115   | F4                 | 0C       | 3E        | 3E/00                       | 57/00   | 61/00   | 6B/00 |  |
| 116   | F5                 | 03       | 3F        | 3F/00                       | 58/00   | 62/00   | 6C/00 |  |
| 117   | F6                 | 0B       | 40        | 40/00                       | 59/00   | 63/00   | 6D/00 |  |
| 118   | F7                 | 83       | 41        | 41/00                       | 5A/00   | 64/00   | 6E/00 |  |
| 119   | F8                 | 0A       | 42        | 42/00                       | 5B/00   | 65/00   | 6F/00 |  |

the ASCII character. Allowable values are 0 to 255.

|       | U.S. Make Cod      |                                     | les (hex)                 | nex) Character Codes AH/AL (hex) |         |         |       |  |
|-------|--------------------|-------------------------------------|---------------------------|----------------------------------|---------|---------|-------|--|
| Key # | Keyboard<br>Legend | Keyboard                            | System                    | Normal                           | Shifted | Control | Alt   |  |
| 120   | F9                 | 01                                  | 43                        | 43/00                            | 5C/00   | 66/00   | 70/00 |  |
| 121   | F10                | 09                                  | 44                        | 44/00                            | 5D/00   | 67/00   | 71/00 |  |
| 122   | F11                | 78                                  | 57                        | 85/00                            | 57/00   | 89/00   | 8B/00 |  |
| 123   | F12                | 07                                  | 58                        | 86/00                            | 88/00   | 8A/00   | 8C/00 |  |
| 124   | Print<br>Screen    | E0-12/<br>E0-7C                     | E0-2A/<br>E0-37<br>E0-37  |                                  |         |         |       |  |
| 125   | Scroll Lock        | 7E                                  | 46                        |                                  |         |         |       |  |
| 126   | Pause              | E1–14/<br>77–E1/<br>F0–14/<br>F0–77 | E1-1D/<br>45-E1/<br>9D/C5 |                                  |         |         |       |  |

# Chapter 9 INT 10h Video Service

## Overview

#### Description

The CBIOS Video Service provides I/O support for both color and monochrome analog video monitors and supports selection of display mode, cursor addressing, text display, scrolling, and writing pixels.

A significant advantage of the CBIOS Video Service is that most routines can be called by the user program regardless of the video mode being used (monochrome, CGA, EGA, or VGA). The CBIOS Video Service offers all the features and functions of the VGA BIOS. The video services themselves find out what the current type of display is and take care of whatever address translation is needed, including getting bit patterns from an in-memory table font if the user's program asks for text display in graphics mode.

#### How the services are invoked

INT 10h invokes the CBIOS Video Service.

The INT 10h vector resides at Interrupt Table Address 00:40h. To ensure compatibility, the CBIOS initializes the INT 10h Video Service vector to absolute address FF065h.

continued

INT 10h Video Service

## **Overview**, Continued

#### How the services are invoked, cont'd

Individual Video Service functions are selected via the AH register. If the number in AH is outside the legal range, no action will be taken. Subfunctions are selected via the AL register or the BL register. The following general rules apply to these services:

- The character or pixel value that is to be written is normally passed in register AL.
- BX, CX, DX and segment registers are preserved through all service calls. Assume that all other register contents, particularly SI and DI, may be destroyed.
- The x coordinate (column number) is passed in CX (graphics functions) or DL (text functions).
- Any display page value is passed in BH. Display pages are zero-based (i.e., page 0 = first page, page 1 = second page, etc.).

## Summary of video service functions

The table below summarizes the Video Service function and subfunctions.

| АН                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h                    | Set Video Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 01h                    | Set Cursor Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 02h                    | Set Cursor Position                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 03h                    | Read Current Cursor Position                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 04h                    | Read Light Pen Position                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 05h                    | Select New Video Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 06h                    | Scroll Current Page Up                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 07h                    | Scroll Current Page Down                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 08h                    | Read Character/Attribute to Screen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 09h                    | Write Character/Attribute from Screen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0Ah                    | Write Character Only to Screen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0Bh                    | Set Color Palette                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0Ch                    | Write Pixel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0Dh                    | Read Pixel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0Eh                    | Write Teletype to Active Page                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0Fh                    | Return Video Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10h                    | Set Palette Registers<br>AL = 00h Set single palette<br>* AL = 01h Set overscan register<br>* AL = 02h Set all palette registers and overscan<br>AL = 03h Toggle Intensity/blinking bit<br>AL = 04h-06h Reserved<br>* AL = 07h Read individual palette register<br>AL = 09h Read overscan register<br>AL = 09h Read all palette registers and overscan register<br>AL = 10h Set individual color register<br>AL = 10h Set individual color registers<br>* AL = 12h Set block of color registers<br>* AL = 13h Select color paging mode (not valid for mode 13h)<br>BL = 00h Select page<br>* AL = 14h Reserved<br>AL = 15h Read single DAC color register<br>AL = 16h Reserved |
| * Not supported on IBM | PS/2 Models 25 and 30 (and compatibles) with MCGA hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

# Overview, Continued

| AH              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10h<br>(cont'd) | Set Palette Registers, continued<br>AL = 17h Read block of color registers<br>AL = 18h-19h Reserved<br>* AL = 1Ah Read color paging status<br>AL = 1Bh Sum color values to gray shades                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 11h             | Character Generator<br>AL = 00h Load user text mode font<br>AL = 01h Load ROM 8x14 text mode font<br>AL = 02h Load ROM 8x8 double dot font<br>AL = 03h Set block specifier (text modes only)<br>AL = 04h Load ROM 8x16 text mode font<br>* AL = 10h Load user text mode load (after mode set)<br>* AL = 11h Load ROM 8x14 text mode font (after mode set)<br>* AL = 12h Load ROM 8x8 double dot text mode font (after<br>mode set)<br>AL = 14h Load ROM 8x16 text mode font (after mode set)<br>AL = 20h Set user graphics characters pointer at INT 1FH<br>(8x8 font)<br>AL = 21h Set user graphics characters pointer at INT 43h<br>* AL = 22h Load ROM 8x16 font for graphics<br>AL = 24h Load ROM 8x16 font for graphics<br>AL = 24h Load ROM 8x16 font for graphics<br>AL = 30h Get font pointer information |
| 12h             | <ul> <li>Alternate Select</li> <li>* BL = 10h Return VGA information<br/>BL = 20h Switch to alternate print screen routine</li> <li>* BL = 30h Select scan lines for text modes<br/>BL = 31h Enable/disable default palette loading during set<br/>mode<br/>BL = 32h Enable/disable video<br/>BL = 33h Enable/disable summing to gray shades</li> <li>* BL = 34h Enable/disable cursor scaling<br/>BL = 35h Switch display</li> <li>* BL = 36h Video screen off/on</li> </ul>                                                                                                                                                                                                                                                                                                                                     |
| 13h             | Write String<br>AL = 00h Cursor not moved<br>AL = 01h Cursor is moved<br>AL = 02h Cursor not moved (text modes only)<br>AL = 03h Cursor is moved (text modes only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14h-19h         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1Ah             | Read/Write Display Combination Code<br>AL = 00h Read display combination code<br>AL = 01h Write display combination code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Summary of video service functions, cont'd

| АН      | Description                                                                                                                                                     |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1Bh     | Return Functionality/State Information                                                                                                                          |
| 1Ch     | Save/Restore Video State*<br>* AL = 00h Return Save/Restore buffer size needed<br>* AL = 01h Save current video state<br>* AL = 02h Restore current video state |
| 1Dh-FFh | Reserved                                                                                                                                                        |

## Summary of video service functions, cont'd

#### In this chapter

This chapter focuses on the Video Service. The following topics are presented:

- Hardware Environment
- Video I/O Ports
- Video Modes
- Mode/Monitor Support
- ROM Character Generators
- System RAM Data
- Video Service Functions

## Hardware Environment

#### Introduction

The CBIOS Video Service assumes the following hardware environment:

- IBM VGA-compatible VLSI chip or chip set
- INMOS G171 or compatible digital-to-analog converter (DAC) chip
- 256K of dynamic read/write video RAM configured as four 64K maps
- Monochrome or color direct drive analog monitor

#### VGA-compatible chip (or chip set)

The VGA chip (or chip set) provides all CRT control signals. It consists of four components: CRT Controller, Sequencer, Graphics Controller, and Attribute Controller.

In general, the VGA-compatible chip provides the interfacing between the system microprocessor and video memory, provides all of the CRT control signals, and outputs 8-bit digital data to the Digital-to-Analog converter for display.

Each of these components contains a fixed number of control registers that are accessed via 8-bit I/O ports. The CBIOS exchanges information with control registers by writing the register number to the appropriate I/O port and by subsequently reading from or writing to the specified register.

## Hardware Environment, Continued

#### Table of VGA component functions

The function of each VGA component is summarized in the table below.

| Component            | Function CRT Controller                                                                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRT Controller       | Generates horizontal and vertical CRT sync timings, cursor<br>and underline timings, video buffer addressing, and refresh<br>addressing.                                |
| Sequencer            | Arbitrates system access to display RAM and fonts. The sequencer allows up to eight fonts with two fonts display at any one time.                                       |
| Graphics Controller  | Handles read/write operation on four parallel bit planes. Out-<br>puts data to Attribute Controller.                                                                    |
| Attribute Controller | Converts incoming text mode attribute data or graphics<br>mode pixel data into 8-bit indexes into the Digital-to-Analog<br>Converter (DAC) color registers (see below). |

#### Digital-to-Analog Converter (DAC)

The video DAC contains 256 individual color registers which can be accessed by the CBIOS as either four 64-color registers or sixteen 16-color registers.

Each DAC color register contains one 18-bit RGB analog value. Six bits of each register are allocated to each primary color. Thus, the color represented in each DAC color register may be any of 256K possible colors (i.e.  $2^{3*6} = 256$ K).

## Hardware Environment, Continued

#### DAC, Attribute controller, BIOS initialization

The CBIOS initializes the 8-bit index values contained in the Attribute Controller and the 18-bit analog color values contained in the DAC color registers each time a video mode is set.

The table below outlines the DAC/Attribute Controller relationship for the three major types of video modes.

#### Mode interrupt/initialization table

| Туре                    | Description                                                                                                                                                                                                                                                                                                                       |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EGA and<br>16-color VGA | DAC<br>The CBIOS initializes access to the 256 DAC color registers in<br>blocks, or pages, of 64 colors each. The first 64-color page is in-<br>itialized to analog equivalents of the 64 EGA colors. The other 192<br>colors remain undefined.                                                                                   |
|                         | Attribute Controller                                                                                                                                                                                                                                                                                                              |
|                         | To maintain color compatibility with existing EGA software, CBIOS<br>initializes the Attribute Controller to the 16 commonly accepted<br>default EGA colors.                                                                                                                                                                      |
| CGA                     | DAC                                                                                                                                                                                                                                                                                                                               |
|                         | The CBIOS initializes access to the 256 DAC color registers as four<br>blocks of 64 colors each in CGA modes. The first 64-color block is<br>initialized as four 16-color sub-blocks. Each of these 16-color<br>blocks is initialized to the 16 colors displayable in CGA mode. The<br>remaining 192 DAC registers are undefined. |
|                         | Attribute Controller                                                                                                                                                                                                                                                                                                              |
|                         | To maintain color compatibility with existing CGA software, the<br>CBIOS initializes the Attribute Controller to the 16-color CGA pal-<br>ette. When applications software requests a CGA color, the Attrib-<br>ute Controller maps the requests through to its analog equivalent in<br>the DAC controller.                       |
| 13h                     | DAC                                                                                                                                                                                                                                                                                                                               |
|                         | The CBIOS initializes all 256 color registers to their IBM PS/2 default equivalents.                                                                                                                                                                                                                                              |
|                         | Attribute Controller                                                                                                                                                                                                                                                                                                              |
|                         | The attribute controller receives 8-bit color values directly from<br>applications programs. It maps those values directly into the DAC<br>color registers.                                                                                                                                                                       |

# **Note:** For more information on the CBIOS Video Service video modes, refer to the Video Modes page heading in this chapter.

## Hardware Environment, Continued

#### Video RAM

The CBIOS Video Service requires 256K of read/write video RAM formatted into four banks (or maps) of 64K.

To maintain compatibility, display memory for each of the historical MDA, CGA, and EGA modes is exactly as it was before. The display memory organization for the new VGA modes is outlined in this chapter in the table found under the Video Modes heading.

#### Analog monitor support

To display all modes, the Video Service requires either a monochrome or a color direct drive analog monitor with a 31.5 KHz horizontal scan frequency.

The display's vertical gain is adjusted automatically by the VGA-compatible circuitry. Thus, video modes with 350, 400, and 480 horizontal scan lines can be displayed without requiring manual adjustment.

# Video I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                          |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0061h       | W                    | System control port B, where:<br>Bit 7 = 1 Reset timer 0 output latch (IRQ 0)<br>Bits 6-4 = Reserved<br>Bit 3 = 0 Enable channel check<br>Bit 2 = 0 Enable parity check<br>Bit 1 = 1 Speaker data enable<br>Bit 0 = 1 Enable timer 2 gate to speaker |
| 0064h       | W                    | 8042 Commands                                                                                                                                                                                                                                        |
| 0064h       | R                    | 8042 Status, where:Bit 7= 1 Parity errorBit 6= 1 General time outBit 5= 1 Auxiliary output buffer fullBit 4= 1 Inhibit switchBit 3= 1 Command/dataBit 2= System flagBit 1= 1 Input buffer fullBit 0= 1 Output buffer full                            |
| 03B4h       | R/W                  | VGA CRT controller index register (mono)                                                                                                                                                                                                             |
| 03B5h       | R/W                  | Other VGA CRT controller registers (mono)                                                                                                                                                                                                            |
| 03BAh       | R                    | VGA input status register 1 (mono)                                                                                                                                                                                                                   |
| 03BAh       | w                    | VGA feature control register (mono)                                                                                                                                                                                                                  |
| 03C0h       | R/W                  | VGA attribute address register                                                                                                                                                                                                                       |
| 03C0h       | w                    | Other VGA attribute registers                                                                                                                                                                                                                        |
| 03C1h       | R                    | Other VGA attribute registers                                                                                                                                                                                                                        |
| 03C2h       | w                    | VGA miscellaneous output register                                                                                                                                                                                                                    |
| 03C2h       | R                    | VGA input status register 0                                                                                                                                                                                                                          |
| 03C3h       | R/W                  | VGA video subsystem enable                                                                                                                                                                                                                           |
| 03C4h       | R/W                  | VGA sequencer address register                                                                                                                                                                                                                       |
| 03C5h       | R/W                  | Other VGA sequencer registers                                                                                                                                                                                                                        |
| 03C6h       | R/W                  | Video DAC PEL mask                                                                                                                                                                                                                                   |
| 03C7h       | w                    | Video DAC PEL address, read mode                                                                                                                                                                                                                     |
| 03C7h       | R                    | Video DAC state register                                                                                                                                                                                                                             |
| 03C8h       | R/W                  | Video DAC PEL address, write mode                                                                                                                                                                                                                    |
| 03C9h       | R/W                  | Video DAC PEL data register                                                                                                                                                                                                                          |
| 03CAh       | R                    | VGA feature control register                                                                                                                                                                                                                         |

INT 10h, Video Service, references the following I/O ports:

# Video I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                |
|-------------|----------------------|--------------------------------------------|
| 03CCh       | R                    | VGA miscellaneous output register          |
| 03CEh       | R/W                  | VGA graphics registers, address register   |
| 03CFh       | R/W                  | VGA and other graphics registers           |
| 03D4h       | R/W                  | VGA CRT controller index register (color)  |
| 03D5h       | R/W                  | Other VGA CRT controller registers (color) |
| 03DAh       | R                    | VGA input status register 1 (color)        |
| 03DAh       | W                    | VGA feature control register (color)       |

#### Introduction

The CBIOS Video Service supports 17 video modes, providing backward compatibility with MDA, CGA, and EGA modes, as well as compatibility with all new VGA modes.

**Models 25 and 30:** IBM PS/2 Models 25 and 30 which utilize multicolor graphics array (MCGA) video subsystems support six video modes, which are outlined in a separate table.

#### Table of CBIOS video modes

The table below lists the 17 video service modes supported by the CBIOS Video Service.

| Mode  | Emul.                                                                                                                                                                                                                                                                                                    | Res.    | Туре     | Max.<br>Colors | Scheme | Char.<br>Box | Max.<br>Pgs. | Buff.<br>Start |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|----------------|--------|--------------|--------------|----------------|
| 0, 1  | CGA*                                                                                                                                                                                                                                                                                                     | 320x200 | Text     | 16/256K        | 40x25  | 8x8          | 8            | B8000          |
| 0, 1  | EGA*                                                                                                                                                                                                                                                                                                     | 320×350 | Text     | 16/256K        | 40x25  | 8x14         | 8            | B8000          |
| 0, 1  | VGA+                                                                                                                                                                                                                                                                                                     | 360×400 | Text     | 16/256K        | 40x25  | 9x16         | 8            | B8000          |
| 2,3   | CGA*                                                                                                                                                                                                                                                                                                     | 640x200 | Text     | 16/256K        | 80x25  | 8x8          | 8            | B8000          |
| 2,3   | EGA*                                                                                                                                                                                                                                                                                                     | 640x350 | Text     | 16/256K        | 80x25  | 8x14         | 8            | B8000          |
| 2, 3! | VGA+                                                                                                                                                                                                                                                                                                     | 720x400 | Text     | 16/256K        | 80x25  | 9x16         | 8            | B8000          |
| 4, 5  | CGA                                                                                                                                                                                                                                                                                                      | 320x200 | Graphics | 4/256K         | 40x25  | 8×8          | 1            | B8000          |
| 6     | CGA                                                                                                                                                                                                                                                                                                      | 640x200 | Graphics | 2/256K         | 80x25  | 8×8          | 1            | B8000          |
| 7     | MDA*                                                                                                                                                                                                                                                                                                     | 720x350 | Text     | MDA Mono       | 80x25  | 9x14         | 8            | B0000          |
| 7!    | VGA*                                                                                                                                                                                                                                                                                                     | 720x400 | Text     | VGA Mono       | 80x25  | 9x16         | 8            | B0000          |
| D     | EGA                                                                                                                                                                                                                                                                                                      | 320x200 | Graphics | 16/256K        | 40x25  | 8×8          | 8            | A0000          |
| E     | EGA                                                                                                                                                                                                                                                                                                      | 640x200 | Graphics | 16/256K        | 80x25  | 8×8          | 4            | A0000          |
| F     | EGA                                                                                                                                                                                                                                                                                                      | 640x350 | Graphics | Mono           | 80x25  | 8x14         | 2            | A0000          |
| 10    | EGA                                                                                                                                                                                                                                                                                                      | 640x350 | Graphics | 16/256K        | 80x25  | 8x14         | 2            | A0000          |
| 11    | VGA                                                                                                                                                                                                                                                                                                      | 640x480 | Graphics | 2/256K         | 80×30  | 8x16         | 1            | A0000          |
| 12    | VGA                                                                                                                                                                                                                                                                                                      | 640x480 | Graphics | 16/256K        | 80x30  | 8x16         | 1            | A0000          |
| 13    | VGA                                                                                                                                                                                                                                                                                                      | 320x200 | Graphics | 256/256K       | 40x25  | 8×8          | 1            | A0000          |
| Legen | Legend: "!" indicates power-on default mode<br>3! = color monitor is attached,<br>7! = monochrome monitor is attached.<br>"*" indicates that scan lines must be specified before mode set. (See AH =<br>12h BL = 30h Select Scan Line for Alphanumeric Codes for details.)<br>"+" indicates default mode |         |          |                |        |              |              |                |

#### Model 25 and 30 video modes

The table below lists the video modes supported by IBM Models 25 and 30 with MCGA.

| Mode                                                                                                                 | Emul. | Res.    | Туре     | Max.<br>Colors | Scheme | Char.<br>Box | Max.<br>Pgs. | Buff.<br>Start |
|----------------------------------------------------------------------------------------------------------------------|-------|---------|----------|----------------|--------|--------------|--------------|----------------|
| 0, 1                                                                                                                 | CGA†  | 320×400 | Text     | 16/256K        | 40x25  | 8x16         | 8            | B8000          |
| 2, 3                                                                                                                 | EGA†  | 640×400 | Text     | 16/256K        | 80x25  | 8x16         | 8            | B8000          |
| 4,5                                                                                                                  | CGA   | 320x200 | Graphics | 4/256K         | 40x25  | 8x8          | 1            | B8000          |
| 6                                                                                                                    | CGA   | 640x200 | Graphics | 2/256K         | 80x25  | 8x8          | 1            | B0000          |
| 7                                                                                                                    | MDA   | 720x350 | Text     | MDA Mono       | 80x25  | 9x14         | 8            | B0000          |
| 11                                                                                                                   | VGA   | 640x480 | Graphics | 2/256K         | 80x30  | 8x16         | 1            | A0000          |
| 13                                                                                                                   | VGA   | 320x200 | Graphics | 256/256K       | 40x25  | 8x8          | 1            | A0000          |
| Legend: "†" indicates that 320x200 or 640x200 is used if hardware initialization detects a nonstandard monitor type. |       |         |          |                |        |              |              |                |

## Video mode facts

The facts below apply to the Video Service modes listed on the previous page.

| Fact                               | Description                                                                                                                                                                                                                                                |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Modes 0, 2, 4 = Modes 1, 3, 5      | In CGA mode, modes hex 1, 3, and 5 have color<br>burst turned on and modes hex 0, 2, and 4 have color<br>burst turned off. The VGA hardware does not support<br>color burst; modes hex 0, 2, and 4 are identical to<br>modes hex 1, 3, and 5 respectively. |
| 200-line modes double-scanned      | All 200 scan line modes are double-scanned by the<br>analog monitor. Each line of video is painted on the<br>screen twice, one beneath the other, before the next<br>new scan line is painted.                                                             |
| Number of text mode lines may vary | 200, 350, or 400 scan lines can be displayed in all text<br>modes. The number of scan lines to display is se-<br>lected via Video Service function AH = 12h, BL = 30h<br>Alternate Select. Refer to AH = 12h in this chapter for<br>further details.       |
| No cursor in graphics              | The cursor is not displayed in graphics modes.                                                                                                                                                                                                             |
| MDA, CGA, EGA Emulation            | To insure compatibility with older software, the CBIOS<br>Video Service supports all 200 and 350 scan line MDA,<br>CGA, and EGA video modes.                                                                                                               |
|                                    | To activate a 200 or 350 scan line mode:                                                                                                                                                                                                                   |
|                                    | <ul> <li>Execute function AH = 12h, BL = 30h Alternate<br/>Scan Line Select with AL = 00h or 01h. (i.e. 200 or<br/>350 scan lines)</li> </ul>                                                                                                              |
|                                    | Execute function AH = 00h Set Mode                                                                                                                                                                                                                         |
|                                    | Note: Unless otherwise indicated, the BIOS defaults to 400 scan lines for all text modes.                                                                                                                                                                  |

## Color/Monochrome analog monitors display all modes

Both monochrome and color 31.5 KHz direct drive analog and multiscan monitors can display all of the modes listed in the table of video modes earlier in this chapter.

| The | following | facts | apply: |  |
|-----|-----------|-------|--------|--|
|     |           |       |        |  |

| lf                                            | Then                                                                                                                                                                                                                                                            |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A monochrome analog<br>monitor is attached    | Colors are displayed as shades of gray, with the maxi-<br>mum number of shades equal to the maximum number of<br>colors display in the respective mode. In mode 0Eh, for<br>example, 16 shades of gray can be displayed.                                        |
|                                               | Mode 13h is an exception to this rule. Only 64 (and not 256) shades of gray can be displayed in mode 13h.                                                                                                                                                       |
| A color analog monitor is attached            | The colors displayed are selected from a BIOS-initialized<br>palette of 64 color registers. The number of colors dis-<br>played in each mode is listed in the table of video modes<br>above. In mode 0Eh, for example, 16 different colors can<br>be displayed. |
|                                               | The BIOS initializes the 64 colors in this palette to analog<br>equivalents of the 64-color digital EGA palette. The re-<br>maining 192 color registers are undefined.                                                                                          |
|                                               | Mode 13h is an exception to this rule. Mode 13h is capa-<br>ble of displaying all of the 256 colors stored in the DAC.<br>The BIOS initializes these colors to IBM-compatible de-<br>faults at mode set.                                                        |
|                                               | Models 25 and 30: In MCGA-based systems, the BIOS initializes the first 16 color registers, leaving 240 color registers undefined.                                                                                                                              |
| A 200 scan line mode is se-<br>lected         | All 200 scan line modes are double-scanned. That is,<br>each horizontal line is scanned twice, for a total of 400<br>scan lines. This is true for both color and monochrome<br>analog monitors.                                                                 |
| Power-on default video<br>modes are in effect | The default power-on mode is mode 3+ (720x400,<br>16-color) when a color analog monitor is attached, or                                                                                                                                                         |
|                                               | The default power-on mode is mode 7+ (720x400,<br>monochrome) when a monochrome analog monitor is<br>attached.                                                                                                                                                  |
|                                               | Models 25 and 30: In MCGA-based systems, the de-<br>fault power-on mode is 3.                                                                                                                                                                                   |

#### **ROM-resident fonts**

The ROM BIOS contains three BIOS-resident character generators (fonts):

- 8x8 dot
- 8x14 dot (not available in IBM Models 25 and 30 with MCGA)
- 8x16 dot

#### 9x14 and 9x16 dot fonts

The BIOS is also capable of generating a 9x16 dot font in text modes 0+,1+, 2+, 3+, and 7+. However, the BIOS generates this 9x16 font by running the 8x16 character set through a ROM-resident table of corrections. The 9x16 font is not available to BIOS end users through the AH = 11h Character Generator function.

The 9x14 dot font is created in the same way that the 9x16 dot font is, except that it is based on the 8x14 character set. The 9x14 dot font is used in mode 7.

#### Text mode fonts and memory map 2

In text modes, the ASCII character number is written to video memory map 0 and the corresponding attribute is written to memory map 1.

Memory map 2 is used for storing character generator (font) data. Each font occupies one 8K block, making for a total of eight possible fonts. A maximum of two 256-character fonts (i.e. 512 characters) can be displayed at one time. The Video Service Set Block Specifier subfunction provides BlOS controls for selecting which two blocks are to be displayed. (See AH = 11h, AL = 03h in this chapter for details.)

## ROM Character Generators, Continued

#### **Default fonts**

The font associated with a given video mode is directly related to the resolution that mode is capable of reproducing. The table below outlines the font/ resolution relationship.

| If the resolution is | Then the default font is… |
|----------------------|---------------------------|
| 320×200              | 8x8                       |
| 320×350              | 8x14                      |
| 360×400              | 9x16                      |
| 640×200              | 8x8                       |
| 640×350              | 8×14                      |
| 640×400              | 8×14                      |
| 640×480              | 8x16                      |
| 720×350              | 9x14                      |
| 720×400              | 9×16                      |

#### How fonts are loaded

Each time a video mode is set, the CBIOS automatically loads the font associated with the specified mode into block 0 in memory map 2.

Note: For 200 and 350 scan line text modes, the user must set the number of scan lines through the Video Service subfunction AH = 12h, BL = 30h, Select Scan Lines for Text Modes, before mode set.

#### Overriding default fonts and default memory blocks

The Video Service functions AH = 11h Character Generator and AH 12h Alternate Select contain subfunctions that enable the user to:

- Load a default font into a nondefault character block in memory map 2
- Specify a nondefault font for display in text or graphics modes
- Load user-defined font for display in text or graphics modes.
- Control the number of scan lines in text modes

Refer to the Character Generator and Alternate Select headings in this chapter for further details.

# System RAM Data

## Video data definitions

The data definitions used by the INT 10h Video services are stored in system RAM in segment 40h and are presented below in offset order.

| System RAM<br>Offset (hex) | Size    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 49h                        | 1 Byte  | Video mode setting.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4Ah                        | 1 Word  | Number of columns on screen.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4Ch                        | 1 Word  | Current page size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4Eh                        | 1 Word  | Current page address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 50h                        | 8 Words | Cursor position on each page. Two bytes/page.<br>First byte (low order) of each pair is column, sec-<br>ond is row. 0, 0 is upper left corner of screen.                                                                                                                                                                                                                                                                                                                                         |
| 60h                        | 1 Word  | Cursor type defined as 6845 video chip-compatible<br>starting and ending scan lines. High order byte<br>holds starting scan line; low order byte holds ending<br>scan line.                                                                                                                                                                                                                                                                                                                      |
| 62h                        | 1 Byte  | Current page number.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 63h                        | 1 Word  | 6845 video chip-compatible I/O port number for<br>current mode. (Port 03D4h or 03B4h)                                                                                                                                                                                                                                                                                                                                                                                                            |
| 65h                        | 1 Byte  | Current mode select register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 66h                        | 1 Byte  | Current palette value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 84h                        | 1 Byte  | Number of rows on screen (24/25)                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 85h                        | 1 Word  | Character height (bytes/character)                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 87h                        | 1 Byte  | Video control bits, where:<br>Bit 7 = Clear RAM<br>Bit 6,5 = Memory on video hardware as follows:<br>00b = 64K<br>01b = 128K<br>10b = 192K<br>11b = 256K<br>Bit 4 = Not used<br>Bit 3 = 0 EGA-compatible mode active<br>Bit 2 = 1 Wait for display enable<br>Bit 1 = 0 color or ECD monitor attached to<br>EGA-compatible adapter<br>= 1 Monochrome monitor is attached to<br>EGA-compatible adapter<br>Bit 0 = 0 translate cursor video modes 0-3<br>when using ECD monitor in 350-line<br>mode |

| System RAM<br>Offset (hex) | Size   | Description                                                                                                                                                                              |
|----------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 88h                        | 1 Byte | EGA/VGA switch data where:<br>Bits 7-4 = Feature connector bits 3-0, respectively<br>Bits 3-0 = Option switches 3-0, respectively                                                        |
| 89h                        | 1 Word | VGA control bits, where:<br>Bit 7 = 200 lines<br>Bits 6-5 = Reserved<br>Bit 4 = 400 lines<br>Bit 3 = No palette load<br>Bit 2 = Mono Monitor<br>Bit 1 = Gray Scaling<br>Bit 0 = Reserved |
| 8Ah                        | 1 Byte | Index to the Display Combination Code table                                                                                                                                              |
| A8h                        | 1 Word | Pointer to video parameter table and overrides (in segment:offset format).                                                                                                               |

#### Video data definitions, cont'd

#### Video Service Pointer Tables

The Video Service initializes and maintains two system RAM pointer tables. Each table consists of seven double-word segment:offset pointers to video parameters and optional auxiliary character generator information.

The Set Mode function, AH = 00h, refers to the video service pointer tables (and to the information pointed to by the tables) on every mode set.

#### **Default table locations**

There are two video service pointer tables: the primary table and the secondary table. The locations of each of these tables is initialized by the CBIOS during the power-on self test and initialization (POST) procedure. The table locations are initialized as follows:

- This memory location (40:A8h in the BIOS Data Area) points to the first pointer table. It is initialized by the CBIOS to a default table in ROM.
- The fifth entry in the first pointer table points to the location of the second pointer table.
- **Note:** Users who wish to override the CBIOS default locations may supply their own values for 40:A8h and entry 5 of Table #1. See next page.

# System RAM Data, Continued

#### Structure of Video Service Pointer Table #1

The location of the first, or primary, pointer table must be stored in 40:A8h. This address is initialized by the CBIOS to a default location.

The table is structured as follows:

| Table Location | Description                                                                                                                                                                                                                                                                                                                                            |                                                                                  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|
| Pointer 1      | POINTER TO VIDEO PARAMETER TABLE<br>Initialized at POST to the ROM BIOS video parameter table.<br>This table entry is mandatory. If reinitialized, it must point to<br>a valid video parameter table.                                                                                                                                                  |                                                                                  |  |
| Pointer 2      | POINTER TO DYNAMIC SAVE AREA<br>Optional table entry. Initialized at POST to 00:00h. When non-<br>zero, this entry must point to a Dynamic Save Area in system<br>RAM. The Dynamic Save Area must be at least 256 bytes<br>long. It contains the 16 EGA palette register values as well as<br>the overscan register value in bytes 0–16, respectively. |                                                                                  |  |
| Pointer 3      | POINTER TO TEXT MODE AUXILIARY CHARACTER<br>GENERATOR<br>Optional table entry. Initialized by the BIOS to 00:00h. When<br>nonzero, this entry must point to a table structured as below:                                                                                                                                                               |                                                                                  |  |
|                | Size                                                                                                                                                                                                                                                                                                                                                   | Description                                                                      |  |
|                | Byte                                                                                                                                                                                                                                                                                                                                                   | Bytes per character                                                              |  |
|                | Byte                                                                                                                                                                                                                                                                                                                                                   | Block to load, 0 = Normal operation                                              |  |
|                | Word                                                                                                                                                                                                                                                                                                                                                   | Count to store, 256 = Normal operation                                           |  |
|                | Word                                                                                                                                                                                                                                                                                                                                                   | Character offset, 0 = Normal operation                                           |  |
|                | Dword                                                                                                                                                                                                                                                                                                                                                  | Pointer to a font table                                                          |  |
|                | Byte                                                                                                                                                                                                                                                                                                                                                   | Displayable rows, where:                                                         |  |
|                |                                                                                                                                                                                                                                                                                                                                                        | 0FFh = Maximum calculated value otherwise<br>indicated number of rows displayed. |  |
|                | ByteConsecutive bytes of mode values for font.0FFh =Indicates end of stream                                                                                                                                                                                                                                                                            |                                                                                  |  |
|                | Note: Using this third pointer can cause unexpected cur<br>operation. See "Function: AH = 01h Set Cursor<br>Type," in this chapter for details.                                                                                                                                                                                                        |                                                                                  |  |

| Table Location | Description                                                                                                                                                                                                                                              |                                                                              |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|
| Pointer 4      | POINTER TO GRAPHICS MODE CHARACTER<br>GENERATOR<br>Optional table entry. Initialized to 00:00h. When nonzero, this<br>entry must point to a table structured as below:                                                                                   |                                                                              |  |
|                | Size                                                                                                                                                                                                                                                     | Description                                                                  |  |
|                | Byte                                                                                                                                                                                                                                                     | Displayable rows                                                             |  |
|                | Word                                                                                                                                                                                                                                                     | Bytes per character                                                          |  |
|                | DWord                                                                                                                                                                                                                                                    | Pointer to font table                                                        |  |
|                | Byte                                                                                                                                                                                                                                                     | Consecutive bytes of mode values for font.<br>0FFh = Indicates end of stream |  |
| Pointer 5      | POINTER TO VIDEO SERVICE POINTER TABLE #2 (Secon-<br>dary Save Pointer Data Area)<br>Initialized by the BIOS to the default Pointer Table #2 location.<br>This table entry is mandatory. If reinitialized, it must point to<br>a valid Pointer Table #2. |                                                                              |  |
| Pointer 6      | Reserved. Set by the BIOS to 00:00h                                                                                                                                                                                                                      |                                                                              |  |
| Pointer 7      | Reserved. Set by the BIOS to 00:00h                                                                                                                                                                                                                      |                                                                              |  |

## Structure of Video Service Pointer Table #1, cont'd

#### Structure of Video Service Pointer Table #2

The location of second, or secondary, pointer table must be stored in Pointer 5 of pointer table #1. Pointer 5 of table #1 is initialized by the BIOS to a default location.

| The t | able | is | structured | as | follows: |
|-------|------|----|------------|----|----------|
|-------|------|----|------------|----|----------|

| Table Location | Description                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Pointer 1      | TABLE LENGTH                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|                | Initialized by the BIOS to default table length.                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| Pointer 2      | POINTER TO DISPLAY COMBINATION CODE (DCC)                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                | Initialized by the CBIOS to the ROM BIOS DCC table. This table<br>entry is mandatory. If reinitialized, it must point to a valid DCC<br>table. The DCC table is structured as below:                                                                                                                                                                                                                                    |  |  |
|                | Size Description                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                | Byte Number of entries in the DCC table                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                | Byte DCC Table Version Number                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                | Byte Maximum display type code                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                | Byte Reserved                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                | 00,00 Entry 0 No Displays<br>00,01 Entry 1 MDPA<br>00,02 Entry 2 CGA<br>02,01 Entry 3 MDPA + CGA<br>00,04 Entry 4 EGA<br>04,01 Entry 5 EGA + MDPA<br>00,05 Entry 6 MEGA<br>02,05 Entry 7 MEGA + CGA<br>00,06 Entry 8 PGC<br>01,06 Entry 9 PGC + MDPA<br>05,06 Entry 10 PGC + MEGA<br>00,08 Entry 11 CVGA<br>01,08 Entry 12 CVGA + MDPA<br>01,08 Entry 13 MVGA<br>02,07 Entry 14 MVGA + CGA<br>02,06 Entry 15 MVGA + PGC |  |  |
|                | Abbreviations<br>MDPA = Monochrome Display and Printer Adapter<br>CGA = Color/Graphics Monitor Adapter<br>EGA = Enhanced Graphics Adapter<br>MEGA = EGA with monochrome display<br>PGC = Professional Graphics Controller<br>VGA = Video Graphics Array<br>MVGA = VGA-based with monochrome display<br>CVGA = VGA-based with color display                                                                              |  |  |

# System RAM Data, Continued

| Table Location | Description          |                                                                                                                                                                                                    |  |
|----------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pointer 3      | GENERA<br>Optional t | TO SECOND TEXT MODE AUXILIARY CHARACTER<br>TOR<br>able entry. Initialized by the BIOS to 00:00h When<br>this entry must point to a table structured as below:                                      |  |
|                | Size                 | Description                                                                                                                                                                                        |  |
|                | Byte                 | Bytes per character                                                                                                                                                                                |  |
|                | Byte                 | Block to load, 0 = Normal operation                                                                                                                                                                |  |
|                | Word                 | Count to store, 256 = Normal operation                                                                                                                                                             |  |
|                | Word                 | Character offset, 0 = Normal operation                                                                                                                                                             |  |
|                | Dword                | Pointer to a font table                                                                                                                                                                            |  |
|                | Byte                 | Displayable rows, where:                                                                                                                                                                           |  |
|                |                      | 0FFh = Maximum calculated value; otherwise<br>indicated number of rows displayed.                                                                                                                  |  |
|                | Byte                 | Consecutive bytes of mode values for font.<br>0FFh = Indicates end of stream                                                                                                                       |  |
|                | te<br>us             | t 3 of the Attribute byte is used to switch between<br>xt mode fonts. It may be necessary to employ the<br>er palette profile table to define a palette of colors<br>dependent of attribute bit 3. |  |

## Structure of Video Service Pointer Table #2, cont'd

| Table Location | Descript               | Description                                                                                                |  |  |
|----------------|------------------------|------------------------------------------------------------------------------------------------------------|--|--|
| Pointer 4      | Pointer to             | Pointer to User Palette Profile Table                                                                      |  |  |
|                | Optional 1<br>nonzero, | table entry. Initialized by the BIOS to 00:00h. When this entry must point to a table structured as below: |  |  |
|                | Size                   | Description                                                                                                |  |  |
|                | Byte                   | Underlining flag, where:<br>1 = On<br>0 = Ignore (Normal operation)<br>-1 = Off                            |  |  |
|                | Byte                   | Reserved                                                                                                   |  |  |
|                | Word                   | Reserved                                                                                                   |  |  |
|                | Word                   | Internal palette count (0–17), where:<br>17 = Normal operation                                             |  |  |
|                | Word                   | Internal palette index (0-16), where:<br>0 = Normal operation                                              |  |  |
|                | DWord                  | Pointer to Internal palette                                                                                |  |  |
|                | Word                   | External palette count (0-256), where:<br>0 = Normal operation                                             |  |  |
|                | Word                   | External palette index (0-255), where:<br>0 = Normal operation                                             |  |  |
|                | DWord                  | Pointer to external palette                                                                                |  |  |
|                | Byte                   | Consecutive bytes of mode values for font, where:                                                          |  |  |
|                |                        | 0FFh = Indicates end of stream                                                                             |  |  |
| Pointer 5      | Reserved               |                                                                                                            |  |  |
| Pointer 7      | Reserved               |                                                                                                            |  |  |

## Structure of Video Service Pointer Table #2, cont'd

#### Description

The Set Video Mode function sets the video mode registers for operation in any supported mode. It selects the active video mode if more than one is installed, clears the screen, positions the cursor at 0,0 and resets the color palette to default color values. (See "Video Modes" in this chapter for a description of each mode.)

**Models 25 and 30:** IBM PS/2 Models 25/30 (and compatibles) equipped with MCGA graphics do not support the full number of VGA video modes. See "Video Modes" for more information.

#### Input/Output

| Input:  | AH | = | 00h                             |
|---------|----|---|---------------------------------|
|         | AL | = | Video mode, where:              |
|         |    |   | 00h-07h — Valid values          |
|         |    |   | 08h-0Ch — Reserved              |
|         |    |   | 0Dh-13h — Valid values          |
| Output: | AL | = | Video mode, where:              |
|         |    |   | 20h — If mode is greater than 7 |
|         |    |   | 30h - If mode is from 0-5 or 7  |
|         |    |   | 3Fh — If mode is mode 6         |

#### Additional information

- Resetting the same video mode can be used to clear the screen.
- To avoid resetting the palette when working with colors, use Video Service 06h rather than Service 00h to clear the screen.
- The cursor is not displayed in graphics modes.
- Modes 0, 2, and 5 are identical to modes 1, 3, and 4.
- The power-on default mode with a color analog monitor attached is 3.
- The power-on default mode with a monochrome analog monitor attached is 7.
- During mode set, if bit 7 of AL is set, the video buffer is not cleared.
- Refer to AH = 12h BL = 30h to select alpha mode scan lines (200, 350, or 400).
- For all modes except mode 13, the first 64 color registers are initialized and the values in the remaining 192 color registers are undefined.

## Function: AH = 01h Set Cursor Type

#### Description

The Set Cursor Type function sets the size of the cursor that will appear in text modes. Cursor size and location within the character box is determined by the starting and ending scan lines indicated in bits 4:0 of registers CH and CL respectively.

The Set Cursor Type function stores cursor size parameters in the cursor type byte at 40:60h.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) equipped with MCGA graphics, this function multiplies CH by 2, then it multiplies CL by 2 and increases the CL product by 1 before writing cursor values to MCGA hardware.

#### Input/Output

| Input:  | AH : | = 01h                                                  |
|---------|------|--------------------------------------------------------|
|         | CH : | Top scan line, where:                                  |
|         |      | Bits 7-6 = 00h (must be 00h, otherwise cursor blinking |
|         |      | becomes erratic)                                       |
|         |      | Bit 5 = To shut cursor off                             |
|         |      | Bits 4-0 = Top scan line                               |
|         | CL = | Bottom scan line, where:                               |
|         |      | Bit 7 = Undefined                                      |
|         |      | Bits $6-5$ = Show cursor                               |
|         |      | Bits 4-0 = Lower scan line                             |
| Output: | None |                                                        |

#### Additional information

- Only one cursor type is available for all video pages.
- The default text mode cursor occupies the bottom two scan lines of the character box associated with the given text mode.
- Setting register bit 5 of the CH register causes the text mode cursor to disappear completely. The cursor can also be eliminated by positioning it to a nondisplay address, e.g. (x,y) = (0,25)
- In graphics mode, bit 5 is set automatically, which prevents the cursor from being displayed. To simulate the cursor, use the solid block character DFh, or change background attributes.
- CGA mode can a display cursor on eight lines, numbered 0 to 7, top to bottom.
- MDA and EGA modes can display a cursor on 14 lines, numbered 0 to 13, top to bottom.
- MCGA and VGA modes can display a cursor on 16 lines, the default character size of this mode.

#### Default cursor settings

The default cursor settings for each mode type are listed below. Default cursor settings are established by function AH = 00h at mode set.

| Mode type | Cursor settings  |
|-----------|------------------|
| CGA       | CH = 6, CL = 7   |
| MDA, EGA  | CH = 11, CL = 12 |
| MCGA, VGA | CH = 13, CL = 14 |

## Function: AH = 02h Set Cursor Position

#### Description

The Set Cursor Position function sets the cursor position (in terms of rowby-column coordinates) for the display page indicated in BL. It saves the position as a two-byte row-by-column table entry in the cursor coordinates byte at 40:50h. Row and column coordinates are indicated in registers DH and DL respectively.

The Set Cursor Position function applies to both text and graphics video modes. In text modes, if the display page selected in BH is the active display page, the screen cursor will move to the coordinates indicated in registers DH and DL. In graphics modes, the cursor is invisible, but it is used to define a position on the screen.

#### Input/Output

| Input:  | AH | = | 02h                                         |
|---------|----|---|---------------------------------------------|
|         | BH | Ξ | Display page number (see function AH = 05h) |
|         | DH | = | Row (0 is top row of screen)                |
|         | DL | = | Column (0 is leftmost column)               |
| Output: | AX | = | 00h                                         |

#### **Cursor Positioning**

Positioning the cursor to coordinates (0,0) places it in the upper left corner of the screen in the 80x25 text mode. Selecting coordinates (79,24) in the 80x25 text mode will allow placement of the cursor in the lower right corner of the screen. The cursor can also be placed in the lower right corner of the screen using coordinates (39,24) in the 40x25 text mode.

The cursor can be turned off by moving it to an off-screen location or changing its coordinates to a position such as (0,25). However, if it is moved too far off-screen, the actual position if the cursor may become unpredictable.

#### Additional information

- The display page number must be set to 0 in CGA graphics mode.
- Multiple display pages in 16-color graphics as well as text modes are supported by both EGA and VGA.

#### Description

The Read Current Cursor Position function reads the cursor position for the given video page from the cursor coordinates byte at 40:50h. It reads the cursor type from 40:60h and returns the current cursor position in text coordinates. This function is useful for determining the exact cursor type before it is changed.

| Input:  | AH | = | 03h                              |
|---------|----|---|----------------------------------|
|         | BH | = | Display page number (zero-based) |
| Output: | AX | = | 00h                              |
|         | СН | = | Starting cursor scan line        |
|         | CL | = | Ending cursor scan line          |
|         | DH | = | Row number                       |
|         | DL | = | Column number                    |

A different cursor is maintained for each display page. Each of these cursors can be looked at independently with this function, whatever page is currently active. How many display pages are available is defined by the display mode selected.

## Function: AH = 04h Read Light Pen Position

#### Description

This function reads the light pen's status and position. PS/2 systems (including Models 25 and 30) do not support light pen input devices. They are not effective on monochrome monitors with long image-retention phosphor, and the light pen position is not accurate enough for use with high resolution devices.

Input: AH = 04hOutput: AH = 00h Light pen is not supported AL = 00h

All registers except AX are altered on return.

# Function: AH = 05h Select New Video Page

## Description

The Select New Video Page function sets the active page for the video mode selected. Refer to the table under the Video Modes heading for a list of the maximum number of pages allowed for each video mode.

#### Input/Output

Input: AH = 05h AL = New page number (zero-based) Output: None

- All page numbers are zero-based (i.e. page numbers begin at page 0).
- In text modes, page numbers range from 0–7.
- Page 0, located at the beginning of display memory, is used by default in all video modes.
- Switching between pages does not alter their contents. Also, no matter which page is active (currently displayed), text can be written to any video page using INT 10h functions 02h, 09h and 10h.
- In the CGA mode, no video paging is possible.
- In EGA and VGA modes, video pages are available up to the limits of video RAM in both alphanumeric and graphics modes.
- The current cursor position is maintained by the CBIOS for as many as eight video pages.
- An instantaneous screen change can be created by building a screen on an undisplayed page, then using this function to display it.

The Scroll Current Page Up/Down functions employ the CH, DH, CL, and DL registers to define a screen window and allow the contents of the window to be scrolled either up or down by the number of character rows specified in register AL. If AL = 00h, the window is blanked instead of scrolled.

Information appearing on the screen but lying outside the parameters of the defined window remains on the screen. Only one window can be defined at any given time.

These two functions operate in both text and graphics modes.

## Input/Output

| Input: | AH  | = | 06h Scroll current page up<br>07h Scroll current page down         |
|--------|-----|---|--------------------------------------------------------------------|
|        | AL  | = | Scroll distance in character rows<br>(0 blanks entire scroll area) |
|        | вн  | = | Attribute to use on blanked lines                                  |
|        | СН  | = | Top row of scroll window                                           |
|        | CL  | = | Left column of scroll window                                       |
|        | DH  | = | Bottom row of scroll window                                        |
|        | DL  | = | Right column of scroll window                                      |
| 0      | Non | ~ |                                                                    |

Output: None

Use the cursor positioning and character writing services to fill the blank line with text.

#### Initializing a Window

Setting the subfunction register AL = 0 initializes a window on the display screen. Setting the AL register to zero blanks out the region specified by the CX and DX general purpose registers and fills them with the attribute in the BH register.

# Function: AH = 08h Read Character/Attribute from Screen

# Description

The Read Character/Attribute from Screen function reads the character at the current cursor location. For text modes, the attribute is also returned. In graphics modes, the character matrix at the cursor position is compared to the bit patterns in the current graphics character definition table to determine the character's ASCII value. Characters other than standard ASCII characters are returned as AL = 00h.

#### Input/Output

| Input:  | AH<br>BH | 08h<br>Display page (refer to "Video Modes" for maximum<br>pages per mode) |
|---------|----------|----------------------------------------------------------------------------|
| Output: |          | Attribute (text modes only)<br>Character read                              |

- To read a character from any valid display page (other than the active one), specify the display page number.
- Information about the screen is in screen memory and need not be stored in a program.
- This function can be used to read the screen for TSR spelling and thesaurus utilities.

The Write Character/Attribute function writes the character to the screen starting at the current cursor location for as many times as indicated in the CX register. The cursor is not moved even if more than one character is written, unless the same character is repeated.

**Note:** INT 10h functions AH = 09h and AH = 0Ah are similar. AH = 09h should be used for all graphics modes.

# Input/Output

| Input:  | AH   | = | 09h                                                              |
|---------|------|---|------------------------------------------------------------------|
|         | AL   | = | ASCII character to write                                         |
|         | BH   | = | Display page (refer to "Video Modes" for maximum pages per mode) |
|         |      | = | Background color (graphics mode 13h only)                        |
|         | BL   | = | Character attribute (text modes)                                 |
|         |      | = | Foreground color (graphics modes) (i.e. color of character)      |
|         | СХ   | = | Repeat count                                                     |
| Output: | None | Ð |                                                                  |

# Function: AH = 09h Write Character/Attribute to Screen, Continued

- In text modes, the number of repeats placed into CX may exceed the number of columns remaining in a given row. Characters will wrap around from row to row. In graphics modes, the number of repeats placed into CX cannot exceed the number of columns remaining in a given row. Characters will not wrap around from row to row.
- In graphics mode 13h, the color specified in BH determines the screen background color.
- In CGA graphics mode, the bit map used for ASCII characters 80-FFh is stored in a table that starts at 0:7Ch. This value is stored in the vector for INT 1Fh. By resetting the vector, the bit map table location can be changed to point to a different bit map.
- For EGA and VGA graphics modes, use the table whose pointer is stored in the vector for INT 43h. For further information refer to the INT 10h, function AH = 11h AL = 20 and AL = 21 headings in this chapter.
- Any value of AL will produce a display; this includes all control characters (e.g. bell, backspace, CR, LF). These control characters are not interpreted as special characters and do not change the cursor position.
- After a character has been written, the cursor has to be explicitly moved to the next position using INT 10h function 02h.
- To write a character without changing the attribute at the current cursor position, use INT 10h function 0Ah.
- When this function is used to write characters in graphics mode, and with bit 7 of BL set to 1, the character is XORed with the contents of the current display. This feature can be used to write characters and then erase them.

The Write Character Only to Screen function operates identically to the Write Character/Attribute function, except that for text modes the attribute bytes corresponding to the characters remain unchanged. Use this function to write a character to the screen in text modes.

**Note:** Use AH = 09h in graphics modes.

#### Input/Output

| Input:  | AH  | = | 0Ah                              |
|---------|-----|---|----------------------------------|
|         | AL  | = | Character to write (ASCII codes) |
|         | BH  | = | Display page (text modes only)   |
|         | СХ  | = | Repeat count                     |
| Output: | Non | e |                                  |

- Any value of AL will produce a display; this includes all control characters (e.g. bell, backspace, CR, LF). These control characters are not interpreted as special characters and do not change the cursor position.
- After a character has been written, the cursor has to be explicitly moved to the next position using INT 10h function 02h.
- To write a character without changing the attribute at the current cursor position, use INT 10h function 0Ah.
- When this function is used to write characters in graphics mode, and with bit 7 of BL set to 1, the character is XORed with the contents of the current display. This feature can be used to write characters and then erase them.

This function selects colors for medium resolution graphics modes. Depending on the value placed in BH, the Set Color Palette function will perform any of four operations.

If BH = 00h, then the value in BL sets the:

- Background color for 320x200 graphics modes (modes 4, 5)
- Border color for 320x200 text modes (modes 0, 1, 2, 3)
- Foreground color for 640x200 graphics mode (mode 6)

If BH = 01h, then the value in BL sets the palette for 320x200 graphics modes (modes 4, 5).

#### Input/Output

| Input:  | AH   | = | 0Bh                                                   |
|---------|------|---|-------------------------------------------------------|
|         | BH   | = | 00h                                                   |
|         |      | = | if mode = 4, 5, set background color to value in BL   |
|         |      | = | If mode = 0, 1, 2, 3, set border color to value in BL |
|         |      | = | If mode = 6, set foreground color (640x200 graphics)  |
|         |      |   | to value in BL                                        |
|         | BL   | = | (0-31), when colors (16-31 are high intensity         |
|         |      |   | background set)                                       |
|         |      |   | or                                                    |
|         | BH   | = | 01h select palette for modes 4, 5 (320x200 graphics)  |
|         | BL   |   | 00h; Palette = Green (1), Red (2), Brown (3)          |
|         |      | = | 01h; Palette = Cyan (1), Magenta (2), White (3)       |
| Output: | None | Э |                                                       |

- In CGA graphics modes, bit 4 of BL selects between normal and high intensity. EGA and VGA graphics modes emulate this by selecting a palette of high intensity colors when bit 4 of BL is set.
- A flashing display can be set by rapidly changing the palette.
- The background color of text is determined by the high order four bits of the attribute byte of each character.

The Write Pixel function writes to video memory the pixel specified by row and column number in DX and CX. When a given video mode allows more than one page, the (0-based) page number must be indicated in BH.

For all graphics modes except mode 13h, bit 7 of AL acts as an inverter flag. If bit 7 of AH is set, then the color value in AL is exclusively ORed (XOR) with the current pixel. That pixel can be erased by writing it a second time.

Refer to "Video Modes" for a table listing video modes, resolutions, and maximum pages/mode.

#### Input/Output

| Input:  | AH   | = | 0Ch                                             |
|---------|------|---|-------------------------------------------------|
|         | AL   | = | Color (Bit 7 is exclusive OR flag)              |
|         | BH   | = | Page number (Modes allowing more than one page) |
|         | DX   | Ξ | Pixel row number                                |
|         | СХ   | = | Pixel column number                             |
| Output: | None | Э |                                                 |

## **Pixel values**

- In four-color graphics modes (display modes 04h and 05h), pixel values range from 0-3.
- In two-color graphics modes (display mode 06h), pixel values range from 0-1.

# Function: AH = 0Dh Read Pixel

# Description

The Read Pixel function returns the value of an addressed pixel to the low order bits of the AL register. This function can be used for collision detection in video games. It can also be used by advanced graphics programs to detect boundaries when moving a graphics object on the screen.

Refer to "Video Modes" for a table listing video modes, resolutions, and maximum pages/mode.

#### Input/Output

| Input:  | AH | = | 0Dh                                             |
|---------|----|---|-------------------------------------------------|
|         | BH | = | Page number (modes allowing more than one page) |
|         | СХ | = | Column number                                   |
|         | DX | = | Row number                                      |
| Output: | AL | = | Color value of pixel read                       |

#### Pixel values

Display modes 04h, 05h and 06h have valid pixel values in the ranges of 0-3, 0-3 and 0-1 respectively. Refer to "Video Modes" for a table listing video modes, resolutions, and maximum pages/mode.

The Write Teletype function makes the display appear as a serial terminal. Display characters are written to regeneration memory to the active page and the cursor is moved to the next character location (scrolling is necessary). Screen width is a function of the video mode currently in effect.

# Input/Output

| Input:  | AH  | = | 0Eh                                    |
|---------|-----|---|----------------------------------------|
|         | AL  | = | Character to write                     |
|         | BL  | = | Foreground color (graphics modes only) |
| Output: | Non | е |                                        |

## Special characters

The four ASCII characters listed below are not displayed but are interpreted instead as control characters. All other characters (including other control characters) are interpreted as display characters.

| Character | ASCII Code | Function                                                                                                    |
|-----------|------------|-------------------------------------------------------------------------------------------------------------|
| Bell      | 07h        | A beep is sounded.                                                                                          |
| Backspace | 08h        | If the cursor is already on column 0, nothing hap-<br>pens. Otherwise, the cursor moves back one<br>column. |
| LF        | 0Ah        | The cursor moves down one row. If done on the last row of the screen, the display is scrolled one row.      |
| CR        | 0Dh        | The cursor moves to column 0 on the current row.                                                            |

# Additional information

• When working in the active page, this function allows a character to be printed at the current cursor position. After printing the character, the function then moves the cursor to the right one space. If by chance the cursor is moved past the end of the line, the function will wrap the cursor to the next line. Scrolling the screen up one line requires that the cursor be moved past the lower right corner of the screen.

# Function: AH = 0Eh Write Teletype to Active Page, Continued

Additional information, cont'd

- In CGA text mode, characters can be written to any legal display page, no matter which page is active.
- Compare this function with INT 10h, function 13h.
- This is the best function for simple output.

#### DOS uses

DOS uses this function in the console driver for putting operating system text and messages on the screen.

This function does not, however, allow the attribute of a text character to be selected. A way of defining an attribute for a character written to the screen may be defined by

- 1. writing in the ASCII blank character (20h) having the desired attribute to the current position using function 09h, and
- 2. writing the desired character using function 0Eh.

With this method, the user does not have to provide for line wrapping and screen scrolling but can turn these over to the BIOS.

# Function: AH = 0Fh Return Video Status

#### Description

The Return Video Status function returns current display mode information. It gives the mode, screen width in characters, and the display page number.

Refer to "Video Modes" in this chapter for maximum pages per mode.

#### Input/Output

| Input:  | AH       | = | OFh                                                                                                                         |
|---------|----------|---|-----------------------------------------------------------------------------------------------------------------------------|
| Output: | AH       | = | Number of columns on screen from the screen width byte (40:4Ah)                                                             |
|         | AL<br>BH |   | Current mode from the video mode setting byte (40:49h)<br>Active display page number from the display page byte<br>(40:62h) |

# Examples of function's use

Some ways to use this function are

- for finding out the screen width in the current screen mode before clearing the screen.
- to determine the settings of the display system at program initialization so that they can be returned to when the program terminates.
- when writing TSR utilities that pop up on the screen while another application is running. The background application may be running in a different mode than the TSR.

# Function: AH = 10h Set Palette/Color Registers

# Description

The Set Palette/Color Register consists of 14 subfunctions that control operations on the color palette registers within EGA/VGA video controllers. These subfunctions allow control of color, blinking and video DAC.

The 14 subfunctions can be divided into two groups:

- Subfunctions that service the Attribute Controller's Internal Palette
- Subfunctions that service the DAC Color Registers.

#### Subfunctions

|         | Subfunction Name                                                                                         | Programs       |
|---------|----------------------------------------------------------------------------------------------------------|----------------|
| 00h     | Set single palette register                                                                              | Atrib. Contrl. |
| 01h*    | Set overscan register                                                                                    | Atrib. Contrl. |
| 02h*    | Set all palette registers and overscan                                                                   | Atrib. Contrl. |
| 03h*    | Toggle intensify/blinking bit                                                                            | Atrib. Contrl. |
| 04h-06h | Reserved                                                                                                 | Atrib. Contrl. |
| 07h*    | Read individual palette register                                                                         | Atrib. Contrl. |
| 08h     | Read overscan register                                                                                   | Atrib. Contrl. |
| 09h     | Read all palette registers and overscan register                                                         | Atrib. Contrl. |
| 10h     | Set individual color register                                                                            | DAC            |
| 11h     | Reserved                                                                                                 | DAC            |
| 12h     | Set block of color registers                                                                             | DAC            |
| 13h*    | Select color paging mode (not valid for mode 13h)<br>BL = 00h Select paging mode<br>BL = 01h Select page | DAC            |
| 14h     | Reserved                                                                                                 | DAC            |
| 15h     | Read single DAC color register                                                                           | DAC            |
| 16h     | Reserved                                                                                                 | DAC            |
| 17h     | Read block of color registers                                                                            | DAC            |
| 18h-19h | Reserved                                                                                                 | DAC            |
| 1Ah     | Read color paging status                                                                                 | DAC            |
| 1Bh     | Sum color values to gray shades                                                                          | DAC            |

## Reference

For more information on the relationship between the DAC and the Attribute Controller, refer to the Hardware Environment heading in this chapter.

#### Error Handling

The CBIOS Video Service checks for valid parameters upon entry into each subfunction. If invalid parameters are detected the subfunction returns with all registers preserved.

#### Subfunction: AL = 00h Set single palette

This subfunction sets a single color value in the Attribute Controller's 16-value internal palette. Each palette register value points to one location among the 256 DAC color registers. This subfunction exits without processing if the current mode is 13h.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) equipped with MCGA graphics, input BX = 0712h. This will define a color register set that results in eight consistent colors.

| Input: | AH | = | 10h                    |
|--------|----|---|------------------------|
|        | AL | = | 00h set single palette |
|        | BL | = | Palette register       |
|        | BH | = | New color value        |
| _      |    |   |                        |

Output: None

#### Subfunction: AL = 01h Set overscan register

This subfunction sets the overscan color (screen border) for the current video modes.

Input: AH = 10h AL = 01h BH = Color value to set Output: None

# Function: AH = 10h Set Palette/Color Registers, Continued

## Subfunction: AL = 02h Set all palette registers and overscan (border color)

This subfunction sets all 16 Attribute Controller internal palette registers, as well as the overscan register (11h), to the values pointed to by the 17-byte table by ES:BX. It exits without processing if the current mode is 13h.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) with MCGA graphics, this subfunction is not supported.

Input: AH = 10h AL = 02h ES:DX = Pointer to 17-byte table, where: Byte 16 = Overscan value (border color) Bytes 15-0 = Palette values

Output: None

#### Subfunction: AL = 03h Toggle intensity/blink bit

This subfunction sets either the background intensity or the foreground blinking for CGA, EGA, and VGA modes.

Input: AH = 10h AL = 03h BL = 00h Enable background intensity = 01h Enable foreground blinking Output: None

#### Subfunctions: AL = 04h to 06h

These subfunctions are reserved.

### Subfunction: AL = 07h Read individual palette register

This subfunction reads the color value of the register input into BL and returns that value in BH.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) with MCGA graphics, this subfunction is not supported.

Input: AH = 10h AL = 07h BL = Palette register to be read (Range 0-15)Output: BH = Value read

#### Subfunction: AH = 08h Read overscan register (border color)

This subfunction reads the color value stored in the overscan register of the current color palette. This value defines the current border color.

Input: AH = 10hAL = 08hOutput: BH = Value read

# Subfunction: AH = 09h Read all palette registers and overscan register (border color)

This subfunction reads the contents of the current palette register and the overscan register and outputs the contents to a table pointed to by ES:DX. The table pointed to by ES:DX must be 17 bytes long.

| Input:  | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                                                  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------|
| ES:DX:  | Pointer to 17-byte buffer for return values                                                                                           |
| Output: | ES:DX = Pointer to 17-byte table destination, where:<br>Byte 16 = Overscan value (border color)<br>Bytes 15-0 = Register color values |

# Function: AH = 10h Set Palette/Color Registers, Continued

# Subfunction: AL = 10h Set individual color register

This subfunction reads in a table of RGB color values from the area pointed to by ES:DX. The number of the first DAC color register to set is specified in BX. The total number of color registers to set is specified in CX. Each red, green, and blue entry must be one byte long.

Bits 7-6 are "don't care" bits. Bits 5-0 are set as 3Fh (most intense) to 00h (off).

| Input: | AH | = | 10h                                            |
|--------|----|---|------------------------------------------------|
|        | AL | = | 10h                                            |
|        | ΒX | = | Color register to set                          |
|        | DH | = | Red value to set, where:                       |
|        |    |   | Bits 7-6 = Reserved                            |
|        |    |   | Bits 5-0 = 3Fh Most intense; 00h = Off (black) |
|        | СН | = | Green value to set, where:                     |
|        |    |   | Bits 7-6 = Reserved                            |
|        |    |   | Bits 5-0 = 3Fh Most intense; 00h = Off (black) |
|        | CL | = | Blue value to set, where:                      |
|        |    |   | Bits 7-6 = Reserved                            |
|        |    |   | Bits 5-0 = 3Fh Most intense; 00h = Off (black) |
|        |    |   |                                                |

#### Output: None

With gray scale summing selected, the weighted sum gray shade value is calculated and saved to each of the three RGB parts of the color register. See INT 10h, function 10h, subfunction 1Bh for a description of this calculation.

#### Subfunction: AL = 11h

This subfunction is reserved.

# Subfunction: AL = 12h Set block of color registers

This subfunction sets a consecutive series of DAC color registers. Input the number of the first color register to set in BX, the number of color registers to set in CX, and the pointer to the table of color values in ES:DX.

Input: AH = 10h AL = 12h BX = First color register to set CX = Number of color registers to set ES:DX = Pointer to table of color values. Table format is red, green, blue, red, green, blue

## Output: None

With gray scale summing selected, the weighted sum gray shade value is calculated and saved to each of the three RGB parts of the color register. See INT 10h, function 10h, subfunction 1Bh for a description of this calculation.

# Function: AH = 10h Set Palette/Color Registers, Continued

#### Subfunction: AL = 13h Select color paging mode

The DAC chip contains 256 color registers. In all modes except mode 13h (i.e., 256-color graphics), the DAC color registers can be logically divided into four blocks, each containing 64 color registers, or into 16 blocks, each containing 16 color registers.

Depending on the value placed into BL, this subfunction performs two operations:

- When BL = 00h, the value placed in BH selects whether the 256 DAC color registers will be logically divided into four blocks of 64 color registers or into 16 blocks of 16 color registers.
- When BL = 01h, the value placed in BL selects an individual block of color registers. When in four-block mode, the allowable range for BH is 00h-03h. When in 16-block mode, the allowable range for BH is 00h-0Fh.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) with MCGA graphics, this subfunction is not supported.

| Input: | AH | = | 10h                               |
|--------|----|---|-----------------------------------|
| J.     | AL | = | 13h                               |
|        | BL | = | 00h Set block mode                |
|        | BH | = | 00h Set 4 blocks of 64 registers  |
|        |    | = | 01h Set 16 blocks of 16 registers |
|        | or |   |                                   |
|        | BL | = | 01h Select individual block       |
|        | BH | = | 00h-03h for 4-block mode          |
|        |    |   | 00h–0Fh for 16–block mode         |
|        |    |   |                                   |

#### Output: None

The Set Mode functions (AH = 10h, AL = 00h) defaults to the 64 register/ block mode, initializing only the first block of 64 color registers. Alternate blocks of color registers are initialized through the select paging mode subfunction (AH = 10h, AL = 13h, BL = 00h). Alternate blocks of color registers must be initialized for the "select page" subfunction (AH = 10h, AL = 13h, BL = 01h) to operate properly.

#### Subfunction: AL = 14h

This subfunction is reserved.

#### Subfunction: AL = 15h Read single DAC color register

This subfunction reads an individual DAC color register.

| Input:  | AH | = | 10h                    |
|---------|----|---|------------------------|
|         | AL | = | 15H                    |
|         | BX | = | Color register to read |
| Output: | СН | = | Green value            |
|         | CL | = | Blue value             |
|         | DH | = | Red value              |

#### Subfunction: AL = 16h

This subfunction is reserved.

#### Subfunction: AL = 17h Read block of color registers

This subfunction reads a block of DAC color registers to the buffer area pointed to by ES:DX.

Input: AH = 10h AL = 17h BX = Which DAC color register begins block CX = Total number of color registers to read ES:DX = Pointer to buffer to save register information in. (3 bytes per color register). Format as red byte, green byte, blue byte...)

Output: ES:DX = Pointer to values read

# Subfunctions: AL = 18h to 19h

These subfunctions are reserved.

# Function: AH = 10h Set Palette/Color Registers, Continued

#### Subfunction: AL = 1Ah Read color paging status

This subfunction returns the current color paging mode as well as the current color page within this mode. See INT 10h, function 10h, subfunction 13h, Select color paging mode.

**Models 25 and 30:** In IBM PS/2 Models 25 and 30 (and compatibles) with MCGA graphics, this subfunction is not supported.

| Input:  | AH | = | 10h                            |
|---------|----|---|--------------------------------|
|         | AL | = | 1Ah                            |
| Output: | BH | = | Current page                   |
|         | BL | = | Current paging mode            |
|         |    | = | 00h (4 pages of 64 registers)  |
|         |    | = | 01h (16 pages of 16 registers) |

#### Subfunction: AL = 1Bh Sum color values to gray shades

This subfunction reads the red, green, and blue values stored in the specified color registers and performs the following weighted sum:

Gray Shade = 30% red + 59% green + 11% blue

The resulting red, green, and blue values are written to the specified color registers. The original contents of each register are not retained.

| Input: | AH | = | 10h                          |
|--------|----|---|------------------------------|
|        | AL | = | 1Bh                          |
|        | BX |   | Color register to start with |
|        | СХ | = | Count of how many to sum     |

The Character Generator function consists of 14 subfunctions, all of which, in one way or another, permit the loading and/or enabling of text mode and graphics mode character generators (fonts).

For more information on text and graphics modes character generators, turn to the ROM Character Generators heading near the beginning of this chapter.

#### Character generator subfunctions

The Character Generator subfunctions are invoked by passing the proper parameter in the AL register. The subfunctions are listed in the table below:

| AL Value               | Subfunction Name                                              |
|------------------------|---------------------------------------------------------------|
| 00h                    | Load user text mode font                                      |
| 01h                    | Load ROM 8x14 text mode font                                  |
| 02h                    | Load ROM 8x8 text mode font                                   |
| 03h                    | Set block specifier (text modes only)                         |
| 04h                    | Load ROM 8x16 text mode font                                  |
| 10h*                   | Load user text mode font (after mode set)                     |
| 11h*                   | Load ROM 8x14 text mode font (after mode set)                 |
| 12h*                   | Load 8x8 double dot text mode font (after mode set)           |
| 14h*                   | Load ROM 8x16 text mode font (after mode set)                 |
| 20h*                   | Set user graphics character pointer at INT 1Fh (8x8 font)     |
| 21h                    | Set user graphics character pointer at INT 43h                |
| 22h                    | Use ROM 8x14 font at INT 43h for graphics                     |
| 23h                    | Use ROM 8x8 font at INT 43h for graphics                      |
| 24h                    | Use ROM 8x16 font at INT 43h for graphics                     |
| 30h                    | Get font pointer information                                  |
| * Not supported on IBM | 1 PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. |

#### Subfunction: AL = 00h Load user text mode font

This subfunction loads a user-defined font into the memory map 2 block specified in BL. The user font must be stored in a table pointed to by ES:BP, with the ASCII character ID or the first character specified in DX.This function is for fonts in text display mode. For fonts in graphics mode, see INT 10h, function 11h, subfunctions 20h-24h.

| Input:         | H = 11h                                            |  |
|----------------|----------------------------------------------------|--|
|                | L = 00h                                            |  |
|                | H = Number of bytes per character                  |  |
|                | L = Block to load (valid values are 0-7)           |  |
|                | X = Number of characters to store                  |  |
|                | X = Character ID of first character in ES:BP table |  |
|                | S:BP = Pointer to the user table                   |  |
| <b>•</b> • • • |                                                    |  |

#### Output: None

Scan lines per character, number of character rows, buffer length, and cursor size are not recalculated by this subfunction. The user-defined font loaded here must occupy the same character box size as the mode the font will be displayed under.

# Subfunction: AL = 01h Load ROM 8x14 text mode font

This subfunction loads the ROM-resident 8x14 font into the memory map 2 block indicated in BL. Use this subfunction to override the CBIOS default character block location for 8x14 character video modes. For fonts in graphics mode, see INT 10h, function 11h, subfunctions 20h-24h.

**Models 25 and 30:** This function is not available on IBM PS/2 Models 25 and 30 with MCGA. If called, AL = 04h is executed.

Input: AH = 11h AL = 01h BL = Block to load (valid values are 0-7) Output: None

## Subfunction: AL = 02h Load 8x8 double dot text mode font

This subfunction loads the ROM-resident 8x8 font into the character block indicated in BL. Use this subfunction to override the CBIOS default character block location for 8x8 character video modes. For fonts in graphics mode, see INT 10h, function 11h, subfunctions 20h-24h.

Input: AH = 11h AL = 02h BL = Block to load (valid values are 0-7) Output: None

#### Subfunction: AL = 03h Set block specifier (text modes only)

VGA-compatible hardware allows the user to display up to 512 text mode characters at a time. However, in text modes, all character font bit patterns are stored in 8K blocks in video memory map 2. Each 8K block can store up to 256 characters. In order to display 512 text mode characters, then, special steps need to be taken to allow end user software to select between either of two possible 8K character blocks.

This subfunction sets up the video hardware so that bit 3 of each text mode attribute byte can select between either of two memory map 2 character blocks, thus allowing up to 512 characters to be displayed in any text mode. Characters are selected according to the rules below:

- The value of bits 4, 1, 0 of BL set by this subfunction indicates the first character block; the value of bits 5, 3, and 2 in BL indicates the second character block.
- The value of bit 3 of each character attribute byte determines from which character block a given ASCII character will be selected.
  - When bit 3 = 0, the character is selected from the block defined by bits 4, 1, and 0 that input into BL.
  - When bit 3 = 1, the character is selected from the block defined by bits 5, 3, and 2 of BL.
- If bits 4, 1, 0 = bits 5, 3, 2, then bit 3 of the character attribute byte toggles foreground intensity on or off. When two character blocks are selected, function call AX = 1000h BX = 0712h will ensure that eight consistent color planes are set.
- **Note:** To make a loaded character block active, this subfunction must be run after any load character block subfunction.

Input: AH = 11h AL = 03h BL = Select character block (see description above) Output: None

#### Subfunction: AL = 03h Set block specifier (text modes only), cont'd

**Models 25 and 30** - On IBM PS/2 Models 25 and 30 (and compatibles) equipped with MCGA hardware, the following rules apply:

- The values of Bits 1 and 0 in BL indicate the first character block; the values of bits 3 and 2 indicate the second character block.
- The value of bit 3 of each character attribute byte determines from which character block a given ASCII character will be selected. When bit 3 = 0, the character is selected from the block defined by BL bits 1 and 0. When bit 3 = 1, the character is selected from the block defined by BL bits 3 and 2.
- If BL bits 1 and 0 = bits 3 and 2, then bit 3 of the attribute byte turns foreground intensity on and off.

# Subfunction: AL = 04h Load 8x16 ROM text mode font

This subfunction loads the ROM-resident 8x16 font into the character block indicated in BL. Use this subfunction to override the CBIOS default character block for 8x16 character block modes. For fonts in graphics mode, see INT 10h, function 11h, subfunctions 20h-24h.

Input: AH = 11h AL = 04h BL = Block to load (valid values are 0-7) Output: None

.....

#### Description: Subfunctions: AL = 10h, 11h, 12h, 14h

Subfunctions AL = 10h, 11h, 12h, and 14h, respectively, are identical to subfunctions AL = 00h, 01h, 02h, and 04h except for the following:

- Page 0 is active
- Bytes per character (points) are recalculated
- Number of rows is recalculated
- Display buffer length is calculated
- CRTC registers below are reprogrammed:
  - Index 09h Maximum scan line index
  - 0Ah Cursor start index
  - 0Bh Cursor end index
  - 12h Vertical displacement end index
  - 14h Underline location (mode 07h only)

**Models 25 and 30:** These subfunctions are not available on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, AL = 10h executes AL = 00h; AL = 11h executes AL = 01h; AL = 12h executes AL = 02h, and AL = 14h executes AL = 04h.

#### Notes:

- The registers programmed by subfunctions 10h, 11h, 12h, and 14h are a subset of all VGA CRTC registers. Because of this, the font downloaded by each of these subfunctions must be relatively close in size to the default font associated with the current video mode. To prevent unpredictable results, these subfunctions should only be called after a mode set call (i.e., INT 10h AH = 00h Set Mode).
- These functions are for fonts in text display mode. For fonts in graphics mode, see INT 10h, function 11h, subfunctions 20h-24h.

### Subfunction: AL = 10h Load user text mode font (after mode set)

This subfunction loads the user character set defined in the table pointed to by ES:BP to the character block indicated BL.

**Models 25 and 30:** This subfunction is not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, subfunction AL = 10h executes AL = 00h.

Input: AH = 11h AL = 10h BH = Number of bytes per character BL = Block to load (valid values are 0-7) CX = Number of characters to store DX = Character ID of first character in ES:BP table ES:BP = Pointer to table

#### Output: None

The registers programmed by subfunction 10h are a subset of all VGA CRTC registers. Because of this, the font downloaded by this subfunction must be relatively close in size to the default font associated with the current video mode. To prevent unpredictable results, these subfunctions should only be called after a mode set call (i.e., INT 10h AH = Set Mode).

## Subfunction: AL = 11h Load ROM 8x14 text mode font (after mode set)

This subfunction loads the ROM 8x14 font into the character block indicated in BL. Bytes/characters (point size), number of display rows, cursor and underline parameter, and display buffer length are recalculated. Use this subfunction to override the CBIOS-defined font for the text mode in question.

**Models 25 and 30:** This subfunction is not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, subfunction AL = 11h executes AL = 01h.

Input: AH = 11h AL = 11hBL = Block to load (valid values are 0-7)

Output: None

The registers programmed by subfunction 11h are a subset of all VGA CRTC registers. Because of this, the font downloaded by this subfunction must be relatively close in size to the default font associated with the current video mode. To prevent unpredictable results, these subfunctions should only be called after a mode set call (i.e., INT 10h AH = Set Mode).

# Subfunction: AL = 12h Load ROM 8x8 double dot text mode font

This subfunction loads the ROM 8x8 font into the character block indicated in BL. Bytes/character (point size), number of display rows, cursor and underline parameters, and display buffer length are recalculated. Use this subfunction to override the BIOS-defined font for the text mode in question.

**Models 25 and 30:** This subfunction is not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, subfunction AL = 12h executes AL = 02h.

Input: AH = 11h AL = 12hBL = Block to load

Output: None

The registers programmed by subfunction 12h are a subset of all VGA CRTC registers. Because of this, the font downloaded by this subfunction must be relatively close in size to the default font associated with the current video mode. To prevent unpredictable results, these subfunctions should only be called after a mode set call (i.e., INT 10h AH = Set Mode).

#### Subfunction: AL = 14h load ROM 8x16 text mode font

This subfunction loads the ROM 8x16 font into the character block indicated in BL. Bytes/character (point size), number of display rows, cursor and underline parameters, and display buffer length are recalculated. Use this subfunction to override the BIOS-defined font for the text mode in question.

**Models 25 and 30:** This subfunction is not supported on IBM PS/2 Models 25 and 30 and compatibles with MCGA hardware. If called, subfunction AL = 14h executes AL = 04h.

Input: AH = 11h AL = 14h BL = Block to load

Output: None

The registers programmed by subfunction 14h are a subset of all VGA CRTC registers. Because of this, the font downloaded by this subfunction must be relatively close in size to the default font associated with the current video mode. To prevent unpredictable results, these subfunctions should only be called after a mode set call (i.e., INT 10h AH = Set Mode).

# Description: Subfunctions: AL = 20h, 21h, 22h, 23h, 24h

Subfunctions AL = 20h, 21h, 22h, 23h, and 24h all deal with fonts that are used in graphics modes. For functions that deal with fonts in text display mode, see INT 10h, function 11h, subfunctions 00h-14h.

To prevent unpredictable results, subfunctions AL = 20h, 21h, 22h, 23h, and 24h should be called only immediately after a mode set (INT 10h, AH = 00h, AL = mode to select).

# Subfunction: AL = 20h Set user graphics font pointer at INT 1Fh (8x8 font)

This subfunction sets the graphics font pointer to the vector contained in INT 1Fh. The INT 1Fh vector is specified in ES:BP. The font table pointed to is used by applications programs running in graphics modes 04h–06h (CGA only) for character codes 80h–FFh.

Input: AH = 11h AL = 20h ES:BP = User graphics font pointer (INT 1Fh is set to the vector contained in ES:BP)

Output: None

Notes:

- The character generators for all graphics modes are contained within the CBIOS. The ROM BIOS-based character generators for graphics modes 0Dh to 13h contain all 256 ASCII characters.
- The character generators for graphics modes 04h, 05h, and 06h, (CGA-compatible graphics modes), contain only the first 128 ASCII characters. The remaining 128 ASCII characters (extended ASCII characters 80h-FFh) may be supplied by the user. All user-supplied character sets must be vectored at a memory location pointed to by INT 1Fh. In general, these user-supplied character sets are built into an 8x8 character box.
- The DOS command GRAFTABL loads a graphic table which allows modes 04h, 05h, and 06h to display extended ASCII characters. Vectoring INT 1Fh to point at the DOS GRAFTABL graphics table is the usual method of providing user-supplied extended ASCII characters. For more information, refer to the MS-DOS technical reference manual.

# Subfunction: AL = 21h Set user graphics font pointer at INT 43h (EGA/VGA only)

This subfunction sets the graphics font pointer to the vector contained in INT 43h. To avoid unpredictable results, this function should be called only after a mode set (INT 10h, AH = 00h Set Video Mode). The INT 43h vector is specified in ES:BP.

| Input:  | AH    | = 11h                           |
|---------|-------|---------------------------------|
|         | AL    | = 21h                           |
|         | BL    | = Rows on screen specifier      |
|         |       | = 00h if user-supplied          |
|         |       | 01h = 14 (0Eh) rows             |
|         |       | 02h = 25 (19h) rows             |
|         |       | 03h = 43 (2Bh) rows             |
|         | ĊX    | = Points (bytes/character)      |
|         | DL    | = Rows per screen (if BL = 00h) |
|         | ES:BP | = Pointer to user table         |
| Output: | None  |                                 |

# Subfunction: AL = 22h Use ROM 8x14 font for graphics

This subfunction specifies the use of the ROM-based 8x14 font in EGA and VGA graphics modes. Use it to display the 8x14 font in non-8x14 font graphics modes. To avoid unpredictable results, this function should be called only after a mode set (INT 10h, AH = 00h Set Video Mode). This Subfunction should be used in conjunction with subfunction AH = 11h, AL = 21h, Set User Graphics Font Pointer at INT 43h.

**Models 25 and 30:** This subfunction is not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, AL = 22h executes subfunction AL = 24h.

Input: AH = 11h AL = 22h BL = Row specifier  $= 00h ext{ if user-supplied}$   $01h = 14 ext{ (0Eh) rows}$   $02h = 25 ext{ (19h) rows}$   $03h = 43 ext{ (2Bh) rows}$   $DL = Rows per screen ext{ (if } BL = 00h)$ : Output: None

#### Subfunction: AL = 23h Use ROM 8x8 double dot font for graphics

This subfunction specifies the use of the ROM-based 8x8 font in EGA and VGA graphics modes. Use it to display the 8x8 font in non-8x8 font graphics modes. To avoid unpredictable results, this function should be called only after a mode set (INT 10h, AH = 00h Set Video Mode). This subfunction should be used in conjunction with subfunction AH = 11h, AL = 21h, Set User Graphics Font Pointer at INT 43h.

| Input:  | AH  | = | 11h                           |
|---------|-----|---|-------------------------------|
|         | AL  | = | 23h                           |
|         | BL  | = | Row specifier                 |
|         |     | = | 00h if user-supplied          |
|         |     |   | 01h = 14 (0Eh) rows           |
|         |     |   | 02h = 25 (19h) rows           |
|         |     |   | 03h = 43 (2Bh) rows           |
|         | DL  | = | Rows per screen (if BL = 00h) |
| Output: | Non | е |                               |

# Subfunction: AL = 24h Use ROM 8x16 font for graphics

This subfunction specifies the use of the ROM-based 8x16 font in EGA and VGA graphics modes. Use it to override to display the 8x16 font in non-8x16 font graphics modes. To avoid unpredictable results, this function should be called only after a mode set (INT 10h, AH = 00h Set Video Mode). This sub-function should be used in conjunction with subfunction AH = 11h, AL = 21h, Set User Graphics Font Pointer at INT 43h.

Input: AH = 11h AL = 24h BL = Row specifier  $= 00h ext{ if user-supplied}$   $01h = 14 (0Eh) ext{ rows}$   $02h = 25 (19h) ext{ rows}$   $03h = 43 (2Bh) ext{ rows}$   $DL = Rows ext{ per screen (if BL = 00h)}$ Output: None

#### Subfunction: AL = 30h Get font pointer information

This subfunction returns font pointer information. The pointer information desired is requested in the BH register. To avoid unpredictable results, this subfunction should be issued immediately after a mode set.

**Models 25 and 30:** IBM PS/2 Models 25 and 30 and compatibles equipped with MCGA hardware do not support 9x14 or 9x16 dot fonts. Calling this function with BH = 05h or 07h yields undefined results.

| Input:  | AH    | = 11h                                                 |
|---------|-------|-------------------------------------------------------|
|         | AL    | = 30h                                                 |
|         | BH    | = Font pointer, where:                                |
|         |       | = 00h Return current INT 1Fh pointer                  |
|         |       | = 01h Return current INT 43h pointer                  |
|         |       | = 02h Return ROM font 8x14 pointer                    |
|         |       | = 03h Return current ROM 8x8 font pointer             |
|         |       | = 04h Return current ROM 8x8 font pointer (top)       |
|         |       | = 05h Return current ROM 9x14 font alternate          |
|         |       | = 06h Return current ROM 8x16 font pointer            |
|         |       | = 07h Return current ROM 9x16 font alternate          |
|         |       | = >07h Returns all registers (including AX) preserved |
| Output: | СХ    | = Bytes per character                                 |
| -       | DL    | = Maximum number of rows on screen                    |
|         | ES:BF | P = Pointer to character table                        |

#### Description

The Alternate Select function contains several subfunctions. Each subfunction allows the user to enable or disable certain operations which are standard video mode defaults. For example, the Video Service automatically programs the DAC color registers each time the video mode is set. Alternate Select subfunction AL = 31h allows the user to selectively enable or disable DAC programming on mode set.

#### Alternate select subfunctions

| BL Value                                                                           | Subfunction Name                                       |  |  |  |
|------------------------------------------------------------------------------------|--------------------------------------------------------|--|--|--|
| 10h*                                                                               | Return VGA information                                 |  |  |  |
| 20h                                                                                | Switch to alternate print screen routine               |  |  |  |
| 30h*                                                                               | Select scan lines for text modes                       |  |  |  |
| 31h                                                                                | Enable/disable default palette loading during mode set |  |  |  |
| 32h                                                                                | Enable/disable video                                   |  |  |  |
| 33h                                                                                | Enable/disable summing to gray shades                  |  |  |  |
| 34h*                                                                               | Enable/disable cursor scaling                          |  |  |  |
| 35h                                                                                | Switch display                                         |  |  |  |
| 36h*                                                                               | Video screen on/off                                    |  |  |  |
| * Not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. |                                                        |  |  |  |

The alternate select subfunctions are listed in the table below:

## Error handling

The Video Service checks for valid parameters upon entry into each alternate select subfunction. If an invalid parameter is detected, the subfunction returns with all registers preserved.

## Subfunction: BL = 10h Return VGA information

This subfunction returns the state of VGA hardware.

**Models 25 and 30:** This function is not available on IBM PS/2 Models 25 and 30 and compatibles with MCGA hardware.

Input: BL = 10h= 00h if VGA color mode Output: BH = 01h if VGA monochrome mode BL = Memory available, where: 00h = 64K available 01h = 128K available 02h = 192K available 03h = 256K available CH = Adapter bits CL = Switch settings

The references to adapter bits and switch settings are retained only for historical reasons. The VGA hardware is not affected. VGA hardware simulates earlier adapter cards in software rather than in hardware. IBM-compatible VGA hardware only gives a software emulation of switches.

### Subfunction: BL = 10h Return VGA information, cont'd

Adapter bits are set from Input Status register 0, responding to output on a given Adapter Control register bit.

| Adapter Bit No. | Adapter Control Output<br>Bit Setting | Input Status Bit No. |
|-----------------|---------------------------------------|----------------------|
| 0               | 0                                     | 5                    |
| 1               | 0                                     | 6                    |
| 2               | 1                                     | 5                    |
| 3               | 1                                     | 6                    |
| 4-7             | unused                                |                      |

The bits of the switch settings byte give the settings of the EGA's configuration DIP switch (where 1 = off, 0 = on). Color = 09h and monochrome = 0Bh.

| Bit No. | Meaning                |
|---------|------------------------|
| 0       | Configuration switch 1 |
| 1       | Configuration switch 2 |
| 2       | Configuration switch 3 |
| 3       | Configuration switch 4 |
| 4-7     | unused                 |

#### Subfunction: BL = 20h Switch to alternate print screen routine

This subfunction sets the INT 05h Print Screen service to the proper alternate Print Screen vector. The default BIOS print screen routine assumes a screen length of 25 lines. This subfunction allows an alternative routine to be selected that supports a screen length other than 25 lines.

Input: AH = 12h BL = 20h Output: None

# Subfunction: BL = 30h Select scan lines for text modes (takes effect on next mode set)

This subfunction sets the number of scan lines to be displayed in text modes. By default, the BIOS sets all text modes to 400 scan lines as part of the power-on self test and initialization (POST) process.

**Models 25 and 30:** This subfunction is not available on IBM PS/2 Models 25 and 30 and compatibles with MCGA hardware.

Input: AH = 12h AL = Number of scan lines, where 00h = 200 scan lines 01h = 350 scan lines 02h = 400 scan linesBL = 30h

**Output:** AL = 12h Function is supported

Notes:

- The number of scan lines indicated in AL will take effect upon the next mode set.
- The BIOS loads the font associated with the mode/scan line combination upon the next mode set.
- 200-line scan modes are double-scanned. Each video line is painted twice before the next new line is begun.

#### Subfunction: BL = 31h Enable/Disable default palette loading during set mode

If Disable Default Palette Loading is selected, no updates are made to the overscan color register, the attribute color registers or the DAC color registers when a video mode is set.

| Input:  | AH | = | 12h                                 |
|---------|----|---|-------------------------------------|
|         | AH | = | 00h                                 |
|         | AL | = | 00h Enable default palette loading  |
|         |    | = | 01h Disable default palette loading |
|         | BL | = | 31h                                 |
| Output: | AL | = | 12h Function supported              |

### Subfunction: BL = 32h Enable/Disable video

This subfunction enables/disables the video I/O port regenerator and the display buffer address decode for the currently active video monitor.

Input: AH = 12h AL = 00h Enable video = 01h Disable video BL = 32h Output: AL = 12h Function supported

#### Subfunction: BL = 33h Enable/Disable summing to gray shades

This subfunction enables/disables gray scale summing that occurs during Mode Set (AH = 00h) and during Set Palette Registers (AH = 10h) for the display that is currently active.

| Input:  | AH | = | 12h                       |
|---------|----|---|---------------------------|
|         | AL | = | 00h Enable summing        |
|         |    | = | 01h Disable summing       |
|         | BL | = | 33h                       |
| Output: | AL | = | 12h Function is supported |

#### Subfunction: BL = 34h Enable/Disable cursor scaling

When cursor scaling is enabled (which is the power-on default), cursor start and end information is scaled to the current character height. See INT 10h, AH = 01h Set Cursor Type for more information on setting cursor type.

**Models 25 and 30:** This function is not available on IBM PS/2 Models 25 and 30 and compatibles with MCGA hardware.

| Input:  | AH | = | 12h                        |
|---------|----|---|----------------------------|
|         | AL | = | 00h Enable cursor scaling  |
|         |    | = | 01h Disable cursor scaling |
|         | BL | = | 34h                        |
| Output: | AL | = | 12h Function is supported  |

#### Subfunction: BL = 35h Switch Display

When there is a conflict between the system video and an adapter video (i.e. overlapping usage of the CBIOS data area and/or hardware capabilities), the adapter video is the power-up default primary video. The system board video remains inactive until switching has been enabled.

To be able to switch, the Disable Video subfunction (AH = 12h, BL = 32H) must be supported by both the adapter and the system board.

- To enable video switching, first call with BL = 35h and AL = 00h to disable the adapter video, then call with AL = 01h to enable system board video.
- Once switching has been enabled, all subsequent switches are done through AL = 02h Disable Active Video and AL = 03h Enable Inactive Video.

| Input: | AH | = | 12h                                                                                    |
|--------|----|---|----------------------------------------------------------------------------------------|
|        | AL | = | 00h Turn off initial video adapter, must have 128-byte                                 |
|        |    |   | save area pointed to by ES:DX                                                          |
|        |    | = | 01h Turn on initial system board video                                                 |
|        |    | = | 02h Disable active video, must have save buffer pointer in ES:DX                       |
|        |    | = | 03h Enable inactive video, must have ES:DX pointer to<br>previously filled save buffer |
|        | BI | = | 35h                                                                                    |

**Output:** AL = 12h function supported

When there is no conflict between the system video and an adapter video board, both video devices are active and use of the display switch subfunction is not necessary.

#### Subfunction: BL = 36h Video screen ON/OFF

This subfunction turns the video screen on or off.

**Models 25 and 30:** This function is not available on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware.

Input: AH = 12h AL = 01h Screen OFF = 00h Screen ON BL = 36hOutput: AL = 12h Function supported

## Description

The Write String function operates similarly to Write Teletype (AH = 0Eh), except that an entire string is handled with each call. The AL register contains two single-bit fields as follows:

| lf           | Then                                                                                                                                                                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AL Bit 0 = 1 | the cursor remains at the last character written.                                                                                                                                                                         |
| AL Bit 0 = 0 | the cursor is restored to where it was before the "write string" operation began.                                                                                                                                         |
| AL Bit 1 = 1 | each string character to be displayed is followed by its attribute.                                                                                                                                                       |
| AL Bit 1 = 0 | carriage return, line feed, backspace, and bell are interpreted as<br>commands rather than as printable characters. The string con-<br>tains only display characters, and the attribute is taken from the<br>BL register. |

#### Input/Output

| Input:  | AH    | = 13h                                              |
|---------|-------|----------------------------------------------------|
|         | ES:BP | = Pointer to start of string                       |
|         | BH    | = Page number (for text modes)                     |
|         | BL    | = Attribute for characters (graphics modes)        |
|         | CX    | = Length of string (attributes don't count)        |
|         | DX    | = Starting cursor position (DH = row, DL = column) |
|         | AL    | = Flags (see above)                                |
| Output: | None  |                                                    |

# Functions: AH = 14h - 19h Reserved

# Function: AH = 1Ah Read/Write Display Combination Code

### Description

The Read/Write Display Combination Code service has two subfunctions, one devoted to reading the display codes and one devoted to writing the display combination codes. In either case, the display code for the active monitor is specified in BL. The display code for the inactive monitor (if any) is specified in BH.

| 1.5                 | Code    | Description                                                     |
|---------------------|---------|-----------------------------------------------------------------|
|                     | 00h     | No display attached                                             |
|                     | 01h     | Monochrome Display Adapter (MDA) with monochrome monitor        |
| 了。」,你们一点了了。"<br>[1] | 02h     | Color Graphics Adapter (CGA) with color monitor                 |
|                     | 03h     | Reserved                                                        |
|                     | 04h     | Enhanced Graphics Adapter (EGA) with color monitor              |
|                     | 05h     | EGA with monochrome monitor                                     |
|                     | 06h     | Professional Graphics Adapter (PGA) with color monitor          |
|                     | 07h     | Video Graphics Array (VGA) with monochrome analog monitor       |
|                     | 08h     | VGA with color analog monitor                                   |
|                     | 09h-0Ah | Reserved                                                        |
|                     | 0Bh     | Multicolor Graphics Array (MCGA) with monochrome analog monitor |
|                     | 0Ch     | MCGA with color analog monitor                                  |
|                     | 0Dh-FEh | Reserved                                                        |
|                     | FFFFh   | Unknown                                                         |

The display codes corresponding to the monitors are listed below.

#### Subfunction: AL = 00h Read display combination code

| Input:  | AH | = | 1Ah                    |
|---------|----|---|------------------------|
|         | AL | = | 00h                    |
| Output: | AL | = | 1Ah Function supported |
|         | BH | = | Inactive display code  |
|         | BL | = | Active display code    |

#### Subfunction: AL = 01h Write display combination code

| Input:  | AH | = 1Ah                                   |     |
|---------|----|-----------------------------------------|-----|
|         | AL | = 01h                                   |     |
|         | BH | = Alternate display code (if an         | ıy) |
|         | BL | <ul> <li>Active display code</li> </ul> |     |
| Output: | AL | = 1Ah — Function supported              |     |

## Function: AH = 1Bh Return Functionality/State Information

#### Description

The Return Functionality/State Information function outputs a table describing the current state of the video hardware to a 40h-byte buffer location pointed to by ES:DI.

#### Input/Output

| Input:  | AH    | = | 1Bh                        |
|---------|-------|---|----------------------------|
|         | BX    | = | 0000h Implementation Type  |
|         | ES:DI | = | Pointer to 40h byte buffer |
| Output: | AL    | = | 1Bh — Function successful  |

Functionality/state information is output to 40h-byte buffer (see description on the following page.

#### **Error conditions**

The CBIOS will accept only one implementation type: BX = 0000h. If a value other than 0000h is input into BX, this function returns the following values:

- AH = 1Bh
- AL = 00h
- All other registers are preserved.

## Structure of the Functionality/State Table

Function AH = 1Bh places the functionality and state of the current video environment in a 40h-byte table pointed to by ES:DI. The structure of the 40h-byte Functionality/State Table is detailed below:

| Offset | Size   | Description                                                                      |  |  |
|--------|--------|----------------------------------------------------------------------------------|--|--|
| DI+00h | Dword  | Segment/offset of static functionality table fixed address                       |  |  |
| Dl+04h | 1 Byte | Video Mode (See the Video Modes table in this chapter for supported video modes) |  |  |
| Dl+05h | 1 Word | Col/row                                                                          |  |  |
| Dl+07h | 1 Word | Display buffer length                                                            |  |  |
| DI+09h | 1 Word | Starting address of buffer                                                       |  |  |
| DI+0Bh | 1 Word | Array of 8 cursor positions                                                      |  |  |
| Dl+1Bh | 1 Word | Cursor type                                                                      |  |  |
| Dl+1Dh | 1 Byte | Active page                                                                      |  |  |
| DI+1Eh | 1 Word | CRT controller base address                                                      |  |  |
| DI+20h | 1 Byte | Current value of 3x8 register                                                    |  |  |
| Dl+21h | 1 Byte | Current value of 3x9 register                                                    |  |  |
| Dl+22h | 1 Byte | Rows on screen                                                                   |  |  |
| Dl+23h | 1 Word | Character height (bytes/character)                                               |  |  |
| DI+25h | 1 Byte | Active display code                                                              |  |  |
| DI+26h | 1 Byte | Inactive display code                                                            |  |  |
| Dl+27h | 1 Byte | Numbers of colors available in current mode                                      |  |  |
| DI+29h | 1 Byte | Display pages supported for current video mode                                   |  |  |

# Function: AH = 1Bh Return Functionality/State Information, Continued

| Offset     | Size     | Description                                                                                                                                                                                                                                                                                                                             |  |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Dl+2Ah     | 1 Byte   | Scan lines in current video mode 00b = 200<br>scan lines 01b = 350<br>scan lines 10b = 400<br>scan lines 11b = 480<br>scan lines 100b - 11111111b<br>Reserved                                                                                                                                                                           |  |  |
| DI+2Bh     | 1 Byte   | Primary character block<br>00b = Block 001b<br>= Block 110b<br>= Block 2 - 1111111b<br>= Block 255                                                                                                                                                                                                                                      |  |  |
| DI+2Ch     | 1 Byte   | Secondary character block<br>00b = Block 001b<br>= Block 110b<br>= Block 2 - 1111111b<br>= Block 255                                                                                                                                                                                                                                    |  |  |
| Dl+2Dh     | 1 Byte   | Miscellaneous state information<br>Bits 7-6 = Reserved<br>Bit 5 = 0 Background intensity<br>= 1 Blinking<br>Bit 4 = 1 Cursor emulation is active<br>Bit 3 = 1 Mode set auto palette loading disabled<br>Bit 2 = 1 Mono display is attached<br>Bit 1 = 1 gray scale summing is active<br>Bit 0 = 1 All modes on all displays active      |  |  |
| DI+2Eh     | 1 Byte   | Reserved                                                                                                                                                                                                                                                                                                                                |  |  |
| DI+2Fh     | 1 Byte   | Reserved                                                                                                                                                                                                                                                                                                                                |  |  |
| DI+30h     | 1 Byte   | Reserved                                                                                                                                                                                                                                                                                                                                |  |  |
| Dl+31h     | 1 Byte   | Video memory available<br>00b = 64K<br>01b = 128K<br>10b = 102K                                                                                                                                                                                                                                                                         |  |  |
|            |          | 10b = 192K<br>11b = 256K                                                                                                                                                                                                                                                                                                                |  |  |
| Dl+32h     | 1 Byte   | Save pointer state information<br>Bits 7-6 = Reserved<br>Bit 5 = 1 Display Combination Code (DCC)<br>extension active<br>Bit 4 = 1 Palette override active<br>Bit 3 = 1 Graphics font override active<br>Bit 2 = 1 Text mode font override active<br>Bit 1 = 1 Dynamic save area active<br>Bit 0 = 1 512-character character set active |  |  |
| DI+33h-3Fh | 13 Bytes | Reserved                                                                                                                                                                                                                                                                                                                                |  |  |

## Structure of the Functionality/State Table, cont'd

#### Structure of the Static Functionality Table

The first entry in the Functionality/State Table is a double word pointer to a 16-byte ROM-based Static Functionality Table.

The Static Functionality Table contains fixed video parameter information. To insure compatibility, the static functionality table is located at E000:305Fh in the CBIOS. The contents of the Static Functionality Table are defined below.

| Offset  | Value | Description                                                                                                                                                                                                                                                           |
|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h     | FFh   | Video modes supported<br>Bit 7 = 1 Mode 7 supported<br>Bit 6 = 1 Mode 6 supported<br>Bit 5 = 1 Mode 5 supported<br>Bit 4 = 1 Mode 4 supported<br>Bit 3 = 1 Mode 3 supported<br>Bit 2 = 1 Mode 2 supported<br>Bit 1 = 1 Mode 1 supported<br>Bit 0 = 1 Mode 0 supported |
| 01h     | F0h   | Video modes supported, ContinuedBit 7= 1 Mode F supportedBit 6= 1 Mode E supportedBit 5= 1 Mode D supportedBit 4= 0 Mode C supportedBit 3= 0 Mode B supportedBit 2= 0 Mode A supportedBit 1= 0 Mode 8 supportedBit 0= 0 Mode 8 supported                              |
| 02h     | 0Fh   | Video modes supported, Continued<br>Bits 7-4 = Reserved<br>Bit 3 = 1 Mode 13 supported<br>Bit 2 = 1 Mode 12 supported<br>Bit 1 = 1 Mode 11 supported<br>Bit 0 = 1 Mode 10 supported                                                                                   |
| 03h-06h | 00h   | Reserved                                                                                                                                                                                                                                                              |
| 07h     | 07h   | Scan line modes available for text modes<br>Bits 7-3 = 00000b Reserved<br>Bit 2 = 1 400 scan lines supported<br>Bit 1 = 1 350 scan lines supported<br>Bit 0 = 1 200 scan lines supported                                                                              |

# Function: AH = 1Bh Return Functionality/State Information, Continued

| Offset  | Value | Description                                                                                                                                                                                                                                                                                                                                          |  |  |
|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 08h     | 02h   | Number of character blocks available in text modes                                                                                                                                                                                                                                                                                                   |  |  |
| 09h     |       | Maximum number of active character blocks avail-<br>able in text modes                                                                                                                                                                                                                                                                               |  |  |
| 0Ah     | FFh   | MiscellaneousBit 7= 1 Color paging supportedBit 6= 1 Color palette supportedBit 5= 1 EGA palette supportedBit 4= 1 Cursor emulation supportedBit 3= 1 Cursor emulation supportedBit 3= 1 Default palette loading supportedBit 2= 1 Character font loading supportedBit 1= 1 gray scale summing supportedBit 0= 1 All modes on all displays supported |  |  |
| 0Bh     | 0Eh   | Miscellaneous, Continued<br>Bits 7-4 = 0000b Reserved<br>Bit 3 = 1 Display combination codes (DCC)<br>supported<br>Bit 2 = 1 Background intensity/blinking control<br>supported<br>Bit 1 = 1 Save/restore supported<br>Bit 0 = 0 Light pen not supported                                                                                             |  |  |
| 0Ch-0Dh | 00h   | Reserved                                                                                                                                                                                                                                                                                                                                             |  |  |
| 0Eh     | 3Fh   | Save pointer functions<br>Bits 7-6 = 00b Reserved<br>Bit 5 = 1 DCC extension<br>Bit 4 = 1 Palette override<br>Bit 3 = 1 Graphics font override<br>Bit 2 = 1 Alpha font override<br>Bit 1 = 1 Dynamic save area<br>Bit 0 = 1 512 Character set supported                                                                                              |  |  |
| 0Fh     | 00h   | Reserved                                                                                                                                                                                                                                                                                                                                             |  |  |

# Structure of the static functionality table, cont'd

# Function: AH = 1Ch Save/Restore Video State

#### Introduction

At any time, the savable portion of the current video state consists of three discrete parts:

| Video State                             | Description                                                                       |  |
|-----------------------------------------|-----------------------------------------------------------------------------------|--|
| Hardware State                          | The contents of the CRT, Attribute, and Graphics Con-<br>troller registers        |  |
| Video BIOS State                        | Those areas in the BIOS Data Area in system RAM con-<br>taining video information |  |
| Digital/Analog<br>Converter (DAC) State | The contents of the DAC control and color registers                               |  |

#### Description

The Save/Restore Video State function consists of three subfunctions that enable the user to save (and subsequently restore) any or all of the three states making up the current video state.

Video state information is stored in system RAM buffer pointed to by ES:BX. The video states (i.e. hardware/BIOS/DAC) to save or restore are selected in CX by setting or clearing Bits 2–0.

#### Save/Restore video state subfunctions

Each of the three Save/Restore Video State subfunctions is selected via the AL register. The table below lists the three subfunctions:

| AL Value | Subfunction Name                       |
|----------|----------------------------------------|
| 00h      | Return Save/Restore buffer size needed |
| 01h      | Save current video state               |
| 02h      | Restore current video state            |

**Models 25 and 30:** This function is not supported on IBM PS/2 Models 25 and 30 (and compatibles) with MCGA hardware. If called, no action is performed.

# Function: AH = 1Ch Save/Restore Video State, Continued

#### Error handling

Upon entry into the Save/Restore Video State function, the CBIOS checks the parameter passed in the AL register. If it is out of range (i.e. greater than 02h), then the function returns with AL = 00h and AH preserved.

#### Buffer format for save/restore video state

The save buffer is composed of a 20h-byte Fixed Offset Area followed by one, two, or three optional areas, depending on which areas (hardware/BIOS/DAC) were specified in CX.

| Offset  | Description                                 |
|---------|---------------------------------------------|
| 00h     | Word offset of hardware save area, if saved |
| 02h     | Word offset of BIOS RAM save area, if saved |
| 04h     | Word offset of DAC save area, if saved      |
| 06h-1Fh | Reserved                                    |

The 20h-byte fixed offset area contains the following information:

## Subfunction AL = 00h Return save/restore buffer size needed

This subfunction returns the buffer size (in 64-byte blocks) needed for any combination of the three video states that can be stored. The video state (or combination of video states) is specified in CX; the buffer size in 64-byte blocks is returned in BX.

| Input:  | AH | = | 1Ch                                                                       |
|---------|----|---|---------------------------------------------------------------------------|
|         | AL | = | 00h                                                                       |
|         | СХ | = | Video state to store, where:                                              |
|         |    |   | Bit 0 = 1 Save video hardware state                                       |
|         |    |   | Bit 1 = 1 Save video BIOS data area                                       |
|         |    |   | Bit 2 = 1 Save video DAC state and color registers                        |
|         |    |   | Bits 3-15 = 0 Reserved                                                    |
| Output: |    |   | 1Ch Function is supported<br>Buffer size block count (1 block = 64 bytes) |
|         |    |   |                                                                           |

## Function: AH = 1Ch Save/Restore Video State, Continued

#### Subfunction: AL = 01h Save current video state

This subfunction stores the video states specified in CX to a system RAM buffer area pointed to by ES:BX.

Input: AH = 1Ch AL = 01h CX = Video state to store, where: Bit 0 = 1 Save video hardware state Bit 1 = 1 Save video BIOS data area Bit 2 = 1 Save video DAC state and color registers Bits 3-15 = 0 Reserved ES:BX = Pointer to system RAM buffer

**Output:** AL = 1Ch Function is supported

#### Warning

Saving a video state alters the original contents of the registers or data areas involved. To maintain the current video state, execute the Restore Video State subfunction immediately after saving the video state.

#### Subfunction: AL = 02h Restore current video state

This subfunction restores the video states specified in CX from the system RAM buffer area pointed to by ES:BX.

| Input:  | AH =    | 1Ch                                                |
|---------|---------|----------------------------------------------------|
|         | AL =    | 02h                                                |
|         | CX =    | Video state to restore, where:                     |
|         |         | Bit 0 = 1 Save video hardware state                |
|         |         | Bit 1 = 1 Save video BIOS data area                |
|         |         | Bit 2 = 1 Save video DAC state and color registers |
|         |         | Bits 3-15 = 0 Reserved                             |
|         | ES:BX = | Pointer to previously saved system RAM buffer      |
| Output: | AL =    | 1Ch Function is supported                          |

#### Structure of hardware state save area

If Bit 0 of the CX register is set and the Save Video State subfunction is executed, then current hardware state is stored to the system RAM buffer pointed to in ES:BX. Executing the Restore Video State subfunction with the same CX and ES:BX values restores the hardware state information to the actual video hardware.

| Offset              | I/O Address                                                             | Index | Description                |  |  |  |
|---------------------|-------------------------------------------------------------------------|-------|----------------------------|--|--|--|
| 00h                 | 03C4h                                                                   |       | Sequencer Index            |  |  |  |
| 01h                 | 3B4h/3D4h*                                                              |       | CRT Controller Index       |  |  |  |
| 02h                 | 03CEh                                                                   |       | Graphics Controller Index  |  |  |  |
| 03h                 | 03C0h                                                                   |       | Attribute Controller Index |  |  |  |
| 04h                 | 03CAh                                                                   |       | Feature Control            |  |  |  |
| SEQUENCER REGISTERS |                                                                         |       |                            |  |  |  |
| 05h                 | 03C5h                                                                   | 01h   | Clocking Mode              |  |  |  |
| 06h                 | 03C5h                                                                   | 02h   | Map Mask                   |  |  |  |
| 07h                 | 03C5h                                                                   | 03h   | Character Map Select       |  |  |  |
| 08h                 | 03C5h                                                                   | 04h   | Memory Mode                |  |  |  |
| 09h                 | 03CCh                                                                   | 00h   | Miscellaneous Output       |  |  |  |
|                     | * 03B4h in Monochrome Emulation Modes<br>03D4h in Color Emulation Modes |       |                            |  |  |  |

The structure of the hardware state save area is as follows:

# Function: AH = 1Ch Save/Restore Video State, Continued

| Offset                   | I/O Address                                | Index | Description                    |  |
|--------------------------|--------------------------------------------|-------|--------------------------------|--|
| CRT CONTROLLER REGISTERS |                                            |       |                                |  |
| 0Ah                      | 3B5h/3D5h*                                 | 01h   | Horizontal Total               |  |
| 0Bh                      | 3B5h/3D5h*                                 | 02h   | Horizontal Display Enable End  |  |
| 0Ch                      | 3B5h/3D5h*                                 | 03h   | Start Horizontal Blanking      |  |
| 0Dh                      | 3B5h/3D5h*                                 | 04h   | End Horizontal Blanking        |  |
| 0Eh                      | 3B5h/3D5h*                                 | 05h   | Start Horizontal Retrace Pulse |  |
| 0Fh                      | 3B5h/3D5h*                                 | 06h   | End Horizontal Retrace         |  |
| 10h                      | 3B5h/3D5h*                                 | 07h   | Vertical Total                 |  |
| 11h                      | 3B5h/3D5h*                                 | 08h   | Overflow                       |  |
| 12h                      | 3B5h/3D5h*                                 | 09h   | Preset Row Scan                |  |
| 13h                      | 3B5h/3D5h*                                 | 0Ah   | Maximum Scan Line              |  |
| 14h                      | 3B5h/3D5h*                                 | 0Ah   | Cursor Start                   |  |
| 15h                      | 3B5h/3D5h*                                 | 0Bh   | Cursor End                     |  |
| 16h                      | 3B5h/3D5h*                                 | 0Ch   | Start Address High             |  |
| 17h                      | 3B5h/3D5h*                                 | 0Dh   | Start Address Low              |  |
| 18h                      | 3B5h/3D5h*                                 | 0Eh   | Cursor Location High           |  |
| 19h                      | 3B5h/3D5h*                                 | 0Fh   | Cursor Location Low            |  |
| 1Ah                      | 3B5h/3D5h*                                 | 10h   | Vertical Retrace Start         |  |
| 1Bh                      | 3B5h/3D5h*                                 | 11h   | Vertical Retrace End           |  |
| 1Ch                      | 3B5h/3D5h*                                 | 12h   | Vertical Display Enable End    |  |
| 1Dh                      | 3B5h/3D5h*                                 | 13h   | Offset                         |  |
| 1Eh                      | 3B5h/3D5h*                                 | 14h   | Underline Location             |  |
| 1Fh                      | 3B5h/3D5h*                                 | 15h   | Start Vertical Blank           |  |
| 20h                      | 3B5h/3D5h*                                 | 16h   | End Vertical Blank             |  |
| 21h                      | 3B5h/3D5h*                                 | 17h   | CRTC Mode Control              |  |
| 22h                      | 3B5h/3D5h*                                 | 18h   | Line Compare                   |  |
|                          | n in Monochrome Ei<br>n in Color Emulatior |       | des                            |  |

## Structure of hardware state save area, cont'd

# Function: AH = 1Ch Save/Restore Video State, Continued

| Offset  | I/O Address                    | Index     | Description                     |  |  |
|---------|--------------------------------|-----------|---------------------------------|--|--|
|         | ATTRIBUTE CONTROLLER REGISTERS |           |                                 |  |  |
| 23h-32h | 03C1h                          | 00h-0Fh   | 00-0F Palette Registers         |  |  |
| 33h     | 03C1h                          | 10h       | Attribute Mode Control Register |  |  |
| 34h     | 03C1h                          | 11h       | Overscan Color Register         |  |  |
| 35h     | 03C1h                          | 12h       | Color Plane Enable Register     |  |  |
| 36h     | 03C1h                          | 13h       | Horizontal PEL Panning Register |  |  |
|         | GRAPH                          | HCS CONTR | OLLER REGISTERS                 |  |  |
| 37h     | 03CFh                          | 00h       | Set/Reset                       |  |  |
| 38h     | 03CFh                          | 01h       | Enable Set/Reset                |  |  |
| 39h     | 03CFh                          | 02h       | Color Compare                   |  |  |
| 3Ah     | 03CFh                          | 03h       | Data Rotate                     |  |  |
| 3Bh     | 03CFh                          | 04h       | Read Map Select                 |  |  |
| 3Ch     | 03CFh                          | 05h       | Graphics Mode Register          |  |  |
| 3Dh     | 03CFh                          | 06h       | Miscellaneous                   |  |  |
| 3Eh     | 03CFh                          | 07h       | Color Don't Care                |  |  |
| 3Fh     | 03CFh                          | 08h       | Bit Mask                        |  |  |
| 40h     | 40:63h                         |           | CRTC Base Address Low           |  |  |
| 41h     | 40:64h                         |           | CRTC Base Address High          |  |  |
| 42h     | AFFFFh                         | 00h       | Plane 0 System Latch            |  |  |
| 43h     | AFFFFh                         | 01h       | Plane 1 System Latch            |  |  |
| 44h     | AFFFFh                         | 02h       | Plane 2 System Latch            |  |  |
| 45h     | AFFFFh                         | 03h       | Plane 3 System Latch            |  |  |

## Structure of hardware state save area, cont'd

#### Structure of video BIOS state save area

If Bit 1 of the CX register is set and the Save Video State subfunction is executed, then the current video BIOS state is stored to the system RAM buffer pointed to in ES:BX. Executing the Restore Video State subfunction with the same CX and ES:BX values restores the video BIOS state information in its location in the BIOS Data Area (0400h-0500h) in system RAM.

#### Video data definitions

The data definitions used by the INT 10h Video services are stored in system RAM in segment 40h and are presented below.

| Location | Size    | Description                                                                                                                                                                   |
|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 49h      | 1 Byte  | Video mode setting.                                                                                                                                                           |
| 4Ah      | 1 Word  | Number of columns on screen.                                                                                                                                                  |
| 4Ch      | 1 Word  | Current page size.                                                                                                                                                            |
| 4Eh      | 1 Word  | Current page address.                                                                                                                                                         |
| 50h      | 8 Words | Cursor position on each page. Two bytes/page.<br>First byte (low order) of each pair is column, sec-<br>ond is row. 0, 0 is upper left corner of screen.                      |
| 60h      | 1 Word  | Cursor type defined as 6845 video chip-compatible<br>starting and ending scan lines. High-order byte<br>holds starting scan line; low-order byte holds end-<br>ing scan line. |
| 62h      | 1 Byte  | Current page number.                                                                                                                                                          |
| 63h      | 1 Word  | 6845-compatible I/O port number for current mode. (Port 03D4h or 03B4h)                                                                                                       |
| 65h      | 1 Byte  | Current mode select register.                                                                                                                                                 |
| 66h      | 1 Byte  | Current palette value.                                                                                                                                                        |
| 84h      | 1 Byte  | Number of rows on screen (24 or 25)                                                                                                                                           |
| 85h      | 1 Word  | Character height (bytes/character)                                                                                                                                            |

## Video data definitions, cont'd

| System RAM<br>Offset (hex) | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 87h                        | 1 Byte | Video control bits, where:<br>Bit 7 = Clear RAM<br>Bit 6,5 = Memory on video hardware as follows:<br>00b = 64K<br>01b = 128K<br>10b = 192K<br>11b = 256K<br>Bit 4 = Not used<br>Bit 3 = 0 If EGA-compatible mode is active<br>Bit 2 = 0 Wait for display enable<br>Bit 1 = 0 If color or ECD monitor is<br>attached to EGA-compatible adapter<br>= 1 If Monochrome monitor is attached to<br>EGA-compatible adapter<br>Bit 0 = 0 If translate cursor video modes<br>0-3 when using ECD monitor in<br>350 line mode |
| 88h                        | 1 Byte | EGA/VGA switch data where:<br>Bits 7-4 = Feature connector bits 3-0, respectively<br>Bits 3-0 = Option switches 3-0, respectively                                                                                                                                                                                                                                                                                                                                                                                  |
| 89h                        | 1 Word | VGA control bits, where:<br>Bit 7 = 200 lines<br>Bits 6-5 = Reserved<br>Bit 4 = 400 lines<br>Bit 3 = No palette load<br>Bit 2 = Mono monitor<br>Bit 1 = Gray scalling<br>Bit 0 = Reserved                                                                                                                                                                                                                                                                                                                          |
| 8Ah                        | 1 Byte | Index to the Display Combination Code table                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| A8h                        | 1 Word | Pointer to video parameter table and overrides (in segment:offset format).                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# Function: AH = 1Ch Save/Restore Video State, Continued

## Structure of DAC state save area

If Bit 2 of the CX register is set and the Save Video State subfunction is executed, then the current state of the DAC is stored to the system RAM buffer pointed to in ES:BX. Executing the Restore Video State subfunction with the same CX and ES:BX values restores the DAC information to the actual DAC hardware.

| Offset | I/O Address | Index | Description           |
|--------|-------------|-------|-----------------------|
| 00h    | 03C7h       |       | Read/Write mode DAC   |
| 01h    | 03C8h       |       | Pixel address         |
| 02h    | 03C6h       |       | Pixel mask            |
| 03h    | 03C9h       | 00h   | Red value color 0     |
| 04h    | 03C9h       | 00h   | Green value color 0   |
| 05h    | 03C9h       | 00h   | Blue value color 0    |
| 06h    | 03C9h       | 01h   | Red value color 1     |
|        |             |       |                       |
| 300h   | 03C9h       | FFh   | Red value color FFh   |
| 301h   | 03C9h       | FFh   | Green value color FFh |
| 302h   | 03C9h       | FFh   | Blue value color FFh  |
| 303h   | 03C1h       | 14h   | Color select register |

The structure of the DAC state save area is as follows:

# Function: AH = 1Dh - FFh Reserved

# Chapter 10 INT 13h Diskette Service

## Overview

#### Description

The CBIOS Diskette Service performs BIOS-level read, write, format, diagnostic, initialization and other operations for up to two internal diskette drives.

#### How diskette services are invoked

The CBIOS Diskette Service is invoked via software INT 13h.

The CBIOS initializes the INT 13h Diskette Service vector to F000:E3FEh, the IBM-compatible entry point. The INT 13h vector resides at address 00:4Ch in the Interrupt Vector Table.

The CBIOS Diskette Service has eleven functions. Individual functions are selected via the AH register.

## Overview, Continued

### When a fixed disk is present

When a fixed disk is installed, the CBIOS automatically redirects all INT 13h Diskette Service requests to INT 40h. This redirection is transparent to end users. End users should continue to invoke INT 13h for both diskette and fixed disk services.

For a discussion of the CBIOS Fixed Disk Service, refer to Chapter 11 of this volume.

#### Summary of diskette functions

The following table summarizes Diskette Service functions:

| Function | Description               |
|----------|---------------------------|
| 00h      | Reset Diskette System     |
| 01h      | Read Diskette Status      |
| 02h      | Read Diskette Sectors     |
| 03h      | Write Diskette Sectors    |
| 04h      | Verify Diskette Sectors   |
| 05h      | Format Diskette Track     |
| 06h-07h  | Reserved                  |
| 08h      | Read Drive Parameters     |
| 09h-14h  | Reserved                  |
| 15h      | Read Drive Type           |
| 16h      | Detect Media Change       |
| 17h      | Set Diskette Type         |
| 18h      | Set Media Type for Format |
| 19h-FFh  | Reserved                  |

## Overview, Continued

#### In this chapter

This chapter focuses on the CBIOS Diskette Service INT 13h. The following topics are discussed:

- Hardware Environment
- Diskette Service I/O Ports
- System RAM Data
- CMOS RAM Data
- ROM BIOS Data
- Error Handling
- Rules for Using CBIOS and ABIOS Diskette Services
- Diskette Service Functions
- INT 0Eh Diskette Hardware Interrupt

## Hardware Environment

#### Hardware assumed

The NEC 765 diskette controller chip (or its equivalent) is used to control the internal and external diskette drives.

#### How diskette drives are identified

Each diskette drive must be identified to the system with a unique number. There are only two valid diskette numbers:

- Diskette drive 0 is number 0
- Diskette drive 1 is number 1

These values must be in DL for most Diskette Service functions.

#### Supported drive types

The CBIOS Diskette Service supports six types of diskette drives:

| Drive Type | Media type | Disk Size | Tracks/Side | Sectors/Track |
|------------|------------|-----------|-------------|---------------|
| 1.44 MB    | 1.44 MB    | 3.5       | 80          | 18            |
| 720K       | 720K       | 3.5       | 40          | 18            |
| 360K       | 360K       | 5.25      | 40          | 9             |
| 320K       | 360K       | 5.25      | 40          | 8             |
| 720K       | 720K       | 5.25      | 80          | 8             |
| 1.2 MB     | 1.2 MB     | 5.25      | 80          | 15            |

#### 360K diskette format compatibility

CBIOS supports 8 or 9 sectors per track and either single-sided or doublesided diskette drives. 360K is the maximum data storage capability for standard double-density diskette drives. 320K, 160K, or 180K diskette capabilities are also supported.

## 5.25 inch diskette compatibility

5.25 inch diskette media can be high density (1.2 MB) or double density (360K). Diskettes written on one type of 5.25 inch drive may or may not be written on or read from using the other type. The following table outlines the possible read/write combinations of 5.25 inch diskette media and drive types.

| Media Type | If diskette was formatted on… | Then it can be read on… | or            | And it can be<br>written to by… |
|------------|-------------------------------|-------------------------|---------------|---------------------------------|
| 360K       | 360K drive                    | 360K drives             | 1.2 MB drives | 360K drives only                |
| 1.2 MB     | 360K drive                    | 360K drives             | 1.2 MB drives | 360K drives only                |

If a high density (1.2 MB) diskette is formatted on a 1.2 MB drive, then it can be read on and written to by 1.2 MB drives only.

The DOS command, format/4, can be used to format a 360K diskette in a 1.2 MB drive. Both 1.2 MB and 360K drives can generally read and write these diskettes.

## 3.5 inch diskette compatibility

The following outlines the possible read/write combinations for 3.5 inch drives and media:

- If a 720K media type diskette is formatted on a 720K drive, then it can be read on either 720K or 1.44 MB drives, but it can only be written to by 720K drives.
- If a 1.44 MB media type diskette is formatted on a 1.44 MB drive, then it can be read on and written to by 1.44 MB drives only.

## Data transfer rates

All supported formats use a 512-byte sector size. Data transfer rates are:

| fränsfer Rate | Diskette Capacity | Drive Capacity | Drive Size |
|---------------|-------------------|----------------|------------|
| 250 Kbs       | 360K              | 360K           | 5.25       |
| 250 Kbs       | 720K              | 720K           | 3.5        |
| 500 Kbs       | 1.2 MB            | 1.2 MB         | 5.25       |
| 300 Kbs       | 360K              | 1.2 MB         | 5.25       |
| 250 Kbs       | 720K              | 1.44 MB        | 3.5        |
| 500 Kbs       | 1.44 MB           | 1.44 MB        | 3.5        |

# **Diskette Service I/O Ports**

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0004h       | R/W                  | DMA channel 2, memory address register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 0005h       | R/W                  | DMA channel 2, transfer count register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 000Ah       | R/W                  | DMA channel 0-3, mask register, where:<br>Bits 7-3= 0 Reserved<br>Bit 2 = 0 Clear mask Bit<br>= 1 Set mask Bit<br>Bits 1-0= 00b Select channel 0<br>= 01b Select channel 1<br>= 10b Select channel 2<br>= 11b Select channel 3                                                                                                                                                                                                                                                                                                                            |  |
| 000Bh       | W                    | DMA channel 0-3, mode register, where:         Bits 7-6= 00b Demand mode         = 01b Signal mode         = 10b Block mode         = 11b Cascade mode         Bit 5 = 0 Address increment select         = 1 Address decrement select         Bit 4 = 0 Autoinitialization disable         = 1 Autoinitialization enable         Bits 3-2= 00b Verify operation         = 01b Write to memory         = 10b Read from memory         = 11b Reserved         Bits 1-0= 00b Channel 0 select         = 01b Channel 1 select         = 10b Channel 3 select |  |
| 000Ch       | w                    | DMA Clear Byte Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 0070h       | W                    | CMOS RAM address register port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 0081h       | R/W                  | DMA channel 2, page register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 03F0h       | R                    | Diskette controller status register A, where:<br>Bit 7 = 1 Interrupt pending<br>Bit 6 = 0 Second drive installed<br>Bit 5 = 1 Step<br>Bit 4 = 1 Track 0<br>Bit 3 = 1 Head 1 select<br>Bit 2 = 0 Index<br>Bit 1 = 0 Write protect<br>Bit 0 = 1 Direction                                                                                                                                                                                                                                                                                                   |  |

# Diskette Service I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                          |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03F1h       | R                    | Diskette controller status register B, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Reserved<br>Bit 5 = 0 Drive 0 select<br>Bit 4 = Write data<br>Bit 3 = Read data<br>Bit 2 = 1 Write enable<br>Bit 1 = 1 Motor enable 1<br>Bit 0 = 1 Motor enable 0                                                                   |
| 03F2h       | W                    | Diskette controller digital output register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Reserved<br>Bit 5 = 1 Motor enable 1<br>Bit 4 = 1 Motor enable 0<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Controller reset<br>Bit 1 = 0 Reserved<br>Bit 0 = 0 Drive select 0<br>= 1 Drive select 1                                  |
| 03F4h .     | R                    | Diskette controller status register, where:Bit 7= 1 Data register is ready for transferBit 6= 1 Transfer is from controller to system<br>= 0 Transfer is from system to controllerBit 5= 1 Non-DMA modeBit 4= 1 Diskette controller busyBit 3= 0 ReservedBit 2= 0 ReservedBit 1= 1 Drive 1 busyBit 0= 0 Drive 0 busy |
| 03F5h       | R/W                  | Diskette controller data registers                                                                                                                                                                                                                                                                                   |
| 03F7h       | R                    | Digital input register, where:<br>Bit 7 = 1 Diskette change<br>Bits 6-1 = Reserved<br>Bit 0 = 0 High density select                                                                                                                                                                                                  |
| 03F7h       | w                    | Diskette controller configuration control register,<br>where:<br>Bits 7-2 = Reserved<br>Bits 1-0 = 00b 500 Kbs mode<br>= 01b 300 Kbs mode<br>= 10b 250 Kbs mode<br>= 11b Reserved                                                                                                                                    |

# System RAM Data

## System RAM data area table

The CBIOS Diskette Service references control data stored in the CBIOS Data Area (400h-500h). All Diskette Service items are defined in the table below.

| Location | Size    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40:10h   | 2 Bytes | Number of devices installed, where:         Bits 15-14 = Number of printer adapters         Bits 13,12 = Reserved         Bits 11-9 = Number of asynchronous adapters<br>(RS232)         Bit 8 = Reserved         Bits 7-6 = Number of diskette drives, where:<br>00b=1 diskette drives         01b=2 diskette drives         Bits 5-4 = Initial video mode, where:<br>00b=EGA or PGA<br>01b=40x25 color<br>10b=80x25 color<br>11b=80x25 black and white         Bit 3 = Reserved         Bit 2 = Pointing device installed         Bit 1 = 1 Math coprocessor installed         Bit 0 = Diskette available for boot |
| 40:3Eh   | 1 Byte  | Diskette drive recalibration status, where:Bit 7= 1 Diskette hardware<br>interrupt has occurredBits 6-4= Not usedBits 3,2= ReservedBit 1= Recalibrate drive 1Bit 0= Recalibrate drive 0                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 40:3Fh   | 1 Byte  | Diskette drive motor status, where:Bit 7= 1 Current operation is a write or format<br>= 0 Current operation is a read or verifyBit 6= ReservedBit 5,4= Drive select status where:<br>00b= Drive 0 selected<br>01b= Drive 1 selected<br>10b= Reserved<br>11b= ReservedBit 1= 1 Drive 1 motor is on<br>Bit 0Bit 0= 1 Drive 0 motor is on                                                                                                                                                                                                                                                                               |
| 40:40h   | 1 Byte  | Diskette motor time-out count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Location | Size    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40:41h   | 1 Byte  | Diskette status return code, where:<br>Bit 7 = 1 Drive not ready<br>Bit 6 = 1 Seek error occurred<br>Bit 5 = 1 Diskette controller failed<br>Bits 4-0 = Error codes, where:<br>01h= Illegal function requested<br>02h= Address mark not found<br>03h= Write protect error<br>04h= Sector not found<br>06h= Drive door was opened<br>08h= DMA overrun error<br>09h= DMA boundary error<br>0Ch = Media type unknown<br>10h= CRC failed on diskette read                                                                                                                                                                                                                                                                |
| 40:42h   | 7 Bytes | Diskette controller status bytes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 40:74h   | 1 Word  | Status from last fixed disk operation, where:00h= No error01h= Invaild function request02h= Address mark not found03h= Write protect error04h= Sector not found05h= Reset failed07h= Drive parameter activity failed08h= DMA overrun on operation09h= Bad sector flag detected0Bh= Bad track detected0Dh= Invaild number of sectors on format0Eh= Control data address mark detected0Fh= DMA arbitration level out of range10h= Uncorrectable ECC or CRC error11h= ECC corrected data error20h= General controller failure40h= Seek operation failed80h= Time-outAAh= Drive not readyBBh= Undefined error occurredCCh= Write fault on selected driveEOH= Status error/error register is 0FFh= Sense operation failed |
| 40:75h   | 1 Byte  | Number of fixed disk drives                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# System RAM data area table, cont'd

# System RAM Data, Continued

| System RAM | /I data area | table, cont'd |
|------------|--------------|---------------|
|------------|--------------|---------------|

| Location   | Size    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40:8Bh     | 2 Bytes | Diskette data rate information<br>Bits 7,6= Last data rate set by controller,<br>where:<br>00b = 500 Kilobytes/second (Kbs)<br>01b = 300 Kbs<br>10b = 250 Kbs<br>11b = Reserved<br>Bits 5,4 = Last diskette drive step rate selected<br>Bits 3,2 = Data transfer rate at operation start,<br>where:<br>00b = 500 Kbs<br>01b = 300 Kbs<br>10b = 250 Kbs<br>10b = 250 Kbs<br>10b = 250 Kbs<br>10b = Reserved<br>Bits 1,0 = Reserved                                                                                                                                                                                                                                                  |
| 40:8Fh     | 1 Byte  | Diskette controller information, where:<br>Bit 7 = Reserved<br>Bit 6 = 1 Drive determined for drive 1<br>Bit 5 = 1 Drive 1 is multirate<br>Bit 4 = 1 Drive 1 supports change line<br>Bit 3 = Reserved<br>Bit 2 = 1 Drive determined for drive 0<br>Bit 1 = 1 Drive 0 is multirate<br>Bit 0 = 1 Drive 0 supports change line                                                                                                                                                                                                                                                                                                                                                        |
| 40:90h-91h | 2 Bytes | Media Type of Both Drives:<br>(One byte per drive. drive 0 at 40:90h; drive 1 at<br>40:91h)<br>Bits 7,6 = Data Transfer Rate, where:<br>00b = 500 Kbs<br>01b = 300 Kbs<br>10b = 250 Kbs<br>Bit 5 = 1 Double stepping required<br>(360K media/1.2 MB drive)<br>Bit 4 = 1 Known media in drive<br>Bit 3 = Reserved<br>Bits 2-0 = Definitions on return to user:<br>111b = 720K media in 720K or 1.44 MB<br>drive; or 1.44 MB media in<br>1.44 MB drive<br>101b = Known 1.2 MB media in 1.2 MB<br>drive<br>100b = Known 360K media in 360K drive<br>011b = Trying 1.2 MB media in 1.2 MB<br>drive<br>001b = Trying 360K media in 360K drive<br>000b = Trying 360K media in 360K drive |

| Location | Size    | Description                                                                                                                  |
|----------|---------|------------------------------------------------------------------------------------------------------------------------------|
| 40:92h   | 2 Bytes | Diskette Service work area. Each entry is first<br>FDMED value tried. One byte per drive. Drive (<br>at 92h, Drive 1 at 93h. |
| 40:94h   | 2 Bytes | Current track number for both drives. One byte per drive. Drive 0 at 94h, drive 1 at 95h.                                    |
| 40:A0h   | 2 Bytes | Walt active flag, where:<br>Bit 7 = 1 Wait time elapsed<br>Bits 6-1= Reserved<br>Bit 0 = 1 INT 15h, AH = 86h occurred        |

## System RAM data area table, cont'd

#### Introduction

The Diskette Service routine makes use of control information located in CMOS RAM data areas 0Eh through 10h. The table below provides detailed information about the areas used.

#### CMOS RAM data area table

The following table describes all CMOS RAM data areas used by this interrupt.

| CMOS RAM<br>Offset (hex) | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Eh                      | 1 Byte | Diagnostic status, where:<br>Bit 7 = 1 Real time clock lost power<br>Bit 6 = 1 CMOS checksum is bad<br>Bit 5 = 1 Invalid configuration information at POST<br>Bit 4 = 1 Memory size compare error at POST<br>Bit 3 = 1 Fixed disk or adapter fails initialization<br>Bit 2 = 1 CMOS time found invalid<br>Bit 1 = 1 Adapters do not match configuration<br>Bit 0 = 1 Time-out in reading an adapter ID |
| 10h                      | 1 Byte | Type of diskette drives:<br>Bits 7-4 = Drive type of drive 0, where:<br>0000b = No drive<br>0001b = $360K$ drive<br>0010b = $1.2$ MB drive<br>0011b = $720K$<br>0100b = $1.44$ MB<br>Bits 3-0 = Drive type of drive 1, where:<br>0000b = No drive<br>0001b = $360K$ drive<br>0010b = $1.2$ MB drive<br>0011b = $720K$<br>0100b = $1.44$ MB                                                             |

# **ROM BIOS Data**

### Introduction

The diskette device service routine in PC XT/AT systems supplied a table of parameters used to manipulate diskette drives. For compatibility, the CBIOS Diskette service must still provide the same table, although some of its values are modified so that the table is more suited to the default 3.5-inch 1.44 MB diskette drives. The default 11-byte table is located in ROM at F000:EFC7h and is pointed to by the interrupt 1Eh vector.

#### Parameter table

| Byte | Description                                                                                                                                                                                                                                                                                                                |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h  | The format for the first data byte of the diskette specify<br>command ls:<br>Bits 7-4 = Stepping rate<br>Bits 3-0 = Head unload time                                                                                                                                                                                       |
|      | The default stepping rate is 0Ah for the 1.44 MB drive with a 1.44 MB diskette inserted. The default head unload time is the maximum value of 240 ms (0Fh).                                                                                                                                                                |
| 01h  | The format for the second data byte of the diskette specify<br>command is:<br>Bits 7-1 = Head load time<br>Bit 0 = Non-DMA mode flag                                                                                                                                                                                       |
|      | The default head load delay time is set to the minimum value of 4 ms (01h). The heads are loaded at the same time as the mo-<br>tor is started, but the motor delay is much longer so the head<br>load time delay is not really needed. The non-DMA mode flag is<br>always set to zero to indicate that DMA is being used. |
| 02h  | Motor turn-off delay. This is the amount of time in timer ticks<br>that the diskette device service routine waits before turning off<br>an inactive diskette drive motor. Timer ticks occur 18.2 times<br>per second and the routine waits about two seconds; therefore<br>the default value for this field is 25h.        |
| 03h  | Bytes per sector. This field is encoded in the following way to<br>match the encoding used by the diskette controller:<br>00 = 128 bytes per sector<br>01 = 256 bytes per sector<br>02 = 512 bytes per sector<br>03 = 1024 bytes per sector<br>The standard sector size is 512 bytes per sector, so the default            |
| 04h  | value for this field is 02h.<br>End of track. Since the sector numbering is one relative, this<br>field is actually the number of sectors per track. For a 1.44 MB<br>diskette in the 1.44 MB drive, this field is 18 sectors per track.                                                                                   |

# Parameter table, cont'd

| Byte | Description                                                                                                                                                                                                                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 05h  | Gap length. This field is the length of the gap between sectors.<br>The default value for this field is 1Bh for a 1.44 MB diskette.                                                                                                                                                                             |
| 06h  | Data Length. Since the bytes per sector field is non-zero, this field is meaningless and is set to FFh.                                                                                                                                                                                                         |
| 07h  | Gap length for format. This field is the length of the gap be-<br>tween sectors to maintain when formatting. The default format<br>gap length for a 1.44 MB diskette is 6Ch.                                                                                                                                    |
| 08h  | Filler byte. This byte is the format filler byte and is F6h.                                                                                                                                                                                                                                                    |
| 09h  | Head seek delay time. This is the amount of time in milliseconds<br>the diskette device service routine must wait for the heads to<br>settle after doing a seek operation. For the 1.44 MB diskette<br>drive, this field is 0Fh.                                                                                |
| 0Ah  | Motor start time. This is the amount of time in eighths of a sec-<br>ond that the diskette device service routine must wait for the<br>motor to come up to speed before doing an I/O operation. The<br>1.44 MB drive has a motor start time of one second so the<br>default value for this field is set to 08h. |

# **Error Handling**

## Introduction

The CBIOS Diskette Service returns the completion status of each function via the AH register, the Carry Flag, Diskette Status (40:41h) and in Disk Controller Status (40:42h).

## Successful functions

Successful functions return as follows:

- AH = 00h (No error)
- Diskette Status (40:41h) = AH
- Carry Flag = 0 (cleared)

## **Unsuccessful functions**

Unsuccessful functions return as follows:

- AH = xxh (Error code)
- Diskette Status (40:41h) = AH
- Carry Flag = 1 (set)

Note: If the error was related to the diskette controller hardware, the contents of AH are also copied to Disk Controller Status (40:42h).

# Error Handling, Continued

# Table: Error Codes

The CBIOS Diskette Service error codes are listed in the table below. The Carry Flag is set if any of the following errors occur.

| Error code (in AH) | Description                             |
|--------------------|-----------------------------------------|
| 00h                | No error                                |
| 01h                | Invalid function request                |
| 02h                | Address mark not found                  |
| 03h                | Write attempted on write-protected disk |
| 04h                | Sector not found                        |
| 06h                | Diskette change line active             |
| 08h                | DMA overrun                             |
| 09h                | DMA boundary error                      |
| 0Ch                | Media type not available                |
| 10h                | Bad CRC                                 |
| 20h                | Diskette controller failed              |
| 40h                | Seek failed                             |
| 80h                | Time-out                                |

# **Rules for Using CBIOS and ABIOS Diskette Services**

## Introduction

Because they interface with two different operating systems, either the CBIOS or the ABIOS Diskette Services may put the diskette hardware into an unknown state.

#### Diskette hardware is not updated

The CBIOS does not inform the ABIOS of the diskette hardware's state when control is passed from the CBIOS to the ABIOS. Conversely, the ABIOS does not update the CBIOS diskette service data areas when control is passed back to the CBIOS from the ABIOS.

As a result, it is possible for one part of the PS/2 ROM BIOS to put the diskette hardware in a state that will not be recognized by the other. To avoid potential confusion, care must be taken to reset the diskette system each time the CBIOS diskette service is re-entered after any ABIOS service call.

#### Rules

The matter is resolved by following the rules below:

- 1. Do not invoke a CBIOS function if there is already an outstanding ABIOS function request.
- 2. Do not invoke an ABIOS function if there is already an outstanding CBIOS function request.
- If the last function call was to ABIOS, invoke CBIOS function INT 13h, AH = 00h, Reset Diskette System, before invoking another CBIOS function.
- 4. If the last function call was to CBIOS, invoke ABIOS Diskette Service function 05h Reset Diskette System before invoking another ABIOS function.
- 5. ABIOS Diskette Service function 05h, Reset Diskette System, must be the first ABIOS function called after ABIOS is initialized.

The Reset Diskette System function resets both the diskette controller and the indicated diskette drive (the R/W arm is moved to cylinder 0). The diskette drive number (either 0 or 1) is indicated in DL.

## Using CBIOS Diskette Services and ABIOS Diskette Services

- Do not invoke a CBIOS Diskette Service function if there already is an outstanding ABIOS function request.
- Invoke INT 13h, AH = 00h, Reset Diskette System, before invoking any other CBIOS Diskette Service I/O function if the last Diskette Service access was via ABIOS.

#### Switching between ABIOS and CBIOS

Invoke this function after switching from CBIOS to ABIOS and before invoking any other ABIOS Diskette Service functions. For more information, see Rules for Using CBIOS and ABIOS Diskette Services in this chapter.

## Input/Output

| Input:  | AH<br>DL | <ul> <li>= 00h</li> <li>= Drive number (0 or 1)</li> <li>Bit 7 = 0 for a diskette</li> <li>1 for a fixed disk</li> </ul>                                                  |
|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH<br>CF | <ul> <li>= 00h No error<br/>xxh Error (See "Error Codes" earlier in this chapter)</li> <li>= Diskette Status (40:41h)</li> <li>= 0 No error</li> <li>= 1 Error</li> </ul> |

Call this function when a problem occurs in attempting to access the diskette system, then retry the function that failed. The disk system will not react immediately. Instead, a reset flag forces the BIOS to recalibrate the disk drive's read/write heads the next time they are used. The heads are pulled to track 0 in order to start the next I/O operation from track 0.

# Function: AH = 01h Read Diskette Status

## Description

The CBIOS Diskette Service stores the error code associated with the last requested function in Diskette Status (40:41h). If the last function executed successfully, Diskette Status is set to 00h. If the last function was not successful, Diskette Status is set to the appropriate non-zero error code.

The Read Diskette Status function reads the value contained in Diskette Status and returns it in the AH register. The Carry Flag (CF) is set if the value returned in AH is nonzero. Otherwise the Carry Flag is cleared.

#### Input/Output

Input: AH = 01h DL = 0 or 1 (drive number) Output: AH = 00h No error xxh Error (See "Error Codes" earlier in this chapter) = Diskette Status (40:41h) CF = 0 No error = 1 Error

The Diskette Status byte is saved after each read, write, verify or format disk function. This allows error handling or error reporting routines to be written which are entirely independent of disk operation routines.

The Read Diskette Sectors function:

- Reads the number of sectors specified in AL,
- From the drive specified in DL,
- To the buffer specified in ES:BX

The diskette drive head number is indicated in DH. Starting cylinder and sector numbers are indicated in CH and CL.

This service is useful for bulk operations that require reading of individual or a whole trackful of sectors. For example, DISKCOPY in DOS uses this service.

#### Input/Output

| Input:  | AH<br>AL<br>CH<br>CL<br>DH<br>DL<br>ES:BX | <ul> <li>= 02h</li> <li>= Number of sectors (1-18, depending on drive media type)</li> <li>= Track number (0-79, depending on drive media type)</li> <li>= Sector number (1-18, depending on drive media type)</li> <li>= Head number (0-1)</li> <li>= Drive number (0 or 1)</li> <li>= Pointer to buffer</li> </ul> |
|---------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AL<br>AH<br>CF                            | <ul> <li>Number of sectors read/written</li> <li>00h No error<br/>xxh Error (See "Error Codes" earlier in this chapter)</li> <li>Diskette Status (40:41h)</li> <li>0 No error</li> <li>1 Error</li> </ul>                                                                                                            |

## Wait for device to reach proper speed

With diskette drives, an error may be caused by the drive motor being off when the request is made. The CBIOS does not wait for the device to reach proper speed before trying to read. The calling program should reset the diskette drive (INT 13h function 00h) and retry three times to make sure that an error is real.

The Write Diskette Sectors function:

- Writes the number of sectors specified in AL,
- From the drive specified in DL,
- To the buffer specified in ES:BX

The diskette drive head number is indicated in DH. Starting cylinder and sector numbers are indicated in CH and CL. Disk sectors must be formatted before they can be written to.

#### Input/Output

| Input:  | AH<br>AL<br>CH<br>CL<br>DH<br>DL | <ul> <li>= 03h</li> <li>= Number of sectors (1-18, depending on drive media type)</li> <li>= Track number (0-79, depending on drive media type)</li> <li>= Sector number (1-18, depending on drive media type)</li> <li>= Head number (0-1)</li> <li>= Drive number (0 or 1)</li> </ul> |
|---------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | ES:BX                            | = Pointer to buffer                                                                                                                                                                                                                                                                     |
| Output: | AL<br>AH<br>CF                   | <ul> <li>Number of sectors read/written</li> <li>00h No error<br/>xxh Error (See "Error Codes" earlier in this chapter)</li> <li>Diskette Status (40:41h)</li> <li>0 No error</li> <li>1 Error</li> </ul>                                                                               |

#### Wait for device to reach proper speed

With diskette drives, an error may be caused by the drive motor being off when the request is made. The CBIOS does not wait for the device to reach proper speed before trying to write. The calling program should reset the diskette drive (INT 13h function 00h) and retry three times to make sure that an error is real.

The Verify Diskette Sectors function:

- · verifies the number of sectors specified in AL,
- from the drive specified in DL,
- to the buffer specified in ES:BX.

The diskette drive head number is indicated in DH. Starting cylinder and sector numbers are indicated in CH and CL. No data is transferred from the disk in this operation. Disk data is not compared to data in memory.

The CBIOS Diskette Service verifies diskette sectors by determining if the sectors can be found, read, and pass the Cyclic Redundancy Check (CRC).

| Input:  | AL<br>CH<br>CL<br>DH | =<br>=<br>= | 04h<br>Number of sectors (1–18, depending on drive media type)<br>Track number (0–79, depending on drive media type)<br>Sector number (1–18, depending on drive media type)<br>Head number (0–1)<br>Drive number (0 or 1) |
|---------|----------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | АН                   | H<br>H      | Number of sectors actually transferred<br>00h No error<br>nnh Error (See "Error Codes" earlier in this chapter)<br>Diskette Status (40:41h)<br>0 No error<br>1 Error                                                      |

# Function: AH = 05h Format Diskette Track

## Description

The Format Diskette Track function formats a single diskette track on the drive specified in DL. The number of sectors is specified in AL, the head number in DH, and the track number in CH. Each call to service 05 can be verified by following it with a call to service 04h.

ES:BX points to a table defining the address fields for the track being formatted.

**Note:** If the diskette drive in question supports more than one diskette format, the CBIOS user must call either Diskette Service function AH = 17h Set Diskette Type or AH = 18h Set Media Type for Format before calling this function.

## Input/Output

| Input:  | AH<br>AL<br>DL<br>DH<br>CH<br>ES:BX | <ul> <li>= 05h</li> <li>= Number of sectors to be formatted (starts at one)</li> <li>= Drive number (0 or 1)</li> <li>= Head number (0 or 1)</li> <li>= Track number (starts at 0)</li> <li>X = Address field buffer</li> </ul>  |
|---------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH<br>CF                            | <ul> <li>= 00h No error</li> <li>= 80h Specified diskette drive does not exist<br/>xxh Error (See "Error Codes" earlier in this chapter)</li> <li>= Diskette Status (40:41h)</li> <li>= 0 No error</li> <li>= 1 Error</li> </ul> |

# Address Field Table

The Address Field Table must contain one entry for each sector on the track to be formatted. Each entry consists of four bytes as defined in the table below.

| Byte | Description                                           |  |
|------|-------------------------------------------------------|--|
| 0    | Track number                                          |  |
| 1    | Head number — zero based                              |  |
| 2    | Sector number                                         |  |
| 3    | Bytes/sector number, where:<br>02h = 512 bytes/sector |  |

#### **Example: Address Field Table**

For example, the address field to format track 3, head 0 of a 9 sector/track diskette with 512-byte sectors, would be:

db 03,00,01,02,03,00,02,02,03,00,03,02

- db 03,00,04,02,03,00,05,02,03,00,06,02
- db 03,00,07,02,03,00,08,02,03,00,09,02

#### Copy protection

Service 05h can be used for copy protection by:

- squeezing more sectors onto a track.
- rearranging the order of the sectors.
- leaving out a sector number.
- specifying 1 or more sectors to be an unconventional size.
- adding a sector with an unconventional address mask.

# Function: AH = 08h Read Drive Parameters

#### Description

The Read Drive Parameters function returns the diskette parameters for the drive specified in DL. (Valid values are 0 and 1.)

- The drive type stored in CMOS RAM determines the parameters returned.
   If the drive type is not stored in CMOS RAM, all registers return a value of zero, except DL which contains the number of diskette drives installed.
- If the media type is known, the maximum media capacity is returned in registers BL, CH, CL, and DH. A pointer to the diskette parameter table is returned in ES:DI.
- If a diskette drive does not support the diskette change line, the parameters for a 360K, nine sector/track diskette in a 360K drive are pointed to by the value in ES:DI. The drive type returned in BL is zero.
- If a change line is supported, the parameters for a 1.44 MB diskette in a 1.44 MB drive are pointed to by ES:DI. The drive type returned in BL is zero.
- If successful, the Carry Flag is cleared. Diskette Status (40:41h) is not modified unless the drive type input into DL is a value reserved for fixed disks only. (Valid values for fixed disk drives are 80h and 81h.)

#### Input/Output

Input: AH = 08h DL = 0 or 1 (drive number) Output: AX = 0 BH = 0BL = Bits 4-7 = 0 Bits 0-3 = Valid drive type value from CMOS 01h = 5.25", 360K, 40 track 02h = 5.25", 1.2 MB, 80 track 03h = 3.5", 720K, 80 track 04h = 3.5", 1.44 MB, 80 track CF = 0 No error = 1 Illegal parameter = Maximum usable track number CH CL = Maximum usable sector number DH = Maximum usable head number (always 1 if CMOS value valid) DL = Number of diskette drives installed (0, 1, or 2) ES:DI = Pointer to diskette drive parameter table for the maximum media type supported on the specified drive

# Functions: AH = 09h - 14h Reserved

# Function: AH = 15h Read Drive Type

# Description

The Read Drive Type function returns information about the drive specified in the DL register. (Valid values are 0 and 1.)

Unlike most other CBIOS Diskette Service functions, the value returned in the AH register by this function is **not** an Error Code. Instead, the value returned in AH corresponds to one of the four indicators described in the table below.

| AH Value | Meaning                                                                  |
|----------|--------------------------------------------------------------------------|
| 0h       | No drive installed                                                       |
| 01h      | Diskette drive that cannot detect media change (360K, 40-track diskette) |
| 02h      | Diskette drive that can detect media change (1.2 MB, 80-track diskette)  |
| 03h      | Fixed disk installed                                                     |

| Input:  |     | 15h<br>Drive number (0 or 1)                                                                                                                                                     |
|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | = = | 00h Drive number is valid<br>01h Diskette drive with no change line<br>02h Diskette drive with a change line<br>03h Fixed disk installed<br>0 No error<br>1 Invalid drive number |

The Detect Media Change function determines if the drive door has been opened since the last time the change line was cleared.

- Use INT 13h function 15h first to determine whether the diskette drive hardware can sense when a diskette is changed.
- If the drive number is not valid, the Carry Flag is set, AH is set to 01h, and control is returned to the caller.
- If the drive is not configured, AH and Diskette Status are set to 80h (time-out), CF is set, and control is returned to the caller.
- When this function returns with CF set, it does not necessarily mean that a diskette has been changed. It only means that the diskette drive door has been opened and closed since the last time the change line was cleared.
- If the change line is not supported, AH and Diskette Status are set to 06h (media change), CF is cleared, and control is returned to the caller.

| Input:  |    |       | 16h<br>Drive number (0 or 1)          |
|---------|----|-------|---------------------------------------|
| Output: | AH | = = = | diskette change line signal is active |

# Function: AH = 17h Set Diskette Type

## Description

The Set Diskette Type function sets the transfer rate for the specified drives using the diskette types passed in AL. 1.44 MB drives are not handled by this function. This function is provided for compatibility with DOS 3.0 or 3.1. Function 18h supersedes it for DOS 3.2 and up. If the diskette type in AL is invalid, AH and Diskette Status are set to 01h, CF is set, and control is returned to the caller. If the drive number is invalid, CF is set, AH and Diskette Status are set to 01h, and control is returned to the caller.

The media transfer rates are set according to the drive type specified. For diskette types 2, 3, and 4, the change line determines if there is a diskette in the drive. If there is no diskette in the drive, AH and Diskette Status are set to 80h (time-out), CF is set, and control is returned to the caller. If a diskette is present, Diskette Status is set to 00h and the following values are set according to the diskette type in AL.

| Diskette Type | Transfer Rate | Double Step | Known Media |
|---------------|---------------|-------------|-------------|
| 02h           | 300 Kbs (01b) | Yes         | Yes         |
| 03h           | 500 Kbs (00b) | No          | Yes         |
| 04h           | 250 Kbs (10b) | No          | Yes         |

| Inpu | t: AH  | = | 17h                                                   |
|------|--------|---|-------------------------------------------------------|
|      | AL     | = | 01h 360K diskette in 360K drive                       |
|      |        | = | 02h 360K diskette in 1.2 MB drive                     |
|      |        | = | 03h 1.2 MB diskette in 1.2 MB drive                   |
|      |        | = | 04h 720K diskette in 720K drive                       |
| Outp | ut: AH | = | 00h No error                                          |
|      |        | = | xxh Error (See "Error Codes" earlier in this chapter) |
|      |        | = | Diskette Status (40:41h)                              |
|      | CF     | = | 0 No error                                            |
|      |        | = | 1 Error                                               |
|      |        |   |                                                       |

The Set Media Type for Format function sets the media type in preparation for a format command.

- If the drive number is not valid, the Carry Flag (CF) is set and control is returned to the caller with both AH and Diskette Status (40:41h) equal to 01h.
- If the drive number is valid, this function determines if the drive supports a change line. If the drive supports a change line, this function determines if there is a diskette in the drive. If there is no diskette, AH and Diskette Status are set to 80h (time-out), the Carry Flag (CF) is set, and control is returned to the caller.
- If the drive type can't be determined, AH and Diskette Status are set to 0Ch (unknown media), CF is set, and control is returned to the caller.
- If there are no problems with the values returned by this function, a diskette table is chosen based on the data input to this function. ES:DI points to the chosen diskette parameter table, AH and Diskette Status are set to 00h, CF is cleared, and control is returned to the caller.

| Input:  | AH<br>CH<br>CL<br>DL | <ul> <li>= 18h</li> <li>= Maximum number of tracks</li> <li>= Maximum sectors per track</li> <li>= Drive number (0 or 1)</li> </ul>                                                                                                                                                                                            |
|---------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | ES:DI<br>AH<br>CF    | <ul> <li>Pointer to drive parameter table</li> <li>00h track/sector combination is supported</li> <li>0Ch Media unknown (CMOS not valid, drive not configured in CMOS, or not in diskette parameter table)</li> <li>80h No diskette in drive</li> <li>Diskette Status (40:41h)</li> <li>0 No error</li> <li>1 Error</li> </ul> |

# INT 0Eh Diskette Hardware Interrupt

#### Introduction

The CBIOS Diskette Interrupt Service Routine (ISR) services interrupts from the diskette controller.

## How CBIOS Diskette ISR is invoked

The Diskette controller generates an INT 0Eh, the CBIOS Diskette ISR, to signal the completion of the last command issued by INT 13h.

To maintain compatibility, the INT 0Eh entry point is located at address F000:EF57h. INT 0Eh resides at address 40h in the Interrupt Vector Table.

#### **CBIOS multitasking support**

Each time the CBIOS Diskette Service issues a diskette controller command, it also invokes INT 15h with AH = 90h Device Busy Loop.

Calling INT 15h allows other tasks in the system to process while diskette I/O is in progress. However, this multitasking must be implemented by user-supplied programs executing in the microprocessor's real address mode.

#### INT 0Eh and multitasking return

When the diskette controller completes a command, it issues an INT 0Eh interrupt and enables interrupts.

INT 0Eh sets Bit 7 of the Diskette Drive Recalibrate Status byte (40:3Eh) and calls INT 15h with AH = 91h and AL = 01h Interrupt Complete. Then it sets Bit 7 of (40:3Eh) to signal the completion of the command.

## I/O Port table

INT 0Eh, Diskette ISR, references the following I/O ports:

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                            |  |  |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 03F0h       | R                    | Diskette controller status register A, where:<br>Bit 7 = 1 Interrupt pending<br>Bit 6 = 0 Second drive installed<br>Bit 5 = 1 Step<br>Bit 4 = 0 Track 0<br>Bit 3 = 1 Select head 1<br>Bit 2 = 0 Index<br>Bit 1 = 0 Write protect<br>Bit 0 = 1 Direction is from controller to diskette |  |  |

## System RAM data area

INT 0Eh, Diskette ISR, references the following system RAM data area locations:

| Location | Length | Description                                                                                                                                                      |  |  |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 40:3Eh   | 1 Byte | Diskette drive recalibrate status, where:                                                                                                                        |  |  |
|          |        | Bit 7 = 1 Diskette hardware interrupt has<br>occurred<br>Bit 6-4 = Not used<br>Bits 3,2 = Reserved<br>Bit 1 = Recalibrate drive 1<br>Bit 0 = Recalibrate drive 0 |  |  |

# Chapter 11 INT 13h Fixed Disk Service

# Overview

### Description

The CBIOS Fixed Disk Service performs BIOS-level read, write, format, diagnostic, initialization and other operations for up to two fixed disk drives.

## How the service is invoked

INT 13h invokes the CBIOS Fixed Disk Service.

The INT 13h vector resides at the Interrupt Vector Table address 00:4Ch. The CBIOS initializes the INT 13h Fixed Disk Service vector to address F000:E3FEh, the IBM-compatible BIOS entry point.

# Summary of fixed disk service functions

The CBIOS Fixed Disk Service contains several functions. Individual functions are selected via AH. The table below summarizes these functions.

| Function | Description                      |  |
|----------|----------------------------------|--|
| 00h      | Reset Disk System                |  |
| 01h      | Read Disk Status                 |  |
| 02h      | Read Disk Sectors                |  |
| 03h      | Write Disk Sectors               |  |
| 04h      | Verify Disk Sectors              |  |
| 05h      | Format Disk Cylinder             |  |
| 06h-07h  | Reserved                         |  |
| 08h      | Read Drive Parameters            |  |
| 09h      | Initialize Drive Parameters      |  |
| 0Ah      | Read Long Disk Sectors           |  |
| 0Bh      | Write Long Disk Sectors          |  |
| 0Ch      | Seek to Cylinder                 |  |
| 0Dh      | Alternate Reset Fixed Disk       |  |
| 0Eh      | Diagnostics 1, Read Test Buffer  |  |
| 0Fh      | Diagnostics 2, Write Test Buffer |  |
| 10h      | Test for Drive Ready             |  |
| 11h      | Recalibrate Drive                |  |
| 12h-14h  | Reserved                         |  |
| 15h      | Read Disk Type                   |  |
| 16h-18h  | Reserved                         |  |
| 19h      | Park Heads                       |  |
| 1Ah      | Format ESDI Drive                |  |
| 1Bh-FFh  | Reserved                         |  |

# Overview, Continued

## In this chapter

This chapter focuses on the CBIOS Fixed Disk Service. The following topics are presented:

- Hardware Environment
- Fixed Disk Service I/O Ports
- System RAM Data
- CMOS RAM Data
- ROM BIOS Data
- Fixed Disk Service Error Handling
- Rules for Using CBIOS and ABIOS Fixed Disk Services
- Fixed Disk Service Functions

# Hardware Environment

### Support for two fixed disk drives

The CBIOS Fixed Disk Service will physically support up to two fixed disk drives. An ST412/506 interface fixed disk adapter or equivalent is assumed present. CBIOS uses information from the drive table which may include support for RLL and ESDI drives. ESDI drives generally require an option ROM.

#### How fixed disks are identified

Each fixed disk must be identified to the system with a unique number.

There are only two valid fixed disk identification numbers — 80h and 81h. The numbers must be assigned as per below:

- Fixed Disk Drive 0 = 80h
- Fixed Disk Drive 1 = 81h

Note: The fixed disk drive values 80h or 81h are required DL register inputs for many of the INT 13h fixed disk services.

#### **CBIOS diskette support**

When a fixed disk is installed, the CBIOS **automatically** redirects all INT 13h Diskette Service requests to INT 40h. This redirecting is transparent to end users, however. End users should continue to invoke INT 13h for **both** diskette and fixed disk services.

For discussion of CBIOS Diskette Services, refer to Chapter 10.

# Fixed Disk Service I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0018h       | W                    | DMA Extended function register where:<br>Bits 7-4 = Progress command, where:<br>00h I/O address register<br>01h Reserved<br>02h Memory address register write<br>03h Memory address register read<br>04h Transfer count register write<br>05h Transfer count register write<br>05h Status register read<br>06h Status register read<br>07h Mode register<br>08h Arbus register set single bit<br>0Ah Mask register reset single bit<br>0Bh-0Ch Reserved<br>0Dh Master clear<br>0Eh-0Fh Reserved<br>Bits 3-0 = 0 Reserved |  |
| 001Ah       | R/W                  | DMA Extended function execute register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 0020h       | R                    | Interrupt request/in-service registers programmed<br>by Operation Command Word 3 (OCW3):<br>Interrupt request register, where:<br>Bits 7-0 = 0 No active request for the cor-<br>responding interrupt line<br>= 1 Active request for the correspond-<br>ing interrupt line<br>Interrupt in-service register, where:<br>Bits 7-0 = 0 The corresponding interrupt line is<br>not currently being serviced<br>= 1 The corresponding interrupt line is<br>currently being serviced                                           |  |
| 0020        | ¥                    | Initialization Command Word 1 (ICW1) (Bit 4 is<br>one), where:<br>Bits 7-5 = 000 Only used in 80/85 mode<br>Bit 4 = 1 Reserved<br>Bit 3 = 0 Edge triggered mode<br>= 1 Level triggered mode<br>Bit 2 = 0 Successive interrupt vectors are<br>separated by eight bytes<br>= 1 Successive interrupt vectors are<br>separated by four bytes<br>Bit 1 = 0 Cascade mode<br>= 1 Single mode - no ICW3 needed<br>Bit 0 = 0 No ICW4 needed<br>= 1 ICW4 needed                                                                    |  |

INT 13h, Fixed Disk Service, references the following I/O ports:

# Fixed Disk Service I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0021h       | w                    | ICW2, ICW3, or ICW4 in sequential order after<br>ICW1 written to Port 0020h                                                                                                                                                                                                                                                                                                                                                                              |
|             |                      | ICW2, where:<br>Bits 7-3 = Address lines A0-A3 of base vector<br>address for Interrupt controller<br>Bits 2-0 = 000 Reserved                                                                                                                                                                                                                                                                                                                             |
|             |                      | ICW3, where:<br>Bits 7-0= 0 Slave controller not attached to<br>corresponding interrupt pin<br>= 0 Slave controller attached to<br>corresponding interrupt pin                                                                                                                                                                                                                                                                                           |
|             |                      | ICW4, where:<br>Bits 7-5= 000 Reserved<br>Bit 4 = 0 No special fully-nested mode<br>= 1 Special fully-nested mode<br>Bits 3-2= 00 Nonbuffered mode<br>= 01 Nonbuffered mode<br>= 10 Buffered mode/slave<br>= 11 Buffered mode/master<br>Bit 1 = 0 Normal EOI<br>= 1 Auto EOI<br>Bit 0 = 0 80/85 mode<br>= 1 8086/8088 mode                                                                                                                               |
| 0021h       | R/W                  | Interrupt mask register (OCW1), where:<br>Bit 7 = 0 Enable parallel printer interrupt<br>Bit 6 = 0 Enable diskette interrupt<br>Bit 5 = 0 Enable fixed disk interrupt<br>Bit 4 = 0 Enable serial interrupt<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Enable video interrupt<br>Bit 1 = 0 Enable keyboard/pointing device/RTC<br>interrupt<br>Bit 0 = 0 Enable timer interrupt                                                                                   |
| 0021h       | W                    | OCW2 (Bit 4 is zero, Bit 3 is zero), where:<br>Bits 7-5 = 000 Rotate in automatic EOI mode<br>(clear)<br>= 001 Non-specific EOI<br>= 010 No operation<br>= 011 Specific EOI<br>= 100 Rotate in automatic EOI mode (set)<br>= 101 Rotate on non-specific EOI<br>command<br>= 110 Set priority command<br>= 111 Rotate on specific EOI command<br>Bit 4 = 0 Reserved<br>Bit 3 = 0 Reserved<br>Bits 2-0 = Interrupt request to which the command<br>applies |

# Fixed Disk Service I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0020h       | W                    | OCW3 (Bit 4 is zero, Bit 3 is one), where:<br>Bit 7 = 0 Reserved<br>Bits 6-5= 00 No operation<br>= 01 No operation<br>= 10 Reset special mask<br>= 11 Set special mask<br>Bit 4 = 0 Reserved<br>Bit 3 = 1 Reserved<br>Bit 2 = 0 No poll command<br>= 1 Poll command<br>Bits 1-0= 00 No operation<br>= 01 No operation<br>= 10 Read interrupt request register on<br>next read at Port 0020h<br>= 11 Read interrupt inservice register on<br>next read at Port 0020h |  |
| 0070h       | W                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0= 0 CMOS address                                                                                                                                                                                                                                                                                                                                                      |  |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 0074h       | W                    | Extended CMOS RAM address register port, least significant byte                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 0075h       | W                    | Extended CMOS RAM address register port, most significant byte                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 0076h       | R/W                  | Extended CMOS RAM data register port                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 0092h       | R/W                  | System control port A, where:Bit 7= 1 Fixed disk activity light bit A is onBit 6= 1 Fixed disk activity light bit B is onBit 5= 0 ReservedBit 4= 1 Watchdog time-out occurredBit 3= 1 Security lock latch is lockedBit 2= 0 ReservedBit 1= 1 Alternate gate A20 activeBit 0= 1 Alternate hot reset                                                                                                                                                                  |  |
| 00A0h       | w                    | Programmable Interrupt Controller 2                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 00A1h       | R/W                  | Programmable Interrupt Controller 2 mask, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Enable fixed disk Interrupt<br>Bit 5 = 0 Enable 80387 exception interrupt<br>Bit 4 = 0 Enable mouse Interrupt<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Reserved<br>Bit 1 = 0 Enable redirect cascade<br>Bit 0 = 0 Enable real time clock Interrupt                                                                                                                                    |  |

# Fixed Disk Service I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0320h       | R/W                  | Fixed Disk Adapter Register (8 or 16 bit)                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 0322h       | W                    | Fixed Disk Adapter Control Register, where:<br>Bit 7 = 1 Reset<br>Bit 6 = 1 Reserved (except during reset)<br>Bit 5 = 1 16-bit mode (must match bit 2)<br>= 0 8-bit mode<br>Bit 4-3 = 0 Reserved<br>Bit 2 = 1 16-bit mode (must match bit 5)<br>= 0 8-bit mode<br>Bit 1 = 1 Enable interrupt through Programmable<br>Interrupt Controller (hardware interrupt)<br>= 0 Enable interrupt through Interrupt<br>Status Register (port 324h)<br>Bit 0 = 1 DMA mode<br>= 0 PIO mode |  |  |
| 0322h       | R                    | Fixed Disk Adapter Status Register, where:<br>Bit 7-6 = 0 Reserved<br>Bit 5 = 1 16-bit mode<br>= 0 8-bit mode<br>Bit 4 = 1 Data transfer requested by adapter<br>Bit 3 = 1 Direction is adapter to system<br>= 0 Direction is system to adapter<br>Bit 2 = 1 Busy<br>Bit 1 = 1 Interrupt request (notification)<br>Bit 0 = 1 Transfer in progress                                                                                                                             |  |  |
| 0324h       | W                    | Fixed Disk Adapter Attention Register, where:<br>Bit 7 = 1 Command control block<br>Bit 6 = 1 Command specify block<br>Bit 5 = 1 Sense summary block<br>Bit 4 = 1 Data transfer requested by system<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Drive 0 select<br>= 1 Drive 1 select<br>Bit 1 = 0 Reserved<br>Bit 0 = 1 Abort current command                                                                                                                                          |  |  |
| 0324h       | R                    | <ul> <li>Fixed Disk Adapter Interrupt Status Register where:</li> <li>Bit 7 = 1 Termination error, bits 0-6 indicate what the error is</li> <li>Bit 6 = 1 Invalid command</li> <li>Bit 5 = 1 Command reject</li> <li>Bit 4-3 = 0 Reserved</li> <li>Bit 2 = 0 Drive 0 selected</li> <li>= 1 Drive 1 selected</li> <li>Bit 1 = 1 Error recovery procedure invoked</li> <li>Bit 0 = 1 Equipment check</li> </ul>                                                                 |  |  |

## Introduction

The Fixed Disk Service makes use of System RAM Data located in the CBIOS Data area and in the CBIOS Extended Data area.

The CBIOS Data area (absolute hex address 400-500) contains data definitions that are referred to by the CBIOS Fixed Disk Service.

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 40:74h   | 1 Word | Status from last fixed disk operation, where:<br>00h = No error<br>01h = Invalid function request<br>02h = Address mark not found<br>03h = Write protect error<br>04h = Sector not found<br>05h = Reset failed<br>07h = Drive parameter activity failed<br>08h = DMA overrun on operation<br>09h = Data boundary error<br>0Ah = Bad sector flag detected<br>0Bh = Bad track detected<br>0Bh = Invalid number of sectors on format<br>0Eh = Control data address mark detected<br>0Fh = DMA arbitration level out of range<br>10h = Uncorrectable ECC or CRC error<br>11h = ECC corrected data error<br>20h = General controller failure<br>40h = Seek operation failed<br>80h = Time-out<br>AAh = Drive not ready<br>BBh = Undefined error occurred<br>CCh = Write fault on selected drive<br>E0h = Status error/reror register is 0<br>FFh = Sense operation failed<br>Number of fived drives |  |
| 40:75h   | 1 Byte | Number of fixed drives                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 40:8Ch   | 1 Byte | Fixed disk controller status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 40:8Dh   | 1 Byte | Fixed disk controller error status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 40:8Eh   | 1 Byte | Fixed disk interrupt flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 40:8Fh   | 1 Byte | Diskette controller information where:<br>Bit 7 = Reserved<br>Bit 6 = 1 If drive determined for drive 1<br>Bit 5 = 1 If drive is multirate<br>Bit 4 = 1 If drive supports change line<br>Bit 3 = Reserved<br>Bit 2 = 1 If drive 0 is multirate<br>Bit 0 = 1 If drive 0 supports change line                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 40:Eh    | 1 Word | Extended CBIOS data area segment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |

# System RAM Data, Continued

## **BIOS Extended Data Area**

The CBIOS Extended Data area is located in the top 1K of system RAM; the segment of the extended data area is defined in location 40:0Eh of the CBIOS Data area. The Fixed Disk Service uses three locations in the CBIOS Extended Data area. Those locations are defined in the table below:

| Location    | Size            | Descript                                                                                                                    | ion                                                                                                       |                                                                                                                                                                                                                                                                                   |
|-------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EDA:3Dh     | 16 Bytes        | Fixed disl<br>Offset                                                                                                        | k paramet<br>Size                                                                                         | er table for drive 0, where:                                                                                                                                                                                                                                                      |
|             |                 | 00h<br>02h<br>03h<br>05h<br>07h<br>08h<br>09h<br>0Ah<br>09h<br>0Ah<br>0Ch<br>0Eh<br>0Fh                                     | Size<br>Word<br>Byte<br>Word<br>Byte<br>Byte<br>Byte<br>Byte<br>Byte<br>Byte<br>Byte<br>Byte              | Description<br>Max number of cylinders<br>Max. number of heads<br>Reserved<br>Starting write precompensa<br>tion cylinder<br>Not used<br>Control byte<br>Reserved<br>Reserved<br>Reserved<br>Landing zone<br>Number of sectors/track<br>Reserved                                  |
| EDA:4Dh     | 16 Bytes        | Fixed disl<br>Offset<br>00h<br>02h<br>03h<br>05h<br>07h<br>08h<br>08h<br>0Ah<br>0Bh<br>0Ch<br>0Eh                           | k paramet<br>Size<br>Word<br>Byte<br>Word<br>Word<br>Byte<br>Byte<br>Byte<br>Byte<br>Byte<br>Word<br>Byte | er table for drive 1, where:<br>Description<br>Max number of cylinders<br>Max. number of heads<br>Reserved<br>Starting write precompensa-<br>tion cylinder<br>Reserved<br>Control byte<br>Reserved<br>Reserved<br>Reserved<br>Reserved<br>Landing zone<br>Number of sectors/track |
| EDA:6Ch     | 1 Byte          | Fixed Disk arbitration level and channel<br>number, where:<br>Bits 7-4 = Channel number<br>Bits 3-0 = DMA arbitration level |                                                                                                           |                                                                                                                                                                                                                                                                                   |
| Note: EDA = | Extended Data A | rea                                                                                                                         |                                                                                                           |                                                                                                                                                                                                                                                                                   |

## Introduction

The Fixed Disk Service makes use of data stored in conventional CMOS RAM, and for those MCA-based systems that include more than four expansion slots, in Extended CMOS RAM.

## Table of CMOS RAM data used

The CMOS RAM data referenced by the Fixed Disk Service is listed below.

| CMOS RAM<br>Offset (hex) | Size   | Description                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|--------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0Eh                      | 1 Byte | Diagnostic status, where:                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                          |        | Bit 7 = 1 Real time clock lost power<br>Bit 6 = 1 CMOS checksum is bad<br>Bit 5 = 1 Invalid configuration information at POST<br>Bit 4 = 1 Memory size compare error at POST<br>Bit 3 = 1 Fixed disk or adapter fails initialization<br>Bit 2 = 1 CMOS time found invalid<br>Bit 1 = 1 Adapters do not match configuration<br>Bit 0 = 1 Time-out in reading an adapter ID |  |  |  |  |  |
| 11h                      | 1 Byte | Type of fixed disk drive 0                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| 12h                      | 1 Byte | Type of fixed disk drive 1                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| 19h                      | 1 Byte | Adapter ID for channel 0, low byte                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 1Ah                      | 1 Byte | Adapter ID for channel 0, high byte                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 1Bh                      | 1 Byte | Adapter ID for channel 1, low byte                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 1Ch                      | 1 Byte | Adapter ID for channel 1, high byte                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 1Dh                      | 1 Byte | Adapter ID for channel 2, low byte                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 1Eh                      | 1 Byte | Adapter ID for channel 2, high byte                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 1Fh                      | 1 Byte | Adapter ID for channel 3, low byte                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| 20h                      | 1 Byte | Adapter ID for channel 3, high byte                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 21h                      | 1 Byte | POS 2 configuration byte for channel 0                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 22h                      | 1 Byte | POS 3 configuration byte for channel 0                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 25h                      | 1 Byte | POS 2 configuration byte for channel 1                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 26h                      | 1 Byte | POS 3 configuration byte for channel 1                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 29h                      | 1 Byte | POS 2 configuration byte for channel 2                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 2Ah                      | 1 Byte | POS 3 configuration byte for channel 2                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 2Dh                      | 1 Byte | POS 2 configuration byte for channel 3                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 2Eh                      | 1 Byte | POS 3 configuration byte for channel 3                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

# CMOS RAM Data, Continued

## Extended CMOS RAM data

The CBIOS uses an additional 2K of CMOS RAM to store Programmable Option Select (POS) data for MCA-based systems that include more than four expansion slots. Fixed disk parameter data for fixed disks other than those listed in the ROM BIOS Fixed Disk Parameter Table is also stored in this extra CMOS RAM.

## Table of Extended CMOS data used

The table below outlines the extended CMOS RAM data used by the Fixed Disk Service.

| CMOS RAM<br>Offset (hex) | Size   | Description                     |  |  |  |
|--------------------------|--------|---------------------------------|--|--|--|
| 0000h                    | 1 Byte | LSB of adapter ID for channel 0 |  |  |  |
| 0001h                    | 1 Byte | MSB of adapter ID for channel 0 |  |  |  |
| 0003h                    | 1 Byte | POS 2 for channel 0             |  |  |  |
| 0004h                    | 1 Byte | POS 3 for channel 0             |  |  |  |
| 0023h                    | 1 Byte | LSB of adapter ID for channel 1 |  |  |  |
| 0024h                    | 1 Byte | MSB of adapter ID for channel 1 |  |  |  |
| 0026h                    | 1 Byte | POS 2 for channel 1             |  |  |  |
| 0027h                    | 1 Byte | POS 3 for channel 1             |  |  |  |
| 0046h                    | 1 Byte | LSB of adapter ID for channel 2 |  |  |  |
| 0047h                    | 1 Byte | MSB of adapter ID for channel 2 |  |  |  |
| 0049h                    | 1 Byte | POS 2 for channel 2             |  |  |  |
| 0069h                    | 1 Byte | LSB of adapter ID for channel 3 |  |  |  |
| 006Ah                    | 1 Byte | MSB of adapter ID for channel 3 |  |  |  |
| 006Ch                    | 1 Byte | POS 2 for channel 3             |  |  |  |
| 008Ch                    | 1 Byte | LSB of adapter ID for channel 4 |  |  |  |
| 008Dh                    | 1 Byte | MSB of adapter ID for channel 4 |  |  |  |
| 008Fh                    | 1 Byte | POS 2 for channel 4             |  |  |  |
| 0090h                    | 1 Byte | POS 3 for channel 4             |  |  |  |
| 00AFh                    | 1 Byte | LSB of adapter ID for channel 5 |  |  |  |
| 00B0h                    | 1 Byte | MSB of adapter ID for channel 5 |  |  |  |

# CMOS RAM Data, Continued

| CMOS RAM<br>Offset (hex) | Size    | Description                       |  |  |  |  |
|--------------------------|---------|-----------------------------------|--|--|--|--|
| 00B2h                    | 1 Byte  | POS 2 for channel 5               |  |  |  |  |
| 00B3h                    | 1 Byte  | POS 3 for channel 5               |  |  |  |  |
| 00D2h                    | 1 Byte  | LSB of adapter ID for channel 6   |  |  |  |  |
| 00D3h                    | 1 Byte  | MSB of adapter ID for channel 6   |  |  |  |  |
| 00D5h                    | 1 Byte  | POS 2 for channel 6               |  |  |  |  |
| 00D6h                    | 1 Byte  | POS 3 for channel 6               |  |  |  |  |
| 00F5h                    | 1 Byte  | LSB of adapter ID for channel 7   |  |  |  |  |
| 00F6h                    | 1 Byte  | MSB of adapter ID for channel 7   |  |  |  |  |
| 0166 – 0175h             | 8 Words | Fixed parameter table for drive 0 |  |  |  |  |
| 0176 – 0185h             | 8 Words | Fixed parameter table for drive 1 |  |  |  |  |

# Extended CMOS data definitions, cont'd

# **ROM BIOS Data**

## Description

The Fixed Disk Parameters Table defines the types of fixed disk drives that can be used. The address of the correct entry within the Fixed Disk Parameters Table is contained in the INT 41h vector for drive 0 and in the INT 46h vector for drive 1. To maintain compatibility, the Fixed Disk Parameters Table is based at hex F000:E401.

#### Parameter table structure

Each entry in the Fixed Disk Parameters Table occupies 16 bytes.

| Offset | Size    | Description                                                                                                                                                                                                    |  |  |  |  |  |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 00h    | 2 Bytes | Maximum number of cylinders                                                                                                                                                                                    |  |  |  |  |  |
| 02h    | 1 Byte  | Maximum number of heads                                                                                                                                                                                        |  |  |  |  |  |
| 03h    | 2 Byte  | Reserved                                                                                                                                                                                                       |  |  |  |  |  |
| 05h    | 2 Bytes | Starting write precompensation cylinder                                                                                                                                                                        |  |  |  |  |  |
| 07h    | 1 Byte  | Reserved                                                                                                                                                                                                       |  |  |  |  |  |
| 08h    | 1 Byte  | Control byte, where:<br>Bit 7,6 = 1 Disable retries (either bit disables)<br>Bit 5 = 1 Defect map present at max,<br>cylinder + 1<br>Bit 4 = 0 Reserved<br>Bit 3 = 1 More than 8 heads<br>Bits 2-0= 0 Reserved |  |  |  |  |  |
| 09h    | 3 Bytes | Reserved                                                                                                                                                                                                       |  |  |  |  |  |
| 0Ch    | 2 Bytes | Landing zone                                                                                                                                                                                                   |  |  |  |  |  |
| 0Eh    | 1 Byte  | Number of sectors per track                                                                                                                                                                                    |  |  |  |  |  |
| 0Fh    | 1 Byte  | Reserved                                                                                                                                                                                                       |  |  |  |  |  |

The 16-byte entry structure is defined in the table below:

#### Fixed disk parameter entries

The CBIOS portion of the ROM BIOS defines only the first 32 entries in the Fixed Disk Table. Fixed disk type 15 is not used. Definitions for fixed disk types 1–32 are located in a 16-byte table starting at F000:E401h.

### Table of fixed disk definitions

The defined entries into the Fixed Disk Parameters table are listed below. Wherever possible, the manufacturer name and model number associated with a given drive type are listed in the column, "Manufacturer."

| Туре | Manufacturer                                                                          | Cyl. | Heads | Write<br>Precomp | Landing<br>Zone | Sectors/<br>Track | Defect<br>Map |
|------|---------------------------------------------------------------------------------------|------|-------|------------------|-----------------|-------------------|---------------|
| 1    | IBM 10 MB                                                                             | 306  | 4     | 128              | 305             | 17                | No            |
| 2    | IBM 20 MB<br>Seagate ST-225<br>CDC Wren II<br>9415-5-25<br>Miniscribe 8438F           | 615  | 4     | 300              | 615             | 17                | No            |
| 3    | IBM 30 MB                                                                             | 615  | 6     | 300              | 615             | 17                | No            |
| 4    | IBM 62 MB                                                                             | 940  | 8     | 512              | 940             | 17                | No            |
| 5    | IBM 46 MB                                                                             | 940  | 6     | 512              | 940             | 17                | No            |
| 6    | IBM 20 MB<br>Miniscribe MS 8425<br>Seagate ST4026<br>Tandon TM 262<br>Tandon TM 702AT | 615  | 4     | 0FFFFh           | 615             | 17                | No            |
| 7    | IBM 30 MB                                                                             | 462  | 8     | 256              | 511             | 17                | No            |
| 8    | IBM 30 MB<br>Seagate ST-4038<br>CDC Wren II<br>9415-5-38<br>Tandon TM 703AT           | 733  | 5     | 0FFFFh           | 733             | 17                | No            |
| 9    | IBM 112 MB                                                                            | 900  | 15    | 0FFFFh           | 901             | 17                | No            |
| 10   | IBM 20 MB                                                                             | 820  | 3     | 0FFFFh           | 820             | 17                | No            |
| 11   | IBM 35 MB                                                                             | 855  | 5     | 0FFFFh           | 855             | 17                | No            |
| 12   | IBM 49 MB                                                                             | 855  | 7     | 0FFFFh           | 855             | 17                | No            |
| 13   | IBM 20 MB                                                                             | 306  | 8     | 128              | 319             | 17                | No            |

Note: If a table entry contains 0FFFFh for Write Precompensation, then there is no write precompensation for this disk. If the write precompensation is zero, then there is write precompensation for all cylinders.

# ROM BIOS Data, Continued

| Туре  | Manufacturer                                                                        | Cyl.        | Heads      | Write<br>Precomp | Landing<br>Zone             | Sectors/<br>Track           | Defect<br>Map |
|-------|-------------------------------------------------------------------------------------|-------------|------------|------------------|-----------------------------|-----------------------------|---------------|
| 14    | IBM 42 MB                                                                           | 733         | 7          | 0FFFFh           | 733                         | 17                          | No            |
| 15    |                                                                                     |             | Not ı      | used             |                             |                             |               |
| 16    | IBM 20 MB                                                                           | 612         | 4          | 0                | 663                         | 17                          | No            |
| 17    | IBM 40 MB                                                                           | 977         | 5          | 300              | 977                         | 17                          | No            |
| 18    | IBM 56 MB                                                                           | 977         | 7          | 0FFFFh           | 977                         | 17                          | No            |
| 19    | IBM 59 MB                                                                           | 1024        | 7          | 512              | 1023                        | 17                          | No            |
| 20    | IBM 30 MB                                                                           | 733         | 5          | 300              | 732                         | 17                          | No            |
| 21    | IBM 42 MB                                                                           | 733         | 7          | 300              | 732                         | 17                          | No            |
| 22    | IBM 30 MB                                                                           | 733         | 5          | 300              | 733                         | 17                          | No            |
| 23    | IBM 10 MB                                                                           | 306         | 4          | 0                | 336                         | 17                          | No            |
| 24    | IBM 20 MB                                                                           | 612         | 4          | 305              | 663                         | 17                          | No            |
| 25    | IBM 10 MB                                                                           | 306         | 4          | 0FFFFh           | 340                         | 17                          | No            |
| 26    | IBM 20 MB                                                                           | 612         | 4          | 0FFFFh           | 670                         | 17                          | No            |
| 27    | IBM 40.5 MB                                                                         | 698         | 7          | 300              | 732                         | 17                          | Yes           |
| 28    | IBM 40.5 MB                                                                         | 976         | 5          | 488              | 977                         | 17                          | Yes           |
| 29    | IBM 10 MB                                                                           | 306         | 4          | 0FFFFh           | 340                         | 17                          | No            |
| 30    | IBM 20 MB                                                                           | 611         | 4          | 306              | 663                         | 17                          | Yes           |
| 31    | IBM 42.5 MB                                                                         | 732         | 7          | 300              | 732                         | 17                          | Yes           |
| 32    | IBM 42.5 MB                                                                         | 1023        | 5          | 0FFFFh           | 1023                        | 17                          | Yes           |
| Note: | If a table entry contains (<br>precompensation for this<br>write precompensation fo | disk. If th | ne write p | Precompens       | ation, then<br>ation is zer | there is no<br>o, then ther | write<br>e is |

# Table of fixed disk definitions, cont'd

# Introduction

Upon return from each function, the Fixed Disk Service indicates the result of the operation with a numeric error code. This error code is returned in AH and is stored in The Fixed Disk Status byte (40:74h).

# Error code and successful functions

Successful functions return with

- AH and Fixed Disk Status (40:74h) set to 00h (i.e. Error Code = 00h, no error)
- Carry Flag (CF) cleared

# Error codes and unsuccessful functions

Functions which have not executed successfully return with

- Carry Flag set
- AH and Fixed Disk Status (40:74h) set to one of 23 possible error codes

# Fixed Disk Service Error Handling, Continued

# Table of error codes

The table below lists the Fixed Disk Service Error Codes.

| Error Code | Description                                        |
|------------|----------------------------------------------------|
| 00h        | No error                                           |
| 01h        | Invalid function passed in AH or invalid parameter |
| 02h        | Address mark not found                             |
| 04h        | Sector not found                                   |
| 05h        | Reset failed                                       |
| 07h        | Drive parameter activity failed                    |
| 08h        | DMA overrun on operation                           |
| 09h        | Data boundary error                                |
| 0Ah        | Bad sector flag detected                           |
| 0Bh        | Bad cylinder detected                              |
| 0Dh        | Invalid number of sectors on format                |
| 0Eh        | Control data address mark detected                 |
| 0Fh        | DMA arbitration level out of range                 |
| 10h        | Uncorrectable ECC or CRC error                     |
| 11h        | ECC corrected data error                           |
| 20h        | Controller failure                                 |
| 40h        | Seek operation failed                              |
| 80h        | Time-out                                           |
| AAh        | Drive not ready or not selected                    |
| BBh        | Undefined error occurred                           |
| CCh        | Write fault on selected drive                      |
| E0h        | Status error/error register = 0                    |
| FFh        | Sense operation failed                             |

# Introduction

Because they interface with two different operating systems, either the CBIOS or the ABIOS Fixed Disk Services may put the fixed disk hardware into an unknown state.

# Fixed disk hardware is not updated

The CBIOS does not inform the ABIOS of the fixed disk hardware's state when control is passed from the CBIOS to the ABIOS. Conversely, the ABIOS does not update the CBIOS fixed disk service data areas when control is passed back to the CBIOS from the ABIOS. As a result, it is possible for one part of the PS/2 ROM BIOS to put the fixed disk hardware in a state that will not be recognized by the other.

To avoid potential confusion, care must be taken to reset the fixed disk system each time the CBIOS Fixed Disk Service is re-entered after **any** ABIOS service call.

### Rules

The matter is resolved by following the rules below:

- 1. Do not invoke a CBIOS function if there is already an outstanding ABIOS function request.
- 2. Do not invoke an ABIOS function if there is already an outstanding CBIOS function request.
- If the last function call was to ABIOS, invoke CBIOS function INT 13h, AH = 0Dh Alternate Reset Fixed Disk System before invoking another ABIOS function.
- 4. If the last function call was to CBIOS, invoke Fixed Disk Service function 05h Reset Fixed Disk System before invoking another ABIOS function.
- 5. ABIOS Fixed Disk function 05h Reset Fixed Disk System must be the first ABIOS function called after ABIOS is initialized.

# Function: AH = 00h Reset Diskette(s) and Fixed Disk

# Description

The Reset Diskette(s) and Fixed Disk function resets both the diskette and the fixed disk controllers. It places both the diskette and the fixed disk systems in a known state by reinitializing the fixed disk and diskette drive parameters and by recalibrating the read/write heads positions of both devices.

The fixed disk drive number (either 80h or 81h) is specified in DL. If successful, this function returns with AH set to 00h and Carry Flag cleared.

**Note:** The diskette system is reset regardless of the drive number specified in DL. To reset the fixed disk controller only, use function AH = 0Dh.

# Input/Output

| Input:  | AH | = | 00h                                    |
|---------|----|---|----------------------------------------|
| Output: | AH | = | 00h No error                           |
|         |    | = | Nonzero, Fixed Disk Service Error Code |
|         |    | = | Fixed Disk Status (40:74h)             |
|         | CF | = | 0 No error                             |
|         |    | = | 1 Error                                |

### **Error conditions**

If not successful, the Reset Diskette(s) and Fixed Disk function returns with a nonzero error code in AH.

### Differentiating diskette from fixed disk errors

The status of the last Diskette Service operation is stored in Diskette Status (40:41h), and the status of the last Fixed Disk Service operation is stored in Fixed Disk Status (40:74h).

- If the error code returned in AH by this function pertains to the diskette system, then the value of Diskette Status will be equal to the value of AH.
- If the error code in AH pertains to the fixed disk, then the value in Fixed Disk Status will be equal to the value in AH.

# Function: AH = 01h Read Disk Status

# Description

The Read Disk Status function returns Fixed Disk Status, the error code from the last operation, in the AL register. Before returning to the caller this function sets Fixed Disk Status and AH to zero and clears the Carry Flag.

# Input/Output

| Input:  | AH | = | 01h                           |
|---------|----|---|-------------------------------|
|         | DL | = | Drive number                  |
|         |    |   | 80h Fixed disk 1              |
|         |    |   | 81h Fixed disk 2              |
| Output: | AH | = | 00h                           |
|         |    | = | Fixed Disk Status (40:74h)    |
|         | AL | = | Error code for last operation |
|         | CF | = | 0 No error                    |
|         |    | = | 1 Error                       |

# **Error conditions**

If not successful, the Read Disk Status function returns with a nonzero Error Code in AH and the Carry Flag set.

# Function: AH = 02h Read Disk Sectors

# Description

The Read Disk Sectors function reads the number of sectors specified in AL from the drive specified in DL to a buffer area defined by ES:BX.

Fixed disk head number is indicated in DH. Starting cylinder and sector number are indicated in CH and CL as shown in the Input/Output section below.

If successful, the Read Disk Sectors function returns with the Carry Flag cleared and AH = 00h.

Note: The number of sectors specified in AL must not be zero or greater than 128. Numbers greater than 128 cause a transfer of greater than 64K, and thus force a DMA boundary error.

# Input/Output

| Input:  | AH<br>AL<br>CH<br>CL | <ul> <li>= 02h</li> <li>= Number of sectors to read</li> <li>= Cylinder number (low 8 bits, zero-based)</li> <li>= Cylinder/sector number, where:<br/>Bits 7-6 = cylinder number (high 2 bits)<br/>Bits 5-0 = sector number</li> </ul> |
|---------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | DL                   | <ul> <li>Head number (zero-based)</li> <li>Drive number<br/>80h fixed disk 1<br/>81h fixed disk 2</li> <li>Fointer to buffer</li> </ul>                                                                                                |
| Output: | AH<br>CF             | <ul> <li>= 00h No error</li> <li>= Nonzero, error code</li> <li>= Fixed disk status (40:74h)</li> <li>= 0 No error</li> <li>= 1 Error</li> </ul>                                                                                       |

# **Error conditions**

If it is unsuccessful, the Read Disk Sectors function returns with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

For example, if an invalid number of sectors is input into AL, then the Read Disk Sectors function returns with the CF set and AH and Fixed Disk Status (40:74h) set to 09h, the Error Code that indicates a DMA boundary error has occurred.

**Note:** Since the disk drive motor takes a certain amount of time to reach a working speed, a program should try this function three times when an error condition occurs. It should also use the reset function between tries.

# Function: AH = 03h Write Disk Sectors

# Description

The Write Disk Sectors function writes the number of sectors specified in AL to the drive specified in DL from a buffer area defined by ES:BX.

The fixed disk head number is indicated in DH. Starting cylinder and sector number are indicated in CH and CL as shown in "Input/Output" below.

If successful, the Write Disk Sectors function returns with the Carry Flag cleared and AH = 00h.

Note: The number of sectors specified in AL must not be zero or greater than 128. Numbers greater than 128 cause a transfer of greater than 64K, and thus force a DMA boundary error.

### Input/Output

| Input:  | AH<br>AL<br>CH<br>CL | <ul> <li>= 03h</li> <li>= Number of sectors to write</li> <li>= Cylinder number (low 8 bits, zero-based)</li> <li>= Cylinder/sector number, where:<br/>Bits 7-6 = cylinder number (high 2 bits)</li> <li>Bits 5-0 = sector number</li> </ul> |
|---------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | DH<br>DL<br>ES:BX    | <ul> <li>Head number (zero-based)</li> <li>Drive number</li> <li>80h fixed disk 1</li> <li>81h fixed disk 2</li> <li>X = Disk transfer address</li> </ul>                                                                                    |
| Output: | AH<br>CF             | <ul> <li>Status of operation — Fixed Disk Status (40:74h)</li> <li>0 No error</li> <li>1 Error</li> </ul>                                                                                                                                    |

# **Error conditions**

If unsuccessful, the Write Disk Sectors function returns with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and Fixed Disk Status (40:74h). For example, if an invalid number of sectors is input into AL, then the Read Disk Sectors function returns with the CF set and AH and Fixed Disk Status (40:74h) set to 09h, the Error Code that indicates a DMA boundary error has occurred.

# Description

The Verify Disk Sectors function verifies the number of sectors specified in AL on the cylinder, head, and drive specified in CH, CL, and DH respectively. (See "Input/Output" below.)

If successful, the Verify Disk Sectors function returns with the Carry Flag cleared and AH and Fixed Disk Status (40:74h) set to 00h.

**Note:** This function does not compare data on disk with data in memory. It merely verifies that the specified sectors can be read and that the cyclical redundancy check (CRC) is correct.

### Input/Output

| AL<br>CH<br>CL | =                                | 04h<br>Number of sectors to verify<br>Cylinder number (low 8 bits, zero-based)<br>Cylinder/sector number, where:<br>Bits 7-6 = cylinder number (high 2 bits)<br>Bits 5-0 = sector number<br>Head number (zero-based) |
|----------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DL             |                                  | Drive number<br>80h fixed disk 1<br>81h fixed disk 2                                                                                                                                                                 |
|                | =                                | 00h No error<br>nonzero, Fixed Disk Service Error Code<br>Fixed Disk Status (40:74h)<br>0 No error<br>1 Error                                                                                                        |
|                | AL<br>CH<br>CL<br>DH<br>DL<br>AH | AL =<br>CH =<br>CL =<br>DH =<br>DL =<br>AH =<br>E<br>CF =                                                                                                                                                            |

# **Error conditions**

If unsuccessful, the Verify Disk Sectors function returns with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and Fixed Disk Status (40:74h).

# Function: AH = 05h Format Disk Cylinder

# Description

The Format Cylinder function formats the cylinder specified in CH and CL using the head specified in DL.

The caller must provide a table of address markers pointed to by ES:BX. There must be one two-byte table entry for each sector on the cylinder. Table entries must be formatted as shown below:

Byte 1 = good/bad flag 00h is good 80h is bad Byte 2 = sector number

# Input/Output

| Input:  | AH<br>CH<br>CL    | <ul> <li>= 05h</li> <li>= Cylinder number (low 8 bits)</li> <li>= Cylinder/sector number, where:<br/>Bits 7-6 = cylinder number (high 2 bits, zero-based)<br/>Bits 5-0 = sector number</li> </ul> |
|---------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | DH<br>DL<br>ES:B> | <ul> <li>Head number (zero-based)</li> <li>Drive number<br/>80h fixed disk 1<br/>81h fixed disk 2</li> <li>K = Pointer to table of 2 byte address markers</li> </ul>                              |
| Output: | AH<br>CF          | <ul> <li>= 00h No error</li> <li>= nonzero, Fixed Disk Service Error Code</li> <li>= Fixed Disk Status (40:74h)</li> <li>= 0 No error</li> <li>= 1 Error</li> </ul>                               |

# **Error conditions**

If unsuccessful, the Format Disk Cylinder function returns with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h). For example, if a time-out error occurs during the execution of this function an error code of 80h is returned in both AH and Fixed Disk Status.

# Function: AH = 08h Read Drive Parameters

### Description

The Read Drive Parameters function returns parameters associated with the fixed disk drive whose number is specified in DL. (Valid numbers are 80h and 81h.)

For drive 80h, the Read Disk Parameters function references the fixed disk parameter table pointed to by the Interrupt 41h vector. For drive 81h, the function references the Interrupt 46h vector.

If successful, the Read Drive Parameters function returns with AL and Fixed Disk Status set to zero. Maximum cylinder number is returned in CH, maximum sector number in CL, maximum head number in DH, and number of fixed disk drives contained in the system is returned in DL.

# Input/Output

| Input:  | AH | = 08h                                                                                                  |
|---------|----|--------------------------------------------------------------------------------------------------------|
|         | DL | = Drive number                                                                                         |
|         |    | 80h fixed disk 1                                                                                       |
|         |    | 81h fixed disk 2                                                                                       |
| Output: | AH | = 07h If drive number in DL is invalid                                                                 |
|         |    | = 00h lf operation is successful                                                                       |
|         | AL | = 00h                                                                                                  |
|         | CF | = 0 No error                                                                                           |
|         |    | = 1 Error                                                                                              |
|         | СН | <ul> <li>Maximum usable cylinder number (low 8 bits, zero-based)</li> <li>(00h if AH = 07h)</li> </ul> |

# Function: AH = 08h Read Drive Parameters, Continued

# Input/Output, cont'd

| Output: | CL | Ξ | Cylinder/sector number, where:                          |
|---------|----|---|---------------------------------------------------------|
|         |    |   | (Bits $7-0 = 00h$ if $AH = 07h$ )                       |
|         |    |   | Bits 7-6 = Maximum usable cylinder number (high 2 bits) |
|         |    |   | Bits 5-0 = Maximum usable sector number                 |
|         | DH | = | Maximum usable head number                              |
|         |    |   | (zero-based, 00h if AH = 07h)                           |
|         | DL | = | Number of drives (zero-based, 00h if AH = 07h)          |
|         |    |   |                                                         |

# **Error conditions**

If the drive number specified in DL is not valid, the Read Drive Parameters function returns with AH and Fixed Disk Status (40:74h) set to 07h to indicate that the drive parameter activity failed. AL, CX, and DX are set to zero, the Carry Flag is set, and control is returned to the caller.

# Description

The Initialize Drive Parameters function initializes the controller associated with the fixed disk drive whose number is specified in DL. (Valid values are 80h and 81h.)

For drive 80h, the Initialize Drive Parameters function references the fixed disk parameter table pointed to by the Interrupt 41h vector. For drive 81h, the function references the Interrupt 46h vector.

If successful, the Initialize Drive Parameters function returns with AH and Fixed Disk Status (40:74h) set and the Carry Flag cleared.

# Input/Output

| Input:  | AH | = | 09h                        |
|---------|----|---|----------------------------|
|         | DL | = | Drive number               |
|         |    |   | 80h fixed disk 1           |
|         |    |   | 81h fixed disk 2           |
| Output: | AH | = | 00h No error               |
|         |    | = | 07h Operation has failed   |
|         |    | = | Fixed Disk Status (40:74h) |
|         | CF | = | 0 No error                 |
|         |    | = | 1 Error                    |

# **Error conditions**

If unsuccessful, the Initialize Drive Parameters function returns with AH and Fixed Disk Status (40:74h) equal to 07h. This indicates that drive parameter activity has failed.

- Note: The Initialize Drive Parameters function generates only two valid return codes:
  - AH = Fixed Disk Status = 00h = Function successful
  - AH = Fixed Disk Status = 07h = Function unsuccessful,
    - drive parameter activity has failed.

# Function: AH = 0Ah Read Long Disk Sectors

# Description

The Read Long Disk Sectors function reads one sector from the location on the fixed disk specified in DL. This function also reads the two words of Error Correction Code (ECC) associated with that sector. Cylinder number, sector number, and head number are specified in CH, CL, and DH, respectively (see "Input/Output," below).

If successful, the Read Long Disk Sectors function returns with the Carry Flag cleared and AH and Fixed Disk Status (40:74h) equal to zero.

Notes: This function is normally reserved for diagnostics and should not be used without good reason.

# Input/Output

| Input:  | AH<br>AL<br>CH<br>CL | <ul> <li>= 0Ah</li> <li>= 01h (must always be 1)</li> <li>= Cylinder number (low 8 bits, zero-based)</li> <li>= Cylinder/sector number, where:<br/>Bits 7-6 = cylinder number (high 2 bits)<br/>Bits 5-0 = sector number</li> </ul> |
|---------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | DH<br>DL<br>ES:B>    | <ul> <li>Head number (zero-based)</li> <li>Drive number</li> <li>80h fixed disk 1</li> <li>81h fixed disk 2</li> <li>K = Disk transfer address</li> </ul>                                                                           |
| Output: | AH<br>CF             | <ul> <li>= 00h No error</li> <li>= Nonzero, (Fixed Disk Service Error Code)</li> <li>= Fixed Disk Status (40:74h)</li> <li>= 0 No error</li> <li>= 1 Error</li> </ul>                                                               |

# **Error conditions**

If unsuccessful, the Read Long Disk Sectors function returns with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

For example, if the number of sectors in AL is not equal to 01h, then the Read Long Sector function returns with AH and Fixed Disk Status (40:74h) equal to 01h (the invalid parameter error code) and the Carry Flag set.

Refer to the Error Conditions heading in this chapter for a table of Fixed Disk Service Error Codes.

# Function: AH = 0Bh Write Long Disk Sectors

# Description

The Write Long Disk Sectors function writes one sector to the location on the fixed disk specified in DL from the buffer pointed to by ES:BX. The function also writes the two words of Error Correction Code (ECC) associated with the specified sector.

Cylinder number, sector number, and head number are specified in CH, CL, and DH, respectively (see Input/Output below).

If successful, the Write Long Sectors function returns with the Carry Flag cleared and AH and Fixed Disk Status (40:74h) equal to zero.

### Additional information

- The caller must indicate the number of long sectors to read in AL. Since the Read Long Disk Sectors function is limited to one sector, any AL value other than 01h results in an invalid parameter error condition.
- Along with function AH = 0Ah, this function is normally reserved for diagnostics and should not be used without good reason.

# Function: AH = 0Bh Write Long Disk Sectors, Continued

# Input/Output

| Input:  | AH<br>AL<br>CH<br>CL | <ul> <li>= 0Bh</li> <li>= 01h (must always be 1)</li> <li>= Cylinder number (low 8 bits, zero-based)</li> <li>= Cylinder/sector number, where:<br/>Bits 7-6 = cylinder number (high 2 bits)<br/>Bits 5-0 = sector number</li> </ul> |
|---------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | DH<br>DL             | <ul> <li>Head number (zero-based)</li> <li>Drive number</li> <li>80h fixed disk 1</li> <li>81h fixed disk 2</li> </ul>                                                                                                              |
|         | ES:BX                | K = Disk transfer address                                                                                                                                                                                                           |
| Output: | АН                   | = 00h No error<br>= nonzero, (Fixed Disk Service Error Code)                                                                                                                                                                        |
|         | CF                   | <ul><li>Fixed Disk Status (40:74h)</li><li>0 No error</li><li>1 Error</li></ul>                                                                                                                                                     |

### **Error conditions**

If unsuccessful, the Write Long Disk Sectors function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

For example, if the number of sectors in AL is not equal to 01h, then the Read Long Sector function returns with AH and Fixed Disk Status (40:74h) equal to 01h (the invalid parameter error code) and the Carry Flag set.

# Function: AH = 0Ch Seek to Cylinder

### Description

The Seek to Cylinder function positions the disk read/write head over the cylinder specified in CH and CL (see Input/Output below). The fixed disk drive number must be specified in DL.

If successful, the Seek to Cylinder function returns with the Carry Flag cleared and AH and Fixed Disk Status (40:74h) equal to zero.

Note: The Read Disk Sectors, Write Disk Sectors, Read Long Disk Sectors and Write Long Disk Sectors functions have a seek operation implicitly built into them and do not require a prior call of this function.

# Input/Output

| Input:  | AH | = | 0Ch                                      |
|---------|----|---|------------------------------------------|
|         | CH | = | Cylinder number (low 8 bits, zero-based) |
|         | CL | = | Cylinder/sector number, where:           |
|         |    |   | Bits 7-6 = cylinder number (high 2 bits) |
|         |    |   | Bits 5-0 = sector number                 |
|         | DH | = | Head number (zero-based)                 |
|         | DL | = | Drive number                             |
|         |    |   | 80h fixed disk 1                         |
|         |    |   | 81h fixed disk 2                         |
| Output: | AH | = | 00h No error                             |
| •       |    | = | Nonzero, (Fixed Disk Service Error Code) |
|         |    | = | Fixed Disk Status (40:74h)               |
|         | CF | = | 0 No error                               |
|         |    | = | 1 Error                                  |
|         |    |   |                                          |

# **Error conditions**

If unsuccessful, the Seek to Cylinder function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Function: AH = 0Dh Alternate Reset Fixed Disk

# Description

The Alternate Reset Fixed Disk is identical to the Reset Diskette(s) and Fixed Disk function (see AH = 00h) except that the diskette system is not reset.

The caller must specify the fixed disk drive to reset in DL. The Alternate Reset Fixed Disk function reinitializes the fixed disk controller and places the specified fixed disk drive in a known state by resetting the fixed disk parameters and by recalibrating the read/write head positions.

If successful, the Alternate Reset Fixed Disk function returns with the Carry Flag cleared and AH and Fixed Disk Status (40:74h) equal to zero.

### Input/Output

| Input:  | AH | = | 0Dh                                      |
|---------|----|---|------------------------------------------|
|         | DL | = | Drive number                             |
|         |    |   | 80h fixed disk 1                         |
|         |    |   | 81h fixed disk 2                         |
| Output: | AH | = | 00h No error                             |
|         |    | = | Nonzero, (Fixed Disk Service Error Code) |
|         |    | = | Fixed Disk Status (40:74h)               |
|         | CF | = | 0 No error                               |
|         |    | = | 1 Error                                  |

### A special case

The ABIOS does not inform the CBIOS of the fixed disk hardware's state when control is passed from the ABIOS to the CBIOS. As a result, it is possible for the ABIOS to put the fixed disk hardware into a state not recognized by the CBIOS.

To avoid confusion, then, care must be taken to reset the fixed disk system each time the CBIOS Fixed Disk Service is re-entered after **any** ABIOS call. The following rules apply:

- 1. Do not invoke a CBIOS function if there is already an outstanding ABIOS function request.
- 2. If the last function call was to ABIOS, invoke CBIOS Fixed Disk Service function AH = 0Dh Alternate Fixed Disk Reset.

# Reference

For more information on the relationship between the CBIOS and ABIOS fixed disk services, turn to the heading "Rules for Using CBIOS and ABIOS Fixed Disk Services" in this chapter.

# **Error conditions**

If it is not successful, the Alternate Reset Disk function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Function: AH = 0Eh Diagnostics 1: Read Test Buffer

# Description

The Diagnostics 1, Read Test Buffer, function reads a test buffer from the fixed disk adapter into the diagnostics buffer specified in ES:BX. Data is not read from the actual physical disk drive.

If successful, the Diagnostics 1 function returns with the Carry Flag (CF) cleared and AH and Fixed Disk Status (40:74h) set to zero.

### Input/Output

| Input:  | AH    | = 0Eh Diagnostics 1, read test buffer      |
|---------|-------|--------------------------------------------|
|         | DL    | = Drive number                             |
|         |       | 80h fixed disk 1                           |
|         |       | 81h fixed disk 2                           |
|         | ES:B> | K = Pointer to diagnostic buffer           |
| Output: | AH    | = 00h No error                             |
|         |       | = Nonzero, (Fixed Disk Service Error Code) |
|         |       | = Fixed Disk Status (40:74h)               |
|         | CF    | = 0 No error                               |
|         |       | = 1 Error                                  |
|         |       |                                            |

# **Error conditions**

If it is not successful, the Diagnostics 1 function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Description

The Diagnostics 2, Write Test Buffer, function writes a test buffer to the adapter from the diagnostics buffer specified in ES:BX. Data is not written to the actual physical disk drive.

If successful, the Diagnostics 2 function returns with the Carry Flag (CF) cleared and AH and Fixed Disk Status (40:74h) set to zero.

# Input/Output

| Input:  | AH    | = 0Fh Diagnostics 2, write test buffer     |
|---------|-------|--------------------------------------------|
|         | DL    | = Drive number                             |
|         |       | 80h fixed disk 1                           |
|         |       | 81h fixed disk 2                           |
|         | ES:B> | K = Pointer to diagnostic buffer           |
| Output: | AH    | = 00h No error                             |
|         |       | = Nonzero, (Fixed Disk Service Error Code) |
|         |       | = Fixed Disk Status (40:74h)               |
|         | CF    | = 0 No error                               |
|         |       | = 1 Error                                  |
|         |       |                                            |

# **Error conditions**

If it is not successful, the Diagnostics 2 function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Function: AH = 10h Test for Drive Ready

# Description

The Test for Drive Ready function determines if the drive specified in DL is ready and can process a command.

If successful, the Test for Drive Ready function returns to the caller with the Carry Flag (CF) cleared and AH and Fixed Disk Status (40:74h) set to zero.

### Input/Output

| Input:  | AH | = | 10h                                                      |
|---------|----|---|----------------------------------------------------------|
|         | DL | = | Drive number                                             |
|         |    |   | 80h fixed disk 1                                         |
|         |    |   | 81h fixed disk 2                                         |
| Output: | AH |   | 00h No error<br>Nonzero, (Fixed Disk Service Error Code) |
|         |    |   | Fixed Disk Status (40:74h)                               |
|         | CF |   | 0 No error                                               |
|         |    | = | 1 Error                                                  |

# **Error conditions**

If it is not successful, the Test for Drive Ready function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Description

The Recalibrate Drive function repositions head 0 over cylinder 0 of the drive specified in DL.

If successful, the Recalibrate Drive function returns with the Carry Flag (CF) cleared and AH and Fixed Disk Status (40:74h) set to zero.

# Input/Output

| Input:  | AH | = | 11h                                      |
|---------|----|---|------------------------------------------|
|         | DL | = | Drive number                             |
|         |    |   | 80h fixed disk 1                         |
|         |    |   | 81h fixed disk 2                         |
| Output: | AH | = | 00h No error                             |
|         |    | = | Nonzero, (Fixed Disk Service Error Code) |
|         |    | = | Fixed Disk Status (40:74h)               |
|         | CF | = | 0 No error                               |
|         |    | = | 1 Error                                  |

# Error conditions

If it is not successful, the Recalibrate Drive function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

Refer to the Error Conditions heading in this chapter for a table of Fixed Disk Service Error Codes.

# Function: AH = 12h - 14h Reserved

# Function: AH = 15h Read Disk Type

# Description

The Read Disk Type function returns the number of 512-byte blocks on the fixed disk if the drive specified in DL is valid. (Valid values are 80h and 81h.)

If successful, the high word 512-byte block amount is returned in CX, and the low word amount is returned in DX. Fixed Disk Status (40:74h) and the Carry Flag (CF) are set to zero, and control is returned to the caller.

### Input/Output

| Input:  | AH | = | 15h                                     |
|---------|----|---|-----------------------------------------|
|         | DL | = | Drive number                            |
|         |    |   | 80h fixed disk 1                        |
|         |    |   | 81h fixed disk 2                        |
| Output: | AH | = | 00h No drive installed                  |
|         |    | = | 03h Fixed disk was accessed             |
|         |    | = | Nonzero (Fixed Disk Service Error Code) |
|         |    | = | Fixed Disk Status (40:74h)              |
|         | CF | = | 0 No error                              |
|         |    | = | 1 Error                                 |
|         |    |   |                                         |

### AH reports drive number validity

For drive 80h, the Read Disk Type function references the fixed disk parameter table pointed to by the Interrupt 41h vector. For drive 81h, the function references the Interrupt 46h vector.

Unlike most other Fixed Disk Service functions, in the Read Disk Type function the value stored in AH is not equal to the value stored in Fixed Disk Status (40:74h). Instead, AH reports whether or not the drive number input into DL is valid (i.e., whether or not the drive is installed).

### **Error conditions**

If the drive number specified in DL is not valid, the Read Disk Type function sets AH, AL, CX, DX, the Carry Flag (CF), and Fixed Disk Status (40:74h) to zero, and returns control to the caller.

# Function: AH = 19h Park Heads

### Description

The Park Heads function positions the heads of the fixed disk read/write mechanism on the landing zone of the disk.

For drive 80h, the landing zone cylinder is specified in the fixed disk parameter table pointed to by the Interrupt 41h vector. For drive 81h, the landing zone cylinder is specified in the parameter table pointed to by the Interrupt 46h vector.

### Input/Output

| Input:  | AH | = | 19h                                                                                                            |
|---------|----|---|----------------------------------------------------------------------------------------------------------------|
|         | DL | = | Drive number<br>80h fixed disk 1<br>81h fixed disk 2                                                           |
| Output: |    | = | 00h No error<br>Nonzero (Fixed Disk Service Error Code)<br>Fixed Disk Status (40:74h)<br>0 No error<br>1 Error |

### **Error conditions**

If it is not successful, the Test for Drive Ready function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

# Function: AH = 1Ah Format ESDI Drive

# Description

The Format ESDI Drive function initializes the disk sector and track address fields on a drive attached to ESDI Fixed Disk Drive Adapter A. Normally, ESDI drives require an option ROM.

This function is a low level format that prepares the fixed disk for physical read/write operations at the sector level. The disk then has to be partitioned with the FDISK command and the FORMAT command used to give the disk a high level format and install a file system on it.

This function is not implemented in every BIOS. The Phoenix CBIOS supports ESDI low-level format through the Phoenix Reference Diskette.

### Warning

The formatting process will destroy all information on the fixed disk.

### Input/Output

| Input:  | AH    | = 1Ah                                                   |
|---------|-------|---------------------------------------------------------|
|         | AL    | = Relative block address (RBA) defect table block count |
|         |       | = 0 No RBA table                                        |
|         |       | > 0 RBA table is used                                   |
|         | CL    | = Format modifier bits, where                           |
|         |       | Bit 0 = ignore primary defect map                       |
|         |       | Bit 1 = ignore secondary defect map                     |
|         |       | Bit 2 = update secondary defect map                     |
|         |       | Bit 3 = do extended surface analysis                    |
|         |       | Bit 4 = generate periodic interrupt                     |
|         |       | Bits 5-7 = reserved (= 0)                               |
|         | DL    | = Drive number                                          |
|         |       | 80h fixed disk 1                                        |
|         |       | 81h fixed disk 2                                        |
|         | ES:B> | K = Pointer to RBA table                                |
| Output: | AH    | = 00h No error                                          |
|         |       | = Nonzero (Fixed Disk Service Error Code)               |
|         |       | = Fixed Disk Status (40:74h)                            |
|         | CF    | = 0 No error                                            |
|         |       | = 1 Error                                               |
|         |       |                                                         |

# **Error conditions**

If it is not successful, the Format ESDI Drive function returns to the caller with the Carry Flag (CF) set and the appropriate Fixed Disk Service error code in both AH and in Fixed Disk Status (40:74h).

Refer to the Error Conditions heading in this chapter for a table of Fixed Disk Service Error Codes.

# Additional information

- When bit 4 of CL is set, INT 15h function AH = 0Fh, subfunction AL = phase code is called after each cylinder is formatted or analyzed. The phase codes are:
  - 0 = reserved
  - 1 = surface analysis
  - 2 = formatting

Refer to INT 15h function AH = 0Fh for further information.

- When bit 2 of CL is set, the secondary defect map for the drive is updated so it reflects any errors found during surface analysis. The secondary defect map is replaced when both bit 1 and bit 2 are replaced.
- To do an extended surface analysis, first format the disk by calling this function with bit 3 cleared, then do the analysis by calling the function with bit 3 set.
- For other types of fixed disk adapters, this function is reserved.

# 12

# Chapter 12 INT 14h Serial Communications Service

# Overview

## Description

The CBIOS Serial Communications Service performs RS-232-C character I/O on IBM-compatible serial port adapters.

# How the Serial Communications Service is invoked

Software INT 14h invokes the CBIOS Serial Communications Service.

The INT 14h vector resides at address 00:50h in the Interrupt Vector Table. The CBIOS initializes the INT 14h vector to address F000:E739h, the IBMcompatible entry point.

# Summary of Serial Communications functions

The CBIOS Serial Communications Service contains six functions. Individual functions are selected via the AH register.

The table below summarizes the Serial Communications Service functions.

| Function | Description                           |
|----------|---------------------------------------|
| 00h      | Initialize Serial Communications Port |
| 01h      | Send Character                        |
| 02h      | Receive Character                     |
| 03h      | Read Serial Port Status               |
| 04h      | Extended Initialize                   |
| 05h      | Extended Serial Port Control          |
| 06h-FFh  | Reserved                              |

# In this chapter

This chapter focuses on the CBIOS Serial Communications Service. The following topics are discussed:

- Hardware Environment
- Serial Communications I/O Ports
- System RAM Data
- ROM BIOS Data
- Error Conditions
- Serial Communications Functions

# NS 16550 Serial Communications Controller

The CBIOS Serial Communications Service assumes a National Semiconductor NS 16550 serial communications controller (or compatible) is in place. The NS 16550 contains a programmable baud rate generator that supports baud rates from 50 baud to 19,200 baud. The NS 16550 also supports 5-, 6-, 7-, and 8-bit characters with 1-, 1.5-, or 2-stop bits operating in even, odd, and no parity modes.

# Serial port addresses/interrupt levels

| Serial Port Number | Base Address | Interrupt Level |
|--------------------|--------------|-----------------|
| 1                  | 03F8h        | 4               |
| 2                  | 02F8h        | 3               |
| 3                  | 3220h        | 3               |
| 4                  | 3228h        | 3               |
| 5                  | 4220h        | 3               |
| 6                  | 4228h        | 3               |
| 7                  | 5220h        | 3               |
| 8                  | 5228h        | 3               |

The following table lists the serial port base addresses.

# Serial Communications I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                               |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03F8h       | W                    | Serial 1, transmitter holding register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when Divisor Latch Access Bit<br>(DLAB) = 0                                                                                                                                                  |
| 03F8h       | R                    | Serial 1, receiver buffer register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when DLAB = 0                                                                                                                                                                                    |
| 03F8h       | R/W                  | Serial 1, divisor latch, low byte, where:<br>Bits 7-0 = Bits 7-0 of divisor, when DLAB = 1                                                                                                                                                                                                |
| 03F9h       | R/W                  | Serial 1, divisor latch, high byte, where:<br>Bits 7-0 = Bits 15-8 of divisor, when<br>DLAB = 1                                                                                                                                                                                           |
| 03F9h       | R/W                  | Serial 1 Interrupt ID Register, where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00b Modem Status Interrupt<br>01b Transmitter Holding Register<br>Empty Interrupt<br>10b Received Data Available<br>Register Interrupt<br>11b Receiver Line Status Interrupt<br>Bit 0 = 0 Interrupt Pending |
| 03FAh       | R                    | Serial 1 Interrupt ID Register, where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00b Modem Status Interrupt<br>01b Transmitter Holding Register<br>Empty Interrupt<br>10b Received Data Available<br>Register Interrupt<br>11b Receiver Line Status Interrupt<br>Bit 0 = 0 Interrupt Pending |

# Serial Communications I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03FAh       | W                    | Serial 1, FIFO Control Register, where:<br>Bits 7-6 = Receiver FIFO register trigger<br>00b = 1 byte<br>01b = 4 bytes<br>10b = 8 bytes<br>11b = 14 bytes<br>Bits 5-3 = 0 Reserved<br>Bit 2 = Transmitter FIFO register reset<br>1 = transmit FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 1 = Receiver FIFO register reset<br>1 = receiver FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 0 = FIFO enable<br>1 = receiver and transmitter FIFOs<br>enabled, must be 1 to program<br>FIFO registers<br>0 = clears receive and transmit<br>FIFO registers, enters<br>character mode |
| 03FBh       | R/W                  | Serial 1, Line Control Register, where:<br>Bit 7 = 0 Receiver Buffer, Transmitter<br>Holding, or Interrupt Enable<br>Registers Access<br>= 1 Divisor Latch Access<br>Bit 6 = 1 Set Break Enabled<br>Bit 5 = Stick Parity<br>Bit 4 = Even Parity Select<br>Bit 3 = Parity Enable<br>Bit 2 = 0 1 Stop Bit<br>= 1 0 Stop Bits<br>Bits 1-0 = 00b 5 Bit Word Length<br>10b 7 Bit Word Length<br>11b 8 Bit Word Length                                                                                                                                                                                                                            |
| 03FCh       | R/W                  | Serial 1, Mode Control Register, where:<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 1 Loopback Mode<br>Bit 3 = 1 Enable OUT2 Interrupt<br>Bit 2 = 1 Force OUT1 Active<br>Bit 1 = 1 Force Request-To-Send Active<br>Bit 0 = 1 Force Data-Terminal-Ready<br>Active                                                                                                                                                                                                                                                                                                                                                                                    |

# Serial Communications I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03FDh       | R/W                  | Serial 1, Line Status Register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter Shift and Holding<br>Registers Empty<br>Bit 5 = 1 Transmitter Holding Register Empty<br>Bit 4 = 1 Break Interrupt<br>Bit 3 = 1 Framing Error<br>Bit 2 = 1 Trailing Edge Ring Indicator<br>Bit1 = 1 Overrun Error<br>Bit 0 = 1 Data Ready   |
| 03FEh       | R                    | Serial 1, Modem Status Register, where:<br>Bit 7 = 1 Data Carrier Detect<br>Bit 6 = 1 Ring Indicator<br>Bit 5 = 1 Data Set Ready<br>Bit 4 = 1 Clear To Send<br>Bit 3 = 1 Delta Data Carrier Detect<br>Bit 2 = 1 Trailing Edge Ring Indicator<br>Bit 1 = 1 Delta Data Set Ready<br>Bit 0 = 1 Delta Clear To Send                  |
| 03FFh       | R                    | Serial 1, Scratch Register                                                                                                                                                                                                                                                                                                       |
| 02F8h       | W                    | Serial 2, transmitter holding register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when DLAB = 0                                                                                                                                                                                                                       |
| 02F8h       | R                    | Serial 2, receiver buffer register, where:<br>Bits 7-0 = Data bits 7-0, respectively,<br>when DLAB = 0                                                                                                                                                                                                                           |
| 02F8h       | R/W                  | Serial 2, divisor latch, low byte, where:<br>Bits 7-0 = Bits 7-0 of divisor, when DLAB = 1                                                                                                                                                                                                                                       |
| 02F9h       | R/W                  | Serial 2, divisor latch, high byte, where:<br>Bits 7-0 = Bits 15-8 of divisor, when DLAB = 1                                                                                                                                                                                                                                     |
| 02F9h       | R/W                  | Serial 2, interrupt enable register, where:         Bits 7-4 = 0 Reserved         Bit 3 = 1 Modem-status interrupt enable         Bit 2 = 1 Receiver-line-status interrupt enable         Bit 1 = 1 Transmitter-holding-register empty interrupt enable         Bit 0 = 1 Received-data-available interrupt enable when DLAB = 0 |

# Serial Communications I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02FAh       | R                    | Serial 2, interrupt identification register, where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00b Modem status interrupt<br>= 01b Transmitter holding register<br>empty interrupt<br>= 10b Received data available register<br>interrupt<br>= 11b Receiver line status interrupt<br>Bit 0 = 0 Interrupt pending                                                                                                                                                                                                                                                                                                                                  |
| 02FAh       | W                    | Serial 2, FIFO control register, where:<br>Bits 7-6 = Receiver FIFO register trigger<br>00b = 1 byte<br>01b = 4 bytes<br>10b = 8 bytes<br>11b = 14 bytes<br>Bits 5-3 = 0 Reserved<br>Bit 2 = Transmitter FIFO register reset<br>1 = transmit FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 1 = Receiver FIFO register reset<br>1 = receiver FIFO register cleared,<br>counter cleared, bit is self-<br>clearing<br>Bit 0 = FIFO enable<br>1 = receiver and transmitter FIFOs<br>enabled, must be 1 to program<br>FIFO registers<br>0 = clears receiver and transmits<br>FIFO registers, enters character<br>mode |
| 02FBh       | R/W                  | Serial 2, line control register, where:<br>Bit 7 = 1 Divisor latch access<br>= 0 Receiver buffer, transmitter<br>holding, or interrupt enable<br>registers access<br>Bit 6 = 1 Set break enable<br>Bit 5 = Stick parity<br>Bit 4 = Even parity select<br>Bit 3 = Parity enable<br>Bit 2 = Number of stop bits<br>Bits 1-0 = 00b Word length is 5 bits<br>= 01b Word length is 7 bits<br>= 11b Word length is 8 bits                                                                                                                                                                                                                           |
| 02FCh       | R/W                  | Serial 2, modem control register, where:<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 1 Loopback mode<br>Bit 3 = 1 Enable OUT2 interrupt<br>Bit 2 = 1 Force OUT1 active<br>Bit 1 = 1 Force request-to-send active<br>Bit 0 = 1 Force data-terminal-ready active                                                                                                                                                                                                                                                                                                                                                                                        |

# Serial Communications I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 02FDh       | R                    | <ul> <li>Serial 2, line status register, where:</li> <li>Bit 7 = 0 Reserved</li> <li>Bit 6 = 1 Transmitter shift and holding registers empty</li> <li>Bit 5 = 1 Transmitter holding register empty</li> <li>Bit 4 = 1 Break interrupt</li> <li>Bit 3 = 1 Framing error</li> <li>Bit 2 = 1 Parity error</li> <li>Bit 1 = 1 Overrun error</li> <li>Bit 0 = 1 Data ready</li> </ul> |
| 02FEh       | R                    | Serial 2, modem status register, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta to carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                                                    |
| 02FFh       | R/W                  | Serial 2, scratch register                                                                                                                                                                                                                                                                                                                                                       |

# Introduction

The Serial Communications Services make use of control information located in the BIOS data area (address 40:00 - 40:100). The table below describes those areas.

| Location | Length  | Description                                                                                                                |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------|
| 00h      | 4 Words | I/O address of up to 4 asynchronous communica-<br>tions adapters. One word for each asynchronous<br>communications adapter |
| 7Ch      | 4 Bytes | Serial (RS232) time-out table for serial ports 0 through 3. One byte per adapter.                                          |

# How the Serial Port Table is initialized

As it identifies each RS-232-C communications line, the CBIOS power-on self test (POST) places its corresponding base port address into the Serial Port Table (40:00h). In systems containing less than four serial ports, POST will initialize the base address for nonexistent ports to 0. All entries into the Serial Port Table are sequential. POST never writes a 0 into the Serial Port Table between two valid base address entries.

# **ROM BIOS Data**

#### Baud rate initialization table

The Baud Rate Initialization Table is located at F000:E729h in the ROM BIOS. The table is structured as follows:

| Baud Rate | Divisor |  |  |
|-----------|---------|--|--|
| 110       | 0417h   |  |  |
| 150       | 0300h   |  |  |
| 300       | 0180h   |  |  |
| 600       | 00C0h   |  |  |
| 1200      | 0060h   |  |  |
| 2400      | 0030h   |  |  |
| 4800      | 0018h   |  |  |
| 9600      | 000Ch   |  |  |
| 19200     | 0006h   |  |  |

# How baud rate divisor is calculated

The input frequency to the device is 1.8432 MHz. The values in the table are calculated as follows:

1,843,200 / 16 = 115200 / Baud Rate = Divisor

For example, a baud rate of 2400 has a divisor of 115200/2400, which equals 48 decimal, 30 hex.

#### Introduction

The Serial Communications Service detects two kinds of errors:

- Parameter-related errors
- Time-out errors

#### Parameter-related errors

The following parameter-related conditions are checked upon entry into each Serial Communications Service function.

- The function number specified in AH must fall within the range 0-5.
- The subfunction number specified in AL (if any) must fall within the range 0-1.
- The serial port specified in DX must fall within the range of 0-3.
- The serial port specified in DX must exist in hardware.

If any of the conditions above are not true, the Serial Communications Service does not perform the requested function and returns with all registers preserved.

#### Time-out errors

A time-out error occurs when either a read or a write of a specified communications line was unable to occur.

The Serial Communications Service read and write functions test the Line Status register and the Modern Status register. When a time-out error occurs, the contents of the status register being tested are returned with bit 7 "time-out error" set.

# Function: AH = 00h Initialize Serial Communications Port

# Description

The Initialize Serial Communications Port function initializes the selected adapter card from the Baud Rate, Parity, Stop Bit, and Word Length parameters specified in the AL register. The function returns with the Modem Status register and the line Status register in AL and AH, respectively. All other registers are preserved.

# 9600 baud limit

The Initialize Serial Communications Port function is unable to initialize a baud rate above 9600 baud because of input parameter size limitations. To initialize the adapter card at a higher rate, use function 04h.

#### Input/Output

| Input: | AH | = | 00h                                              |
|--------|----|---|--------------------------------------------------|
|        | AL | = | Serial port initialization parameters, where:    |
|        |    |   | Bits $7-5 =$ Baud rate, where:                   |
|        |    |   | 000b = 110 baud                                  |
|        |    |   | 001b = 150 baud                                  |
|        |    |   | 010b = 300 baud                                  |
|        |    |   | 011b = 600 baud                                  |
|        |    |   | 100b = 1200  baud                                |
|        |    |   | 110b = 4800 baud                                 |
|        |    |   | 111b = 9600 baud                                 |
|        |    |   | Bits 4-3 = Parity, where:                        |
|        |    |   | 00b = None                                       |
|        |    |   | 01b = Odd                                        |
|        |    |   | 10b = None                                       |
|        |    |   | 11b = Even                                       |
|        |    |   | Bit 2 = Number of stop bits, where:              |
|        |    |   | 0b = 1 Stop bit<br>1b = 2 Stop bits              |
|        |    |   | Bits $1-0 =$ Character size, where:              |
|        |    |   | 10b = 7-bit characters                           |
|        |    |   | 11b = 8-bit characters                           |
|        | DX | = | Serial port number (valid values are 0, 1, 2, 3, |
|        | DA | - | where $0 = COM1$ , $1 = COM2$ , etc.)            |
|        |    |   |                                                  |

Input/Output, cont'd

**Output:** AH = Line Status, where: Bit 7 = 0 Reserved Bit 6 = 1 Transmitter shift and holding register empty Bit 5 = 1 Transmitter holding register empty Bit 4 = 1 Break interrupt Bit 3 = 1 Framing error Bit 2 = 1 Parity error Bit 1 = 1 Overrun error Bit 0 = 1 Data ready AL = Modem Status, where: Bit 7 = 1 Data carrier detect Bit 6 = 1 Ring indicator Bit 5 = 1 Data set ready Bit 4 = 1 Clear to send Bit 3 = 1 Delta data carrier select Bit 2 = 1 Trailing edge ring indicator Bit 1 = 1 Delta data set ready Bit 0 = 1 Delta clear to send

# Function: AH = 01h Send Character

# Description

The Send Character function transmits the character supplied in AL over the communication line specified in DX.

If successful, this function returns with the contents of the Line Status Register in AH, Bit 7 = 0. If unsuccessful, AH, Bit 7 = 1.

#### Input/Output

| Input:  |    | = | 01h<br>Character<br>Serial Port Number (valid values are 0, 1, 2, 3, where<br>0 = COM1, $1 = COM2$ , etc.                                                                                                                                                                                                                                             |
|---------|----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH |   | Line Status Register, where:<br>Bit 7 = 0 No time-out error has occurred<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register empty<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready<br>Character sent (unchanged) |

#### **Error conditions**

When a time-out error occurs during the execution of the Send Character function, the value returned in AH can reflect the state of either the Modem Status Register or of the Line Status Register. However, since bit 7 of AH is used to report that an error has occurred, it is not available to report a time-out error. For this reason, if this function or INT 14h function 02h reports an error, it is preferable to use INT 14h function 03h, which gives a complete status report, rather than the less-complete status bits returned with the error bit in functions 01h and 02h.

#### Description

The Receive Character function receives one character from the serial port specified in the DX register.

If successful, this function returns with the character received in the AL register. The contents of the Line Status Register is returned in the AH register.

#### Input/Output

| Input:  | AH<br>DX | 02h<br>Serial port number (Valid values are 0, 1, 2, 3,<br>where 0 = COM1, 1 = COM2, etc.)                                                                                                                                                                                                                                                    |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH       | Line Status Register, where:<br>Bit 7 = 0 No time-out error has occurred<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register empty<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready<br>Character received |

# **Error conditions**

If a time-out error occurs during the execution of the Receive Character function, the value returned in AH can reflect the state of either the Modem Status Register or of the Line Status Register. However, since bit 7 of AH is used to report that an error has occurred, it is not available to report a time-out error. For this reason, if this function or INT 14h function 01h reports an error, it is preferable to use INT 14h function 03h, which gives a complete status report, rather than the less-complete status bits returned with the error bit in functions 01h and 02h.

# Function: AH = 03h Read Serial Port Status

# Description

The Read Serial Port Status function returns the current Modern Status in the AL register and the current Line Status in the AH register. All other registers are preserved.

# Input/Output

| Input:  | AH<br>DX | 03h<br>Serial port number (Valid values are 0, 1, 2, 3, where<br>0 = COM1, 1 = COM2, etc.)                                                                                                                                                                                                                       |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH       | Line Status, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register empty<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready<br>Modem status, where: |
|         |          | Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta data carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                             |

1

# Description

The Extended Initialize function does an extended initialization of the adapter card selected in the DX register based on the Break, Parity, Stop Bit, Word Length, and Baud Rate values placed in the BH, BL, CH, and CL registers. This function is a superset of function 00h.

The function returns with the Modern Status Register and the Line Status Register in the AL and AH registers, respectively.

This function must be used to initialize baud rates greater than 9600.

# Input/Output

| Input: | AH | = | 04h                                        |
|--------|----|---|--------------------------------------------|
|        | AL | = | Break, where:                              |
|        |    |   | 00h = No break                             |
|        |    |   | 01h = Break                                |
|        | BH | = | Parity, where:                             |
|        |    |   | 00h = None                                 |
|        |    |   | 01h = Odd                                  |
|        |    |   | 02h = Even                                 |
|        |    |   | 03h = Stick parity odd                     |
|        |    |   | 04h = Stick parity even                    |
|        | BL | = | Stop Bit, where:                           |
|        |    |   | 00h = One                                  |
|        |    |   | 01h = Two if 6-, 7-, or 8- bit word length |
|        |    |   | One-and-one-half if 5-bit word length      |
|        | СН | = | Word length, where:                        |
|        |    |   | 00h = 5 Bits                               |
|        |    |   | 01h = 6 Bits                               |
|        |    |   | 02h = 7 Bits                               |
|        |    |   | 03h = 8 Bits                               |
|        |    |   |                                            |

# Input/Output, cont'd

| Input:<br>(cont'd) | CL |   | Baud rate, where:<br>00h = 110 Baud<br>01h = 150 Baud<br>02h = 300 Baud<br>03h = 600 Baud<br>04h = 1200 Baud<br>05h = 2400 Baud<br>06h = 4800 Baud<br>07h = 9600 Baud<br>08h = 19200 Baud<br>RS-232-C communications line to use (Valid values are<br>0, 1, 2, 3, where $0 = COM1, 1 = COM2$ , etc.) |
|--------------------|----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output:            | АН | = | Line Status<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register empty<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready                     |
|                    | AL | = | Modem Status<br>Bit 7 = 1 Time-out error<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta data carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                      |

#### Introduction

The Modem Control Register is an 8-bit register that controls data exchange with the modem, data set, or peripheral device emulating a modem.

The Extended Serial Port Control function will either read from or write to the Modern Control Register depending on the parameter input into the AL register. The two subfunctions and their AL register parameter values are listed below:

- AL = 00h Read the Modern Control Register
- AL = 01h Write to the Modem Control Register

# Function: AH = 05h Extended Serial Port Control, Continued

#### Subfunction: AL = 00h read the modem control register

This subfunction reads the NS 16550 (or compatible) Modem Control Register and returns the value in BL. The Modern Status Register is returned in AL.

| input/Output |                |   |                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|----------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input:       | AH<br>AL<br>DX | = | 05h Extended serial port control<br>00h Read the Modem Control Register<br>RS-232-C communications line to use (Valid values are<br>0, 1, 2, 3, where 0 = COM1, 1 = COM2, etc.)                                                                                                                                                                                                                                                |
| Output:      | AH             |   | Line Status, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready<br>Modem status, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send |

Input/Output

- Bit 3 = 1 Delta data carrier detect
- Bit 2 = 1 Trailing edge ring indicator
- Bit 1 = 1 Delta data set ready
- Bit 0 = 1 Delta clear to send
- BL = Modem Control Register, where:
  - Bits 7-5 = 0 Reserved
  - Bit 4 = 1 Loopback mode
  - Bit 3 = 1 Enable OUT2 interrupt
  - Bit 2 = 1 Force OUT1 active

Bit 1 = 1 Force request-to-send active

Bit 0 = 1 Force data-terminal-ready active

All other registers are preserved.

continued

# Function: AH = 05h Extended Serial Port Control, Continued

# Subfunction: AL = 01h write modem control register

This subfunction writes the value placed in BL to the NS 16550 Modem Control Register. The subfunction returns with the value written to the Modem Control Register in BL, the Modem Status register in AL, and the Line Status register in AH.

# Input/Output

| Input:  | AH<br>AL<br>BL | = | 05h Extended Serial Port Control<br>01h Write Modem Control Register<br>Modem Control Register, where:<br>Bits 7-5 = 0 Reserved<br>Bit 4 = 1 Loopback mode<br>Bit 3 = 1 Enable OUT2 interrupt<br>Bit 2 = 1 Force OUT1 active<br>Bit 1 = 1 Force request-to-send active<br>Bit 0 = 1 Force data-terminal-ready active<br>RS-232-C communications line to use (Valid values are<br>0, 1, 2, 3, where 0 = COM1, 1 = COM2, etc.) |
|---------|----------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | АН             | = | Line Status, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Transmitter shift and holding register empty<br>Bit 5 = 1 Transmitter holding register<br>Bit 4 = 1 Break interrupt<br>Bit 3 = 1 Framing error<br>Bit 2 = 1 Parity error<br>Bit 1 = 1 Overrun error<br>Bit 0 = 1 Data ready                                                                                                                                           |
|         | AL             | = | Modem status, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta data carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                                                                                                                 |

# Function: AH = 05h Extended Serial Port Control, Continued

Subfunction: AL = 01h, cont'd

| Output:                            | BL | = | Modem (    | Co | ntrol Register, where:             |
|------------------------------------|----|---|------------|----|------------------------------------|
| (cont'd)                           |    |   | Bits 7-5 : | =  | 0 Reserved                         |
|                                    |    |   | Bit 4 =    | =  | 1 Loopback mode                    |
|                                    |    |   | Bit 3 =    | =  | 1 Enable OUT2 interrupt            |
|                                    |    |   | Bit 2 :    | =  | 1 Force OUT1 active                |
|                                    |    |   | Bit 1 =    | =  | 1 Force request-to-send active     |
|                                    |    |   | Bit 0 =    | =  | 1 Force data-terminal-ready active |
| All other registers are preserved. |    |   |            |    |                                    |

Functions: AH = 06h - FFh Reserved

# 13

# Chapter 13 INT 15h System Services

# Overview

### Introduction

INT 15h, System Services, provides several services:

# ABIOS initialization routines

The CBIOS System Services contain two functions that are called during ABIOS initialization. These services are reserved exclusively for operating systems that employ the ABIOS.

### Multitasking hooks

The CBIOS provides six hooks for use by multitasking operating systems. In a DOS environment (which is not a multitasking operating system) these six functions do nothing except return to the caller. A multitasking operating system would normally intercept these function calls by replacing the INT 15h vector and processing these function calls itself.

# Joystick support

Function 84h supports up to two joysticks. Function 84h has two subfunctions: read current switch settings and read resistive inputs.

# Introduction, cont'd

# Wait routines

INT 15h provides two wait functions: Function 83h, Set Event Wait Interval, and Function 86h, Wait. Function 86h does not return control to the caller until a specified interval is completed. Function 83h returns control to the caller.

### Protected mode support

The CBIOS System Services provides limited protected mode support through two functions: Function 87h, Move Block, and function 89h, Switch Processor to Protected Mode.

The ABIOS provides full protected mode, bimodal, and real mode addressing support.

### Pointing device interface

INT 15h function C2h provides complete mouse support.

### System information

Function C0h, Return System Configuration Parameters, Function C1h, Return Extended BIOS Data Area Segment Address, Function C3h, Watchdog time-out, and Function C4h, Programmable Option Select, provide detailed system services.

# How INT 15h services are invoked

INT 15h invokes the CBIOS System Services.

The INT 15h vector resides at Interrupt table address 00:3Ch. To insure compatibility, the CBIOS initializes the INT 15h vector to F000:F859h.

Individual System Services functions are selected via the AH register. Subfunctions are selected via the AL, DX, or BH registers.

#### Summary of INT 15h system services

The table below lists the System Services functions and subfunctions.

Note: Functions AH = 80h, 81h, 82h, 85h, 90h, and 91h (i.e. those marked with an asterisk in the table below) are multitasking hooks. A multi-tasking operating system would normally intercept these function calls by replacing the INT 15h vector and processing these function calls itself. In DOS (which is not a multitasking operating system) these six functions do nothing except return immediately to the caller with the Carry Flag cleared.

| Reserved<br>Build System Parameters Table<br>Build Initialization Table<br>Reserved                         |
|-------------------------------------------------------------------------------------------------------------|
| Build Initialization Table<br>Reserved                                                                      |
| Reserved                                                                                                    |
|                                                                                                             |
| Formert FCDI Duive Deviadio Internunt                                                                       |
| Format ESDI Drive Periodic Interrupt                                                                        |
| Reserved                                                                                                    |
| Power-On Self Test Error Log<br>AL = 00h Read POST Error Log<br>AL = 01h Write Error Code to POST Error Log |
| Reserved                                                                                                    |
| Keyboard Intercept                                                                                          |
| Reserved                                                                                                    |
| Device Open*                                                                                                |
| Device Close*                                                                                               |
| Program Termination*                                                                                        |
| Set Event Wait Interval                                                                                     |
| AL = 00h Set Wait<br>AL = 01h Cancel Wait                                                                   |
| Joystick Support<br>DX = 00h Read Current Switch Settings<br>DX = 01h Read Resistive Inputs                 |
| System Request Key*                                                                                         |
|                                                                                                             |

| AH Value               | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 86h                    | Wait                                                                                                                                                                                                                                                                                                                                                                          |
| 87h                    | Move Block                                                                                                                                                                                                                                                                                                                                                                    |
| 88h                    | Read Extended Memory Size                                                                                                                                                                                                                                                                                                                                                     |
| 89h                    | Switch Processor to Protected Mode                                                                                                                                                                                                                                                                                                                                            |
| 8Ah to 8Fh             | Reserved                                                                                                                                                                                                                                                                                                                                                                      |
| 90h                    | Device Busy Loop*                                                                                                                                                                                                                                                                                                                                                             |
| 91h                    | Interrupt Complete*                                                                                                                                                                                                                                                                                                                                                           |
| 92h to BFh             | Reserved                                                                                                                                                                                                                                                                                                                                                                      |
| C0h                    | Return System Configuration Parameters                                                                                                                                                                                                                                                                                                                                        |
| C1h                    | Return Extended BIOS Data Area Segment Address                                                                                                                                                                                                                                                                                                                                |
| C2h                    | Pointing Device InterfaceAL = 00hEnable/Disable Pointing DeviceAL = 01hReset Pointing DeviceAL = 02hSet Sample RateAL = 03hSet ResolutionAL = 04hRead Device TypeAL = 05hPointing Device Interface InitializationAL = 06hExtended CommandsBH = 00hReturn StatusBH = 01hSet Scaling Factor to 1=1BH = 02hSet Scaling Factor to 2=1AL = 07hDevice Drive Far Call Initialization |
| C3h                    | Watchdog Time-out<br>AL = 00h Disable watchdog time-out<br>AL = 01h Enable watchdog time-out                                                                                                                                                                                                                                                                                  |
| C4h                    | Programmable Option Select<br>AL = 00h Return Base Position Adapter Register<br>Address<br>AL = 01h Enable Cursor for Setup<br>AL = 02h Adapter Enable                                                                                                                                                                                                                        |
| C5h to FFh             | Reserved                                                                                                                                                                                                                                                                                                                                                                      |
| * Multitasking hooks ( | described in note above)                                                                                                                                                                                                                                                                                                                                                      |

# Summary of INT 15h System Services, cont'd

# Overview, Continued

# In this chapter

The following topics are discussed in the rest of the INT 15h System Services chapter:

- Hardware Environment
- System Services I/O Ports
- System RAM Data
- Extended System RAM Data
- CMOS RAM Data
- ROM BIOS Data
- System Services Functions

# Hardware Environment

The INT 15h System Services routines assume the existence of two 8259A Programmable Interrupt Controllers, an 8237 DMA controller, an 8254 programmable interval timer/counter chip, and an 8042/8242 keyboard controller or equivalents thereof.

These routines deal with input/output devices, including keyboards, mouse pointing devices, joysticks, touch pads, track balls, RS-232 devices, and other serial devices.

# System Services I/O Ports

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0020h       | w                    | Programmable interrupt controller 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0021h       | R/W                  | Programmable interrupt controller 1 mask                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0040h       | R/W                  | Programmable Interrupt Timer – Read/write counter 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0043h       | W                    | Control byte for timers 0 and 2, where:<br>Bits 7-6 = timer select, where<br>00b = select timer 0<br>01b = reserved<br>10b = select timer 2<br>Bits 5-4 = timer action where:<br>00b = counter latch command<br>01b = read/write counter bits 0-7<br>only<br>10b = read/write counter bits 8-15<br>only<br>11b = Read/write counter bits 0-7<br>first, then bits 8-15<br>Bits 3-1 = timer mode where<br>000b = mode 0 select<br>001b = mode 1 select<br>X10b = mode 2 select<br>X10b = mode 4 select<br>100b = mode 4 select<br>100b = mode 5 select<br>Bit 0 = 1 binary coded decimal counter<br>= 0 binary counter 16 bits |

INT 15h, System Services, references the following I/O ports:

# System Services I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                             |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0044h       | R/W                  | Timer 3 counter register                                                                                                                                                                                                                                                                                                                |
| 0047h       | W                    | Control byte for timer three where:<br>Bits 7–6 = 00b select timer 3<br>Bits 5–4 = 00b counter latch command<br>= 01b read/write counter bit 0–7 only<br>Bits 3–0 = 0 reserved                                                                                                                                                          |
| 0060h       | R/W                  | Keyboard/auxiliary data port                                                                                                                                                                                                                                                                                                            |
| 0061h       | R                    | System control port B, where:Bit 7= 1 Parity checkBit 6= 1 Channel checkBit 5= 1 Timer 2 outputBit 4= 1 Toggle with each refresh requestBit 3= 0 Channel check enabledBit 2= 0 Parity check enabledBit 1= 1 Speaker data enabledBit 0= 1 Timer 2 gate to speaker enabled                                                                |
| 0061h       | w                    | System control port B, where:<br>Bit 7 = 1 Reset timer 0 output latch (IRQ 0)<br>Bits 6-4 = Reserved<br>Bit 3 = 0 Enable channel check<br>Bit 2 = 0 Enable parity check<br>Bit 1 = 1 Speaker data enable<br>Bit 0 = 1 Enable timer 2 gate to speaker                                                                                    |
| 0064h       | R                    | 8042 Status, where:Bit 7= 1 Parity errorBit 6= 1 General time outBit 5= 1 Auxiliary output buffer fullBit 4= 1 Inhibit switchBit 3= 1 Command/dataBit 2= System flagBit 1= 1 Input buffer fullBit 0= 1 Output buffer full                                                                                                               |
| 0064h       | w                    | 8042 Commands                                                                                                                                                                                                                                                                                                                           |
| 0070h       | w                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>Bits 6-0 = 0 CMOS address                                                                                                                                                                                                                                            |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                                                                             |
| 0092h       | R/W                  | System control port A, where:<br>Bit 7 = 1 Fixed disk activity light bit A is on<br>Bit 6 = 1 Fixed disk activity light bit B is on<br>Bit 5 = 0 Reserved<br>Bit 4 = 1 Watchdog time-out occurred<br>Bit 3 = 1 Security lock latch locked<br>Bit 2 = 0 Reserved<br>Bit 1 = 1 Alternate gate A20 active<br>Bit 0 = 1 Alternate hot reset |

# System Services I/O Ports, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                         |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0094h       | W                    | System board setup enable register, where:<br>Bit 7 = 0 Enable system board setup<br>Bit 6 = 1 Reserved<br>Bit 5 = 0 Enable VGA setup<br>Bits 4-0 = 1 Reserved                                                                                                                                                      |
| 0096h       | R/W                  | Channel position select register, where:<br>Bit 7 = 1 Channel reset<br>Bits 6-4 = Reserved (written as 0, read as 1)<br>Bit 3 = 1 Channel select<br>Bits 2-0 = Channel number                                                                                                                                       |
| 00A0h       | w                    | Programmable Interrupt Controller 2                                                                                                                                                                                                                                                                                 |
| 00A1h       | R/W                  | Interrupt Controller 2 mask, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Enable fixed disk Interrupt<br>Bit 5 = 0 Enable 80387 exception Interrupt<br>Bit 4 = 0 Enable mouse Interrupt<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Reserved<br>Bit 1 = 0 Enable redirect cascade<br>Bit 0 = 0 Enable real time clock Interrupt |
| 0100h       | R                    | System board or adapter ID (low byte)                                                                                                                                                                                                                                                                               |
| 0101h       | R                    | System board or adapter ID (high byte)                                                                                                                                                                                                                                                                              |
| 0201h       | R/W                  | Joystick port                                                                                                                                                                                                                                                                                                       |

# System RAM Data

# System RAM data table

The following table shows the data definitions used by INT 15h. The data definitions are stored in system RAM in segment 40h.

| Location | Size    | Description                                                                                                            |
|----------|---------|------------------------------------------------------------------------------------------------------------------------|
| 40:0Eh   | 2 Words | Extended BIOS data area segment                                                                                        |
| 40:67h   | 2 Words | Pointer to reset code (Offset:segment)                                                                                 |
| 40:98h   | 1 Word  | User wait flag offset address                                                                                          |
| 40:9Ah   | 1 Word  | User wait flag segment address                                                                                         |
| 40:9Ch   | 1 Word  | Least significant wait count                                                                                           |
| 40:9Eh   | 1 Word  | Most significant wait count                                                                                            |
| 40:A0h   | 1 Word  | Wait active flag, where:<br>Bit 7 = 1 Wait time elapsed<br>Bits 6-1 = Reserved<br>Bit 0 = 1 INT 15h, AH = 86h occurred |

# Extended System RAM Data

# Extended System RAM Table

The following table provides the name, length, location, and description of all extended System RAM data areas used by the auxiliary device service:

| Location                                              | Size    | Description                                                                                                                                                                                                                                                                                |  |
|-------------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| EDA:17h                                               | 1 Byte  | Number of error codes in the POST error log                                                                                                                                                                                                                                                |  |
| EDA:18h                                               | 5 Words | POST error log                                                                                                                                                                                                                                                                             |  |
| EDA:39h                                               | 1 Byte  | Watchdog timer initial count                                                                                                                                                                                                                                                               |  |
| EDA:22h                                               | 1 Word  | Device drive offset                                                                                                                                                                                                                                                                        |  |
| EDA:24h                                               | 1 Byte  | Device driver segment                                                                                                                                                                                                                                                                      |  |
| EDA:26h                                               | 1 Byte  | Pointing device flag (Flag 1)<br>Bit 7 = 1 Command in progress<br>Bit 6 = 1 Resend received from auxiliary device<br>Bit 5 = 1 Acknowledge received from auxiliary<br>device<br>Bit 4 = 1 BAT failure received from auxiliary<br>device<br>Bits 3-0 = Data package size counter (in bytes) |  |
| EDA:27h                                               | 1 Byte  | Pointing device flag (Flag 1)<br>Bit 7 = 1 Device driver far call installed<br>Bit 6 = 1 Pointing device interface installed<br>Bit 5 = Reserved<br>Bit 4 = Reserved<br>Bits 3-0 = Data package size (in bytes)                                                                            |  |
| Note: EDA = Segment of Extended System RAM Data Area. |         |                                                                                                                                                                                                                                                                                            |  |

# CMOS RAM Data

# CMOS RAM data area table

The following table describes all CMOS RAM locations used by the INT 15h System Services routines:

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Bh      | 1 Byte | Status register B, where:<br>Bit 7 = 0 Run<br>= 1 Halt<br>Bit 6 = 1 Enable periodic interrupt<br>Bit 5 = 1 Enable alarm interrupt<br>Bit 4 = 1 Enable update-ended interrupt<br>Bit 3 = 1 Enable square wave interrupt<br>Bit 2 = 1 Calendar is in binary format<br>= 0 Calendar is in BCD format<br>Bit 1 = 1 24-hour mode<br>= 0 12-hour mode<br>Bit 0 = 1 Enable Daylight Savings Time                                                            |
| 0Fh      | 1 Byte | Reason for shutdown, where:<br>00h = Power on or soft reset<br>01h = Memory size pass<br>02h = Memory test pass<br>03h = Memory test fail<br>04h = POST end; boot system<br>05h = JMP dword pointer with end-of-interrupt<br>06h = Protected tests pass<br>07h = Protected tests fail<br>08h = Memory size fail<br>08h = Memory size fail<br>09h = INT 15h Block Move<br>0Ah = JMP dword pointer without end-of-<br>interrupt<br>0Bh = Used by ABIOS |
| 34h      | 1 Byte | Miscellaneous information<br>Bits 7-4 = Actual number of RS-232 ports installed<br>Bits 3-0 = Block move status before reset to real<br>mode                                                                                                                                                                                                                                                                                                         |
| 35h      | 1 Byte | Low byte of actual expansion memory size                                                                                                                                                                                                                                                                                                                                                                                                             |
| 36h      | 1 Byte | High byte of actual expansion memory size                                                                                                                                                                                                                                                                                                                                                                                                            |

# System configuration table

The System Configuration table is located in the CBIOS ROM at F000:E6F5h. This table can be called into RAM via INT 15h function AH = C0h Return System Configuration Parameters.

| Offset | Initial<br>value | Length | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h    | 0                | 1 Word | Number of bytes in this table (minimum = 8)                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 02h    | 1                | 1 Byte | Model byte, where:<br>Model 80 = F8h<br>Model 70 = F8h<br>Model 60 = FCh<br>Model 50 = FCh<br>Model 30 = FAh<br>Model 25 = FAh<br>Unknown system board = FFh                                                                                                                                                                                                                                                                                                                          |
| 03h    | 1                | 1 Byte | Submodel byte, where:           Model 80         = 00h or 01h           Model 70         = 09h           Model 60         = 05h           Model 50         = 04h           Model 30         = 00h           Model 25         = 01h           Unknown system board = FFh                                                                                                                                                                                                               |
| 04h    | 1                | 1 Byte | BIOS revision level (first release = 00b)                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 05h    | 1                | 1 Byte | Feature information byte, where:<br>Bit 7 = 1 Fixed disk BIOS uses DMA channel 3<br>Bit 6 = 1 Second interrupt chip present<br>Bit 5 = 1 Real time clock present<br>Bit 4 = 1 Keyboard intercept (INT 15h, function<br>AH = 4Fh) called by keyboard interrupt<br>service (INT 09h)<br>Bit 3 = 1 Wait for external event supported<br>Bit 2 = 1 Extended BIOS data area is allocated<br>Bit 1 = 1 Micro Channel supported<br>= 0 PC-type I/O channel implemented<br>Bit 0 = 0 Reserved |
| 06h    | 0                | 1 Byte | Feature information byte 2 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 07h    | 1                | 1 Byte | Feature information byte 3 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 08h    | 1                | 1 Byte | Feature information byte 4 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 09h    | 0                | 1 Byte | Feature information byte 5 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Function: AH = 04h Build System Parameters Table

#### Description

The System Parameters table lists the system stack requirements, the number of devices installed in the system, and entry points of the ABIOS Common Entry routines. An operating system (e.g. MS OS/2) calls this CBIOS function during the first step in initializing ABIOS. This function preserves the interrupt flag and the contents of the DS register.

This function should only be called by operating systems that make use of the ABIOS. Calling this function from within DOS will give unpredictable results.

| Input:                                                | AH    | = 04h                                                        |  |  |  |
|-------------------------------------------------------|-------|--------------------------------------------------------------|--|--|--|
|                                                       | ES:DI | = Pointer to location in RAM where the table is to be built. |  |  |  |
|                                                       | DS    | = Segment of the Extended System RAM data area.              |  |  |  |
|                                                       |       | (Offset is assumed to be 0000h)                              |  |  |  |
| Output:                                               | AH    | = 00h lf function was successful                             |  |  |  |
|                                                       | CF    | = 1 Exception error has occurred                             |  |  |  |
| Note: All registers except AX and flags are restored. |       |                                                              |  |  |  |

#### For more information

For more information on ABIOS initialization, refer to the volume, ABIOS for IBM PS/2 Computers and Compatibles, in this series.

# Function: AH = 05h Build Initialization Table

#### Description

The ABIOS Initialization Table describes the initialization information for each device ABIOS is to support. An operating system (e.g. MS OS/2) calls this CBIOS function during the second step in initializing ABIOS. This function preserves the interrupt flag and the contents of the DS register.

This function should only be called by operating systems that make use of the ABIOS. Calling this function from within DOS will give unpredictable results.

| Input:  | AH       | = 05h                                                                                                                |
|---------|----------|----------------------------------------------------------------------------------------------------------------------|
|         | ES:DI    | = Pointer to location in RAM where the table is to be built.                                                         |
|         | DS       | <ul> <li>Segment of the Extended System RAM data area.</li> <li>(Offset is assumed to be 0000h)</li> </ul>           |
| Output: | AH<br>CF | <ul> <li>= 00h If function was successful</li> <li>= 0 No error</li> <li>= 1 Exception error has occurred</li> </ul> |

Note: All registers except AX and flags are restored.

#### For more information

For more information on ABIOS initialization, refer to the volume, ABIOS for IBM PS/2 Computers and Compatibles, in this series.

# Functions: AH = 06h-0Eh Reserved

# Description

The BIOS uses this function on an ESDI Fixed Disk Drive Adapter/A when doing a format or surface analysis operation and after each cylinder is completed. Refer to INT 13h, function AH = 1Ah Format ESDI Drive. These devices generally require an option ROM.

| Input:  | AH | = | OFh                                                                                    |
|---------|----|---|----------------------------------------------------------------------------------------|
|         | AL | = | Phase code                                                                             |
|         |    | = | 0 Reserved                                                                             |
|         |    | = | 1 Surface analysis                                                                     |
|         |    | = | 2 Formatting                                                                           |
| Output: | CF |   | 0 Formatting or analysis should continue<br>1 Formatting or analysis should be stopped |

# Additional information

- A program can intercept this function call so it will be informed as each cylinder is formatted or analyzed. The program could count the interrupts for each phase to get the current cylinder number.
- The BIOS default handler for this function will return with the carry flag set.
- For other types of fixed disk adapters, this function is reserved. Also, not every BIOS implements this function.

# Function: AH = 10h - 20h Reserved

# Function: AH = 21h Power-On Self Test Error Log

# Description

This function has two subfunctions which actually read and write to and from the POST error log. This error log holds one word (16 bit) error codes which are used by the reference diskette to select the appropriate diagnostic message. These subfunctions are called by entering either 00h or 01h in register AL. If any other value is in AL, AH is set to two, one is subtracted from AL, CF is set to one, and control is returned to the caller.

The error log is stored at 40:27h in the extended system RAM data area. Up to five errors can be logged into the array. The number of error codes logged is stored in 40:26h.

Models 25 and 30: This function is not available on IBM PS/2 Models 25 and 30 (and compatibles).

| Input:  | AH | = | 21h                                    |
|---------|----|---|----------------------------------------|
|         | AL | = | 00h Read POST error log                |
|         |    | = | 01h Write error code to POST error log |
| Output: | CF |   | 0 No error<br>1 Invalid input          |

# Subfunction: AL = 00h Read POST error log

This subfunction returns the number of logged error codes and a pointer to the error log. The information returned in this function reflects the results of the last POST that was performed. 40:26h contains the number of error codes. 40:27h is the pointer to the POST error log, which is made up of single word entries. The first byte is the device error code. The second byte is the device identifier.

| Input:  | AH    | = 21h                               |
|---------|-------|-------------------------------------|
|         | AL    | = 00h                               |
|         | CF    | = 0                                 |
| Output: | AH    | = 00h                               |
|         | BH    | = 00h                               |
|         | BL    | = Number of POST error codes stored |
|         | ES:DI | = Pointer to POST error log.        |

#### Subfunction: AL = 01h Write error code to POST error log

This subfunction stores the device and error code in BX into the POST error log. If the maximum number of errors (5) is already stored, this code is not stored.

| AH | =                          | 21h                                             |
|----|----------------------------|-------------------------------------------------|
| AL | =                          | 01h                                             |
| BH | =                          | Device code                                     |
| BL | =                          | Device error                                    |
| AH | =                          | 00h Successful                                  |
|    | =                          | 01h Error code; location full                   |
| AL |                            | Index into error log, if successful             |
|    | =                          | 05h Error code; location full                   |
| CF | =                          | 0 No error                                      |
|    | =                          | 1 Error code location full (AH = 01h; AL = 05h) |
|    | AL<br>BH<br>BL<br>AH<br>AL | BH =<br>BL =<br>AH =<br>AL =<br>CF =            |

#### **Error conditions**

No error codes are stored if the maximum number of codes is already stored. If the maximum number of error codes is already stored, AH is set to one, AL to 5, CF to 1, and control is returned to the caller.

# Functions: AH = 22h – 4Eh Reserved

# Function: AH = 4Fh Keyboard Intercept

# Description

The keyboard interrupt function is called by INT 09h when any key is pressed. This function returns the scan code in AL with CF = 1. This function can be used to scan codes to create alternate keyboard layouts, and to cause systems to ignore certain keystrokes.

An operating system or resident utility can intercept this function in order to filter the raw keyboard data stream. A new handler can be written to substitute a different scan code, return the existing scan code, or return the carry flag cleared (thus causing the keystroke to be discarded).

Input: AH = 4Fh Output: AL = Scan code CF = 0 Keystroke unchanged (original scan code in AL) = 1 Keystroke changed (new scan code in AL)

INT 15h function C0h can be called to see if a machine's BIOS supports the keyboard intercept function.

# Functions: AH = 50h - 7Fh Reserved

#### Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. This is a way of capturing control of a logical device so as to arbitrate its usage by multiple processes.

Input: AH = 80h BX = Device ID CX = Process ID Output: AX = 0080h

# Function: AH = 81h Device Close

#### Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. This function releases control of a logical device for a process. See also INT 15 functions 80h and 82h.

Input: AH = 81h BX = Device ID CX = Process IDOutput: AX = 0081h

# Function: AH = 82h Program Termination

# Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. This function releases control of all logical devices for a process that will soon terminate. See also INT 15h functions 80h 81h.

Input: AH = 82h BX = Device ID Output: AX = 0082h

#### Description

INT 15h provides two wait functions: Function 83h, Set Event Wait Interval, and Function 86h, Wait. Function 86h does not return control to the caller until a specified interval is completed. Function 83h returns control to the caller.

Models 25 and 30: This function is not available on IBM PS/2 Models 25 and 30 (and compatibles).

| Input:  | AH | = | 83h                      |
|---------|----|---|--------------------------|
|         | AL | = | 00h Set wait function    |
|         |    | = | 01h Cancel wait function |
| Output: | CF | = | 0 No error               |
|         |    | = | 1 Invalid input          |

#### **Error conditions**

If the subfunction code in AL is not 00h or 01h, one is subtracted from AL, CF is set to one, and control is returned to the caller.

# **Additional Information**

- An event wait's duration is an integral multiple of 976 microseconds. This function is implemented with CMOS date/clock interrupts.
- Use this function to get programmed, hardware-independent delays of finer granularity than provided with the MS-DOS Get Time function (INT 21h function 2Ch). The latter returns time only in hundredths of a second.
- See also INT 15h function 86h, Wait, which halts the calling program for an interval specified in milliseconds.

# Function: AH = 83h Set Event Wait Interval, Continued

### Subfunction: AL = 00h Set interval

This subfunction starts the wait requested the calling routine if no wait has already been started. If a wait has already been started, control is returned to the caller with CF set to one.

| Input:  |                | <ul> <li>= 83h</li> <li>= 00h</li> <li>= Microseconds until posting (high byte)</li> <li>= Microseconds until posting (low byte)</li> <li>= Pointer to byte in caller's memory that will have bit 7 set when the interval expires</li> </ul> |
|---------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH<br>AL<br>CF | <ul> <li>= 83h</li> <li>= A value written to CMOS register B, if successful</li> <li>= 00h Function busy</li> <li>= 0 No error</li> <li>= 1 Error, function busy</li> </ul>                                                                  |

# Subfunction: AL = 01h Cancel set interval

This function cancels the interval in progress.

| Input:  | AH | = | 83h        |
|---------|----|---|------------|
|         | AL | = | 01h        |
| Output: | AX | = | 8300h      |
|         | CF | = | 0 No error |
|         |    | = | 1 Error    |

# Function: AH = 84h Joystick Support

#### Description

This function controls a joystick connected to the game control adapter. It has two subfunctions: read current joystick switch settings and read resistive inputs.

| Input:  | AH | = | 84h                                         |
|---------|----|---|---------------------------------------------|
|         | DX | = | 00h Read current switch setting subfunction |
|         |    | = | 01h Read resistive inputs subfunction       |
| Output: | CF |   | 0 No error<br>1 Error                       |

#### **Error conditions**

CF is set to one if the value in DX is not 00h or 01h.

#### Subfunction: DX = 00h Read current switch settings

This subfunction returns the switch settings read from the joystick in bits 4 through 7 of AL. The switch settings are at port 0201h. Bits 3-0 of AL are set to zero.

| Input:  | AH | = | 84h                                                                            |
|---------|----|---|--------------------------------------------------------------------------------|
|         | DX | = | 00h                                                                            |
| Output: |    |   | DH on entry to this function<br>Switch settings in bits $7-4$ , Bits $3-0 = 0$ |

# Function: AH = 84h Joystick Support, Continued

#### Subfunction: DX = 01h Read resistive inputs

This subfunction retrieves the relative position of the X and Y coordinates of the two possible joysticks. Control is returned to the caller and CF is set to zero.

| Input:  | AH    | =   | 84h                                                    |
|---------|-------|-----|--------------------------------------------------------|
|         | DX    | =   | 01h                                                    |
| Output: | AX    | =   | Joystick A X-coordinate value                          |
|         | BX    | =   | Joystick A Y-coordinate value                          |
|         | СН    | =   | Joystick B X-coordinate value                          |
|         | DX    | =   | Joystick B Y-coordinate value                          |
|         |       |     | K Ohm joystick connected, potentiometer values will be |
| ar      | round | 0-4 | 416 (0000–01A0h).                                      |

# Function: AH = 85h System Request Key

#### Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. The function is called by the BIOS keyboard driver when the SysReq key is pressed.

Input: AH = 85h AL = 00h Key make = 01h Key break Output: AX = 0085h

#### Description

INT 15h provides two wait functions: Function 83h, Set Event Wait Interval, and Function 86h, Wait. Function 86h does not return control to the caller until a specified interval is completed. Function 83h returns control to the caller.

| Input:  | AH | = | 86h                                                    |
|---------|----|---|--------------------------------------------------------|
|         | СХ | = | High byte of wait interval (in microseconds)           |
|         | DX | = | Low byte of wait interval (in microseconds)            |
| Output: | AH | = | 86h                                                    |
|         | AL | = | Mask written to interrupt controller 2 (if successful) |
|         |    | = | Unmodified if function busy                            |
|         | CF | = | 0 No error                                             |
|         |    | = | 1 Function busy                                        |

#### **Error conditions**

If a wait is already in progress, CF is set to one and control is returned to the caller.

| CBIOS Function                                                  | Effects on CBIOS RTC ISR                                                                     |
|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| INT 15h: AH = 83h Event Wait Interval<br>INT 15h: AH = 86h Wait | These functions activate the CBIOS Real<br>Time Clock ISR's Periodic Interrupt<br>component. |
| INT 1Ah: AH = 06h Set User Alarm                                | This function activates the CBIOS real time<br>clock ISR's Alarm Interrupt component.        |

#### Additional information

- The wait's duration is an integral multiple of 976 microseconds.
- Use this function to get programmed, hardware-independent delays of finer granularity than provided with the MS-DOS Get Time function (INT 21h function 2Ch). The latter returns time only in hundredths of a second.

# Function: AH = 87h Move Block

#### Description

This function moves a block of memory for a real mode program to or from extended memory by switching to protected mode. Conventional memory is located at addresses below 640K. Only this area can be accessed by MS-DOS and its application programs. Extended memory is located at addresses above 1 MB, and has to be accessed by an 80286 or 80386 operating in protected mode. The caller must build a Global Descriptor Table with the specified settings as input to this function.

Models 25 and 30: This function is not available on IBM PS/2 Models 25/30 (and compatibles).

#### **Global Descriptor Table**

The caller supplies a pointer in ES:SI to a global descriptor table (GDT) that contains six entries. These entries must be:

- Dummy (must be zero).
- Global descriptor table (must be zero): points to the data segment where the GDT is located; can be modified by the CBIOS.
- Source address (initialized by caller): points to the source block that is to be moved.
- Destination address (initialized by caller): points to the address where the block is to be moved.
- BIOS code segment (must be zero): the CBIOS uses this entry to create a protected mode code segment.
- Caller stack segment (must be zero): the CBIOS creates a protected mode stack segment here.

| Location | initial Value (hex)   | Size    | Description            |
|----------|-----------------------|---------|------------------------|
| 00h      | 0000000h              | 4 Words | Dummy entry            |
| 08h      | 0000000h              | 4 Words | Location of GDT        |
| 10h      | User-supplied address | 4 Words | Address of source GDT  |
| 18h      | User-supplied address | 4 Words | Source address         |
| 20h      | 0000000h              | 4 Words | Destination address    |
| 28h      | 0000000h              | 4 Words | Caller's stack segment |

#### Function processing

ES:SI points to a global descriptor table (GDT) that the caller builds before calling this function. The descriptors in this table perform a block move in protected mode. The data access right byte should be set to 93h in order to permit access to the data. The 24-bit address must be set to the target/source.

The Timer 0 latch is not cleared by this function. Bits 0–3 of CMOS location 34h are cleared upon completion of this function.

Interrupts are disabled while the block move is performed. For this reason, using this function may interfere with software such as communications programs and network drivers that depend on prompt servicing of hardware interrupts.

#### Processor-specific information

On 80386-based systems, 32-bit moves are performed. The CBIOS uses I/O port 0092h to reset the processor on 80286-based systems.

#### Input/Output

| Input:  | AH<br>CX<br>ES:SI |                                                                                                                                                                                                                                        |
|---------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | AH<br>CF<br>ZF    | <ul> <li>= 00h Successful move</li> <li>= 01h RAM Parity error occurred</li> <li>= 02h Other exception interrupt error</li> <li>= 0 No error</li> <li>= 1 Error</li> <li>= 0 Unsuccessful move</li> <li>= 1 Successful move</li> </ul> |

#### **Error conditions**

If an exception interrupt occurs during the block move, AH is set to 02h. CF is set to one, ZF is set to zero, and control is returned to the caller.

If a parity error occurs, AH is set to 01h, CF is set to one, ZF is set to zero, and control is returned to the caller.

# Function: AH = 88h Read Extended Memory Size

#### Description

The Read Extended Memory Size function reads the size of the extended memory stored in CMOS locations 35h and 36h (beginning at address (100000h) and stores the combined contents as a word in the AX register.

Models 25 and 30: This function is not available on IBM PS/2 Models 25 and 30 (and compatibles).

Input: AH = 88h

**Output:** AX = Number of contiguous 1K blocks of extended memory starting at address 1024K (10000h)

#### Additional information

- The system may not be able to use the extended memory unless the system board is fully populated.
- Extended memory is located at addresses above 1 MB, and has to be accessed by an 80286 or 80386 operating in protected mode. As MS-DOS is a real mode operating system, extended memory cannot be used for executing its programs. Extended memory can, however, be used to store volatile data.

#### Description

The Switch Processor to Protected Mode function sets the processor into protected mode and passes control to the code segment pointed to in the GDT (global descriptor table).

| Models 25 and 30: | This function is not available on IBM PS/2 Models 25 and |
|-------------------|----------------------------------------------------------|
|                   | 30 (and compatibles).                                    |

| Input:  | AH    | = 89h                                                                                                |
|---------|-------|------------------------------------------------------------------------------------------------------|
|         | BH    | <ul> <li>Offset within IDT that defines where first 8 hardware<br/>interrupts are based</li> </ul>   |
|         | BL    | <ul> <li>Offset within IDT that defines where second 8 hardware<br/>interrupts are based</li> </ul>  |
|         | ES:SI | = Pointer to GDT built by user                                                                       |
| Output: | AH    | <ul> <li>= 00h successful (CF = 0). Returns in protected mode</li> <li>= FFh Unsuccessful</li> </ul> |
|         | CF    | = 0 No error<br>= 1 Error                                                                            |

#### **Global Descriptor Table requirements**

The GDT as described below defines the memory management environment that will be in effect upon return to the caller.

The entry requirements are:

- ES:SI points to a global descriptor table, which must be built before calling this function.
- The GDT entries are used by this function to initialize the interrupt descriptor table (IDT) register, the GDT register, and the stack segment (SS) selector. The data segment (DS) selector and the extra segment (ES) selector are initialized by the caller.
- BH must contain an index into the IDT (interrupt descriptor table) to point to where the first eight hardware interrupts begin.
- BL must contain an index into the IDT to point to where the second eight hardware interrupts begin.

# Function: AH = 89h Switch Processor to Protected Mode, Continued

#### **Global Descriptor Table format**

The following table describes the information contained in the global descriptor table:

| Offset<br>from<br>ES:SI                                                 | Table<br>Entry # | Size    | Description                                              |
|-------------------------------------------------------------------------|------------------|---------|----------------------------------------------------------|
| 0                                                                       | 00h              | 4 Words | Dummy. Must be initialized to 0                          |
| 1                                                                       | 08h              | 4 Words | Points to this GDT                                       |
| 2                                                                       | 10h              | 4 Words | Points to caller-defined Interrupt Descriptor Table      |
| 3                                                                       | 18h              | 4 Words | Points to caller's data segment                          |
| 4                                                                       | 20h              | 4 Words | Points to caller's extra segment                         |
| 5                                                                       | 28h              | 4 Words | Points to caller's stack segment                         |
| 6                                                                       | 30h              | 4 Words | Points to code segment to which the function will return |
| 7                                                                       | 38h              | 4 Words | Used during this function to map BIOS code segment       |
| Note: The user-supplied GDT starting address must be in register ES:SI. |                  |         |                                                          |

#### **GDT Processing**

All of the descriptors are initialized by the caller except the BIOS code segment descriptor. The access rights byte is set to 09Bh, the address to E0000h, and the data segment limit to FFFFh. The DS, ES, and SS selectors are loaded with 0081h, 0020h, and 0028h, respectively.

CBIOS interrupt vectors are not written to operate in protected mode. For this reason a program that enters protected mode must construct its own IDT which does not overlap the CBIOS real mode table, and which handles all I/O interrupts while the program is in protected mode.

#### **Error conditions**

If not successful, the Carry Flag is set and AH is set to FFh.

#### Reference

For information about the descriptor definition, see function AH = 87h earlier in this chapter.

# Function: AH = 90h Device Busy

#### Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. This would allow other tasks to be dispatched while I/O is in progress.

| Input:  | AH    | = 90h                                               |
|---------|-------|-----------------------------------------------------|
|         | AL    | = Type code (hex), where:                           |
|         |       | = 00h Disk time-out                                 |
|         |       | = 01h Diskette time-out                             |
|         |       | = 02h Keyboard                                      |
|         |       | = 03h Pointing device time-out                      |
|         |       | = 21h Waiting for keyboard input                    |
|         |       | = 80h Network.                                      |
|         |       | = FCh Fixed disk reset time-out                     |
|         |       | = FDh Diskette drive motor start                    |
|         |       | = FEh Printer time-out                              |
|         | ES:B> | K = Points to a network control block (if AL = 80h) |
| Output: | CF    | = 0 Wait time not satisfied                         |
| -       |       | = 1 Minimum wait time satisfied                     |

# Function: AH = 91h Interrupt Complete

#### Description

This function is used by multitasking operating systems. A multitasking operating system would point INT 15h to itself, intercept this function, and process the request as necessary. This would allow the operating system to be informed when I/O is done so the requesting task could be reactivated.

| Input:  | AH = 91h                                                |
|---------|---------------------------------------------------------|
|         | AL = Type code, where:                                  |
|         | = 00h Disk time-out                                     |
|         | = 01h Diskette time-out                                 |
|         | = 02h Keyboard                                          |
|         | = 03h Pointing device time-out                          |
|         | = 80h Network                                           |
|         | = FCh Fixed disk reset time-out                         |
|         | = FDh Diskette drive motor start                        |
|         | = FEh Printer time-out                                  |
|         | ES:BX = Points to a network control block (if AL = 80h) |
| Output: | None                                                    |

# Functions: AH = 92h - BFh Reserved

# Description

The Return Configuration Parameters function returns a pointer in ES:BX to the system configuration parameter table, located in ROM at F000:E6F5h, which gives information about the system.

| Input: AH = C0h                               |               |
|-----------------------------------------------|---------------|
| Output: AH = 00h Successful                   |               |
| = 86h System model could not be determ        | ined          |
| CF = 0 No error (AH = 00h)                    |               |
| = 1 System model could not be determine       | əd (AH = 86h) |
| ES:BX = Address of system configuration table |               |

### System configuration table

| Offset | Initial<br>value | Length | Description                                                                                                                                                                                                                                                             |
|--------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h    | 0                | 1 Word | Number of bytes in this table (minimum = 8)                                                                                                                                                                                                                             |
| 02h    | 1                | 1 Byte | Model byte, where:<br>Model 80 = F8h<br>Model 70 = F8h<br>Model 60 = FCh<br>Model 50 = FCh<br>Model 30 = FAh<br>Model 25 = FAh<br>Unknown system board = FFh                                                                                                            |
| 03h    | 1                | 1 Byte | Submodel byte, where:           Model 80         = 00h or 01h           Model 70         = 09h           Model 60         = 05h           Model 50         = 04h           Model 30         = 00h           Model 25         = 01h           Unknown system board = FFh |
| 04h    | 1                | 1 Byte | BIOS revision level (first release = 00b)                                                                                                                                                                                                                               |

| Offset | Initial<br>value | Length | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 05h    | 1                | 1 Byte | Feature information byte, where:<br>Bit 7 = 1 Fixed disk BIOS uses DMA channel 3<br>Bit 6 = 1 Second interrupt chip present<br>Bit 5 = 1 Real time clock present<br>Bit 4 = 1 Keyboard intercept (INT 15h, function<br>AH = 4Fh) called by keyboard interrupt<br>service (INT 09h)<br>Bit 3 = 1 Walt for external event supported<br>Bit 2 = 1 Extended BIOS data area is allocated<br>Bit 1 = 1 Micro Channel supported<br>= 0 PC-type I/O channel implemented<br>Bit 0 = 0 Reserved |
| 06h    | 0                | 1 Byte | Feature information byte 2 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 07h    | 1                | 1 Byte | Feature information byte 3 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 08h    | 1                | 1 Byte | Feature information byte 4 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 09h    | 0                | 1 Byte | Feature information byte 5 (reserved, zeros)                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### System configuration table, cont'd

#### Determining model type: another method

The machine model type on which the BIOS is running can be determined by reading the system board ID from POS Register 0 (I/O Port 0100h) and POS Register 1 (I/O Port 0101h):

- Model 50 = FBFFh
- Model 60 = F7FFh
- Model 80 = FEFFh

#### Description

This function returns the address of the data segment of the extended BIOS data area (EBDA) in ES. The extended BIOS data area address is at 40:0Eh.

The BIOS uses the EBDA for transient data storage. For example, a program passes the address of a pointing device interface subroutine to the BIOS, which stores this address in its extended data area.

The EBDA is allocated by the POST routines, which adjust the amount of free memory to allow for it. Refer to INT 12h to determine the amount of free memory available.

Input: AH = C1h Output: ES = Extended BIOS data area segment address

# Function: AH = C2h Pointing Device Interface

#### Introduction

Function AH = C2h Pointing Device Interface contains a set of subfunctions designed to support pointing devices. Although the pointing device most commonly attached to a system is a mouse, any type of serial input device that is compatible with the Phoenix or IBM PS/2 8042 keyboard controller firmware can be used.

For more information on IBM-compatible 8042 controller firmware, please refer to Appendix B.

#### Purpose of Pointing Device Interface subfunctions

In general, the Pointing Device Interface subfunctions offer mouse driver software (or other pointing device software) a way to initialize, enable, disable, and reset the mouse, as well as control such device parameters as sample rate, resolution, and scaling factor.

#### INT 74h ISR, function C2h, and data transmission

It is important to note that data package transmission from the pointing device to the system is not handled directly by Function C2h. Pointing device data transmission is handled mainly through INT 74h, the Interrupt Service Routine (ISR) associated with pointing devices.

The flow of data from pointing devices to the system is as follows:

- Pointing device transmits data package to 8042 chip.
- 8042 interrupts systems on IRQ 12.
- IRQ 12 is handled by INT 74h ISR.
- INT 74h ISR collects data package, storing the information in the CBIOS Extended Data Area.
- INT 74h pushes pointing device data onto the stack and calls the pointing device's device driver.
- The address of the pointing device's device driver must be stored in the CBIOS Extended Data Area by Function C2h, Subfunction 07h Device Driver Far Call Initialization.

#### Table of subfunctions

There are several Pointing Device Interface subfunctions. The subfunctions are selected through either the AL register alone or through a combination of both the AL and BH registers.

| AL value | BH value | Description                              |
|----------|----------|------------------------------------------|
| 00h      |          | Enable/Disable pointing device           |
| 01h      |          | Reset pointing device                    |
| 02h      |          | Set sample rate                          |
| 03h      |          | Set resolution                           |
| 04h      |          | Read device type                         |
| 05h      |          | Pointing device interface initialization |
| 06h      | 00h      | Return status                            |
| 06h      | 01h      | Set scaling to 1:1                       |
| 06h      | 02h      | Set scaling to 2:1                       |
| 07h      |          | Device driver far call initialization    |

#### Error codes

The error status of each Pointing Device Interface subfunction is returned in the AH register. When an error condition occurs, the Carry Flag is set and control is returned to the caller.

| AH Value | Description           |
|----------|-----------------------|
| 00h      | No error              |
| 01h      | Invalid function call |
| 02h      | Invalid input         |
| 03h      | Interface error       |
| 04h      | Resend                |
| 05h      | No far call installed |

#### Subfunction: AL = 00h Enable/Disable pointing device

This subfunction either enables a pointing device to allow the device to be used, or disables the device so it can no longer be used until re-enabled.

| Input:  | AH | = | C2h                       |
|---------|----|---|---------------------------|
|         | AL | = | 00h                       |
|         | BH | = | 00h Disable               |
|         |    | = | 01h Enable                |
| Output: | AH | = | 00h No error              |
|         |    | = | 01h Invalid function      |
|         |    | = | 03h Interface error       |
|         |    | = | 04h Reset                 |
|         |    | = | 05h No far call installed |
|         | CF | = | 0 No error                |
|         |    | = | 1 Error                   |

#### Subfunction: AL = 01h Reset pointing device

This subfunction resets a pointing device, and stores the device ID in BH and the initial byte transmitted from the pointing device in BL. The Pointing Device Flag (40:28h) is cleared before this function terminates.

If this subfunction completes successfully, the pointing device state will be:

- disabled,
- the sample rate will be 100 reports per second,
- the resolution will be 4 counts per millimeter.
- the scaling will be 1:1, and
- the data package size will be the same.

| Input:  | AH | = | C2h                           |
|---------|----|---|-------------------------------|
|         | AL | = | 01h                           |
| Output: | AH | = | 00h No error                  |
|         |    | = | 03h Interface error           |
|         |    | = | 04h Resend                    |
|         | BH | = | 00h Device ID                 |
|         | BL | = | First byte of device response |
|         | CF | = | 0 No error                    |
|         |    | = | 1 Error                       |
|         |    |   |                               |

#### Subfunction: AL = 02h Set sample rate

This subfunction establishes a sample rate for the auxiliary device. If the sample rate is out of range, an invalid input condition (AH = 02h) is set and the subfunction is terminated. The rate sent to the device is derived from the value in BH, as defined in the following table:

| BH Input Value | Reports per Second Sent to Auxiliary Device |
|----------------|---------------------------------------------|
| 00h            | 0Ah = 10 reports/second                     |
| 01h            | 14h = 20 reports/second                     |
| 02h            | 28h = 40 reports/second                     |
| 03h            | 3Ch = 60 reports/second                     |
| 04h            | 50h = 80 reports/second                     |
| 05h            | 64h = 100 reports/second                    |
| 06h            | C8h = 200 reports/second                    |

#### Input/Output

| Input:  | <br>= | C2h<br>02h<br>Sample rate value (00h to 06h)                                                    |
|---------|-------|-------------------------------------------------------------------------------------------------|
| Output: |       | 00h No error<br>02h Invalid input<br>03h Interface error<br>04h Resend<br>0 No error<br>1 Error |

# Function: AH = C2h Pointing Device Interface, Continued

#### Subfunction: AL = 03h Set resolution

This subfunction sets the resolution of the auxiliary device. If the resolution is out of range, this subfunction terminates and sets an invalid input indicator.

| Input:  | AH<br>AL<br>BH | = | 03h                       |
|---------|----------------|---|---------------------------|
|         |                |   | 03h = 8 counts/millimeter |
| Output: | AH<br>CF       |   |                           |

# Subfunction: AL = 04h Read device type

This subfunction reads a byte from the auxiliary device and stores it in BH. If the first byte from the auxiliary device is not an Acknowledge, the device is re-enabled and a Resend condition is set.

| Input:  | AH | = | C2h                 |
|---------|----|---|---------------------|
|         | AL | = | 04h                 |
| Output: | AH | = | 00h No error        |
|         |    | = | 03h Interface error |
|         |    | = | 04h Resend          |
|         | BH | = | 00h Device ID       |
|         | CF | = | 0 No error          |
|         |    | Ξ | 1 Error             |

#### Subfunction: AL = 05h Pointing device interface initialization

This subfunction initializes the auxiliary device. If the data package size is out of range, this subfunction stops and sets CF on and AH to 02h.

The auxiliary device reset is attempted three times. If all attempts fail, the data package size bits are reset, AH is set to 03h, and CF is set.

If this subfunction completes normally, the pointing device state is:

- disabled,
- the sample rate will be 100 reports/second,
- the resolution will be 4 counts/millimeter, and
- the scaling will be 1:1.

| Input:  | AH | = | C2h                                   |
|---------|----|---|---------------------------------------|
|         | AL | = | 05h                                   |
|         | BH | = | Data package size (01h-08h, in bytes) |
| Output: | AH | = | 00h No error                          |
|         |    | = | 02h Invalid input                     |
|         |    | = | 03h interface error                   |
|         |    | = | 04h Resend                            |
|         | CF | = | 0 No error                            |
|         |    | = | 1 Error                               |

#### Subfunction: AL = 06h Extended commands

This subfunction jumps to a subfunction based on the value in BH. If BH is out of range, this subfunction terminates and sets an invalid subfunction indicator.

| Input:  | AH         | =      | C2h                               |
|---------|------------|--------|-----------------------------------|
|         | AL         | =      | 06h                               |
|         | BH         | =      | 00h Return status                 |
|         |            | =      | 01h Set scaling factor to $1 = 1$ |
|         |            | =      | 02h Set scaling factor to 2 = 1   |
| Output  | <b>۸</b> Ц |        | OOb No. arrest                    |
| Output. | АП         | =      | 00h No error                      |
| output. | АП         |        | 01h Invalid subfunction           |
| output. |            | =      |                                   |
| output. |            | =<br>= | 01h Invalid subfunction           |

#### Subfunction: AL = 06h BH = 00h Return status

This subfunction reads and returns the status of the auxiliary device. The device sends three status bytes that are stored in registers BL, CL, and DL.

| Input:   | АН | = | C2h                                         |
|----------|----|---|---------------------------------------------|
| •        | AL | = | 06h                                         |
|          | BH | = | 00h                                         |
| <b>O</b> | AH | _ | 00h No error                                |
| Output:  | АП | = |                                             |
|          |    | = | 04h Resend                                  |
|          | BL |   |                                             |
|          | DL | = | Status byte 1, where:<br>Bit 7 = 0 Reserved |
|          |    |   |                                             |
|          |    |   | Bit 6 = 0 Stream mode                       |
|          |    |   | = 1 Remote mode<br>Bit 5 = 0 Disable        |
|          |    |   | = 1 Enable                                  |
|          |    |   |                                             |
|          |    |   | Bit $4 = 0$ 1:1 scaling                     |
|          |    |   | = 1 2:1 scaling<br>Bit 3 = 0 Reserved       |
|          |    |   | Bit $2 = 1$ Left button pressed             |
|          |    |   | Bit 1 = 0 Reserved                          |
|          |    |   | Bit $0 = 1$ Right button pressed            |
|          | CF | _ | 0 No error                                  |
|          | 0  | = | · · ·                                       |
|          | CL | - |                                             |
|          |    |   | 00h = 1 count per millimeter                |
|          |    |   | 01h = 2 counts per millimeter               |
|          |    |   | 02h = 4 counts per millimeter               |
|          |    |   | 03h = 8 counts per millimeter               |
|          | DL | = |                                             |
|          |    |   | 0Ah = 10 reports per second                 |
|          |    |   | 14h = 20 reports per second                 |
|          |    |   | 28h = 40 reports per second                 |
|          |    |   | 3Ch = 60 reports per second                 |
|          |    |   | 50h = 80 reports per second                 |
|          |    |   | 64h = 100 reports per second                |
|          |    |   | C8h = 200 reports per second                |
|          |    |   |                                             |

Subfunction: AL = 06h BH = 01h Set scaling factor to 1:1

Input: AH = C2h AL = 06h BH = 01hOutput: AH = 00h No error = 03h Interface error = 04h Resend CF = 0 No error = 1 Error

Subfunction: AL = 06h BH = 02h Set scaling factor to 2:1

Input: AH = C2h AL = 06h BH = 02h Output: AH = 00h No error = 03h Interface error = 04h Resend CF = 0 No error = 1 Error

#### Subfunction: AL = 07h Device driver far call initialization

This subfunction stores the device driver segment address in the CBIOS data area at 22h and the device driver offset address at 24h so that the device may be accessed.

There must be a routine that receives control when the pointing device data is available. The device driver far call initialization gives the address of this routine to the CBIOS. Whenever pointing device data is available, the pointing device interrupt handler calls the routine, with the following arguments on the stack:

- Status First word on the stack
- X data Second word
- Y data Third word
- Z data Fourth word on the stack

# Function: AH = C2h Pointing Device Interface, Continued

# Subfunction: AL = 07h Device driver far call initialization, cont'd

These words will be in the following format:

| Word | Byte | Bit<br>number | Description                      |
|------|------|---------------|----------------------------------|
| 1    | Low  | 7             | = 1 Y data overflow              |
|      |      | 6             | = 1 X data overflow              |
|      |      | 5             | = 1 Negative Y data sign         |
|      |      | 4             | = 1 Negative X data sign         |
|      |      | 3             | = 1 Reserved (must be 1)         |
|      |      | 2             | = 0 Reserved (must be 0)         |
|      |      | 1             | = 1 Right button pressed         |
|      |      | 0             | = 1 Left button pressed          |
| 1    | High | 7-0           | = 0 Reserved                     |
| 2    | Low  | 7             | = X data — most significant bit  |
|      |      | 0             | = X data — least significant bit |
| 2    | High | 7–0           | = 0 Reserved                     |
| 3    | Low  | 7             | = Y data — most significant bit  |
|      |      | 0             | = Y data — least significant bit |
| 3    | High | 7-0           | = 0 Reserved                     |
| 4    | Low  | 7-0           | = 0 Reserved                     |
| 4    | High | 7-0           | = 0 Reserved                     |

When transferring control to the user routine, the pointing device interrupt handler uses a far call. The user routine should be coded as a far procedure and should not move the parameters off the stack before returning.

| Input:  | AH    | = | C2h                                      |
|---------|-------|---|------------------------------------------|
|         | AL    | = | 07h                                      |
|         | ES:BX | = | Device drive segment and offset address. |
| Output: | AH    | = | 00h No error                             |
|         |       | = | Error status (40:41h)                    |

#### Description

The watchdog time-out function has two subfunctions: enable and disable. The watchdog timer ensures that a program does not turn interrupts off for too long a period. If interrupts are turned off for too long, the timer interrupt may not be serviced.

The watchdog time-out decrements each timer tick that the timer interrupt is not serviced. At the end of the watchdog period, an NMI is generated. POST disables the watchdog timer. The user must enable it.

Models 25 and 30: This function is not available on IBM PS/2 Models 25 and 30 (and compatibles).

#### **Error conditions**

If the subfunction code is not valid, one is subtracted from AL, CF is set to one, and control is returned to the caller.

#### Subfunction: AL = 00h Disable watchdog time-out

This subfunction disables the watchdog timer.

| Input:  | AH | = | C3h        |
|---------|----|---|------------|
|         | AL | = | 00h        |
| Output: | CF | = | 0 No error |
|         |    | = | 1 Error    |

#### Subfunction: AL = 01h Enable watchdog time-out

This subfunction enables the watchdog time-out with the time-out timer tick count (from 1-255) in BX.

| Input:  | AH | = | C3h                           |
|---------|----|---|-------------------------------|
|         | AL | = | 01h                           |
|         | BX | = | Watchdog timer count (1-255)  |
| Output: | CF | = | 0 No error                    |
|         |    | = | 1 Timer count is out of range |

# Function: AH = C4h Programmable Option Select

#### Description

This function allows the caller to access the Programmable Option Select (POS) features of the system's adapter cards. Three subfunctions are provided and are selected through the AL register: return base address, enable channel for setup, and enable adapter.

Models 25 and 30: This function is not available on IBM PS/2 Models 25 and 30 (and compatibles).

Subfunction: AL = 00h Return base POS adapter register address

| Input:  | AH | = | C4h                               |
|---------|----|---|-----------------------------------|
|         | AL | = | 00h                               |
| Output: | CF | = | 0 No Error                        |
|         |    | = | 1 Error                           |
|         | DX | = | Base POS adapter register address |

#### Subfunction: AL = 01h Enable channel for setup

This subfunction enables the channel specified in BL. Channel numbers must be between 1 and 8, if not, CF is set and control is returned to the caller. Channel numbers for specific models are not checked. This subfunction does not modify any registers.

| Input:  | AH | = | C4h                      |
|---------|----|---|--------------------------|
|         | AL | = | 01h                      |
|         | BL | = | Channel number (1-8)     |
| Output: | CF | = | 0 No error               |
|         |    | = | 1 Invalid channel number |

# Subfunction: AL = 02h Adapter enable

This subfunction disables the setup for all channels, thus enabling the adapters on those channels.

Input: AH = C4h AL = 02hOutput: CF = 0 No Error = 1 Error

Functions: AH = C5h – FFh Reserved

# 14

# Chapter 14 INT 17h Parallel Printer Service

# **Overview**

#### Description

The CBIOS Parallel Printer Service provides BIOS-level support for up to three parallel printer ports.

#### How the Parallel Printer Service is invoked

Software INT 17h invokes the CBIOS Parallel Printer Service.

The INT 14h vector resides at address 005Ch in the Interrupt Vector Table. The CBIOS initializes the INT 17h vector to F000:EFD2h, the IBM-compatible entry point.

# Summary of Parallel Printer Service functions

The CBIOS Parallel Printer Service contains three functions. Individual functions are selected via the AH register.

| Function | Description         |
|----------|---------------------|
| 00h      | Print Character     |
| 01h      | Initialize Printer  |
| 02h      | Read Printer Status |
| 03h-FFh  | Reserved            |

#### In this chapter

This chapter focuses on the INT 17h Parallel Printer Service. The following topics are discussed:

- Hardware Environment
- Parallel Port I/O Addresses
- System RAM Data
- Error Handling
- Parallel Printer Service Functions

#### Parallel printer ports assumed

The CBIOS Parallel Printer Service assumes three parallel printer ports.

# Parallel Port I/O Addresses

The characteristics of each printer port are defined in the following table.

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                 |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0278h       | R/W                  | Parallel 3 data port                                                                                                                                                                                                                                                        |
| 0279h       | R/W                  | Parallel 3, status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1-0 = Reserved                                                               |
| 027Ah       | R/W                  | Parallel 3, control port, where:<br>Bits 7-6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe |
| 0378h       | R/W                  | Parallel 2 data port                                                                                                                                                                                                                                                        |
| 0379h       | R/W                  | Parallel 2, status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1-0 = Reserved                                                               |

# Parallel Port I/O Addresses, Continued

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                 |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 037Ah       | R/W                  | Parallel 2, control port, where:<br>Bits 7-6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe |
| 03BCh       | R/W                  | Parallel 1, data port                                                                                                                                                                                                                                                       |
| 03BDh       | R/W                  | Parallel 1, status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer is selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ has occurred<br>Bits 1-0 = Reserved                                                               |
| 03BEh       | R/W                  | Parallel 1, control port, where:<br>Bits 7-6 = Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read from port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe |

#### Introduction

The CBIOS Parallel Printer Service makes use of information located in the BIOS Data Area of system RAM (address 40:00h through 40:100h). The table below describes the BIOS Data Area definitions referred to by the Printer Device Service.

| Location | Size    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 08h      | 3 words | I/O address of up to 3 printer adapters.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10h      | 1 word  | Number of devices installed, where:         Bits 15-14 = Number of printer adapters         Bits 13-12 = Reserved         Bits 11-9 = Number of asynchronous adapters<br>(RS232)         Bits 8 = Reserved         Bits 7-6 = Number of diskette drives, where:<br>00b = 1 diskette drives         01b = 2 diskette drives         Bits 5-4 = Initial video mode, where:<br>00b = EGA/VGA or PGA<br>01b = 40x25 color<br>10b = 80x25 color<br>11b = 80x25 black and white         Bit 3 = Reserved         Bit 2 = Pointing device         Bit 1 = 1 If math coprocessor         Bit 0 = Diskette available for boot |
| 78h      | 3 bytes | One byte per adapter. Time-out values for printe number 1 through 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Before entering any functions, this service ensures that the DX index is not out of range, that the function number is not out of range, and that the printer is at the specified index. There are only three printer ports.

If any of the above conditions are not met, the service returns to the caller with all registers restored except AH. When DX is out of range or the printer does not exist, AX is not modified. When the function number is out of range, AH is returned, and is decremented by 2.

# Function: AH = 00h Print Character

#### Description

The Print Character function prints the character in the AL register to the printer specified in the DX register. The printer status is returned in the AH register.

#### Input/Output

| Input:  | AL<br>DX |   | Character to print<br>Printer number (0 = LPT1, 1 = LPT2, or 2 = LPT3) used as<br>an index to the printer base port address table at 40:08h. |  |                                                                                                                                                   |  |
|---------|----------|---|----------------------------------------------------------------------------------------------------------------------------------------------|--|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Output: | АН       | = | Bit 7<br>Bit 6<br>Bit 5<br>Bit 4<br>Bit 3<br>Bit 2<br>Bit 1                                                                                  |  | us, where:<br>1 Printer not busy<br>1 Acknowledgment<br>1 Out of paper<br>1 Printer selected<br>1 I/O error<br>Reserved<br>Reserved<br>1 Time-out |  |
|         |          |   |                                                                                                                                              |  |                                                                                                                                                   |  |

#### Description

The Initialize Printer function initializes the printer selected in the DX register. The printer status is returned in register AH.

# Input/Output

| Input:  | DX | = | Printer number (0 = LPT1, 1 = LPT2, or 2 = LPT3) used as an index to the printer base port address table at $40:08h$ . |  |                                                                                                                                                                       |
|---------|----|---|------------------------------------------------------------------------------------------------------------------------|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | АН | = | Bit 7<br>Bit 6                                                                                                         |  | tus, where:<br>1 Printer not busy<br>1 Acknowledgment from printer<br>1 Out of paper<br>1 Printer selected<br>1 I/O error<br>Reserved<br>Reserved<br>1 Time-out error |

# Function: AH = 02h Read Printer Status

# Description

The Read Printer Status function reads and returns the status of the printer selected by the DX register.

# Input/Output

| Input:  | DX | = | Printer number ( $0 = LPT1$ , $1 = LPT2$ , or $2 = LPT3$ ) used as an index to the printer base port address table at 40:08h. |  |                                                                                                                                                                      |  |  |
|---------|----|---|-------------------------------------------------------------------------------------------------------------------------------|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Output: | АН | = | Bit 7<br>Bit 6<br>Bit 5<br>Bit 4<br>Bit 3<br>Bit 2<br>Bit 1                                                                   |  | us, where:<br>1 Printer not busy<br>1 Acknowledgment from printer<br>1 Out of paper<br>1 Printer selected<br>1 I/O error<br>Reserved<br>Reserved<br>1 Time-out error |  |  |
|         |    |   |                                                                                                                               |  |                                                                                                                                                                      |  |  |

Functions: AH = 03h - FFh Reserved

# Chapter 15 INT 1Ah Time-of-Day Service

#### Overview

#### Introduction

The CBIOS provides the following timer-related support:

INT 1Ah Time-of-Day Service Software INT 1Ah invokes the CBIOS Time-of-Day Service. The Time-

of-Day Service provides CBIOS users with 12 system time and date functions.

#### INT 08h System Timer ISR

The Intel 82284 clock generator chip, or its equivalent, "ticks" roughly 18.2 times per second. Each tick generates hardware INT 08h, System Timer Interrupt.

The CBIOS System Timer routine increments the system time count, then invokes software INT 1Ch. CBIOS users may revector INT 1Ch to their own routines. If not revectored, INT 1Ch returns immediately to the caller with all registers preserved.

continued

INT 1Ah Time-of-Day Service

407

# Overview, Continued

### Introduction, cont'd

### INT 70h Real Time Clock ISR

The Motorola MC146818A real time clock chip, or its equivalent, generates a hardware interrupt approximately 1024 times per second.

The CBIOS Services contain three functions that determine how the CBIOS Real Time clock hardware ISR will handle interrupts from the Real Time clock chip.

| CBIOS Function                                                  | Effects on CBIOS RTC ISR                                                                  |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| INT 15h: AH = 83h Event Walt Interval<br>INT 15h: AH = 86h Walt | These functions activate the CBIOS Real Time<br>Clock ISR's Periodic Interrupt component. |
| INT 1Ah: AH = 06h Set User Alarm                                | This function activates the CBIOS real time clock ISR's Alarm Interrupt component.        |

### In this chapter

This chapter discusses each of the CBIOS timer-related services. The following topics are presented:

- INT 1Ah Time-of-Day Service
- INT 08h System Timer ISR
- INT 70h Real Time Clock ISR

### Introduction

The CBIOS Time-of-Day service provides 12 system time-related functions.

### How the CBIOS Time-of-Day service is invoked

The CBIOS Time-of-Day service is invoked via software interrupt INT 1Ah. Individual Time-of-Day functions are selected via the AH register. Subfunctions are selected via the AL register.

The INT 1Ah vector resides at address 00:68h in the Interrupt Vector Table. The CBIOS initializes the INT 1Ah vector to address F000:FE6Eh, the IBM-compatible entry point.

### Summary of Time-of-Day service functions

The following table lists the Time-of-Day functions.

| Functions         | Description                                 |
|-------------------|---------------------------------------------|
| 00h               | Read System Timer Time Counter              |
| 01h               | Set System Timer Time Counter               |
| 02h               | Read Real Time Clock Time                   |
| 03h               | Set Real Time Clock Time                    |
| 04h               | Read Real Time Clock Date                   |
| 05h               | Set Real Time Clock Date                    |
| 06h               | Set Real Time Clock Alarm                   |
| 07h               | Reset Real Time Clock Alarm                 |
| 08h               | Set Real Time Clock Activated Power-On Mode |
| 09h               | Read Real Time Clock Alarm Time and Status* |
| 0Ah               | Read System Timer Day Counter               |
| 0Bh               | Set System Timer Day Counter                |
| 0Ch – FFh         | Reserved                                    |
| * For IBM PS/2 Mo | odels 25 and 30 only                        |

### Hardware Environment

The CBIOS Time-of-Day Service routine assumes the existence of a CMOS real time clock that contains 64 bytes of nonvolatile RAM and is compatible with a Motorola MC146818A chip. Also, the Intel 82284 clock generator chip, or its equivalent, is assumed.

### Time-of-Day Service I/O Ports

INT 1Ah, Time-of-Day Service, references the following I/O ports:

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0070h       | w                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0= 0 CMOS address                                                                                                                                                                                                                   |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                                                                      |
| 00A1h       | R/W                  | Programmable Interrupt Controller 2 mask, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Enable fixed disk interrupt<br>Bit 5 = 0 Enable 80387 exception interrupt<br>Bit 4 = 0 Enable mouse interrupt<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Reserved<br>Bit 1 = 0 Enable redirect cascade<br>Bit 0 = 0 Enable real time clock interrupt |

### System RAM data

The following table lists all system RAM data areas, beginning at segment 40h, used by the Time-of-Day service.

| Location | Size   | Description                          |  |
|----------|--------|--------------------------------------|--|
| 40:6Ch   | 1 Word | Least significant timer 'tick' count |  |
| 40:6Eh   | 1 Word | Most significant timer 'tick' count  |  |
| 40:70h   | 1 Byte | 24 hour rollover flag                |  |
| 40:CEh   | 1 Word | Count of days since 1/1/80           |  |

# INT 1Ah Time-of-Day Service, Continued

### **CMOS RAM Data**

The following table presents the CMOS RAM data areas used by the Time-of-Day service routine.

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h      | 1 Byte | Current second in binary coded decimal (BCD)                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 01h      | 1 Byte | Second alarm in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 02h      | 1 Byte | Current minute in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 03h      | 1 Byte | Minute alarm in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 04h      | 1 Byte | Current hour in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 05h      | 1 Byte | Hour alarm in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 06h      | 1 Byte | Current day of week in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 07h      | 1 Byte | Current Date in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 08h      | 1 Byte | Current month in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 09h      | 1 Byte | Current year in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0Ah      | 1 Byte | Status Register A, where:<br>Bit 7 = 1 Update in progress<br>Bits 6-4 = Divider that identifies the time-based<br>frequency<br>Bits 3-0 = Rate-selection bits that define output<br>frequency and periodic interrupt rate                                                                                                                                                                                                                                               |
| 0Bh      | 1 Byte | Status Register B, where:         Bit 7       = 0 Run         = 1 Halt         Bit 6       = 1 Enable periodic interrupt         Bit 5       = 1 Enable alarm interrupt         Bit 4       = 1 Enable update-ended interrupt         Bit 3       = 1 Enable square wave Interrupt         Bit 2       = 1 Calendar is in binary format         = 0 Calendar is in BCD format         Bit 1       = 1 24-hour mode         Bit 0       = 1 Enable Daylight Savings Time |
| 0Ch      | 1 Byte | Status register C, where:<br>Bits 7-4 = IRQF, PF, AF, and UF flags,<br>respectively<br>Bits 3-0 = Reserved                                                                                                                                                                                                                                                                                                                                                              |
| 0Dh      | 1 Byte | Status register D, where:<br>Bit 7 = 1 Real time clock has power<br>Bits 6-0 = Reserved                                                                                                                                                                                                                                                                                                                                                                                 |
| 37h      | 1 Byte | Century in BCD                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### Time-of-Day Error Handling

The CBIOS Time-of-Day service generates one error that is applicable to all functions of this service. The Carry Flag is set if an invalid function is requested. The function number is stored in AH if there is an invalid function request.

Otherwise, each function handles all other errors uniquely. Refer to the description for each function for specific information about error codes.

### Function: AH = 00h Read System Timer Time Counter

The Read System Timer Time Counter function reads and returns the system tick count from the system RAM location 40:6Eh (high word) and 40:6Ch (low word).

The values stored in these locations are defined by the frequency of the timer interrupt, which is approximately 18.2 ticks per second. The AL register will be 0 if the timer has not exceeded 24 hours. Otherwise, RAM data area location 40:70h has the same value that the AL register has.

Interrupts are disabled while reading RAM data memory locations because a timer tick update may occur.

Execution of this function causes the Timer Overflow Flag at 40:70h to be reset to 0.

| Input:  | AH | = | 00h                                                      |
|---------|----|---|----------------------------------------------------------|
| Output: | AH | = | 00h                                                      |
|         | AL | = | Timer overflow value, where:                             |
|         |    | = | 0 Timer count is less than 24 hours since the last       |
|         |    |   | power-on or system reset. Any value greater than 0 Timer |
|         |    |   | count is more than 24 hours since last power-on, system  |
|         |    |   | reset, last system-timer time counter read, or last      |
|         |    |   | system-timer time counter set.                           |
|         | CF | = | 0 No error                                               |
|         |    | = | 1 Error                                                  |
|         | СХ | = | High word of tick count                                  |

DX = Low word of tick count

### Function: AH = 01h Set System Timer Time Counter

The Set system timer time counter function stores values from CX and DX to RAM data areas 40:6Eh (high word) and 40:6Ch (low word).

Execution of this function causes the Timer Overflow Flag at 40:70h to be reset to 0.

| Input:  | AH | = | 01h                     |
|---------|----|---|-------------------------|
|         | СХ | = | High word of tick count |
|         | DX | = | Low word of tick count  |
| Output: |    | _ | 00b                     |
| Output. | АП | - | 0011                    |
| Calpul. |    |   | 0 No error              |

### Function: AH = 02h Read Real Time Clock Time

This function first finds out if the CMOS RAM is currently updating its clock value.

If an update is not in progress, the appropriate values are taken from CMOS RAM and returned to the caller, with the Carry Flag cleared and AH = 00h.

### Input/Output

| Input:  | AH | = | 02h                                   |
|---------|----|---|---------------------------------------|
| Output: | AH | = | 00h                                   |
|         | AL | = | Same as CH                            |
|         | CF | = | 0 Clock operating                     |
|         |    | = | 1 Clock not operating                 |
|         | CH | = | Hours in BCD                          |
|         | CL | = | Minutes in BCD                        |
|         | DH | = | Seconds in BCD                        |
|         | DL | = | 00h - No Daylight Savings Time option |
|         |    |   | 01h — Daylight Savings Time option    |

### **Error conditions**

If a time-out occurs, which indicates an update is in progress, CF is set to one, AH is cleared, and control is returned to the caller.

### Function: AH = 03h Set Real Time Clock Time

This function first finds out if the CMOS RAM is currently updating its clock value. If an update is in progress, the real time clock is initialized.

The values defined in the input section are stored in their respective CMOS RAM storage locations. Hours are stored in CMOS RAM location 04h, minutes in location 02h, and seconds in location 00h.

### Input/Output

| Input:  | AH | = | 03h                                |
|---------|----|---|------------------------------------|
|         | СН | = | Hours in BCD                       |
|         | CL | = | Minutes in BCD                     |
|         | DH | = | Seconds in BCD                     |
|         | DL | = | 00h No DST option                  |
|         |    |   | 01h DST option                     |
| Output: | AH | = | 00h                                |
|         | AL | = | Value written to CMOS 0Bh register |
|         | CF | = | 0 No error                         |
|         |    | = | 1 Error                            |
|         |    |   |                                    |

### **Error conditions**

If a time-out occurs, which indicates that an update is in progress, the clock is initialized and the routine continues as if an update were not in progress.

### Function: AH = 04h Read Real Time Clock Date

This function first finds out if the CMOS RAM is currently updating its clock value.

If no time-out occurs, the century, year, month, and day are extracted from CMOS RAM and are returned to the caller as described in the output section. Upon return, the Carry Flag is cleared and AH = 00h.

### Input/Output

Input: AH = 04h Output: AH = 00h CF = 0 No error = 1 Clock update in progress CH = Century in BCD (either 19 or 20) CL = Year in BCD DH = Month in BCD DL = Day in BCD

### **Error conditions**

If a time-out occurs, which indicates that an update is in progress, the Carry Flag is set, AH is cleared, and control is returned to the caller.

### Function: AH = 05h Set Real Time Clock Date

This function first finds out if the CMOS RAM is currently updating its clock value.

The values defined in the input section are stored in their respective CMOS RAM storage locations. Century is stored in location 37h, year in 09h, month in location 08h, and day in location 06h. This function then returns to the caller with the Carry Flag cleared and AH = 00h.

### Input/Output

| Input:  | AH | = | 05h                                |
|---------|----|---|------------------------------------|
|         | СН | = | Century in BCD (either 19 or 20)   |
|         | CL | = | Year in BCD                        |
|         | DH | = | Month in BCD                       |
|         | DL | = | Day in BCD                         |
| Output: | AH | = | 00h                                |
|         | AL |   | Value written to CMOS 0Bh register |
|         | CF | = | 0 No error                         |
|         |    |   |                                    |
|         |    | = | 1 Error                            |

### **Error conditions**

If a time-out occurs, which indicates that an update is in progress, the clock is initialized.

### Function: AH = 06h Set Real Time Clock Alarm

This function first tests if an alarm is in progress. If an alarm is in progress, control is returned to the caller with the Carry Flag set and AH cleared.

If an alarm is currently not enabled, this test finds out if the CMOS RAM is updating its clock value. If a time-out occurs, which indicates that an update is in progress, the clock is initialized. This function then sets the alarm with the values from registers CH, CL and DH.

The alarm interrupt will take place at the hour, minute, and second specified in registers CH, CL, and DH, respectively. You can only have one alarm function in an active state at any one time. The alarm interrupt, once set, will be activated every 24 hours until reset.

The values defined in the input section are stored in their respective CMOS RAM storage locations.

Note: This function clears AX, not just AH.

### Input/Output

| Input:  | AH | = | 06h                 |
|---------|----|---|---------------------|
|         | CH | = | Hours in BCD        |
|         | CL | = | Minutes in BCD      |
|         | DH | = | Seconds in BCD      |
| Output: | AH | = | 00h                 |
|         | AL | = | 00h                 |
|         | CF | = | 0 No error          |
|         |    | = | 1 Alarm already set |

### **Error conditions**

CF is set to one if an alarm has already been set.

### Function: AH = 07h Reset Real Time Clock Alarm

This function stops the real time clock alarm interrupt.

Input: AH = 07h Output: AH = 00h CF = 0 No error = 1 Error

### Function: AH = 09h Read Real Time Clock Alarm and Status

This function reads the real time clock alarm's time and status.

Models 25 and 30: This function applies only to PS/2 Models 25 and 30. Other PS/2 models will return CF = 1, invalid function request.

| input:  | AH | = | 09h                          |
|---------|----|---|------------------------------|
| Output: | СН | = | Hours in BCD                 |
|         | CL | = | Minutes in BCD               |
|         | DH | = | Seconds in BCD               |
|         | DL | = | Alarm status                 |
|         |    |   | 00h = Alarm is not installed |

### Function: AH = 0Ah Read System Timer Day Counter

The Read System Timer Day Counter function reads the count of days since 1/1/80 from the System RAM data area 40:CEh, and returns it to the caller in the CX register.

Models 25 and 30: On the IBM PS/2 Models 25 and 30, POST initializes the count of days since 1/1/80 to zero.

| Input:  | AH | = | 0Ah                        |
|---------|----|---|----------------------------|
| Output: | AH | = | 00h                        |
|         | CF | = | 0 No error                 |
|         |    | = | 1 Error                    |
|         | СХ | = | Count of days since 1/1/80 |

### Function: AH = 0Bh Set System Timer Day Counter

The Set System Timer Day Counter function sets the count of days since 1/1/80 in the ROM BIOS data field 40:CEh from the parameter passed in the CX register.

Models 25 and 30: On the IBM PS/2 Models 25 and 30 (and compatibles), POST initializes the count of days since 1/1/80 to zero.

Input: AH = 0Bh CX = Count of days since 1/1/80Output: AH = 00h CF = 0 No error= 1 Error

### AH = 0Ch to FFh Reserved

Functions AH = 0Ch to FFh are reserved.

### **INT 08h System Timer ISR**

### Description

The Intel 82284 clock generator chip, or its equivalent, "ticks" roughly 18.2 times per second. Each tick generates hardware INT 08h, System Timer Interrupt.

The CBIOS System Timer routine increments the double word, system time count. The system time count is stored in the CBIOS system RAM data area at locations 40:6Ch (low word) and 40:6Eh (high word).

If the count in these location exceeds 24 hours, then the contents of location 40:70h is set to 1 and the date is incremented. When 40:70h is set, the system time count (40:6Ch and 40:6Eh) is cleared.

### Diskette motor count

The processing of INT 08h includes the decrement of the diskette motor counts at 40:35h. If the count reaches zero, the diskette motors are turned off.

### INT 1Ch

Once it has serviced the clock, INT 08h issues a software INT 1Ch. CBIOS users may revector INT 1Ch to their own routines.

If not revectored, INT 1Ch returns immediately to the caller with all registers preserved.

#### How CBIOS System-Timer ISR is invoked

The CBIOS System-Timer hardware interrupt service routine is invoked via hardware INT 08h.

The INT 08h vector resides at address 00:20h in the Interrupt Vector Table. The CBIOS initializes the INT 08h vector to F000:FEA5h, the IBM-compatible entry point.

### System RAM data

The CBIOS system timer ISR references the following system RAM data:

| Location | Size   | Description                   |
|----------|--------|-------------------------------|
| 40:0Eh   | 1 Byte | Extended BIOS data area       |
| 40:3Fh   | 1 Byte | Diskette drive motor status   |
| 40:40h   | 1 Byte | Diskette motor time-out count |
| 40:6Ch   | 1 Word | Least significant timer count |
| 40:6Eh   | 1 Word | Most significant timer count  |
| 40:70h   | 1 Byte | 24 hour rollover flag         |
| 40:CEh   | 1 Byte | Count of days since 1/1/80    |

### Extended BIOS data area

The CBIOS system timer ISR references the following item in the CBIOS extended data area:

| Location                               | Size   | Description                  |  |  |
|----------------------------------------|--------|------------------------------|--|--|
| EDA:35h                                | 1 Byte | Watchdog timer initial count |  |  |
| Note: EDA = Extended Data Area segment |        |                              |  |  |

### Hardware Environment

The CBIOS System Timer routine assumes the existence of a CMOS real time clock with 64 bytes of nonvolatile RAM, compatible with a Motorola MC146818A chip. Also, the Intel 82284 clock generator chip or its equivalent is assumed.

# System Timer I/O Ports

| INT 08h, | System | Timer | ISR, | references | the | following | I/O ports: |   |
|----------|--------|-------|------|------------|-----|-----------|------------|---|
|          |        |       |      |            |     |           |            | _ |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0020h       | R/W                  | Base port of 8259 Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0040h       | R/W                  | Read/write counter 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0042h       | R/W                  | Read/write counter 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0043h       | W                    | Control word register for counters 0 and 2, where:<br>Bits 7-6 = 00b Select counter 0<br>= 01b Reserved<br>= 10b Select counter 2<br>Bits 5-4 = 00b Counter latch command<br>= 01b Read/write counter bits 0-7 only<br>= 10b Read/write counter bits 8-15 only<br>= 11b Read/write counter bits 0-7 first,<br>then bits 8-15<br>Bits 3-0 = 000b Mode 0 select<br>= 001b Mode 1 select<br>= X10b Mode 2 select<br>= X10b Mode 4 select<br>= 100b Mode 4 select<br>= 101b Mode 5 select<br>Bit 0 = 0 Binary counter 16 bits<br>= 1 Binary coded decimal counter |
| 0044h       | w                    | Read/write counter 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0047h       | W                    | Control word register for counter 3, where:<br>Bits 7-6 = 00b Select counter 3<br>= 01b Reserved<br>= 10b Reserved<br>= 11b Reserved<br>Bits 5-4 = 00b Counter latch command select<br>counter 0<br>= 01b Read/write counter bits 0-7 only<br>= 10b Reserved<br>= 11b Reserved<br>Bits 3-0 = 00b                                                                                                                                                                                                                                                              |
| 0061h       | R                    | System control port B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 03F2h       | w                    | Diskette controller digital output register, where:<br>Bit 7-6 = 0 Reserved<br>Bit 5 = 1 Motor enable 1<br>Bit 4 = 1 Motor enable 0<br>Bit 3 = 0 Allow interrupts<br>Bit 2 = 0 Controller reset<br>Bit 1 = 0 Reserved<br>Bit 0 = 0 Drive select 0<br>= 1 Drive select 1                                                                                                                                                                                                                                                                                       |

### Introduction

The Motorola MC146818A real time clock chip, or its equivalent, generates a hardware interrupt approximately 1024 times per second. The CBIOS real time clock hardware interrupt service routine (ISR) is invoked on each real time clock interrupt.

### How the real time clock ISR is invoked

The CBIOS real time clock ISR is invoked via hardware interrupt INT 70h.

The INT 70h vector resides at address 00:1Ch in the Interrupt Vector Table. The CBIOS initializes the INT 70h vector to address F000:5124h, the IBM-compatible entry point.

### Real Time clock ISR processing

The CBIOS Services contain three functions that determine how the CBIOS Real Time clock hardware ISR will handle interrupts from the Real Time clock chip.

| CBIOS Function                                                                                                                                                    | Effects on Real Time Clock Processing                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT 15h: AH = 83h Event Walt Interval<br>INT 15h: AH = 86h Walt<br>These functions activate the CBIOS<br>Real Time Clock ISR's Periodic Inter-<br>rupt component. | PERIODIC INTERRUPT PROCESSING<br>The CBIOS Real Time clock ISR decre-<br>ments a counter (set to a user-defined<br>period of time) by 1/1024 second for each<br>RTC interrupt.<br>When the count is less than or equal to<br>zero, bit 7 of a user Wait flag is set.                                                                                                                                                                   |
| INT 1Ah: AH = 06h Set User Alarm<br>This function activates the CBIOS<br>real time clock ISR's Alarm Interrupt<br>component.                                      | ALARM INTERRUPT PROCESSING<br>The CBIOS real time clock ISR decrements<br>a counter (set to a user-specified period<br>of time) by 1/1024 second for each RTC<br>interrupt. When the count reaches zero,<br>the CBIOS real time clock ISR issues a<br>software INT 4Ch.<br>CBIOS users may revector INT 4Ch to<br>their own routines. If not revectored, INT<br>4Ch returns immediately to the caller with<br>all registers preserved. |

# INT 70h Real Time Clock ISR, Continued

### Hardware Environment

The CBIOS Real Time Clock Interrupt Service routine assumes the existence of a CMOS real time clock with 64 bytes of nonvolatile RAM, compatible with a Motorola MC146818A chip. Also, the Intel 82284 clock generator chip or its equivalent is assumed.

### System RAM data area

The CBIOS real time clock ISR references the following system RAM data:

| Location | Size   | Description                                                                                                                                |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 40:6Ch   | 1 Word | Least significant timer count (incremented by INT 08h)                                                                                     |
| 40:6Eh   | 1 Word | Most significant timer count                                                                                                               |
| 40:70h   | 1 Byte | 24 hour rollover flag                                                                                                                      |
| 40:98h   | 1 Word | User wait flag offset address                                                                                                              |
| 40:9Ah   | 1 Word | User wait flag segment address                                                                                                             |
| 40:9Ch   | 1 Word | Least significant wait count                                                                                                               |
| 40:9Eh   | 1 Word | Most significant wait count                                                                                                                |
| 40:A0h   | 1 Byte | Wait active flag, where:<br>Bit 7 = 1 If wait time elapsed<br>Bits 6-1 = Reserved<br>Bit 0 = 1 If INT 15h, AH = 86h (wait)<br>has occurred |

### Real Time Clock I/O Ports

INT 70h, Real Time Clock ISR, references the following I/O ports:

| I/O Address | Read/Write<br>Status | Description                                                                                                     |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------|
| 0020h       | R/W                  | Master Programmable Interrupt Controller                                                                        |
| 0070h       | W                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0 = 0 CMOS address |
| 0071h       | R/W                  | CMOS RAM data port                                                                                              |
| 00A0h       | R/W                  | Slave Programmable Interrupt Controller                                                                         |

### CMOS RAM data table areas

The CBIOS real time clock ISR references the following CMOS RAM data:

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                    |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Bh      | 1 Byte | Status register B, where:Bit 7= 0 Run= 1 HaltBit 6= 1 Enable periodic interruptBit 5= 1 Enable alarm interruptBit 4= 1 Enable alarm interruptBit 3= 1 Enable square wave interruptBit 2= 1 Calendar is in binary format= 0 Calendar is in BCD formatBit 1= 1 24-hour mode= 0 12-hour modeBit 0= 1 Enable Daylight Savings Time |
| 0Ch      | 1 Byte | Status register C, where:<br>Bits 7-4 = IRQF, PF, AF, and UF flags,<br>respectively<br>Bits 3-0 = Reserved                                                                                                                                                                                                                     |
| 0Dh      | 1 Byte | Status register D, where:<br>Bit 7 = 1 Real time clock has power<br>Bits 6-0 = Reserved                                                                                                                                                                                                                                        |

# **1**6

# Chapter 16 Single Function CBIOS Services

## Overview

### Introduction

Most of the CBIOS device services contain a group of functions intended to service a given device. For example, in the CBIOS Parallel Printer service, invoking INT 17h with AH = 00h causes the service to execute its print character function. On the other hand, invoking INT 17h with AH = 01h causes the service to execute its Initialize Printer Port function.

### The single function services

In addition to its multifunction device services, the CBIOS also contains four single function device services. Since these services perform only one function, it is not necessary to specify a function number in the AH register.

# Overview, Continued

### In this chapter

Because each single function service can be described on one or two pages, they are grouped into this one chapter.

This chapter presents the following topics:

- INT 05h Print Screen Service
- INT 11h Equipment List Service
- INT 12h Memory Size Service
- INT 19h Bootstrap Loader Service

### Description

The Print Screen Service:

- prints the contents of the entire current video screen to printer number 0,
- moves the cursor across the screen as the lines on the screen are printed,
- repositions the cursor position to its original position, and
- returns all registers to their original values.

Since the Print Screen Service takes a considerable amount of time to execute, interrupts are enabled throughout the routine.

### How the service is invoked

INT 05h invokes the CBIOS Print Screen Service.

The INT 05h vector resides at the Interrupt Vector Table address 00:14h. The CBIOS initializes the INT 05h Print Screen Service vector to address F000:FF54h, the IBM-compatible BIOS entry point.

Note: INT 05h is usually invoked by the keyboard interrupt handler (INT 09h) when the PrtSc key is pressed. However, CBIOS users may invoke INT 05h independently of the INT 09h interrupt handler. For more information on INT 09h, refer to Chapter 8 of this volume.

### System RAM Data

The Print Screen Service uses two system RAM data definitions. Both definitions are located in the CBIOS Data Area (absolute hex address 400h to 500h) and are defined in the table below:

| Location | Size   | Description                                                                                                                                                                          |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40:84h   | 1 Byte | Number of rows on screen (24/25)                                                                                                                                                     |
| 40:100h  | 1 Byte | Print Screen Status Byte, where:<br>00h = Print Screen Service inactive, or Print<br>Screen Service successful upon return<br>01h = Print Screen in progress<br>FFh = Error occurred |

# INT 05h Print Screen Service, Continued

## Input/Output

| Input:  | None                           |
|---------|--------------------------------|
| Output: | None (Registers are preserved) |

### Error conditions

The Print Screen Service recognizes three kinds of error conditions.

The table below summarizes the Print Screen Service error handling procedures.

| lf                                          | Then the Print Screen Service                                                                                                                                       |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| the printer is busy                         | <ul> <li>Sets location 40:100h = FFh</li> <li>Repositions cursor to original position</li> <li>Preserves all registers</li> <li>Returns to the caller</li> </ul>    |
| the printer is out of paper                 | <ul> <li>Repositions cursor to original position</li> <li>Preserves all registers</li> <li>Returns to the caller</li> <li>Sets location 40:100h = FFh</li> </ul>    |
| recursive print screen<br>requests are made | <ul> <li>Preserves all registers</li> <li>Returns to the caller</li> <li>Does not change location 40:100h (it was set to 01 by previous INT 05h request)</li> </ul> |

### Description

The Equipment List Service returns the contents of system RAM location 40:10h in the AX register. This memory location contains the system equipment list as determined by the CBIOS power-on self test and initialization (POST) routine.

### How the service is requested

INT 11h requests the Equipment List Service of the CBIOS.

The INT 11h vector resides at the Interrupt Vector Table address 0:44h. The CBIOS initializes the INT 11h Equipment List Service vector to address F000:F84Dh, the IBM-compatible entry point.

### Input/Output

| Input:  | None                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output: | Equipment List<br>AX = Contents of system RAM location 40:10h, where:<br>Bits 15-14 = Number of printer adapters<br>Bits 13-12 = Reserved<br>Bits 11-9 = Number of RS-232-C asynchronous adapters<br>Bit 8 = Reserved<br>Bits 7-4 = Number of diskette drives, (if Bit 0 = 1),<br>where:<br>00b = 1 diskette drive<br>01b = 2 diskette drives |
|         | Bit 5-4 = Initial video mode, where:<br>00b = EGA  or PGA<br>01b = 40x25  color<br>10b = 80x25  color<br>11b = 80x25  black and white<br>Bit 3 = Reserved<br>Bit 2 = 1 If pointing device installed<br>Bit 1 = 1 If math coprocessor installed<br>Bit 0 = 1 If diskette available for boot                                                    |

# **INT 12h Memory Size Service**

### Description

The Memory Size Service returns the contents of system RAM location 40:13h in the AX register. This location contains the amount of available base memory in kilobytes as it is determined by the CBIOS power-on self test and initialization routine (POST).

POST determines the amount of available base memory according to the formula below:

| Available base memory | = Installed base memory                                                    |
|-----------------------|----------------------------------------------------------------------------|
|                       | <ul> <li>Memory reserved for<br/>Extended Data Area</li> </ul>             |
|                       | <ul> <li>Upper 1K reserved for BIOS</li> <li>Extended Data Area</li> </ul> |

Note: The CBIOS Extended Data Area generally occupies 1K of upper memory. In systems with 640K of installed base memory, the Memory Size Service will report 639K of available base memory.

### How the service is invoked

INT 12h invokes the CBIOS Memory Size Service.

The INT 12h vector resides at the Interrupt Vector Table address 0:48h. The CBIOS initializes the INT 12h memory size service vector to address F000:F841h, the IBM-compatible entry point.

### Input/Output

| Input:  | None                                            |
|---------|-------------------------------------------------|
| Output: | Available Base Memory                           |
|         | AX = Contents of location 40:13h in binary form |

### Description

The Bootstrap Loader Service attempts to load the 512-byte boot sector code from either floppy or fixed disk to address 0:7C00h, transferring control to that code segment.

The boot code is located in the first sector of the floppy diskette (track 0, head 0, sector 1) or in the first sector of the fixed disk (cylinder 0, head 0, sector 1).

### Input/Output

Input: = None Output: = None (registers are preserved)

### How the service is invoked

INT 19h invokes the CBIOS Bootstrap Loader Service.

The INT 19h vector resides at the Interrupt Vector Table address 0:64h. The CBIOS initializes the INT 19h Bootstrap Loader Service vector to address F000:E6F2h, the IBM-compatible entry point.

**Note:** INT 19h is usually invoked by the power-on self test and initialization (POST) routine at the end of all POST processing. CBIOS users are free to invoke INT 19h independently of POST. Users should be aware, however, that invoking INT 19h does not reset or reinitialize the system but simply causes the system to reboot. For more information on POST and INT 19h, refer to Chapter 6 of this volume.

# INT 19h Bootstrap Loader Service, Continued

### Bootstrap processing

Once INT 19h has been invoked, the Bootstrap Loader Service executes as described below:

| Step                                            | Description                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. Locate and load<br>boot code                 | The boot code, located in the first sector of the floppy, under-<br>takes the following processing: diskette (track 0, head 0, sec-<br>tor 1) or in the first sector of the hard disk (cylinder 0, head<br>0, sector 1). The Bootstrap Loader attempts to locate the<br>boot sector and load it into memory at address 0:7C00h.                                            |
| 2. Check for<br>power-on<br>password            | The Bootstrap Loader Service tests for the presence of a sys-<br>tem power-on password before it attempts to transfer control<br>to the boot code. End users enable or disable the power-on<br>password via the Reference Diskette.                                                                                                                                        |
| 3. If power-on<br>password enabled              | If the Bootstrap Loader finds the power-on password is<br>enabled, it provides the user with three opportunities to enter<br>the password correctly. After three attempts the system halts<br>and must be turned off, then turned on again before INT 19h<br>may be invoked again. The Bootstrap Loader recalculates the<br>CRC if the power-on password has been changed. |
| 4. Process boot code, if found                  | Once power-on password issues have been resolved, the<br>Bootstrap Loader Service transfers control to the boot code if<br>it has been located.                                                                                                                                                                                                                            |
| 5. If no boot code<br>found, invoke INT<br>18h. | If the Bootstrap Loader Service does not find the boot sector<br>code, it invokes INT 18h. By default, INT 18h displays the<br>message "No boot device available, press F1 to continue."<br>(See INT 18h DSR handler below.)                                                                                                                                               |

### INT 18h DSR handler

If no boot sector is found either on the diskette in drive A: or on the fixed disk, Bootstrap Loader Service invokes software interrupt INT 18h. INT 18h can be vectored to a "no boot device" routine which takes over the boot process. For example, INT 18h can be vectored to a routine that would allow the system to be booted over a network.

By default, the CBIOS initializes INT 18h to point to a routine that displays the message: "NO BOOT DEVICE AVAILABLE, PRESS F1 TO CONTINUE."

### INT 19h and the power-on password

The Bootstrap Loader Service maintains a flag which is set when the poweron password has been input correctly. Once the power-on password is input correctly, INT 19h may be invoked again (either directly or through <Ctrl> <Alt> <Del> warm boot) without requiring user re-entry of the password.

### Password Messages

In PS/2 MCA-compatible systems, security is implemented primarily by password control. There are two types of password control:

- sign-on, which controls access to the system, and
- keyboard security, which controls access to the keyboard.

Several messages relate to password control. They are described in the following table.

| Message                           | Cause                                                                                                               | Solution                                   |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
| Enter password                    | A password has been<br>installed and now controls<br>access to the system.                                          | Enter the correct 1-7 character password.  |
| Password Ok                       | A correct password has been entered.                                                                                | No action.                                 |
| Password has been<br>removed      | The old password has<br>been deleted. Now there<br>is no password protection<br>until a new password is<br>entered. | No action.                                 |
| New password has been installed   | A new password is now entered.                                                                                      | Use the new password to access the system. |
| System halted! Must<br>power down | An incorrect password<br>was entered. The system<br>stops and must be<br>rebooted.                                  | Enter the correct password.                |
| Password is incorrect             | Incorrect password entered.                                                                                         | Enter the correct password.                |

Models 25 and 30: Password control is not available in PS/2 compatible systems (such as Models 25 and 30) which are not MCA-based.

# INT 19h Bootstrap Loader Service, Continued

### I/O Ports Used

INT 19h, Bootstrap Loader Service, references the following I/O ports:

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0060h       | R/W                  | Keyboard/auxiliary data port                                                                                                                                                                                                                                                                                                     |
| 0064h       | w                    | 8042 Commands                                                                                                                                                                                                                                                                                                                    |
| 0064h       | R                    | 8042 Status, where:<br>Bit 7 = 1 Parity error<br>Bit 6 = 1 General time out<br>Bit 5 = 1 Auxiliary output buffer full<br>Bit 4 = 1 Inhibit switch<br>Bit 3 = 1 Command<br>0 Data<br>Bit 2 = System flag<br>Bit 1 = 1 Input buffer full<br>Bit 0 = 1 Output buffer full                                                           |
| 0070h       | w                    | CMOS RAM address register port, where:<br>Bit 7 = 1 NMI disable<br>= 0 NMI enabled<br>Bits 6-0 = 0 CMOS address                                                                                                                                                                                                                  |
| 0071h       | R/W                  | CMOS RAM data register port                                                                                                                                                                                                                                                                                                      |
| 0090h       | w                    | Arbitration register, where:<br>Bit 7 = 1 Enable system microprocessor cycle<br>Bit 6 = 1 Arbitration mask<br>Bit 5 = 1 Enable extended arbitration<br>Bits 4-0 = 0 Reserved                                                                                                                                                     |
| 0090h       | R                    | Arbitration register, where:<br>Bit 7 = 1 System microprocessor cycles enabled<br>Bit 6 = 1 Arbitration mask by NMI<br>Bit 5 = 1 Bus timeout<br>Bit 4 = 0 Reserved<br>Bits 3-0 = Arbitration level                                                                                                                               |
| 0092h       | R/W                  | System control port A, where:<br>Bit 7 = 1 Fixed disk activity light bit A on<br>Bit 6 = 1 Fixed disk activity light bit B on<br>Bit 5 = Reserved<br>Bit 4 = 1 Watchdog time-out occurred<br>Bit 3 = 1 Security lock latch is locked<br>Bit 2 = Reserved<br>Bit 1 = 1 Alternate gate A20 active<br>Bit 0 = 1 Alternate hot reset |
| 0094h       | R/W                  | System board setup enable register, where:<br>Bit 7 = 0 Enable system board setup<br>= 1 Disable system board setup<br>Bit 6 = 1 Reserved<br>Bit 5 = 0 Enable VGA setup<br>1 Disable VGA setup<br>Bits 4-0 = 1 Reserved                                                                                                          |

# INT 19h Bootstrap Loader Service, Continued

### System RAM data

The Bootstrap Loader Service uses three system RAM data definitions. The definitions are located in the BIOS Data Area (absolute hex address 400h to 500h) and are defined in the table below.

| Location | Size   | Description                                                                                                                            |
|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------|
| 40:12h   | 1 Byte | Reserved for manufacturer's test, where:<br>Bits 7-1 = Reserved<br>Bit 0 = 1 Manufacturing test mode<br>= 0 Nonmanufacturing test mode |
| 40:72h   | 1 Word | System Reset Flag Where:<br>1234h = Bypass memory text<br>4321h = Reserved for ABIOS                                                   |
| 40:75h   | 1 Byte | Number of fixed disk drives                                                                                                            |

### CMOS RAM data

The Bootstrap Loader Service uses four CMOS RAM data areas. The definitions are located in the standard CMOS RAM Data Area and are defined in the table below.

| Location | Size   | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Eh      | 1 Byte | Diagnostic status, where:Bit 7= 1 Real time clock has lost powerBit 6= 1 CMOS checksum is badBit 5= 1 Invalid configuration<br>information found at POSTBit 4= 1 Memory size compare error found at<br>POSTBit 3= 1 Fixed disk or adapter fails initialization<br>Bit 2Bit 1= 1 CMOS time found invalidBit 1= 1 Adapters do not match configuration<br>Bit 0Bit 0= 1 Time-out in reading an adapter ID |
| 13h      | 1 Byte | Password Configuration<br>Bits 7-2= 0 Reserved<br>Bit 1 = 1 Network password installed<br>= 0 Network password not installed<br>Bit 0 = 1 Power-on password installed<br>= 0 Power-on password not installed                                                                                                                                                                                           |
| 38h-3Eh  | 1 Byte | Power-on password                                                                                                                                                                                                                                                                                                                                                                                      |
| 39h      | 1 Byte | Power-on password checksum                                                                                                                                                                                                                                                                                                                                                                             |

# Appendix A CBIOS Error Messages

### Overview

### Introduction

The CBIOS can generate a variety of messages. Messages can be merely informational, or can alert the user to a hardware or software failure.

A Phoenix CBIOS generates both beep codes (useful for error conditions when POST is not completed and the monitor is not yet initialized by the system) and screen error messages.

#### In this appendix

This appendix lists all CBIOS error messages and beep codes. The following information is presented:

- POST: Error Handling
- POST: Beep Codes
- POST: System Failure Messages
- POST: Boot Failure Messages
- POST: Informational Messages
- NMI: Run Time Messages
- INT 19h: Password Messages
- Model 25 and 30 Beep Codes
- Model 25 and 30 Error Messages

**CBIOS Error Messages** 

# **POST: Error Handling**

### Introduction

The Phoenix POST reports test or initialization failures in one of the following ways:

- Beep codes
- System failure messages
- Boot failure messages
- Informational messages

### Beep codes

When a POST test fails before the video screen is available for display, POST halts the processor and notifies the user by sounding a series of beeps. Beep codes are written to a hardware test I/O port. The default value for the hardware test I/O port is 0680h, but it may be different in some systems. Hardware test equipment external to the system can be used to read this information.

Beep codes are generated by the Phoenix CBIOS only.

### System failure messages

POST notifies the user of a test or initialization failure by displaying a message on the screen. Each message is preceded by an error code. The error code is also stored in the POST error log.

End users use the reference diskettes supplied with their systems to run a utility program that provides a detailed explanation of each error stored in the POST error log.

The IBM CBIOS displays only the numeric error code for a given system failure.

### Boot failure messages

Once the POST test and initialization procedures are completed, POST boots the system by issuing software interrupt, INT 19h System Boot load. If this process fails, POST displays a screen message or graphic. System boot messages are not preceded by a numeric error code and are not logged into the POST error log.

### Informational messages

In addition to error messages, the CBIOS POST also generates a set of messages that inform the user of the progress of POST memory testing.

# POST: Beep Codes (Phoenix CBIOS Only)

When a POST test fails before the video screen is available for display, the Phoenix CBIOS POST notifies the user by sounding a series of beeps, and halts the processor. Beep codes are also written to a hardware test I/O port. The default value for this port is in I/O port 680h, but it may vary. Hardware test equipment external to the system can be used to read this information.

| Beep<br>Code | Contents<br>Port 680h | Description                                      |
|--------------|-----------------------|--------------------------------------------------|
| none         | 01h                   | CPU register test in progress                    |
| 1-1-3        | 02h                   | CMOS write/read failure                          |
| 1-1-4        | 03h                   | ROM BIOS checksum failure                        |
| 1-2-1        | 04h                   | Programmable interval timer failure              |
| 1-2-2        | 05h                   | DMA initialization failure                       |
| 1-2-3        | 06h                   | DMA page register write/read failure             |
| 1-3-1        | 08h                   | RAM refresh verification failure                 |
| none         | 09h                   | First 64K RAM test in progress                   |
| 1-3-3        | 0Ah                   | First 64K RAM chip or data line failure multibit |
| 1-3-4        | 0Bh                   | First 64K RAM odd/even logic failure             |
| 1-4-1        | 0Ch                   | Address line failure first 64K RAM               |
| 1-4-2        | 0Dh                   | Parity failure first 64K RAM                     |
| 2-1-1        | 10h                   | Bit 0 first 64K RAM chip or data line failure    |
| 2-1-2        | 11h                   | Bit 1 first 64K RAM chip or data line failure    |
| 2-1-3        | 12h                   | Bit 2 first 64K RAM chip or data line failure    |
| 2-1-4        | 13h                   | Bit 3 first 64K RAM chip or data line failure    |
| 2-2-1        | 14h                   | Bit 4 first 64K RAM chip or data line failure    |
| 2-2-2        | 15h                   | Bit 5 first 64K RAM chip or data line failure    |
| 2-2-3        | 16h                   | Bit 6 first 64K RAM chip or data line failure    |
| 2-2-4        | 17h                   | Bit 7 first 64K RAM chip or data line failure    |
| 2-3-1        | 18h                   | Bit 8 first 64K RAM chip or data line failure    |
| 2-3-2        | 19h                   | Bit 9 first 64K RAM chip or data line failure    |
| 2-3-3        | 1Ah                   | Bit A first 64K RAM chip or data line failure    |

# POST: Beep Codes (Phoenix CBIOS Only), Continued

| Beep<br>Code | Contents<br>Port 680h | Description                                             |
|--------------|-----------------------|---------------------------------------------------------|
| 2-3-4        | 1Bh                   | Bit B first 64K RAM chip or data line failure           |
| 2-4-1        | 1Ch                   | Bit C first 64K RAM chip or data line failure           |
| 2-4-2        | 1Dh                   | Bit D first 64K RAM chip or data line failure           |
| 2-4-3        | 1Eh                   | Bit E first 64K RAM chip or data line failure           |
| 2-4-4        | 1Fh                   | Bit F first 64K RAM chip or data line failure           |
| 3-1-1        | 20h                   | Slave DMA register failure                              |
| 3-1-2        | 21h                   | Master DMA register failure                             |
| 3-1-3        | 22h                   | Master interrupt mask register failure                  |
| 3-1-4        | 23h                   | Slave interrupt mask register failure                   |
| none         | 25h                   | Interrupt vector loading in progress                    |
| 3-2-4        | 27h                   | Keyboard controller test failure                        |
| none         | 28h                   | CMOS power failure and checksum calculation in progress |
| none         | 29h                   | CMOS configuration validation in progress               |
| 3-3-4        | 2Bh                   | Screen memory test failure                              |
| 3-4-1        | 2Ch                   | Screen initialization failure                           |
| 3-4-2        | 2Dh                   | Screen retrace test failure                             |
| none         | 2Eh                   | Search for video ROM in progress                        |
| none         | 30h                   | Screen operable                                         |
| none         | 30h                   | Screen running with video ROM                           |
| none         | 31h                   | Monochrome monitor operable                             |
| none         | 32h                   | Color monitor (40 column) operable                      |
| none         | 33h                   | Color monitor (80 column) operable                      |

# **POST: System Failure Messages**

| Error<br>Code | Message                                                                | Possible Cause                                                                                                                                                                     | Suggested Solution                                                                                                                                                |  |
|---------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 102           | System Board Failure                                                   | Timer 0 or 2 failed during POST.                                                                                                                                                   | Replace the system board.                                                                                                                                         |  |
| 103           | System Board Failure                                                   | The timer interrupt failed while testing timer 0 dur-<br>ing POST.                                                                                                                 | Replace the system board.                                                                                                                                         |  |
| 104           | System Board Failure                                                   | An unexpected interrupt<br>has occurred while the<br>processor was in pro-<br>tected mode.                                                                                         | Replace the system<br>board.                                                                                                                                      |  |
| 108           | System Board Failure                                                   | Timer 2 failed during POST.                                                                                                                                                        | Replace the system board.                                                                                                                                         |  |
| 114           | Option ROM Check-<br>sum Failure — <i>xxxx:0</i>                       | The checksum<br>calculated for an option<br>ROM does not match<br>the checksum stored in<br>the option ROM. XXXX<br>indicates the segment<br>address of the failing<br>option ROM. | Replace the failing<br>option ROM or adapter<br>card containing the<br>option ROM.                                                                                |  |
| 130           | System Board Fallure                                                   | A shutdown failure has<br>occurred during POST.                                                                                                                                    | Replace the system board.                                                                                                                                         |  |
| 131           | System Board Failure                                                   | Gating of the A20<br>address line failed when<br>entering/exiting pro-<br>tected mode.                                                                                             | Replace the system<br>board.                                                                                                                                      |  |
| 161           | Real Time Clock Fail-<br>ure (battery) Please<br>Reconfigure and Retry | The real time clock's bad battery flag bit is set.                                                                                                                                 | Replace the battery.<br>If the problem persists,<br>replace the system<br>board.                                                                                  |  |
| 162           | Real Time Clock Fail-<br>ure (CRC) Please<br>Reconfigure and Retry     | The checksum for the CMOS in the real time clock is incorrect.                                                                                                                     | Run the Reference<br>Diskette to update<br>CMOS. If the problem<br>persists, replace the<br>battery. if the problem<br>still occurs, replace the<br>system board. |  |

| Error |                                                                                   |                                                                                                                                                                                                                                                        |                                                                                                                                                                                 |
|-------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code  | Message                                                                           | Possible Cause                                                                                                                                                                                                                                         | Suggested Solution                                                                                                                                                              |
| 163   | Time and Date Not<br>Set                                                          | The date and time in the<br>real time clock has not<br>been set or has been<br>corrupted.                                                                                                                                                              | Run the Reference<br>Diskette to update time<br>and date. If the prob-<br>lem persists, replace<br>the battery. If the<br>problem still occurs,<br>replace the system<br>board. |
| 164   | Invalid Configuration<br>Information (Memory)<br>Please Reconfigure<br>and Retry  | The amount of memory<br>found in the system does<br>not match the amount of<br>memory specified in<br>CMOS.                                                                                                                                            | Run the Reference<br>Diskette to correctly<br>configure the system.<br>If the problem persists,<br>replace the system<br>board.                                                 |
| 165   | Invalid Configuration<br>Information (Adapter)<br>Please Reconfigure<br>and Retry | An adapter configured<br>by the Reference Disk-<br>ette program does not<br>exist in the correct slot<br>in the system.                                                                                                                                | Run the Reference<br>Diskette to correctly<br>configure the system.                                                                                                             |
| 166   | Invalid Configuration<br>Information (Adapter)<br>Please Reconfigure<br>and Retry | <ul> <li>An adapter configured<br/>by the Reference Disk-<br/>ette either</li> <li>does not exist in the<br/>slot specified by the<br/>system, or</li> <li>is not responding.</li> </ul>                                                               | Run the Reference<br>Diskette to correctly<br>configure the system.<br>If the problem persists,<br>replace the adapter.                                                         |
| 167   | Invalid Configuration<br>Information (diskette)                                   | Diskette adapter does<br>not exist or is not<br>responding.                                                                                                                                                                                            | Run the Reference<br>Diskette to configure<br>the system. Replace<br>the adapter if problem<br>persists.                                                                        |
| 168   | Invalid configuration in-<br>formation (System<br>board)                          | Math coprocessor either not operating or missing.                                                                                                                                                                                                      | Either replace copro-<br>cessor or reconfigure.                                                                                                                                 |
| 201   | Memory Failure at<br>xxxx:yyyy, Read aa,<br>Expecting bb                          | A read/write error has<br>occurred in memory at<br>the address specified by<br>'xxxx:yyyy.' The test<br>value written to the<br>memory location is indi-<br>cated by 'bb' and the<br>value read from the<br>memory location is indi-<br>cated by 'aa.' | Replace the memory in<br>the system. If the<br>problem persists, re-<br>place the system<br>board.                                                                              |

| Error<br>Cod <del>e</del> | Message                                                  | Possible Cause                                                                                                                                                                                                                                              | Suggested Solution                                                                                                                                             |
|---------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 202                       | Memory Failure at<br>xxxx:yyyy, Read aa,<br>Expecting bb | A memory parity error<br>has occurred in memory<br>at the address specified<br>by 'xxxx:yyyy.' The test<br>value written to the<br>memory location is indi-<br>cated by 'bb' and the<br>value read from the<br>memory location is indi-<br>cated by 'aa.'   | Replace the memory<br>in the system. If the<br>problem persists, re-<br>place the system<br>board.                                                             |
| 203                       | Memory Failure at<br>xxxx:yyyy, Read aa,<br>Expecting bb | An address line failure<br>has occurred in memory<br>at the address specified<br>by 'xxxx:yyyy.' The test<br>value written to the<br>memory location is indi-<br>cated by 'bb' and the<br>value read from the<br>memory location is indi-<br>cated by 'aa.' | Replace the memory<br>in the system. If the<br>problem persists, re-<br>place the system<br>board.                                                             |
| 301                       | Keyboard Failure                                         | The keyboard controller<br>has failed during POST.                                                                                                                                                                                                          | Check the keyboard to<br>make sure it is func-<br>tioning correctly and is<br>installed correctly. If<br>the problem persists,<br>replace the system<br>board. |
| 304                       | Keyboard Failure                                         | The clock line on the<br>keyboard controller has<br>failed during POST.                                                                                                                                                                                     | Check the keyboard to<br>make sure it is func-<br>tioning correctly and is<br>installed correctly. If<br>the problem persists,<br>replace the system<br>board. |
| 306                       | Keyboard Failure                                         | The data line on the key-<br>board controller has<br>failed during POST.                                                                                                                                                                                    | Check the keyboard to<br>make sure it is working<br>correctly and is in-<br>stalled correctly. If the<br>problem persists, re-<br>place the system<br>board.   |

| Error<br>Code | Message                       | Possible Cause                                                                                          | Suggested Solution                                                                                                                                         |
|---------------|-------------------------------|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 307           | Keyboard Failure              | A stuck key has been<br>detected on the<br>keyboard.                                                    | Check the keyboard to<br>make sure it is working<br>correctly and is in-<br>stalled correctly. If the<br>problem persists,<br>replace the system<br>board. |
| 601           | Diskette Drive Failure        | The reset function has failed on the diskette subsystem.                                                | The diskette controller has failed and should be replaced.                                                                                                 |
| 602           | Diskette Drive x<br>Failure   | The seek function<br>has failed on diskette<br>drive x.                                                 | The drive is malfunc-<br>tioning and should be<br>replaced.                                                                                                |
| 901           | Parallel Port Failure         | Parallel printer data port<br>failed.                                                                   | Use an alternate printer port or replace the system board.                                                                                                 |
| 1101          | Serial Port Failure           | The serial port on the system board has failed.                                                         | Use an alternate serial port or replace the sys-<br>tem board.                                                                                             |
| 1780          | Fixed Disk Drive 0<br>Failure | Fixed disk drive 0 is not<br>ready, or the recalibra-<br>tion function failed during<br>initialization. | Check the fixed disk<br>controller. Check all<br>connections. If the<br>problem persists, test<br>the drive using the Ref-<br>erence Diskette.             |
| 1781          | Fixed Disk Drive 1<br>Failure | Fixed disk drive 1 is not<br>ready, or the recalibra-<br>tion function failed during<br>initialization. | Check the fixed disk<br>controller. Check all<br>connections. If the<br>problem persists, test<br>the drive using the Ref-<br>erence Diskette.             |
| 1782          | Fixed Disk Reset<br>Failure   | Fixed disk failed reset.                                                                                | Check the fixed disk<br>controller. Check all<br>connections. If the<br>problem persists, test<br>the drive using the Ref-<br>erence Diskette.             |
| 1790          | Fixed Disk Drive 0<br>Failure | The verify function has failed on fixed disk drive 0.                                                   | Run Reference Diskette<br>to determine if the disk<br>is usable.                                                                                           |

| Fixed Disk Drive 1<br>Failure<br>Video Failure<br>Video Failure<br>Chip Set CMOS Failure | The verify function<br>has failed on fixed disk<br>drive 1.<br>The system board video<br>controller has failed dur-<br>ing POST.<br>The system board video<br>controller has failed dur-<br>ing POST.<br>Bad chip set battery, or | Run the Reference<br>Diskette to determine if<br>the disk is usable.<br>Replace the system<br>board.<br>Replace the system<br>board.                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Video Failure                                                                            | controller has failed dur-<br>ing POST.<br>The system board video<br>controller has failed dur-<br>ing POST.                                                                                                                      | board.<br>Replace the system<br>board.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                          | controller has failed dur-<br>ing POST.                                                                                                                                                                                           | board.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Chip Set CMOS Failure                                                                    | Bad chip set battery or                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                          | bad CMOS RAM.                                                                                                                                                                                                                     | Replace the chip set battery.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Chip Set Shadow RAM<br>Failure                                                           | ROM not shadowed to RAM.                                                                                                                                                                                                          | Enable RAM shadowing<br>again. If still generated,<br>bad or nonexistent<br>RAM.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bad Configuration In-<br>formation in CMOS                                               | Chip set CMOS has in-<br>correct information.                                                                                                                                                                                     | Reconfigure with the<br>Reference Diskette. If<br>error persists, replace<br>CMOS battery or<br>CMOS RAM.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Pointing Device<br>Interface Failure                                                     | The pointing device<br>(mouse) was detected<br>but did not accept a<br>command.                                                                                                                                                   | Check the pointing de-<br>vice for proper opera-<br>tion. If the problem<br>persists, replace the<br>device. If the problem<br>still occurs, replace the<br>system board.                                                                                                                                                                                                                                                                                                                                                    |
| Pointing Device<br>Interface Failure                                                     | The pointing device<br>(mouse) was detected<br>but an interface error<br>occurred while testing.                                                                                                                                  | Check the pointing de-<br>vice for proper opera-<br>tion. If the problem<br>persists, replace the<br>device. If the problem<br>still occurs, replace the<br>system board.                                                                                                                                                                                                                                                                                                                                                    |
| Pointing Device Failure                                                                  | The pointing device<br>(mouse) was detected<br>but a time-out occurred<br>while attempting to<br>access it.                                                                                                                       | Check the pointing de-<br>vice for proper opera-<br>tion. If the problem<br>persists, replace the<br>device. If the problem<br>still occurs, replace the<br>system board.                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                          | Bad Configuration In-<br>formation in CMOS         Pointing Device<br>Interface Failure         Pointing Device<br>Interface Failure         Pointing Device<br>Interface Failure         Pointing Device Failure                 | Bad Configuration In-<br>formation in CMOS       Chip set CMOS has in-<br>correct information.         Pointing Device<br>Interface Failure       The pointing device<br>(mouse) was detected<br>but did not accept a<br>command.         Pointing Device<br>Interface Failure       The pointing device<br>(mouse) was detected<br>but an interface error<br>occurred while testing.         Pointing Device Failure       The pointing device<br>(mouse) was detected<br>but an interface error<br>occurred while testing. |

#### Description

Once the POST test and initialization procedures are completed, POST boots the system by issuing a software interrupt, INT 19h System Bootload. If there is a failure in this process, POST displays a message or graphic on the screen.

Unlike those associated with failures in POST test or initialization procedures, system boot messages are not preceded by a numeric error code and are not logged into the POST error log.

The table below lists the POST system boot error messages, their possible cause, and suggested solution.

| Message                         | Possible Cause                                                                                                                                                                                                                                     | Suggested Solution                                                                                                                                                                      |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Not a Boot Diskette             | The diskette in the disk-<br>ette drive does not con-<br>tain a valid bootstrap sec-<br>tor. Either the diskette is<br>defective or has not been<br>formatted.                                                                                     | Remove diskette and retry<br>boot. If no fixed disk is avail-<br>able, insert a diskette known<br>to be bootable, then retry<br>boot.                                                   |
| No Boot Device Available        | A read of diskette drive 0<br>timed out, and no fixed<br>disk is available from<br>which to boot.                                                                                                                                                  | Retry boot. If the problem<br>persists, replace the diskette<br>or fixed disk.                                                                                                          |
| Fixed Disk Read Failure         | A read of diskette drive 0<br>timed out, and a read of<br>the fixed disk falled. The<br>fixed disk is probably<br>defective.                                                                                                                       | Retry boot. If the problem persists, replace the fixed disk.                                                                                                                            |
| No Boot Sector on<br>Fixed Disk | A read of diskette drive 0<br>timed out, and the boot-<br>strap sector on the fixed<br>disk is invalid. The fixed<br>disk is either defective,<br>has not been formatted,<br>and/or has never had<br>FDISK (or a comparable<br>utility) run on it. | Retry boot with a diskette<br>known to be bootable. Try for-<br>matting the fixed disk and/or<br>running FDISK, then retry<br>boot. If the problem persists,<br>replace the fixed disk. |

# **POST: Informational Messages**

## Description

The following messages are for informational purposes only and do not report error conditions.

| Message                              | Meaning                                                                                                                       |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| xxxK Base Memory                     | The amount of base memory in kilobytes that tested successfully.                                                              |
| xxxK Expanded Memory                 | The amount of expanded memory in kilo-<br>bytes that tested successfully.                                                     |
| xxxK Extended Memory                 | The amount of extended memory in kilobytes that tested successfully.                                                          |
| xxxK Extra Memory                    | The amount of extra memory in kilobytes that tested successfully.                                                             |
| xxxK Standard Memory                 | The amount of standard memory in kilobytes that tested successfully.                                                          |
| Decreasing available memory          | This message immediately follows any mem-<br>ory error messages and indicates that the<br>memory chips are failing.           |
| Memory tests terminated by keystroke | This message indicates that the spacebar<br>was pressed while the memory tests were<br>running, which stops the memory tests. |
| Strike the F1 key to continue        | This message indicates that an error was found during POST. Pressing the F1 key allows the system to reboot.                  |

# **NMI: Run Time Messages**

## Phoenix CBIOS NMI error messages

The Phoenix CBIOS NMI service generates the following run time error messages:

| Error<br>Cod <del>e</del> | Message                                 | Possible Cause                                                                                                                                                                                                                                                                    | Suggested Solution                                                                                                                                                                                                                                            |
|---------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 110                       | Memory Parity Error<br>at <i>xxxxx</i>  | Memory is failing. If the<br>NMI handler can deter-<br>mine the address of the<br>failing memory, it will be<br>displayed in place of<br>xxxxx. If the failing mem-<br>ory is not found, then<br>the message will read<br>"Memory Parity Error<br>????".                          | Check the system<br>board and all installed<br>devices for proper op-<br>eration. Replace if<br>necessary.                                                                                                                                                    |
| 111                       | I/O Card Parity Error<br>at <i>xxxx</i> | The peripheral card has<br>failed. If the NMI handler<br>can determine the ad-<br>dress of the failing mem-<br>ory, it will be displayed in<br>place of <i>xxxxx</i> . If the<br>failing memory is not<br>found, then the message<br>will read "I/O Card Par-<br>ity Error ????". | Check the system<br>board and all installed<br>devices for proper op-<br>eration. Replace if<br>necessary.                                                                                                                                                    |
| 112                       | Watchdog Time-out                       | The watchdog timer has<br>detected that the timer<br>0 interrupt has not been<br>serviced. A program or<br>device has probably<br>failed while interrupts<br>were off.                                                                                                            | Reboot the system. If<br>the problem persists,<br>check all installed de-<br>vices for proper opera-<br>tion. Replace if neces-<br>sary. If the problem still<br>occurs, examine all<br>programs for errors<br>which cause the inter-<br>rupts to remain off. |
| 113                       | DMA Bus Time-out                        | A device has driven the<br>-BURST signal line for<br>more than 7.8 micro-<br>seconds, causing the<br>central arbiter device<br>(on the motherboard)<br>to generate a bus<br>time-out.                                                                                             | Check system board<br>and all installed devices<br>for proper operation.<br>Replace if necessary.                                                                                                                                                             |

## NMI: Run Time Messages, Continued

#### **IBM CBIOS NMI error messages**

IBM PS/2 systems have a different set of error messages. The messages are followed by the segment address of the bad memory location or ????? if it cannot be found. These error codes and messages are listed in the following table:

| Error Code | Message                                 |
|------------|-----------------------------------------|
| . 110      | System Board Memory Failure             |
| 111        | I/O Channel Check Activated             |
| 112        | Watchdog Time-out                       |
| 113        | Direct Memory Access (DMA) Bus Time-out |

Models 25 and 30: IBM PS/2 Models 25 and 30 support memory parity error in the same way as other PS/2 systems but substitute the message PARITY CHECK1 for message 110 and PARITY CHECK2 for message 111.

> Time-out error handling is not supported on IBM PS/2 Model 25 and 30 systems.

#### Description

In MCA-based PS/2 and compatible systems, The CBIOS INT 19h Bootstrap Loader Service performs password checking after the boot sector is loaded.

Several messages relate to password control. They are described in the following table.

| Message                           | Cause                                                                                                               | Solution                                     |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| Enter password                    | A password has been<br>installed and now controls<br>access to the system.                                          | Enter the correct 1-7<br>character password. |
| Password Ok                       | A correct password has been entered.                                                                                | No action.                                   |
| Password has been<br>removed      | The old password has<br>been deleted. Now there<br>is no password protection<br>until a new password is<br>entered. | No action.                                   |
| New password has been installed   | A new password is now entered.                                                                                      | Use the new password to access the system.   |
| System halted! Must<br>power down | An incorrect password<br>was entered. The system<br>stops and must be<br>rebooted.                                  | Re-enter the correct password.               |
| Password is incorrect             | Incorrect password<br>entered.                                                                                      | Re-enter the correct password.               |

Models 25 and 30: Password control is not available in PS/2-compatible systems (such as Models 25 and 30) which are not MCA-based.

# Model 25 and 30 Beep Codes

| Beep<br>Code | Contents<br>Port 90h | Description                                       |
|--------------|----------------------|---------------------------------------------------|
| none         | 01h                  | CPU register test in progress                     |
| 1-1-4        | 03h                  | ROM BIOS checksum failure                         |
| 1-2-2        | 05h                  | DMA initialization failure                        |
| 1-2-3        | 06h                  | DMA page register write/read failure              |
| 1-3-1        | 08h                  | RAM refresh verification failure                  |
| 1-3-2        | 09h                  | First 64K RAM test in progress                    |
| 1-3-3        | 0Ah                  | First 64K RAM chip or data line failure multi-bit |
| 1-4-1        | 0Ch                  | Address line failure first 64K RAM                |
| 1-4-2        | 0Dh                  | Parity failure first 64K RAM                      |
| 2-1-1        | 10h                  | Bit 0 first 64K RAM chip or data line failure     |
| 2-1-2        | 11h                  | Bit 1 first 64K RAM chip or data line failure     |
| 2-1-3        | 12h                  | Bit 2 first 64K RAM chip or data line failure     |
| 2-1-4        | 13h                  | Bit 3 first 64K RAM chip or data line failure     |
| 2-2-1        | 14h                  | Bit 4 first 64K RAM chip or data line failure     |
| 2-2-2        | 15h                  | Bit 5 first 64K RAM chip or data line failure     |
| 2-2-3        | 16h                  | Bit 6 first 64K RAM chip or data line failure     |
| 2-2-4        | 17h                  | Bit 7 first 64K RAM chip or data line failure     |
| 2-3-1        | 18h                  | Bit 8 first 64K RAM chip or data line failure     |
| 2-3-2        | 19h                  | Bit 9 first 64K RAM chip or data line failure     |
| 2-3-3        | 1Ah                  | Bit 10 first 64K RAM chip or data line failure    |
| 2-3-4        | 1Bh                  | Bit 11 first 64K RAM chip or data line failure    |
| 2-4-1        | 1Ch                  | Bit 12 first 64K RAM chip or data line failure    |
| 2-4-2        | 1Dh                  | Bit13 first 64K RAM chip or data line failure     |
| 2-4-3        | 1Eh                  | Bit 14 first 64K RAM chip or data line failure    |
| 2-4-4        | 1Fh                  | Bit 15 first 64K RAM chip or data line failure    |
| none         | 21h                  | Master DMA register initialization                |
| 3-1-3        | 22h                  | Master Interrupt mask register failure            |
| none         | 25h                  | Interrupt vector loading in progress              |
| 3-2-4        | 27h                  | Keyboard failure                                  |
| none         | 2Ch                  | Screen initialization failure                     |
| 3-4-3        | 2Eh                  | Search for video ROM in failure                   |

| Model | 25 | and | 30 | POST | error | message | table |
|-------|----|-----|----|------|-------|---------|-------|
|-------|----|-----|----|------|-------|---------|-------|

| Message                                                                            | Possible Cause                                                                                                                                          | Solution                                                                                                |
|------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| Diskette configuration<br>error                                                    | The specified configuration is not supported.                                                                                                           | Change the configuration.                                                                               |
| Diskette drive reset failed                                                        | The diskette adapter has failed.                                                                                                                        | Check the diskette adapter.                                                                             |
| Diskette drive 1 seek<br>failure                                                   | The B: drive failed or is Check the B: drive. missing.                                                                                                  |                                                                                                         |
| Diskette drive 0 seek<br>failure                                                   | The A: drive has either failed or is missing.                                                                                                           | Check the A: drive.                                                                                     |
| Diskette drive reset<br>failed                                                     | The diskette adapter has failed.                                                                                                                        | Check the diskette adapter.                                                                             |
| Diskette read failure —<br>strike F1 to retry boot                                 | The diskette is either not formatted or defective. Bootable diskette and boot.                                                                          |                                                                                                         |
| Display adapter failed;<br>using alternate                                         | <ul> <li>The color/monochrome<br/>switch is incorrect.</li> <li>The primary video<br/>adapter failed.</li> </ul>                                        | <ul> <li>Change the switch to the correct setting.</li> <li>Check the primary video adapter.</li> </ul> |
| Errors found disk X:<br>Failed Initialization                                      | POST reports fixed disk<br>configuration information<br>is incorrect.<br>Rerun SETUP and en<br>correct fixed disk<br>information.                       |                                                                                                         |
| Errors found<br>incorrect configuration in-<br>formation memory size<br>miscompare | POST reports the size of<br>base or expansion mem-<br>ory does not agree with<br>configuration information.                                             | Rerun SETUP and enter correct memory size.                                                              |
| Fixed disk configuration error                                                     | The specified configuration is not supported.                                                                                                           | Correct the fixed disk configuration.                                                                   |
| Fixed disk controller<br>failure                                                   | The controller card has failed.                                                                                                                         | Replace the controller card.                                                                            |
| Fixed disk failure                                                                 | Bad disk.                                                                                                                                               | Retry boot. If that doesn't work, replace the fixed disk.                                               |
| Fixed disk read failure —<br>strike F1 to retry boot                               | The fixed disk is defective.                                                                                                                            | Retry boot. If that doesn't work, replace the fixed disk.                                               |
| Invalid configuration infor-<br>mation — please run<br>SETUP program               | <ul> <li>Memory size is<br/>incorrect.</li> <li>Display adapter is<br/>configured incorrectly.</li> <li>Wrong number of<br/>diskette drives.</li> </ul> | Run the SETUP utility.                                                                                  |

# Model 25 and 30 Error Messages, Continued

| Message                                                                                                              | Possible Cause                                                               | Solution                                  |  |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------|--|
| Keyboard clock line<br>failure                                                                                       | Either the keyboard or the keyboard con-                                     | Make sure the keyboard cable and keyboard |  |
| Keyboard data line failure                                                                                           | nection is defective.                                                        | connected properly.                       |  |
| Keyboard controller<br>failure                                                                                       | The keyboard controller firmware has failed.                                 | Check the keyboard controller.            |  |
| Keyboard is locked —<br>please unlock                                                                                | The keyboard lock lo-<br>cated at the front of the<br>computer is activated. | Unlock the keyboard.                      |  |
| Keyboard stuck key<br>failure                                                                                        | A key(s) is jammed.                                                          | Try pressing the key(s)<br>again.         |  |
| Memory address line fail-<br>ure at hex-value, read<br>hex-value, expecting<br>hex-value                             | Circuitry associated with the memory chips has failed.                       |                                           |  |
| Memory data line failure<br>at hex-value, read hex-<br>value, hex-value                                              | One of the memory chips<br>or associated circuitry<br>has failed.            |                                           |  |
| Memory high address<br>line failure at <i>hex-value</i> ,<br>read <i>hex-value</i> , expect-<br>ing <i>hex-value</i> | Circuitry associated with<br>the memory chips has<br>failed.                 |                                           |  |
| Memory double word<br>logic failure at hex-<br>value, read hex-value,<br>expecting hex-value                         | Memory chip circuitry failed.                                                |                                           |  |
| Memory odd/even logic<br>failure at <i>hex-failure</i> ,<br>read <i>hex-value</i> , expect-<br>ing <i>hex-value</i>  | the memory chips has                                                         |                                           |  |
| Memory parity failure at<br>hex-value, read<br>hex-value, expecting<br>hex-value                                     | One of the parity memory Cry replacing the memory chips has failed.          |                                           |  |
| Memory write/read fail-<br>ure at <i>hex-value</i> , read<br><i>hex-value</i> , expecting<br><i>hex value</i>        | One of the memory chips<br>has failed.<br>Try replacing the memor<br>chips.  |                                           |  |

## Model 25 and 30 POST error message table, cont'd

| <b></b>                                                      |                                                                                                                                                                               | · · · · · · · · · · · · · · · · · · ·                                                                |  |
|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| Message                                                      | Possible Cause                                                                                                                                                                | Solution                                                                                             |  |
| No boot device<br>available — strike F1 to<br>retry boot     | Either diskette drive A:,<br>the fixed disk, or the disk-<br>ette itself is defective.<br>Retry boot. If that doesr<br>work, replace the floppy<br>diskette or the fixed disk |                                                                                                      |  |
| No boot sector on fixed<br>disk — strike F1 to retry<br>boot | The C: drive is not<br>formatted or is not<br>bootable.                                                                                                                       |                                                                                                      |  |
| Not a boot diskette —<br>strike F1 to retry boot             | The diskette in drive A: is not formatted as a bootable diskette.                                                                                                             | Replace the diskette with a bootable diskette and retry boot.                                        |  |
| No timer tick interrupt                                      | The timer chip has failed.                                                                                                                                                    | Check the timer chip on the system board.                                                            |  |
| Hex-value optional ROM<br>bad checksum =<br>hex-value        | The peripheral card contains a defective ROM.                                                                                                                                 | Replace the peripheral card.                                                                         |  |
| Shutdown failure                                             | The keyboard controller or<br>its associated logic has<br>failed.                                                                                                             | Check the keyboard controller.                                                                       |  |
| Time-of-day clock<br>stopped                                 | The Time-of-day clock<br>chip has failed.                                                                                                                                     | Run the SETUP utility.                                                                               |  |
| Time-of-day not set —<br>please run SETUP<br>program         | Clock not set.                                                                                                                                                                | Run the SETUP utility.                                                                               |  |
| Timer chip counter 2 failed                                  | Chip failed.                                                                                                                                                                  | Check the timer chip system board.                                                                   |  |
| Timer or Interrupt con-<br>troller bad                       |                                                                                                                                                                               |                                                                                                      |  |
| Unexpected interrupt in protected mode                       | The nonmaskable interrupt<br>(NMI) port can't be dis-<br>abled.                                                                                                               | Check the system board,<br>particularly the logic associ-<br>ated with the nonmaskable<br>interrupt. |  |

# Model 25 and 30 POST error message table, cont'd

# Model 25 and 30 Error Messages, Continued

## Model 25 and 30 POST Informational Messages

Informational messages require no action but provide valuable information.

| Message                              | Meaning                                                                                                                       |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| xxxK Base Memory                     | The amount of base memory in kilobytes that tested successfully.                                                              |
| xxxK Expanded Memory                 | The amount of expanded memory in kilo-<br>bytes that tested successfully.                                                     |
| xxxK Extended Memory                 | The amount of extended memory in kilobytes that tested successfully.                                                          |
| xxxK Extra Memory                    | The amount of extra memory in kilobytes that tested successfully.                                                             |
| xxxK Standard Memory                 | The amount of standard memory in kilobytes that tested successfully.                                                          |
| Decreasing available memory          | This message immediately follows any mem-<br>ory error messages and indicates that the<br>memory chips are failing.           |
| Memory tests terminated by keystroke | This message indicates that the spacebar<br>was pressed while the memory tests were<br>running, which stops the memory tests. |
| Strike the F1 key to continue        | This message indicates that an error was found during POST. Pressing the F1 key allows the system to reboot.                  |

## Model 25 and 30 Run Time Messages

The Model 25/30 bus may generate error messages if I/O or RAM errors occur. The possible errors are:

| Error Message                                                                      | Suggested Solution |
|------------------------------------------------------------------------------------|--------------------|
| Memory address line failure at <i>hex-value</i> expecting <i>hex-value</i>         | Failed memory chip |
| Memory data line failure at <i>hex-value</i> expecting <i>hex-value</i>            | Failed memory chip |
| Memory double word logic failure at <i>hex-value</i><br>expecting <i>hex-value</i> | Failed memory chip |
| Memory high address line failure at <i>hex-value</i> expecting <i>hex-value</i>    | Failed memory chip |
| Memory odd/even logic failure at <i>hex-value</i> expecting <i>hex-value</i>       | Failed memory chip |
| Memory parity failure at hex-value expecting hex-value                             | Failed memory chip |
| Memory parity error at xxxxx                                                       | Failed memory chip |
| Memory read/write failure at <i>hex-value</i> expecting <i>hex-value</i>           | Failed memory chip |
| hex-value Optional ROM bad checksum = hex-value                                    | I/O card failed    |
| I/O card parity error at xxxx                                                      | I/O card failed    |

# Appendix B Keyboard/Mouse Controller

## Overview

#### Introduction

The overall CBIOS hardware environment is described in Chapter 2. However, because it is so integral to the proper functioning of MCA-based PS/2 computers, the 8042 peripheral controller chip, as well as its accompanying keyboard/mouse control firmware, are discussed in greater detail here.

#### In this appendix

This appendix presents the following information:

- 8042 Hardware
- 8042 Firmware
- 80x86/8042 Device Interface
- System Commands to 8042
- 8042-to-System Replies
- System Commands to Keyboard
- Keyboard Replies to System
- System Commands to the Mouse
- Mouse-to-System Replies

Keyboard/Mouse Controller

## 8042 Hardware

#### Introduction

The Intel 8042 peripheral controller is a single chip microcomputer that can be programmed to allow bidirectional communication between the master microprocessor and up to two auxiliary serial input devices. The 8042 chip is generally mounted on the system motherboard. 8042 programs reside as firmware in the 8042 chip itself.

#### **Device support**

The kind of devices a given 8042 chip supports are dependent on how the 8042 is programmed.

On IBM MCA-compatible systems, the 8042 is programmed to allow bidirectional communication between the system and the keyboard, as well as between the system and one other auxiliary serial device, such as a mouse, joystick, or trackball.

#### 8042 Keyboard/Mouse Controller functions

The 8042-based Keyboard/Mouse Controller in PS/2 MCA-compatible systems supports the following functions:

- Bidirectional keyboard interface
- Key code to 8042 scan code translation
- Keyboard password support
- 8042 keyboard inhibit switch
- Access to processor RESET signal
- Controlling gate A20 signal
- Bidirectional auxiliary device interface
- INT 74h interface to BIOS and auxiliary device driver
- Keyboard and auxiliary device error checking

Note: Here the master processor, i.e. the 80286 or 80386, is referred to as the "system."

#### 8042 microprocessor features

The 8042 peripheral controller chip contains the following features:

| Feature                  | Description                                                                                                                                                                    |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Bus Input Register  | 8-bit write-only register accessed by the system at I/O addresses 064h and 060h.                                                                                               |
| Data Bus Output Register | 8-bit read-only register accessed by the system at I/O address 060h.                                                                                                           |
| Status Register          | 8-bit read-only register accessed by the system at I/O address 064h.                                                                                                           |
| 2KB ROM                  | Contains the 8042 firmware                                                                                                                                                     |
| 256 Bytes RAM            | Locations 20h to 3Fh contain 8042 firmware data defini-<br>tions and can be read and written to by the system.<br>The remaining RAM is reserved as 8042 firmware work<br>area. |
| 8–Bit Timer              | Controls 8042 scan rate. (See "Timing Facts" below)                                                                                                                            |
| 8-Bit Input Port         | Data/Commands received from the keyboard or auxil-<br>iary device are transmitted through the 8042 input port.                                                                 |
| 8-Bit Output Port        | Data/Commands sent from the 8042 to the keyboard or auxiliary device are transmitted from the 8042 output port.                                                                |
| Keyboard Clock Input Pin | Clock Input for keyboard.                                                                                                                                                      |
| Aux. Device Input Pin    | Clock Input for auxiliary device.                                                                                                                                              |

#### 8042 timing facts

The 8042 operates at a crystal frequency of 10 MHz. This gives a minimum count for the timer of 50 microseconds. When the 8042's 8-bit timer is started, it will increment to its maximum count (FFh), overflow to zero and continue to count. Incrementing from maximum to zero (overflow) sets the 8042 timer flag and generates an interrupt request to the 8042.

**Note:** Operating 8042 chips at a crystal rate other than 10 MHz may cause incompatibility problems.

#### 8042 Status Register definition

The 8042 Status register is an 8-bit read-only register that is accessed by the system at I/O address 064h. The values of the Input Buffer Flag, Output Buffer Flag, Auxiliary Output Buffer Flag, and Command/Data Flag help coordinate the bidirectional transfer of information between the 8042 and the system.

#### Status Register bit definitions

The bit definitions of the status register are as follows:

| Bit # | Definition                                                                                                                                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7 | PARITY ERROR.<br>When this bit is a 1, it indicates that the last byte received from the key-<br>board or auxiliary device had the incorrect parity.                                                                                        |
| Bit 6 | GENERAL TIME-OUT.<br>When this bit is a 1, it indicates that a time-out has occurred during the<br>transmission of data between the 8042 and the keyboard or the auxiliary<br>device.                                                       |
| Bit 5 | AUXILIARY DEVICE OUTPUT BUFFER FULL.<br>When this bit is a 1, data received from the auxiliary device is present in the output buffer.                                                                                                      |
| Bit 4 | INHIBIT SWITCH.<br>Since there is no inhibit switch in the PS/2, this bit must be a 1, to indicate<br>that the keyboard is not inhibited.                                                                                                   |
| Bit 3 | COMMAND/DATA (F1).<br>When this bit is a 1, the byte in the input buffer is a command for the<br>8042. When this bit is a 0, the byte in the input buffer is either a data byte<br>for the 8042 or a command or data byte for the keyboard. |
| Bit 2 | SYSTEM FLAG (F0).<br>The 8042 replicates this bit from the system bit in the command byte.                                                                                                                                                  |
| Bit 1 | INPUT BUFFER FULL.<br>When this bit is a 1, a byte is present in the input buffer.                                                                                                                                                          |
| Bit 0 | OUTPUT BUFFER FULL.<br>When this bit is a 1, a byte is present in the output buffer.                                                                                                                                                        |

# 8042 Hardware, Continued

## I/O Port definitions

The table below lists the bit definitions of the 8042 Input Port, Output Port, and Test Inputs.

| Port   | Bit Definition                                                                                                                                                                                                                                                   |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input  | Bit 0 = Keyboard data input<br>Bit 1 = Auxiliary device data input<br>Bit 2 = Undefined<br>Bit 3 = Fuse status of +5V dc line<br>0 = Fuse is open<br>1 = Fuse is closed<br>Bit 4 = Undefined<br>Bit 5 = Undefined<br>Bit 6 = Undefined<br>Bit 7 = Undefined      |
| Output | Bit 0 = System reset<br>Bit 1 = Gate A20<br>Bit 2 = Auxiliary device data output<br>Bit 3 = Auxiliary device clock output<br>Bit 4 = Output buffer full<br>Bit 5 = Auxiliary output buffer full<br>Bit 6 = Keyboard clock output<br>Bit 7 = Keyboard data output |
| Test   | T0 = Keyboard clock input<br>T1 = Auxiliary device clock input                                                                                                                                                                                                   |

## 8042 Firmware

#### Description

On MCA-based, IBM PS/2 and compatible systems, the 8042 peripheral controller is programmed with firmware that supports the keyboard and one auxiliary device, usually a mouse.

The 8042 firmware:

- processes commands received by the 8042 from the system,
- passes through those commands intended for the keyboard or the auxiliary device,
- coordinates input from both the keyboard and the auxiliary device,
- outputs keyboard or auxiliary device data to the data bus,
- pulses IRQ 1 to initiate INT 09h, the CBIOS Keyboard Service ISR, and
- pulses IRQ 12 to initiate INT 74h, the Auxiliary Device ISR.

#### Phoenix scan code support

IBM-compatible keyboards that are attached to MCA-based PS/2 systems generate IBM keyboard scan code set 2, as defined in Chapter 8. Phoenix's 8042 firmware supports keyboard scan code set 2 only.

## 8042 firmware data definitions

The 8042 Peripheral Controller chip contains 256 bytes of internal RAM. Firmware for the 8042 has the ability to read/write to 8042 RAM locations 020h to 03Fh. The 8042 firmware data is defined in the table below.

| Location | Initial Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20h      | 30h           | Command byte<br>The command byte is a byte that is stored in the<br>8042 at RAM location 20h. It contains 8 flag bits<br>that are used by the program. The command byte<br>can be written or read by the system. The bit defi-<br>nition of the command byte is as follows:<br>Bit 7 = Reserved, must be 0.<br>Bit 6 = IBM PC Compatibility Mode. When this bit is<br>a 1, the 8042 translates the scan codes re-<br>ceived from the keyboard to those used by<br>the IBM PC. When this bit is a 0, the 8042<br>passes the scan codes to the system with-<br>out translation.<br>Bit 5 = Disable Auxiliary Device. When this bit is a<br>1, the 8042 disables the auxiliary device by<br>setting the auxiliary device clock line low.<br>Bit 4 = Disable Keyboard. When this bit is a 1, the<br>8042 disables the keyboard by setting the<br>keyboard clock line low.<br>Bit 3 = Reserved |
|          |               | <ul> <li>Bit 2 = System Flag. The value of this bit is written to the system flag bit (F0) of the status register.</li> <li>Bit 1 = Enable Auxillary Output Buffer Full Interrupt. When this bit is a 1, the 8042 generates an interrupt to the system by setting the Auxiliary OBF port bit (output port 2, bit 5) high, when it places a byte in the 8042 output buffer.</li> <li>Bit 0 = Enable Output Buffer Full Interrupt. When this bit is a 1, the 8042 generates an interrupt to the system by setting the OBF port bit (output port 2, bit 4) high, when it places a byte in the 8042 generates an interrupt to the system by setting the OBF port bit (output port 2, bit 4) high, when it places a byte in the 8042 output buffer.</li> </ul>                                                                                                                                 |
| 21h      | 01h           | Number of times 8042 will send Resend command to device, if data received with error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 22h      | 0Bh           | If not 0, device is read for a response to a trans-<br>mission.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23h      | 00h           | Running count of number of Resends sent to key-<br>board since power-up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25h      | 02h           | Initialized, but never used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Location                                                                                                                                                              | Initial Value | Description                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------|
| 27h                                                                                                                                                                   | F8h           | Timer value.                                                                                     |
| 28h                                                                                                                                                                   | CEh           | Timer value.                                                                                     |
| 29h                                                                                                                                                                   | 0Bh           | Initialized, but never used.                                                                     |
| 2Ah                                                                                                                                                                   | 10h           | Initialized, but never used.                                                                     |
| 2Ch                                                                                                                                                                   | 15h           | Initialized, but never used.                                                                     |
| 2Dh                                                                                                                                                                   | 00h           | = 80h when break code (F0h) received from<br>keyboard<br>= 00h after adding 80h to key scan code |
| 30h                                                                                                                                                                   | 0Bh           | If not 0, device is read for a response to a trans-<br>mission.                                  |
| 31h                                                                                                                                                                   | 00h           | Running count of number of Resends sent to auxi<br>iary device since power-up.                   |
| 33h                                                                                                                                                                   | 00h           | Code for null (FFh).                                                                             |
| 34h                                                                                                                                                                   | 00h           | Code for null (FFh).                                                                             |
| 36h                                                                                                                                                                   | 00h           | Code for left shift (2Ah).                                                                       |
| 37h                                                                                                                                                                   | 00h           | Code for right shift (36h).                                                                      |
| Note: The initial values shown here are set by the 8042 firmware initialization at run time. They may be changed by the CBIOS POST or other routines at a later time. |               |                                                                                                  |

#### 8042 firmware data definitions, cont'd

# 80x86/8042 Device Interface

#### Introduction

The figure below illustrates the relationship between the system, the 8042 peripheral controller chip, the keyboard, and the auxiliary device.





# System Commands to 8042

## Introduction

Commands from the system to the 8042 are written to the Data Bus Input Register, an 8-bit write-only register that is accessed by the system at I/O addresses 064h. If an accompanying data byte is expected, the system must then write the data byte to I/O address 060h.

#### 8042 commands

All 8042 commands are shown in the following table.

| Command   | Description                                                                                                                                                                                                                                                                                                                                         |  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 20h       | READ THE 8042 COMMAND BYTE.<br>Instructs the 8042 to send the contents of location 20h, the com-<br>mand byte, to the system.                                                                                                                                                                                                                       |  |
| 21h – 3Fh | READ THE 8042 RAM.<br>Instructs the 8042 to send the contents of the RAM location, defined<br>by bits 5-0 of the command, to the system.                                                                                                                                                                                                            |  |
| 60h       | WRITE THE 8042 COMMAND BYTE.<br>Instructs the 8042 to write the data byte following the command to<br>the location of the command byte (20h).                                                                                                                                                                                                       |  |
| 61h – 7Fh | WRITE THE 8042 RAM.<br>Instructs the 8042 to write the data byte following the command to<br>the RAM location defined by bits 0-5 of the command.                                                                                                                                                                                                   |  |
| A4h       | TEST PASSWORD INSTALLED.<br>Instructs the 8042 to check whether there is a password currently<br>installed. If there is no password, the contents of the first location<br>where the password would be stored will be zero. If there is a pass-<br>word installed, FAh is placed in the 8042 output buffer, if not, F1h is<br>placed in the buffer. |  |
| A5h       | LOAD SECURITY.<br>Instructs the 8042 to read password data from the 8042 input buffer<br>and store it until a null (0) is detected. The null is stored as the last<br>byte of the password.                                                                                                                                                         |  |
| A6h       | ENABLE SECURITY.<br>Instructs the 8042 to check the installed password against the in-<br>coming keystrokes for a match.                                                                                                                                                                                                                            |  |
| A7h       | DISABLE AUXILIARY DEVICE INTERFACE.<br>Instructs the 8042 to set bit 5 of the command byte. This disables<br>the auxiliary device by driving the auxiliary clock low.                                                                                                                                                                               |  |
|           | Note: The 8042 firmware will ignore any commands written to port 064h other than those listed.                                                                                                                                                                                                                                                      |  |

# 8042 commands, cont'd

| Command                                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A8h                                                                                            | ENABLE AUXILIARY DEVICE INTERFACE.<br>Instructs the 8042 to clear bit 5 of the command byte. This enables<br>the auxiliary device by driving the auxiliary clock high.                                                                                                                                                                                                                                                                             |
| A9h                                                                                            | AUXILIARY INTERFACE TEST.<br>Instructs the 8042 to test the auxiliary device clock and data lines.<br>The result of the test is placed in the output buffer as follows:<br>00 — No error detected.<br>01 — Auxiliary device clock line is stuck low.<br>02 — Auxiliary device clock line is stuck high.<br>03 — Auxiliary device data line is stuck low.<br>04 — Auxiliary device data line is stuck high.                                         |
| AAh                                                                                            | SELF TEST.<br>Instructs the keyboard 8042 to perform internal diagnostics tests. A<br>55h is placed in the output buffer if no errors are detected.                                                                                                                                                                                                                                                                                                |
| ABh                                                                                            | <ul> <li>KEYBOARD INTERFACE TEST.</li> <li>Instructs the 8042 to test the keyboard clock and data lines. The result of the test is placed in the output buffer as follows:</li> <li>00 — No error detected.</li> <li>01 — Keyboard device clock line is stuck low.</li> <li>02 — Keyboard device clock line is stuck high.</li> <li>03 — Keyboard device data line is stuck low.</li> <li>04 — Keyboard device data line is stuck high.</li> </ul> |
| ACh                                                                                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ADh                                                                                            | DISABLE KEYBOARD INTERFACE.<br>Instructs the 8042 to set bit 4 of the command byte. This disables<br>the keyboard by driving the keyboard clock low.                                                                                                                                                                                                                                                                                               |
| AEh                                                                                            | ENABLE KEYBOARD INTERFACE,<br>Instructs the 8042 to clear bit 4 of the command byte. This enables<br>the keyboard by driving the keyboard clock line high.                                                                                                                                                                                                                                                                                         |
| C0h                                                                                            | READ INPUT PORT.<br>Instructs the 8042 to read the 8042 input port (port 1) and place the<br>data in the 8042 output buffer.                                                                                                                                                                                                                                                                                                                       |
| C1h                                                                                            | POLL INPUT PORT LOW.<br>Instructs the 8042 to continuously read input port 1 bits 0-3 into the<br>status register, bits 4-7, until IBF goes high, when the next com-<br>mand is executed.                                                                                                                                                                                                                                                          |
| Note: The 8042 firmware will ignore any commands written to port 064h other than those listed. |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

# System Commands to 8042, Continued

## 8042 commands, cont'd

| Command                                                                                        | Description                                                                                                                                                                                                                                     |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C2h                                                                                            | POLL INPUT PORT HIGH.<br>Instructs the 8042 to continuously read input port 1 bits 4-7 into the<br>status register, bits 4-7, until IBF goes high, when the next com-<br>mand is executed.                                                      |
| D0h                                                                                            | READ OUTPUT PORT.<br>Instructs the 8042 to read the 8042 output port (port 2) and place<br>the data in the 8042 output buffer.                                                                                                                  |
| D1h                                                                                            | WRITE OUTPUT PORT.<br>Instructs the 8042 that the next byte of data received should be sent<br>to the 8042 output port.                                                                                                                         |
| D2h                                                                                            | WRITE KEYBOARD OUTPUT BUFFER.<br>Instructs the 8042 that the next byte of data received should be sent<br>to the output buffer. The controller will generate an interrupt to the<br>system if the interrupt bit is enabled in the command byte. |
| D3h                                                                                            | WRITE AUXILIARY DEVICE OUTPUT BUFFER.<br>Instructs the 8042 that the next byte of data received should be sent<br>to the output buffer. The 8042 generates an interrupt to the system<br>if the interrupt bit is enabled in the command byte.   |
| D4h                                                                                            | WRITE TO AUXILIARY DEVICE.<br>Instructs the 8042 that the next byte of data received should be<br>transmitted to the auxiliary device.                                                                                                          |
| E0h                                                                                            | READ TEST INPUTS.<br>Instructs the 8042 to read the 8042 T0 and T1 inputs and place them<br>in the output buffer. Bit 0 represents T0 and bit 1 represents T1.                                                                                  |
| F0 – FF                                                                                        | PULSE OUTPUT PORT.<br>Instructs the 8042 to pulse bits 0-3 of the output port (port 2) low<br>for 6 microseconds. Bits 0 through 3 of the command indicate the<br>bits to be pulsed.                                                            |
|                                                                                                | If the bit is a 0 then the corresponding bit on port 2 should be pulsed. If the bit is a 1 then the corresponding bit should not be pulsed.                                                                                                     |
| Note: The 8042 firmware will ignore any commands written to port 064h other than those listed. |                                                                                                                                                                                                                                                 |

# 8042-to-System Replies

## **Command list**

There are four 8042-to-system replies.

| Command | Description                                   |
|---------|-----------------------------------------------|
| F1h     | NO PASSWORD INSTALLED.                        |
| FAh     | PASSWORD INSTALLED.                           |
| FEh     | RESEND COMMAND.                               |
| 55h     | NO ERROR DETECTED ON 8042 FIRMWARE SELF-TEST. |

# System Commands to Keyboard

## Introduction

Commands passed from the system directly to the keyboard are written to I/O address 0060h. The value of the Status Register's Command/Data Flag must be 0.

#### Command list

| Command | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EDh     | SET/RESET LED TOGGLE STATUS INDICATORS.The Num Lock, Caps Lock, and Scroll Lock LED indicators can beturned on or off by a command from the system. The EDh com-mand byte is written to port 060h and the keyboard responds withFAh (ACK). The system then writes the option byte to port 60h.A value of 1 means turn the LED on. The option byte takes the for-mat below:Bit Description7-3Reserved (must be 00000b)2Caps Lock LED1Num Lock LED0Scroll Lock LED |
| EEh     | ECHO.<br>The system uses this command to test the keyboard. The keyboard<br>issues an EEh (Echo) in reply to this command.                                                                                                                                                                                                                                                                                                                                       |
| EFh     | INVALID COMMAND.<br>The keyboard does not acknowledge this command.                                                                                                                                                                                                                                                                                                                                                                                              |
| F0h     | CHOOSE ALTERNATE SCAN CODE SET.<br>The 8042 APCF supports scan code set 2 only.                                                                                                                                                                                                                                                                                                                                                                                  |
| F1h     | INVALID COMMAND.<br>The keyboard does not acknowledge this command                                                                                                                                                                                                                                                                                                                                                                                               |
| F2h     | READ KEYBOARD ID BYTES.<br>The keyboard acknowledges the command and sends the two key-<br>board ID bytes.                                                                                                                                                                                                                                                                                                                                                       |
| F3h     | SET TYPEMATIC REPEAT RATE AND DELAY PERIOD.<br>The system may set typematic rate and delay.                                                                                                                                                                                                                                                                                                                                                                      |
| F4h     | ENABLE.<br>Commands the keyboard to clear its output buffer and begin scanning.                                                                                                                                                                                                                                                                                                                                                                                  |
| F5h     | DEFAULT DISABLE.<br>Resets all conditions within the keyboard to their power-on default<br>state and disables scanning. The keyboard responds with ACK,<br>clears its output buffers, and waits for the next instruction from the<br>system.                                                                                                                                                                                                                     |

# System Commands to Keyboard, Continued

# Command list, cont'd

| Command   | Description                                                                                                                                                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F6h       | SET DEFAULT<br>Resets all conditions within the keyboard to their power-on default<br>state and enables scanning. The keyboard responds with ACK and<br>clears all output buffers. |
| F7h – FDh | RESERVED                                                                                                                                                                           |
| FEh       | RESEND.<br>If the system detects an error in transmission, it issues the resend<br>command. The keyboard responds by sending the previous output.                                  |
| FFh       | RESET.<br>System issues this command to invoke the keyboard's internal self<br>test.                                                                                               |

# Keyboard Replies to System

## Introduction

Replies from the keyboard to the system are read by the system at port 060h. The keyboard to system replies are listed in the table below.

# **Reply list**

| Reply                      | Description                                                                                                                                                                                                                                                |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h<br>(Code Sets 2 and 3) | OVERRUN CHARACTER<br>When the keyboard exceeds its buffer capacity, it places 00h<br>(the overrun character) into the bottom of the keyboard<br>buffer. When the overrun character reaches the top of the<br>buffer, the keyboard sends it to the system.  |
| 83ABh                      | KEYBOARD ID<br>The two-byte keyboard ID is defined as 83ABh. The keyboard<br>replies to the keyboard ID command with ACK, then sends the<br>low ID byte followed by the high ID byte.                                                                      |
| AAh                        | BAT COMPLETION CODE<br>At power-on-reset the keyboard logic initiates a keyboard Ba-<br>sic Assurance Test (BAT). If the BAT was successful, then<br>the keyboard replies with AAh, the BAT Completion Code.                                               |
| FCh                        | BAT FAILURE CODE<br>When the BAT is not completed successfully, the keyboard<br>responds with FCh, the BAT Failure Code. The keyboard will<br>then discontinue scanning, and it will wait for a Reset com-<br>mand or some other response from the system. |
| EEh                        | ECHO<br>This is the keyboard's reply to EEh, the system-to-keyboard<br>echo command.                                                                                                                                                                       |
| FAh                        | ACKNOWLEDGE (ACK)<br>Keyboard reply to any valid system command other than Echo<br>or Resend. The keyboard will discard ACK if it receives an-<br>other system command while it is attempting to reply with<br>ACK.                                        |
| FEh                        | RESEND<br>Keyboard receipt of invalid input or input with incorrect parity<br>causes the keyboard to issue FEh, the Resend command.                                                                                                                        |
| FF<br>(Code Set 1)         | OVERRUN CHARACTER<br>When the keyboard exceeds its buffer capacity, it places 00h<br>(the overrun character) into the bottom of the keyboard<br>buffer. When the overrun character reaches the top of the<br>buffer, the keyboard sends it to the system.  |

#### Introduction

The command D4h, Write to Auxiliary Device, tells the 8042 firmware to transmit the next byte it receives to the auxiliary device. All commands written to the mouse must therefore be written according to the process described below:

- 1. D4h, Write to Auxiliary Device, must be written to port 064h.
- 2. nnh, the system-to-mouse command, must be written to port 060h.
- **Note:** Unless it receives D4h in port 064h first, the 8042 firmware will pass all commands written to port 060h directly to the keyboard.

#### **Command list**

| Command | Description                                                                                                                                                                                                                                                                                           |                                                                         |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| E6h     | RESET SCALING<br>Resets scaling 1:1                                                                                                                                                                                                                                                                   |                                                                         |
| E7h     | SET SCALING 2:1<br>This command can only be used when the mouse is in Stream<br>Mode. In Stream Mode, the current X/Y coordinate values are<br>converted to new values each time the sample period expires. In<br>2:1 scaling, the relationship between the input and output values<br>is as follows: |                                                                         |
|         | Input                                                                                                                                                                                                                                                                                                 | Output                                                                  |
|         | 0<br>1<br>2<br>3<br>4<br>5<br>N (>=6)                                                                                                                                                                                                                                                                 | 0<br>1<br>3<br>6<br>9<br>2.0 x N                                        |
| E8h     | SET RESOLUTION<br>This is a two-byte command. The second byte written to port<br>060h is interpreted as a resolution in counts per mm. There are<br>four possible resolutions. The relationship between second byte<br>and resolution is listed below:                                                |                                                                         |
|         | Byte                                                                                                                                                                                                                                                                                                  | Resolution                                                              |
|         | 00h<br>01h<br>02h<br>03h                                                                                                                                                                                                                                                                              | 1 count per mm<br>2 counts per mm<br>4 counts per mm<br>8 counts per mm |

# System Commands to the Mouse, Continued

## Command list, cont'd

| Command | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| E9h     | STATUS REQUEST<br>This command elicits a 3-byte mouse status report. The format<br>of the mouse status report is shown below:                                                                                                                                                                                                                                                                                                                                                             |  |
|         | Byte 3 = Sampling Rate, where:                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|         | Bit 7 = Most significant bit<br>Bit 0 = Least significant bit                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|         | Byte 2 = Resolution, where:                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|         | Bit 7 = Most significant bit<br>Bit 0 = Least significant bit                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|         | Byte 1 = Mouse Status, where:                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|         | Bit 7 = Reserved<br>Bit 6 = 0 Stream mode                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|         | = 1 Remote mode<br>Bit 5 = 0 Disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|         | = 1 Enabled<br>Bit 4 = 0 Scaling 1:1                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|         | = 1 Scaling 2:1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|         | Bit 3 = Reserved<br>Bit 2 = 1 Left mouse button pressed                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|         | Bit 1 = Reserved<br>Bit 0 = 1 Right mouse button pressed                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| EAh     | SET STREAM MODE<br>In Stream mode, the mouse transmits data to the system each<br>time a mouse button is pressed or released, or each time the<br>mouse detects a unit of movement. The mouse data sample rate<br>determines the maximum number of times per second mouse<br>data can be transmitted to the system. If no button is pressed<br>or if the mouse is not moved, then no data is transmitted to the<br>system. The Set Stream Mode command turns the mouse stream<br>mode on. |  |
| EBh     | READ DATA<br>The Read Data command forces the transmission of one mouse<br>data packet. The Read Data command is valid in both stream<br>mode and in remote mode.                                                                                                                                                                                                                                                                                                                         |  |
| ECh     | RESET WRAP MODE<br>This command resets the mouse to normal operation.                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| EEh     | SET WRAP MODE<br>This command sets wrap mode, the mouse "echo" mode. With<br>the exception of ECh, Reset Wrap Mode, and FFh, Reset Mouse,<br>the mouse will echo back all data and commands received from<br>the system.                                                                                                                                                                                                                                                                  |  |

# System Commands to the Mouse, Continued

# Command list, cont'd

| Command | Description                                                                                                                                                                                                                                                                                                                                       |                                                                                                                 |  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|
| F0h     | SET REMOTE MODE<br>In Remote mode, the mouse data can only be transmitted in reply<br>to a Read Data command.                                                                                                                                                                                                                                     |                                                                                                                 |  |
| F2h     | READ DEVICE TYPE<br>The mouse ID byte is 00h. The mouse returns 00h in reply to the<br>Read Device Command.                                                                                                                                                                                                                                       |                                                                                                                 |  |
| F3h     | SET SAMPLING RATE<br>Sampling Rate is defined as the number of times per second the<br>system checks for mouse data. This is a two-byte command.<br>F3h, the Set Sampling Rate command, must be followed by a sec-<br>ond byte, representing the hex value of the sample rate. The val-<br>ues listed below are allowable sample rates.           |                                                                                                                 |  |
|         | Hex Value (2nd Byte)                                                                                                                                                                                                                                                                                                                              | Sample Rate                                                                                                     |  |
|         | 0Ah<br>14h<br>28h<br>3Ch<br>50h<br>64h<br>C8h                                                                                                                                                                                                                                                                                                     | 10/second<br>20/second<br>40/second<br>60/second<br>80/second<br>100/second<br>200/second                       |  |
| F4h     |                                                                                                                                                                                                                                                                                                                                                   | ENABLE<br>Enables data transmissions if the mouse has been set to stream<br>mode. Has no effect in remote mode. |  |
| F5h     |                                                                                                                                                                                                                                                                                                                                                   | DISABLE<br>Disables mouse data transmissions if the mouse is in stream<br>mode. Has no effect in remote mode.   |  |
| F6h     | SET DEFAULT         The Set Default command reinitializes the mouse to its power-on default state. The mouse power-on default state is as follows:         Sampling Rate       = 100/second         Scaling       = Linear Scaling         Mode       = Stream mode         Resolution       = 4 counts/mm         Transmissions       = Disabled |                                                                                                                 |  |
| FEh     | RESEND<br>Errors in transmissions from the mouse cause the system to send<br>the Resend command. The mouse responds by retransmitting its<br>last data packet.                                                                                                                                                                                    |                                                                                                                 |  |
| FFh     | RESET<br>Reset mode instructs the mouse to run its internal self test rou-<br>tine. This command puts the mouse into reset mode.                                                                                                                                                                                                                  |                                                                                                                 |  |

## Mouse-to-System Replies

## **Reply list**

There are only two mouse-to-system replies. Both replies are related to command processing and are read by the system at port 060h.

| Reply | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FAh   | ACK (Acknowledge)<br>The mouse replies with FAh, ACK, anytime it receives a valid<br>command from the system. Unlike mouse serial data packets, the<br>ACK reply is not stored in a buffer in internal memory, but is dis-<br>carded immediately after it is transmitted. If a new command is<br>received while the mouse is in the ACK reply process, the mouse<br>discards the ACK reply and begins processing the new command<br>immediately. |
|       | Note: The commands ECh, Reset Wrap Mode, and FFh, Reset,<br>are exceptions to mouse ACK behavior. The mouse does<br>not respond with ACK to either of these commands.                                                                                                                                                                                                                                                                            |
| FEh   | RESEND<br>The mouse replies with FEh, Resend, anytime it receives an inva-<br>lid command from the system. Two invalid commands in<br>succession cause the mouse to send the error code FCh to the<br>system. A single, isolated invalid command, however, does not<br>affect mouse processing in any way. The mouse simply ignores<br>single invalid commands, maintaining its present operational state.                                       |

## Appendix C

# Hardware Environment for 8086–Based Systems

## Overview

#### In this appendix

This appendix describes the hardware environment needed to implement the ROM BIOS on PS/2 systems (e.g. IBM Models 25 and 30) and compatibles based on the 8086 microprocessor. These systems are not MCA-compatible.

The following topics are discussed:

- Hardware Address Locations
- Microprocessor
- 8087 Math Coprocessor
- System Support Gate Array
- I/O Support Gate Array
- System Time-Related Logic
- Interrupt Controller Extensions
- System Timer
- DMA Controller
- 8259 Programmable Interrupt Controller
- Miscellaneous Additional Logic

Hardware Environment for 8086-Based Systems

## Hardware Address Locations

## Table: Hardware I/O Port Definitions

The following table gives the locations of the various  $\ensuremath{\text{I/O}}$  ports and their functions.

**Note:** An *x* before a bit setting description indicates that this bit setting has no meaning when the condition stated after the *x* is true.

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000h       | R/W                  | DMA channel 0, memory address register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0001h       | R/W                  | DMA channel 0, transfer count register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0002h       | R/W                  | DMA channel 1, memory address register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0003h       | R/W                  | DMA channel 1, transfer count register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0004h       | R/W                  | DMA channel 2, memory address register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0005h       | R/W                  | DMA channel 2, transfer count register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0006h       | R/W                  | DMA channel 3, memory address register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0007h       | R/W                  | DMA channel 3, transfer count register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0008h       | R                    | DMA channel 0-3, status register, where:Bit 7= 1 Channel 3 requestBit 6= 1 Channel 2 requestBit 5= 1 Channel 1 requestBit 4= 1 Channel 0 requestBit 3= 1 Terminal count on channel 3Bit 2= 1 Terminal count on channel 2Bit 1= 1 Terminal count on channel 1Bit 0= 1 Terminal count on channel 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0008h       | W                    | DMA write command, where:         Bit 7       = 0       DACK sense active low         = 1       DACK sense active high         Bit 6       = 0       DREQ sense active high         Bit 6       = 0       DREQ sense active high         Bit 5       = 0       Late write selection         = 1       Extended timing         = 1       Rotating priority         Bit 3       = 0         = 1       Compressed timing         = 1       Compressed timing         = x       Bit 0 is one         Bit 2       = 0         Bit 2       = 0         = 0       Disable controller         = 1       Disable channel 0 address hold         = 1       Enable channel 0 address hold         = 1       Bit 0 is zero         Bit 0       = 0         Bit 0       = 0         Disable memory to memory         = 1       Enable memory to memory |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0009h       | W                    | DMA request register, where:<br>Bits 7-3 = x Reserved<br>Bit 2 = 0 Reset request bit<br>= 1 Set request bit<br>Bits 1-0 = 00b Select channel 0<br>= 01b Select channel 1<br>= 10b Select channel 2<br>= 11b Select channel 3                                                                                                                                                                                                                                                                                                                         |
| 000Ah       | R/W                  | DMA single mask register, where:<br>Bits 7-3= x Reserved<br>Bit 2 = 0 Clear mask bit<br>Bits 1-0= 00b Select channel 0 mask bit<br>= 01b Select channel 1 mask bit<br>= 10b Select channel 2 mask bit<br>= 11b Select channel 3 mask bit                                                                                                                                                                                                                                                                                                             |
| 000Bh       | W                    | DMA mode register, where:<br>Bits 7-6= 00b Demand mode select<br>= 01b Single mode select<br>= 10b Block mode select<br>= 11b Cascade mode select<br>Bit 5 = 0 Address increment select<br>= 1 Address decrement select<br>Bit 4 = 0 Disable auto initialization<br>= 1 Enable auto initialization<br>Bits 3-2= 00b Verify transfer<br>= 01b Write transfer<br>= 10b Read transfer<br>= 11b Illegal value<br>= xx if Bits 7 and 6 on<br>Bits 1-0= 00b Select channel 0<br>= 01b Select channel 1<br>= 10b Select channel 2<br>= 11b Select channel 3 |
| 000Ch       | w                    | DMA clear byte pointer. Sets a low byte/high byte<br>flip-flop for the dual read/write ports to a known<br>state, where the next access will be to the low<br>byte register.                                                                                                                                                                                                                                                                                                                                                                         |
| 000Dh       | R                    | DMA read temporary register. Holds data during memory-to-memory transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 000Dh       | w                    | DMA master clear (Resets the 8237. The com-<br>mand, status, request, temporary, and internal<br>first/last flip-flop registers are cleared, and the<br>mask register is set. The 8237 is in the idle<br>state).                                                                                                                                                                                                                                                                                                                                     |
| 000Eh       | w                    | DMA clear mask register (Clears all four channel<br>masks so they can accept DMA requests)                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| I/O Address   | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000Fh         | W                    | DMA write all mask register bits, where:Bits 7-4= xBits 7=0Clear channel 0 mask bit= 1Set channel 0 mask bitBit 2= 0Clear channel 1 mask bit= 1Set channel 1 mask bitBit 1= 0Clear channel 2 mask bit= 1Set channel 2 mask bit= 1Set channel 3 mask bit= 1Set channel 3 mask bit                                                                                                                                                                                                                  |
| 0010h – 001Fh |                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0020h         | R                    | PIC Interrupt request/In-service registers pro-<br>grammed by Operation Command Word 3 (OCW3):                                                                                                                                                                                                                                                                                                                                                                                                    |
|               |                      | Interrupt request register, where:<br>Bits 7-0= 0 No active request for the correspon-<br>ing interrupt line<br>= 1 Active request for the corresponding<br>interrupt line                                                                                                                                                                                                                                                                                                                        |
|               |                      | Interrupt in-service register, where:<br>Bits 7-0= 0 The corresponding interrupt line is not<br>currently being serviced<br>= 1 The corresponding interrupt line is<br>currently being serviced                                                                                                                                                                                                                                                                                                   |
| 0020h         | W                    | PIC Initialization Command Word 1 (ICW1) (Bit 4 is one), where:         Bits 7-5= 000 Only used in 80/85 mode         Bit 4 = 1 Reserved         Bit 3 = 0 Edge triggered mode         = 1 Level triggered mode         Bit 2 = 0 Successive interrupt vectors are separated by eight bytes         = 1 Successive interrupt vectors are separated by four bytes         Bit 1 = 0 Cascade mode         = 1 Single mode – no ICW3 needed         Bit 0 = 0 No ICW4 needed         = 1 ICW4 needed |
| 0021h         | W                    | <ul> <li>PIC ICW2, ICW3, or ICW4 in sequential order after<br/>ICW1 written to Port 0020h</li> <li>ICW2, where:</li> <li>Bits 7-3 = Address lines A0-A3 of base vector<br/>address for interrupt controller</li> <li>Bits 2-0 = 000 Reserved</li> </ul>                                                                                                                                                                                                                                           |

| I/O Address       | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0021h<br>(cont'd) |                      | PIC ICW3, where:<br>Bits 7-0= 0 Slave controller not attached to<br>corresponding interrupt pin<br>= 0 Slave controller attached to<br>corresponding interrupt pin                                                                                                                                                                                                                                                                                         |
|                   |                      | ICW4, where:<br>Bits 7-5= 000 Reserved<br>Bit 4 = 0 No special fully-nested mode<br>= 1 Special fully-nested mode<br>Bits 3-2= 00 Nonbuffered mode<br>= 01 Nonbuffered mode<br>= 10 Buffered mode/slave<br>= 11 Buffered mode/master<br>Bit 1 = 0 Normal EOI<br>= 1 Auto EOI<br>Bit 0 = 0 80/85 mode<br>= 1 8086/8088 mode                                                                                                                                 |
| 0021h             | R/W                  | PIC Interrupt mask register (OCW1), where:Bit 7= 0Enable parallel printer interruptBit 6= 0Enable diskette interruptBit 5= 0Enable fixed disk interruptBit 4= 0Enable serial interruptBit 3= 0ReservedBit 2= 0Enable video interruptBit 1= 0Enable keyboard/pointing device/RTCInterruptInterruptBit 0= 0Enable timer interrupt                                                                                                                            |
| 0021h             | W                    | PIC OCW2 (Bit 4 is zero, Bit 3 is zero), where:<br>Bits 7-5 = 000 Rotate in automatic EOI mode<br>(clear)<br>= 001 Nonspecific EOI<br>= 010 No operation<br>= 011 Specific EOI<br>= 100 Rotate in automatic EOI mode (set)<br>= 101 Rotate on nonspecific EOI<br>command<br>= 110 Set priority command<br>= 111 Rotate on specific EOI command<br>Bit 4 = 0 Reserved<br>Bit 3 = 0 Reserved<br>Bits 2-0 = Interrupt request to which the command<br>applies |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0020h       | W                    | PIC OCW3 (Bit 4 is zero, Bit 3 is one), where:<br>Bit 7 = 0 Reserved<br>Bits 6-5= 00 No operation<br>= 01 No operation<br>= 10 Reset special mask<br>= 11 Set special mask<br>Bit 4 = 0 Reserved<br>Bit 3 = 1 Reserved<br>Bit 2 = 0 No poll command<br>= 1 Poll command<br>Bits 1-0= 00 No operation<br>= 01 No operation<br>= 10 Read interrupt request register on<br>next read at Port 0020h<br>= 11 Read interrupt in-service register on<br>next read at Port 0020h                                                     |
| 0024h-003Fh |                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0040h       | R/W                  | System timer counter 0 (Current 16-bit count for timer 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0041h       | R/W                  | System timer counter 1 (Current 16-bit count for timer 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0042h       | R/W                  | System timer counter 2 (Current 16-bit count for timer 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0043h       | W                    | System timer control register, where:Bits 7-6 = 00 Select counter 0= 01 Select counter 1= 10 Select counter 1= 10 Select counter 2= 11 IllegalBits 5-4 = 00 Counter latching operation= 01 Read/load least significant byte only= 10 Read/load most significant byte only= 11 Read/load least significant byte,<br>then most significant byte,<br>then most significant byteBits 3-1 = 000 Mode 0= 001 Mode 1= x10 Mode 2= x11 Mode 3= 100 Mode 4= 101 Mode 5Bit 0 = 0 Binary counter (16 bits)= 1 BCD counter (four digits) |
| 0044h-005Fh |                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0060h       | R                    | Keyboard/Pointing device output buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0061h       | W                    | System control port, where:<br>Bit 7 = x Reserved<br>Bit 6 = x Reserved<br>Bit 5 = 0 Enable I/O channel check<br>Bit 4 = 0 Enable RAM parity check<br>Bit 3 = x Reserved<br>Bit 2 = x Reserved<br>Bit 1 = x Beeper data<br>Bit 0 = 1 Enable timer 2 gate to speaker                                                                                                                                                                                                                                                                                      |
| 0062h       | R                    | System board status, where:Bit 7= 1Bit 6= 1I/O channel check activeBit 5= xTimer 2 output statusBit 4= xReservedBit 3= xReservedBit 4= 0Disk installedBit 1= 1Coprocessor installedBit 0= xReserved                                                                                                                                                                                                                                                                                                                                                      |
| 0063h       | R                    | Software vector number, where:<br>Bits 7-3= Software vector number of interrupt<br>vector for hardware interrupt 1<br>minus one                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0064h       | w                    | Keyboard status port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0065h       | R/W                  | Planar control register, where:Bit 7= 1Enable parallel port outputBit 6= 0ReservedBit 5= 0ReservedBit 4= 1Select serial chipBit 3= 1Select diskette chipBit 2= 1Select video chipBit 1= 1Select parallel port chipBit 0= 1Select fixed disk chip                                                                                                                                                                                                                                                                                                         |
| 0066h       | R/W                  | <ul> <li>Keyboard/pointing device control port 1, where:</li> <li>Bit 7 = 0 Enable keyboard/pointing device command start</li> <li>Bit 6 = 0/1/0 System ready for keyboard/auxil-iary data</li> <li>Bit 5 = 0 Enable keyboard/auxiliary command start</li> <li>Bit 4 = 0/1/0 System ready for keyboard/point-ing device data</li> <li>Bit 3 = 1 Keyboard/pointing device attached to Port 0067h</li> <li>Bit 2 = 0 Keyboard unlocked</li> <li>= 1 Keyboard locked</li> <li>Bit 1 = 0 Port 0068h enabled</li> <li>Bit 0 = 0 Port 0067h enabled</li> </ul> |

| I/O Address | Read/Write<br>Status | Device Description                                                                                                                                                                                                                                                                                                                                        |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0067h       | R                    | Device 2 data port (data from keyboard input here)                                                                                                                                                                                                                                                                                                        |
| 0067h       | w                    | Device 2 command port                                                                                                                                                                                                                                                                                                                                     |
| 0068h       | R                    | Device 1 data port (data from mouse come here)                                                                                                                                                                                                                                                                                                            |
| 0068h       | W                    | Device 1 command port (commands to the mouse sent from here)                                                                                                                                                                                                                                                                                              |
| 0069h       | w                    | Device 1 and 2 control port 2, where:<br>Bits 7-5 = x Reserved<br>Bit 4 = I/O pointing device/keyboard command<br>start<br>Bit 3 = I/O pointing device/ keyboard command<br>start<br>Bit 2 = 1 POST completion<br>Bit 1-0 = Reserved                                                                                                                      |
| 006Ah       | R/W                  | Undefined system port, where:<br>Bits 7-6= 00 Reserved<br>Bit 5 = 1 Device 0 data ready<br>Bits 4-3= 00 Reserved<br>Bit 2 = 1 Device 1 data ready<br>Bit 1 = 0 Reserved<br>Bit 0 = x Diskette related to rate                                                                                                                                             |
| 006Bh       | R/W                  | Planar RAM control/status register, where:Bit 7= 0Upper 512K failed (Parity check<br>pointer)= 1Lower 128K failedBit 6= 1Enable RAM, 90000h - 9FFFFhBit 5= 1Enable RAM, 80000h - 8FFFFhBit 4= 1Enable RAM, 70000h - 7FFFhBit 3= 1Enable RAM, 6000h - 6FFFFhBit 2= 1Enable RAM, 50000h - 5FFFFhBit 1= 1Enable RAM, 40000h - 4FFFFhBit 0= 1Remap low memory |
| 006Ch-0076h |                      | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 0077h       | w                    | Undefined system port                                                                                                                                                                                                                                                                                                                                     |
| 0078h-0079h |                      | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 0080h       | R/W                  | DMA page register channel 2                                                                                                                                                                                                                                                                                                                               |
| 0081h       | R/W                  | DMA page register channel 3                                                                                                                                                                                                                                                                                                                               |
| 0082h       | R/W                  | DMA page register channel 1                                                                                                                                                                                                                                                                                                                               |
| 0083h-0086h |                      | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 0087h       | R/W                  | DMA page register channel 0                                                                                                                                                                                                                                                                                                                               |

| I/O Address | Read/Write<br>Address | Description                                                                                                                                                                                                                                     |
|-------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0088h-008Fh |                       | Reserved                                                                                                                                                                                                                                        |
| 0090h       | R/W                   | Manufacturing port register (flags various stages of POST testing in progress)                                                                                                                                                                  |
| 0091h-009Fh |                       | Reserved                                                                                                                                                                                                                                        |
| 00A0h       | R                     | Interrupt controller extension request register,<br>where:<br>Bit 7 = 1 Enable NMI<br>= 0 Disable NMI<br>Bits 6-4 = x Reserved<br>Bit 3 = 1 Device 1 (Port 0068h) interrupt<br>Bit 2 = 1 Device 0 (Port 0067h) interrupt<br>Bits 1-0 = Reserved |
| 00A1h       | R/W                   | Interrupt controller extension mask register,<br>where:<br>Bits 7-1= Reserved<br>Bit 0 = 1 Enable mask for RTC alarm interrupt                                                                                                                  |
| 00A2h-00AFh |                       | Reserved                                                                                                                                                                                                                                        |
| 00B0h       | R                     | Real time clock alarm clear register (clears the<br>alarm interrupt condition of the clock chip when<br>read)                                                                                                                                   |
| 00B1h       | w                     | Real time clock alarm enable register, where:<br>Bits 7-1= x Reserved<br>Bit 0 = 1 Alarm enabled                                                                                                                                                |
| 00B2h       |                       | Reserved                                                                                                                                                                                                                                        |
| 00B3h       | R/W                   | Real time clock enable register, where:<br>FFh = Enable clock operation                                                                                                                                                                         |
| 00B4h       | R/W                   | Real time clock status register, where:<br>Bits 7-1= 0 Reserved<br>Bit 0 = 1 Clock update in progress                                                                                                                                           |
| 00B5h-00DFh |                       | Reserved                                                                                                                                                                                                                                        |
| 00E0h       | R/W                   | Real time clock 100 microsecond counter, where:<br>Bits 7-4= 100 microsecond count in BCD<br>Bits 3-0= 0 Reserved                                                                                                                               |
| 00E1h       | R/W                   | Real time clock millisecond counter, where:<br>Bits 7-4= 1 100 millisecond counter in BCD<br>Bits 3-0= 0 10 millisecond counter in BCD                                                                                                          |
| 00E2h       | R/W                   | Real time clock seconds register (in BCD)                                                                                                                                                                                                       |

## Hardware Address Locations, Continued

| I/O Address | Read/Write<br>Status | Device Description                                                                                                                                                                                      |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00E3h       | R/W                  | Real time clock minutes register (in BCD                                                                                                                                                                |
| 00E4h       | R/W                  | Real time clock hours register (in BCD)                                                                                                                                                                 |
| 00E5h       | R/W                  | Real time clock day of week (not used by the<br>BIOS), where:<br>Bits 7-3= 0 Reserved<br>Bits 2-0= Day of week                                                                                          |
| 00E6h       | R/W                  | Real time clock day register (day of the month in BCD)                                                                                                                                                  |
| 00E7h       | R/W                  | Real time clock month register (in BCD)                                                                                                                                                                 |
| 00E8h       |                      | Real time clock month encode register 1<br>Bit 7 = 1 Reserved<br>Bit 6 = 1 Reserved<br>Bit 5 = Encoded month (bit 3)<br>Bit 4 = Encoded month (bit 2)<br>Bits 3-0= 0000 Reserved                        |
| 00E9h       | R/W                  | Real time clock year register. Year (module 100)<br>in BCD format.                                                                                                                                      |
| 00EAh       | R/W                  | Real time clock alarm seconds register (alarm<br>time in seconds in BCD; set to FFh when alarm is<br>not set)                                                                                           |
| 00EBh       | R/W                  | Real time clock alarm minutes register (alarm time<br>in minutes in BCD; set to FFh when alarm is not<br>set)                                                                                           |
| 00ECh       | R/W                  | Real time clock alarm hours register (alarm time<br>in hours in BCD; set to FFh when alarm is not<br>set)                                                                                               |
| 00EDh       | R/W                  | Real time clock month encode register 2, where:Bit 7= 1ReservedBit 6= 1ReservedBit 5= 0ReservedBit 4= 0ReservedBit 3= 0ReservedBit 2= 0ReservedBit 1= Encoded month (bit 1)Bit 0= Encoded month (bit 0) |

## Table: Hardware I/O Port Definitions, cont'd

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                               |
|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00EEh       | R/W                  | Real Time Clock checksum register 1, where:Bit 7= 1ReservedBit 6= 1ReservedBit 5= 1Bit 5 of checksumBit 4= 1Bit 4 of checksum invertedBit 3= 1ReservedBit 2= 1ReservedBit 1= 0ReservedBit 0= 021st century= 120th century |
| 00EFh       | R/W                  | Real Time Clock checksum register 2, where:Bit 7= 1ReservedBit 6= 1ReservedBit 5=Bit 3 of checksum invertedBit 4=Bit 2 of checksumBit 3= 1ReservedBit 2= 1ReservedBit 1=Bit 1 of checksumBit 0=Bit 0 of checksum inverted |
| 00F0h-00FEh |                      | Reserved                                                                                                                                                                                                                  |
| 00FFh       | w                    | Undefined system port                                                                                                                                                                                                     |
| 0100h-0277h |                      | Reserved                                                                                                                                                                                                                  |
| 278h        | R/W                  | Parallel 3 data port                                                                                                                                                                                                      |
| 279h        | R/W                  | Parallel 3 status port (see 0379h)                                                                                                                                                                                        |
| 27Ah        | R/W                  | Parallel 3 control port (see 037Ah)                                                                                                                                                                                       |
| 27Bh-2F1h   |                      | Reserved                                                                                                                                                                                                                  |
| 02F2h       |                      | Adapter Interrupt register level 2                                                                                                                                                                                        |
| 02F3h       |                      | Adapter interrupt register level 3                                                                                                                                                                                        |
| 02F4h       |                      | Adapter interrupt register level 4                                                                                                                                                                                        |
| 02F5h       |                      | Adapter interrupt register level 5                                                                                                                                                                                        |
| 02F6h       |                      | Adapter interrupt register level 6                                                                                                                                                                                        |
| 02F7h       |                      | Adapter interrupt register level 7                                                                                                                                                                                        |
| 2F8-2FFh    |                      | Serial register 2 (see 3F8h-3FFh)                                                                                                                                                                                         |
| 031Fh       |                      | Reserved                                                                                                                                                                                                                  |
| 0320h       | R/W                  | Fixed disk adapter control register                                                                                                                                                                                       |
| 0321h       |                      | Reserved                                                                                                                                                                                                                  |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0322h       | W                    | Fixed disk adapter control register, where:<br>Bit 7 = 1 Reset<br>Bit 6 = 1 Reserved (except during reset)<br>Bit 5 = 0 Force 8-bit programmed I/O (PIO)<br>mode<br>Bit 4 = 0 Reserved<br>Bit 3 = 0 Reserved<br>Bit 2 = 0 Force 8-bit PIO mode<br>Bit 1 = 0 Interrupt through adapter status<br>register (324)<br>= 1 Interrupt through programmable<br>interrupt controller<br>Bit 0 = 0 Programmed I/O (PIO) mode<br>= 1 DMA mode |
| 0322h       | R                    | Fixed disk adapter status register, where:Bit 7= 0Bit 6= 0ReservedBit 5= 0Force 8-bit PIO modeBit 4= 1Data transfer requested by adapterBit 3= 0Data direction is system to adapter= 1Data direction is adapter to systemBit 2= 1Adapter busyBit 1= 1Interrupt occurred flagBit 0= 1Transfer in progress                                                                                                                            |
| 0323h       |                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0324h       | w                    | Fixed disk adapter attention register, where:Bit 7= 1System request to send CCB (command control block)Bit 6= 0ReservedBit 5= 1System request to send sense summary blockBit 4= 1Data transfer requested by systemBit 3= 0ReservedBit 2= 0Reserved (Select drive 0)Bit 1= 0ReservedBit 0= 0Abort current command                                                                                                                    |
| 0324h       | R                    | Fixed disk adapter interrupt status register, where:Bit 7= 1Termination error, error in bits 6–0Bit 6= 1Invalid commandBit 5= 1Command rejectBit 4= 0ReservedBit 3= 0ReservedBit 2= 0ReservedBit 1= 1Error recovery procedure invokedBit 0= 1Equipment check                                                                                                                                                                        |
| 0325h-0377h |                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0378h       | R/W                  | Parallel 2 data port                                                                                                                                                                                                                                                                                                                                                                                                                |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0379h       | R/W                  | Parallel 2 status port, where:<br>Bit 7 = 0 Busy<br>Bit 6 = 0 Acknowledge<br>Bit 5 = 1 Out of paper<br>Bit 4 = 1 Printer selected<br>Bit 3 = 0 Error<br>Bit 2 = 0 IRQ occurred<br>Bit 1 = 0 Reserved<br>Bit 0 = 0 Reserved                                                 |
| 037Ah       | R/W                  | Parallel 2, control port, where:<br>Bits 7-6= 0 Reserved<br>Bit 5 = 0 Direction is write to port<br>= 1 Direction is read to port<br>Bit 4 = 1 Enable IRQ<br>Bit 3 = 1 Select printer<br>Bit 2 = 0 Initialize printer<br>Bit 1 = 1 Automatic line feed<br>Bit 0 = 1 Strobe |
| 037Bh-03B3h |                      | Reserved                                                                                                                                                                                                                                                                   |
| 03B4h       | R/W                  | VGA CRT controller index register (mono)                                                                                                                                                                                                                                   |
| 03B5h       | R/W                  | Other VGA CRT controller registers (mono)                                                                                                                                                                                                                                  |
| 03BAh       | R                    | VGA input status register 1 (mono)                                                                                                                                                                                                                                         |
| 03BAh       | w                    | VGA feature control register (mono)                                                                                                                                                                                                                                        |
| 3BCh        | R/W                  | Parallel 1 data port                                                                                                                                                                                                                                                       |
| 3BDh        | R/W                  | Parallel 1 status port (see 379h)                                                                                                                                                                                                                                          |
| 3BEh        | R/W                  | Parallel 1 control port 37Ah)                                                                                                                                                                                                                                              |
| 3BFh        |                      | Reserved                                                                                                                                                                                                                                                                   |
| 03C0h       | R/W                  | VGA attribute address register                                                                                                                                                                                                                                             |
| 03C0h       | w                    | Other VGA attribute registers                                                                                                                                                                                                                                              |
| 03C1h       | R                    | Other VGA attribute registers                                                                                                                                                                                                                                              |
| 03C2h       | w                    | VGA miscellaneous output register                                                                                                                                                                                                                                          |
| 03C2h       | R                    | VGA input status register 0                                                                                                                                                                                                                                                |
| 03C3h       | R/W                  | VGA video subsystem enable                                                                                                                                                                                                                                                 |
| 03C4h       | R/W                  | VGA sequencer address register                                                                                                                                                                                                                                             |
| 03C5h       | R/W                  | Other VGA sequencer registers                                                                                                                                                                                                                                              |
| 03C6h       | R/W                  | Video DAC PEL mask                                                                                                                                                                                                                                                         |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03C7h       | w                    | Video DAC PEL address, read mode                                                                                                                                                                                                                                                                                                                                                                      |
| 03C7h       | R                    | Video DAC state register                                                                                                                                                                                                                                                                                                                                                                              |
| 03C8h       | R/W                  | Video DAC PEL address, write mode                                                                                                                                                                                                                                                                                                                                                                     |
| 03C9h       | R/W                  | Video DAC PEL data register                                                                                                                                                                                                                                                                                                                                                                           |
| 03CAh       | R                    | VGA feature control register                                                                                                                                                                                                                                                                                                                                                                          |
| 03CCh       | R                    | VGA miscellaneous output register                                                                                                                                                                                                                                                                                                                                                                     |
| 03CEh       | R/W                  | VGA graphics registers, address register                                                                                                                                                                                                                                                                                                                                                              |
| 03CFh       | R/W                  | VGA and other graphics registers                                                                                                                                                                                                                                                                                                                                                                      |
| 03D4h       | R/W                  | VGA CRT controller index register, where:<br>Bits 7-6= Reserved<br>Bit 5 = Index5<br>Bit 4 = Index4<br>Bit 3 = Index3<br>Bit 2 = Index2<br>Bit 1 = Index1<br>Bit 0 = Index0                                                                                                                                                                                                                           |
| 03D5h       | R/W                  | VGA Data register                                                                                                                                                                                                                                                                                                                                                                                     |
| 03D6h-03D7h |                      | VGA registers                                                                                                                                                                                                                                                                                                                                                                                         |
| 03D8h       | R/W                  | CGA mode control register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Reserved<br>Bit 5 = 0 No blink<br>= 1 Blink<br>Bit 4 = 1 Mode 6, 640 x 200<br>Bit 3 = 1 Enable display Image<br>Bit 2 = 0 Palette address 00h and CGA border<br>register select color<br>= 1 Palette address 00h-07h are the two<br>colors selected<br>Bit 1 = 1 Select mode 4 and 5, 320 x 200<br>Bit 0 = 1 Select 80 x 25 mode |
| 03D9h       | R/W                  | CGA border control register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 0 Reserved<br>Bit 5 = 320 x 200 palette select<br>Bit 4 = Alternate intensity<br>Bits 3-0 = Border color                                                                                                                                                                                                                         |

| Address     | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03DAh       | R                    | VGA status register, where:<br>Bits 7-4= 0 Reserved<br>Bit 3 = Vertical sync<br>Bit 2 = 0 Reserved<br>Bit 1 = 0 Reserved<br>Bit 0 = Display enable                                                                                                                                                                                                                 |
| 03DBh-03DCh |                      | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 03DDh       | R/W                  | VGA extended mode control, where:<br>Bit 7 = Readable DAC installed<br>Bits 6-3= 0 Reserved<br>Bit 2 = 256 colors<br>Bit 1 = 0 Reserved<br>Bit 0 = 0 Reserved                                                                                                                                                                                                      |
| 03DEh-03EFh |                      | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 03F0h       | R                    | Diskette controller port A register, where:<br>Bit 7 = 1 Interrupt pending<br>Bit 6 = 0 Second drive installed<br>Bit 5 = 1 Step (latched)<br>Bit 4 = 1 Track 0<br>Bit 3 = 1 Head 1 selected<br>Bit 2 = 1 Index<br>Bit 1 = 0 Write protect<br>Bit 0 = 0 Direction                                                                                                  |
| 03F1h       | R                    | Diskette controller port B register, where:<br>Bit 7 = 0 Reserved<br>Bit 6 = 1 Select drive 1<br>Bit 5 = 1 Select drive 0<br>Bit 4 = 0 Write data (latched)<br>Bit 3 = 0 Read data (latched)<br>Bit 2 = 0 Write enable (latched)<br>Bit 1 = 1 Select drive 3<br>Bit 0 = 1 Select drive 2                                                                           |
| 03F2h       | W                    | Diskette controller digital output register, where:<br>Bit 7 = 0 Enable motor drive 3<br>Bit 6 = 0 Enable motor drive 2<br>Bit 5 = 0 Enable motor drive 1<br>Bit 4 = 0 Enable motor drive 0<br>Bit 3 = 0 Enable DMA and interrupt<br>Bit 2 = 1 Reset controller<br>Bits 1-0=00 Select drive 0<br>= 01 Select drive 1<br>= 10 Select drive 2<br>= 11 Select drive 3 |
| 03F3h       |                      | Reserved                                                                                                                                                                                                                                                                                                                                                           |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                        |
|-------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03F4h       | R                    | Diskette main status register, where:<br>Bit 7 = Request for master<br>Bit 6 = Stat input/output<br>Bit 5 = Non-DMA mode<br>Bit 4 = Diskette controller busy<br>Bit 3,2 = Reserved<br>Bit 1 = Drive 1 busy<br>Bit 0 = Drive 0 busy |
| 03F5h       | R/W                  | Diskette controller data registers                                                                                                                                                                                                 |
| 03F6h       |                      | Reserved                                                                                                                                                                                                                           |
| 03F7h       | R                    | Diskette controller digital input register, where:<br>Bit 7 = Diskette change<br>Bits 6-4 = Reserved<br>Bit 3 = DMA enable<br>Bit 2 = No write precompensation<br>Bit 1 = Select 250 rate<br>Bit 0 = Reserved                      |
| 03F7h       | W                    | Diskette controller configuration control register,<br>where:<br>Bits 7-3 = Reserved<br>Bit 2 = No write precompensation<br>Bit 1 = 0 500 Kbs mode<br>= 1 250 Kbs mode<br>Bit 0 = Reserved                                         |
| 03F8h       | W                    | Serial register 1, transmitter holding register,<br>where:<br>Bits 7-0 = Data bits 7 through 0, respectively,<br>when Divisor Latch Access Bit<br>(DLAB) = 0                                                                       |
| 03F8h       | w                    | Serial register 1, receiver buffer register, where:<br>Bits 7-0 = Data bits 7-0, respectively, when<br>DLAB = 0                                                                                                                    |
| 03F8h       | R/W                  | Serial register 1, divisor latch, low byte, where:<br>Bits 7-0 = Bits 7-0 of the divisor when DLAB = 1                                                                                                                             |
| 03F9h       | R/W                  | Serial register 1, divisor latch, high byte, where:<br>Bits 7-0 = Bits 15-8 of the divisor when DLAB = 1                                                                                                                           |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03F9h       | R/W                  | Serial register 1, interrupt enable register, where:Bits 7-4 = 0 ReservedBit 3 = 1 Enable modem status interruptBit 2 = 1 Enable receiver line status interruptBit 1 = 1 Enable transmitter holding register<br>empty interruptBit 0 = 1 Enable received data available inter-<br>rupt when DLAB = 0                                                                                                                                                                                                                                            |
| 03FAh       | R                    | Serial register 1, interrupt identification register,<br>where:<br>Bits 7-3 = 0 Reserved<br>Bits 2-1 = 00 Modem status interrupt<br>= 01 Transmitter holding register empty<br>interrupt<br>= 10 Received data available register<br>interrupt<br>= 11 Receiver line status interrupt<br>Bit 0 = 0 Interrupt pending                                                                                                                                                                                                                            |
| 03FBh       | R/W                  | Serial register 1, line control register, where:<br>Bit 7 = 1 Divisor latch access<br>= 0 Receiver buffer, transmitter holding or<br>enable registers access<br>Bit 6 = 1 Set break enabled<br>Bit 5 = 1 Stick parity, if parity is enabled<br>Bit 4 = 1 Even parity select, if parity is enabled<br>Bit 3 = 1 Parity enable<br>Bit 2 = 0 1 stop bit is specified if word length<br>> 5; 1.5 stop bits are specified if word<br>length = 5<br>Bit 1-0 = 00b Word length is 5 bits<br>= 10b Word length is 7 bits<br>= 11b Word length is 8 bits |
| 03FCh       | R/W                  | Serial register 1, modem control register, where:<br>Bit 7-5 = 0 Reserved<br>Bit 4 = 1 Loop back mode<br>Bit 3 = 1 Enable OUT2 interrupt<br>Bit 2 = 1 Force OUT1 active<br>Bit 1 = 1 Force request-to-send active<br>Bit 0 = 1 Force data-terminal-ready active                                                                                                                                                                                                                                                                                 |

| I/O Address | Read/Write<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 03FDh       | R                    | <ul> <li>Serial register 1, Line status register, where:</li> <li>Bit 7 = 0 Reserved</li> <li>Bit 6 = 1 Transmitter shift and holding registers empty</li> <li>Bit 5 = 1 Transmitter holding register empty</li> <li>Bit 4 = 1 Break interrupt</li> <li>Bit 3 = 1 Framing error</li> <li>Bit 2 = 1 Parity error</li> <li>Bit 1 = 1 Overrun error</li> <li>Bit 0 = 1 Data ready</li> </ul> |
| 03FEh       | R                    | Serial register 1, modem status register, where:<br>Bit 7 = 1 Data carrier detect<br>Bit 6 = 1 Ring indicator<br>Bit 5 = 1 Data set ready<br>Bit 4 = 1 Clear to send<br>Bit 3 = 1 Delta data carrier detect<br>Bit 2 = 1 Trailing edge ring indicator<br>Bit 1 = 1 Delta data set ready<br>Bit 0 = 1 Delta clear to send                                                                  |
| 03FFh       | R/W                  | Serial register 1, scratch register                                                                                                                                                                                                                                                                                                                                                       |

## Microprocessor

#### Requirement

The 8086 PS/2 BIOS must be implemented in a system that uses the Intel 8086-2 or an equivalent microprocessor.

#### **Processor speeds supported**

The 8086 PS/2 BIOS supports microprocessor speeds of from 4.77 to 10 MHz.

#### Wait states supported

The 8086 PS/2 BIOS supports either zero or one wait state.

#### Address modes

The 8086 PS/2 BIOS supports real address mode only. Real address mode supports 20-bit addresses, made up of 16-bit segments and 4-bit offsets, with a maximum addressable memory area of 1 MB. All segments are 64K.

## 8087 Math Coprocessor

#### Introduction

The 8086 PS/2 BIOS can be implemented in systems that include an Intel 8087 math coprocessor or its equivalent.

#### Description

The 8087 math coprocessor performs high speed arithmetic, logarithmic, and trigonometric floating point arithmetic calculations. This permits much speedier processing for mathematically-intensive processing applications.

The math coprocessor works in parallel with the microprocessor, allowing both to process instructions separately. See the user manual for the Intel 8087 math coprocessor for details about the extended data types, registers, and instructions available with this chip.

#### Math coprocessor hardware interface

The coprocessor operates in an asynchronous mode and can use the same clock generator as the microprocessor. It functions as an I/O device and its presence is indicated if Bit 1 of port 0062h is on.

The coprocessor BUSY signal tells the microprocessor that the coprocessor is operating. The WAIT signal means that it is executing and forces the microprocessor to wait until the coprocessor is done.

The coprocessor operates in the real address mode.

## System Support Gate Array

#### Gate array contents

A system such as the PS/2 Model 30 and compatibles has a system support gate array. The system support gate array contains the following:

- a bus controller,
- a memory controller and parity checker,
- bus conversion logic,
- a wait-state generator, and
- a system clock generator.

#### **Bus controller**

The 8086 PS/2 BIOS supports a bus controller that has three bus masters. The bus masters are:

- a microprocessor master
- a coprocessor master, and
- a system support gate array bus master.

The 8086 PS/2 BIOS supports the XT I/O bus, so all XT-compatible add-on boards are supported.

#### Memory controller

The 8086 PS/2 BIOS supports a memory controller/parity checker function.

#### **Bus conversion logic**

The system support gate array also contains bus conversion logic and a wait-state generator.

#### System clock generator

The system support gate array contains the system clock function. The 8086 PS/2 BIOS expects an Intel 82284 clock generator chip, or equivalent chip, to be available.

## I/O Support Gate Array

#### I/O support

The 8086 PS/2 BIOS I/O support function includes support of all of the following I/O features and capabilities:

- a serial port
- a parallel port
- a diskette controller
- a fixed disk controller, and
- a VGA video controller.

Each of these capabilities is discussed in the following sections.

#### Serial port

The 8086 PS/2 BIOS supports either a National Semiconductor 16550 serial port controller, or equivalent logic. The serial port can be addressed as Serial 1 or Serial 2. IRQ 4 is the line for Serial 1 and IRQ 3 for Serial 2. The serial ports are at I/O port addresses 03F8h and 02F8h.

#### NS16550 characteristics

The NS16550 supports:

- Characters of 5, 6, 7, or 8 bits,
- 1, 1.5, or 2 stop bits, and
- even, odd, or no parity modes.

**Note:** The NS16550 is functionally compatible with the NS16450 and the NS8250.

#### Programmable baud rate generator

The serial port controller can operate at speeds of from 110 to 19,200 bps.

## I/O Support Gate Array, Continued

#### Parallel port

The 8086 PS/2 BIOS supports a parallel port that can transfer 8 bits of data at standard TTL levels. The parallel port can be called port 1, 2, or 3, is AT-compatible, and has a bidirectional mode, supporting both input and output. It also supports level sensitive interrupts and a readable interrupt pending status.

#### Parallel port addresses

Parallel Control Data Status Port Number Address Address Address 1 03BCh 03BDh 03BEh 2 0378h 0379h 037Ah 3 0278h 0279h 027Ah

The following table lists the parallel port addresses:

#### Diskette controller

The 8086 PS/2 BIOS supports an NEC 765, or equivalent diskette controller. Diskette support from other PS/2 BIOS products may exist only for 720K 3.5 inch diskette drives. Four types of diskette drives are supported by the Phoenix 8086 PS/2 BIOS:

- 720K 3.5 inch,
- 1.44 MB 3.5 inch,
- 360K 5.25 inch, and
- 1.2 MB 5.25 inch drives.

The Phoenix 8086 PS/2 BIOS also will work with a system with no diskette drives, as long as the BIOS options are configured to support the configuration error message suppression option.

## I/O Support Gate Array, Continued

#### Diskette drive configuration

The IBM PS/2 8086 BIOS supports one or two internal diskette drives.

The Phoenix 8086 PS/2 BIOS supports up to two internal diskette drives and one external diskette drive. These drives can be any combination of zero, one or two internal diskette drives (which can be a mix of any supported drive types), and one external drive (must be a 3.5 inch drive).

#### Fixed disk controller

The 8086 PS/2 BIOS supports zero, one, or two fixed disks. The BIOS assumes that a Western Digital ST506 fixed disk controller, or equivalent, is available.

#### Fixed disk I/O channels

The 8086 PS/2 BIOS supports a dedicated I/O channel for fixed disk support at I/O address 0320h. The fixed disk adapter status register and control registers are at I/O address 0322h, the fixed disk adapter attention register is at 0324h, and the fixed disk adapter interrupt status register is at 0324h.

The DMA controller is programmed to perform the read/write fixed disk functions. DMA channel three is used for fixed disk data transfers. The system board controls the chip select feature of the fixed disk controller through the Planar Control Register (Port 0065h).

#### Video controller

The Phoenix 8086 PS/2 BIOS supports the Video Graphics Array (VGA) controller. The IBM 8086 PS/2 BIOS supports the MCGA standard.

#### DAC

The video DAC (digital-to-analog converter chip) contains 256 individual color registers which can be accessed by the BIOS as either four 64-color registers or sixteen 16-color registers.

Each DAC color register contains one 18-bit RGB (red-green-blue) analog value. Six bits of each register are allocated to each primary color. Thus, the color represented in each DAC color register may be any of 256K possible colors (i.e.  $2^{3*6} = 256$ K).

#### Video RAM

The Video Service requires 256K of read/write video RAM formatted into four banks (or maps) of 64K each.

To maintain compatibility, display memory for each of the historical MDA, CGA, and EGA modes is exactly as it was before. The display memory organization for the new VGA modes is outlined in the INT 10h Video Ser-vice Section.

#### Analog monitor support

To display all modes, the Video Service requires either a monochrome or a color direct drive analog monitor with a 31.5 KHz horizontal scan frequency.

The display's vertical gain is adjusted automatically by the VGA-compatible circuitry. Thus, video modes with 350, 400, and 480 horizontal scan lines can be displayed without requiring manual adjustment.

#### Multiscan monitor support

In addition to 31.5 KHz direct drive analog monitors, the Video Service also supports multiscan rate monitors capable of operating in analog modes (e.g. NEC Multisync monitor). Monitors of this type require an adapter cable that matches the signal assignments and monitor ID circuitry of the DAC external video controller.

#### Keyboard controller

The 8086 PS/2 BIOS supports an intelligent keyboard subsystem which is referred to as the keyboard support hardware in this book.

#### Pointing device interface

The pointing device in the 8086 PS/2 BIOS is controlled by the keyboard support hardware. INT 73h handles interrupts from the pointing device. The INT 15h pointing device services control the device operations.

## System Time-Related Logic

#### Chip requirements

The 8086 PS/2 BIOS expects the following time-handling chips or their equivalents to be available:

- Intel 82284 Clock Generator
- Intel 8254A Programmable Timer
- Real time clock (described later in the Interrupt Controller Extensions discussion).

#### Intel 82284 Clock Generator

The 8086 PS/2 BIOS expects an Intel 82284 clock generator chip, or equivalent chip, to be available.

#### 8254A Programmable Timer

The 8086 PS/2 BIOS expects an Intel 8254A Programmable Timer chip, or equivalent, to be available. The 8254A Programmable Timer is a counter and timer that provides three channel timers. All channels are driven by a 1.19 MHz oscillator signal.

#### **Timer Counters**

There are some differences between the three timer channels:

Counters 0 and 2 are:

- independent 16-bit counters,
- can be preset, and
- can count in BCD (binary coded decimal) or in binary.

Counter 3 is:

- 8 bits only,
- can be preset,
- counts in binary only, and
- can count only downward.

The 8086 PS/2 BIOS assumes the existence of the interrupt controller extension feature, which controls the:

- keyboard,
- pointing device, and
- real time clock interfaces.

See the INT 15h System Services section for a discussion of the interrupt controller extension.

#### Keyboard subsystem

The 8086 PS/2 BIOS supports a keyboard subsystem. 101-key keyboards are supported.

#### Pointing device interface

The pointing device (mouse) is controlled by INT 71h, which determines whether an interrupt is a keyboard, pointing device, or RTC interrupt.

INT 73h handles all interrupts from pointing devices. The INT 15h pointing devices functions control the mouse operation.

#### **Real Time Clock**

The 8086 PS/2 BIOS assumes a Real Time Clock function that is controlled by the interaction of I/O ports 00B0h – 00EFh. The ROM BIOS assumes that no CMOS RAM is available in systems based on the 8086.

#### Chip requirements

The 8086 PS/2 BIOS expects an Intel 8253 Programmable Timer chip, or equivalent, to be available. The 8253 Programmable Timer is a counter and timer that works as an arrangement of four 16-bit I/O ports at addresses 0040h-0043h. The 1.19 MHz clock signal is received from the I/O support gate array. Ports 0040h-0042h are counters, and 0043h is a control register for timer mode programming.

#### **Timer Channels**

There are some differences between the three timer channels:

Channel 0:

- is a general-purpose timer,
- provides a constant time base for a time-of-day clock, and
- can count in binary coded decimal or in binary.

Channel 1:

- is for internal diagnostics,
- can be preset,
- counts in binary only, and
- can count only downward.

Channel 2:

- used for tone generation,
- outputs to the beeper data of the I/O support gate array, and
- is controlled by Bit 0 of port 0061h.

## System Timer, Continued

#### System timer modes

The system timer has six modes. These modes are described in the following table:

| Mode | Name                            |
|------|---------------------------------|
| 0    | Interrupt on Terminal Count     |
| 1    | Hardware Retriggerable One-Shot |
| 2    | Rate Generator                  |
| 3    | Square Wave                     |
| 4    | Software-Triggered Strobe       |
| 5    | Hardware Retriggerable Strobe   |

#### Common timer mode operations

All modes have the following operations in common:

- All control logic resets when control bytes are written to a counter.
- Counters do not stop when they reach zero.
- In Modes 0, 1, 4, and 5 the counter wraps to the highest possible count, and continues to count.
- In Modes 2 and 3, the counter reloads the initial count and continues to count.

#### **DMA requirements**

The 8086 PS/2 BIOS expects the DMA controller to be compatible with an Intel 8237, or equivalent controller. It is also expected that the DMA controller is capable of 8-bit wide data access between 8-bit I/O adapters and 8-bit system memory. The Direct Memory Access (DMA) controller allows I/O devices to transfer data directly to and from memory, significantly decreasing I/O processing by the microprocessor.

The 8086 PS/2 BIOS supports one 8237 DMA controller, supporting 4 channels (channels 0–3), each capable of 20-bit wide data access, operating at 4 MHz, and uses I/O port addresses 0000h to 001Fh.

#### Microprocessor access to DMA

The microprocessor can address the DMA controller and access the DMA registers. The microprocessor can control the DMA modes, transfer addresses, transfer counts, channel masks, and page registers.

On a 10 MHz system, the DMA controller requires

- 1 wait state to complete processing of any command from the system,
- at least three clock cycles to complete an I/O read or write transfer, and
- at least two clock cycles for a memory read or write transfer.

The system microprocessor must access the DMA with 8-bit I/O instructions.

#### DMA data transfer

After the DMA controller is programmed to service a data transfer request, a transfer can take place. Channels 0–3 are 8-bits wide and can transfer up to 64K to/from any address in system memory. DMA transfers take six clock cycles of 250ns each, or 1.5 microseconds. More wait states may be added for slower devices by making the I/O channel inactive.

## DMA page registers

The following table shows the DMA page register characteristics:

| I/O Port<br>Address | Read/Write<br>Status | Length | Description |
|---------------------|----------------------|--------|-------------|
| 0081h               | R/W                  | 8 bits | Channel 2   |
| 0082h               | R/W                  | 8 bits | Channel 3   |
| 0083h               | R/W                  | 8 bits | Channel 1   |
| 0087h               | R/W                  | 8 bits | Channel 0   |

## 8259 Programmable Interrupt Controller

#### Description

The Intel 8259 Programmable Interrupt Controller handles all interrupts. One 8259 Programmable Interrupt Controller, or equivalent, is supported by the 8086 PS/2 BIOS. Compatibility with interrupts expected in existing software is maintained in the PS/2-compatible BIOS.

#### Levels of interrupts

There are eight levels of interrupts. Several devices may share the same hardware interrupt, which reduces the interrupt controller's sensitivity to a transient signal on the I/O bus.

#### Interrupt uses

The following table shows how interrupts are used in 8086-based PS/2-compatible systems:

| interrupt<br>Level | System Board<br>Availability                           | l/O Channel<br>Availability | Comments                          |
|--------------------|--------------------------------------------------------|-----------------------------|-----------------------------------|
| NMI                | Parity check and<br>coprocessor                        | I/O channel check           | Only available on system<br>board |
| IRQ 0              | Timer channel 0                                        | Not available               | Called by INT 71h                 |
| IRQ 1              | Keyboard, pointing de-<br>vice, and real time<br>clock | Not available               |                                   |
| IRQ 2              | Video                                                  | Available                   |                                   |
| IRQ 3              | Reserved                                               | Available                   |                                   |
| IRQ 4              | Serial port                                            | Available                   |                                   |
| IRQ 5              | Fixed disk                                             | Available                   |                                   |
| IRQ 6              | Diskette drives                                        | Available                   |                                   |
| IRQ 7              | Parallel port                                          | Available                   |                                   |

## 8259 Programmable Interrupt Controller, Continued

#### Interrupt Sharing

Multiple adapters may share an interrupt level. Adapters sharing interrupts allow the IRQ line to float high, and each adapter causes an interrupt by pulsing the line low. Adapters sharing interrupts must monitor the IRQ line, and must not issue interrupts until they are rearmed after an interrupt by another adapter.

Interrupt sharing provides a way to:

- link an adapter's interrupt handler to a chain of interrupt handlers,
- share interrupt levels among active adapters, and
- unlink the interrupt handler from the chain when the task is deactivated.

## **Miscellaneous Additional Logic**

#### NMI mask

The NMI (nonmaskable interrupt) input to the 8086 is masked off at poweron reset. Bit 7 of I/O port address 00A0h is set to one to enable the NMI. A power-on reset clears this bit.

#### System control port (0061h)

Port 0061h contains information used for system control.

| Bit | Description                   |  |
|-----|-------------------------------|--|
| 7   | Reserved                      |  |
| 6   | Reserved                      |  |
| 5   | Enable channel check          |  |
| 4   | Enable parity check           |  |
| 3   | Reserved                      |  |
| 2   | Reserved                      |  |
| · 1 | Beeper data                   |  |
| 0   | Enable timer 2 gate to beeper |  |

The following table shows Port 0061h write operations:

#### System board status port (0062h)

The following table shows Port 0062h read operations:

| Description              |                                                                                                                                               |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Parity error occurred    |                                                                                                                                               |
| I/O channel check active |                                                                                                                                               |
| Timer 2 output status    |                                                                                                                                               |
| Reserved                 |                                                                                                                                               |
| Reserved                 |                                                                                                                                               |
| Disk installed           |                                                                                                                                               |
| Coprocessor installed    |                                                                                                                                               |
| Reserved                 |                                                                                                                                               |
|                          | Parity error occurred<br>I/O channel check active<br>Timer 2 output status<br>Reserved<br>Reserved<br>Disk installed<br>Coprocessor installed |

# Glossary

#### ABIOS

Advanced BIOS. The BIOS designed to support multitasking operating systems such as OS/2. It comes packaged with a traditional Compatibility BIOS (CBIOS).

#### Adapter Card

A circuit board that can be installed into one of the expansion slots inside a PS/2-compatible computer in order to expand the capabilities of the computer.

#### Adapter Description Files (ADFs)

Text files supplied on a diskette by manufacturers of PS/2-compatible adapter cards. The ADFs contain information such as what resources are needed to use the card. The ADFs must be copied to a working copy of the Reference Diskette after the adapter card is installed.

#### Adapter ROM

The read-only memory on the adapter, which contains code to control the adapter device. An adapter is a peripheral card that extends the operation of the system. For example, a fixed disk drive controller is an adapter that may have an adapter ROM. Adapter ROM code may include an ABIOS ROM extension.

continued

Glossary

#### Address Bus

One or more lines (conductors) that carry address codes from the microprocessor to all parts of the system.

#### Arbitration

Arbitration is a process through which devices compete for possession of the channel on a prioritized basis.

#### Arbitration Level

Arbitration levels are the levels of priority assigned to devices that compete for possession of the channel.

#### **Bimodal Operation**

Refers to the ability of a program to operate in both the real address mode and the protected address mode of the 80286, 80386SX, or 80386 microprocessor. ABIOS services are bimodal; they operate in either real or protected mode.

#### BIOS

Basic Input/Output System. Systems software that interfaces between the operating system and hardware.

#### Boot

Process of starting the computer.

#### **Burst Mode**

Burst mode is a method of DMA transfer that allows a device to remain inactive for long periods and then send large amounts of data in a short time.

#### Bus

One or more lines (conductors) that carry signals or power.

#### Byte

Eight contiguous bits; a bit is the smallest item of information that a computer can process.

#### Cache

Method of using a fast device to speed up access to a slow device.

#### CBIOS

Compatibility BIOS. The traditional single-tasking portion of a PS/2-compatible BIOS.

#### **CBIOS Service**

A software routine that services a given peripheral device, and provides an interface between the operating system and the hardware. These services are single task, call/return functions, as opposed to the device services offered by ABIOS.

#### CMOS

Acronym for Complementary Metal Oxide Semiconductor. In PS/2 compatibles, it is low-power memory that is battery-backed and is therefore not lost when the computer is turned off.

#### Configuration

The process of setting up all the parts of the computer so they run effectively.

#### Cyclic Redundancy Check (CRC)

A method of redundancy check where the check key is produced by a cyclic or repeating algorithm. A common means of error checking.

#### Default

A value, setting, or option that is assigned by the program or system.

#### **Direct Memory Access (DMA)**

Direct Memory Access is a means for I/O devices to transfer data directly to and from system memory without the intervention of the microprocessor. This significantly decreases I/O processing by the microprocessor.

#### **DMA Controller**

A DMA controller is a device which gives addresses and control signals to the device that has won the bus through arbitration. The controller does not enter into the arbitration itself.

#### DMA Device

A DMA device enters into arbitration for the channel. If it wins, it receives addresses and control signals from the DMA controller so it can read or write data.

#### DOS

Acronym for Disk Operating System and short for PC-DOS and MS-DOS. DOS, like other operating systems, organizes the files and memory for other programs.

#### **Error Handler**

An invisible program on the Reference Diskette that reads the POST error log. If an error is found, a cause and solution type message about the error is displayed.

#### **Expanded Memory**

For AT-compatible systems, up to 32 MB of additional "paged" memory above the DOS 640K limit. Application programs written according to LIM EMS or AST EEMS specifications can use this type of memory. Examples of such programs are Lotus 1-2-3, Symphony and Framework.

#### Expanded Memory Specification (EMS)

For AT-compatible systems, a specification and protocol established by a consortium of computer manufacturers, principally Lotus, Intel, and Microsoft (LIM), which establishes a set of rules for organizing and accessing expanded memory.

#### Extended Expanded Memory Specification (EEMS)

A specification and protocol established by a consortium of computer manufactures, principally AST, Quadram, and Ashton-Tate, which establishes a set of rules for organizing and accessing expanded memory.

#### **Extended Memory**

The memory above 1 MB. XENIX and IBM's VDISK can use this memory, but DOS and almost all application programs cannot, since use of the protected mode of the Intel 80386 or 80386 microprocessor is required.

#### Fixed Disk (Hard Disk)

A magnetic storage device consisting of a drive mechanism with permanently installed metallic disks; a "filing cabinet" for the computer.

#### Hardware

The physical equipment and components in the computer system.

#### Interrupt

The suspending of microprocessor program execution by a demand for attention coming from a peripheral device. After the interrupt has been serviced, the suspended microprocessor task can be resumed where it was broken off by the interrupt.

#### Kilobytes (K)

1024 bytes.

#### **Known State**

When a device is initialized or reset, and then set to a particular preestablished condition, it is said to be in a known state.

#### Low Level Format

Electronic equivalent of drawing a detailed street map on the fixed disk. The electronic markings tell the system at what points to start and end reads and writes.

#### Main Memory

The memory between 0 and 1 MB.

#### Megabyte (MB)

One million, or 1024 x 1024 bytes.

#### Memory

A device that can store data recorded in it and from which the data can be retrieved.

#### Micro Channel

Information is exchanged between the computer system board and the adapter cards which are plugged into it by means of the "bus." Micro Channel refers to the particular bus design in a PS/2-compatible computer. It is also referred to as MCA, for Micro Channel Architecture.

#### Microprocessor

Central processing unit, or "brain" of the computer.

#### Multitasking

Multitasking programs execute multiple program modules simultaneously. Information input into one module does not need to be processed completely before information can be input into another module. ABIOS supports multiple concurrent requests.

#### Offset

A method of addressing that defines an address as relative to the beginning of a memory segment.

#### **Operating System**

Generic systems software which controls the execution of applications software.

#### **Option Diskette**

The diskette provided by manufacturers of adapter cards that contains adapter description files (ADFs), which are written to the Reference Diskette and used by it to configure the system.

#### Parameter

Value, option, or setting that can be set in two or more ways.

#### Power-on Self Test (POST)

A program that tests all parts of the computer every time you turn on the computer.

#### Program

A set of instructions defining the operations of a computer in order to achieve the desired results.

#### Programmable Option Select (POS)

A way of setting up peripheral devices on a PS/2 machine via the poweron self test (POST), in which values are placed in registers on the devices. This software set up routine replaces the traditional switches and jumpers on devices.

#### Protected Virtual Address Mode (Protected Mode)

One of two 80286 or three 80386 memory addressing modes. In protected virtual address mode, the 80386/80286 uses all address lines. This allows addressing of up to 16 megabytes of physical memory in an 80286 and 4 GB in an 80386. The 80286 processor's internal memory management allows addressing of an additional 1 gigabyte of virtual memory in protected mode (the 80386 up to 64 Terabytes). Protected mode addresses are specified in selector:offset format. ABIOS data structures support protected mode access of all ABIOS services.

#### PS/2-Compatible Computer

Any computer that can run software programs written for an IBM PS/2 computer. IBM PS/2 systems come in two basic varieties: Models 25 and 30 versus Models 50, 60, 70, and 80. The former systems do not implement the Micro Channel Architecture (MCA).

#### **Real Address Mode**

One of two 80286 memory addressing modes (the 80386 has three). In real address mode, the 80286 and 80386 microprocessors use 20 address lines, thus allowing memory addressing of up to 1 megabyte of physical memory (2<sup>20</sup>). Real address mode does not support virtual memory addressing. Real mode addresses are specified in segment:offset format. ABIOS data structures support real mode access of all ABIOS services.

#### **Reference Diskette**

In PS/2-compatible MCA-based systems, POST error recovery, access to system utilities, and system configuration are all controlled by a utility diskette, the Reference Diskette. The Reference Diskette can automatically configure a system, resolving conflicts between adapter card settings, and optimally configuring the system.

#### Segment

A unit of contiguous, one-dimensional address space. In real mode, these address blocks are 64K in size, referenced by one byte. In protected mode, programs can allocate segments of any size they require up to 64K.

#### Selector

A value contained in a segment register (such as the CS, DS, SS, or ES segment registers) when in protected mode. This value determines what segment is currently being used; e.g., with CS, what segment is being used for executing code.

#### Single-Tasking

Single-tasking operating systems can only execute one program module or routine at a time. Information input into a module or routine must be processed completely before information can be input into another module.

#### Software

A comprehensive term used to identify all of the nonhardware components of a computer. Software includes computer programs and data.

#### System Board

A large circuit board that holds most of the main electronic parts of the computer.

#### System Board ROM

Read-only memory chips that reside on the system board and provide control information for various system components.

#### Task

In an 80386, a task is the execution of a single process or set of instructions to perform a particular function. It is not the same as an operating system task.

#### Time-Out

When the interval of time expected for a certain process (an interrupt) to occur is exceeded.

#### Virtual 8086 Mode (80386 only)

A way of emulating the 8086 or 8088 microprocessors on the 80386. The 8086 program runs in protected mode as a task that can run with multiple 8086 virtual tasks, as well as alongside other multiprogrammed 80386 tasks.

# **Additional Resources**

The following books provide additional material related to the CBIOS:

Dettman, Terry R. DOS Programmer's Reference. Carmel, IN: Que® Corporation, 1988.

Duncan, Ray. Advanced MS-DOS Programming. Redmond, WA: Microsoft Press, 1986.

Duncan, Ray. *IBM® ROM BIOS*. Redmond, WA: Microsoft Press, 1988.

International Business Machines Corporation. *IBM® Personal System/2™* and Personal Computer BIOS Interface Technical Reference. Boca Raton, FL: IBM, 1987.

International Business Machines Corporation. *IBM® Personal System/2™ Model 30 Technical Reference*. Boca Raton, FL: IBM, 1987.

International Business Machines Corporation. *IBM Personal System/2™ Model 50 and 60 Technical Reference*. Boca Raton, FL: IBM, 1987.

Norton, Peter and Wilton, Richard. *The New Peter Norton Programmer's Guide to the IBM® PC and PS/2®*. Redmond, WA: Microsoft Press, 1988.

Wadlow, Thomas A. *Memory Resident Programming on the IBM PC*. Reading, MA: Addison-Wesley Publishing Co., Inc., 1987.

Wilton, Richard. *Programmer's Guide to PC*<sup>®</sup> and PS/2<sup>™</sup> Video Systems. Redmond, WA: Microsoft Press, 1987.

# Index

# Α

Abbreviations, xiii-xiv ABIOS. 1-2 and Diskette Service, 268 and Fixed Disk Service, 303 initialization of, 363-364 for multitasking operating systems, 25 and POST. 111 Acknowledge keyboard reply, 476 Acknowledge mouse reply, 480 Acronyms, xiii-xiv Active character blocks, 216 Active display code, 238 Active page, 192, 238 Adapter description files, 28, 49 Adapter enable POS subfunction, 397 Adapters asynchronous communication, 78 enabling of, 397 error messages for, 445, 455 IDs for, 358 in CMOS RAM, 93, 295 in extended CMOS RAM, 95-97, 296-297 POS, 63 interrupt registers for, 491 Micro Channel support for, 27 multiscan monitor cables for, 31, 505 printer, 78, 403 setting of, 104 slots for, 5, 9, 103 Address line failures, 442, 454

Address modes, microprocessor, 25.499 Addresses, I/O Port CMOS RAM register port for, 60, 89, 122, 257, 291, 357, 410, 425, 436 CRT controller, 238 DMA controller, 42-43, 48, 55-56, 60-63, 482-484 extended CMOS RAM port for, 89 parallel port, 33, 64-65, 68-69, 503 for PICs, 50 POS adapter register, 396 ROM, compatibility of, 100-101 serial port, 34, 65-67, 71-73, 331-336 for system control port, 52, 59-61, 121-122, 172, 291, 357, 422, 436, 487 video expansion ROM, 115 ADF (adapter description files), 28, 49 Alarm in CMOS RAM, 411 interrupt processing for, 423 real time clock, 90, 417-418, 489-490 Allocated bytes, 85 Alt key, 133 and character code tables, 153-162 and pause state table, 139 status of, 145 work area for, 79, 135 Alternate keyboard layouts, 368 Alternate Reset Fixed Disk, Fixed Disk Service, 318-319 Alternate scan codes, 474

#### A, cont'd

Alternate Select, Video Service, 229 Enable/Disable cursor scaling, 233 Enable/Disable default palette loading during set mode, 232 Enable/Disable summing to gray shades, 233 Enable/Disable video, 233 Return VGA Information, 230-231 Select scan lines for text modes. 232 Switch Display, 234 Switch to alternate print screen routine, 231 Video screen ON/OFF, 234 Analog monitor support, 31, 171, 177, 505 Applications programs, compatibility for, 3 Arbitration levels, 61 and bus sharing, 41 and DMA controller, 45-46 for fixed disks, 86, 294 register for, 122, 436 Arbus register, DMA, 43, 47 Arithmetic operations, 26, 500 ASCII characters, 151-162 Asynchronous communication adapters, 78 Attention register, fixed disk adapter, 68, 292, 492 Attributes address register for, 69, 172, 493 controller for, 30, 169-170, 247 and memory maps, 216 reading of, from screen, 194 writing of, to screen, 195-196, 202 Autoinitialization of DMA controller, 43 Auxiliary character generator second text mode, pointer to, 185 text mode, pointer to, 182

Auxiliary devices controller for, 32 data for, 85 Intel 8042 interface commands for, 470-471 status of, 392

### В

Background color, 198 Backspace as control character, 201 Banks, memory, 31, 171 Base memory in CMOS RAM, 93 message for, 450, 458 BASIC, interrupts for, 9, 77 BAT (Battery Assurance Test), 476 Battery failure, 444 Baud rate generator for, 35, 331, 502 initialization of, 110, 338, 340, 345-346 ROM compatible address for, 100 Beep, bell character for, 201 Beep codes, 440, 442-443, 454 Bell as control character, 201 Bimodal operating systems, ABIOS for, 2 BIOS data area for, 5, 242 video state, 242, 248-250 See also ROM and ROM BIOS Blinking attribute, 206 Blocks moving of, 376-377 specifier for, 216-217 Blue value, address for, 250

### **B**, cont'd

Bootina error messages for, 441, 449, 457 and POST, 117, 449 service entry point for, 100 Bootstrap Loader interrupt, 9, 77, 433-437 Border control register, CGA, 494 Break key, Keyboard Service, 136-137 Breakpoint interrupt, 8, 76 Buffers fixed disk, 86, 320-321 keyboard, 79, 81, 116, 135, 147, 464, 486 video, 174-175, 238, 243 Build Initialization Table, System Services, 364 Build System Parameters Table. System Services, 363 Burst mode for DMA transfer, 45 Bus controller, 501 Bus sharing, 41 Busy devices, 381 printer, 430 BUSY math coprocessor signal, 26-27, 500 Bytes per sector parameter, 105, 264 С

Cables for multiscan monitors, 31, 505 Cancel set interval wait subfunction, 372 Capacity, diskette, 256 Caps Lock key, 133 and character code tables, 151

and pause state table, 139 status of, 145 Card selected feedback register. DMA, 61 Carriage return as control character. 201 CBIOS data area, 78-84 extended, 85-86 CDC fixed disks, 108, 299 Central Arbitration Control, 27 and DMA bus time-out errors, 125 and DMA controller, 45 and NMIs, 119 Century in CMOS RAM, 94, 411 CGA. See Color Graphics Adapter Character generators graphics mode, 183 ROM, 178-179 second text mode auxiliary, 185 text mode auxiliary, 182 Video Service for, 213 Get font pointer information, 228 Load 8x8 double dot text mode font, 215 Load 8x16 ROM text mode font. 217 Load ROM 8x8 double dot text mode font, 221 Load ROM 8x14 text mode font, 215, 220 Load ROM 8x16 text mode font, 222 Load user text mode font, 214, 219 Set block specifier, 216-217 Set user graphics font pointer at INT 1Fh, 223 Set user graphics font pointer at INT 43h, 224 Use ROM 8x8 double dot font for graphics, 226

C, cont'd Use ROM 8x14 font for graphics, 225 Use ROM 8x16 font for graphics. 227 Characters blocks of, 239, 241 codes for, 151-162 control, 197, 201 and fonts, address for, 100 height of, 81, 180, 248 printing of, 404 reading of, from screen, 194 receiving of, 343 sending of, 342 serial port, 34, 331, 340, 345, 502 size of, in video modes, 174-175 writing of, to screen, 195-197 Checksum and checksum errors, 442, 454 optional ROM, 457 power-on password, 94, 437 real time clock register for, 491 and ROM detection, 115 Clear Byte Pointer, DMA, 55, 63, 257, 483 Clear Mask Register, DMA, 56, 63, 483 Clearing of screen, 187 Clock generator, 36, 420, 424, 501, 507 Clock Time, 413 Read System Timer Day Counter, 418 Read System Timer Time Counter, 412 Real Time Clock ISR, 423-425 Reset Real Time Clock Alarm, 418 Set Real Time Clock Alarm, 417 Set Real Time Clock Date, 416 Set Real Time Clock Time, 414 Set System Timer Day Counter, 419

Set System Timer Time Counter, 413 System RAM for, 410, 421, 424 System Timer ISR, 420-422

Closing of devices, 369

CMOS RAM, 4-6, 40, 87 diskette drive type in, 276 for Diskette Service, 263 failure of, 442-443, 448 for Fixed Disk Service, 295-297 initialization and testing of, 113-114 I/O ports for, 89 for passwords, 54, 437 port addresses for, 60, 291, 357 reading from, 39 registers for, 5, 60, 89, 122, 257, 291, 357, 410, 425, 436 for System Services, 361 for Time-of-Day Service, 410-411, 425 writing to, 39

Collision detection, 200

Color Graphics Adapter compatibility of, 31, 163, 171, 174, 176, 505 cursor with, 189 display code for, 236 initialization of, 170 registers for, 494 screen writing by, 196 video paging in, 192

Color monitors, testing of, 443

Colors available, 238 paging mode for, 210, 212 registers for, 31, 208–209, 211 in video modes, 174–177 See a/so Palettes and palette registers

Columns on screen, 80, 180, 238, 248

### C, cont'd

Command byte for diskette controller, 80 for Intel 8042, 60, 172, 464, 467, 470 Command port, device, 488 Compatibility, 1 ABIOS for, 2 CBIOS for, 3 diskette, 254-255 keyboard, 143, 148 of ROM addresses, 100-101 of video modes, 31, 163, 171, 174, 176, 505 Configuration for adapter slots, 5 CMOS RAM data for, 92-94 data table for, 100 for disk drives, 29, 504 diskette controller register for, 71, 258, 496 error message for, 455 POS byte for, 295 Connectors, Micro Channel extension, 27 - 28Control characters for, 197, 201 EGA/VGA bits for, 82, 181, 249 fixed disk, 81, 107, 298, 491-492 keyboard port for, 487 parallel port. 33, 65, 68-69, 401-402, 493, 503 PIT word register for, 59, 121, 422 system port for, 515 system timer register for, 486 timer byte for, 356 timer channel registers for, 38 video bits for, 82, 180, 249 Controllers attribute, 30, 169-170, 247 CRT. See CRT controller diskette. See Diskette controller DMA, 41-48, 511-512 fixed disk, 29, 51, 114, 293, 504

interrupt, 121, 489, 508 keyboard. See Intel 8042 keyboard controller serial port, 34-35, 331, 502 Conversion logic, bus, 501 Coordinates, joystick, reading of, 373 Coprocessors. See Math coprocessors Copy protection, diskette, 275 Counts and counters of days, 84, 410, 421 in DMA controller, 42-44 PIT, 37-38, 59, 356 real time clock, 489 tick, 410 timer, 80, 357, 410, 418-419, 421, 424.486 wait, 84, 359, 424 CPU clock for, 36, 420, 424, 501, 507 initialization of, 113 testing of, 113, 442, 454 CRC (Cyclic Redundancy Check), 273 in CMOS RAM, 94 in extended CMOS RAM, 97 for fixed disks, 309 CRT controller, 30, 169, 504 address of, 238 index register, 68, 70, 172-173, 493-494 initialization and testing of, 114 registers for, 246 Ctrl kev, 133 and character code tables, 153-162 and pause state table, 139 status of, 145 Ctrl, Alt, and Del keys, 112, 119, 135-136 Ctrl-Break flag, 81 Ctrl and Break keys, 135-137

C. cont'd Ctrl and Num Lock keys, 136, 138 - 139Current mode select register, 80, 180, 248 Current pages address of, 80, 180, 248 number of, 80, 180, 248 size of, 80, 180, 248 Current palette value, 80, 180, 248 Current track number, 83, 262 Current video state, 244 Cursor in graphics modes, 176 positioning of, 80, 180, 190-191, 238. 248 scaling of, 233 type of, 80, 180, 188-189, 248 Cyclic Redundancy Check, 273 in CMOS RAM, 94 in extended CMOS RAM, 97 for fixed disks. 309 Cylinders, 107-109, 298 current number, 365 formatting of, 310 seeking of, 317 D DAC. See Digital-to-analog converters Data auxiliary device port for, 85 BIOS area for, 5 CBIOS area for, 78-84 CMOS RAM area for, 5, 60, 89, 122, 257, 291, 357, 425, 436 device port for, 488 diskette controller register for, 70,

diskette transfer rates, 82, 256, 261.280 DMA transfer of. See Direct memory access extended BIOS area for, 5, 385, 421. 432 extended CMOS RAM area for, 5, 40, 60, 89, 95-98, 291, 294, 410 keyboard/auxiliary port for, 59, 357, 436 length of, diskette, 106, 265 parallel port for, 33, 68-69, 401-402, 491-493, 503 video register for, 69, 172, 494 Date in CMOS RAM, 411 error message for, 445 in real time clock, 90, 415-416, 490 ROM compatible address for, 101 Day of week in CMOS RAM, 411 in real time clock, 90, 490 Days, count of, 84, 410, 421 Decreasing available memory message, 450, 458 Default settings for cursor, 189 for fonts, 179 for keyboard, 474-475 for mouse, 479 for palette, 232 for video modes, 177 Defect map, fixed disk, 108-109, 299-300 Delay diskette motor drive, 105, 264 typematic, 146, 474 Detect Media Change, Diskette Service, 279 Device Busy, System Services, 381

258, 496

**D.** cont'd Device Close, System Services, 369 Device driver far call initialization subfunction, 393-394 Device drivers, offset for, 85, 360 Device Open, System Services, 369 Devices closing of, 369 command port for, 488 mouse type, 479 opening of, 369 pointing type, 390 service routines for, 7, 10-12 size of, in DMA controller, 44 Diagnostic status in CMOS RAM, 92, 263, 295, 437 Diagnostics, fixed disk, long sectors for, 314-315 Diagnostics 1: Read Test Buffer, Fixed Disk Service, 320 Diagnostics 2: Write Test Buffer, Fixed Disk Service, 321 Digital input register, diskette controller, 71, 258, 496 Digital output register, diskette controller, 70, 258, 422, 495 Digital-to-analog converters, 30-31, 168-170, 505 color registers for, 211 port addresses for, 69, 172, 493 state of, 242, 250 Direct memory access arbitration levels for, 46 controller for, 41-48, 511-512 and Micro Channel, 27 port addresses for, 48, 55-56, 60-63, 482-484 time-out errors and messages for, 125-126, 451-452 Direct memory Access (DMA) Bus Time-out message, 452

Disable watchdog time-out subfunction, 395 DISKCOPY command (DOS), 271 Diskette BIOS Revector interrupt, 9. 77 Diskette controller command bytes for, 80, 260 information for, 83, 261 initialization and testing of, 114 parameter table for, 100 port addresses for, 70-71, 257-258, 495-496 Diskette Hardware Interrupt service, 282-283 Diskettes and disk hardware, 29 and ABIOS, 268 CMOS RAM data for, 263 current track number, 83, 262 data rate information for, 82, 255, 261 drive type of, 92, 254, 263, 278, 280, entry point for, 100 error handling for, 266-267 error messages for, 445, 447, 455 hardware environment for, 254-256 I/O ports for, 257-258 initialization and testing of, 114 IRQ assignment for, 51 media type, 83, 254, 261, 281 motor count for, 420 motor status of, 79, 259, 421 parameters table for, 9, 77, 105-106, 264-265, 276-277 recalibration status of, 79, 259, 283 resetting of, 304 ROM BIOS data for, 264–265 services for, 8, 17, 76, 251-253 Detect Media Change, 279 Diskette Hardware Interrupt, 282-283 Format Diskette Track, 274–275 Read Diskette Sectors, 271 Read Diskette Status, 270

### D, cont'd

Read Drive Parameters, 276-277 Read Drive Type, 278 Reset Diskette System, 269 Set Diskette Type, 280 Set Media Type for Format, 281 System RAM data for, 259-262 Verify Diskette Sectors, 273 Write Diskette Sectors, 272 status return code for, 80, 260 transfer rate of, 82 work area for, 83, 262 Display. See Screen; Video Display combination code index to, 181, 249 pointer to, 184 read/writing of, 236-237 Divide by Zero interrupt, 8, 76 Divisor latch, serial port, 65, 71, 332, 334.496 DMA. See Direct memory access Door, diskette, 279 DOS interrupts for, 6, 9, 77 system messages for, 202 Dot fonts, 178 Double dot fonts graphics mode, 226 text mode, 215, 221 Drive ready, testing for, 322 DSR (device service routines), 10-12 Dummy interrupt handler, 101

Е

Dynamic save area, 182

ECC (Error Correction Code), 315 Echo, keyboard, 474, 476 EGA. See Enhanced Graphics Adapter

EGA/VGA control bits, 82, 181, 249

EGA/VGA switch data, 82, 181, 249

84-key keyboard filtering, 143-144, 148, 153-157, 368

Emulation of video modes, 174–176

- Enable channel for setup POS subfunction, 396
- Enable/Disable cursor scaling video subfunction, 233
- Enable/Disable default palette loading during set mode video subfunction, 232
- Enable/Disable pointing device subfunction, 388
- Enable/Disable summing to gray shades video subfunction, 233

Enable/Disable video subfunction, 233

Enable register, real time clock, 489

Enable watchdog time-out subfunction, 395

End-of-interrupt process, 116

End of track, diskette, 106, 264

- Enhanced Graphics Adapter compatibility with, 31, 163, 171, 174, 176, 505 cursor with, 189 display code for, 236 initialization of, 170 screen writing in, 196 video paging in, 192
- Enter password message, 435, 453

Environment. See Hardware environment

EOI (end-of-interrupt) process, 116

Equipment installed in CMOS RAM, 93

## E, cont'd

Equipment List service, 16, 431 entry point for, 100 interrupt for, 8, 76 Error Correction Code, 315 Error handling for Diskette Service, 266-267 for Fixed Disk Service, 82, 301-303 for math coprocessors, 27 for parallel printer services, 404 by POST, 113, 118, 440-441 for Serial Communications Service. 339 for Time-of-Day Service, 412 See also Parity errors Error log numbers for, in extended CMOS RAM, 97-98 POST, 85, 360, 366-367, 440 Error messages, 439-441 beep codes, 442-443, 454 boot failure, 441, 449, 457 information, 450 Model 25 and 30, 454-459 password, 453 run time, 451-452 system failure, 444-448 ESDI drives formatting of, 326-327, 365 ROM for. 288 Event wait interval. 371-372 Expansion memory in CMOS RAM, 93, 361 message for, 450, 458 size of, 94 Extended BIOS data area, 5, 85-86, 385, 421, 432 Extended CMOS RAM data area for, 5, 40, 60, 89, 95-98, 291, 294, 410 as feature, 103 port addresses for, 60, 89, 291

Extended commands pointing device subfunction, 391 Extended function execute register. DMA, 56, 289 Extended function register, DMA, 56, 121. 289 Extended Initialize serial communications service, 345-346 Extended keyboard, 148-150 Extended memory message for, 450, 458 size of, 97, 378 Extended mode DMA, 48 parallel port. 33 register for, 495 Extended Serial Port Control service, 347 - 350Extended System RAM for System Services, 360 Extension connectors, Micro Channel, 27 Extension registers, interrupt controller, 489 Extra memory, message for, 450, 458 F FDISK command (DOS), 326 Feature control, VGA, 68-70, 103-104, 172-173, 493-494 Feature information byte in System Configuration Table, 102, 362, 384 FIFO control register, serial port, 66, 72, 333, 335 Filler byte, diskette, 106, 265

Filtering of keyboard, 143-144, 148, 153-157, 368

F. cont'd Firmware, Intel 8042, 466-468 Fixed disk and ABIOS, 303 arbitration levels for, 86, 294 buffer for, 86 CMOS RAM for, 295-297 control byte, 81 controllers for, 29, 51, 114, 293, 504 and Diskette Service, 252 drive type for, 92, 295, 324 entry point for, 100 error handling of, 301-303 error message for, 455 error register for, 82 failure of, 447-448 hardware environment for, 288 interrupt for, 8-9, 76-77 interrupt flag for, 82, 293 I/O ports for, 289-292 number of, 81, 260, 293, 437 parameters table for, 9, 77, 86, 97, 100, 107-109, 294, 297, 311-313 port registers for, 64, 67-68, 81, 292, 298, 491-492 ROM BIOS for, 298-300 services for, 18, 285-287 Alternate Reset Fixed Disk, 318-319 Diagnostics 1: Read Test Buffer, 320 Diagnostics 2: Write Test Buffer, 321 Format Disk Cylinders, 310 Format ESDI Drive, 326-327 Initialize Drive Parameters, 313 Park Heads, 325 Read Disk Sectors, 306-307 Read Disk Status, 305 Read Disk Type, 324 Read Drive Parameters, 311-312 Read Long Disk Sectors, 314-315 Recalibrate Drive, 323 Reset Diskette(s) and Fixed Disk, 304

Seek to Cylinder, 317 Test for Drive Ready, 322 Verify Disk Sectors, 309 Write Disk Sectors, 308 Write Long Disk Sectors, 315-316 status register for, 82 System RAM for, 293-294 Fixed Disk Read Failure message, 449 Flag register and interrupts, 6, 10 Flags Ctrl-Break, 81 in DMA controller, 42-43 extended keyboard status, 150 fixed disk interrupt, 82, 293 keyboard shift, 79 in keyboard status register, 464 pointing device, 85, 360 shift, 134-135, 145 system control, 53 System Reset, 81, 437 24 hour roll over, 80, 410, 421, 424 user wait, 84, 359, 424 wait active, 84, 262, 359, 424 Flashing displays, 198 Floating point operations, 26, 500 Fonts default, 179 double dot graphics mode, 226 text mode, 215, 221 pointers for, 223-224, 228 ROM, 178 graphics mode, 225, 227 text mode, 215, 217, 220-222 sequencer for, 30, 169 size of, 218 user graphics, 223-224 text mode, 214, 219

FORMAT command (DOS), 326

# F, cont'd

Format Disk Cylinders, Fixed Disk Service, 310

Format Diskette Track, Diskette Service, 274–275

Format ESDI Drive, Fixed Disk Service, 326–327

Format ESDI Drive Periodic Interrupt, System Services, 365

Format of first byte of diskette, 105, 264

Format/4 command (DOS), 255

Function descriptions, 11-12

Function register in DMA controller, 43 Functionality/State Table, 237-241

# G

Game control adapter, 373-374 Game port address, 64 Gap length, diskette, 106, 265 Gate array I/O support, 502-506 system support, 501 General expansion ROM, 115 Get font pointer information video subfunction, 228 Get Time function (DOS), 371, 375 Global Descriptor Table, 376-377, 379-380 GRAFTABL command (DOS), 223 Graphics controller, VGA, 30, 169, 247 Graphics modes, 174-176 character generator for, 183 fonts for, 223-227 VGA registers for, 69, 173, 494

writing to screen in, 196 Gray scale summing, 233 Gray shades, 212 Green value, address for, 250

# Η

Hardware environment, 23-24, 481 clock generator, 36 CMOS RAM, 40 for Diskette Service, 29, 254-256 DMA controller, 41-48, 511-512 for Fixed Disk Service, 288 independence from, 1, 3 Intel 8259 Programmable Interrupt Controller, 513-514 interrupt controller extensions, 508 interrupts for, 7-9, 282-283 I/O port list, 55-73, 482-498 I/O support gate array, 502-506 for Keyboard Service, 32, 131 math coprocessors, 26-27, 500 Micro Channel, 27-28 microprocessors, 25, 499 NMI mask, 54, 515 parallel port, 33 for Parallel Printer Service, 401-402 parameter tables for, 7 POST tests for, 113-114 power-on passwords, 54 Programmable Interrupt Controller, 50 - 51Programmable Interval Timer, 37-38 Programmable Option Select, 49 real time clock, 39 for Serial Communications Service, 34-35, 331 system board status port, 515 system control ports, 52-53, 515 for System Services, 356 system support gate array, 501 for system timers, 36-39, 507, 509-510

H. cont'd for Time-of-Day Service, 410, 421, 424 for Video Service, 30-31, 168-171 video state of, 242, 245-247 Hardware Retriggerable system timer modes, 37, 510 Heads diskette, 275 fixed disk, 107-109, 298, 325 seek delay time of, 106, 265 Height, character, 81, 180, 248 High density diskettes, 255 Hours in CMOS RAM, 411 in real time clock, 90, 490

# I

IBM fixed disks, 108–109, 299–300 Identification of adapter cards, 49 of fixed disks, 288

Inactive display code, 238

Index register, CRT controller, 68, 70, 172–173, 493–494

Information messages, 450

Inhibit switch in keyboard status register, 464

Initialization of baud rate, 110, 338 and building of Systems Parameter table, 363 of DMA controller, 43 error messages for, 455 failures during, 440, 442 of interrupt vectors, 7 of pointing devices, 391, 393–394 during POST, 113–114 of video adapters, 170 of windows, 193 Initialization Command Words, DMA, 57, 289–290, 484–485

Initialization Table, building of, 364

Initialize Drive Parameters Fixed Disk Service, 313

Initialize Printer service, 405

Initialize Serial Communications Port service, 340–341

INMOS G171 DAC converter, 30-31

Input extended keyboard, 148 Intel 8042 commands for, 471–472 keyboard, 143, 464–465 VGA status registers for, 68–709, 172–173, 231, 493

Insert key and pause state table, 139 status of, 145

Installed memory parameter in system RAM, 78

Intel 8042 keyboard controller, 32, 131, 356, 461–463 commands and status registers for, 60, 172, 464, 467, 470 initialization and testing of, 113 interfacing by, 468–469 port addresses for, 60, 172, 357, 436, 465 status register for, 464 system commands for, 470–472 See a/so Keyboard

Intel 8086 microprocessor, 499

Intel 8087/80287/80387 math coprocessors, 26–27, 500 exceptions for, 9, 77, 127

Intel 8237 DMA Controller, 41, 113, 356

Intel 8253 Programmable Timer chip, 509-510

Intel 8254A Programmable Interval Timer, 37–38, 113, 507

- Intel 8259A Programmable Interrupt Controller, 50–51, 113, 356, 422, 513
- Intel 80286/80386/80386SX microprocessors, 25
- Intel 82284 Clock Generator, 36, 420, 424, 507
- Intel 82385 Cache Controller, 113
- Intensity/blink bit, setting of, 206
- Intercept, keyboard, 368
- Internal function requests for Keyboard Service, 136
- Interrupt Complete, System Services, 382
- Interrupt on Terminal Count, system timer mode, 37, 510
- Interrupt request/In-service registers, PIC, 56. 289, 484

Interrupts and interrupt vectors, 5-9 controller for, 121, 489, 508 enable register for, 65, 71, 334, 497 fixed disk adapter status register for, 68, 492 fixed disk flag for, 82, 293 identification register for, 65, 71, 332, 335, 497 level-sensitive, 27, 34, 50, 331, 513 loading of, 443, 454 maskable, 50 PIC mask registers for, 57–58, 290, 485 request line for, 7 ROM compatible address for, 101 sharing of, 514 software, 7-12 table of, 5-9 See also Nonmaskable interrupts

Invalid configuration messages, 445

Invalid Op Code interrupt, 8, 76

- Invalid Task Segment State interrupt, 8, 76
- I/O Card Parity Error message, 123, 451, 459
- I/O Channel Check Activated message, 124, 452
- I/O devices, 29-35, 502-506
- See also specific devices
- I/O expansion ROM, 115
- I/O ports, 55–73, 482–498
  for bootstrap loader service, 436–437
  for CMOS RAM, 89
  for Diskette Service, 257–258
  for Fixed Disk Service, 289–292
  for Keyboard Service, 134, 465
  for nonmaskable interrupts, 121–122
  for Serial Communications Service, 332–336
  for System Services, 356–358
  for Time-of-Day Service, 422, 425
  for Video Service, 172–173

Isolation, hardware, 1, 3

ISR (Interrupt Service Routines), 24

# J

Joysticks, 356 device support for, 32 port for, 358 System Services for, 373–374

## Κ

Keyboard, 32, 356, 506 alternate, layout for, 368 Break, 137

K. cont'd buffers for, 79, 81, 116, 135, 147, 464.486 and character codes, 153-162 data port for, 59, 357, 436 error messages for, 456 extended, 148-150 entry point for, 100 failure of, 446-447 hardware environment for, 131 ID for. 474 initialization and testing of, 114 I/O ports for, 134 interface command for, 471 interrupt controller extensions for, 508 interrupts for, 8, 51, 76 internal function requests, 136 keyboard-to-system communication, 132–133 Pause, 138-139 Print Screen, 140 and reading of character code tables, 151-152 scan codes and character code tables for, 151 security for, 435, 453 services for, 21, 129-130 Read Extended Keyboard Input, 148 Read Keyboard Input, 143 Return Extended Keyboard Status, 149 **Return Extended Shift Flags** Status, 150 Return Keyboard Status, 144–145 Return Shift Flag Status, 145 Set Typematic Rate and Delay, 146 shift flags for, 79, 134-135, 145, 150 status register for, 135, 144-145, 464 Store Key Data, 147 System RAM data for, 134–135 System Request, 141

System Reset, 136 system communication with, 132–133, 474–476 system replies from, 476 See a/so Intel 8042 keyboard controller Keyboard Break interrupt, 9, 77

Keyboard controller test failure, 443, 454

Keyboard Intercept System Services, 368

# L

Landing zones, fixed disk, 107-109, 298.325 Last unexpected interrupt, 80 LED toggle status indicators, 474 Level-sensitive interrupts, 27, 50, 513 Light pen position, 191 LIM EMS Driver interrupt, 9, 77 Line control register, 66, 72, 333, 335.497 Line feed as control character, 201 Line status register, 67, 73, 334, 336, 341, 344-346, 498 Load 8x8 double dot text mode font subfunction, 215 Load 8x16 ROM text mode font subfunction, 217 Load ROM 8x8 double dot text mode font subfunction, 221 Load ROM 8x14 text mode font subfunction, 215, 220 Load ROM 8x16 text mode font subfunction, 222 Load ROM BASIC interrupt, 8, 76

Load user text mode font video subfunction, 214, 219 L, cont'd Loader, bootstrap, 433-437 Loading of fonts, 179 Logarithmic operations, 26, 500 Logical interrupts, 7-8 Long disk sectors, 314-316 Low level fixed disk formatting, 326-327

### Μ

Main status register, diskette, 496 Make codes, 153-162 Manufacturers of fixed disks, 18, 299 - 300Manufacturing checkpoint ports, 73 Manufacturing port register, 489 Mask register, DMA, 43, 55, 62, 257, 483 failures in, 443, 454 Maskable hardware interrupts, PIC for, 50 Masks interrupt controller, 358 NMI, 54, 515 PIC, 62, 410, 485 video DAC PEL, 69, 172, 493 Master Clear, DMA, 55, 63, 483 Master DMA register failure, 443, 454 Master PIC, 425 Math Coprocessor Not Present interrupt, 8, 76 Math coprocessors, 26-27, 500 exceptions generated by, 127 IRQ assignment for, 51 port address for, 63 MCGA. See Multicolor Graphics Array

MDA. See Monochrome Display Adapter Media detection of change in, 279 types of, diskette, 83, 254, 261, 281 Memory address register for, 55, 62, 257, 482 commands for, 470 controller for, 501 error messages for, 456-457, 459 extended, 97, 378, 450, 458 failures in, 442-443, 445-446, 454 installed, 78 messages for, 450-452 moving blocks of, 376-377 registers of, as feature, 103-104 video, 30-31, 171, 239, 505 See also CMOS RAM; System RAM Memory map 2 for fonts, 178 Memory maps and attribute bytes, 216 Memory Parity Error message, 123, 451 Memory Refresh arbitration level, 46 Memory Size service, 17, 432 entry point for, 100 interrupt for, 8, 76 Memory tests terminated by keystroke message, 450, 458 Messages password, 435 system, 202 See also Error messages Micro Channel, 27-28, 97 Microprocessors, 25, 499 arbitration level for, 46 and DMA, 44, 511 Intel 8042 interfacing to, 468-469 Miniscribe fixed disks, 108, 299

### M, cont'd Minutes in CMOS RAM, 411 in real time clock, 90, 490 Miscellaneous information in CMOS **RAM. 94** Miscellaneous output register, VGA, 69, 172-173, 493-494 Model 25 and 30 beep codes for, 454 error messages for, 455-459 video modes for, 175 Model byte in System Configuration Table, 102, 362, 383-384 Models, features of, 103-104 Modem control register, 66, 72, 333, 335, 497 reading and writing of, 348-350 Modem status register, 67, 73, 334, 336, 341, 344-346, 498 Modems, conversion of data from, 35 Modes CGA control register for, 494 DMA register for, 43, 55, 63, 257, 483 select register for, 80, 180, 248 system timer, 37-38, 510 video, 174-176, 238-241 Monitors support for, 31, 171, 177, 505 testing of, 443 Monochrome Display Adapter compatibility with, 31, 163, 171, 174, 176 cursor with, 189 display code for, 236 initialization of, 170 Monochrome monitors, testing of, 443 Month

in CMOS RAM, 411

in real time clock, 90, 490 Motor, diskette count for, 420 start time, 106, 265 status of, 79, 259, 421 turn-off delay, 105, 264 Motorola MC146818A Real Time Clock, 39, 90, 408, 421, 423-424 CMOS RAM for, 40 Mouse, 356 device support for, 32 IRQ assignment for, 51 system commands to, 477-479 system replies from, 480 Move Block System Services, 376-377 Multicolor Graphics Array cursor with, 189 display code for, 236 modes for, 174-175 support for, 504 Multiscan monitor support, 31, 505 Multitasking operating systems

ABIOS for, 2, 25 services for, 369–370, 374, 381–382 support for, 282

# Ν

National Semiconductor 16550 serial port controller, 34-35, 331, 502

NEC 765 diskette controller, 29, 254, 503

New password has been installed message, 435, 453

NMI. See Nonmaskable interrupts

No Boot Device Available message, 117, 434, 449

### N, cont'd

No Boot Sector on Fixed Disk message, 449 No Error Detected Intel 8042 reply, 473 No Password Installed Intel 8042 reply, 473 Nonmaskable interrupts, 8, 76, 119-120 arbitration level for, 46 coprocessor exceptions, 127 entry point for, 100 error message for, 451-452 I/O ports for, 121-122 masks for, 54, 515 parity error handling by, 123-124 time-out error handling by, 125 - 126Not a Boot Diskette message, 449 Num Lock key, 133, 136, 138-139 and character code tables, 151 and pause state table, 139 status of, 145 Number cylinder, 365 of fixed disks, 81, 260, 293, 437 of installed devices, 78, 403 for interrupts, 6-9 page, 80, 180, 192, 248 track, 83, 262 Numeric exception error handling, 27 Numeric keypad input, work area for, 79

# 0

101-key keyboard, 143-144, 149, 152
Offset, device driver, 85, 360
Opening of devices, 369
Operating System Bootstrap Loader function, 112 Optional ROM checksum errors, 444, 457 Out of paper condition, 430 Output buffer, keyboard, 464, 486 Output port, keyboard, 465, 472 Overflow interrupt, 8, 76 Overrun characters, keyboard, 476 Overscan register, 205–207

# Ρ

Page table address registers, DMA, 60 Pages, video, 174-175 active, setting of, 192 addresses of, 80, 180, 248 modes for, 210, 212 number of, 80, 180, 192, 248 register for, 257, 442, 454, 488, 512 scrolling of, 193 size of, 80, 180, 248 Palettes and palette registers default, enabling/disabling of, 232 reading of, 207 setting of, 198, 205-206 user profile table for, 186 value in, 80, 180, 248 Parallel ports, 491-493 addresses for, 33, 64-65, 68-69, 401-402, 493, 503 failure of, 447 hardware for, 33, 503 IRQ assignment for, 51 Parallel Printer Service, 22, 399-400 error handling for, 404 hardware environment for, 401-402 Initialize Printer, 405 interrupts for, 8, 76

P. cont'd services for, 404-406 Print Character, 404 Read Printer Status, 406 System RAM data for, 403 Parallel-to-serial conversions, 35 Parameter passing for functions, 10 - 11Parameters and parameter tables, 7 diskette, 9, 77, 105-106, 264-265, 276-277 fixed disk, 9, 77, 86, 97, 100, 107-109, 294, 297, 311-313 system, building of, 363 system configuration, 383-384 video, 182, 249 Parity errors, 442, 454 in keyboard status register, 464 messages for, 451, 456, 459 NMI handling of, 123-124 Parity modes, serial port, 34, 331, 340, 345, 502 Park Heads Fixed Disk Service, 325 Password has been removed message, 435, 453 Password Installed Intel 8042 reply, 473 Password is incorrect message, 435, 453 Password Ok message, 435, 453 Passwords and CMOS RAM, 93 disabling of, 103-104 Intel 8042 commands for, 470 messages for, 435, 453, 473 power-on, 54, 94, 434-435, 437 Pause Keyboard Service, 136,

PEL addresses, DAC, 69, 172, 493-494

138-139

Periodic interrupt processing, 365, 423

PGA (Professional Graphics Adapter), display code for, 236

Physical DMA channels, 47

PIC. See Programmable Interrupt Controller

PIO (programmed I/O), 43

PIT. See Programmable Interval Timer

Pixels, 199-200, 250

Planar control registers, 487-488

Pointers

to DCC table, 184

to dynamic save area, 182

- for fonts, 223-224, 228
- to graphics mode character generator, 183

to second text mode auxiliary character generator, 185

state of, 239

- to text mode auxiliary character generator, 182
- to user palette profile table, 186
- to video parameter table, 182
- to Video Service pointer table #2, 183

Pointing device interface initialization subfunction, 391

Pointing Device Interface, System Services, 386–394

Pointing devices failures in, 448 flag for, 85, 360 initialization and testing of, 114 interface for, 32, 506 interrupt controller extensions for, 508 interrupts for, 9, 77 services for, 386–387 Device driver far call initialization, 393–394

### P, cont'd

Enable/Disable pointing device. 388 Extended commands, 391 Pointing device interface initialization, 391 Read device type, 390 Reset pointing device, 388 Return status, 392 Set resolution, 390 Set sample rate, 389 Set scaling factor to 1:1, 393 Set scaling factor to 2:1, 393 Pop up utilities, function for, 203 Port offset, fixed disk, 81 Ports. See I/O ports; Parallel ports; Serial ports POS. See Programmable Option Select Position select register, 61 Positioning of cursor, 80, 180, 190-191, 238, 248 of fixed disk head, 317 of I/O expansion RAM, 115 of light pen, 191 POST. See Power-on self tests Power-on passwords, 54, 94, 434-435, 437 Power-On Self Test Error Log System Services, 366-367 Power-on self tests, 111-114, 366-367 beep codes by, 442-443 boot failure messages by, 449 and bootstrap loader, 433 and CRC in extended CMOS RAM, 97 for EBDA, 385 entry point for, 100 error codes, number of, 85, 360 error handling by, 118, 440-441

error log by, 85, 360, 366-367 information messages by, 450 and I/O expansion, 115 and memory size, 432 and passwords, 54 for POS registers, 28, 49 and real-mode re-entry, 116 and Serial Port Table, 337 and system boot, 117 and system equipment list, 431 System RAM for, 84 for vector initialization, 7 Video Service tables initialization durina, 181 Power-on video default modes, 177 Power-up entry points, ROM compatible, 101 Primary Video Service table, 181-182 Print Character, Parallel Printer Service, 404 Print Screen and Print Screen, Keyboard Service, 13, 136, 140, 429-430 alternate routine for, 231 entry point for, 101 interrupt for, 8, 76 status byte for, 84, 429 Printer adapters for, 78, 403 busy, 430 entry point of services for, 100 time-out table for, 81 Priorities and bus sharing, 41 Processor interrupts for, 7 switching of, to protected mode, 379-380 Professional Graphics Adapter, display code for, 236 Program counter and interrupts, 6, 10 Program Termination, System Services, 370

### **P**, cont'd

Programmable baud rate generator, 35. 331. 502 Programmable Interrupt Controller. 50-51.356 master and slave, 425 port addresses for, 56-58, 61-62, 291. 484-486 Programmable Interval Timer, 507 counter for, 37-38, 59, 356 failure of, 442 port addresses for, 58-59 Programmable Option Select, 49 configuration bytes for, 93-94, 295 in extended CMOS RAM, 95-97 and Micro Channel, 27-28 port addresses for, 61, 64 registers for, 122 Programmable Option Select, System Services, 396-397 Programmed I/O, 43 Protected address mode, 25 error message for, 457 for math coprocessor, 26 switching to, 379-380 PS/2 systems, 3 features in, 103 parity error handling in, 124 time-out error handling in, 126 Pulse output port, keyboard, Intel 8042 command for, 472 R RAM. See CMOS RAM; Memory; System RAM

Rate Generator, system timer mode, 37, 510

Raw keyboard data stream, filtering of, 368

Read all palette registers and overscan video subfunction, 207

Read block of color registers video subfunction, 211

Read Character/Attribute from Screen, Video Service, 194

- Read color paging status video subfunction, 212
- Read Current Cursor Position, Video Service, 191
- Read current switch settings joystick subfunction, 373

Read data command for mouse, 478

Read device type subfunction, 390

Read Disk Sectors, Fixed Disk Service, 306–307

Read Disk Status, Fixed Disk Service, 305

Read Disk Type, Fixed Disk Service, 324

Read Diskette Sectors, Diskette Service, 271

Read Diskette Status, Diskette Service, 270

Read Drive Parameters, Diskette Service, 276–277

Read Drive Parameters, Fixed Disk Service, 311-312

Read Drive Type, Diskette Service, 278

Read Extended Keyboard Input, Keyboard Service, 148

Read Extended Memory Size, System Services, 378

Read individual palette register video subfunction, 207

Read Keyboard Input, Keyboard Service, 143

### R, cont'd

Read Light Pen Position, Video Service, 191 Read Long Disk Sectors, Fixed Disk Service, 314-315 Read operation for System Control Port. 52 Read overscan register video subfunction, 207 Read Pixel, Video Service, 200 Read POST error log subfunction, 366 Read Printer Status, Parallel Printer Service, 406 Read Real Time Clock Alarm and Status, Time-of-Day Service, 418 Read Real Time Clock Date, Time-of-Day Service, 415 Read Real Time Clock Time, Timeof-Day Service, 413 Read resistive inputs joystick subfunction, 374 Read Serial Port Status, Serial Communications Service, 344 Read single DAC color register video subfunction, 211 Read System Timer Day Counter, Time-of-Day Service, 418 Read System Timer Time Counter, Time-of-Day Service, 412 Read the modem control register subfunction, 348 Read/write counter, PIT, 59 Read/Write Display Combination Code, Video Service, 236-237 Reading of attributes, 194 of character code tables, 151-152 from CMOS RAM, 39 of extended keyboard input, 148

READY input, CPU, 36 Real address mode, 25 for math coprocessor, 26, 500 re-entry of, 116 Real time clock, 39, 408, 421, 423-424 alarm in, 90, 417-418, 489-490 battery failure for, 444 CMOS RAM for, 5 data definitions for, 90 date in, 415-416 generator for, 36, 420, 424, 501, 507 interrupt controller extensions for, 508 interrupt for, 9, 51, 77 I/O ports for, 489-490 reading and writing of, 423-425 time in, 413-414 Rebooting and NMI clearing, 119 Recalibrate Drive, Fixed Disk Service, 323 Recalibration status, diskette drive, 79, 259, 283 Receive Character, Serial Communications Service, 343 Receiver buffer register, 65, 71, 332, 334, 496 Recursive print screen requests, 430 Red value, address for, 250 Redirect Cascade interrupt, 9, 77, 51 Redirection of Diskette Service, 252 Reference diskette or ADF files, 28, 49 and passwords, 54 for POST, 97, 113 Refresh register in DMA controller, 43 Refresh verification failure, 442, 454 Remote mode, mouse, 479

### R, cont'd

Resends, Intel 8042 firmware, 467-468 keyboard commands and reply for, 473. 475-476 mouse command and reply for, 479-480 Reset Diskette System, Diskette Service, 269 Reset Diskette(s) and Fixed Disk, Fixed Disk Service, 304 RESET input, CPU, 36 Reset pointing device subfunction. 388 Reset Real Time Clock Alarm, Timeof-Day Service, 418 Resetting of fixed disk, alternate, 318-319 of keyboard, 475 of mouse, 479 pointer to code for, 80 of system, 112, 136 vector for, 112 Resolution of default fonts, 179 of mouse, 477 of pointing devices, 390 of video modes. 174-175 Restore current video state subfunction. 244 Return base POS adapter register address subfunction, 396 Return Extended BIOS Data Area. System Services, 385 Return Extended Keyboard Status, Keyboard Service, 149 Return Extended Shift Flags Status. Keyboard Service, 150 Return Functionality/State Information, Video Service, 237-241

Return Keyboard Status, Keyboard Service, 144-145

- Return save/restore buffer size needed video subfunction, 243
- Return Shift Flag Status, Keyboard Service, 145
- Return status pointing device subfunction, 392
- Return System Configuration Parameters, System Services, 103, 383–384
- Return VGA Information video subfunction, 230–231
- Return Video Status, Video Service, 203
- Revision level in System Configuration Table, 102, 362, 383
- RGB analog values in DAC, 31, 169, 208

ROM and ROM BIOS. 5, 99 baud rate initialization, 110 character generators for Video Service in, 178-179 checksum failure in, 442, 454 compatibility table for, 100-101 diskette parameters table, 105-106 for Diskette Service, 264-265 for ESDI drives, 288 feature control, 103-104 fixed disk parameters table. 107 - 109for Fixed Disk Service, 298-300 graphics mode fonts in, 225-227 initialization and testing of, 113 I/O expansion, 115 option, checksum failure in, 444, 457 for Serial Communications Service, 338 System Configuration Table, 102 for System Services, 362

### R, cont'd

text mode fonts in, 215, 217, 220–222 video, failure of, 443, 454 video expansion, 115 Rows, screen, 81, 180, 238, 248, 429 RS–232 devices, 337, 356 Run time errors, 451–452

### S

Sample rate for pointing devices, 389, 479 Save current video state subfunction, 244 Save/Restore Video State, Video Service, 242-250 Scaling cursor, 233 mouse, 477 pointing device, 393 Scan codes, 133, 368, 474 Scan lines, 31, 505 selection of, for text modes, 232 in video modes, 239-240 Scratch register, 67, 73, 334, 336, 498 Screen clearing of, 187 columns on, 80, 180, 248 dimensions of, 174-175 failure of memory for, 443, 454 printing of, 429-430 rows on, 81, 180, 248, 429 settings for, 203 See also Video Scroll Current Page Up/Down, Video Service, 193 Scroll Lock key, 133, 136-137 and pause state table, 139

status of, 145 Seagate fixed disks, 108, 299 Second text mode auxiliary character generator, 185 Secondary Video table, 181, 184-186 Seconds in CMOS RAM, 411 in real time clock, 90, 489 Sectors boot, loading of, 433-437 bytes per, 105, 264 fixed disk long, reading of, 314-316 reading of, 306-307 verifying of, 309 writing of, 308 number of, 275 reading of, 271 track diskette, 254 fixed disk, 107-109, 298 Security, keyboard, 435, 453, 470 Seek to Cylinder, Fixed Disk Service, 317 Select color paging mode video subfunction, 210 Select New Video Page, Video Service, 192 Select scan lines for text modes video subfunction, 232 Self test, Intel 8042, 471 Send Character, Video Service, 342 Sequencer, VGA, 30, 169 registers for, 69, 172, 245, 493 Serial ports, 491, 502 addresses for, 65-67, 71-73, 332-336 controller for, 34-35, 331, 502 entry point for, 100

error handling for, 339 failure of. 447 hardware environment for, 34-35, 331 initialization and testing of, 114 interrupts for, 8, 76 I/O ports for, 332-336 IRQ assignment for, 51 registers for, 496-498 ROM BIOS data for, 338 services for, 19, 329-330 Extended Initialize, 345-346 Extended Serial Port Control. 347 - 350Initialize Serial Communications Port. 340-341 Read Serial Port Status, 344 Receive Character, 343 Send Character, 342 System RAM for, 337 time-out table for, 81, 337

Serial terminal, display as, 201

Serial-to-parallel conversions, 35

Set all palette registers and overscan video subfunction, 206

- Set block of color registers video subfunction, 209
- Set block specifier video subfunction, 216-217
- Set Color Palette, Video Service, 198
- Set Cursor Position, Video Service, 190
- Set Cursor Type, Video Service, 188–189
- Set Diskette Type, Diskette Service, 280
- Set Event Wait Interval, System Services, 371–372
- Set individual color register video subfunction, 208
- Set interval wait subfunction, 372

- Set Media Type for Format, Diskette Service, 281
- Set overscan register video subfunction, 205
- Set Palette/Color Registers, Video Service, 204 Read all palette registers and overscan, 207 Read block of color registers, 211 Read color paging status, 212 Read individual palette register, 207 Read overscan register, 207 Read single DAC color register, 211 Select color paging mode, 210 Set all palette registers and overscan, 206 Set block of color registers, 209 Set individual color register, 208 Set overscan register, 205 Set single palette, 205 Sum color values to gray shades,
  - 212 Toggle intensity/blink bit, 206
- Set Real Time Clock Alarm, Time-of-Day Service, 417
- Set Real Time Clock Date, Time-of-Day Service, 416
- Set Real Time Clock Time, Time-of-Day Service, 414
- Set resolution pointing device subfunction, 390
- Set sample rate pointing device subfunction, 389
- Set scaling factor to 1:1 pointing device subfunction, 393
- Set scaling factor to 2:1 pointing device subfunction, 393
- Set single palette video subfunction, 205
- Set System Timer Day Counter, Time-of-Day Service, 419

Set System Timer Time Counter, Time-of-Day Service, 413 Set Typematic Rate and Delay, Keyboard Service, 146 Set user graphics font pointer at INT 1Fh video subfunction, 223 Set user graphics font pointer at INT 43h video subfunction, 224 Set Video Mode, Video Service, 187 Setup enable register, system board, 61, 358, 436 Sharing of buses. 41 of interrupts, 514 Shift key, 133 and character code tables, 153-162 flags for, 79, 134-135, 145, 150 and pause state table, 139 Shift and Print Screen keys, 136 Shutdown code values for, 116 failure message for, 457 reason for, in CMOS RAM, 92, 361 Sign-on password control, 435 Single function services, 427-437 Single Step interrupt, 8, 76 Single-tasking operating systems, 25 Size of characters, 174-175 current page, 80, 180, 248 cursor, 188 of diskette drives, 254-255 of memory, 94, 97, 358, 432 service for, 8, 17, 76, 100, 432 Slave DMA register failure, 443 Slave PIC, 425 Software interrupts, 7–12

Software Triggered Strobe system timer mode, 37, 510 Software vector number, 487 Speeds, microprocessor, 25, 499 Spelling utility, screen reading with, 194 Square Wave system timer mode, 37, 510 ST506 fixed disk adapter, 29, 288, 504 Standard memory, message for, 450, 458 Start time, diskette motor, 106, 265 Status and status registers of auxiliary device, 392 CMOS RAM, 91, 361, 425 of diskette motors, 79, 259, 421 for diskettes, 70, 80, 257, 260, 270, 283 in DMA controller, 43, 55, 62, 257, 482 extended keyboard, 149 extended shift flags, 150 for fixed disk, 82, 305, 492 keyboard, 135, 144-145, 464 from last disk operation, 81, 260, 293 for mouse, 478 parallel port, 33, 65, 68, 401-402, 491, 493, 503 for print screen, 84, 429 printer, reading of, 406 real time clock, 418, 489 serial port, 344 shift flag, 145 system board, 515 system RAM, 83-84 Time-of-Day, 411 VGA, 495 video, 203, 237-241, 244 Stop bits, serial port, 34, 331, 340, 345, 502

Store Key Data service, 147

Stream mode for mouse, 478

Strike the F1 key to continue message, 450, 458

Strings, writing of, 235

Subaddress extension, POS, 64

Subfunctions, 10, 13

- Submodel byte in System Configuration Table, 102, 362, 383
- Sum color values to gray shades video subfunction, 212
- Switch data, EGA/VGA, 82, 181, 249
- Switch Display video subfunction, 234
- Switch Processor to Protected Mode, System Services, 379–380
- Switch to alternate print screen routine video subfunction, 231

SysReq key, 136, 141 service for, 374

System

booting of, 117 clock generator for, 501 configuration parameters for, 363, 383-384 failure of, 440, 444-448 gate array for, 501 keyboard communication with. 132-133, 470-472, 474-476 keyboard status register flag for, 464 messages for, 202 mouse commands for, 477-480 reset flag for, 81, 437 resetting of, 136 scan codes for, 133, 151 System board

copy of, 94 failure of, 444-445 setup of, 64 status of, 487, 515

System Board Memory Failure message, 124, 452

System Configuration Table, 102, 362, 383–384

- System control ports addresses for, 59–61, 121–122, 172, 291, 357, 422, 436, 487 definition for, 52–53, 515
- System halted! message, 435, 453
- System model ID, ROM compatible address for, 101
- System Parameters table, building of, 363
- System RAM, 4-6, 75 CBIOS data area, 78-84, 293 CBIOS extended data area, 85-86 for Diskette Service, 259-262 for Fixed Disk Service, 293-294 initialization and testing of, 113-114 interrupt vectors for, 76-77 for Keyboard Service, 134-135 for Parallel Printer Service, 403 for Serial Communications Service. 337 for System Services, 359 for Time-of-Day Service, 410, 421, 424 for Video Service, 180-186 System request and System Request
- Key service, 136, 141, 374
- System Reset, Keyboard Service, 136

System Services, 19–21, 351–355 Build Initialization Table, 364 Build System Parameters Table, 363 CMOS RAM for, 361 Device Busy, 381 Device Close, 369 Device Open, 369 entry point for, 100 extended System RAM for, 360

Format ESDI Drive Periodic Interrupt, 365 hardware environment for, 356 interrupt for, 8, 76 Interrupt Complete, 382 I/O ports for, 356-358 Joystick Support, 373-374 Keyboard Intercept, 368 Move Block, 376-377 Pointing Device Interface, 386-394 Power-On Self Test Error Log, 366-367 Program Termination, 370 Programmable Option Select, 396 - 397Read Extended Memory Size, 378 Return Extended BIOS Data Area, 385 Return System Configuration Parameters, 383-384 ROM BIOS data for, 362 Set Event Wait Interval, 371-372 Switch Processor to Protected Mode. 379-380 System RAM for, 359 System Request Key, 374 Wait, 375 Watchdog Time-Out, 395 System timer and time-related devices, 36-39, 507 channel for, 38, 507, 509 counter for, 412-413, 418-419, 486 entry point for, 100 interrupt for, 8, 76 System Timer & Real-Time Clock interrupt, 9, 77 System Timer ISR Time-of-Day

# т

Service, 420-422

Table of Interrupt Vectors, 5 Tandon fixed disks, 108, 299 Temporary Holding register, DMA controller, 43, 483 Termination of programs, 370 Test buffers, fixed disk, 320-321 Test for Drive Ready, Fixed Disk Service, 322 Test inputs, keyboard, 472 Test port, keyboard, 465 Text modes, 174-176 auxiliary character generator for, 182. 185 fonts for dot. 178 double dot, 215, 221 ROM, 215, 217, 220-222 user, 214, 219 scan lines selection for, 232 writing to screen in, 196 Thesaurus utility, screen reading with, 194 Tick count, 410 Time and timer channels in, 37-38, 507, 509 count for, 80, 357, 410, 421, 424 error messages for, 457 Intel 8042 firmware for, 468 Interrupt for, 51 real time clock, reading and setting of. 413-414 system devices for, 36-39, 507 system message for, 445 Time-of-Day clock stopped message, 457 Time-of-Day Service, 22, 407-409 CMOS RAM for, 410-411, 425 entry point for, 100 error handling for, 412 hardware environment for, 410, 421, 424 I/O ports for, 422, 425 Real Time Clock ISR, 423-425 services for, 412-422

### T, cont'd

Read Real Time Clock Alarm and Status, 418 Read Real Time Clock Date, 415 Read Real Time Clock Time, 413 Read System Timer Day Counter, 418 Read System Timer Time Counter, 412 Reset Real Time Clock Alarm, 418 Set Real Time Clock Alarm, 417 Set Real Time Clock Date, 416 Set Real Time Clock Time, 414 Set System Timer Day Counter. 419 Set System Timer Time Counter, 413 System RAM for, 410, 421, 424 System Timer ISR, 420-422 Time-out diskette motor count for, 79, 259, 421 errors from, 339 handling of, 125-126 messages for, 451-452 in keyboard status register, 464 printer table for, 81 serial table for, 81, 337 Toggle intensity/blink bit video subfunction, 206 Toggle keys, 133 Tone Generation for Speaker timer channel, 38 Touch pads, 356 Track diskette, 254 end of, 106, 264 formatting of, 274-275 number, 83, 262 fixed disk sectors per, 107, 298 Trackballs, 32, 356 Transfer control bytes, DMA, 44

Transfer count register, DMA, 55, 62, 257, 482 Transfer rates, diskette, 82, 256, 261, 280 Transfer status flags, DMA, 42-43 Transmitter holding register, 65, 71, 332, 334, 496 Trigonometric operations, 26, 500 Turn off delay, diskette motor drive, 105, 264 24-hour roll over flag, 80, 410, 421, 424 200-line modes, 176-177 Type of cursor, 80, 180, 188-189, 248 of diskette drives, 263, 278, 280 of fixed disk, 92, 295, 324 of media, 83, 254, 261, 281 Typematic rate and delay, 146, 474

# U

- Use ROM 8x8 double dot font for graphics video subfunction, 226
- Use ROM 8x14 font for graphics video subfunction, 225
- Use ROM 8x16 font for graphics video subfunction, 227

User Alarm interrupt, 9, 77

User graphics font pointer, 223-224

User interrupts, 7-9, 77

User palette profile table, 186

User text mode fonts, 214, 219

User Timer Tick interrupt, 9, 77

User wait flag, 84, 359, 424

## V

Vectors, 5-9, 487 Verify Disk Sectors, Fixed Disk Service, 309 Verify Diskette Sectors, Diskette Service, 273 VGA. See Video Graphics Array Video buffer for, 174-175, 238, 243 Character Generator, 213-228 control bits for, 82, 180, 249 entry point for, 100 expansion ROM for, 115 failure of, 448 hardware for, 30-31, 504-505 hardware environment for, 168-171 I/O ports for, 172-173 interrupt for, 8, 76 memory for, 30-31, 171, 239, 505 modes for, 80, 174-176, 180, 187, 248monitor support for, 177 pages for. See Pages, video ROM character generators for, 178 - 179ROM failure for, 443, 454 services for, 13-16, 163-167 Alternate Select, 229-234 Read Character/Attribute from Screen, 194 Read Current Cursor Position, 191 Read Light Pen Position, 191 Read Pixel, 200 Read/Write Display Combination Code, 236-237 Return Functionality/State Information, 237-241 Return Video Status, 203 Save/Restore Video State, 242-250 Scroll Current Page Up/Down, 193 Select New Video Page, 192 Set Color Palette, 198 Set Cursor Position, 190 Set Cursor Type, 188-189

Set Palette/Color Registers, 204 - 212Set Video Mode, 187 Write Character/Attribute to Screen, 195-196 Write Character Only to Screen, 197 Write Pixel, 199 Write String, 235 Write Teletype to Active Page, 201-202 status of, 203 subsystem enable, 69, 172, 493 system RAM data for, 180-186 See also Screen Video Graphics Array chip set for, 30, 168-170, 505 cursor with, 189 display code for, 236 I/O port registers for, 495 parameter tables for. 9. 77. 84. 100, 181–182, 249 port addresses for, 68-69, 172-173, 493-495 returning information about, 230 screen writing in, 196 video paging in, 192 Video Graphics Characters interrupt, 9,77 Video screen ON/OFF subfunction, 234 Video Service pointer table #2, 183 Virtual DMA channels, 47

# W

Wait active flag, 84, 262, 359, 424 Wait count, 84, 359, 424 Wait interval, event, 371–372 WAIT math coprocessor signal, 26, 500

W. cont'd Wait states, microprocessor, 25, 499 Wait System Services, 375 Warm boots, 112 Watchdog Time-out message, 126, 451-452 Watchdog Time-Out, System Services, 395 Watchdog Timer channel for, 38 initial count in, 86, 421 and time-out errors, 125-126 Western Digital ST506 fixed disk adapter, 29, 504 Width I/O address, 27 of screen, 203 Windows, initialization of, 193 Wrap mode, mouse, 478 Write Character/Attribute to Screen, Video Service, 195-196 Write Character Only to Screen, Video Service, 197

Write Disk Sectors, Fixed Disk Service, 308 Write Diskette Sectors, Diskette Service, 272

Write error code to POST error log subfunction, 367

Write Long Disk Sectors, Fixed Disk Service, 315–316

Write Mask Register, DMA, 63

Write modem control register subfunction, 349–350

Write operation for System Control Port, 52

Write Pixel, Video Service, 199

Write precompensation, fixed disk, 107–109, 298

Write String, Video Service, 235

Write Teletype to Active Page, Video Service, 201–202

Writing to CMOS RAM, 39

### Υ

#### Year

in CMOS RAM, 411 in real time clock, 90, 490

# **The Phoenix Technical Reference Series**

Phoenix Technologies Ltd.

**CBIOS for IBM® PS/2® Computers and Compatibles** is an indispensable guide to the CBIOS, the part of the PS/2 BIOS that supports single-tasking operating systems such as DOS. It is written for anyone who needs a detailed understanding of the system software resident in their IBM PS/2 or compatible computer—applications programmers, operating system developers, hardware manufacturers, and students of PC architecture. This reference book is the most complete source of information available on ROM-based system software for DOS.

Key information includes:

- complete bit-level descriptions of I/O port addresses, CMOS RAM data areas, ROM BIOS and Extended ROM BIOS data areas, and all system configuration tables
- descriptions of undocumented IBM CBIOS features
- programming tips for using BIOS functions more productively
- complete documentation of the power-on self test (POST) routine
- complete beep code and error message documentation
- descriptions of key hardware commands, including DMA, POS, and the Micro Channel.<sup>™</sup>

The information in this book is applicable to all IBM PS/2 and compatible computers, ranging from IBM PS/2 Models 25 through Model 80.

**Phoenix Technologies Ltd.** of Norwood, Massachusetts is the industry leader in providing ROM BIOS products for IBM PC and PS/2 compatibles.

The Phoenix Technical Reference Series includes two other technical reference volumes on BIOS software—*ABIOS for IBM PS/2 Computers and Compatibles: The Complete Guide to ROM-Based System Software for OS/2 and System BIOS for IBM PC/XT/ AT Computers and Compatibles: The Complete Guide to ROM-Based System Software.* 

| Applications  |       |                      |
|---------------|-------|----------------------|
| OS/2          | DOS   |                      |
| ABIOS         | CBIOS | System BIOS          |
| PS/2 Hardware |       | PC/XT/AT<br>Hardware |

Addison-Wesley Publishing Company, Inc.

