Personal Computer Hardware Reference Library # Technical Reference #### First Edition (August 1986) The following paragraph does not apply to the United Kingdom or any country where such provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or implied warranties in certain transactions, therefore, this statement may not apply to you. This publication could include technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this publication at any time. It is possible that this publication may contain reference to, or information about, IBM products (machines and programs), programming, or services that are not announced in your country. Such references or information must not be construed to mean that IBM intends to announce such IBM products, programming, or services in your country. Requests for copies of this publication and for technical information about IBM Personal Computer products should be made to your authorized IBM Personal Computer dealer or your IBM Marketing Representative. © Copyright International Business Machines Corporation 1986 The following statement applies to all IBM Personal Computer products unless otherwise indicated by the information referring to that product. # FEDERAL COMMUNICATIONS COMMISSION RADIO FREQUENCY INTERFERENCE STATEMENT Warning: This equipment has been certified to comply with the limits for a Class B computing device, pursuant to Subpart J of Part 15 of FCC rules. Only peripherals (computer input/output devices, terminals, printers, etc.) certified to comply with the Class B limits may be attached to this computer when this computer is operated in a residential environment. Operation with noncertified peripherals is likely to result in interference to radio and TV reception. #### **CAUTION** This product is equipped with a 3-wire power cord and plug for the user's safety. Use this power cord in conjunction with a properly grounded electrical outlet to avoid electrical shock. # **Notes:** ### **Preface** This manual describes the various units of the IBM Personal Computer XT Model 286 and how they interact. It also has information about the basic input/output system (BIOS) and about programming support. The information in this publication is for reference, and is intended for hardware and program designers, programmers, engineers, and anyone else who needs to understand the design and operation of the IBM Personal Computer XT Model 286. This manual consists of eight sections: - The first three sections describe the IBM Personal Computer XT Model 286 including hardware, charts, and register information - Section 4 describes keyboard operation, the commands to and from the system, and the various keyboard layouts. - Section 5 contains information about the usage of BIOS and a system BIOS listing. - Section 6 contains instruction sets for the 80286 microprocessor and the 80287 math coprocessor. - Section 7 provides information about characters, keystrokes, and colors. - Section 8 contains information about the compatibility of the IBM Personal Computer XT Model 286 and the rest of the IBM Personal Computer family. A glossary, bibliography, and index are included. #### **Prerequisite Publications** Guide to Operations for the IBM Personal Computer XT Model 286 #### **Suggested Reading** - BASIC for the IBM Personal Computer - Disk Operating System (DOS) - Macro Assembler for the IBM Personal Computer #### **Additional Information** The Technical Directory lists all the service and technical information that is available for the IBM Personal Computer family of products. To receive a free copy of the Technical Directory, call toll free 1-800-IBM-PCTB, Monday through Friday, 8:00 a.m. to 8:00 p.m. Eastern Time. # **Contents** | SECTION 1. SYSTEM BOARD | 1-1 | |-------------------------|------| | Memory | 1-4 | | Microprocessor | 1-4 | | System Performance | 1-7 | | System Memory Mapping | 1-8 | | Direct Memory Access | 1-9 | | System Interrupts 1 | -12 | | | -13 | | Interrupt Sharing 1 | -14 | | System Timers 1 | -22 | | | -23 | | ROM Subsystem 1 | -23 | | | -24 | | | -24 | | | -25 | | | -31 | | I/O Addresses 1 | -38 | | | -43 | | | -43 | | | -43 | | | -44 | | Keyboard Controller 1 | -44 | | | l-59 | | Specifications 1 | -72 | | | -72 | | Connectors 1 | -74 | | Logic Diagrams 1 | -77 | | | | | SECTION 2. COPROCESSOR | | | Description | 2-3 | | Programming Interface | 2-3 | | Hardware Interface | 2-4 | | | | | SECTION 3. POWER SUPPLY | | | Inputs | 3-3 | | Outputs | 3-3 | | DC Output Protection | 3-4 | | Output Voltage Sequencing | | |----------------------------------------|-------| | No-Load Operation 3-4 | | | Power-Good Signal 3-4 | | | Connectors | | | <b>SECTION 4. KEYBOARD</b> | | | Description 4-3 | | | Power-On Routine 4-5 | | | Commands from the System 4-6 | | | Commands to the System 4-13 | | | Keyboard Scan Codes 4-15 | | | Clock and Data Signals 4-27 | | | Keyboard Encoding and Usage 4-30 | | | Keyboard Layouts 4-40 | | | Specifications 4-47 | | | Logic Diagram 4-48 | | | <b>SECTION 5. SYSTEM BIOS</b> | | | System BIOS Usage 5-3 | | | Quick Reference 5-14 | | | SECTION 6. INSTRUCTION SET 6-1 | | | 80286 Instruction Set | | | Data Transfer 6-3 | | | Arithmetic 6-6 | | | Logic 6-9 | | | String Manipulation 6-11 | | | Control Transfer 6-13 | | | Processor Control 6-17 | | | Protection Control 6-18 | | | 80287 Coprocessor Instruction Set 6-22 | | | Data Transfer 6-22 | | | Comparison 6-23 | | | Constants 6-24 | | | Arithmetic 6-25 | | | Transcendental 6-26 | | | SECTION 7. CHARACTERS, KEYSTROKES, AND | | | COLORS 7-1 | | | Character Codes | | | Quick Reference 7-14 | \ \ \ | | SECTION 8. IBM PERSONAL COMPUTER | | |-------------------------------------------------|------| | COMPATIBILITY | 8-1 | | Hardware Considerations | | | System Board | 8-3 | | | 8-5 | | | 8-5 | | Copy Protection | 8-5 | | Application Guidelines | | | High-Level Language Considerations | | | Assembler Language Programming Considerations . | 8-8 | | Multitasking Provisions 8 | 3-15 | | Machine-Sensitive Code 8 | | | Glossary | X-1 | | Bibliography X | -37 | | Index X | -39 | # **Notes:** # **Notes:** # System Block Diagram # **SECTION 1. SYSTEM BOARD** | Memory | 1-4 | |--------------------------------------|------| | Microprocessor | | | Real Address Mode | | | Protected (Virtual Address) Mode | | | System Performance | | | System Memory Mapping | | | Direct Memory Access | | | System Interrupts | 1-12 | | Hardware Interrupt Listing | 1-13 | | Interrupt Sharing | 1-14 | | Design Overview | 1-14 | | Program Support | 1-15 | | Precautions | 1-17 | | Examples | 1-18 | | System Timers | 1-22 | | System Clock | 1-23 | | ROM Subsystem | 1-23 | | RAM Subsystem | 1-24 | | I/O Channel | 1-24 | | Connectors | 1-25 | | I/O Channel Signal Description | 1-31 | | I/O Addresses | 1-38 | | NMI Controls | 1-39 | | I/O Port (Read/Write) | 1-40 | | Diagnostic-Checkpoint Port | 1-42 | | Coprocessor Controls | 1-42 | | Other Circuits | 1-43 | | Speaker | 1-43 | | 128K RAM Jumper (J10) | 1-43 | | Display Switch | 1-44 | | Keyboard Controller | 1-44 | | Keyboard Controller Initialization | 1-45 | | Receiving Data from the Keyboard | 1-45 | | Scan Code Translation | 1-46 | | Sending Data to the Keyboard | 1-53 | | Keyboard Controller System Interface | | | Status Register | 1-54 | | Status-Register Bit Definition | 1-54 | |--------------------------------------|------| | Output Buffer | 1-56 | | Input Buffer | 1-56 | | Commands (I/O Address Hex 64) | 1-56 | | I/O Ports | 1-58 | | Real-Time Clock CMOS RAM Information | 1-59 | | Real-Time Clock Information | 1-60 | | CMOS RAM Configuration Information | 1-63 | | I/O Operations | 1-70 | | Specifications | 1-72 | | System Unit | 1-72 | | Connectors | 1-74 | | Logic Diagrams | | The system board is approximately 22 by 33.8 centimeters (8.5 by 13.2 inches). It uses very large scale integration (VLSI) technology and has the following components: - Intel 80286 Microprocessor - System support function: - Seven-Channel Direct Memory Access (DMA) - Sixteen-level interrupt - Three programmable timers - System clock - 64K read-only memory (ROM) subsystem, expandable to 128K. - A 640K (may be set to 512K) random-access memory (RAM) subsystem - Eight input/output (I/O) slots: - Five with a 98-pin card-edge socket - Three with a 62-pin card-edge socket - Speaker attachment - Keyboard attachment - Complementary metal oxide semiconductor (CMOS) memory RAM to maintain system configuration - Real-Time Clock - Battery backup for CMOS configuration table and Real-Time Clock ### **Memory** The system board consists of two 256K-by-9 random access memory module packages, plus two banks of 64K-by-4 random access memory (RAM) modules. Total memory size is 640K, with parity checking. ### Microprocessor The Intel 80286 microprocessor has a 24-bit address, 16-bit memory interface<sup>1</sup>, an extensive instruction set, DMA and interrupt support capabilities, a hardware fixed-point multiply and divide, integrated memory management, four-level memory protection, 1G (1,073,741,824 bytes) of virtual address space for each task, and two operating modes: the 8086-compatible real address mode and the protected virtual address mode. More detailed descriptions of the microprocessor may be found in the publications listed in the Bibliography of this manual. #### Real Address Mode In the real address mode, the microprocessor's physical memory is a contiguous array of up to one megabyte. The microprocessor addresses memory by generating 20-bit physical addresses. The selector portion of the pointer is interpreted as the upper 16 bits of a 20-bit segment address. The lower 4 bits of the 20-bit segment address are always zero. Therefore, segment addresses begin on multiples of 16 bytes. All segments in the real address mode are 64K in size and may be read, written, or executed. An exception or interrupt can occur if data operands or instructions attempt to wrap around the end of a segment. An example of this is a word with its low-order byte at offset FFFF and its high-order byte at 0000. If, in the real #### 1-4 System Board In this manual, the term interface refers to a device that carries signals between functional units. address mode, the information contained in the segment does not use the full 64K, the unused end of the segment may be overlayed by another segment to reduce physical memory requirements. #### **Protected (Virtual Address) Mode** The protected mode offers extended physical and virtual memory address space, memory protection mechanisms, and new operations to support operating systems and virtual memory. Note: See "BIOS Programming Hints" in Section 5 for special cautions while operating in the protected mode. The protected mode provides a 1G virtual address space for each task mapped into a 16M physical address space. The virtual address space may be larger than the physical address space, because any use of an address that does not map to a physical memory location will cause a restartable exception. As in the real address mode, the protected mode uses 32-bit pointers, consisting of 16-bit selector and offset components. The selector, however, specifies an index into a memory resident table rather than the upper 16 bits of a real memory address. The 24-bit base address of the desired segment is obtained from the tables in memory. The 16-bit offset is added to the segment base address to form the physical address. The microprocessor automatically refers to the tables whenever a segment register is loaded with a selector. All instructions that load a segment register will refer to the memory-based tables without additional program support. The memory-based tables contain 8-byte values called descriptors. The following is a block diagram of the system board. ### 1-6 System Board # **System Performance** The 80286 microprocessor operates at 6 MHz, resulting in a clock cycle time of 167 nanoseconds. A bus cycle requires two clock cycles, making a 334-nanosecond 16-bit, microprocessor cycle time. Eight-bit bus operations to 8-bit devices take six clock cycles (which include four wait states), resulting in a 1-microsecond microprocessor cycle. Sixteen-bit bus operations to 8-bit devices take 12 clock cycles (which include 10 wait states) resulting in a 2-microsecond microprocessor cycle. The refresh controller steps one refresh address every 15 microseconds. Each refresh cycle requires eight clock cycles to refresh all of the system's dynamic memory; 256 refresh cycles are required every 4 milliseconds, but the system hardware refreshes every 3.84ms. The following formula determines the percentage of bandwidth used for refresh for the 6 MHz clock. The DMA controller operates at 3 MHz, which results in a clock cycle time of 334 nanoseconds. All DMA data-transfer bus cycles are five clock cycles or 1.66 microseconds. Cycles spent in the transfer of bus control are not included. # **System Memory Mapping** The following shows the mapping of the system memory. | Address | Name | Function | |---------------------|---------------------------------|-----------------------------------------------------------------------------------| | 000000 to<br>07FFFF | 512K system<br>board memory | First 512K of system board memory | | 080000 to<br>09FFFF | 128K system<br>board memory | System board memory (512K to 640K)<br>May be disabled with jumper J10. | | 0A0000 to<br>0BFFFF | 128K video<br>RAM | Reserved for graphics display buffer | | 0C0000 to<br>0DFFFF | 128K I/O<br>expansion ROM | Reserved for ROM on I/O adapters | | 0E0000 to<br>0EFFFF | 64K reserved<br>on system board | Duplicated code assignment at address FE0000 | | 0F0000 to<br>0FFFFF | 64K ROM on the system board | Duplicated code assignment at address FF0000 | | 100000 to<br>FDFFFF | Maximum<br>memory 15M | <pre>1/0 channel memory - 640K to 15M installed on memory expansion options</pre> | | FE0000 to | 64K reserved<br>on system board | Duplicated code assignment at address OE0000 | | FF0000 to | 64K ROM on the system board | Duplicated code assignment at address OF0000 | **System Memory** ## **Direct Memory Access** The system supports seven direct memory access (DMA) channels. Two Intel 8237A-5 DMA Controller chips are used, with four channels for each chip. The DMA channels are assigned as follows: | Controller 1 Controller 2 | | |---------------------------|---------------------------| | Ch 0 - Reserved | Ch 4 - Cascade for Ctlr 1 | | Ch 1 - SDLC | Ch 5 - Reserved | | Ch 2 - Diskette | Ch 6 - Reserved | | Ch 3 - LAN | Ch 7 - Reserved | #### **DMA Channels** DMA controller 1 contains channels 0 through 3. These channels support 8-bit data transfers between 8-bit I/O adapters and 8- or 16-bit system memory. Each channel can transfer data throughout the 16M system-address space in 64K blocks. The following figures show address generation for the DMA channels. | Source | DMA Page Registers | Controller | |---------|--------------------|------------| | Address | A23<>A16 | A15<>A0 | #### Address Generation for DMA Channels 0 through 3 Note: The addressing signal, 'byte high enable' (BHE), is generated by inverting address line A0. #### DMA controller 1 command code addresses follow. | Hex<br>Address | Register Function | |------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000<br>001<br>002<br>003<br>004<br>005<br>006<br>007 | CHO base and current address CHO base and current word count CH1 base and current address CH1 base and current word count CH2 base and current address CH2 base and current word count CH3 base and current address CH3 base and current word count | | 008<br>009<br>00A<br>00B<br>00C<br>00D<br>00E<br>00F | Read Status Register/Write Command Register<br>Write Request Register<br>Write Single Mask Register Bit<br>Write Mode Register<br>Clear Byte Pointer Flip-Flop<br>Read Temporary Register/Write Master Clear<br>Clear Mask Register<br>Write All Mask Register Bits | #### **DMA Controller 1 (Channels 0-3)** DMA controller 2 contains channels 4 through 7. Channel 4 is used to cascade channels 0 through 3 to the microprocessor. Channels 5, 6, and 7 support 16-bit data transfers between 16-bit I/O adapters and 16-bit system memory. These DMA channels can transfer data throughout the 16M system-address space in 128K blocks. Channels 5, 6, and 7 cannot transfer data on odd-byte boundaries. | Source | DMA Page Registers | Controller | |---------|--------------------|------------| | Address | A23<>A17 | A16<>A1 | Address Generation for DMA Channels 5 through 7 **Note:** The addressing signals, BHE and A0, are forced to a logical 0. The following figure shows the addresses for the page register. | Page Register | I/O Hex Address | |-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------| | DMA Channel O DMA Channel 1 DMA Channel 2 DMA Channel 3 DMA Channel 5 DMA Channel 6 DMA Channel 7 Refresh | 0087<br>0083<br>0081<br>0082<br>008B<br>0089<br>008A<br>008F | #### **Page Register Addresses** Addresses for all DMA channels do not increase or decrease through page boundaries (64K for channels 0 through 3, and 128K for channels 5 through 7). DMA channels 5 through 7 perform 16-bit data transfers. Access can be gained only to 16-bit devices (I/O or memory) during the DMA cycles of channels 5 through 7. Access to the DMA controller, which controls these channels, is through I/O addresses hex 0C0 through 0DF. DMA controller 2 command code addresses follow. | Hex<br>Address | Register Function | |-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0C0<br>0C2<br>0C4<br>0C6<br>0C8<br>0CA<br>0CC | CH4 base and current address CH4 base and current word count CH5 base and current address CH5 base and current word count CH6 base and current address CH6 base and current word count CH7 base and current address CH7 base and current word count | | 0D0<br>0D2<br>0D4<br>0D6<br>0D8<br>0DA<br>0DC | Read Status Register/Write Command Register<br>Write Request Register<br>Write Single Mask Register Bit<br>Write Mode Register<br>Clear Byte Pointer Flip-Flop<br>Read Temporary Register/Write Master Clear<br>Clear Mask Register<br>Write All Mask Register Bits | **DMA Controller 2 (DMA Channels 4-7)** All DMA memory transfers made with channels 5 through 7 must occur on even-byte boundaries. When the base address for these channels is programmed, the real address divided by 2 is the data written to the base address register. Also, when the base word count for channels 5 through 7 is programmed, the count is the number of 16-bit words to be transferred. Therefore, DMA channels 5 through 7 can transfer 65,536 words, or 128Kb maximum, for any selected page of memory. These DMA channels divide the 16M memory space into 128K pages. When the DMA page registers for channels 5 through 7 are programmed, data bits D7 through D1 contain the high-order seven address bits (A23 through A17) of the desired memory space. Data bit D0 of the page registers for channels 5 through 7 is not used in the generation of the DMA memory address. At power-on time, all internal locations, especially the mode registers, should be loaded with some valid value. This is done even if some channels are unused. ### **System Interrupts** The 80286 microprocessor's non maskable interrupt (NMI) and two 8259A controller chips provide 16 levels of system interrupts. **Note:** Any or all interrupts may be masked (including the microprocessor's NMI). ### **Hardware Interrupt Listing** The following shows the interrupt-level assignments in decreasing priority. **Hardware Interrupt Listing** ### **Interrupt Sharing** A definition for standardized hardware design has been established that enables multiple adapters to share an interrupt level. This section describes this design and discusses the programming support required. **Note:** Since interrupt routines do not exist in ROM for protected mode operations, this design is intended to run only in the microprocessor's real address mode. #### **Design Overview** Most interrupt-supporting adapters hold the 'interrupt request' line (IRQ) at a low level and then drive the line high to cause an interrupt. In contrast, the shared-interrupt hardware design allows IRQ to float high through pull-up resistors on each adapter. Each adapter on the line may cause an interrupt by momentarily pulsing the line to a low level. The high-to-low transition arms the 8259A Interrupt Controller; the low-to-high transition generates the interrupt. The duration of this pulse must be between 125 and 1,000 nanoseconds. The adapters must have an 'interrupt' status bit (INT) and a 'interrupt enable' bit (ENA) that can be controlled and monitored by its software. Each adapter sharing an interrupt level must monitor the IRQ line. When any adapter drives the line low, all other adapters on that line must be prevented from issuing an interrupt request until they are rearmed. If an adapter's INT status bit is at a high level when the interrupt sharing logic is rearmed, the adapter must reissue the interrupt. This prevents lost interrupts if two adapters issue an interrupt at the same time and an interrupt handler issues a Global Rearm after servicing one of the adapters. Q The following diagram is an example of the shared interrupt logic. **Shared Interrupt Logic Diagram** #### **Program Support** During multitasking, tasks are constantly being activated and deactivated in no particular order. The interrupt-sharing program support described in this section provides for an orderly means to: - Link a task's interrupt handler to a chain of interrupt handlers - Share the interrupt level while the task is active - Unlink the interrupt handler from the chain when the task is deactivated. #### Linking to a Chain Each newly activated task replaces the interrupt vector in low memory with a pointer to its own interrupt handler. The old interrupt vector is used as a forward pointer (FPTR) and is stored at a fixed offset from the new task's interrupt handler. #### **Sharing the Interrupt Level** When the new task's handler gains control as a result of an interrupt, the handler reads the contents of the adapter's interrupt status register to determine if its adapter caused the interrupt. If it did, the handler services the interrupt, disables the interrupts (CLI), issues a non-specific End of Interrupt (EOI), and then, to rearm the interrupt hardware, writes to address 02FX, where X corresponds to interrupt levels 3 through 7, and 9 (IRQ9 is 02F2). A write to address 06FX, where X may be 2 through 7, is required for interrupt levels 10 through 15, respectively. Each adapter in the chain decodes the address which results in a Global Rearm. An adapter is required to decode the least significant 11 bits for this Global Rearm command. The handler then issues a Return From Interrupt (IRET). If its adapter did not cause the interrupt, the handler passes control to the next interrupt handler in the chain. #### Unlinking from the Chain To unlink from the chain, a task must first locate its handler's position within the chain. By starting at the interrupt vector in low memory, and using the offset of each handler's FPTR to find the entry point of each handler, the chain can be methodically searched until the task finds its own handler. The FPTR of the previous handler in the chain is replaced by the task's FPTR, thus removing the handler from the chain. #### Error Recovery Should the unlinking routine discover that the interrupt chain has been corrupted (an interrupt handler is linked but does not have a valid SIGNATURE), an unlinking error-recovery procedure must be in place. Each application can incorporate its own unlinking error procedure into the unlinking routine. One application may choose to display an error message requiring the operator to either correct the situation or power down the system. Another application may choose an error recovery procedure that restores the original interrupt vector in low memory, and bypasses the corrupt portion of the interrupt chain. This error recovery procedure may not be suitable when adapters that are being serviced by the corrupt handler are actively generating interrupts, since unserviced interrupts lock up that interrupt level. #### **ROS Considerations** Adapters with their handlers residing in ROS may choose to implement chaining by storing the 4 byte FPTR (plus the FIRST flag if it is sharing interrupt 7 or 15) in on-adapter latches or ports. Adapter ROS without this feature must first test to see that it is the first in the chain. If it is the first in the chain, the adapter can complete the link; if not, the adapter must exit its routine without linking. #### **Precautions** The following precautions must be taken when designing hardware or programs using shared interrupts: - Hardware designers should ensure the adapters: - Do not power up with the ENA line active or an interrupt pending. - Do not generate interrupts that are not serviced by a handler. Generating interrupts when a handler is not active to service the adapter causes the interrupt level to lock up. The design relies on the handler to clear its adapter's interrupt and issue the Global Rearm. - Can be disabled so that they do not remain active after their application has terminated. - Programmers should: - Ensure that their programs have a short routine that can be executed with the AUTOEXEC.BAT to disable their adapter's interrupts. This precaution ensures that the adapters are deactivated if the user reboots the system. - Treat words as words, not bytes. Remember that data is stored in memory using the Intel format (word 424B is stored as 4B42). #### **Interrupt Chaining Structure** ``` ENTRY: JMP SHORT PAST ; Jump around structure FPTR DD 0 ; Forward Pointer ; Used when unlinking to identify ; compatible interrupt handlers F1RST EQU 80H ; Flags F1RST EQU 80H ; Flags F1RST F1 ``` The interrupt chaining structure is a 16-byte format containing FPTR, SIGNATURE, and RES\_BYTES. It begins at the third byte from the interrupt handler's entry point. The first instruction of every handler is a short jump around the structure to the start of the routine. Since the position of each interrupt handler's chaining structure is known (except for the handlers on adapter ROS), the FPTRs can be updated when unlinking. The FIRST flag is used to determine the handler's position in the chain when unlinking when sharing interrupts 7 and 15. The RESET routine, an entry point for the operating system, must disable the adapter's interrupt and RETURN FAR to the operating system. Note: All handlers designed for interrupt sharing must use 424B as the signature to avoid corrupting the chain. #### **Examples** In the following examples, notice that interrupts are disabled before control is passed to the next handler on the chain. The next handler receives control as if a hardware interrupt had caused it to receive control. Also, notice that the interrupts are disabled before the non-specific EOI is issued, and not reenabled in the interrupt handler. This ensures that the IRET is executed (at which point the flags are restored and the interrupts reenabled) before another interrupt is serviced, protecting the stack from excessive build up. #### **Example of an Interrupt Handler** ``` Location of your card's interrupt control/status register Interrupt bit in your card's interrupt control status register Global Rearm location for interrupt level 7 YOUR_CARD EQU xxxx ISB EQU хx REARM EQU 2F7H ; Specific EOI for 8259's interrupt ; level 7 ; Non-specific EOI ; Location of 8259 operational control ; register ; Location of 8259 interrupt mask SPC_EOI 67H ΕQU EQU EQU 20H 20H EO! OCR IMR EQU 21H register SEGMENT ASSUME PROC JMP PARA CS:MYCSEG,DS:DSEG FAR SHORT PAST MYCSEG ENTRY ; Entry point of handler ; Forward Pointer ; Used when unlinking to identify ; compatible interrupt handlers ; Flags FPTR DD SIGNATURE DW 0 424BH DB EQU SHORT FLAGS FIRST JMP RESET RES_BYTES DB PAST: STI PUSH DUP 7 (0) ; Future expansion ; Actual start of handler code ; Save needed registers ; Save needed registers ; Select your status register ; Read the status register ; Your card caused the interrupt? ; Yes, branch to service logic ; Are we the first ones in? ; If yes, branch for EOI and Rearm ; Restore registers ; Disable interrupts ; Pass control to next guy on chain DX,YOUR_CARD AL,DX AL,ISB SERVICE CS:FLAGS,FIRST EXIT MOV IN TEST JNZ TEST JNZ POP CLI JMP DWORD PTR CS:FPTR SERVICE: EXIT: ; Service the interrupt ; Disable the interrupts AL,EOI OCR,AL DX,REARM DX,AL MOV OUT MOV OUT POP IRET ; Issue non-specific EOI to 8259 ; Rearm the cards ; Restore registers ; Disable your card ; Return FAR to operating system RESET: RET ENDP MYCSEG END ENTRY ENDS Entry ``` #### **Linking Code Example** #### **Unlinking Code Example** ``` PUSH PUSH CL1 MOV INT DS ES Disable interrupts DOS get interrupt vector ES:BX points to first of chain Pickup segment part of interrupt vector AX,350FH 21H CX,ES handler in the chain? AX,CS BX,OFFSET ENTRY MOV ; Are we the first MOV CMP ; Get code seg into comparable register ; interrupt vector in low memory ; pointing to your handler's offset? UNCHAIN_A AX,CX JNE CMP ; No, branch ; Vector pointing to your ; handler's segment? JNE UNCHAIN_A ; No, branch ; Set interrupt vector in low memory to point to the handler ; pointed to by your pointer PUSH MOV MOV MOV INT POP DS, WORD PTR CS:FPTR DS, WORD PTR CS FPTR[2] AX.250FH ; DOS set Interrupt vector 21H DS JMP UNCHAIN_X CMP ; BX , ES = FPTR segment, CX = CS H ; Is handler using the appropriate ; conventions (is SIGNATURE present in ; the interrupt chaining structure)? ; No, invoke error exception handler ; Get FPTR's segment and offset RY ; Is this forward pointer pointing to ; your handler's offset? = FPTR offset, ES:[BX+6],4B42H UNCHAIN_A: JNE LDS CMP exception SI,E5:[BX+2] SI,OFFSET ENTRY No, branch Move to compare Is this forward pointer pointing to your handler's segment? UNCHAIN_B CX,DS AX,CX JNE MOV UNCHAIN B ; No, branch handler in the chain AX,WORD PTR CS:FPTR; Get your FPTR's offset ES:[BX+2],AX ; Replace offset of FPTR of handler that points to you AX,WORD PTR CS:FPTR[2]; Get your FPTR's segment ES:[BX+4],AX ; Replace segment of FPTR of handler that points to you AL,CS:FLAGS ; Get your flags AL,FIRST ; Isolate FIRST flag ES:[BX + 6],AL ; Set your first flag into prior routine JNE ; Located your MOV MOV MOV MOV AND OR JMP BX,SI DS ES UNCHAIN_B: MOV ; Move new offset to BX PUSH UNCHAIN A JMP ; Examine next handler in chain UNCHAIN_X: STI ; Enable interrupts POP ``` ### **System Timers** The system has three programmable timer/counters, Channels 0 through 2. They are controlled by an Intel 8254-2 Timer/Counter chip, and are defined as follows: | Channel 0 | System Timer | | |-----------|--------------|--| | | | | GATE 0 Tied on CLK IN 0 1.193182 MHz OSC CLK OUT 0 8259A IRQ 0 Channel 1 Refresh Request Generator GATE 1 Tied on CLK IN 1 1.193182 MHz OSC CLK OUT 1 Request refresh cycle **Note:** Channel 1 is programmed as a rate generator to produce a 15-microsecond period signal. #### Channel 2 Tone Generation for Speaker GATE 2 Controlled by bit 0 of port hex 61, PPI bit CLK IN 2 1.193182 MHz OSC CLK OUT 2 Used to drive the speaker The 8254-2 Timer/Counter is a programmable interval timer/counter that system programs treat as an arrangement of four external I/O ports. Three ports are treated as counters; the fourth is a control register for mode programming. The following is a system-timer block diagram. **System-Timer Block Diagram** # **System Clock** The 82284 System Clock Generator is driven by a 12-MHz crystal. Its output 'clock' signal (CLK) is the input to the system microprocessor and the I/O channel. # **ROM Subsystem** The system board's ROM subsystem consists of two 32K by 8-bit ROM/EPROM modules in a 32K-by-16-bit arrangement. The code for odd and even addresses resides in separate modules. ROM is assigned at the top of the first and last 1M address space (0F0000 and FF0000). ROM is not parity-checked. Its maximum access time is 170 nanoseconds and its maximum cycle time is 333 nanoseconds. # **RAM Subsystem** The system board's RAM subsystem starts at address 000000 of the 16M address space and consists of 640K of read/write (R/W) memory. The 640K memory is composed of two 256K-by-9 random access memory module packages (512K), plus two banks of 64K-by-4 RAM modules (128K). The 64K-by-4 RAM modules may be disabled at jumper J10, located on the system board. Memory access time is 150 nanoseconds and the cycle time is 275 nanoseconds. Memory refresh requests one memory cycle every 15 microseconds through the timer/counter (channel 1). The RAM initialization program performs the following functions: - Initializes channel 1 of the timer/counter to the rate generation mode, with a period of 15 microseconds - Performs a memory write operation to any memory location. **Note:** The memory must be accessed or refreshed eight times before it can be used. # I/O Channel The I/O channel supports: - I/O address space hex 100 to hex 3FF - 24-bit memory addresses (16M) - Selection of data accesses (either 8- or 16-bit) - Interrupts - DMA channels - I/O wait-state generation - Open-bus structure (allowing multiple microprocessors to share the system's resources, including memory) - Refresh of system memory from channel microprocessors. #### 1-24 System Board # **Connectors** The following figure shows the location and the numbering of the I/O channel connectors. These connectors consist of five 98-pin and three 62-pin edge connector sockets. Note: The three 62-pin positions can support only 62-pin I/O bus adapters. The following figure shows the pin numbering for the 62-pin I/O channel connectors J1, J7 and J8. I/O Channel Pin Numbering (J1, J7 and J8) The following figure shows the pin numbering for the 98-pin I/O channel connectors J2 through J6. I/O Channel Pin Numbering (J2-J6) The following figures summarize pin assignments for the I/O channel connectors. | I/O Pin | Signal Name | 1/0 | |---------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | A1<br>A2<br>A3<br>A4<br>A5<br>A6<br>A7<br>A8<br>A9<br>A11<br>A112<br>A112<br>A118<br>A119<br>A223<br>A224<br>A224<br>A229<br>A229<br>A230<br>A331 | -1/0 CH CK SD7 SD6 SD7 SD7 SD6 SD5 SD4 SD2 SD1 RD7 SA18 SA17 SA15 SA11 SA10 SA9 SAA6 SAA6 SAA6 SAA6 SAA6 SAA6 SAA6 | -00000000000000000000000000000000000000 | I/O Channel (A-Side) | I/O Pin | Signal Name | 1/0 | |------------|-----------------|--------| | B1 | GND | Ground | | B2 | RESET DRV | 0 | | B3<br>B4 | +5 Vdc | Power | | B5 | IRQ 9<br>-5 Vdc | Da., | | B6 | | Power | | B7 | DRQ2<br>-12 Vdc | Power | | B8 | OWS | l | | B9 | +12 Vdc | Power | | B10 | GND | Ground | | B11 | -SMEMW | 0 | | B12 | -SMEMR | ŏ | | B13 | -10W | 1/0 | | B14 | -ior | 1/0 | | B15 | -DACK3 | Ö | | B16 | DRQ3 | | | B17 | -DACK1 | 0 | | B18 | DRQ1 | l l | | B19 | -REFRESH | 1/0 | | B20 | CLK | Ò | | B21 | IRQ7 | ! | | B22 | IRQ6 | ļ ļ | | B23<br>B24 | IRQ5 | ! | | B24<br>B25 | IRQ4 | ļ | | B26 | IRQ3<br>-DACK2 | Ó | | B27 | T/C | 0 | | B28 | BALE | ŏ | | B29 | +5Vdc | Power | | B30 | 14.318MHz OSC | 0 | | B31 | GND | Ground | I/O Channel (B-Side) | I/O Pin | Signal Name | 1/0 | |----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------| | C1<br>C2<br>C3<br>C5<br>C6<br>C7<br>C8<br>C9<br>C10<br>C12<br>C13<br>C14<br>C15<br>C17 | -SBHE LA23 LA22 LA21 LA20 LA19 LA18 LA17 -MEMR -MEMW SD08 SD10 SD11 SD12 SD12 SD13 SD14 | 1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0<br>1/0 | I/O Channel (C-Side, J2 through J6 only) | I/O Pin | Signal Name | 1/0 | |------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7<br>D8<br>D9<br>D10<br>D12<br>D12<br>D13<br>D14<br>D15<br>D16<br>D17 | -MEM CS16 -1/0 CS16 -1/0 CS16 -1/0 CS16 -1/0 CS11 -1/0 CS16 C | <br> | I/O Channel (D-Side, J2 through J6 only) # I/O Channel Signal Description The following is a description of the system board's I/O channel signals. All signal lines are TTL compatible. I/O adapters should be designed with a maximum of two low-power Shottky (LS) loads per line and be capable of driving the data and address lines similar to a 74LS245 driver. #### SA0 through SA19 (I/O) Address signals 0 through 19 are used to address memory and I/O devices within the system. These 20 address lines, in addition to LA17 through LA23, allow access of up to 16M of memory. SA0 through SA19 are gated on the system bus when 'buffered address latch enable' signal (BALE) is high and are latched on the falling edge of BALE. These signals are generated by the microprocessor or DMA Controller. They also may be driven by other microprocessors or DMA controllers that reside on the I/O channel. #### LA17 through LA23 (I/O) These signals (unlatched) are used to address memory and I/O devices within the system. They give the system up to 16M of addressability. These signals are valid from the leading edge of BALE to the trailing edge of the '-I/O Read' (-IOR) or '-I/O Write' (-IOW) command cycle. These decodes should be latched by I/O adapters on the falling edge of the 'buffered address latch enable' signal (BALE). These signals also may be driven by other microprocessors or DMA controllers that reside on the I/O channel. #### CLK (O) This is the system 'clock' signal. It is a synchronous microprocessor cycle clock with a cycle time of 167 nanoseconds. The clock has a 50% duty cycle. This signal should be used only for synchronization. It is not intended for uses requiring a fixed frequency. #### **RESET DRV (O)** The 'reset drive' signal is used to reset or initialize system logic at power-up time or during a low voltage condition. This signal is active high. #### SD0 through SD15 (I/O) These signals provide data bits 0 through 15 for the microprocessor, memory, and I/O devices. D0 is the least-significant bit and D15 is the most-significant bit. All 8-bit devices on the I/O channel should use D0 through D7 for communications to the microprocessor. The 16-bit devices will use D0 through D15. To support 8-bit devices, the data on D8 through D15 will be gated to D0 through D7 during 8-bit transfers to these devices; 16-bit microprocessor transfers to 8-bit devices will be converted to two 8-bit transfers. #### **BALE (O) (buffered)** The 'buffered address latch enable' signal is available to the I/O channel as an indicator of a valid microprocessor or DMA address (when used with 'address enable' signal, AEN). Microprocessor addresses SA0 through SA19 are latched with the falling edge of BALE. BALE is forced high (active) during DMA cycles. From the trailing edge of a command cycle (for example, the trailing edge of -IOR or -IOW) to the leading edge of BALE, the address lines are in transition and are not stable. #### -I/O CH CK (I) The '-I/O channel check' signal provides the system board with parity (error) information about memory or devices on the I/O channel. When this signal is active (low), it indicates a non-correctable system error. #### I/O CH RDY (I) The 'I/O channel ready' signal is pulled low (not ready) by a memory or I/O device to lengthen I/O or memory cycles. Any slow device using this line should drive it low immediately upon detecting its valid address and a Read or Write command. Machine cycles are extended by an integral number of clock cycles (167 nanoseconds). This signal should be held low for no more than 2.5 microseconds. #### IRQ3-IRQ7, IRQ9-IRQ12, IRQ14, and IRQ15 (I) Interrupt requests 3 through 7, 9 through 12, 14, and 15 are used to signal the microprocessor that an I/O device needs attention. The interrupt requests are prioritized, with IRQ9 through IRQ12, IRQ14, and IRQ15 having the highest priority (IRQ9 is the highest), and IRQ3 through IRQ7 having the lowest priority (IRQ7 is the lowest). An interrupt request is generated when an IRQ line is raised from low to high. The line is high until the microprocessor acknowledges the interrupt request (Interrupt Service routine). See the figure on page 1-13 for additional information. Note: Interrupt requests IRQ0-IRQ2, IRQ8, IRQ13 are used on the system board and are not available on the I/O channel. #### -IOR (I/O) The '-I/O read' signal instructs an I/O device to drive its data onto the data bus. This signal may be driven by the system microprocessor or DMA controller, or by a microprocessor or DMA controller resident on the I/O channel. This signal is active low. #### -IOW (I/O) The '-I/O write' signal instructs an I/O device to read the data off the data bus. It may be driven by any microprocessor or DMA controller in the system. This signal is active low. #### -SMEMR (O) -MEMR (I/O) These signals instruct the memory devices to drive data onto the data bus. -SMEMR is active only when the memory decode is within the low 1M of memory space. -MEMR is active on all memory read cycles. -MEMR may be driven by any microprocessor or DMA controller in the system. -SMEMR is derived from -MEMR and the decode of the low 1M of memory. When a microprocessor on the I/O channel wishes to drive -MEMR, it must have the address lines valid on the bus for one clock cycle before driving -MEMR active. Both signals are active low. #### -SMEMW (O) -MEMW (I/O) These signals instruct the memory devices to store the data present on the data bus. -SMEMW is active only when the memory decode is within the low 1M of the memory space. -MEMW is active on all memory write cycles. -MEMW may be driven by any microprocessor or DMA controller in the system. -SMEMW is derived from -MEMW and the decode of the low 1M of memory. When a microprocessor on the I/O channel wishes to drive -MEMW, it must have the address lines valid on the bus for one clock cycle before driving -MEMW active. Both signals are active low. #### DRQ0-DRQ3 and DRQ5-DRQ7 (I) The 'DMA request' signals 0 through 3 and 5 through 7 are asynchronous channel requests used by peripheral devices and a microprocessor to gain DMA service (or control of the system). They are prioritized, with DRQ0 having the highest priority and DRQ7 the lowest. A request is generated by bringing a DRQ line to an active (high) level. A DRQ line is held high until the corresponding 'DMA acknowledge' (DACK) line goes active. DRQ0 through DRQ3 perform 8-bit DMA transfers; DRQ5 through DRQ7 perform 16-bit transfers. DRQ4 is used on the system board and is not available on the I/O channel. #### -DACK0 to -DACK3 and -DACK5 to -DACK7 (O) -DMA acknowledge 0 through 3 and 5 through 7 are used to acknowledge DMA requests. These signals are active low. #### AEN (O) The 'address enable' signal is used to degate the microprocessor and other devices from the I/O channel to allow DMA transfers to take place. When this line is active, the DMA controller has control of the address bus, the data bus, Read command lines (memory and I/O), and the Write command lines (memory and I/O). This signal is active high. #### -REFRESH (I/O) This signal is used to indicate a refresh cycle and can be driven by a microprocessor on the I/O channel. This signal is active low. #### T/C(O) The 'terminal count' signal provides a high pulse when the terminal count for any DMA channel is reached. #### -SBHE (I/O) The 'system bus high enable' signal indicates a transfer of data on the upper byte of the data bus, SD8 through SD15. Sixteen-bit devices use -SBHE to condition data bus buffers tied to SD8 through SD15. This signal is active low. #### -MASTER (I) This signal is used with a DRQ line to gain control of the system. A processor or DMA controller on the I/O channel may issue a DRQ to a DMA channel in cascade mode and receive a -DACK. Upon receiving the -DACK, a microprocessor may pull -MASTER active (low), which will allow it to control the system address, data, and control lines (a condition known as *tri-state*). After -MASTER is low, the microprocessor must wait one clock cycle before driving the address and data lines, and two clock cycles before issuing a Read or Write command. If this signal is held low for more than 15 microseconds, the system memory may be lost because of a lack of refresh. #### -MEM CS16 (I) The '-memory 16-bit chip select' signal indicates to the system that the present data transfer is a 1 wait-state, 16-bit, memory cycle. It must be derived from the decode of LA17 through LA23. -MEM CS16 is active low and should be driven with an open collector or tri-state driver capable of sinking 20 mA. #### -I/O CS16 (I) The '-I/O 16-bit chip select' signal indicates to the system that the present data transfer is a 16-bit, 1 wait-state, I/O cycle. It is derived from an address decode. -I/O CS16 is active low and should be driven with an open collector or tri-state driver capable of sinking 20 mA. #### 14.318MHz OSC (0) The '14.318MHz oscillator' signal is a high-speed clock with a 70-nanosecond period (14.31818 MHz). This signal is not synchronous with the system clock. It has a 50% duty cycle. #### **0WS (I)** The 'zero wait state' signal tells the microprocessor that it can complete the present bus cycle without inserting any additional wait cycles. In order to run a memory cycle to a 16-bit device without wait cycles, 0WS is derived from an address decode gated with a Read or Write command. 0WS is active low and should be driven with an open collector or tri-state driver capable of sinking 20 mA. # I/O Addresses The following describes the system board's I/O addresses. Note: I/O Addresses, hex 000 to 0FF, are reserved for the system board I/O. Hex 100 to 3FF are available on the I/O channel. The system board decodes up to 10 bits of I/O address information. I/O addresses above 3FF must not conflict with the system board I/O addresses. I/O Address Map #### 1-38 System Board #### **NMI Controls** During POST, the non-maskable interrupt (NMI) into the 80286 is masked off. The mask bit can be set and reset with system programs as follows: Mask On (Disable NMI) Write to I/O address hex 070, with data bit 7 equal to a logical 1. Mask Off (Enable NMI) Write to I/O address hex 070, with data bit 7 equal to a logical 0. Note: At the end of POST, the system enables NMI. The '-I/O channel check' signal (-I/O CH CK) is used to report noncorrectable errors on RAM adapters on the I/O channel. This check creates an NMI if the NMI is enabled. During POST, the NMI is masked off and -I/O CH CK is disabled. Follow these steps when enabling -I/O CH CK and the NMI. - 1. Write data in all I/O RAM-adapter memory locations; this establishes good parity at all locations. - 2. Enable -I/O CH CK. - 3. Enable the NMI. **Note:** All three of these functions are performed by POST. When a check occurs, an interrupt (NMI) results. Read the status bits to determine the source of the NMI (see the figure, "I/O Address Map" on page 1-38). To determine the location of the failing adapter, write to any memory location within a given adapter. If the parity check was from that adapter, -I/O CH CK is reset to inactive. # I/O Port (Read/Write) Address hex 061 is a read/write port on the system board. #### Input (Read) The following are the input (read) bit descriptions for this I/O port. - Bit 7 +RAM Parity Check—System board memory parity check. - 0 No memory parity check error has occurred. - 1 A memory parity check error has occurred. A non-maskable interrupt (NMI) will occur if NMI is enabled. The error bit can be reset by toggling output port hex 061, bit 2, to a 1 and then back to a 0. - **Bit 6** +I/O Channel Check—Error on an I/O channel adapter (memory parity error or adapter errors). - 0 No I/O channel error has occurred. - 1 An I/O channel error has occurred. A non-maskable interrupt (NMI) will occur if NMI is enabled. The error bit can be reset by toggling output port hex 061, bit 3, to a 1 and then back to a 0. - Bit 5 Timer 2 Channel Out—Reflects the level of the Timer 2 output. - Bit 4 Refresh Detect—Toggles every 15 microseconds, indicating normal Refresh activity - Bits 3 to 0 Read the status of bits 3, 2, 1, and 0, respectively, written to output port hex 061. #### 1-40 System Board #### Output (Write) The following are the output (write) bit descriptions for the system board I/O port. #### Bits 7 to 4 Not used - Bit 3 -Enable I/O Channel Check - 0 Enables I/O Channel Check errors. - 1 Disables I/O Channel Check errors. During power-up this bit is toggled to a 1, then back to a 0, to clear the I/O channel check flip-flop of previous errors. - Bit 2 -Enable System Board RAM Parity Check - 0 Enables system board RAM parity check. - 1 Disables system board RAM parity check. During power-up this bit is toggled to a 1, then back to a 0, to clear the RAM parity check flip-flop before BIOS checks the system memory for parity errors. - Bit 1 +Speaker Data—Controls the speaker output (along with Timer 2 Clock output). - Bit 0 +Timer 2 Gate Speaker - 0 Disables 8254 Timer 2 clock input (1.19 MHz). - 1 Enables 8254 Timer 2 clock input (1.19 MHz). # **Diagnostic-Checkpoint Port** I/O address hex 080 is used as a diagnostic-checkpoint port or register. This port corresponds to a read/write register in the DMA page register (74LS612). This port is used by POST during power up. # **Coprocessor Controls** The following is a description of the Math Coprocessor controls. - **0F0** An 8-bit Out command to port F0 will clear the latched Math Coprocessor '-busy' signal. The '-busy' signal will be latched if the coprocessor asserts its '-error' signal while it is busy. The data output should be zero. - **0F1** An 8-bit Out command to port F1 will reset the Math Coprocessor. The data output should be zero. # **Other Circuits** # **Speaker** The system unit has a 2-1/4 inch permanent-magnet speaker, which can be driven from: - The I/O-port output bit - The timer/counter's CLK OUT 2 - Both of the above # 128K RAM Jumper (J10) The system board has a three-pin, Berg-strip connector (J10). From the rear of the system to the front, the pins are numbered 1 through 3. Jumper placement across these pins determines whether the last 128K RAM (512KB to 640KB) of system board memory is enabled or disabled. | Pin | Assignments | | |-----|---------------|--| | 1 | No Connection | | | 2 | Ground | | | 3 | RAM Select | | **RAM Jumper Connector (J10)** With the jumper on pins 1 and 2, the 128K RAM is enabled. When the jumper is on pins 2 and 3, the 128K RAM is disabled. Note: The normal mode is the enabled mode. # **Display Switch** Set the slide switch on the system board to select the primary display adapter. Its positions are assigned as follows: On (toward the front of the system unit): The primary display is attached to the Color/Graphics Monitor Adapter. Off (toward the rear of the system unit): The primary display is attached to the Monochrome Display and Printer Adapter. The switch may be set to either position if the primary display is attached to an Enhanced Graphics Adapter. **Note:** The primary display is activated when the system is powered on. # **Keyboard Controller** The keyboard controller is a single-chip microcomputer (Intel 8042, or EPROM version 8742) that is programmed to support the keyboard serial interface. The keyboard controller receives serial data from the keyboard, checks the parity of the data, translates scan codes, and presents the data to the system as a byte of data in its output buffer. The controller can interrupt the system when data is placed in its output buffer, or wait for the system to poll its status register to determine when data is available. Data is sent to the keyboard by first polling the controller's status register to determine when the input buffer is ready to accept data and then writing to the input buffer. Each byte of data is sent to the keyboard serially with an odd parity bit automatically inserted. Since the keyboard is required to acknowledge all data transmissions, another byte of data should not be sent to the keyboard until acknowledgement is received for the previous byte sent. The output-buffer-full interrupt may be used for both send and receive routines. ## **Keyboard Controller Initialization** At power-on, the keyboard controller sets the system flag bit to 0. After a power-on reset or the execution of the Self Test command, the keyboard controller disables the keyboard interface by forcing the 'keyboard clock' line low. The keyboard interface parameters are specified at this time by writing to locations within the 8042 RAM. The keyboard-inhibit function is then disabled by setting the inhibit-override bit in the command byte. A hex 55 is then placed in the output buffer if no errors are detected during the self test. Any value other than hex 55 indicates that the 8042 is defective. The keyboard interface is now enabled by lifting the 'keyboard data' and 'keyboard clock' signal lines, and the system flag is set to 1. The keyboard controller is then ready to accept commands from the system unit microprocessor or receive keyboard data. The initialization sequence causes the keyboard to establish Mode 2 protocol (see "Data Stream" on page 4-27). ## Receiving Data from the Keyboard The keyboard sends data in a serial format using an 11-bit frame. The first bit is a start bit, and is followed by eight data bits, an odd parity bit, and a stop bit. Data sent is synchronized by a clock supplied by the keyboard. At the end of a transmission, the keyboard controller disables the interface until the system accepts the byte. If the byte of data is received with a parity error, a Resend command is automatically sent to the keyboard. If the keyboard controller is unable to receive the data correctly after a set number of retries, a hex FF is placed in its output buffer, and the parity bit in the status register is set to 1, indicating a receive parity error. The keyboard controller will also time a byte of data from the keyboard. If a keyboard transmission does not end within 2 milliseconds, a hex FF is placed in the keyboard controller's output buffer, and the receive time-out bit in the status register is set. No retries will be attempted on a receive time-out error. Note: When a receive error occurs in the default mode (bits 5, 6, and 7 of the command byte set to 0), hex 00 is placed in the output buffer instead of hex FF. See "Commands (I/O Address Hex 64)" on page 1-56 for a detailed description of the command byte. #### **Scan Code Translation** Scan codes received from the keyboard are converted by the keyboard controller before being placed into the controller's output buffer. The following figures show the keyboard layouts. Each key position is numbered for reference. # 101-Key Keyboard # 102-Key Keyboard The following figure is the scan-code translation table. | System | Keyboard | Key | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Scan Code | Scan Code | (101/102-key) | | 01<br>02<br>03<br>04<br>05<br>06<br>07<br>08<br>09<br>0A<br>0B<br>0C<br>0D<br>0E<br>0F<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>1A<br>18<br>11<br>10<br>11<br>22<br>23<br>24<br>25<br>26<br>27<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28<br>28 | 76<br>16<br>16<br>16<br>16<br>16<br>16<br>16<br>17<br>16<br>17<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18 | 110<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>15<br>16<br>17<br>18<br>19<br>20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28<br>43<br>31<br>32<br>33<br>34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>41<br>41<br>42<br>(U.S. on ly)<br>42<br>(except U.S.) | | 2C | 1A | 46 | | 2D | 22 | 47 | | 2E | 21 | 48 | | 2F | 2A | 49 | Scan-Code Translation Table (Part 1 of 3) | System | Keyboard | Key | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Scan Code | Scan Code | (101/102-key) | | 30<br>31<br>32<br>33<br>34<br>35<br>38<br>39<br>38<br>39<br>38<br>39<br>38<br>39<br>40<br>41<br>42<br>44<br>44<br>45<br>46<br>47<br>48<br>49<br>48<br>49<br>48<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49<br>49 | 32<br>31<br>341<br>49A<br>59<br>11<br>29B<br>585<br>004<br>00C<br>03B<br>83A<br>01<br>097<br>77E<br>67<br>77D<br>692<br>77A<br>77O<br>77 or 12<br>67<br>77O<br>77 or 12<br>67<br>77O<br>77O<br>77O<br>77O<br>77O<br>77O<br>77O<br>77O<br>77O | 50<br>51<br>52<br>53<br>54<br>557<br>60<br>61<br>30<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>90<br>125<br>91<br>96<br>101<br>105<br>97<br>102<br>106<br>938<br>103<br>99<br>104<br>45 (except U.S.)<br>124<br>108<br>64<br>95 | | E0 37 | 7C | 100 | | E0 38 | E0 11 | 62 | | E0 47 | E0 6C | 80 | Scan-Code Translation Table (Part 2 of 3) | System | Keyboard | Key | |-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | Scan Code | Scan Code | (101/102-key) | | EO 48 EO 49 EO 4B EO 4D EO 4F EO 50 EO 51 EO 52 EO 53 E1 1D 45 E1 9D C5 | FO 47 75<br>FO 47 7D<br>FO 47 6B<br>FO 47 74<br>FO 47 72<br>FO 47 7A<br>FO 47 70<br>FO 47 71<br>E1 14 77 E1<br>FO 14 FO 77 | 83<br>85<br>79<br>89<br>81<br>84<br>86<br>75<br>76 | Scan-Code Translation Table (Part 3 of 3) The following scan codes are reserved. | Кеу | Keyboard<br>Scan Code | System<br>Scan Code | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------------------| | Reserved | 6618767F7F7F7F6E80808080807F39913CF234578ADE | 55789ABCDEF0123456666666666777777777777777777777777777 | **Reserved Scan-Code Translation Table** ## Sending Data to the Keyboard The keyboard sends data in the same serial format used to receive data from the keyboard. A parity bit is automatically inserted by the keyboard controller. If the keyboard does not start clocking the data from the keyboard controller within 15 milliseconds, or complete that clocking within 2 milliseconds, a hex FE is placed in the keyboard controller's output buffer, and the transmit time-out error bit is set in the status register. The keyboard is required to respond to all transmissions. The keyboard responds to any valid command and parameter, other than Echo and Resend, with an Acknowledge (ACK) response, hex FA. If the response contains a parity error, the keyboard controller places a hex FE in its output buffer, and the transmit time-out and parity error bits are set in the status register. The keyboard controller is programmed to set a 25-millisecond time limit for the keyboard to respond. If this time limit is exceeded, the keyboard controller places a hex FE in its output buffer and sets the transmit time-out and receive time-out error bits in the status register. No retries are attempted by the keyboard controller for any transmission error. ## **Keyboard Controller System Interface** The keyboard controller communicates with the system through a status register, an output buffer, and an input buffer. The following figure is a block diagram of the keyboard interface. **Keyboard Controller Interface Block Diagram** #### **Status Register** The status register is an 8-bit read-only register at I/O address hex 64. It has information about the state of the keyboard controller (8042) and interface. It may be read at any time. #### **Status-Register Bit Definition** - Bit 7 Parity Error—A 0 indicates the last byte of data received from the keyboard had odd parity. A 1 indicates the last byte had even parity. The keyboard should send data with odd parity. - **Bit 6** Receive Time-Out—A 1 indicates that a transmission was started by the keyboard but did not finish within the programmed receive time-out delay. - Bit 5 Transmit Time-Out—A 1 indicates that a transmission started by the keyboard controller was not properly completed. If the transmit byte was not clocked out within the specified time limit, this will be the only error bit on. #### 1-54 System Board If the transmit byte was clocked out but a response was not received within the programmed time limit, the transmit time-out and receive time-out error bits are set to 1. If the transmit byte was clocked out but the response was received with a parity error, the transmit time-out and parity error bits are set to 1. - Bit 4 Always set to 1. - Bit 3 Command/Data—The keyboard controller's input buffer may be addressed as either I/O address hex 60 or 64. Address hex 60 is defined as the data port, and address hex 64 is defined as the command port. Writing to address hex 64 sets this bit to 1; writing to address hex 60 sets this bit to 0. The controller uses this bit to determine if the byte in its input buffer should be interpreted as a command byte or a data byte. - Bit 2 System Flag—This bit is monitored by the system during the reset routine. If it is a 0, the reset was caused by a power on. The controller sets this bit to 0 at power on and it is set to 1 after a successful self test. This bit can be changed by writing to the system flag bit in the command byte (hex 64). - Bit 1 Input Buffer Full—A 0 indicates that the keyboard controller's input buffer (I/O address hex 60 or 64) is empty. A 1 indicates that data has been written into the buffer but the controller has not read the data. When the controller reads the input buffer, this bit will return to 0. - Bit 0 Output Buffer Full—A 0 indicates that the keyboard controller's output buffer has no data. A 1 indicates that the controller has placed data into its output buffer but the system has not yet read the data. When the system reads the output buffer (I/O address hex 60), this bit will return to a 0. ## **Output Buffer** The output buffer is an 8-bit read-only register at I/O address hex 60. The keyboard controller uses the output buffer to send scan codes received from the keyboard, and data bytes requested by command, to the system. The output buffer should be read only when the output-buffer-full bit in the status register is 1. ## **Input Buffer** The input buffer is an 8-bit write-only register at I/O address hex 60 or 64. Writing to address hex 60 sets a flag, which indicates a data write; writing to address hex 64 sets a flag, indicating a command write. Data written to I/O address hex 60 is sent to the keyboard, unless the keyboard controller is expecting a data byte following a controller command. Data should be written to the controller's input buffer only if the input buffer's full bit in the status register is 0. The following are valid keyboard controller commands. ## Commands (I/O Address Hex 64) - 20 Read Keyboard Controller's Command Byte—The controller sends its current command byte to its output buffer. - Write Keyboard Controller's Command Byte—The next byte of data written to I/O address hex 60 is placed in the controller's command byte. Bit definitions of the command byte are as follows: - **Bit 7** Reserved—Should be written as a 0. - Bit 6 IBM Personal Computer Compatibility Mode—Writing a 1 to this bit causes the controller to convert the scan codes received from the keyboard to those used by the IBM Personal Computer. This includes converting a 2-byte break sequence to the 1-byte IBM Personal Computer format. - Bit 5 IBM Personal Computer Mode—Writing a 1 to this bit programs the keyboard to support the IBM Personal Computer keyboard interface. In this mode the controller does not check parity or convert scan codes. - Bit 4 Disable Keyboard—Writing a 1 to this bit disables the keyboard interface by driving the 'clock' line low. Data is not sent or received. - Bit 3 Not used. - Bit 2 System Flag—The value written to this bit is placed in the system flag bit of the controller's status register. - Bit 1 Reserved—Should be written as a 0. - Bit 0 Enable Output-Buffer-Full Interrupt—Writing a 1 to this bit causes the controller to generate an interrupt when it places data into its output buffer. - AA Self-Test—This commands the controller to perform internal diagnostic tests. A hex 55 is placed in the output buffer if no errors are detected. - AB Interface Test—This commands the controller to test the 'keyboard clock' and 'keyboard data' lines. The test result is placed in the output buffer as follows: - 00 No error detected. - 01 The 'keyboard clock' line is stuck low. - 02 The 'keyboard clock' line is stuck high. - 03 The 'keyboard data' line is stuck low. - 04 The 'keyboard data' line is stuck high. - AD Disable Keyboard Feature—This command sets bit 4 of the controller's command byte. This disables the keyboard interface by driving the clock line low. Data will not be sent or received. - AE Enable Keyboard Interface—This command clears bit 4 of the command byte, which releases the keyboard interface. - C0 Read Input Port—This commands the controller to read its input port and place the data in its output buffer. This command should be used only if the output buffer is empty. - Possible De Read Output Port—This command causes the controller to read its output port and place the data in its output buffer. This command should be issued only if the output buffer is empty. - Write Output Port—The next byte of data written to I/O address hex 60 is placed in the controller's output port. **Note:** Bit 0 of the controller's output port is connected to System Reset. This bit should not be written low as it will reset the microprocessor. - E0 Read Test Inputs—This command causes the controller to read its T0 and T1 inputs. This data is placed in the output buffer. Data bit 0 represents T0, and data bit 1 represents T1. - F0-FF Pulse Output Port—Bits 0 through 3 of the controller's output port may be pulsed low for approximately 6 microseconds. Bits 0 through 3 of this command indicate which bits are to be pulsed. A 0 indicates that the bit should be pulsed, and a 1 indicates the bit should not be modified. **Note:** Bit 0 of the controller's output port is connected to System Reset. Pulsing this bit resets the microprocessor. #### I/O Ports The keyboard controller has two I/O ports, one assigned for input and the other for output. Two test inputs are used by the controller to read the state of the keyboard's 'clock' (T0) and 'data' (T1) lines. The following figures show bit definitions for the input and output ports, and the test-inputs. #### 1-58 System Board ``` Bit 7 Bit 6 Display switch - Primary display attached to: 0 = Color/Graphics adapter 1 = Monochrome adapter Manufacturing Jumper 0 = Manufacturing jumper installed 1 = Jumper not installed Always set to 1 Bit 4 Bit 3 Reserved Bit 2 Reserved Bit 1 Reserved Bit 0 Reserved ``` #### **Input-Port Bit Definitions** | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | Keyboard data (output) Keyboard clock (output) Input buffer empty Output buffer full Reserved Reserved Gate A20 System reset | |-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| |-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------| #### **Output-Port Bit Definitions** Note: In the real address mode Gate A20 prevents address line A20 from being set, maintaining compatibility with the 8088 microprocessor. When in the protected (virtual address) mode, Gate A20 allows addressing above the 1M range. | TO Keyboard data (input) TO Keyboard clock (input) | T1 Keyboard data (input) TO Keyboard clock (input) | |----------------------------------------------------|----------------------------------------------------| |----------------------------------------------------|----------------------------------------------------| **Test-Input Bit Definitions** # **Real-Time Clock CMOS RAM Information** The RTC (Real-time Clock) CMOS RAM chip (Motorola MC146818A) contains the real-time clock and 64 bytes of CMOS RAM. The internal clock circuitry uses 14 bytes of this RAM, and the rest is allocated to configuration information. The following figure shows the CMOS RAM addresses. | Addresses | Description | |------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 - 0D<br>0E<br>0F<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>1A - 2D<br>2E - 2F<br>30<br>31<br>32<br>33<br>34 - 3F | * Real-time clock information * Diagnostic status byte * Shutdown status byte Diskette drive type byte - drives A and B Reserved Fixed disk types byte - drives C and D Reserved Equipment byte Low base memory byte High base memory byte Low expansion memory byte High expansion memory byte Disk C extended byte Disk D extended byte Disk D extended byte Reserved 2-byte CMOS checksum * Low expansion memory byte * Ligh expansion memory byte * Date century byte * Information flags (set during power on) Reserved | #### **CMOS RAM Internal Address Map** \* These bytes are not included in the checksum calculation and are not part of the configuration record. # **Real-Time Clock Information** The following figure describes real-time clock bytes and specifies their addresses. | Byte | Function | Address | |----------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------| | 0 1 2 3 4 5 6 7 8 9 | Seconds Second Alarm Minutes Minute Alarm Hours Hour Alarm Day of Week Date of Month Month Year | 00<br>01<br>02<br>03<br>04<br>05<br>06<br>07<br>08 | | 10<br>11<br>12<br>13 | Status Register A<br>Status Register B<br>Status Register C<br>Status Register D | OÁ<br>OB<br>OC<br>OD | Real-Time Clock Internal Addresses 00 - 0D Note: The setup program initializes registers A, B, C, and D when the time and date are set. Also Interrupt 1A is the BIOS interface to read/set the time and date. It initializes the status bytes the same as the Setup program. # Status Register A - Bit 7 Update in Progress (UIP)—A 1 indicates the time update cycle is in progress. A 0 indicates the current date and time are available to read. - Bit 6-Bit 4 22-Stage Divider (DV2 through DV0)—These three divider-selection bits identify which time-base frequency is being used. The system initializes the stage divider to 010, which selects a 32.768-kHz time base. - Bit 3-Bit 0 Rate Selection Bits (RS3 through RS0)—These bits allow the selection of a divider output frequency. The system initializes the rate selection bits to 0110, which selects a 1.024-kHz square wave output frequency and a 976.562-microsecond periodic interrupt rate. #### Status Register B - Bit 7 Set—A 0 updates the cycle normally by advancing the counts at one-per-second. A 1 aborts any update cycle in progress and the program can initialize the 14 time-bytes without any further updates occurring until a 0 is written to this bit. - Bit 6 Periodic Interrupt Enable (PIE)—This bit is a read/write bit that allows an interrupt to occur at a rate specified by the rate and divider bits in register A. A 1 enables an interrupt, and a 0 disables it. The system initializes this bit to 0. - Bit 5 Alarm Interrupt Enable (AIE)—A 1 enables the alarm interrupt, and a 0 disables it. The system initializes this bit to 0. - Bit 4 Update-Ended Interrupt Enabled (UIE)—A 1 enables the update-ended interrupt, and a 0 disables it. The system initializes this bit to 0. - Bit 3 Square Wave Enabled (SQWE)—A 1 enables the the square-wave frequency as set by the rate selection bits in register A, and a 0 disables the square wave. The system initializes this bit to 0. - Bit 2 Date Mode (DM)—This bit indicates whether the time and date calendar updates are to use binary or binary coded decimal (BCD) formats. A 1 indicates binary, and a 0 indicates BCD. The system initializes this bit to 0. - Bit 1 24/12—This bit indicates whether the hours byte is in the 24-hour or 12-hour mode. A 1 indicates the 24-hour mode and a 0 indicates the 12-hour mode. The system initializes this bit to 1. - Bit 0 Daylight Savings Enabled (DSE)—A 1 enables daylight savings and a 0 disables daylight savings (standard time). The system initializes this bit to 0. #### Status Register C - Bit 7-Bit 4 IRQF, PF, AF, UF—These flag bits are read-only and are affected when the AIE, PIE, and UIE bits in register B are set to 1. - **Bit 3–Bit 0** Reserved—Should be written as a 0. # Status Register D Bit 7 Valid RAM Bit (VRB)—This bit is read-only and indicates the status of the power-sense pin (battery level). A 1 indicates battery power to the real-time clock is good. A 0 indicates the battery is dead, so RAM is not valid. Bits 6-Bit 0 Reserved—Should be written as a 0. # **CMOS RAM Configuration Information** The following lists show bit definitions for the CMOS configuration bytes (addresses hex 0E - 3F). # Diagnostic Status Byte (Hex 0E) - Bit 7 Power status of the real-time clock chip—A 0 indicates that the chip has not lost power (battery good), and a 1 indicates that the chip lost power (battery bad). - Bit 6 Configuration Record (Checksum Status Indicator)—A 0 indicates that checksum is good, and a 1 indicates it is bad. - Bit 5 Incorrect Configuration Information—This is a check, at power-on time, of the equipment byte of the configuration record. A 0 indicates that the configuration information is valid, and a 1 indicates it is invalid. Power-on checks require: - At least one diskette drive to be installed (bit 0 of the equipment byte set to 1). - The primary display adapter setting in configuration matches the system board's display switch setting and the actual display adapter hardware in the system. - Bit 4 Memory Size Comparison—A 0 indicates that the power-on check determined the same memory size as in the configuration record, and a 1 indicates the memory size is different. - Bit 3 Fixed Disk Adapter/Drive C Initialization Status—A 0 indicates that the adapter and drive are functioning properly and the system can attempt "boot up." A 1 indicates that the adapter and/or drive C failed initialization, which prevents the system from attempting to "boot up." Bit 2 Time Status Indicator (POST validity check)— A 0 indicates that the time is valid, and a 1 indicates that it is invalid. Bit 1-Bit 0 Reserved #### Shutdown Status Byte (Hex 0F) The bits in this byte are defined by the power on diagnostics. For more information about this byte, refer to "System BIOS". # **Diskette Drive Type Byte (Hex 10)** Bit 7-Bit 4 Type of first diskette drive installed: **0000** No drive is present. 0001 Double Sided Diskette Drive (48 TPI). 0010 High Capacity Diskette Drive (96 TPI). **0011** 720KB Diskette Drive (3.5 inch). **Note:** 0100 through 1111 are reserved. **Bit 3–Bit 0** Type of second diskette drive installed: 0000 No drive is present. 0001 Double Sided Diskette Drive (48 TPI). 0010 High Capacity Diskette Drive (96 TPI). **0011** 720KB Diskette Drive (3.5 inch). Note: 0100 through 1111 are reserved. Hex address 11 contains a reserved byte. Fixed Disk Type Byte (Hex 12) Bit 7-Bit 4 Defines the type of fixed disk drive installed (drive C): 0000 No fixed disk drive is present. **0001** Define type 1 through type 14 as shown in the following table (also see BIOS to 1110 listing at label FD\_TBL) 1111 Type 16 through 255. See "Drive C Extended Byte (Hex 19)" on page 1-68. Bit 3-Bit 0 Defines the type of second fixed disk drive installed (drive D): **0000** No fixed disk drive is present. 0001 Define type 1 through type 14 as shown in the following table (also see BIOS 1110 listing at label FD\_TBL) 1111 Type 16 through 255. See "Drive D Extended Byte (Hex 1A)" on page 1-68. The following table shows the BIOS fixed disk parameters. | Туре | Cylinders | Heads | Write<br>Precomp | Landing<br>Zone | |-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 | 306<br>615<br>615<br>940<br>940<br>615<br>462<br>733<br>900<br>820<br>855<br>306<br>733 | 44686485535787 | 128<br>300<br>300<br>512<br>512<br>None<br>256<br>None<br>None<br>None<br>None<br>128<br>None | 305<br>615<br>940<br>940<br>615<br>511<br>733<br>901<br>820<br>855<br>319<br>733 | | 15 | Extended Parameters (hex 19 and 1A) | | | | **BIOS Fixed Disk Parameters** # Hex address 13 contains a reserved byte. # **Equipment Byte (Hex 14)** Bit 7-Bit 6 Indicates the number of diskette drives installed: **00** 1 drive 01 2 drives 10 Reserved 11 Reserved # Bit 5-Bit 4 Primary display - 00 Primary display is attached to an adapter that has its own BIOS, such as the Enhanced Graphics Adapter - 01 Primary display is in the 40-column mode and attached to the Color/Graphics Monitor Adapter. - 10 Primary display is in the 80-column mode and attached to the Color/Graphics Monitor Adapter. - 11 Primary display is attached to the Monochrome Display and Printer Adapter. #### Bit 3-Bit 2 Not used. Bit 1 Math Coprocessor presence bit: 0 Math Coprocessor not installed 1 Math Coprocessor installed **Bit 0** Diskette drive presence bit: 0 Diskette drive not installed 1 Diskette drive installed **Note:** The equipment byte defines basic equipment in the system for power-on diagnostics. # Low and High Base Memory Bytes (Hex 15 and 16) Bit 7-Bit 0 Address hex 15—Low-byte base size Bit 7-Bit 0 Address hex 16—High-byte base size Valid Sizes: **0200H** 512K-system board RAM **0280H** 640K-system board RAM. # Low and High Expansion Memory Bytes (Hex 17 and 18) Bit 7-Bit 0 Address hex 17—Low-byte expansion size Bit 7-Bit 0 Address hex 18—High-byte expansion size Valid Sizes: 0200H 512K-Expansion Memory 0400H 1024K-Expansion Memory 0600H 1536K-Expansion Memory through 3C00H 15360K-Expansion Memory (15M maximum). #### **Drive C Extended Byte (Hex 19)** Bit 7-Bit 0 Defines the type of first fixed disk drive installed (drive C): 00000000 through 00001111 are reserved. 00010000 to 111111111 define type 16 through 255 as shown in the following table (see BIOS listing at label FD\_TBL). # **Drive D Extended Byte (Hex 1A)** Bit 7-Bit 0 Defines the type of second fixed disk drive installed (drive D): 00000000 through 00001111 are reserved. 00010000 to 111111111 define type 16 through 255 as shown in the following table (see BIOS listing at label FD\_TBL). The following table shows the BIOS fixed disk parameters for fixed disk drive types 16 through 24. Note: Types 25 through 255 are reserved. | Туре | Cylinders | Heads | Write<br>Precomp | Landing<br>Zone | |------|-----------|-----------|------------------|-----------------| | 16 | 612 | 457757544 | All Cylinders | 663 | | 17 | 977 | | 300 | 977 | | 18 | 977 | | None | 977 | | 19 | 1024 | | 512 | 1023 | | 20 | 733 | | 300 | 732 | | 21 | 733 | | 300 | 732 | | 22 | 733 | | 300 | 733 | | 23 | 306 | | None | 336 | | 24 | 612 | | 305 | 663 | | 25 | Reserved | | | | | • | | | | | | 255 | Reserved | | | | **BIOS Fixed Disk Parameters (Extended)** Hex addresses 1B through 2D are reserved. # Checksum (Hex 2E and 2F) Bit 7-Bit 0 Address hex 2E—High byte of checksum Bit 7-Bit 0 Address hex 2F—Low byte of checksum **Note:** Checksum is calculated on addresses hex 10-2D. #### Low and High Expansion Memory Bytes (Hex 30 and 31) Bit 7-Bit 0 Address hex 30—Low-byte expansion size Bit 7-Bit 0 Address hex 31—High-byte expansion size Valid Sizes: 0200H 512K-Expansion Memory 0400H 1024K-Expansion Memory 0600H 1536K-Expansion Memory through 3C00H 15360K-Expansion Memory (15M maximum). Note: These bytes reflect the total expansion memory above the 1M address space as determined at power-on time. This expansion memory size can be determined through system interrupt 15 (see the BIOS listing). The base memory at power-on time is determined through the system memory-size-determine interrupt (hex 12). # **Date Century Byte (Hex 32)** Bit 7-Bit 0 BCD value for the century (BIOS interface to read and set). # **Information Flag (Hex 33)** Bit 7 When set, this bit indicates that the top 128K of base memory is installed. Bit 6 This bit is set to instruct the Setup utility to put out a first user message after initial setup. Bit 5-Bit 0 Reserved #### Hex addresses 34 through 3F are reserved. # I/O Operations Writing to RTC CMOS RAM involves two steps: 1. OUT to port hex 70 with the internal CMOS address. Bits D0 - D5 contain the required address. Note: Bits D6 and D7 do not go to RTC CMOS RAM. D6 is a "don't care" bit. D7 is the value of the NMI mask: writing a 1 to D7 disables NMI; writing a 0 to D7 enables NMI. 2. OUT to port hex 71 with the data to be written. Reading CMOS RAM also requires two steps: 1. OUT to port hex 70 with the internal CMOS address. Bits D0 - D5 contain the required address. Note: Bits D6 and D7 do not go to RTC CMOS RAM. D6 is a "don't care" bit. D7 is the value of the NMI mask: writing a 1 to D7 disables NMI; writing a 0 to D7 enables NMI. 2. IN from port hex 71, and the data read is returned in the AL register. Note: Execute the steps in the order shown to ensure acknowledgement of the MC146818A Standby lead during system power-downs. # **Specifications** # **System Unit** #### **Size** • Length: 500 millimeters (19.6 inches) • Depth: 410 millimeters (16.1 inches) • Height: 142 millimeters (5.5 inches) # Weight 12.7 kilograms (28 pounds) # **Power Cables** • Length: 1.8 meters (6 feet) #### **Environment** • Air Temperature - System On: 15.6 to 32.2 degrees C (60 to 90 degrees F) - System Off: 10 to 43 degrees C (50 to 110 degrees F) Wet Bulb Temperature - System On: 22.8 degrees C (73 degrees F) - System Off: 26.7 degrees C (80 degrees F) Humidity - System On: 8% to 80% #### 1-72 System Board - System Off: 20% to 80% - Altitude - Maximum altitude: 2545.1 meters (8350 feet) # **Heat Output** • 824 British Thermal Units (BTU) per hour #### **Noise Level** • Operating (without display or printer) - 46 decibels (dba) maximum noise level. #### **Electrical** - Range 1 (57-63 Hz) - Nominal: 115 Vac - Minimum: 90 Vac - Maximum: 137 Vac - Range 2 (47-53 Hz) - Nominal: 230 Vac - Minimum: 180 Vac - Maximum: 265 Vac - Lithium Battery - 6.0 Vdc - 1 Ampere/Hour Capacity - UL Approved. # **Connectors** The system board has the following additional connectors: - One power supply connector (P1) - Battery connector (P2) - Speaker connector (P3) - Keyboard connector (J9). The pin assignments for the system board connector (P1) and the power supply connectors P8 and P9, are as follows. Beginning at the rear of the system, the pins on the system board connector are numbered 1 through 12. Power supply connector P8 attaches to system board connector P1, pins 1 through 6. P9 connects to P1, pins 7 through 12. | System Board<br>Connector | Pin | Assignments | Power Supply<br>Connector | Pin | |---------------------------|----------------------------|----------------------------------------------------------------|---------------------------|----------------------------| | P1 | 1<br>2<br>3<br>4<br>5<br>6 | Power Good<br>+5 Vdc<br>+12 Vdc<br>-12 Vdc<br>Ground<br>Ground | P8 | 1<br>2<br>3<br>4<br>5<br>6 | | | 7<br>8<br>9<br>10<br>11 | Ground<br>Ground<br>-5 Vdc<br>+5 Vdc<br>+5 Vdc<br>+5 Vdc | P9 | 1<br>2<br>3<br>4<br>5 | System Board Connector (P1) to Power Supply Connectors (P8 and P9) The battery connector, P2, is a four-pin, keyed, Berg strip. The pins are numbered 1 through 4 from the rear of the system. The pin assignments are: | Pin | Assignments | |-----|-------------| | 1 | +6 Vdc | | 2 | Key | | 3 | Ground | | 4 | Ground | #### **Battery Connector (P2)** The speaker connector, P3, is a four-pin, keyed, Berg strip. The pins are numbered 1 through 4 from the rear of the system. The pin assignments are: | Pin | Function | |--------|-------------------------------------| | 1 2 34 | Data out<br>Key<br>Ground<br>+5 Vdc | #### **Speaker Connector (P3)** The keyboard connector, J9, is a five-pin, 90-degree Printed Circuit Board (PCB) mounting, DIN connector. For pin numbering, see the "Keyboard" Section. The pin assignments are: | Pin | Assignments | |-----|----------------| | 1 | Keyboard Clock | | 2 | Keyboard Data | | 3 | Reserved | | 4 | Ground | | 5 | +5 Vdc | **Keyboard Connector (J9)** The following figure shows the layout of the system board. 1-76 System Board # Logic Diagrams System Board 1-77 1-78 System Board System Board 1-79 1-80 System Board System Board 1-81 1-82 System Board System Board (Sheet 7 of 22) System Board 1-83 1-84 System Board System Board 1-85 System Board (Sheet 10 of 22) System Board (Sheet 11 of 22) System Board (Sheet 12 of 22) 1-88 System Board System Board 1-89 1-90 System Board System Board 1-91 System Board (Sheet 16 of 22) 1-92 System Board System Board 1-93 1-94 System Board System Board 1-95 1-96 System Board System Board (Sheet 21 of 22) System Board 1-97 System Board (Sheet 22 of 22) # SECTION 2 # **SECTION 2. COPROCESSOR** | Description | 2-3 | |-----------------------|-----| | Programming Interface | 2-3 | | Hardware Interface | 2-4 | **Notes:** # **Description** The Math Coprocessor (80287) enables the IBM Personal Computer XT Model 286 to perform high-speed arithmetic, logarithmic functions, and trigonometric operations. The coprocessor works in parallel with the microprocessor. The parallel operation decreases operating time by allowing the coprocessor to do mathematical calculations while the microprocessor continues to do other functions. The coprocessor works with seven numeric data types, which are divided into the following three classes: - Binary integers (3 types) - Decimal integers (1 type) - Real numbers (3 types). # **Programming Interface** The coprocessor offers extended data types, registers, and instructions to the microprocessor. The coprocessor has eight 80-bit registers, which provide the equivalent capacity of forty 16-bit registers. This register space allows constants and temporary results to be held in registers during calculations, thus reducing memory access and improving speed as well as bus availability. The register space can be used as a stack or as a fixed register set. When used as a stack, only the top two stack elements are operated on. The following figure shows representations of large and small numbers in each data type. | Data Type | Bits | Significant<br>Digits<br>(Decimal) | Approximate Range (Decimal) | |----------------|------|------------------------------------|----------------------------------------------------------| | Word Integer | 16 | 4 | $-32,768 \le X \le +32,767$ | | Short Integer | 32 | 9 | $-2 \times 10^9 \le X \le +2 \times 10^9$ | | Long Integer | 64 | 18 | $-9 \times 10^{18} \le X \le +9 \times 10^{18}$ | | Packed Decimal | 80 | 18 | -999 ≤ X ≤ +999 (18 digits) | | Short Real * | 32 | 6-7 | $8.43 \times 10^{-37} \le X \le 3.37 \times 10^{38}$ | | Long Real * | 64 | 15-16 | $4.19 \times 10^{-307} \le X \le 1.67 \times 10^{308}$ | | Temporary Real | 80 | 19 | $3.4 \times 10^{-4932} \le X \le 1.2 \times 10^{4932}$ | #### **Data Types** \* The Short Real and Long Real data types correspond to the single and double precision data types. #### Hardware Interface The coprocessor uses a 4.77 MHz clock (generated by a 14.318 MHz clock generator divided by three). The coprocessor is wired so that it functions as an I/O device through I/O port addresses hex 00F8, 00FA, and 00FC. The microprocessor sends OP codes and operands through these I/O ports. The microprocessor also receives and stores results through the same I/O ports. The coprocessor's 'busy' signal informs the microprocessor that it is executing; the microprocessor's Wait instruction forces the microprocessor to wait until the coprocessor is finished executing. The coprocessor detects six different exception conditions that can occur during instruction execution. If the appropriate exception mask within the coprocessor is not set, the coprocessor sets its error signal. This error signal generates a hardware interrupt (interrupt 13) and causes the 'busy' signal to the coprocessor to be held in the busy state. The 'busy' signal may be cleared by an 8-bit I/O Write command to address hex F0 with D0 through D7 equal to 0. The power-on self-test code in the system ROM enables IRQ 13 and sets up its vector to point to a routine in ROM. The ROM routine clears the 'busy' signal's latch and then transfers control #### 2-4 Coprocessor to the address pointed to by the NMI interrupt vector. This allows code written for any IBM Personal Computer to work on an IBM Personal Computer XT Model 286. The NMI interrupt handler should read the coprocessor's status to determine if the NMI was caused by the coprocessor. If the interrupt was not generated by the coprocessor, control should be passed to the original NMI interrupt handler. The coprocessor has two operating modes similar to the two modes of the microprocessor. When reset by a power-on reset, system reset, or an I/O write operation to port hex 00F1, the coprocessor is in the real address mode. This mode is compatible with the 8087 Math Coprocessor used in other IBM Personal Computers. The coprocessor can be placed in the protected mode by executing the SETPM ESC instruction. It can be placed back in the real mode by an I/O write operation to port hex 00F1, with D7 through D0 equal to 0. The coprocessor instruction extensions to the microprocessor can be found in Section 6 of this manual. Detailed information for the internal functions of the Intel 80287 Coprocessor can be found in books listed in the bibliography. # **Notes:** # **SECTION 3. POWER SUPPLY** | Inputs | | | | |---------------------------|------|--|------| | Outputs | | | | | DC Output Protection | | | | | Output Voltage Sequencing | <br> | | <br> | | No-Load Operation | | | | | Power-Good Signal | | | | | Connectors | | | | | N | Λ | ŧ | Δ | 0 | • | |-----|---|---|---|---|---| | T 4 | v | ı | C | 3 | ٠ | The system power supply is located *inside* the system unit and provides power for the system board, the adapters, the diskette drives, the fixed disk drive, the keyboard, and the IBM Monochrome Display. # **Inputs** The power supply can operate at 110 Vac, 4.6 A or 220/240 Vac, 2.3 A at frequencies of either $60 \pm 3 \text{ Hz}$ or $50 \pm 3 \text{ Hz}$ . The power supply automatically adjusts to input voltages of 110 Vac or 220 Vac. The following figure shows the input requirements. | Range | Voltage (Vac) | Current (Amperes) | |---------|----------------------------|-------------------| | 115 Vac | Minimum 90<br>Maximum 137 | Maximum 4.6 | | 230 Vac | Minimum 180<br>Maximum 265 | Maximum 2.3 | **Input Requirements** # **Outputs** The power supply provides +5, -5, +12, and -12 Vdc. The following figure shows the load current and regulation tolerance for these voltages. The power to the IBM Monochrome Display display is controlled by the power supply. Warning: The voltage provided to the monochrome display from the power supply is the same as the input line voltage to the power supply. Ensure that the monochrome display is the correct model for the input line voltage. | Nominal | Load Cui | rrent (A) | Regulation | |---------|----------|-----------|-------------| | Output | Minimum | Maximum | Tolerance | | +5 Vdc | 4.0 | 20.0 | +5% to -4% | | -5 Vdc | 0.0 | 0.3 | +10% to -8% | | +12 Vdc | 1.0 | 4.2 | +5% to -4% | | -12 Vdc | 0.0 | 0.25 | +10% to -9% | **DC Load Requirements** # **DC** Output Protection An overcurrent condition will not damage the power supply. # **Output Voltage Sequencing** Under normal conditions, the output voltage levels track within 50 milliseconds of each other when power is applied to, or removed from the power supply, provided at least minimum loading is present. # **No-Load Operation** No damage or hazardous conditions occur when primary power is applied with no load on any output level. In such cases, the power supply may switch off, and a power-on reset will be required. The power supply requires a minimum load for proper operation. # **Power-Good Signal** The power supply provides a 'power-good' signal to indicate proper operation of the power supply. When the supply is switched off for a minimum of one second and then switched on, the 'power-good' signal is generated, assuming there are no problems. This signal is a logical AND of the dc output-voltage sense signal and the ac input-voltage sense signal. The 'power-good' signal is also a TTL-compatible high level for normal operation, and a low level for fault conditions. The ac fail signal causes 'power-good' to go to a low level at least one millisecond before any output voltage falls below the regulation limits. The operating point used as a reference for measuring the one millisecond is normal operation at minimum line voltage and maximum load. The dc output-voltage sense signal holds the 'power-good' signal at a low level when power is switched on until all output voltages have reached their minimum sense levels. The 'power-good' signal has a turn-on delay of at least 100 milliseconds but not longer than 500 milliseconds and is capable of sourcing 2 milliamperes and sinking 10 milliamperes. The following figure shows the minimum sense levels for the output voltages. | Level (Vdc) | Minimum (Vdc) | |-------------|---------------| | +5 | +4.5 | | -5 | -4.3 | | +12 | +10.8 | | -12 | -10.2 | Sense Level # **Connectors** The following figure shows the pin assignments for the power-supply output connectors. | Load Point | Voltage (Vdc) | | |----------------------------------------------|------------------------------------------------------|--| | P8-1<br>P8-2<br>P8-3<br>P8-4<br>P8-5<br>P8-6 | Power Good *<br>+5<br>+12<br>-12<br>Ground<br>Ground | | | P9-1<br>P9-2<br>P9-3<br>P9-4<br>P9-6 | Ground<br>Ground<br>-5<br>+5<br>+5<br>+5 | | | P10-1<br>P10-2<br>P10-3<br>P10-4 | +12<br>Ground<br>Ground<br>+5 | | | P11-1<br>P11-2<br>P11-3<br>P11-4 | +12<br>Ground<br>Ground<br>+5 | | | * see "Power-Good Signal" | | | **Power Supply Output Connectors** # **SECTION 4. KEYBOARD** | Description | 4-3 | |--------------------------------------|------| | Cabling | 4-3 | | Sequencing Key-Code Scanning | 4-4 | | Keyboard Buffer | 4-4 | | Keys | 4-4 | | Power-On Routine | 4-5 | | Power-On Reset | 4-5 | | Basic Assurance Test | 4-5 | | Commands from the System | 4-6 | | Default Disable (Hex F5) | 4-7 | | Echo (Hex EE) | 4-7 | | Enable (Hex F4) | 4-7 | | Invalid Command (Hex EF and F1) | 4-7 | | Read ID (Hex F2) | 4-7 | | Resend (Hex FE) | 4-8 | | Reset (Hex FF) | 4-8 | | Select Alternate Scan Codes (Hex F0) | | | Set All Keys (Hex F7, F8, F9, FA) | | | Set Default (Hex F6) | 4-9 | | Set Key Type (Hex FB, FC, FD) | | | Set/Reset Status Indicators (Hex ED) | 4-10 | | Set Typematic Rate/Delay (Hex F3) | 4-11 | | Commands to the System | 4-13 | | Acknowledge (Hex FA) | 4-13 | | BAT Completion Code (Hex AA) | 4-13 | | BAT Failure Code (Hex FC) | 4-13 | | Echo (Hex EE) | 4-13 | | Keyboard ID (Hex 83AB) | 4-14 | | Key Detection Error (Hex 00 or FF) | 4-14 | | Overrun (Hex 00 or FF) | 4-14 | | Resend (Hex FE) | 4-14 | | Keyboard Scan Codes | 4-15 | | Scan Code Set 1 | 4-16 | | Scan Code Set 2 | 4-20 | | Scan Code Set 3 | 4-24 | | Clock and Data Signals | 4-27 | | Data Stream | 4-27 | | Keyboard Data Output | 4-28 | |-----------------------------|------| | Keyboard Data Input | 4-29 | | Keyboard Encoding and Usage | 4-30 | | Character Codes | 4-30 | | Extended Functions | 4-34 | | Shift States | 4-36 | | Special Handling | 4-38 | | Keyboard Layouts | 4-40 | | French Keyboard | 4-41 | | German Keyboard | 4-42 | | Italian Keyboard | 4-43 | | Spanish Keyboard | 4-44 | | U.K. English Keyboard | 4-45 | | U.S. English Keyboard | 4-46 | | Specifications | 4-47 | | Power Requirements | 4-47 | | Size | 4-47 | | Weight | 4-47 | | Logic Diagram | 4-48 | # **Description** The keyboard has 101 keys (102 in countries outside the U. S.). At system power-on, the keyboard monitors the signals on the 'clock' and 'data' lines and establishes its line protocol. A bidirectional serial interface in the keyboard converts the 'clock' and 'data' signals and sends this information to and from the keyboard through the keyboard cable. #### **Cabling** The keyboard cable connects to the system with a five-pin DIN connector, and to the keyboard with a six-position SDL connector. The following table shows the pin configuration and signal assignments. SDL Connector | DIN Connector<br>Pins | SDL Connector<br>Pins | Signal Name | Signal Type | |---------------------------------|--------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>Shield | D<br>B<br>F<br>C<br>E<br>A<br>Shield | +KBD CLK<br>+KBD DATA<br>Reserved<br>Ground<br>+5.0 Vdc<br>Not used<br>Frame Ground | Input/Output<br>Input/Output<br>Ground<br>Power | #### **Sequencing Key-Code Scanning** The keyboard detects all keys pressed, and sends each scan code in the correct sequence. When not serviced by the system, the keyboard stores the scan codes in its buffer. #### **Keyboard Buffer** A 16-byte first-in-first-out (FIFO) buffer in the keyboard stores the scan codes until the system is ready to receive them. A buffer-overrun condition occurs when more than 16 bytes are placed in the keyboard buffer. An overrun code replaces the 17th byte. If more keys are pressed before the system allows keyboard output, the additional data is lost. When the keyboard is allowed to send data, the bytes in the buffer will be sent as in normal operation, and new data entered is detected and sent. Response codes do not occupy a buffer position. If keystrokes generate a multiple-byte sequence, the entire sequence must fit into the available buffer space or the keystroke is discarded and a buffer-overrun condition occurs. #### **Keys** With the exception of the Pause key, all keys are *make/break*. The make scan code of a key is sent to the keyboard controller when the key is pressed. When the key is released, its break scan code is sent. Additionally, except for the Pause key, all keys are *typematic*. When a key is pressed and held down, the keyboard sends the make code for that key, delays 500 milliseconds $\pm$ 20%, and begins sending a make code for that key at a rate of 10.9 characters per second $\pm$ 20%. The typematic rate and delay can be modified [see "Set Typematic Rate/Delay (Hex F3)" on page 4-11]. If two or more keys are held down, only the last key pressed repeats at the typematic rate. Typematic operation stops when #### 4-4 Keyboard the last key pressed is released, even if other keys are still held down. If a key is pressed and held down while keyboard transmission is inhibited, only the first make code is stored in the buffer. This prevents buffer overflow as a result of typematic action. Note: Scan code set 3 allows key types to be changed by the system. See "Scan Code Tables (Set 3)" on page 4-24 for the default settings. Commands to change the default settings are listed in "Commands from the System" on page 4-6. #### **Power-On Routine** The following activities take place when power is first applied to the keyboard. #### **Power-On Reset** The keyboard logic generates a 'power-on reset' signal (POR) when power is first applied to the keyboard. POR occurs a minimum of 150 milliseconds and a maximum of 2.0 seconds from the time power is first applied to the keyboard. #### **Basic Assurance Test** The basic assurance test (BAT) consists of a keyboard processor test, a checksum of the read-only memory (ROM), and a random-access memory (RAM) test. During the BAT, activity on the 'clock' and 'data' lines is ignored. The LEDs are turned on at the beginning and off at the end of the BAT. The BAT takes a minimum of 300 milliseconds and a maximum of 500 milliseconds. This is in addition to the time required by the POR. Upon satisfactory completion of the BAT, a completion code (hex AA) is sent to the system, and keyboard scanning begins. If a BAT failure occurs, the keyboard sends an error code to the system. The keyboard is then disabled pending command input. Completion codes are sent between 450 milliseconds and 2.5 seconds after POR, and between 300 and 500 milliseconds after a Reset command is acknowledged. Immediately following POR, the keyboard monitors the signals on the keyboard 'clock' and 'data' lines and sets the line protocol. ### **Commands from the System** The following table shows the commands that the system may send and their hexadecimal values. The commands may be sent to the keyboard at any time. The keyboard will respond within 20 milliseconds, except when performing the basic assurance test (BAT), or executing a Reset command. Note: Mode 1 will accept only the 'reset' command. The commands are described below, in alphabetic order. They have different meanings when issued by the keyboard (see "Commands to the System" on page 4-13). #### **Default Disable (Hex F5)** The Default Disable command resets all conditions to the power-on default state. The keyboard responds with ACK, clears its output buffer, sets the default key types (scan code set 3 operation only) and typematic rate/delay, and clears the last typematic key. The keyboard stops scanning, and awaits further instructions. #### Echo (Hex EE) Echo is a diagnostic aid. When the keyboard receives this command, it issues a hex EE response and, if the keyboard was previously enabled, continues scanning. #### Enable (Hex F4) Upon receipt of this command, the keyboard responds with ACK, clears its output buffer, clears the last typematic key, and starts scanning. #### **Invalid Command (Hex EF and F1)** Hex EF and hex F1 are invalid commands and are not supported. If one of these is sent, the keyboard does not acknowledge the command, but returns a Resend command and continues in its prior scanning state. No other activities occur. #### Read ID (Hex F2) This command requests identification information from the keyboard. The keyboard responds with ACK, discontinues scanning, and sends the two keyboard ID bytes. The second byte must follow completion of the first by no more than 500 microseconds. After the output of the second ID byte, the keyboard resumes scanning. #### Resend (Hex FE) The system sends this command when it detects an error in any transmission from the keyboard. It is sent only after a keyboard transmission and before the system allows the next keyboard output. When a Resend is received, the keyboard sends the previous output again (unless the previous output was Resend, in which case the keyboard sends the last byte before the Resend command). #### **Reset (Hex FF)** The system issues a Reset command to start a program reset and a keyboard internal self test. The keyboard acknowledges the command with an ACK and ensures the system accepts ACK before executing the command. The system signals acceptance of ACK by raising the 'clock' and 'data' lines for a minimum of 500 microseconds. The keyboard is disabled from the time it receives the Reset command until ACK is accepted, or until another command is sent that overrides the previous command. Following acceptance of ACK, the keyboard is re-initialized and performs the BAT. After returning the completion code, the keyboard defaults to scan code set 2. #### **Select Alternate Scan Codes (Hex F0)** This command instructs the keyboard to select one of three sets of scan codes. The keyboard acknowledges receipt of this command with ACK, clears both the output buffer and the typematic key (if one is active). The system then sends the option byte and the keyboard responds with another ACK. An option byte value of hex 01 selects scan code set 1, hex 02 selects set 2, and hex 03 selects set 3. An option byte value of hex 00 causes the keyboard to acknowledge with ACK and send a byte telling the system which scan code set is currently in use. After establishing the new scan code set, the keyboard returns to the scanning state it was in before receiving the Select Alternate Scan Codes command. #### Set All Keys (Hex F7, F8, F9, FA) These commands instruct the keyboard to set all keys to the type listed below: | Hex Value | Command | | |-----------|-------------------------------------|--| | F7 | Set All Keys - Typematic | | | F8 | Set All Keys - Make/Break | | | F9 | Set All Keys - Make | | | FA | Set All Keys - Typematic/Make/Break | | The keyboard responds with ACK, clears its output buffer, sets all keys to the type indicated by the command, and continues scanning (if it was previously enabled). Although these commands can be sent using any scan code set, they affect only scan code set 3 operation. #### Set Default (Hex F6) The Set Default command resets all conditions to the power-on default state. The keyboard responds with ACK, clears its output buffer, sets the default key types (scan code set 3 operation only) and typematic rate/delay, clears the last typematic key, and continues scanning. ### Set Key Type (Hex FB, FC, FD) These commands instruct the keyboard to set individual keys to the type listed below: | [ | Hex Value | Command | |---|----------------|------------------------------------------------------------------------------| | | FB<br>FC<br>FD | Set Key Type - Typematic<br>Set Key Type - Make/Break<br>Set Key Type - Make | The keyboard responds with ACK, clears its output buffer, and prepares to receive key identification. Key identification is accomplished by the system identifying each key by its scan code value as defined in scan code set 3. Only scan code set 3 values are valid for key identification. The type of each identified key is set to the value indicated by the command. These commands can be sent using any scan code set, but affect only scan code set 3 operation. #### **Set/Reset Status Indicators (Hex ED)** Three status indicators on the keyboard— Num Lock, Caps Lock, and Scroll Lock—are accessible by the system. The keyboard activates or deactivates these indicators when it receives a valid command-code sequence from the system. The command sequence begins with the command byte (hex ED). The keyboard responds to the command byte with ACK, discontinues scanning, and waits for the option byte from the system. The bit assignments for this option byte are as follows: | Bit | Indicator | |-----|-----------------------| | 0 | Scroll Lock Indicator | | 1 | Num Lock Indicator | | 2 | Caps Lock Indicator | | 3-7 | Reserved (must be Os) | If a bit for an indicator is set to 1, the indicator is turned on. If a bit is set to 0, the indicator is turned off. The keyboard responds to the option byte with ACK, sets the indicators and, if the keyboard was previously enabled, continues scanning. The state of the indicators will reflect the bits in the option byte and can be activated or deactivated in any combination. If another command is received in place of the option byte, execution of the Set/Reset Mode Indicators command is stopped, with no change to the indicator states, and the new command is processed. Immediately after power-on, the lights default to the Off state. If the Set Default and Default Disable commands are received, the lamps remain in the state they were in before the command was received. #### Set Typematic Rate/Delay (Hex F3) The system issues the Set Typematic Rate/Delay command to change the typematic rate and delay. The keyboard responds to the command with ACK, stops scanning, and waits for the system to issue the rate/delay value byte. The keyboard responds to the rate/delay value byte with another ACK, sets the rate and delay to the values indicated, and continues scanning (if it was previously enabled). Bits 6 and 5 indicate the delay, and bits 4, 3, 2, 1, and 0 (the least-significant bit) the rate. Bit 7, the most-significant bit, is always 0. The delay is equal to 1 plus the binary value of bits 6 and 5, multiplied by 250 milliseconds $\pm$ 20%. The period (interval from one typematic output to the next) is determined by the following equation: Period = $(8 + A) \times (2^B) \times 0.00417$ seconds. where: A = binary value of bits 2, 1, and 0. B = binary value of bits 4 and 3. The typematic rate (make codes per second) is 1 for each period and are listed in the following table. | Bit | Typematic<br>Rate ± 20% | Bit | Typematic<br>Rate ± 20% | |----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | 00000<br>00001<br>00010<br>00011<br>00100<br>00101<br>00110<br>00111<br>01000<br>01001<br>01010<br>01010<br>01101<br>01110 | 30.0<br>26.7<br>24.0<br>21.8<br>20.0<br>18.5<br>17.1<br>16.0<br>13.3<br>12.0<br>10.9<br>10.9 | 10000<br>10001<br>10010<br>10011<br>10100<br>10101<br>10110<br>10111<br>11000<br>11001<br>11011<br>11100<br>11101<br>11110 | 7.5<br>6.0<br>5.5<br>5.0<br>4.3<br>4.0<br>3.3<br>2.7<br>2.7<br>2.1<br>2.0 | The default values for the system keyboard are as follows: Typematic rate = 10.9 characters per second $\pm 20\%$ . Delay = $500 \text{ milliseconds } \pm 20\%$ . The execution of this command stops without change to the existing rate if another command is received instead of the rate/delay value byte. ### **Commands to the System** The following table shows the commands that the keyboard may send to the system, and their hexadecimal values. | Command | Hex Value | |----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------| | Key Detection Error/Overrun Keyboard ID BAT Completion Code BAT Failure Code Echo Acknowledge (ACK) Resend Key Detection Error/Overrun | 00 (Code Sets 2 and 3)<br>83AB<br>AA<br>FC<br>EE<br>FA<br>FE<br>FF (Code Set 1) | The commands the keyboard sends to the system are described below, in alphabetic order. They have different meanings when issued by the system (see "Commands from the System" on page 4-6). #### Acknowledge (Hex FA) The keyboard issues Acknowledge (ACK) to any valid input other than an Echo or Resend command. If the keyboard is interrupted while sending ACK, it discards ACK and accepts and responds to the new command. ### **BAT Completion Code (Hex AA)** Following satisfactory completion of the BAT, the keyboard sends hex AA. Any other code indicates a failure of the keyboard. #### **BAT Failure Code (Hex FC)** If a BAT failure occurs, the keyboard sends this code, discontinues scanning, and waits for a system response or reset. #### Echo (Hex EE) The keyboard sends this code in response to an Echo command. #### **Keyboard ID (Hex 83AB)** The Keyboard ID consists of 2 bytes, hex 83AB. The keyboard responds to the Read ID with ACK, discontinues scanning, and sends the 2 ID bytes. The low byte is sent first followed by the high byte. Following output of Keyboard ID, the keyboard begins scanning. #### **Key Detection Error (Hex 00 or FF)** The keyboard sends a key detection error character if conditions in the keyboard make it impossible to identify a switch closure. If the keyboard is using scan code set 1, the code is hex FF. For sets 2 and 3, the code is hex 00. #### Overrun (Hex 00 or FF) An overrun character is placed in the keyboard buffer and replaces the last code when the buffer capacity has been exceeded. The code is sent to the system when it reaches the top of the buffer queue. If the keyboard is using scan code set 1, the code is hex FF. For sets 2 and 3, the code is hex 00. #### Resend (Hex FE) The keyboard issues a Resend command following receipt of an invalid input or any input with incorrect parity. If the system sends nothing to the keyboard, no response is required. # **Keyboard Scan Codes** The following tables list the key numbers of the three scan code sets and their hexadecimal values. The system defaults to scan set 2, but can be switched to set 1 or set 3 (see "Select Alternate Scan Codes (Hex F0)" on page 4-8). #### Scan Code Set 1 In scan code set 1, each key is assigned a base scan code and, in some cases, extra codes to generate artificial shift states in the system. The typematic scan codes are identical to the base scan code for each key. #### Scan Code Tables (Set 1) The following keys send the codes as shown, regardless of any shift states in the keyboard or the system. Refer to "Keyboard Layouts" beginning on page 4-40 to determine the character associated with each key number. | Key Number | Make Code | Break Code | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | 1 2 3 4 5 6 7 8 9 10 1 12 3 15 6 7 8 9 10 1 12 3 15 6 7 8 9 2 1 2 2 3 4 5 6 7 8 9 3 1 2 3 3 3 2 3 3 3 2 3 3 3 3 3 4 5 6 7 8 9 10 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 29<br>023<br>04<br>05<br>06<br>07<br>08<br>00<br>00<br>00<br>00<br>00<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18<br>19<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18<br>18 | A8888888888888889999999999988888888888 | | IUI-KEY I | ceyboard only | • | | Key Number | Make Code | Break Code | |-------------------------------------------|----------------------------------------|-------------------------------------------------| | 33333334444444445555555555666669999999999 | 22222222222222222222222222222222222222 | A12345678BCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA | | j ^^ 102-ke | y keyboard on | ıy. | | Key Number | Make Code | Break Code | |------------|-----------|------------| | 120 | 43 | C3 | | 121 | 44 | C4 | | 122 | 57 | D7 | | 123 | 58 | D8 | | 125 | 46 | C6 | The remaining keys send a series of codes dependent on the state of the various shift keys (Ctrl, Alt, and Shift), and the state of Num Lock (On or Off). Because the base scan code is identical to that of another key, an extra code (hex E0) has been added to the base code to make it unique. | Key<br>No. | Base Case, or<br>Shift+Num Lock<br>Make/Break | Shift Case<br>Make/Break * | Num Lock on<br>Make/Break | |------------|-----------------------------------------------|----------------------------|---------------------------| | 75 | E0 52 | EO AA EO 52 | EO 2A EO 52 | | | /E0 D2 | /EO D2 EO 2A | /EO D2 EO AA | | 76 | E0 53 | EO AA EO 53 | EO 2A EO 53 | | | /E0 D3 | /EO D3 EO 2A | /EO D3 EO AA | | 79 | EO 4B | EO AA EO 4B | EO 2A EO 4B | | | /EO CB | /EO CB EO 2A | /EO CB EO AA | | 80 | EO 47 | EO AA EO 47 | EO 2A EO 47 | | | /EO C7 | /EO C7 EO 2A | /EO C7 EO AA | | 81 | EO 4F | EO AA EO 4F | EO 2A EO 4F | | | /EO CF | /EO CF EO 2A | /EO CF EO AA | | 83 | EO 48 | EO AA EO 48 | EO 2A EO 48 | | | /EO C8 | /EO C8 EO 2A | /EO C8 EO AA | | 84 | EÔ 50 | EO AA EO 50 | EO 2A EO 50 | | | /EO DO | /EO DO EO 2A | /EO DO EO AA | | 85 | EO 49 | EO AA EO 49 | EO 2A EO 49 | | | /EO C9 | /EO C9 EO 2A | /EO C9 EO AA | | 86 | E0 51 | EO AA EO 51 | EO 2A EO 51 | | | /E0 D1 | /EO D1 EO 2A | /EO D1 EO AA | | 89 | EO 4D | EO AA EO 4D | EO 2A EO 4D | | | /EO CD | /EO CD EO 2A | /EO CD EO AA | <sup>\*</sup> If the left Shift key is held down, the AA/2A shift make and break is sent with the other scan codes. If the right Shift key is held down, B6/36 is sent. If both Shift keys are down, both sets of codes are sent with the other scan code. | Key<br>No. | Scan Code Make/Break | Shift Case Make/Break * | |------------|---------------------------------|---------------------------| | 95 | EO 35/EO B5 | EO AA EO 35/EO B5 EO 2A | | * | f the left Shift key is held do | own, the AA/2A shift make | \* If the left Shift key is held down, the AA/2A shift make and break is sent with the other scan codes. If the right Shift key is held down, B6/36 is sent. If both Shift keys are down, both sets of codes are sent with the other scan code. | Key | Scan Code | Ctrl Case, Shift Case | Alt Case | |-----|-----------------------------|-----------------------|------------| | No. | Make/Break | Make/Break | Make/Break | | 124 | EO 2A EO 37<br>/EO B7 EO AA | EO 37/EO B7 | 54/D4 | | Key No. | Make Code | Ctrl Key Pressed | |---------|-------------------|------------------| | 126 * | E1 1D 45 E1 9D C5 | EO 46 EO C6 | #### Scan Code Set 2 In scan code set 2, each key is assigned a unique 8-bit make scan code, which is sent when the key is pressed. Each key also sends a break code when the key is released. The break code consists of 2 bytes, the first of which is the break code prefix, hex F0; the second byte is the same as the make scan code for that key. The typematic scan code for a key is the same as the key's make code. #### Scan Code Tables (Set 2) The following keys send the codes shown, regardless of any shift states in the keyboard or system. Refer to "Keyboard Layouts" beginning on page 4-40 to determine the character associated with each key number. | Key Number | Make Code | Break Code | |-------------------------------------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------| | 1 2 3 4 5 6 7 8 9 10 1 12 13 15 6 17 8 19 20 1 22 23 4 25 6 27 28 29 30 31 * 101-kg | 011222333444560010222334404BD8C | 011265E60DE6560D5D4DC55C344D4BD8C000000000000000000000000000000000000 | | * 101-key keyboard only. | | | | Key Number | Make Code | Break Code | |-------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------| | 33333333333444444444455555555555666669999999999 | 1B 22B 433B 22B 42 55 5 5 1 6 1 22 1 A 2 1 A 1 9 A 5 1 1 2 E E 7 7 6 6 6 7 7 7 7 7 7 7 7 7 7 7 7 7 | 1838433828C2DA21A21A21A494199411900FFFFFFFFFFFFFFFFFFFFFFFFFFFF | | Key Number | Make Code | Break Code | |------------|-----------|------------| | 120 | 01 | FO 01 | | 121 | 09 | FO 09 | | 122 | 78 | FO 78 | | 123 | 07 | FO 07 | | 125 | 7E | FO 7E | The remaining keys send a series of codes dependent on the state of the various shift keys (Ctrl, Alt, and Shift), and the state of Num Lock (On or Off). Because the base scan code is identical to that of another key, an extra code (hex E0) has been added to the base code to make it unique. | Key<br>No. | Base Case, or<br>Shift+Num Lock<br>Make/Break | Shift Case<br>Make/Break * | Num Lock on<br>Make/Break | |------------|-----------------------------------------------|----------------------------|---------------------------| | 75 | EO 70 | E0 F0 12 E0 70 | E0 12 E0 70 | | | /EO FO 70 | /E0 F0 70 E0 12 | /E0 F0 70 E0 F0 12 | | 76 | E0 71 | EO FO 12 EO 71 | E0 12 E0 71 | | | /E0 F0 71 | /EO FO 71 EO 12 | /E0 F0 71 E0 F0 12 | | 79 | EO 6B | EO FO 12 EO 6B | E0 12 E0 6B | | | /EO FO 6B | /EO FO 6B EO 12 | /E0 F0 6B E0 F0 12 | | 80 | EO 6C | EO FO 12 EO 6C | EO 12 EO 6C | | 81 | /EO FO 6C | /E0 F0 6C E0 12 | /E0 F0 6C E0 F0 12 | | | EO 69 | E0 F0 12 E0 69 | E0 12 E0 69 | | 83 | /E0 F0 69 | /E0 F0 69 E0 12 | /E0 F0 69 E0 F0 12 | | | E0 75 | E0 F0 12 E0 75 | E0 12 E0 75 | | 84 | /EO FO 75 | /EO FO 75 EO 12 | /E0 F0 75 E0 F0 12 | | | EO 72 | EO FO 12 EO 72 | E0 12 E0 72 | | 85 | /EO FO 72 | /E0 F0 72 E0 12 | /E0 F0 72 E0 F0 12 | | | EO 7D | E0 F0 12 E0 7D | E0 12 E0 7D | | | /EO FO 7D | /E0 F0 7D E0 12 | /E0 F0 7D E0 F0 12 | | 86 | EO 7A | EO FO 12 EO 7A | E0 12 E0 7A | | | /EO FO 7A | /EO FO 7A EO 12 | /E0 F0 7A E0 F0 12 | | 89 | EO 74 | EO FO 12 EO 74 | EO 12 EO 74 | | | /EO FO 74 | /EO FO 74 EO 12 | /EO FO 74 EO FO 12 | If the left Shift key is held down, the FO 12/12 shift make and break is sent with the other scan codes. If the right Shift key is held down, FO 59/59 is sent. If both Shift keys are down, both sets of codes are sent with the other scan code. | Key<br>No. | Scan Code Make/Break | Shift Case Make/Break * | |------------|------------------------------|-------------------------| | 95 | E0 4A/E0 F0 4A | EO FO 12 4A/EO 12 FO 4A | | * | If the left Shift key is hel | | If the left Shift key is held down, the FO 12/12 shift make and break is sent with the other scan codes. If the right Shift key is held down, FO 59/59 is sent. If both Shift keys are down, both sets of codes are sent with the other scan code. | Key | Scan Code | Ctrl Case, Shift Case | Alt Case | |-----|-----------------------------------|-----------------------|------------| | No. | Make/Break | Make/Break | Make/Break | | 124 | EO 12 EO 7C<br>/EO FO 7C EO FO 12 | EO 7C/EO FO 7C | 84/F0 84 | | Key No. | Make Code | Ctrl Key Pressed | |---------|-------------------------|------------------| | 126 * | E1 14 77 E1 F0 14 F0 77 | E0 7E E0 F0 7E | ## Scan Code Set 3 In scan code set 3, each key is assigned a unique 8-bit make scan code, which is sent when the key is pressed. Each key also sends a break code when the key is released. The break code consists of 2 bytes, the first of which is the break-code prefix, hex F0; the second byte is the same as the make scan code for that key. The typematic scan code for a key is the same as the key's make code. With this scan code set, each key sends only one scan code, and no keys are affected by the state of any other keys. ## Scan Code Tables (Set 3) The following keys send the codes shown, regardless of any shift states in the keyboard or system. Refer to "Keyboard Layouts" beginning on page 4-40 to determine the character associated with each key number. | Key Number | lumber Make Code | Break Code | Default Key State | |-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>15<br>16<br>17<br>18<br>19<br>20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28 | 45<br>45<br>46<br>55<br>66<br>60<br>17<br>8<br>9<br>9<br>20<br>21<br>22<br>35<br>30<br>43<br>44<br>40<br>54 | F00011265E60DE6560D50D4DC55C334DE65E60D5D4DC55C3344D4BFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF | Typematic | | Key Number | Make Code | Break Code | Default Key State | |-----------------------------------------------|----------------------------|----------------|--------------------------| | 29 * | 5¢ | F0 5C | Typematic | | 30 | 14 | FO 14 | Make/Break | | 31 | 1C | FO 1C | Typematic | | 32<br>33 | 1B | FO 1B | Typematic | | 33 | 23 | FO 23 | Typematic | | 34 | 2B | FO 2B | Typematic | | 35<br>36 | 34 | FO 34 | Typematic | | 36 | 33 | F0 33 | Typematic | | 37<br>38 | 3B<br>42 | FO 3B | Typematic | | 38 | 42 | FO 42 | Typematic | | 39 | 4B | FO 4B | Typematic | | 39<br>40 | 4C | FO 4C | Typematic | | 41 | 52 | F0 52 | Typematic | | 42 ** | 52 | FO 53 | Typematic | | 42 | 53<br>5A | F0 5A | Typematic | | 43<br>44 | 12 | FO 12 | Make/Break | | ካፍ ** | 12 | F0 12 | | | 45 **<br>46 | 13<br>1A | FO 1A | Typematic | | 47 | 22 | F0 1A<br>F0 22 | Typematic | | 48 | 21 | F0 21 | Typematic | | | 2 A | F0 21 | Typematic | | 49 | 32<br>32 | F0 2A<br>F0 32 | Typematic | | 50<br>51<br>52<br>53<br>54<br>557<br>58<br>60 | 32<br>31 | | Typematic | | 5, | | F0 31 | Typematic | | 54 | 3A<br>41 | FO 3A<br>FO 41 | Typematic | | 55 | | | Typematic | | 24 | 49<br>4A | FO 49<br>FO 4A | Typematic | | 22 | | F0 4A<br>F0 59 | Typematic | | 2/ | 59<br>11 | F0 59<br>F0 11 | Make/Break<br>Make/Break | | 20 | 11 | | Make/Break | | | 19<br>29 | F0 19 | Make/Break | | 61 | 29 | F0 29 | Typematic | | 62 | 39<br>58<br>67 | F0 39<br>F0 58 | Make only | | 64 | 50 | | Make only | | 75<br>76 | 6/ | F0 67 | Make only | | /6 | 64 | F0 64 | Typematic | | 79<br>80 | 61<br>6E | F0 61<br>F0 6E | Typematic | | 81 | | F0 65 | Make only | | 01 | 65 | [0 65 | Make only | | 83<br>84<br>85<br>86 | 63<br>60 | F0 63<br>F0 60 | Typematic | | 04<br>9r | 6F | F0 60<br>F0 6F | Typematic | | <b>9</b> 5 | 6D | F0 6F<br>F0 6D | Make only | | 86<br>89 | | | Make only | | 02 | 6A<br>76 | F0 6A | Typematic | | 90 | /6 | F0 76 | Make only | | 91 | 6C<br>6B | F0 6C<br>F0 6B | Make only | | 92 | PR | 1 10 68 | Make only | | 93 | 69 | F0 69 | Make only | | 95<br>96 | <u> </u> | F0 77 | Make only | | 96 | 69<br>77<br>75<br>73<br>72 | F0 75<br>F0 73 | Make only | | | 1 /3 | F0 73 | Make only | | 97<br>98 | 1 42 1 | FO 72 | Make only | \* 101-key keyboard only. \*\* 102-key keyboard only. ## **Clock and Data Signals** The keyboard and system communicate over the 'clock' and 'data' lines. The source of each of these lines is an open-collector device on the keyboard that allows either the keyboard or the system to force a line to an inactive (low) level. When no communication is occurring, the 'clock' line is at an active (high) level. The state of the 'data' line is held active(high) by the keyboard. When the system sends data to the keyboard, it forces the 'data' line to an inactive level and allows the 'clock' line to go to an active level. An inactive signal will have a value of at least 0, but not greater than +0.7 volts. A signal at the inactive level is a logical 0. An active signal will have a value of at least +2.4, but not greater than +5.5 volts. A signal at the active level is a logical 1. Voltages are measured between a signal source and the dc network ground. The keyboard 'clock' line provides the clocking signals used to clock serial data to and from the keyboard. If the host system forces the 'clock' line to an inactive level, keyboard transmission is inhibited. When the keyboard sends data to, or receives data from the system, it generates the 'clock' signal to time the data. The system can prevent the keyboard from sending data by forcing the 'clock' line to an inactive level; the 'data' line may be active or inactive during this time. During the BAT, the keyboard allows the 'clock' and 'data' lines to go to an active level. #### **Data Stream** Data transmissions to and from the keyboard consist of an 11-bit data stream (Mode 2) sent serially over the 'data' line. A logical 1 is sent at an active (high) level. The following table shows the functions of the bits. | Bit | Function | |-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10 | Start bit (always 0) Data bit 0 (least-significant) Data bit 1 Data bit 2 Data bit 3 Data bit 4 Data bit 5 Data bit 6 Data bit 7 (most-significant) Parity bit (odd parity) Stop bit (always 1) | The parity bit is either 1 or 0, and the 8 data bits, plus the parity bit, always have an odd number of 1's. **Note:** Mode 1 is a 9-bit data stream that does not have a parity bit or stop bit and the start bit is always 1. ## **Keyboard Data Output** When the keyboard is ready to send data, it first checks for a keyboard-inhibit or system request-to-send status on the 'clock' and 'data' lines. If the 'clock' line is inactive (low), data is stored in the keyboard buffer. If the 'clock' line is active (high) and the 'data' line is inactive (request-to-send), data is stored in the keyboard buffer, and the keyboard receives system data. If the 'clock' and 'data' lines are both active, the keyboard sends the 0 start bit, 8 data bits, the parity bit, and the stop bit. Data will be valid before the trailing edge and beyond the leading edge of the clock pulse. During transmission, the keyboard checks the 'clock' line for an active level at least every 60 milliseconds. If the system lowers the 'clock' line from an active level after the keyboard starts sending data, a condition known as *line contention* occurs, and the keyboard stops sending data. If line contention occurs before the leading edge of the 10th clock signal (parity bit), the keyboard buffer returns the 'clock' and 'data' lines to an active level. If contention does not occur by the 10th clock signal, the keyboard completes the transmission. Following line contention, the system may or may not request the keyboard to resend the data. Following a transmission, the system can inhibit the keyboard until the system processes the input, or until it requests that a response be sent. ### **Keyboard Data Input** When the system is ready to send data to the keyboard, it first checks to see if the keyboard is sending data. If the keyboard is sending, but has not reached the 10th 'clock' signal, the system can override the keyboard output by forcing the keyboard 'clock' line to an inactive (low) level. If the keyboard transmission is beyond the 10th 'clock' signal, the system must receive the transmission. If the keyboard is not sending, or if the system elects to override the keyboard's output, the system forces the keyboard 'clock' line to an inactive level for more than 60 microseconds while preparing to send data. When the system is ready to send the start bit (the 'data' line will be inactive), it allows the 'clock' line to go to an active (high) level. The keyboard checks the state of the 'clock' line at intervals of no more than 10 milliseconds. If a system request-to-send (RTS) is detected, the keyboard counts 11 bits. After the 10th bit, the keyboard checks for an active level on the 'data' line, and if the line is active, forces it inactive, and counts one more bit. This action signals the system that the keyboard has received its data. Upon receipt of this signal, the system returns to a ready state, in which it can accept keyboard output, or goes to the inhibited state until it is ready. If the keyboard 'data' line is found at an inactive level following the 10th bit, a framing error has occurred, and the keyboard continues to count until the 'data' line becomes active. The keyboard then makes the 'data' line inactive and sends a Resend. Each system command or data transmission to the keyboard requires a response from the keyboard before the system can send its next output. The keyboard will respond within 20 milliseconds unless the system prevents keyboard output. If the keyboard response is invalid or has a parity error, the system sends the command or data again. However, the two byte commands require special handling. If hex F3 (Set Typematic Rate/Delay), hex F0 (Select Alternate Scan Codes), or hex ED (Set/Reset Mode Indicators) have been sent and acknowledged, and the value byte has been sent but the response is invalid or has a parity error, the system will resend both the command and the value byte. ## **Keyboard Encoding and Usage** The keyboard routine, provided by IBM in the ROM BIOS, is responsible for converting the keyboard scan codes into what will be termed *Extended ASCII*. The extended ASCII codes returned by the ROM routine are mapped to the U.S. English keyboard layout. Some operating systems may make provisions for alternate keyboard layouts by providing an interrupt replacer, which resides in the read/write memory. This section discusses only the ROM routine. Extended ASCII encompasses 1-byte character codes, with possible values of 0 to 255, an extended code for certain extended keyboard functions, and functions handled within the keyboard routine or through interrupts. #### **Character Codes** The character codes described later are passed through the BIOS keyboard routine to the system or application program. A "-1" means the combination is suppressed in the keyboard routine. The codes are returned in the AL register. See "Characters, Keystrokes, and Color" later in this manual for the exact codes. SECTION 4 The following figure shows the keyboard layout and key positions. 101/102-Key Keyboard 4-31 | Key | Base Case | Uppercase | Ctrl | Alt | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | 1 2 3 4 5 6 7 8 9 10 11 12 13 5 16 17 8 9 10 11 12 13 5 16 17 8 9 10 12 22 23 4 5 6 7 8 9 0 1 1 12 22 23 4 5 6 7 8 9 0 1 1 12 22 23 4 5 6 7 8 9 0 1 1 12 22 23 4 5 6 7 8 9 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>0<br> | ~!@#\$% ^&* () | -1 -1 Nul(000) (*) -1 -1 -1 -1 RS(030) -1 -1 -1 -1 US(031) -1 Del(127) (*) DC1(017) ETB(023) ENQ(005) DC2(018) DC2(018) DC4(020) EM(025) NAK(021) HT(009) SI(015) DLE(016) Esc(027) GS(029) FS(028) -1 SOH(001) DC3(019) EOT(004) ACK(006) BEL(007) BS(008) LF(010) VT(011) FF(012) -1 LF(010) -1 SUB(026) CAN(024) ETX(003) | (((((((((((((((((((((((((((((((((((((( | Notes: (\*) Refer to "Extended Functions" in this section. (\*\*) Refer to "Special Handling" in this section. Character Codes (Part 1 of 2) ## 4-32 101/102-Key Keyboard | Key | Base Case | Uppercase | Ctrl | Alt | |-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------| | 49<br>50<br>51<br>52<br>53<br>54<br>55<br>57<br>Shift | v<br>b<br>n<br>m | V<br>B<br>N<br>M<br><> > | SYN(022)<br>STX(002)<br>S0(014)<br>CR(013)<br>-1<br>-1<br>-1 | (*)<br>(*)<br>(*)<br>(*)<br>(*)<br>(*)<br>-1 | | (Right)<br>58 Ctrl<br>(Left) | -1 | -1 | -1 | -1 | | 60 Alt<br>(Left) | -1 | -1 | -1 | -1 | | 61<br>62 Alt | Space<br>-1 | Space<br>-1 | Space<br>-1 | Space<br>-1 | | (Right)<br>64 Ctrl<br>(Right) | -1 | -1 | -1 | -1 | | 90 Num<br>Lock | -1 | -1 | -1 | -1 | | 95<br>100<br>105<br>106<br>108<br>110<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>125 Scroll<br>Lock | / + Enter Esc Null (*) Pause(**) | / + Enter Esc Null (*) Pause(**) | (*) (*) (*) (*) (*) Esc Null (*) | (*) (*) (*) (*) (*) (*) (*) Null(*) Null(*) Null(*) Null(*) Null(*) Null(*) Null(*) Null(*) Null(*) Pause(**) | | Notes: (*) Refer to "Extended Functions" in this section. (**) Refer to "Special Handling" in this section. | | | | | Character Codes (Part 2 of 2) The following table lists keys that have meaning only in Num Lock, Shift, or Ctrl states. The Shift key temporarily reverses the current Num Lock state. | Key | Num<br>Lock | Base Case | Alt | Ctrl | |-----------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------| | 91<br>92<br>93<br>96<br>97<br>98<br>99<br>101 | 74<br>18<br>52<br>09<br>6 | Home (*) ← (*) End (*) † (*) (*) ↓ (*) Ins Page Up (*) ← (*) | -1<br>-1<br>-1<br>-1<br>-1<br>-1 | Clear Screen Reverse Word(*) Erase to EOL(*) (*) (*) (*) (*) Top of Text and Home Advance Word | | 103 | 3 | Page Down<br>(*) | -1 | (*)<br>Erase to EO\$<br>(*) | | 104 | • | Delete (*,**) | (**) | (**) | | Note:<br>(*) F<br>(**) | Notes: (*) Refer to "Extended Functions" in this section. (**) Refer to "Special Handling" in this section. | | | | **Special Character Codes** #### **Extended Functions** For certain functions that cannot be represented by a standard ASCII code, an extended code is used. A character code of 000 (null) is returned in AL. This indicates that the system or application program should examine a second code, which will indicate the actual function. Usually, but not always, this second code is the scan code of the primary key that was pressed. This code is returned in AH. The following table is a list of the extended codes and their functions. | Second<br>Code | Function | |---------------------------------------------------|-------------------------------------| | 1 3 1 4 6 2 3 8 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 | Alt Esc Nul Character Alt Backspace | **Keyboard Extended Functions (Part 1 of 2)** | Second<br>Code | Function | | |----------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------| | 151<br>152<br>153<br>155<br>157<br>159<br>160<br>161<br>162<br>163<br>164<br>165 | Alt<br>Alt<br>Alt<br>Alt<br>Alt<br>Alt<br>Alt<br>Alt<br>Alt<br>Alt | Home Up Page Up Left Right End Down Page Down Insert Delete Keypad / Tab Enter | **Keyboard Extended Functions (Part 2 of 2)** #### **Shift States** Most shift states are handled within the keyboard routine, and are not apparent to the system or application program. In any case, the current status of active shift states is available by calling an entry point in the BIOS keyboard routine. The following keys result in altered shift states: Shift: This key temporarily shifts keys 1 through 13, 16 through 29, 31 through 41, and 46 through 55, to uppercase (base case if in Caps Lock state). Also, the Shift temporarily reverses the Num Lock or non-Num Lock state of keys 91 through 93, 96, 98, 99, and 101 through 104. Ctrl: This key temporarily shifts keys 3, 7, 12, 15 through 29, 31 through 39, 43, 46 through 52, 75 through 89, 91 through 93, 95 through 108, 112 through 124 and 126 to the Ctrl state. The Ctrl key is also used with the Alt and Del keys to cause the system-reset function; with the Scroll Lock key to cause the break function; and with the Num Lock key to cause the pause function. The system-reset, break, and pause functions are described under "Special Handling" later in this section. Alt: This key temporarily shifts keys 1 through 29, 31 through 43, 46 through 55, 75 through 89, 95, 100, and 105 through 124 to the Alt state. The Alt key is also used with the Ctrl and Del keys to cause a system reset. The Alt key also allows the user to enter any character code from 1 to 255. The user holds down the Alt key and types the decimal value of the characters desired on the numeric keypad (keys 91 through 93, 96 through 99, and 101 through 103). The Alt key is then released. If the number is greater than 255, a modulo-256 value is used. This value is interpreted as a character code and is sent through the keyboard routine to the system or application program. Alt is handled internal to the keyboard routine. Caps Lock: This key shifts keys 17 through 26, 31 through 39, and 46 through 52 to uppercase. When Caps Lock is pressed again, it reverses the action. Caps Lock is handled internal to the keyboard routine. When Caps Lock is pressed, it changes the Caps Lock Mode indicator. If the indicator was on, it will go off; and if it was off, it will go on. Scroll Lock: When interpreted by appropriate application programs, this key indicates that the cursor-control keys will cause windowing over the text rather than moving the cursor. When the Scroll Lock key is pressed again, it reverses the action. The keyboard routine simply records the current shift state of the Scroll Lock key. It is the responsibility of the application program to perform the function. When Scroll Lock is pressed, it changes the Scroll Lock Mode indicator. If the indicator was on, it will go off; and if it was off, it will go on. Num Lock: This key shifts keys 91 through 93, 96 through 99, and 101 through 104 to uppercase. When Num Lock is pressed again, it reverses the action. Num Lock is handled internal to the keyboard routine. When Num Lock is pressed, it changes the Num Lock Mode indicator. If the indicator was on, it will go off; if it was off, it will go on. **Shift Key Priorities and Combinations:** If combinations of the Alt, Ctrl, and Shift keys are pressed and only one is valid, the priority is as follows: the Alt key is first, the Ctrl key is second, and the Shift key is third. The only valid combination is Alt and Ctrl, which is used in the system-reset function. ## **Special Handling** #### **System Reset** The combination of any Alt, Ctrl, and Del keys results in the keyboard routine that starts a system reset or restart. System reset is handled by BIOS. #### **Break** The combination of the Ctrl and Pause/Break keys results in the keyboard routine signaling interrupt hex 1B. The extended characters AL=hex 00, and AH=hex 00 are also returned. #### **Pause** The Pause key causes the keyboard interrupt routine to loop, waiting for any character or function key to be pressed. This provides a method of temporarily suspending an operation, such as listing or printing, and then resuming the operation. The method is not apparent to either the system or the application program. The key stroke used to resume operation is discarded. Pause is handled internal to the keyboard routine. #### **Print Screen** The Print Screen key results in an interrupt invoking the print-screen routine. This routine works in the alphameric or graphics mode, with unrecognizable characters printing as blanks. #### System Request When the System Request (Alt and Print Screen) key is pressed, a hex 8500 is placed in AX, and an interrupt hex 15 is executed. When the SysRq key is released, a hex 8501 is placed in AX, and another interrupt hex 15 is executed. If an application is to use System Request, the following rules must be observed: Save the previous address. Overlay interrupt vector hex 15. Check AH for a value of hex 85: If yes, process may begin. If no, go to previous address. The application program must preserve the value in all registers, except AX, upon return. System Request is handled internal to the keyboard routine. #### Other Characteristics The keyboard routine does its own buffering, and the keyboard buffer is large enough to support entries by a fast typist. However, if a key is pressed when the buffer is full, the key will be ignored and the "alarm" will sound. The keyboard routine also suppresses the typematic action of the following keys: Ctrl, Shift, Alt, Num Lock, Scroll Lock, Caps Lock, and Ins. During each interrupt hex 09 from the keyboard, an interrupt hex 15, function (AH)=hex 4F is generated by the BIOS after the scan code is read from the keyboard adapter. The scan code is passed in the (AL) register with the carry flag set. This is to allow an operating system to intercept each scan code prior to its being handled by the interrupt hex 09 routine, and have a chance to change or act on the scan code. If the carry flag is changed to 0 on return from interrupt hex 15, the scan code will be ignored by the interrupt handler. # **Keyboard Layouts** The keyboard is available in six layouts: - French - German - Italian - Spanish - U.K. English - U.S. English The various layouts are shown in alphabetic order on the following pages. Nomenclature is on both the top and front face of the keybuttons. The number to the upper right designates the keybutton position. # French Keyboard # German Keyboard 4-42 # Italian Keyboard # Spanish Keyboard # U.K. English Keyboard # U.S. English Keyboard # **Specifications** The specifications for the keyboard are as follows. ## **Power Requirements** - +5 Vdc ± 10% - Current cannot exceed 275 mA ## Size - Length: 492 millimeters (19.4 inches) Depth: 210 millimeters (8.3 inches) Height: 58 millimeters (2.3 inches), legs extended ## Weight 2.25 kilograms (5.0 pounds) 101/102-KEY KEYBOARD # **SECTION 5. SYSTEM BIOS** | System BIOS Usage | 5-3 | |-------------------------------------|--------| | Parameter Passing | 5-4 | | Vectors with Special Meanings | 5-6 | | Other Read/Write Memory Usage | 5-9 | | BIOS Programming Hints | . 5-10 | | Adapters with System-Accessible ROM | | | Modules | . 5-12 | | Ouick Reference | . 5-14 | # Notes: # System BIOS Usage The basic input/output system (BIOS) resides in ROM on the system board and provides low level control for the major I/O devices in the system and provides system services, such as time-of-day and memory size determination. Additional ROM modules may be placed on option adapters to provide device-level control for that option adapter. BIOS routines enable the assembly language programmer to perform block (disk or diskette) or character-level I/O operations without concern for device address and characteristics. During POST, a test is made for valid code starting at address hex E0000 and ending at hex EFFFF. The goal of the BIOS is to provide an operational interface to the system and relieve the programmer of concern about the characteristics of hardware devices. The BIOS interface isolates the user from the hardware, allowing new devices to be added to the system, yet retaining the BIOS level interface to the device. In this manner, hardware modifications and enhancements are not apparent to user programs. The IBM Personal Computer Macro Assembler manual and the IBM Personal Computer Disk Operating System (DOS) manual provide useful programming information related to this section. A complete listing of the BIOS is given later in this section. Access to the BIOS is through program interrupts of the microprocessor in the real mode. Each BIOS entry point is available through its own interrupt. For example, to determine the amount of base RAM available in the system with the microprocessor in the real mode, INT 12H invokes the BIOS routine for determining the memory size and returns the value to the caller. ## **Parameter Passing** All parameters passed to and from the BIOS routines go through the 80286 registers. The prolog of each BIOS function indicates the registers used on the call and return. For the memory size example, no parameters are passed. The memory size, in 1K increments, is returned in the AX register. If a BIOS function has several possible operations, the AH register is used at input to indicate the desired operation. For example, to set the time of day, the following code is required: ``` MOV AH,1 ; function is to set time-of-day MOV CX,HIGH_COUNT ; establish the current time DX,LOW_COUNT INT 1AH ; set the time ``` To read the time of day: ``` MOV AH,O ; function is to read time-of-day INT 1AH ; read the timer ``` The BIOS routines save all registers except for AX and the flags. Other registers are modified on return only if they are returning a value to the caller. The exact register usage can be seen in the prolog of each BIOS function. The following figure shows the interrupts with their addresses and functions. | Int | Address | Name | BIOS Entry | |-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------| | 0 1 2 3 4 5 6 7 8 9 A B C D E F 0 1 1 2 | 0-3<br>4-7<br>8-B<br>C-F<br>10-13<br>14-17<br>18-18<br>10-23<br>24-27<br>28-27<br>28-28<br>20-33<br>34-37<br>38-38<br>30-34<br>40-47<br>48-48 | Divide by Zero Single Step Non-maskable Breakpoint Overflow Print Screen Reserved Time of Day Keyboard Reserved Communications Communications Alternate Printer Diskette Printer Video Equipment Check Memory | D11 D11 NMI INT D11 PRINT_SCREEN D11 TIMER_INT KB_INT D11 D11 D11 D11 D11 D11 VIDEO IO EQUIPMENT MEMORY SIZE | | 13 | 4C-4F | Diskette/Disk | DETERMINE DISKETTE 10 RS232 10 CASSETTE 10/System Extensions KEYBOARD 10 PRINTER TO F600:0000 BOOTSTRAP TIME OF DAY DUMMY RETURN DUMMY RETURN | | 14 | 50-53 | Communications | | | 15 | 54-57 | Cassette | | | 16 | 58-5B | Keyboard | | | 17 | 5C-5F | Printer | | | 18 | 60-63 | Resident BASIC | | | 19 | 64-68 | Bootstrap | | | 1A | 68-6B | Time of Day | | | 1B | 6C-6F | Keyboard Break | | | 1C | 70-73 | Timer Tick | | | 1D | 74-77 | Video Initialization | VIDEO PARMS | | 1E | 78-7B | Diskette Parameters | DISK_BASE | | 1F | 7C-7F | Video Graphics Chars | O | 80286-2 Program Interrupt Listing (Real Mode Only) **Note:** For BIOS index, see the BIOS Quick Reference on page 5-14. The following figure shows hardware, BASIC, and DOS reserved interrupts. | Interrupt | Address | Function | |----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28-3F<br>40-5F<br>60-67<br>68-6F<br>70<br>71<br>72<br>73<br>74<br>75 | 80-83<br>84-87<br>88-88<br>80-93<br>94-97<br>98-98<br>90-97<br>100-17F<br>180-19F<br>100-103<br>104-107<br>108-108<br>100-107 | DOS program terminate DOS function call DOS terminate address DOS Ctrl Break exit address DOS fatal error vector DOS absolute disk read DOS absolute disk write DOS terminate, fix in storage Reserved for DOS Reserved for BIOS | | 80-85<br>86-F0 | 200-217<br>218-3C3 | Reserved for BASIC<br>Used by BASIC interpreter while | | F1-FF | 3C4-3FF | BASIC is running<br>Not used | Hardware, Basic, and DOS Interrupts ## **Vectors with Special Meanings** **Interrupt 15—Cassette I/O:** This vector points to the following functions: - Device open - Device closed - Program termination - Event wait - Joystick support - System Request key pressed ## 5-6 System BIOS - Wait - Move block - Extended memory size determination - Processor to protected mode Additional information about these functions may be found in the BIOS listing. Interrupt 1B—Keyboard Break Address: This vector points to the code that is executed when the Ctrl and Break keys are pressed. The vector is invoked while responding to a keyboard interrupt, and control should be returned through an IRET instruction. The power-on routines initialize this vector to point to an IRET instruction so that nothing will occur when the Ctrl and Break keys are pressed unless the application program sets a different value. This routine may retain control with the following considerations: - The Break may have occurred during interrupt processing, so that one or more End of Interrupt commands must be sent to the 8259 controller. - All I/O devices should be reset in case an operation was underway at the same time. Interrupt 1C—Timer Tick: This vector points to the code that will be executed at every system-clock tick. This vector is invoked while responding to the timer interrupt, and control should be returned through an IRET instruction. The power-on routines initialize this vector to point to an IRET instruction, so that nothing will occur unless the application modifies the pointer. The application must save and restore all registers that will be modified. When control is passed to an application with this interrupt, all hardware interrupts from the 8259 interrupt controller are disabled. Interrupt 1D—Video Parameters: This vector points to a data region containing the parameters required for the initialization of the 6845 on the video adapter. Notice that there are four separate tables, and all four must be reproduced if all modes of operation are to be supported. The power-on routines initialize this vector to point to the parameters contained in the ROM video routines. Interrupt 1E—Diskette Parameters: This vector points to a data region containing the parameters required for the diskette drive. The power-on routines initialize this vector to point to the parameters contained in the ROM diskette routine. These default parameters represent the specified values for any IBM drives attached to the system. Changing this parameter block may be necessary to reflect the specifications of other drives attached. Interrupt 1F—Graphics Character Extensions: When operating in graphics modes 320 x 200 or 640 x 200, the read/write character interface will form a character from the ASCII code point, using a set of dot patterns. ROM contains the dot patterns for the first 128 code points. For access to the second 128 code points, this vector must be established to point at a table of up to 1K, where each code point is represented by 8 bytes of graphic information. At power-on time, this vector is initialized to 000:0, and the user must change this vector if the additional code points are required. Interrupt 40—Reserved: When a Fixed Disk and Diskette Drive Adapter is installed, the BIOS routines use interrupt 40 to revector the diskette pointer. Interrupt 41 and 46—Fixed Disk Parameters: These vectors point to the parameters for the fixed disk drives, 41 for the first drive and 46 for the second. The power-on routines initialize the vectors to point to the appropriate parameters in the ROM disk routine if CMOS is valid. The drive type codes in CMOS are used to select which parameter set each vector is pointed to. Changing this parameter hook may be necessary to reflect the specifications of other fixed drives attached. ## Other Read/Write Memory Usage The IBM BIOS routines use 256 bytes of memory from absolute hex 400 to hex 4FF. Locations hex 400 to 407 contain the base addresses of any RS-232C adapters installed in the system. Locations hex 408 to 40F contain the base addresses of any printer adapters. Memory locations hex 300 to hex 3FF are used as a stack area during the power-on initialization and bootstrap, when control is passed to it from power-on. If the user desires the stack to be in a different area, that area must be set by the application. The following figure shows the reserved memory locations. | Address | Mode | Function | |--------------------|----------------|---------------------------------------------------------------------------------------| | 400-4A1 | ROM BIOS | See BIOS listing | | 4A2-4EF<br>4F0-4FF | | Reserved Reserved as intra-application | | 40 40 | | communication area for any application | | 500-5FF | | Reserved for DOS and BASIC | | 500 | DOS | Print screen status flag store | | | | O=Print screen not active or successful | | 1 | | print screen operation<br>1=Print screen in progress | | | | 255=Error encountered during print | | | | screen operation | | 504 | DOS | Single drive mode status byte | | 510-511 | BASIC | BASIC's segment address store | | 512-515<br>516-519 | BASIC<br>BASIC | Clock interrupt vector segment:offset store Break key interrupt vector segment:offset | | פול-סול | DMS1C | store | | 51A-51D | BASIC | Disk error interrupt vector segment:offset store | **Reserved Memory Locations** The following is the BASIC workspace for DEF SEG (default workspace). | Offset | Length | | |------------------------|--------|---------------------------------------------------------------------------| | 2E | 2 | Line number of current line being executed | | 347 | 2 | Line number of last error | | 30 | 2 | Offset into segment of start of program text | | 2E<br>347<br>30<br>358 | 2 2 2 | Offset into segment of start of variables (end of program text 1-1) | | 6A | 1 | Keyboard buffer contents 0=No characters in buffer 1=Characters in buffer | | 4E | ] 1 | Character color in graphics mode* | ### **Basic Workspace Variables** ### **Example** 100 PRINT PEEK (&H2E) + 256 x PEEK (&H2F) | L | Н | |--------|--------| | Hex 64 | Hex 00 | The following is a BIOS memory map. | Starting Address | | |------------------|-----------------------------| | 00000 | BIOS interrupt vectors | | 001E0 | Available interrupt vectors | | 00400 | BIOS data area | | 00500 | User read/write memory | | E0000 | Read only memory | | F0000 | BIOS program area | **BIOS Memory Map** ## **BIOS Programming Hints** The BIOS code is invoked through program interrupts. The programmer should not "hard code" BIOS addresses into applications. The internal workings and absolute addresses within BIOS are subject to change without notice. If an error is reported by the disk or diskette code, reset the drive adapter and retry the operation. A specified number of retries ### 5-10 System BIOS should be required for diskette reads to ensure the problem is not due to motor startup. When altering I/O-port bit values, the programmer should change only those bits necessary to the current task. Upon completion, the original environment should be restored. Failure to adhere to this practice may cause incompatibility with present and future applications. Additional information for BIOS programming can be found in Section 8 of this manual. #### **Move Block BIOS** The Move Block BIOS was designed to make use of the memory above the 1M address boundary while operating with IBM DOS. The Block Move is done with the Intel 80286 Microprocessor operating in the protected mode. Because the interrupts are disabled in the protected mode, Move Block BIOS may demonstrate a data overrun or lost interrupt situation in certain environments. Communication devices, while receiving data, are sensitive to these interrupt routines; therefore, the timing of communication and the Block Move should be considered. The following table shows the interrupt servicing requirements for communication devices. | Baud Rate | 11 Bit (ms) | 9 bit (ms) | | | | | |-------------------------------------|---------------------------------------|---------------------------------------|--|--|--|--| | 300<br>1200<br>2400<br>4800<br>9600 | 33.33<br>8.33<br>4.16<br>2.08<br>1.04 | 30.00<br>7.50<br>7.50<br>1.87<br>0.93 | | | | | | Times are approximate | | | | | | | **Communication Interrupt Intervals** The following table shows the time required to complete a Block Move. | Block Size | Buffer<br>Addresses | Time in ms | | | | | |---------------------|---------------------------------------|----------------------|--|--|--|--| | Normal<br>512 Byte | Both even<br>Even and odd<br>Both odd | 0.98<br>1.04<br>1.13 | | | | | | Maximum<br>64K | Both even<br>Even and odd<br>Both odd | 37.0<br>55.0<br>72.0 | | | | | | Time is approximate | | | | | | | ### **Move Block BIOS Timing** Following are some ways to avoid data overrun errors and loss of interrupts: - Do not use the Block Move while communicating, or - Restrict the block size to 512 bytes or less while communicating, or - Use even address buffers for both the source and the destination to keep the time for a Block Move to a minimum. ## **Adapters with System-Accessible ROM Modules** The ROM BIOS provides a way to integrate adapters with on-board ROM code into the system. During POST, interrupt vectors are established for the BIOS calls. After the default vectors are in place, a scan for additional ROM modules occurs. At this point, a ROM routine on an adapter may gain control and establish or intercept interrupt vectors to hook themselves into the system. The absolute addresses hex C8000 through E0000 are scanned in 2K blocks in search of a valid adapter ROM. A valid ROM is defined as follows: Byte 0 Hex 55 Byte 1 Hex AA Byte 2 A length indicator representing the number of 512-byte blocks in the ROM Byte 3 Entry by a CALL FAR A checksum is also done to test the integrity of the ROM module. Each byte in the defined ROM module is summed modulo hex 100. This sum must be 0 for the module to be valid. When the POST identifies a valid ROM, it does a CALL FAR to byte 3 of the ROM, which should be executable code. The adapter can now perform its power-on initialization tasks. The adapter's ROM should then return control to the BIOS routines by executing a RETURN FAR. # **Quick Reference** | BIOS MAP | 5-16 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------| | Test1 Data Area Description Common POST and BIOS Equates Test .01 Through Test .16 POST and Manufacturing Test Routines | <b>5-18</b> 5-20 5-22 5-27 5-48 | | <b>Test2</b> Test .17 Through Test .23 | | | Test3. POST Exception Interrupt Tests | 5-66 | | Test4. POST and BIOS Utility Routines CMOS_READ CMOS_WRITE E_MSG P_MSG ERR_BEEP BEEP WAITF CONFIG_BAD PRT_SEG KBD_RESET D11 - Dummy Interrupt Handler Hardware Interrupt 9 Handler (Type 71) | 5-72<br>5-72<br>5-73<br>5-73<br>5-74<br>5-74<br>5-74<br>5-75<br>5-75<br>5-78 | | Test5. Exception Interrupt Tests SYSINIT1 - Build Protected Mode Descriptors GDTBLD - Build the GDT for POST SIDTBLD - Build the IDT for POST Test6 | 5-79<br>5-80<br>5-80<br>5-81<br>5-84 | | STGTSTCNT<br>ROMERR<br>XMIT8042<br>BOOTSTRAP | 5-84<br>5-86<br>5-86<br>5-86 | | Diskette BIOS | 5-88 | | Wood Diek RIMS | : 11 <i>4</i> | | Keyboard BIOS | . 5-126 | |------------------------------------|---------| | Printer BIOS | . 5-139 | | RS232 BIOS | . 5-141 | | Video BIOS | . 5-144 | | BIOS | . 5-162 | | Memory Size Determine | . 5-162 | | Equipment Determine | | | | | | NMI | . 3-103 | | BIOS1 | . 5-164 | | Event Wait | . 5-165 | | Joystick Support | | | Wait | | | | | | Block Move | | | Extended Memory Size Determine | | | Processor to Virtual Mode | | | Configuration Parameters | . 5-174 | | BIOS2 | . 5-177 | | | | | Time of Day | | | Alarm Interrupt Handler | | | Print Screen | | | Timer 1 Interrupt Handler | . 5-182 | | ORGS - PC Compatibility and Tables | 5_183 | | POST Error Messages | | | TOST Effor Wiessages | . 2-103 | ``` | F00012B1D | SEEK | F0001E379 | F1781 | F0001FF62 | SEEKS | F0001E38C | F1782 | F00013E08 | SET_CDLOR | F0001E38C | F1790 | F00013E08 | SET_CDLOR | F0001E38C | F1790 | F00013D47 | SET_CPOS | F0001E3BC | F1791 | F00013D42 | SET_CTOPE | F0001E3D2 | F3A | F00013D82 | SET_MODE | F0001E3D6 | F3D1 | F00013E08 | SET_MODE | F0001E3D6 | F3D1 | F00011B3C | SET_TDD | F0001E406 | F00F_TBL | F00011B3C | SET_TDD | F0001E3D6 | F3D1 | F00011B3C | SET_TDD | F0001E3D6 | F3D1 | F00011B3C | SET_TDD | F0001E3D6 | F3D1 | F00011B3C | SHUT3 | F0001E3D6 | K1 | F00011B3C | SHUT3 | F0001E3D6 | K1 | F00011B3C | SHUT4 | F0001E3B6 | K7 | F00011BCF | SHUT6 | F0001E3B6 | K7 | F00011BCF | SHUT6 | F0001E3B6 | K7 | F00011BCF | SHUT7 | F0001E3B6 | K1 | F00013A25 | SND DXTA | F0001E3B6 | K1 | F00013A25 | SND DXTA | F0001E3B6 | K1 | F00013A25 | SND DXTA | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB | STGTST CNT | F0001E3B6 | K1 | F0001BCB ``` THE BIOS ROUTINES ARE MEANT TO BE ACCESSED THROUGH SOFTWARE INTERRUPTS ONLY. ANY ADDRESSES PRESENT IN THESE LISTINGS ARE INCLUDED ONLY FOR COMPLETENESS, NOT FOR REFERENCE. APPLICATIONS WHICH REFERENCE ANY ABSOLUTE ADDRESSES WITHIN THE CODE SEGMENTS OF BIOS VIOLATE THE STRUCTURE AND DESIGN OF BIOS. ``` PAGE 118,121 TITLE TEST! ---- 04/21/86 POWER ON SELF TEST (POST) ``` THESE LISTINGS PROVIDE INTERFACE INFORMATION FOR ACCESSING THE BIOS ROUTINES. THE POWER ON SELF TEST IS INCLUDED. THE BIOS ROUTINES ARE MEANT TO BE THEOLOGY SOFTMARE INTERRUPTS ONLY. ANY ADDRESSES PRESENT IN THESE LISTINGS ARE INCLUDED ONLY FOR COMPLETENESS, NOT FOR REFERENCE. APPLICATIONS WHICH REFREENCE ANY ABSOLUTE ADDRESSES WITHIN THE CODE SEGMENTS OF BIOS VIOLATE THE STRUCTURE AND DESIGN OF BIOS. | 111 | | | c | PAGE<br>INCLUDE DSEG.IN | ю | | | | |-------------------|--------------|----------|--------|-------------------------|-----------|-------------------------|---|-----------------------------------------------------------------| | 113<br>114<br>115 | | | 0000 | | | LOCATIONS<br>OST & BIOS | | | | 117 | 0000 | | č | ABSO | SEGMENT | AT A | | ADDRESS= 0000:0000 | | 119 | 0000 | | C | | DB | | | START OF INTERRUPT VECTOR TABLE | | 121 | | 11 | č | ●STG_LOC0 | | 7 | 1 | START OF INTERROPT VECTOR TABLE | | 153 | 8000 | 77777777 | c | ONMI_PTR | ORG<br>DD | 4*002H<br>? | | NON-MASKABLE INTERRUPT VECTOR | | 124 | 0014 | | Č | | ORG | 4*005H | | | | 126 | | 7777777 | C | PINTS_PTR | DD | 7 | 1 | PRINT SCREEN INTERRUPT VECTOR | | 127 | 0020 | | C | | ORG | 4*008H | | | | 129 | 0020 | 7777777 | c | ●INT_PTR | DD | ? | 1 | HARDWARE INTERRUPT POINTER (8-F) | | 131 | 0040 | | č | AVIDED 1117 | ORG<br>DD | 4°010H | | VIDEO I/O INTERRUPT VECTOR | | 132 | | 7777777 | ¢ | OVIDEO_INT | | r . | | VIDEO 1/0 INTERROFT VECTOR | | 134 | 004C | 7777777 | ç | ORG_VECTOR | ORG | 4°013H | | DISKETTE/DISK INTERRUPT VECTOR | | 136 | 0060 | | c | | ORG | 4°018H | | , | | 138 | | 7777777 | Č | ●BASIC_PTR | DD | 7 | | POINTER TO CASSETTE BASIC | | 139 | 0074 | | c | | ORG | 4*01DH | | | | 141 | 0074 | 77777777 | Č | OPARM_PTR | DD | 7 | 1 | POINTER TO VIDEO PARAMETERS | | 143 | 0078 | | č | DISK_POINTER | ORG<br>DD | 4*01EH | | POINTER TO DISKETTE PARAMETER TABLE | | 145 | | 7777777 | ç | ODISK_FOINTER | | 7 | 1 | FOINTER TO DISKETTE PARAMETER TABLE | | 146 | 007C | 77777777 | CCC | ●EXT_PTR | ORG<br>DD | 4°01FH<br>? | | POINTER TO GRAPHIC CHARACTERS 128-255 | | 148 | 0100 | | ç | - | ORG | 4*040H | | | | 150 | | 7777777 | CCC | OD I SK_VECTOR | DD | 7 | 1 | POINTER TO DISKETTE INTERRUPT CODE | | 152 | 0104 | | С | | ORG | 4*041H | | | | 153 | 0104 | 7777777 | ç | OHF_TBL_VEC | DD | 7 | 1 | POINTER TO FIRST DISK PARAMETER TABLE | | 155 | 0118 | 77777777 | Ç | OHF1_TBL_VEC | ORG<br>DD | 4*046H | | POINTER TO SECOND DISK PARAMETER TABLE | | 157 | | | С | *** 1_100_100 | ORG | | , | POTRICK TO DESGROUP DIGHT PRINCIPLE TRADEL | | 158<br>159 | 01C0<br>01C0 | 7777777 | ç | OSLAVE_INT_PTR | DD | 4*070H<br>? | | POINTER TO SLAVE INTERRUPT HANDLER | | 160 | 01D8 | | C | - | ORG | 4*076H | | | | 162 | | 7777777 | č | OHDISK_INT | DD | 7 | 1 | POINTER TO FIXED DISK INTERRUPT CODE | | 164 | 0400 | | | | ORG<br>DW | 0400H | | | | 165 | 0400 | 7777 | č | <b>◆TOS</b> | 0# | 7 | | STACK USED DURING POST ONLY USE WILL OVERLAY INTERRUPTS VECTORS | | 167 | 0500 | | 000000 | | ORG | 0500H | | | | 169 | 0500 | | č | ●MFG_TEST_RTN | LABEL | FAR | i | LOAD LOCATION FOR MANUFACTURING TESTS | | 171 | 7C00 | | C | | ORG | 7C00H | | | | 172<br>173 | 7000 | | C | ●BOOT_LOCN | LABEL | FAR | 1 | BOOT STRAP CODE LOAD LOCATION | | 174 | 7C00 | | C | ABS0 | ENDS | | | | | I BM<br>TEST | Personal Computer MAC<br>1 04/21/86 POWER | RO / | SELF TEST (POST | lon 2.00 | | 1-5<br>04-21-86 | |--------------|-------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 373 | | | PAGE | | EQUATES | | | 374<br>375 | | C | INCLUDE POSTEQU | J. INC | | | | 376 | | č | EQUATES | USED BY | POST AND B | BIOS 1 | | 377 | | С | | | | | | 378<br>379 | = OOFC | ç | | =0.1 | OFCH | . PURTEU MARFI BURE | | 380 | - 0002 | č | MODEL_BYTE<br>SUB_MODEL_BYTE<br>BIO3_LEVEL<br>RATE_UPPER<br>RATE_LOWER | EQU | 002H | ; SYSTEM MODEL BYTE<br>; SYSTEM SUB-MODEL TYPE<br>; BIOS REVISION LEVEL<br>; UPPER LIMIT + 13%<br>; LOWER LIMIT - 20% | | 381 | × 0000 | č | BIOS_LEVEL | EQU | 002H<br>000H | BIOS REVISION LEVEL | | 382<br>383 | = F780<br>= F9FD | 0000 | RATE UPPER | EQU | 0F780H<br>0F9FDH | ; UPPER LIMIT + 13X | | 384 | = 1910 | č | WALE TOWER | 540 | OF 9F DH | ; COWER LIMIT - 20% | | 385 | | ç | 1 8042 | KEYBOAR | DINTERFACE | E AND DIAGNOSTIC CONTROL REGISTERS | | 366<br>367 | = 0060<br>= 0061 | Č | PORT A PORT B RAM FAR ON RAM PAR OFF FAMTY ERR GATE2 | EQU | 060H | ; 8042 KEYBOARD SCAN CODE/CONTROL PORT | | 388 | = 00F3 | č | RAM FAR ON | EQU | 111100118 | : AND MASK FOR PARITY CHECKING FNAMER ON | | 389 | = 000C | č | RAM_PAR_OFF | EQU | 000011008 | OR MASK FOR PARITY CHECKING ENABLE OFF | | 390<br>391 | # 00C0<br># 0001 | Č | FARITY_ERR<br>GATE2 | EQU | 11000000B | R/W MEMORY - I/O CHANNEL PARITY ERROR | | 392 | = 000Z | c | SPK2 | EQU | 000000108 | SPEAKER OUTPUT DATA ENABLE BIT | | 393 | = 0010 | С | REFRESH BIT | EQU | 00010000B | REFRESH TEST BIT | | 394<br>395 | = 0020<br>= 0040 | ç | OUT2 _ | EQU | 0010000008 | ; SPEAKER TIMER OUT2 INPUT BIT | | 376 | = 0080 | č | PARITY CHECK | FOU | 100000008 | MEMORY PARITY CHECK OCCURRED BIT MASK | | 397 | ■ 0064 | č | STATUS PORT | EQU | 064H | 8042 STATUS PORT | | 398 | = 0001 | Ç | OUT BUF FULL | EQU | 00000001B | # 0 * +OUTPUT BUFFER FULL | | 399<br>400 | = 0002<br>= 0004 | č | OUTE TO CHECK PARITY CHECK STATUS PORT OUT BUF FULL INPT BUF FULL SYS_FLAG CMD_DATA EVER | EQU | 064H<br>0000001B<br>0000010B<br>0000100B<br>0001000B<br>0010000B | MEMORY PARTITY CHECK OCCURRED BIT MASK<br> 80 4 - DUTPUT BUFFER FULL<br> 1 = + INPUT BUFFER FULL<br> 2 = -SYSTEM FLAG -POST/-SELF TEST<br> 3 = -COMMAND/-DATA<br> 4 = + KEYBOARD INHIBITED<br> 5 = + TRANSMIT TIMEOUT<br> 6 = + PRATITY 15 EVEN | | 401 | <b>= 0008</b> | č | CMD_DATA | EQU | 00001000B | 3 = -COMMAND/+DATA | | 402 | = 0010<br>= 0020 | č | KYBD_INH | EQU | 00010000B | : 4 = +KEYBOARD INHIBITED | | 404 | = 0040 | č | RCV TMOUT | EQU | 01000000B | : 6 * +RECEIVE TIME OUT | | 405 | - 0080 | č | CMD_DATA KYBD_INH TRANS_TMOUT RCV_TMOUT PARTTY_EVEN | EQU | 10000000B | 7 = +PARITY IS EVEN | | 406<br>407 | | č | 8043 | IMBUT B | | FINITION SAYED IN OMEG TST - 1 BASE PLANAR RIW MEMORY EXTENSION 640/X 18 BASE PLANAR RIW MEMORY SIZE 256/5/2 1 LOOP POST JUMPER BIT FOR MANUFACTURING 10 ISPLAY TYPE SWITCH JUMPER BIT 1 KEYBOARD INHIBIT SWITCH BIT | | 408 | = 0008 | ç | BASE MEMB | EQU | 00001000B | BASE PLANAR RTW MEMORY EXTENSION 640/X | | 409 | - 0010 | ç | BASE MEM | EQU | 00010000B | BASE PLANAR R/W MEMORY SIZE 256/512 | | 410 | = 0020<br>= 0040 | C | MFG_LOOP | FOU | 001000008 | : LOOP POST JUMPER B!! FOR MANUFACTURING DISPLAY TYPE SWITCH .NUMPER RIT | | 412 | = 0080 | č | KEY_BO_INHIB | EQU | 10000000B | KEYBOARD INHIBIT SWITCH BIT | | 413 | | ç | | | | | | 414 | = 0060 | č | WRITE 8042 LOC | FOU | HOAO | : WRITE 8042 COMMAND BYTE | | 416 | ■ OOAA | č | SELF_TEST | EQU | DAAH | 8042 SELF TEST | | 417 | ■ 00AB<br>■ 00AD | C | INTR_FACE_CK | EQU | OABH | ; CHECK 8042 INTERFACE COMMAND | | 419 | = OOAE | č | ENA KBD | EQU | OAEH | ENABLE KEYBOARD COMMAND | | 420 | = 00C0 | Č | READ_8042_INPUT | EQU | ОСОН | READ 8042 INPUT PORT | | 421<br>422 | = 00DD<br>= 00DF | č | DISABLE BITZO | EQU | ODDH | ; DISABLE ADDRESS LINE BIT 20 | | 423 | = 00E0 | č | KYBD CEK DATA | EQU | 0E0H | GET KEYBOARD CLOCK AND DATA COMMAND | | 424 | = OOFE | Ç | SHUT_CMD | EQU | OFEH | CAUSE A SHUTDOWN COMMAND | | 425<br>426 | = 0001 | Č | WRITE 8042_LOC<br>SELF TEST<br>INTR FACE_CK<br>DIS RBD<br>ENA KBD<br>READ 8042 INPUT<br>DISABLE BIT20<br>ENABLE BIT20<br>ENABLE BIT20<br>ENABLE BIT20<br>KYBD CLK DATA<br>SHUT-CMD<br>KYBD—CLK | EQU | 001H | ; WRITE 8042 COMMAND BYTE<br>; 8042 SELF TEST<br>; CHECK 8042 INTERFACE COMMAND<br>; DISABLE KEYBOARD COMMAND<br>; ENABLE KEYBOARD COMMAND<br>; READ 8042 INPUT PORT<br>; DISABLE ADDRESS LINE BIT 20<br>; ENABLE ADDRESS LINE BIT 20<br>; EXTRACT ADDRESS LINE BIT 20<br>; CETT KEYBOARD CLOCK AND DATA COMMAND<br>; KAYBOARD CLOCK BIT 0 | | 427 | | | | | | | | 428<br>429 | = OOFF<br>= OOFE | ç | KØ_RESET | EQU | 0FFH | SELF DIAGNOSTIC COMMAND | | 430 | = 00FA | ç | KB_MAKE BREAK | EQU | OFAH | : TYPAMATIC COMMAND | | 431 | = 00F4 | č | KB_ENABCE | EQU | OF4H | KEYBOARD ENABLE | | 432<br>433 | = 00F3<br>= 00F2 | CCC | KB_TYPA_RD | EGU | OF3H | ; TYPAMATIC RATE/DELAY COMMAND | | 434 | = 00EÉ | č | KB_ECHO | EQU | DEEH | ECHO COMMAND | | 435 | = 00ED | Ċ | LED_CMD | EQU | 0EDH | SELF DIAGNOSTIC COMMAND TOPALAT COMMAND TOPALAT COMMAND KEYBOARD ENABLE TYPALATIC RATE/DELAY COMMAND READ KEYBOARD ID COMMAND ECHO COMMAND LED WRITE COMMAND | | 436<br>437 | | č | 1 804 | 2 KEYBDA | RD RESPONSE | I OVER RUN SCAN CODE I RESEND REQUEST I ACKNOWLEGGE FROM TRANSMISSION I KEYBOARD BREAK CODE RESPONSE FROM SELF DIAGNOSTIC | | 438 | = 00FF | č | KB_OVER_RUN | EQU | OFFH | OVER RUN SCAN CODE | | 439<br>440 | = OOFE<br>= OOFA | C | KH_RESEÑO | EQU | OFEH | RESEND REQUEST | | 441 | = 00F0 | č | KB BREAK | EQU | OFOH | : KEYBOARD BREAK CODE | | 442 | = 00AA | Ĉ | KB_OK | EQU | OAAH | RESPONSE FROM SELF DIAGNOSTIC | | 443<br>444 | | č | KEY | | | | | 446 | = 0045 | č | NUM KEY<br>SCROLL_KEY | EQU | 69 | ; SCAN CODE FOR NUMBER LOCK KEY<br>; SCAN CODE FOR SCROLL LOCK KEY<br>; SCAN CODE FOR ALTERNATE SHIFT KEY | | 446 | ■ 0046 | C | SCROLL KEY | EQU | 70 | SCAN CODE FOR SCROLL LOCK KEY | | 447<br>448 | = 0038<br>= 001D | C | ALT KEY | EQU | 29 | | | 449 | = 003A | č | CAPS KEY | EQU | 58 | | | 450<br>451 | = 0053<br>= 0052 | Ċ | DEL_KEY | EQU | 83 | SCAN CODE FOR DELETE KEY SCAN CODE FOR INSERT KEY | | 452 | ± 002A | č | CTL KEY CAPS KEY DEL_REY INS KEY LEFT KEY RIGHT KEY | EQU | 82<br>42 | SCAN CODE FOR INSERT RET<br>SCAN CODE FOR LEFT SHIFT<br>SCAN CODE FOR RIGHT SHIFT | | 453 | × 0036 | č | RIGHT KEY | EQU | 54 | SCAN CODE FOR RIGHT SHIFT | | 454<br>455 | = 0054 | č | SYS_KEY | EQU | 84 | SCAN CODE FOR SYSTEM KEY | | 456 | | C | : ENH | ANCED KE | YBOARD SCAN | CODES | | 457 | = OOAB | • | in s | EQU | OABH | 1 IST ID CHARACTER FOR KBX | | 458<br>459 | = 0041<br>= 0054 | c | 10_5<br>10_5 | EQU | 041H<br>054H | I ZND ID CMARACTER FOR KBX | | 460 | = 0057 | č | ID 2<br>ID 2A<br>FIT M<br>FIZ M | EQU | 87 | FII KEY MAKE | | 461 | <b>= 0058</b> | Č | FIZTM | EQU | 88 | CODES SET ID CHARACTER FOR KBX AND ID CHARACTER FOR KBX ALTERNATE END ID CHAR FOR KBX I FI KEY MAKE I FIZ KEY MAKE GENERAL MARKER CODE | | 462<br>463 | = 00E0<br>= 00E1 | č | MC_E0<br>MC_E1 | EQU<br>EQU | 224<br>225 | : GENERAL MARKER CODE<br>: PAUSE KEY MARKER CODE | | | | • | | | -3- | | | TEST1 04/21/86 POWER ON SELF TEST (POST) | | |----------------------------------------------------------------------------------|-------| | Ard | | | | | | 465 C : FLAG EQUATES WITHIN OKB_FLAG | | | 466 = 0001 C RIGHT SHIFT EQU 00000001B : RIGHT SHIFT KEY DEPRESSED | | | 467 = 0002 C LEFT SHIFT EQU 00000010B : LEFT SHIFT KEY DEPRESSED | | | 468 # 0004 C CTL SHIFT EQU 00000100B ; CONTROL SHIFT KEY DEPRESSED | | | 469 = 0008 C ALTSHIFT EQU 00001000B : ALTERNATE SHIFT KEY DEPRESSED | | | 1 | | | 47: = 0020 C NUM_STĀTE EQU 00100000B ; NUM LOCK STATE IS ACTIVE | | | 472 = 0040 C CAPS_STATE EQU 01000000B ; CAPS_LOCK_STATE_IS_ACTIVE | | | 473 = 0080 C INS_STATE EQU 10000000B INSERT STATE IS ACTIVE | | | 474 C - | | | 475 C 3 | | | CTL_SHIFT | | | 417 = 0002 C L_ALT_SHIFT EQU 00000010B ; LEFT ALT KEY DOWN | | | 478 = 0004 C SYS_SRIFT EQU 00000100B SYSTEM KEY DEPRESSED AND HELD | | | 479 = 0008 C HOLD_STATE EQU 00001000B SUSPEND KEY HAS BEEN TOGGLED | | | 480 = 0010 C SCROEL_SHIFT EQU 00010000B ; SCROLL LOCK KEY IS DEPRESSED | | | 481 = 0020 C NUM_SHTFT EQU 00100000B : NUM LOCK KEY IS DEPRESSED | | | 482 = 0040 | | | 483 = 0080 C INS_SHIFT EQU 10000000B ; INSERT KEY IS DEPRESSED | | | 484 C | | | 486 = 0007 C KB LEDS EQU 00000111B : KEYBOARD LED STATE BITS | | | 485 B 0007 C KB LEDS EQU 0000011B 3 RETBURD LED STATE BITS | | | 487 C ; 00000001B ; SCROLL LOCK INDICATOR 488 C : 00000010B ; NUM LOCK INDICATOR | | | 489 C : 00000100B : NOM LOCK INDICATOR 489 C : 00000100B : CAPS LOCK INDICATOR | | | 490 C : EQU 00001000B : RESERVED (MUST BE ZERO) | | | 491 = 0010 C KB FA EQU 00010000B : ACKNOWLEDGMENT RECEIVED | | | 492 = 0020 C KB FE EQU 00100000B ; RESEND RECEIVED FLAG | | | 493 = 0040 C KB PR LED EQU 01000000B MODE INDICATOR UPDATE | | | 494 = 0080 C KB ERR EQU 10000000B : KEYBOARD TRANSMIT ERROR FLAG | | | 484 C | | | 496 C ;FLAGS EQUATES WITHIN 9KB_FLAG 3 | | | 497 = 0001 C LC E1 EQU 00000001B : LAST CODE WAS THE E1 HIDDEN CODE | | | 498 = 0002 C LC E0 EQU 00000010B : LAST CODE WAS THE E0 HIDDEN CODE | | | 499 = 0004 C R CTL SHIFT EQU 00000100B ; RIGHT CTL KEY DOWN | | | 500 = 0008 C RTALTTSHIFT EQU 00001000B ; RIGHT ALT KEY DOWN | | | 601 = 0008 C GRAPH_ON EQU 00001000B ; ALT GRAPHICS KEY DOWN (WT ONLY) | | | 502 = 0010 C KBX EQU 00010000B ; ENHANCED KEYBOARD INSTALLED | | | 503 = 0020 C SET_NUM_LK EQU 00100000B ; FORCE NUM LOCK IF READ ID AND KE | x | | C | ACTER | | 505 = 0080 C RD_ID EQU 10000000B ; DOING A READ ID (MUST BE BITO) | | ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 --- 04/21/86 POWER ON SELF TEST (POST) POSTEQU.INC - COMMON EQUATES 1-7 04-21-86 = 0000 = 0001 = 0003 = 0004 = 0005 = 0006 = 0007 = 0008 = 0000 = 000C = 000C = 000F = 0010 = 0012 = 0014 = 0015 = 0016 = 0017 = 0018 = 0019 = 001A = 0080 = 0001 = 0080 = 0080 = 0010 = 0010 = 0094 = 0030 = 0004 = 0005 = 0014 = 0025 = 0001 = 0002 = 0001 = 0002 = 0010 = 0020 = 0000 = 0000 = 0000 = 0000 = 0000 ``` | IBM Personal Computer MA<br>TEST1 04/21/86 POWE | CRO Assembler Ver | _sion 2.00 | 1-8 | |-------------------------------------------------|---------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16311 04/21/86 PUWE | R UN SELF IES! (FU: | T) - COMMON EQUATES | U4-21-06 | | | 103124011110 | COMMON EGONIES | | | 615 | C PAGE | | ; END OF INTERRUPT COMMAND TO 8259 ; 8259 PORT ; 8259 PORT ; 2ND 8259 ; START OF 8259 INTERRUPT TABLE LOCATION ; VIDEO VECTOR DMA STATUS REGISTER PORT ADDRESS ; DMA CH.0 ADDRESS REGISTER PORT ADDRESS ; 2ND DMA STATUS PORT ADDRESS ; 2ND DMA STATUS PORT ADDRESS ; 2ND DMA STATUS PORT ADDRESS ; 2ND DMA CH.0 ADDRESS REGISTER ADDRESS ; 8254 TIMER - BASE ADDRESS ; 8254 TIMER - BASE ADDRESS ; MANUFACTURING AND POST CHECKPOINT PORT ; DMA CHANNEL 0 PAGE REGISTER ADDRESS | | 616 | C 1 1N | NTERRUPT EQUATES | | | 617 = 0020 | C EOI | EQU 020H | END OF INTERRUPT COMMAND TO 8259 | | 618 = 0020 | C INTAOO | EQU 020H | ; 8259 PORT | | 619 = 0021 | C INTAO1 | EQU 021H | ; 8259 PORT | | 620 = 00A0 | C INTBOO | EQU 0A0H | ; 2ND 8259 | | 621 = 00A1 | C INTBOI | EQU OA1H | i e | | 622 = 0070 | C INT_TYPE | EQU 070H | ; START OF 8259 INTERRUPT TABLE LOCATION | | 623 = 0010 | C INT_VIDEO | EQU 010H | ; VIDEO VECTOR | | 624 | C 1 | | | | 625 = 0008 | C DMADS | EQU 008H | DMA STATUS REGISTER PORT ADDRESS | | 427 - 0000 | C DWA | EQU 000H | ; DMA CH.U ADDRESS REGISTER FORT ADDRESS | | 428 - 0000 | C DMAI | EOU OCON | . SND DMA CH A ADDRESS DECISTED ADDRESS | | 629 | C | | I DMA STATUS REGISTER PORT ADDRESS I DMA CH-0 ADDRESS REGISTER PORT ADDRESS I SND DMA STATUS PORT ADDRESS I 2ND DMA STATUS PORT ADDRESS I 2ND DMA CH-0 ADDRESS REGISTER ADDRESS 0254 TIMER - BASE ADDRESS MANUFACTURING AND POST CHECKPOINT PORT | | 630 - 0040 | Č TIMER | FOU 040H | . 8254 TIMER - BASE ADDRESS | | 631 | c · · · · · · · · | 240 | , DEST TIMEN DAGE ROBRESS | | 632 | Č : MAN | UFACTURING PORT | | | 633 = 0080 | C MFG PORT | EQU 80H | : MANUFACTURING AND POST CHECKPOINT PORT | | 634 | c | | DMA CHANNEL O PAGE REGISTER ADDRESS | | 635 | С | | , | | 636 | C : MAN | UFACTURING BIT DEFIN | ITION FOR OMFG ERR FLAG+1 | | 637 = 0001 | C MEM FAIL | EQU 00000001B | STORAGE TEST FAILED (ERROR 20X) | | 638 = 0002 | C PRO_FAIL | EQU 00000010B | : VIRTUAL MODE TEST FAILED (ERROR 104) | | 639 = 0004 | C LMCS_FAIL | EQU 00000100B | LOW MEG CHIP SELECT FAILED (ERROR 109) | | 640 = 0008 | C KYCLK_FAIL | EQU 00001000B | ; KEYBOARD CLOCK TEST FAILED (ERROR 304) | | 641 = 0010 | C KY_SYS_FAIL | EQU 00010000B | ; KEYBOARD OR SYSTEM FAILED (ERROR 303) | | 642 = 0020 | C KYBD_FAIL | EQU 00100000B | ; KEYBOARD FAILED (ERROR 301) | | 643 = 0040 | C DSK_FAIL | EQU 01000000B | DISKETTE TEST FAILED (ERROR 601) | | 644 = 0080 | C KEY_FAIL | EQU 10000000B | ; KETBOARD LOCKED (ERROR 302) | | 645 | <u> </u> | | | | 040 | 0 011 0105 | FOU 08111 | . CTART OF DWA DAGE OFGICEROS | | 448 - 0085 | C LAST DWA BACE | EQU USIN | : START OF DMA PAGE REGISTERS | | 440 | E EV31_DMV_LVGE | EWO OBTH | , ENDI DMN FAME REGISTER | | 650 | č + | | : START OF DMA PAGE REGISTERS : LAST DMA PAGE REGISTER : MATH COPROCESSOR CONTROL PORT : POST STACK SEGMENT : POST STACK POINTER | | 651 = 00F0 | Č Ý287 | FQU OFOH | : MATH COPROCESSOR CONTROL PORT | | 652 | č ^==· | | | | 653 | C 1 | | | | 654 = 0000 | C POST SS | EQU 00000H | POST STACK SEGMENT | | 655 = 8000 | C POST_SP | EQU 08000H | POST STACK POINTER | | 656 | ç - | | | | 667 | C 1 | | | | 658 = 000D | C CR | EQU 000DH | CARRIAGE RETURN CHARACTER | | 659 = 000A<br>660 = 000B | C LF | EQU 000AH | ; LINE FEED CHARACTER | | 661 = 0001 | C RVRI | EQU 00001000B | VIDEO VERTICAL RETRACE BIT | | 662 = 0100 | C H | EQU 0000001B | HIGH BYTE FACTOR (V 100H) | | 663 = 0101 | čŸ | FOII H+1 | HIGH AND LOW BYTE FACTOR (Y 101H) | | 664 | - ^ | | , AND EST DIVE I ACION (A 1011) | | 665 | LIST | | | | | | | ! POST STACK SEGMENT ! POST STACK POINTER ! CARRIAGE RETURN CHARACTER ! LINE FEED CHARACTER BIT ! VIDEO HORIZONTAL RETRACE BIT ! VIDEO HORIZONTAL RETRACE BIT ! HIGH BYTE FACTOR (X 100H) ! HIGH AND LOW BYTE FACTOR (X 101H) | ``` IBM Personal Computer MACRO Assambler Version 2.00 I-9 TESTI ---- 04/21/86 POWER ON SELF TEST (POST) 04-21-86 $350ATA.INC - DESCRIPTOR EQUATES PAGE INCLUDE SYSDATA.INC PROTECTED MODE EQUATES FOR POST TESTS AND BIOS ROUTINES 1 ;---- LENGTH EQUATES FOR PROTECTED MODE TESTS SDA_LEN SYSTIDT LEN GDT-LEN DESG_LEN MCRT_SIZE CCRT_SIZE ECCRT_SIZE MAX_SEG_LEN NULL_SEG_LEN | 256 SYSTEM DATA AREA LENGTH | 256 SYSTEM | DIT ENTRIES, 8 BYTES EACH | TYPE GOT_DEF | GOT_STRUCTURE LENGTH | 1 LENGTH OF A DESCRIPTOR | 4*1024 | MONDORNOME GTT SIZE | CONTROL EQU EQU EQU EQU EQU EQU ;---- LOCATION EQUATES FOR PROTECTED MODE TESTS SYS_IDT_LOC SDA_LOC GDT_LOC MCRTe_LO MCRTe_LO MCRTe_LO CCRTe_LO ECCRTe_LO_LO ECCRTe_LO-HI ECCRTe_HI_LO ECCRT_ECTRTE_HI_LO ECCRT_ECTRTE_HI_LO ECCRT_ECTRTE_HI_LO ECCRT_ECTRTE_HI_LO ECCRT_ECTRT_ECTRTE_HI_LO ECCRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_ECTRT_E ;---- DEFINITIONS FOR ACCESS RIGHTS BYTES ; PRESENT ; DPL = 3 : CODE/DATA SEGMENT : NOT EXECUTABLE : GROW-UP (IOFFSET <= LIMIT) : WRITIABLE : ACCESSED : DL = 0 : DPL = 0 : DPL = 0 : DPL = 0 : DPL = 0 CPL3_DATA_ACCESS EQU 11110011B CPL0_DATA_ACCESS CPL0_CODE_ACCESS LDT_DESC FREE_TSS INT_GATE TRAP_GATE EQU EQU EQU EQU EQU . 000000000000001B ; PROTECTED MODE ENABLE VIRTUAL_ENABLE ;---- THE GLOBAL DESCRIPTOR TABLE DEFINITION FOR POWER ON SELF TESTS COT_DEF GOT_DEF GOT_DEF SYS_IDT_PTR SYS_IDT_PTR C BUCRT_PTR C CCCRT_PTR E CCRT_PTR E CCRT_PTR E CCRT_PTR SYS_ROM_CS E CCRT_PTR SYS_ROM_CS E CCRT_PTR SYS_TEMP DOST_LDTR POST_LDTR GOT_LDTPTR GOT_DEF GOT_SE CS - POST IDT, ROM RESIDENT DYNAMIC POINTER FOR ES DYNAMIC POINTER FOR CS DYNAMIC POINTER FOR SS DYNAMIC POINTER FOR DS TR VALUE FOR THIS MACHINE'S TSS ; LDTR VALUE FOR THIS MACHINE'S LDT - segment descriptor table entry structure DATA_DESC STRUC SEG_CIMIT BASE_LO_WORD DW BASE_HI_BYTE DB DATA_ACG_RIGHTS DB DATA_DESC DW DATA_DESC ENDS ; SEGMENT LIMIT (1 - 66636 BYTES); ; 24 BIT SEGMENT PHYSICAL DODRESS (0 - (16M-1)); ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE 0000 FOR THE 80286 ;---- GATE DESCRIPTOR TABLE ENTRY STRUCTURE GATE DESC. STRUC ENTRY POINT DW 7 CS SELECTOR DW 7 WORD COUNT DB 7 GATE ACC RIGHTS DB 7 GATE ACC RIGHTS DW 7 GATE ACS ENDS DESTINATION ROUTINE ENTRY POINT SELECTOR FOR DESTINATION SEGMENT MAMBER OF WORDS TO COPY FROM STACK ACCESS RIGHTS BYTE RESERVED - MUST BE 0000 FOR THE 80286 ``` ·LIST ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST! ---- 04/21/86 POWER ON SELF TEST (POST) 1-10 716667012346667012346667012346670123466701234667012346670123466670123466701234667012346670123466701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012 PAGE SEGMENT WORD PUBLIC PUBLIC C8042 PUBLIC OBF 42 PUBLIC POSTI PUBLIC START_1 START_I CMOS_READINEAR COMSTETITEINEAR COMFTO BADINEAR DIIINEAR DDSINEAR DDSINEAR DDSINEAR DDSINEAR DDSINEAR MITORININEAR REPINEAR MITORININEAR PRINT SCREENINEAR PRINT SCREENINEAR ROM CHECKINEAR SHUTZINEAR SILIVE VECTOR TABLEINEAR SYSINITINEAR VIDEO_PARMSIBTTE EXTRN ASSUME CS:CODE,DS:NOTHING,ES:NOTHING,SS:NOTHING 0000 POSTI PROC NEAR = 0000 0000 37 38 58 37 34 36 32 43 47 50 52 28 20 49 42 40 20 43 4F 52 50 2E 20 31 39 38 31 2C 31 39 38 36 20 20 BEGIN $ '78X7462COPR. IBM CORP. 1981,1986 ' COPYRIGHT NOTICE | EVEN BOUNDARY | 18 M | 1986 | EVEN BOUNDARY | 18 X 7 4 6 2 C O P R . I B M | 1986 | GDD MODULE | 1788XX77446623 | CCOOPPRR. | I I BBMM | 198866 | COPPRIGHT NOTICE 0022 37 37 38 38 58 58 58 37 37 34 34 36 36 32 33 20 20 43 43 45 4F 4F 50 50 52 52 2E 2E 20 20 49 49 42 42 40 40 20 20 31 31 31 39 39 38 38 30 304E 20 20 ;PAD INITIAL RELIABILITY TESTS -- (POST1) : TEST.01 80286 PROCESSOR TEST (REAL MODE) DESCRIPTION CERTIFY FLAGS, REGISTERS AND CONDITIONAL JUMPS. ASSUME DS:DATA 0050 FA 0050 FA 0050 FA 0051 BB 058D 0056 PE 0057 73 27 0058 FB 23 0050 FB 22 0050 FB 22 0050 FB 22 0050 FB 10 055 F I DISABLE INTERRUPTS I FLAG MASK IN (AH) AND NMI MASK IN (AL) IDISABLE NMI INTERRUPTS, LATCH STANDBY ISET "SF" "ZF" "AF" "PF" "CF" FLAGS ON I GO TO ERROR ROUTINE IF "ZF" NOT SET I GO TO ERROR ROUTINE IF "FF" NOT SET I GO TO ERROR ROUTINE IF "FF" NOT SET I GO TO ERROR ROUTINE IF "FF" NOT SET I CAD COUNT REGISTER WITH SHIFT COUNT SHIFT "AF" INTO CARRY BIT POSITION I GO TO ERROR ROUTINE IF "AF" NOT SET I SET THE "OF" FLAG ON I SETUP FOR TESTING I SET OF "FLAG ON START_I I CL I MOY GUNT SAHF UNS JNP JNS LAMF MOVE SAMF JNC J ERRO2 ERRO2 ERRO2 ERRO2 CL,5 AH,CL ERRO2 AL,40H AL,1 ERRO2 AH,AH ERROZ 006F 76 0F 0071 78 0D 0073 74 0B 0075 9F 0076 D2 EC 0078 72 06 007A D0 E4 007C 70 02 007E 74 03 0080 0080 F4 0081 EB FD ERRO2 ERRO2 AH,CL ERRO2 AH,1 ERRO2 C7A ERR02: ERROR HALT ERRO2 0083 0083 88 ---- R 0086 8E D8 AX,DATA DS,AX ; SET DATA SEGMENT ; INTO THE (DS) SEGMENT REGISTER CHECK FOR PROCESSOR SHUTDOWN 0088 E4 64 008A A8 04 008C 75 03 008E E9 0123 R AL,STATUS_PORT AL,SYS_FLAG C78 SHUT0 ; READ CURRENT KEYBOARD PROCESSOR STATUS ; CHECK FOR SHUTDOWN IN PROCESS FLAG ; GO IF YES ; ELSE CONTINUE NORMAL POWER ON CODE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTI ---- 04/21/86 POWER ON SELF TEST (POST) 1-11 PAGE 1----- C7B: 0091 0091 B0 8F 0093 E6 70 0095 EB 00 0097 E4 71 0099 3C 09 009B 86 C4 009D 74 41 MOV OUT JMP IN CMP XCHG JE AL, CMOS SHUT DOWN+NMI CMOS PORT, AL $+2 AL, CMOS DATA AL, O9H AL, AH C7C : CMOS ADDRESS FOR SHUTDOWN BYTE ; I/O DELAY ; GET REQUEST NUMBER ; WAS IT SHUTDOWN REQUEST 97 ; SAVE THE SHUTDOWN REQUEST ; BYPASS INITIALIZING INTERRUPT CHIPS :---- CHECK FOR SHUTDOWN DA 009F 80 FC 0A 00A2 74 3C CMP JE AH, OAH C7C WAS IT SHUTDOWN REQUEST A? BYPASS INITIALIZING INTERRUPT CHIPS 00A4 2A C0 00A6 E6 F1 SUB AL,AL X287+1,AL INSURE MATH PROCESSOR RESET RE-INITIALIZE THE 8259 INTERRUPT #1 CONTROLLER CHIP : 14E IME 060 AL,11H INTAOO,AL $+2 AL,08H INTAO1,AL $+2 AL,04H INTAO1,AL $+2 AL,01H INTAO1,AL $+2 AL,0FFH INTAO1,AL 00A8 B0 11 00AA E6 20 00AC EB 00 00AE B0 08 00B0 E6 21 00B2 E 00 00B4 B0 04 00B6 E6 21 00B8 EB 00 00BA B0 01 00BC EB 00 ; ICW1 - EDGE, MASTER, ICW4 # WAIT STATE FOR I/O # SETUP ICW2 - INTERRUPT TYPE 8H (8-F) ; WAIT STATE FOR I/O ; SETUP ICW3 - MASTER LEVEL 2 ; I/D WAIT STATE ; SETUP ICW4 - MASTER,8086 MODE # WAIT STATE FOR I/O # MASK ALL INTERRUPTS OFF # (VIDEO ROUTINE ENABLES INTERRUPTS) # CONTROLLER CHIP : RE-INITIAL IZE THE 8259 INTERRUPT 00C4 B0 11 00C6 E6 A0 00C8 E9 07 00CC E6 A1 00CE E6 A1 00CE E6 A1 00CE E6 A1 00D4 EB 00 00D4 EB 00 00D4 EB 00 00DA EB 00 00DA EB 00 00DC E6 A1 YOM YOM YOU YOU YOU YOU YOU YOU YOU ; WAIT STATE FOR I/O ; SETUP ICW2 - INTERRUPT TYPE 70 (70-7F) ; SETUP ICW3 - SLAVE LEVEL 2 ; I/O DELAY ; SETUP ICW4 - 8086 MODE, SLAVE SHUTDOWN RESTART RETURN CONTROL AFTER A SHUTDOWN COMMAND IS ISSUED DESCRIPTION A TEST IS MADE FOR THE SYSTEM FLAG BEING SET. IF THE SYSTEM FLAG IS SET, THE SHUTDOWN BYTE IN CMOS IS USED TO DETERMINE WHERE CONTROL IS RETURNED. SOFT RESET OR UNEXPECTED SHUTDOWN SHUT DOWN AFTER MEMORY SIZE SHUT DOWN AFTER MEMORY TEST SHUT DOWN WITH MEMORY TEST SHUT DOWN WITH BOOT LOADER REQUEST JMP DWORD REQUEST - (INTERRUPT CHIPS & 287 ARE INITIALIZED) PROTECTED MODE TESTS PASSED PROTECTED MODE TESTS FAILED BLOCK MOVE SHUTDOWN REQUEST JMP DWORD REQUEST - (W/O INTERRUPT CHIPS INITIALIZED) CMOS = 0 CMOS = 1 CMOS = 2 CMOS = 3 CMOS = 4 CMOS = 5 CMOS = 6 CMOS = 7 CMOS = 8 CMOS = 9 CMOS = A RETURNS ARE MADE WITH INTERRUPTS AND NMI DISABLED. USER MUST RESTORE SSISP (POST DEFAULT SET = 000010400) ENABLE NON-MASKABLE INTERRUPTS (NMI) WITH AN OUT TO PORT 70H WITH HIGH ORDER BIT OFF, AND THEM ISSUE A STI TO ENABLE INTERRUPTS. FOR SHUTDOWN (6) THE USER MUST ALSO RESTORE THE INTERRUPT MASK REGISTERS. NOTES: :---- CHECK FROM WHERE 00E0 80 8F 00E2 E6 70 00E4 90 00E5 2A C0 00E7 E6 71 00E9 86 E0 00EB 8C 0A 00ED 77 34 00E7 8E 0103 R 00F4 03 F0 00F4 03 F0 00F6 2E1 8B IC ; CLEAR CMOS BYTE MOV OUT NOP SUB OUT XCHG CMP JA MOV ADD ADD MOV AL, CMOS_SHUT_DOWN+NMI CMOS_PORT, AL : I/O DELAY : SET BYTE TO 0 AL, AL CMOS DATA, AL AH, AL AL, OAH SHUTO SI, OFFSET BRANCH SI, AX SI, AX BX, CS1[SI] COMPARE WITH MAXIMUM TABLE ENTRIES SKIP TO POST IF GREATER THAN MAXIMUM POINT TO THE START OF THE BRANCH TABLE ; POINT TO BRANCH ADDRESS ; MOVE BRANCH TO ADDRESS TO BX REGISTER :---- SET TEMPORARY STACK FOR POST MOV MOV MOV JMP AX,ABS0 SS,AX SP,OFFSET OTOS BX ; SET STACK SEGMENT TO ABSO SEGMENT 00F9 B8 ---- R 00FC BE D0 00FE BC 0400 R 0101 FF E3 ; SET STACK POINTER TO END OF VECTORS ; JUMP BACK TO RETURN ROUTINE J JUMP BACK TO RETURN ROUTINE J SHAT DOWN AFTER MEMORY SIZE SHAT DOWN AFTER MEMORY SIZE SHAT DOWN AFTER MEMORY TEST SHAT DOWN WITH BOOT LOADER REQUEST J MP DWONN WITH BOOT LOADER REQUEST J MP DWOND REQUEST WITH INTERRUPT INIT PROTECTED MODE TEST? PASSED PROTECTED MODE TEST? PASSED BLOCK MOVE SHATDOWN REQUEST J MP DWOND REQUEST (W/O INTERRUPT INIT) JMP DWOND REQUEST (W/O INTERRUPT INIT) 0103 0123 R 0105 0992 R 0107 0000 E 0109 0000 E 010B 0000 E 010F 0000 E 0111 0000 E 0113 0795 R 0115 0000 E SHUTO SHUT1 SHUT2 SHUT3 SHUT4 SHUT6 SHUT6 SHUT7 SHUT8 SHUT9 SHUTA ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-12 PAGE 1---- 010_ROM_INIT MUST BE INITIALIZED BY THE USER FOR VECTORED REQUESTS SHUT5: ; FLUSH THE KEYBOARD BUFFER ; FLUSH LAST TIMER REQUEST IF PENDING ; - TO ALLOW TIMER INTERRUPTS AL, PORT_A AL, EDI INTAGO, AL SHUTA: DWORD PTR #10_ROM_INIT ; FAR JUMP TO USER DEFINED LOCATION ; AFTER SHUTDOWN TO REAL MODE CODE ; WITH INTERRUPTS AND MUI DISABLED JMP :---- CHECKPOINT 01 SHUT0: MOV AL,01H MFG_PORT,AL ; READ/WRITE/TEST THE 80286 REGISTERS WITH ONE'S AND ZERO'S ; SETUP ONE'S PATTERN IN (AX) ; SET CARRY FLAG ; GO IF NO CARRY AX, OFFFFH ERR01 C8: # WRITE PATTERN TO ALL REGISTERS MOY MOY MOY MOY MOY MOY JOR JOR JOR JOR JOR JOR JOR JOR JMP DS.AX BX.AS ES.BX CX.ES SS.CX SP.SP SI.BP DI.SI C9.DI.SI C9.DI.SI ; PATTERN MAKE IT THROUGH ALL REGISTERS ; NO - GO TO ERROR ROUTINE ; CLEAR CARRY FLAG CB 1 TSTIA 1 ZERO PATTERN MAKE IT THROUGH ? 1 YES - GO TO NEXT TEST C9: OR JZ HLT 1 HALT SYSTEM INSURE THAT CMOS CLOCK INTERRUPTS ARE DISABLED CIOA: ADDRESS CMOS ALARM BYTE WITH NMI=OFF MOY OUT NOP IN MOY OUT NOP IN AXD XCHG OUT XCHG AL, (CMOS_REG_B+NMI) CMOS_PORT, AL I 1/0 DELAY READ DATA TO OPEN STANDBY LATCH ADDRESS TO BOTH (AH) AND (AL) ADDRESS CWOS ALARM BYTE WITH NMI-OFF 1/0 DELAY GET THE CURRENT CONTROL REGISTER CLEAR SET, PIE, AIE, AND SQWE BITS SAVE IT AL,CMOS_DATA AX,X*(CMOS_REG_B+NMI) CMOS_PORT,AL AL,CMOS_DATA AL,0000001118 AL,AH CMOS_PORT,AL AL,AH CMOS_DATA,AL MOV NOP OUT NOP IN AL,CMOS_REG_C+NMI ; ADDRESS CMOS FLAGS BYTE WITH NM1=OFF ; I/O DELAY CMOS_PORT,AL ; I/O DELAY ; READ STATUS TO CLEAR PENDING INTERRUPT AL,CMOS_DATA RESET MOV OUT 1NOV OUT NOV 1N MOV MOV MOV MOV MOV OUT CLEAR DATA BYTE TO DISABLE VIDEO GET COLOR MODE CONTROL PORT ADDRESS DISABLE COLOR VIDEO MONOCHROME MODE RESET MASK GET ADDRESS OF MONOCHROME MODE CONTROL GET ADDRESS OF MONOCHROME STATUS REGISTER ADDRESS OF MONOCHROME STATUS REGISTER READ STATUS TO DISABLE EGA VIDEO ADDRESS OF COLOR MODE STATUS REGISTER READ STATUS TO DISABLE EGA VIDEO ADDRESS OF COLOR MODE STATUS REGISTER READ STATUS TO DISABLE EGA VIDEO SELECT ATTRIBUTE PALETTE REGISTER OF STATUS OF THE PALETTE REGISTER OF DISABLE PARITY CHECKERS TEST.02 DESCRIPTION DESCRIPTION READ ONLY MEMORY MODULES (TWO) CONTAINING POST, BASIC AND BIOS. 1---- CHECKPOINT 02 AL,02H MFG_PORT,AL MOV OUT ◆◆ CHECKPOINT 02 ◆◆ ASSUME SS.CODE MOV AX, CS MOV SS.AX MOV DS, AX XOR SI, SI XOR BX, BX MOV CH, 080H ; SETUP SS SEGMENT REGISTER ; SET UP DATA SEGMENT TO POINT TO ; ROM ADDRESS START ; CLEAR CHECK REGISTER ; COUNT FOR 32K WORDS I MOVE TWO BYTES INTO AX -- SI=SI+2 ADD DOD BYTE AT DS:SI+1 TO CHECKSUM ADD EVEN BYTE AT DS:SI+1 TO CHECKSUM LOOP COUNT FOR 66K BYTES (3EK WORD) I KNIT IF 'LOOP RESET THE CARRY FLAG (NOTE: MODEL BYTE MUST NOT = ZERO) CONTINUE IF CHECKSUM VALID (ZERO) LODSW ADD ADD LOOP JNC BL,AH BL,AL C11 C11E JZ CIIA CIIEs ; ELSE HALT IF CHECKSUM PROBLEM ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-13 TEST.03 VERIFY CMOS SMUTDOWN BYTE DESCRIPTION ROLLING BIT WRITTEN AND VERIFIED AT SMUTDOWN ADDRESS. 1---- VERIFY AND CLEAR SHUTDOWN FLAG CIIAE AL,03H MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 03 ◆◆ CX,09H AH,1 ; LOOP COUNT ; START WITH BIT 0 AL,CMOS_SHUT_DOWN+NMI CMOS_PORT,AL AL,AH CMOS_DATA,AL AL,CMOS_SHUT_DOWN+NMI MOY OUT MOY OUT MOY NOP OUT NOP IN CMP JNZ RCL LOOP ; OUTPUT ROLLING BIT READ CMOS CMOS_PORT,AL ; I/O DELAY AL,CMOS_DATA AL,AH ERRO1 AH,1 C11B : MUST BE THE SAME : ERROR IF NOT : ROLL A BIT THROUGH SHUTDOWN BYTE : LOOP TILL DONE TEST.04 8264 CHECK TIMER I DESCRIPTION CHECK THAT TIMER I ALL BITS ON ASSUME DS:DATA MOV AX.DATA MOV DS,AX MOV AL,04H OUT MFG_PORT,AL : SET DATA SEGMENT --- DISABLE DMA CONTROLLER OUT DMA08.AL OUT DMA18,AL VERIFY THAT TIMER I FUNCTIONS OK DX, PRESET_FLAG AL, 54H TIMER+3, AL $+2 AL, 18 TIMER+1, AL BH, 05H MOV OUT JMP MOV OUT MOV ; SAVE RESET FLAG WHILE REFRESH IS OFF ; SELECT TIMER 1,LSB,MODE 2 : I/O DELAY : SET INITIAL TIMER COUNT TO 18 ; LOOP COUNT ; TIMER! BITS_ON ; LATCH TIMER! COUNT ; I/O DELAY BH,05H AL,40H $+2 TIMER+3,AL BL,01FH C13 AL,TIMER+1 BL,AL C12 BH C12 ; YES - SEE IF ALL BITS GO ON ; TIMER: BITS OFF ; READ TIMER T COUNT ; ALL BITS ON IN TIMER ; TIMER!_BITS_ON : TRY AGAIN ; TIMER 1 FAILURE, HALT SYSTEM ; TIMERI_BITS_OFF TEST.05 9254 CHECK TIMER 1 ALL BIT OFF DESCRIPTION CHECK THAT TIMER 1 ALL BITS OFF :---- CHECKPOINT 05 AL,05H MFG_PORT,AL MOV MOV SUB OUT MOV AL,BL CX,CX TIMER+1,AL BH,05H ; SET TIMER I COUNT : SET TRY AGAIN COUNT : TIMER_LOOP : LATCH TIMER ! COUNT ! DELAY FOR TIMER ! ADDED DELAY FOR TIMER ! READ TIMER ! COUNT AL,40H TIMER+3,AL $+2 $+2 AL,TIMER+1 BL,AL C16 C14 BH C14 MOV JMP JMP IN AND JZ LOOP DEC JNZ HLT ; GO TO WRAP DMA REGISTER TESTS : TIMER_LOOP TEST. 06 8237 DMA 0 INITIALIZATION CHANNEL REGISTER TEST DESCRIPTION DISABLE THE 8237 DMA CONTROLLER: WRITE/READ THE CURRENT ADDRESS: AND WORD COUNT REGISTERS FOR ALL CHANNELS: ``` 5-30 TEST1 ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 --- 04/21/86 POWER ON SELF TEST (POST) 1-14 04-21-86 ;---- CHECKPOINT 06 AX,DATA DS,AX AL,06H MFG PORT,AL GRESET_FLAG,DX DMA+ODH,AL MOV MOV OUT MOV OUT ; SET DATA SEGMENT ;---- WRAP DMA O CHANNEL ADDRESS AND COUNT REGISTERS AL, OFFH BL., AL BH., AL CX., 8 DX., DMA DY., AL $-2 DX., AL AL, 01 H $-2 AL, DX AL, DX AL, DX CX, AL A ; WRITE PATTERN "FF" TO ALL REGISTERS ; SAVE PATTERN FOR COMPARE C16: SAVE PATTERN FOR COMPARE SETUP LOOP COUNT SETUP 1/0 PORT ADDRESS OF REGISTER WRITE PATTERN TO REGISTER, LSB 1/0 DELY AND THE PATTERN BEFORE READ 1/0 DELAY READ 16-BIT DMA CH REG, LSB 2ST DMA 1/0 DELAY SAVE LSB OF DMA CHANNEL REGISTER PATTERN READ AS WRITTERY YES - CHECK MEXT REGISTER 1 PATTERN REGISTER 1 PATTERN TO DEXT CHANNEL REGISTER 1 SET 1/0 PORT TO NEXT CHANNEL REGISTER 1 SET 1/0 PORT TO NEXT CHANNEL REGISTER 1 WRIT DMA. CH 1 SET 1/0 PORT TO NEXT CHANNEL REGISTER 1 WRIT DMA. CH 1 WRITE PATTERN TO 0 1 YES CONTINUE C18: INC LOOP INC JZ CMP BL,055H JZ C19 CMP BL,0AAH JZ C20 MOY AL,055H JMP C16 ; CHECK IF "55" PATTERN DONE ; GO IF YES ; CHECK IF "AA" PATTERN DONE ; GO IF YES :---- WRITE DMA WITH AA PATTERN C19: MOY AL, OAAH TEST.OT 8237 DMA I INITIALIZATION CHANWEL REGISTER TEST DESCRIPTION 1 DESCRIPTION 1 WRITE/READ THE CURRENT DMA I WRITE/READ THE CURRENT DMA I REGISTERS FOR ALL CHANNELS. ----- C20: MOV AL,07H OUT MFG PORT,AL OUT DMAT+0DH*2,AL 1---- WRAP DMA 1 CHANNEL ADDRESS AND COUNT REGISTERS AL OFFH BH.AL CX.8 DX.DMA1 DX.AL S+2 DX.OH S+2 AL.OH S+2 AL.DX S+2 AH.DX BX.AX C18A CISAI WRAP DM. WOY HOY HOY HOY HOY OUT JMP OUT JMP HOY IN CMP HOY LT CISAI SATUP PATTERN FOR COMPARE SETUP LOOP COUNT SETUP 1/0 PORT ADDRESS OF REGISTER WITE PATTERN TO REGISTER, LSB 1/0 CELAY BIT REGISTER MSS TO ANOTHER PAT BEFORE RD 1/0 DELAY BIT REGISTER 1/0 DELAY READ 16-BIT DMA CH REG, LSB 2ST DMA 1/0 DELAY 1/4 DE DX,2 C17A AL C16A :---- WRITE DMA WITH 55 PATTERN CMP BL.55H JZ C20A CMP BL.0AAM JZ C21 MOY AL.55H JMP C16A ; CHECK IF 55 PATTERN DONE ; GO IF YES ; CHECK IF AA PATTERN DONE ; GO IF YES ;---- WRITE DMA WITH AA PATTERN C20A: MOV AL, DAAH JMP C16A ;---- INITIALIZE AND START MEMORY REFRESH C21: MOV BX, PRESET FLAG MOV PEQUIP_FLAG, AX MOV AL, 18 OUT TIMER+1, AL ; GET THE RESET FLAG ; DO A DUMMY MEMORY WRITE BEFORE REFRESH ; START REFRESH TIMER :---- SET DMA COMMAND ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTI --- 04/21/86 POWER ON SELF TEST (POST) 1~15 04-21-86 1335 02AF E6 08 1336 02AF E6 08 1336 02BF E6 08 1337 02BF E6 08 1338 02BF E6 08 1339 1340 02BF E6 08 1341 02BB E6 08 1342 02BB E6 08 1343 02BF E6 08 1344 02BF E6 08 1345 02CF E6 08 1346 02BF E6 08 1347 02BF E6 08 1348 02CF E6 08 1349 02CF E6 08 1350 02CF E6 08 1351 02CF E6 08 1352 02CF E6 08 1354 02CF E6 08 1355 02CF E6 08 1356 02CF E6 08 1357 02DF E6 08 1358 02CF 1359 I DACK SENSE LOW, DREQ SENSE HIGH LATE WRITE, FIXED PRIGRITY, NORMAL TIMING, CONTROLLER ENABLE, CHO ADDRESS HOLD DISABLE, MEMORY TO MEMORY DISABLE SAME TO SECOND CONTROLLER OUT DMA18,AL MODE SET ALL DMA CHANNELS AL, 40H AL, 40H AL, 0COH DMA108-06H, AL 3-2 41H DMA10-06H, AL DMA108-06H, AL DMA-08H, AL DMA-08H, AL DMA108-06H, AL S-2 AL, 42H DMA108-06H, AL DMA18-06H, AL DMA18-06H, AL DMA18-06H, AL DMA18-06H, AL DMA18-06H, AL YOM TUO YOM TUO TUO YOM YOM YOM YOM TUO TUO TUO * SET MODE FOR CHANNEL O ; SET CASCADE MODE ON CHANNEL 4 ; I/O DELAY ; SET MODE FOR CHANNEL 1 SET MODE FOR CHANNEL 5 1/0 DELAY SET MODE FOR CHANNEL 2 3 SET MODE FOR CHANNEL 6 2 1/0 DELAY 3 SET MODE FOR CHANNEL 3 : SET MODE FOR CHANNEL 7 RESTORE RESET FLAG MOV ●RESET_FLAG, BX TEST.08 DMA PAGE REGISTER TEST DESCRIPTION WRITE/READ ALL PAGE REGISTERS AL,08H AL MOVT BY MOVT CMP X GC CONNECT ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 08 ◆◆ CZZA: ; TEST DMA PAGES 81 THROUGH 8EH SAVE CURRENT DATA PATTERN CHECK LAST WRITTEN CHANGE DATA BEFORE READ DATA AS WRITTEN? ; CONTINUE TILL PORT 80 I NEXT PATTERN TO RIPPLE TEST LAST DMA PAGE REGISTER (USED FOR ADDRESS LINES DURING REFRESH) MOV MOV MOV OUT AL,0CCH DX,LAST_DMA_PAGE AH,AL DX,AL ; WRITE AN CC TO PAGE REGISTERS C22: SAVE THE DATA PATTERN VERIFY PAGE REGISTER SF AL,AL AL,DX AL,AH C26 AH,OCCH C25 AL,033H C22 SUB IN CMP JNZ CMP JNZ MOV JMP ; CHANGE DATA PATTERN BEFORE READ ; GET THE DATA FROM PAGE REGISTER ; GO IF ERROR GO IF ERROR SET UP DATA PATTERN OF 33 DO DATA 33 CMP JZ SUB JMP AH,0 C27 AL,AL C22 ; CHECK DONE ; GO IF YES ; SET UP FOR DATA PATTERN 00 ; DO DATA 0 1---- ERROR HALT HLT # HALT SYSTEM TEST.09 STORAGE REFRESH TEST DESCRIPTION VERIFY REFRESH IS OCCURRING C27: AL,09H MFG_PORT.AL CX.CX ◆◆◆◆◆◆◆◆ AL.PORT_B AL,REFRESH_BIT C28 C26 I INSURE REFRESH BIT IS TOGGLING C29 t ; INSURE REFRESH IS ON ``` ; ERROR HALT IF NO REFRESH BIT ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 --- 04/21/86 POWER ON SELF TEST (POST) 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 1446 | 14 TEST.10 8042 INTERFACE TEST DESCRIPTION JUMPERS DESCRIPTION TO THE 8042. INSUR A 55H IS RECEIVED. READ MANUFACTURING AND ISPLAY UMPERS AND SAVE IN MFG TEST. :---- CHECKPOINT OA MOY AL,0AH ; OUT MFG_PORT,AL ; ;---- SOFT RESET (HANDLE ALL POSSIBLE CONDITIONS) : GO IF NOT : FLUSH : IS THE OUTPUT BUFFER ALSO FULL? : TRY AGAIN : CONTINUE IF OK ERRO: HLT : HALT SYSTEM IF BUFFER FULL :---- ISSUE A RESET TO THE 8042 TST4: MOV OUT AL,08H MFG_PORT,AL MOV MOV JMP TST4_B: TEST JZ IN TST4_A: MOV JMP TST4_C: IN CMP ; SELF TEST COMMAND ; SET RETURN ADDRESS ; SE! RETON ADDRESS 1 SO IF NOT 1 GO IF NOT 1 FLUSH 1 FLUSH 1 GO WAIT FOR BUFFER 1 GO WAIT FOR BUFFER 1 GET THE ENDING RESPONSE MOY AL,OCH MFG_PORT,AL JNZ 1 GO IF NOT OK :---- GET THE SWITCH SETTINGS MOV MOV JMP E30B: MOV JMP E30C: IN AL,READ 8042 INPUT SP.OFFSET C8542C SHORT C8042 SP.OFFSET OBF_42B SHORT OBF_42 AL,PORT_A DMA_PAGE+1,AL ; READ INPUT COMMAND ; SET RETURN ADDRESS ; ISSUE COMMAND : SET RETURN ADDRESS ; GO WAIT FOR RESPONSE ; GET THE SWITCH ; SAVE TEMPORARY :---- WRITE BYTE 0 OF 8042 MEMORY AL, WRITE 8042 LOC SP, OFFSET C80428 SHORT C8042 TST4_D1 MOV MOV JMP TST4_D: JZ ; WRITE BYTE COMMAND ; SET RETURN ADDRESS ; ISSUE THE COMMAND ; CONTINUE IF COMMAND ACCEPTED MOV OUT HLT AL,ODH MFG_PORT,AL TST4_D1: MOV OUT JMP : ENABLE CUTPUT BUFFER FULL INTERRUPT, ; DISABLE KEYBOARD, SET SYSTEM FLAG, ; PC : COMPATIBILITY, INHIBIT OVERRIDE 1823 0399 E8 10 1824 1626 1827 0390 FA 1828 039E E6 64 1828 039E E6 67 1829 03A0 28 C9 1830 03A2 E4 64 1831 03A4 80 21 1832 03A6 E0 FA 1833 03A8 E3 67 1834 03A9 28 C9 1833 03A8 E3 06 1839 03A0 E4 64 1838 03 C8042: CLI OUT STATUS_PORT, AL SUB CX, CX — C42_11 IN AL, STATUS_PORT TEST LOOPNUZ RET C42_1 | : NO INTERRUPTS ALLOWED : SEND COMMAND IN AL REGISTER : LOOP COUNT : WAIT FOR THE COMMAND ACCEPTED :---- WAIT FOR 8042 RESPONSE : 200MS/PER LOOP * 6 =1200 MS + : CHECK FOR RESPONSE GO IF RESPONSE TRY AGAIN DECREMENT LOOP COUNT RETURN TO CALLER C42_31 RET : TEST.11 DASE 64K READ/WRITE MEMORY TEST B DESCRIPTION AN,55,FF,01, AND 00 TO 1 ST 64K 1 OF STORAGE. VERIFY STORAGE ADDRESSABILITY. : E30A: MOY AL, OEM ; OUT MFG_PORT, AL ; ◆◆◆◆◆◆◆◆◆◆ ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST: --- 04/21/86 POWER ON SELF TEST (POST) 1-17 04-21-86 | 1962 | 03BE | 88 | --- | R | 1963 | 03C | 80 | 16 | 00T2 | R | 1964 | 03C | 80 | 16 | 00T2 | R | 1964 | 03C | 80 | 16 | 00T2 | R | 1964 | 03C | 80 | 16 | 00T2 | R | 1964 | 03C | 28 | F6 | 1560 1570 | 03D8 | E7 E AX,DATA DS,AX BX, GRESET_FLAG GET THE SYSTEM SEGMENT OF DATA SAVE PRESET FLAG IN BX SET DIRECTION FLAG TO INCREMENT SET FOR 32K WORDS FIRST 16K MOV MOV CLD MOV SUB SUB MOV CMP JMP CX.2000H°4 DI.DI SI.SI AX.AX DS.AX ES.AX BX.1234H E30A 0 CLR_STG ; WARM START? ; GO IF NOT ;---- GET THE INPUT BUFFER (SWITCH SETTINGS) E30A_0: MOV OUT AL,OFH MFG_PORT.AL AL PARITY CHECK DMA PAGE+6, AL SP, DFFSET C2 STGTST_CNT BX, AX C31 C33 MOV OUT MOV JMP MOV JNZ JMP SET BASE MEMORY PARITY USE AS TEMPORARY SAVE SET RETURN ADDRESS C30: ; SAVE FAILING BIT PATTERN : STORAGE OK, CONTINUE ;---- TEMPORARY STACK FOR POST ROUTINES C2 DW C8042A DW OBF_42A DW C8042B DW C8042C DW OBF_42B DW C30 TST4_B TST4_C TST4_D E30B E30C OSF_428 DW E3UC BASE 64K STORAGE FAILLINE SHAY THE CHECKPOINT (MFG CHECKPOINT) DISPLAY THE CHECKPOINT IN MFG PORT+3 DISPLAY CHECKPOINT IN MFG PORT+3 I DISPLAY CHECKPOINT IN MFG PORT+3 LOW BYTE IN MFG PORT+2 A READ/WRITE SCOPE LOOP OF THE FIRST WORD FOR POSSIBLE ADDRESS LINE FAILURES MOV OUT MOV OUT AL,BH MFG_PORT+1.AL AL,BL MFG_PORT+2.AL C31: : SAVE HIGH BYTE ; SAVE LOW BYTE ;---- CHECK FOR VIDEO ROM CX,0C00H CX,0C00H CX,CX BX,BX BX,BX BX,BX S+2 CX,0AA55H CX,0C800H MI CX,CX CS2 CS1_0 ; START OF I/O ROM ; POINT TO SEGMENT ; GET THE FIRST 2 LOCATIONS MOV SUB MOV JMP CMP JZ ADD CMP JNZ JNP BUS SETTLE I IS THE VIDEO ROM PRESENT? IGO IF YEAR POINT TO NEXT 2K BLOCK TOP OF VIDEO ROM AREA YET? TOP OF VIDEO ROM AREA YET? TOP OF VIDEO ROM AREA YET? TOP OF VIDEO ROM SERO FLAG IGO IF NOTERO FLAG BYPASS ERROR DISPLAY IF VIDEO ROM Z5: SET VIDEO MODE TO DISPLAY MEMORY ERROR THIS RUTTINE INTIALIZE THACHMENT TO 15 SPAN MONOCHROME ATTACHMENTS ARE INITIALIZED. 1---- INITIALIZE COLOR/MONOCHROME DX,3D8H AL,AL DX,AL : 260 # CONTROL REGISTER ADDRESS OF COLOR CARD # MODE SET ; CONTROL REGISTER ADDRESS OF B/W CARD ; MODE SET FOR CARD ; RESET VIDEO ; BACK TO BASE REGISTER MOV MOV OUT SUB DX,0388H AL,1 DX,AL DX,4 1 OH EQU MOV 8X,0FFSET VIDEO_PARMS+M4*3 1 POINT TO VIDEO PARAMETERS 2_2: MOV 0X,144 1 COUNT OF MONOCHROME VIDEO PARAMETERS :---- BX POINTS TO CORRECT ROW OF INITIALIZATION TABLE XOR AH,AH ; AH IS REGISTER NUMBER DURING LOOP ;---- LOOP THROUGH TABLE, OUTPUTTING REGISTER ADDRESS, THEN VALUE FROM TABLE MOV OUT INC INC OUT INC OUT INC OEC LOOP MOV AND JZ MOV MOV ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-18 3---- FILL REGEN AREA WITH BLANK DI.DI AX.OBOOOH ES,AX ; SET UP POINTER FOR REGEN ; SET UP ES TO VIDEO REGEN CX,2048 AX,' '+7*H STOSW D1,D1 BX,0B800H ES,BX CX,8192 STOSW XOR MOV MOV MOV REP CLEAR COLOR VIDEO BUFFER MEMORY SET UP ES TO COLOR VIDEO MEMORY ; FILL WITH BLANKS :---- ENABLE VIDEO AND CORRECT PORT SETTING MOV MOV OUT ; SET VIDEO ENABLE PORT ;---- SET UP OVERSCAN REGISTER INC DX MOV AL,30H OUT DX,AL ; SET OVERSCAN PORT TO A DEFAULT ; VALUE 30H FOR ALL MODES EXCEPT 640X200 ; OUTPUT THE CORRECT VALUE TO 3D9 PORT ;---- ENABLE COLOR VIDEO AND CORRECT PORT SETTING MOV DX,3D8H MOV AL,28H OUT DX,AL ; SET VIDEO ENABLE PORT ;---- SET UP OVERSCAN REGISTER INC DX MOV AL,30H OUT DX,AL ; SET OVERSCAN PORT TO A DEFAULT ; VALUE 30H FOR ALL MODES EXCEPT 640X200 ; OUTPUT THE CORRECT VALUE TO 3D9 PORT ;---- DISPLAY FAILING CHECKPOINT AND MOV AX,CS ; SET STACK SEGMENT TO CODE SEGMENT MOV BX,08000H DS,BX ; SET DS TO B/W DISPLAY BUFFER AL,'0' CX,6 DI,DI [DI],AL DI 1724 0497 80 30 006 1725 0499 89 90 006 1726 0499 89 0006 1726 0499 89 0006 1726 0490 89 00 1729 0440 40 1730 0441 40 1731 0442 82 FA 1732 0442 87 FB 1735 0449 87 B0 1736 0440 87 B0 1738 0480 1739 0481 80 0583 R MOV MOV SUB MOV INC INC LOOP CMP JZ SUB BH,088H Z i DT,DI ; CHECK THAT COLOR BUFFER WRITTEN ; POINT TO START OF BUFFER MOV MOV MOV JMP BH,080H ES,8X BH,088H DS,8X Z_0 : ES = MONOCHROME : SET SEGMENT TO COLOR : DS = COLOR AL, . [Di],AL ES:[DI],AL DI Z_1 : MOV MOV INC INC INC INC SHOV SHOV MOP ; DISPLAY A BLANK ; WRITE TO COLOR BUFFER ; WRITE TO MONOCHROME REGEN BUFFER ; POINT TO NEXT POSITION DI DI AL,MFG_PORT+1 CL,4 AL,CL SP,OFFSET Z1_0 SHORT PR GET THE HIGH BYTE OF FAILING PATTERN ; SHIFT COUNT ; NIBBLE SWAP AL, MFG_PORT+1 AL, OFH SP.OFFSET Z2_0 SHORT PR AL, MFG_PORT+2 CL, CL SP.OFFSET Z3_0 SHORT PR AL, MFG_PORT+2 AL, MFG_PORT+2 AL, OFH SP,OFFSET Z4_0 NOV JMP IN NOV JMP JMP JMP JMP JMP JMP JMP Z1: ; ISOLATE TO LOW NIBBLE ; GET THE HIGH BYTE OF FAILING PATTERN ; SHIFT COUNT ; NIBBLE SWAP Z2: Z3: SECTION 5 :---- CONVERT AND PRINT ; CONVERT 00-OF TO ASCII CHARACTER I ADD FIRST CONVERSION FACTOR I ADJUST FOR NUMBERIC AND ALPHA RANGE I ADD CONVERSION AND ADJUST LOW NIBBLE I ADJUST HIGH NIBBLE TO ASCII RANGE ADD DAA ADC DAA PR: AL,090H AL,040H [D1].AL ES:[D1].AL D1 D1 WRITE TO COLOR BUFFER WRITE TO MONOCHROME BUFFER POINT TO NEXT POSITION AL, . . [DI], AL ES:[DI], AL DI DI AL, '2' ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-19 04-21-86 1790 04FD 88 05 1791 04FF 28: 88 05 1791 04FF 28: 88 05 1794 0502 471 1794 0502 471 1794 0502 471 1795 0502 471 1795 0502 471 1795 0502 471 1796 0502 28: 88 05 1797 0508 471 1798 0502 471 1798 0502 471 1798 0502 471 1798 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 471 1799 0502 [DI],AL ES:[DI],AL DI AL,.0. [DI],AL ES:[DI],AL DI AL,.1. [DI],AL ES:[DI],AL MOV INC INC MOV MOV INC INC MOV MOV MOV # WRITE TO DISPLAY REGEN BUFFER ;---- ROLL ERROR CODE IN MFG_PORT FIRST THE CHECKPOINT C31_0: MOV OUT OUT SUB AL,0DDH MFG_PORT,AL MFG_PORT+3,AL CX,CX AX,AX DS,AX AX,EAR AX,[DI] C31_A SUB MOV MOV SUB MOV MOV LOOP ; WRITE AN AASS : READ THE FIRST WORD : DISPLAY CHECKPOINT LONGER C31_B: MOV MOV LOOP [D1],AX AX,[D1] C31_C1 (D1].AX C31_D; MOV MOV LOOP [D1].AX C31_E: MOY MOY LOOP [DI],AX AX,[DI] ;---- ROLL ERROR CODE IN MFG_PORT --> NEXT THE HIGH BYTE ; XOR OF FAILING BIT PATTERN ; HIGH BYTE IN OUT AL,MFG_PORT+1 MFG_PORT,AL MOV MOV MOV LOOP AX,0AA55H [Di],AX AX,[DI] C31_G # WRITE AN AASS . READ THE FIRST WORD C31_H: MOV MOV LOOP [D1],AX AX,[D1] C31_H C31_1: MOV MOV LOOP C31_1 VX.[D1] :---- ROLL ERROR CODE IN MFG_PORT --> THEN THE LOW BYTE C31_K; SUB MOV MOV MOV LOOP C31_L; AL,MFG PORT+2 MFG PORT,AL AX, TAASSH DI,DI [DI],AX AX,[DI] C31_K ; LOW BYTE WRITE AN AA55 1 READ THE FIRST WORD C31_L C31_M; MOV MOV LOOP [D1],AX AX,[D1] C31_M MOV MOV LOOP JMP [DI].AX AX.[DI] C31_0 C31_0 1 DO AGAIN DM DM DM ; TEMPORARY STACK ; TEMPORARY STACK ; TEMPORARY STACK : TEMPORARY STACK 1---- CLEAR STORAGE ENTRY CLR_STG: ASSUME DS:DATA REP STOSW MOV AX,DATA MOV OS:AX MOV ORRESET_FLAG,BX : RESTORE RESET FLAG ;---- SETUP STACK SEGMENT AND SP C33: MOV MOV MOV MOV AX,DATA DS,AX SP,POST_SS SS,SP SP,POST_SP ; SET DATA SEGMENT ;---- INITIALIZE DISPLAY ROW COUNT MOV PROWS.25-1 1 SET ROWS FOR PRINT SCREEN DEFAULT ``` 5-36 TEST1 ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST: --- 04/2:/86 POWER ON SELF TEST (POST) 1-20 04-21-86 1905 05A4 B0 11 1906 05A6 E6 80 1907 1908 05A6 E6 80 1917 1908 05A6 E6 80 1919 05A7 1910 05A8 32 DB 1911 05A7 1912 05AC E4 61 1915 05AC E4 61 1915 05AC E8 61 1915 05AC E8 61 1916 05B6 E1 FA 1916 05B6 E1 FA 1918 05B6 E0 FA 1919 05B6 E0 FA 1919 05B6 E0 FA 1919 05B6 E0 FA 1919 05B6 E0 FA 1922 05B6 E0 FA 1922 05B6 E0 FA 1922 05B6 E0 FA 1923 05B6 E0 FA 1924 05C B7 07 1927 05C E8 0000 E 1928 05C B7 07 1927 05C E8 0000 E 1928 05C B7 07 1927 05C E8 0000 E 1928 05C B7 07 1938 05C B7 07 1938 05C B7 07 1938 05C B7 07 1949 AL,11H MFG_PORT,AL VERIFY SPEED/REFRESH CLOCK RATES ( ERROR = 1 LONG AND 1 SHORT BEEP ) C34: READ REFRESH BIT REGISTER MASK FOR BIT DECREMENT LOOP COUNTER TILL ON AL,PORT_B AL,REFRESH_BIT C34 READ REFRESH BIT REGISTER HASK FOR BIT DECREMENT LOOP COUNTER TILL OFF IN TEST LOOPNZ DEC JNZ ; DECREMENT REFRESH CYCLE REPEAT COUNT ; REPEAT TILL CYCLE COUNT DONE BL C34 CMP JAE CX,RATE_UPPER C36 : CHECK FOR RATE BELOW UPPER LIMIT : SKIP ERROR BEEP IF BELOW MAXIMUM C36E: ; GET BEEP COUNTS FOR REFRESH ERROR ; CALL TO POST ERROR BEEP ROUTINES ; HALT SYSTEM - BAD REFRESH RATE CX,RATE_LOWER CHECK FOR RATE ABOVE LOWER LIMIT GO TO ERROR BEEP IF BELOW MINIMUM GET THE INPUT BUFFER (SWITCH SETTINGS) AL_DMA_PAGE+1 AL_KEY_BD INHIB+DSP_JMP+MFG_LOOP+BASE_MEM+BASE_MEM8 ; STRIP BITS ##FG_TST_AL ; SAVE SETTINGS AL_AL DMA_PAGE+1,AL DMA_PAGE+1,AL TEST. 11A VERIFY 286 LGDT/SGDT LIDT/SIDT INSTRUCTIONS DESCRIPTION LOAD GOT AND IDT REGISTERS WITH AA, 55,00 AND VERIFY CORRECT. 3---- VERIFY STATUS INDICATE COMPATIBILITY (REAL) MODE SMSW AX DB 00FH,001H,0E0H TEST AX,0FH JNZ ERR_PROT ; GET THE CURRENT STATUS WORD ; PE/MP/EM/TS BITS SHOULD BE ZERO ; GO IF STATUS NOT REAL MODE :---- TEST PROTECTED MODE REGISTERS MOV AL,12H MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 12 ◆◆ DS ES DI,SYS_IDT_LOC CX,3 AX,0AAAH WRT PAT AX,05555H WRT_PAT AX,AX WRT_PAT PUSH POP MOV MOV CALL MOV CALL SUB CALL ; SET ES TO SAME SEGMENT AS DS ; USE THIS AREA TO BUILD TEST PATTERN ; FIRST PATTERN ; WRITE NEXT PATTERN ; WRITE 0 TEST 286 CONTROL FLAGS STD PUSHF POP TEST JNZ TEST JZ CLD PUSHF POP TEST JNZ ; SET DIRECTION FLAG FOR DECREMENT ; GET THE FLAGS AX AX,0200H ERR_PROT AX,0400H ERR_PROT I INTERRUPT FLAG SHOULD BE OFF GO IF NOT CHECK DIRECTION FLAG GO IF NOT SET I CLEAR DIRECTION FLAG INSURE DIRECTION FLAG IS RESET ERR_PROT: HLT JMP ; TEST OK CONTINUE ; PROTECTED MODE REGISTER FAILURE ; INSURE NO BREAKOUT OF HALT :---- WRITE TO 286 REGISTERS | Troops | WRITE 1 | WRT_PATINGP | MCV | REP | MCV | REP | MCV | REP | MCV | REP | MCV | REP | MCV | REP R CX.3 STOSW BP,SYS_IDT_LOC ES 026H [BP] 00FH BYTE BX,MORD PTR [BP] BYTE OFFSET CS:??0001 001H ; STORE 6 BYTES OF PATTERN ; LOAD THE IDT 0622 0F 0623 0623 8B 5E 00 0626 0623 0623 01 0626 0626 BD DOAO : REGISTER FROM THIS AREA OFFSET CS::77000. O01H OFFSET CS::770002 BP,SYS_IDT_LOC ES 026H [BP] O0FH BYTE DX,WORD PTR [BP] BYTE 2008 0623 01 2009 0626 BD DOAD 2010 0626 BD DOAD 2011 2012 0629 26 2013 2014 062A 0F 2015 062B 8B 56 00 2017 062E : LOAD THE GDT ; FROM THE SAME AREA ``` ``` 18M Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-21 2018 0628 2019 0628 01 2020 062E 2021 2022 2023 2024 062E BD D8A0 2026 0631 26 2027 0632 0F OFFSET CS:??0004 001H OFFSET CS:?70005 .---- READ AND VERIFY 286 REGISTERS ; STORE THE REGISTERS HERE ** SEGOY DB SIDT SI ; GET THE IDT REGISTERS 2023 0632 0F 2029 0633 88 4E 00 2029 0633 89 4E 00 2030 0633 89 4E 00 2031 0633 01 2034 0638 8D D8A5 2035 0633 6D D8A5 2036 0633 01 2034 0636 8D D8A5 2036 0638 8D D8A5 2037 0639 8D D8A5 2038 0638 8D D8A5 2038 0638 8D D8A5 2038 0638 8D D8A5 2038 0638 8D D8A5 2039 0643 8D D8A5 2039 0643 8D D8A5 2040 0638 0648 8D D8A5 2040 0648 8D D8A5 2040 0649 0 ; GET THE GOT REGISTERS # HALT IF ERROR CONTINUE TILL DONE INITIALIZE THE 8259 INTERRUPT $1 CONTROLLER CHIP : AL,AL X287+1,AL AL,11H INTA00,AL $+2 AL,8 INTA01,AL $+2 SUB OUT MOV OUT JMP MOV OUT JMP ; RESET MATH PROCESSOR ; ICW1 - EDGE, MASTER, ICW4 1 I/O DELAY S SETUP ICW2 - INTERRUPT TYPE 8 (8-F) 1 1/0 DELAY AL.04H INTA01.AL $+2 AL.01H INTA01.AL $+2 AL.0FFH INTA01.AL MOV JMP MOV OUT JMP MOV OUT 1 SETUP ICW3 - MASTER LEVEL 2 ; I/O DELAY ; SETUP ICW4 - MASTER,8086 MODE # 1/O DELAY # MASK ALL INTERRUPTS OFF # (VIDEO ROUTINE ENABLES INTERRUPTS) INITIALIZE THE 8259 INTERRUPT #2 CONTROLLER CHIP : AL, IIH INTBOO, AL $+2 INTBOI, AL AL, INT_TYPE INTBOI, AL $+2 INTBOI, AL $+2 AL, OIH INTBOI, AL $+2 AL, OFFH : ICW1 - EDGE, SLAVE ICW4 YOM YOM YOM TUO YOM YOM YOM YOM YOM YOM : 1/0 DELAY : SETUP 'ICW2 - INTERRUPT TYPE 70 (70-7F) ; SETUP ICW3 - SLAVE LEVEL 2 : I/O DELAY : SETUP ICW4 - 8086 MODE, SLAVE $+2 AL,OFFH INTBOI.AL 2099 0691 E6 A1 2100 2101 2102 2103 0693 B0 14 2104 0695 E6 80 2105 SET UP THE INTERRUPT VECTORS TO TEMPORARY INTERRUPT MOV AL,14H MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 14 ◆◆ 0075 E6 80 2106 0697 B9 0078 2107 0694 2B FF 2108 0695 B5 0700 E 2109 0641 B8 2111 0641 B6 2112 0644 AB 2113 0645 E2 F7 2118 0645 E2 F7 ; FILL ALL INTERRUPT LOCATIONS ; FIRST INTERRUPT LOCATION ; SET (ES) ALSO ; GET ADDRESS OF INTERRUPT OFFSET ; PLACE IN INTERRUPT VECTOR LOCATION ; GET THE CURRENT CODE SEGMENT ; PLACE DOE SEGMENT IN VECTOR LOCATION MOV SUB MOV MOV STOSW MOV STOSW LOOP CX,78H DI,DI ES,DI AX,OFFSET DII D3: AX,CS DB ESTABLISH BIOS SUBROUTINE CALL INTERRUPT VECTORS 15 16 17 06A7 B0 15 18 06A9 E6 80 AL,15H MFG_PORT,AL DI, OFFSET *VIDEO_INT : SET VIDEO INTERRUPT AREA CS DS : SET UP ADDRESS OF VECTOR TABLE AX, DS : SET AX *SEGMENT CX, 16 DI OFFSET VECTOR_TABLE+16 START WITH VIDEO ENTRY MOV PUSH POP MOV MOV MOV 06AB BF 0040 R 06AE 0E 06AF 1F 2124 2125 0680 BE 00 2126 0683 B9 00 2127 2128 0686 A5 2129 0687 47 2130 0688 47 2131 0689 EZ FB 0680 BE 0010 E 0683 B9 0010 ; MOVE VECTOR TABLE TO LOW MEMORY D3A: D3A : SKIP SEGMENT POINTER ``` ``` IBM Personal Computer MACRO Assembler Yersion 2.00 TEST: ---- 04/21/86 POWER ON SELF TEST (POST) 2132 2133 2134 2135 2135 2135 2136 2138 2139 2140 2141 0680 B6 0000 E 2143 0600 B6 00 2144 0600 B6 00 2144 2143 0600 B6 00 2144 2143 2144 2145 2147 2148 2149 2150 0604 B8 0000 E TEST.12 VERIFY CMOS CHECKSUM/BATTERY OK 1 DESCRIPTION DETERMINE IF COMFIG RECORD CAN BE USED FOR INITIALIZATION. ASSUME DS:DATA CALL DDS ; SET THE DATA SEGMENT MOV AL, 16H OUT MFG PORT, AL ---- IS THE BATTERY LOW THIS POWER UP? MOV CALL TEST JZ AL,CMOS_REG_D+NM! : CHECK BATTERY CONDITION CMOS_READ : READ THE BATTERY STATUS AL,10000000B : IS THE BATTERY LOW? CMOSIA : ERROR IF YES 2152 0007 3-7 2153 2154 04CB 80 8E 2155 04CD E8 0000 E 2156 04D0 A8 80 2157 04D2 74 15 2158 2159 04D4 EB 64 MOV CALL TEST JZ AL,CMOS_D!AG+NM! CMOS_READ AL,BAD_BAT CMOS! GET THE OLD STATUS FROM DIAGNOSTIC STATUS BYTE HAS CUSTOMER SETUP BEEN EXECUTED? GO CHECK CHECKSUM IF YES ; CONTINUE WITHOUT CONFIGURATION JMP SHORT CMOS4 1---- SET DEFECTIVE BATTERY FLAG 162 163 06D6 B0 17 164 06D8 E6 B0 CMOSIA: MOV OUT AL,17H MFG_PORT,AL AX,X° (CMOS_DIAG+NMI) CMOS READ AL,BAD_BAT AL,AH CMOS WRITE SHORT CMOS4 CMOS DIAGNOSTIC STATUS BYTE GET THE CURRENT STATUS SET THE DEAD BATTERY FLAG SATE OUTPUT THE STATUS OUTPUT THE STATUS OUTPUT THE STATUS 65 66 06DA 88 8E8E 67 06DD E8 0000 E 68 06E0 0C 80 69 06E2 86 C4 70 06E4 E8 0000 E 71 06E7 EB 51 MOV CALL OR XCHG CALL JMP ---- VERIFY CHECKSUM CMOS1: MOV CALL CMP JNZ AX,X°(CMOS_DIAG+NMI) CMOS READ •RESET_FLAG,1234H CMOS1_A ; CLEAR OLD STATUS ; GET THE CURRENT STATUS ; IS THIS A SOFT RESET ; GO IF NOT 75 06E9 B8 8E8E 76 06EC E8 0000 E 77 06EF 81 3E 0072 R 1234 78 06F5 75 04 179 180 06F7 24 10 181 06F9 EB 02 182 06FB 183 06FB 2A C0 184 06FD 185 06FD 86 C4 186 06FF ES 0000 E AND : CLEAR ALL BUT THE CMOS/POR MEMORY SIZE CMOS1_A: SUB CMOS1_B: XCHG CALL AL,AL ; CLEAR STATUS IF POWER ON RESET 2184 06FD 28-5 C4 2185 06FP 85 0000 E 2185 06FP 85 0000 E 2186 0702 28 DB 2189 0704 28 C9 2190 0706 81 90 2190 0706 81 90 2190 0706 81 90 2190 0708 85 AAC 2190 0708 85 AAC 2190 0710 73 FE C1 2194 070C 28 0000 E 2194 070C 28 0000 E 2195 070T 37 EC 2195 0711 37 DC 2197 0713 FE C1 2196 0711 37 DC 2197 0713 FE C1 2198 0711 38 DE 22197 0713 FE DC 2200 0714 38 DB 2200 0714 38 DB 2200 0714 38 DB 2200 0714 80 AE 2200 0714 80 AE 2200 0728 87 AB 2200 0728 87 AB 2200 0728 87 AB 2200 0728 87 AB 2200 0728 87 AB 2200 0728 BB 2211 0730 BB 2220 0730 BB 2221 0730 BB 2221 0730 BB 2222 0730 BB 2223 0744 BB 2223 0744 BB 2223 0745 2233 0745 BB 2234 234 0745 BB 2446 0745 BB 2447 0745 BB 2448 0745 BB 2448 0745 BB 2448 0745 ; SAVE THE CURRENT STATUS AL,AH CMOS_WRITE BX.BX CX.CX CL,CMOS_DISKETTE+NMI CH,CMOS_CKSUM_HI+NMI SUB SUB MOV MOV ; SET START OF CMOS CHECKSUMED AREA ; SET END OF CMOS CHECKSUMED AREA +1 ; (FIRST BYTE OF CHECKSUM) CMOS2: MOV CALL SUB AND INC CMP JZ MOV CALL MOV CALL CMP JZ CH, CMOS_CKSUM_HI+NMI AL, CL CMOS READ AH, AR BX, AX CL CL CMOS CMOSZ ZX, BX CMOSZ ZX, BX CMOSZ CMOSZ AL, CMOS CKSUM_HI+NMI CMOS READ AH, AL CMOS CKSUM_LO+NMI CMOS READ CMOSA CMOSA CMOSA I (FIRST BYTE OF CHECKSUM) ADDRESS THE BEGINNING INSURE AH#O ADD TO CURRENT VALUE POINT TO NEXT BYTE ADDRESS IN CMOS POINT TO NEXT BYTE ADDRESS IN CMOS POINT TO NEXT BYTE ADDRESS IN CMOS POINT TO NEXT BYTE HIGH) OF THE CHECK SUM BYTE HIGH) OF THE CHECK SUM BYTE FIRST BYTE OF CHECKSUM SAVE IT SECOND BYTE OF CHECKSUM ; IS THE CHECKSUM OK ; GO IF YES :---- SET CMOS CHECKSUM ERROR CMOS3: MOV AX,X*(CMOS_D!AG+NM!) CALL CMOS_READ OR AL,BĀD_CKSUM AC,AH CALL CALL CMOS_WR!TE ; ADDRESS DIAGNOSTIC STATUS ; GET THE CURRENT STATUS ; SET BAD CHECKSUM FLAG ; SAVE IT ; SET FLAG 3---- INSURE CMOS DIVIDERS SET CMOS4: MOV CALL AND JNZ AX,X*(CMOS_REG_A+NMI) CMOS_READ AL,00FH CMOS9 : ADDRESS CMOS REGISTER A ; GET CURRENT DIVISORS ; LOOK AT PERIODIC RATE BITS ; EXIT IF SET TO SOMETHING USEFUL CMDS9: AL,26H AL,AH CMOS_WRITE ; ELSE SET THE STANDARD DEFAULT USED BY ; BIOS FOR THE 976.56 US RATE ; FOR THE PERIODIC CLOCK AL,18H MFG_PORT.AL |---- ENABLE PROTECTED MODE AL.PORT_B AL.RAM_PAR_OFF PORT_B.AL : DISABLE MEMORY AND I/O PARITY CHECKS IN OR OUT :---- SET RETURN ADDRESS BYTE IN CMOS MOY AL,19H MFG_PORT,AL ``` 2243 2244 0759 B8 018F 2245 076C E8 0000 E MOV AX,1°H+(CMOS\_SHUT\_DOWN+NMI) ; SET THE RETURN ADDRESS FOR CMOS\_WRITE ; THE FIRST SHUTDOWN RETURN ADDRESS ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTI --- 04/21/86 POWER ON SELF TEST (POST) 1-23 SP,POST_SS SS,SP SP.POST_SP SYSINITT SET STACK FOR SYSINITI # CALL THE DESCRIPTOR TABLE BUILDER # AND REAL-TO-PROTECTED MODE SWITCHER ;---- SET TEMPORARY STACK BYTE PTR GOT_PTR | SET (DS;) S DS DS:SS TEMP.BASE_LO_WORD,0 BYTE PTR DS:(SS_TEMP.BASE_H!_BYTE),0 S1.SS_TEM SS,SI PUSH POP MOV MOV MOV MOV SET (DS:) SELECTOR TO GDT SEGMENT TEST.13 DESCRIPTION: THIS ROUTINE RUNS IN PROTECTED MODE IN ORDER TO ADDRESS ALL OF STORAGE. IT CHECKS THE MACHINE STATUS WORD (MSW) FOR PROTECTED MODE AND THE BASE MEMORY SIZE IS DETERMINED AND SAVED. BIT 4 OF THE CMOS DIAGNOSTIC STATUS BYTE IS SET IF 512K --> 460K MEMORY IS INSTALLED. DURING A POWER UP SEQUENCE THE MEMORY SIZE DETERMINE IS DONE WITH PLANAR AND 1/O PARITY CHECKS DISABLED. DURING A SOFT RESET THE MEMORY SIZE DETERMINE WILL CHECK FOR PARITY ERRORS. :---- INSURE PROTECTED MODE SMSW AX 1 GOT THE MACHINE STATUS WORD OP TEST AX, YIRTUAL_ENABLE ; ARE WE IN PROTECTED MODE VIR_OK VIR_OK AX, 8°H+(CMOS_SHUT_DOWN+NMI) ; SET THE RETURN ADDRESS CALL CMOS_WRITE ; AND SET SHUTDOWN 8 PROC_SHUTDOWN 1 CAUSE A SHUTDOWN 8 ---- VIRTUAL MODE ERROR HALT SHUT8: HLT JMP SHUT8 ; ERROR HALT ;---- 64K SEGMENT LIMIT VIR OK: MOV DS:ES_TEMP.SEG_LIMIT,MAX_SEG_LEN :---- CPLO, DATA ACCESS RIGHTS MOV BYTE PTR DS: (ES_TEMP.DATA_ACC_RIGHTS), CPL0_DATA_ACCESS :---- START WITH SEGMENT ADDRESS 01-0000 (SECOND 64K) MOV BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),01H MOV DS:ES_TEMP.BASE_LO_WORD,0H MOV AL,18H ; ♦♦♦♦♦♦♦♦♦ OUT MFG_PORT,AL ; ♦♦ CHECKPOINT 18 ♦♦ MQV BX,16*4 ; SET THE FIRST 64K DONE :---- START STORAGE SIZE/CLEAR POINT ES TO DATA POINT TO SEGMENT TO TEST DO THE FIRST 64K CHECK IF TOP OF MEMORY NOT_FIN: 2324 0700 83 C3 40 2325 2326 2326 2326 2327 2328 0703 FE 06 004C 2329 2330 2331 2332 0707 80 3E 004C 0A 2333 070C 75 874 2336 070E 80 0847 R 2336 070E 80 0847 R 2337 2338 2339 0704 2337 2338 2339 0704 2357 2340 0704 28 FF 2340 0704 80 A55 2340 0704 80 FF 2340 0704 80 FF 2340 0704 80 FF 2340 0708 26: 69 05 2344 0708 26: 69 05 2344 0708 26: 89 05 2344 0708 26: 89 05 2344 0708 36: 80 05 2345 0786 33 C1 2345 0786 33 C1 2345 0786 33 C1 2345 0786 18 2350 0786 18 2350 0787 18 2353 2359 ;---- DO NEXT 64K (0X0000) BLOCK INC BYTE PTR DS: (ES_TEMP.BASE_HI_BYTE) ;---- CHECK FOR END OF FIRST 640K (END OF BASE MEMORY) CMP BYTE PTR DS1(ES_TEMP.BASE_HI_BYTE)_OAH JNZ NOT_DONE 1_GO_IF NOT CALL HOW BIG_END ; GO_SET_MEMORY_SIZE JMP DONE |---- FILL/CHECK LOOP DI.DI AX,0AA55H CX,AX ES:[DI],AX AL,0FH AX,ES:[DI] ES:[DI],AX AX,CX HOW_BIG_END : TEST PATTERN : SAVE PATTERN : WRITE PATTERN TO MEMORY : PUT SOMETHING IN AL : GET PATTERN : INSURE NO PARITY I/O CHECK : COMPARE PATTERNS : GO END IF NO COMPARE PUSH DS PUSH BYTE PTR RSDA_PTR POP DS ;---- IS THIS A SOFT RESET PRESET_FLAG, 1234H DS HOW_BIG_2 3 SOFT RESET 3 RESTORE DS 4 GO IF NOT SOFT RESET ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTI ---- 04/21/86 POWER ON SELF TEST (POST) :---- INSURE NO PARITY WITH PARITY BITS OFF MOY WORD PTR ES: [DI],0101H ; TURN OFF BOTH PARITY BITS AL, PORT B AL, RAM_PAR_OFF PORT B.AL AL, RAM_PAR_ON PORT B.AL BYTE PTR OFFH AX AX, ES:[DI] ; TOGGLE PARITY CHECK ENABLES AL.PORT B AL.PARITY ERR ES:[DI].AX HOW_BIG_END ; CHECK FOR PLANAR OR I/O PARITY CHECK CLEAR POSSIBLE PARITY ERROR GO IF PLANAR OR I/O PARITY CHECK CHECK ALL BITS WRITE OK MOV MOV PUSH IN AND MOV POP JNZ CMP JNZ CHECK 64K BLOCK FOR PARITY CHECK HOW_BIG_2: SUB MOV REP AX,AX CX,2000H°4 STOSW ; WRITE ZEROS ; SET COUNT FOR 32K WORDS ; FILL 32K WORDS STOSW DS CS CS CX,2000M*4 SI,SI LODSW DI,DI AL,FORT B AL, PUSH PUSH POP MOV SUB REP SUB IN MOP POP JNZ ; GET ES TO DS : SET COUNT FOR 32K WORDS ; SET TO BEGINNING OF BLOCK ; CHECK FOR PLANAR OR I/O PARITY CHECK ; CLEAR POSSIBLE PARITY ERROR ; RESTORE SEGMENTS : GO IF PLANAR OR 1/O PARITY CHECK RET HOW_BIG_END: PUSHF MOV OUT ; SAVE THE CURRENT FLAGS $ $$\display \display AL,1CH MFG_PORT,AL ;---- SET OR RESET 512 TO 640 INSTALLED FLAG AX,X°(CMOS_INFO128+NMI) ; SET/RESET 640K STATUS FLAG CMOS_READ ; GET THE DIAGNOSTIC STATUS AL,M540K BX,512 ; CHECK MEMORY SIZE K640 ; SET FLAG FOR 512 -> 640 INS AL,NOT M640K MOV CALL OR CMP JA AND ; CHECK MEMORY SIZE ; SET FLAG FOR 512 -> 640 INSTALLED XCHG CALL ; RESTORE THE DATA SEGMENT ; SAVE MEMORY SIZE ; RESTORE THE FLAG REGISTER TEST. 13A PROTECTED MODE TEST AND MEMORY SIZE DETERMINE ( ABOVE 1024K ) DESCRIPTIONI THIS ROUTINE RUNS IN PROTECTED MODE IN ORDER TO ADDRESS ABOVE I MEG. THE MEMORY SIZE IS DETERMINED AND SAVED IN CMOS. URLING A POWER UP SECUENCE THE MEMORY SIZE DETERMINE IS DONE WITH PLANAR AND 1/O PARITY CHECKS DISABLED. DURING A SOFT RESET THE MEMORY SIZE DETERMINE WILL CHECK FOR PARITY ERRORS. PUSH BYTE PTR GDT_PTR POP DS SECTION 5 2452 0874 1F 2453 2455 0875 C6 06 004C 10 2457 087A C7 06 004A 0000 2457 087A C7 06 004A 0000 2458 2458 2459 0880 80 1D 2462 0884 28 DB 2462 0884 28 DB 2463 2465 2465 0886 6A 48 2467 0886 6A 48 2470 088C 74 03 2471 088E E9 092C R 2473 088E E9 092C R ;---- START WITH SEGMENT ADDRESS 10-0000 (ONE MEG AND ABOVE) MOV BYTE PTR D$:(ES_TEMP.BASE_HI_BYTE),10H MOV DS:ES_TEMP.BASE_LO_WORD,0R MOV AL,1DH MFG_PORT,AL вх, вх SUB ; START WITH COUNT 0 ---- START STORAGE SIZE/CLEAR NOT_DONE1: PUSH POP CALL JZ BYTE PTR ES_TEMP ES HOW BIG! DONEA : POINT ES TO DATA : POINT TO SEGMENT TO TEST : DO THE FIRST 64K : CHECK IF TOP JMP DONE! ; GO IF TOP ``` ``` IBM Personal Computer MACRO Assemblar Version 2.00 TESTI ---- 04/21/86 POWER ON SELF TEST (POST) 2474 0891 83 C3 40 2476 2476 2477 2478 0894 FE 06 004C 2477 2478 0894 FE 06 004C 2477 2480 0898 80 3E 004C FE 2482 0898 80 3E 004C FE 2483 0897 75 ET 2484 0897 ES 0919 R 2485 08A2 E9 092C R 2486 08A5 28 FF 2490 08A5 28 FF 2490 08A5 28 FF 2491 08A7 88 A85 2492 08A8 88 C8 2492 08A8 89 C8 2494 08A7 80 0F 2494 08A7 80 0F 2496 08B2 261 89 05 2496 08B2 261 89 05 2496 08B2 161 80 05 2497 08B7 33 C1 2499 08B9 15 2500 08B8 1E 2500 08B8 1E 2500 08C6 A18 2504 08EE 17 2507 08C6 75 2F 2508 DONEA: ADD BX,16*4 : BUMP MEMORY COUNT BY 64K :---- DO NEXT 64K (XX0000) BLOCK INC BYTE PTR DS: (ES_TEMP.BASE_HI_BYTE) :---- CHECK FOR TOP OF MEMORY (FE0000) CMP BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),0FEH ; LAST OF MEMORY? JNZ NOT DOME! ; GO IF NOT CALL HOW BIG_END! ; GO SET MEMORY SIZE DOME! DI,DI AX,0AA55H CX,AX ESI[DI],AX AL,0FH AX,ESI[DI] ESI[DI],AX HOW_BIG_ENDI I TEST PATTERN I SAVE PATTERN I SEND PATTERN TO MEMORY I PUT SOMETHING IN AL I GET PATTERN I INSURE NO PARITY I/O CHECK I COMPARE PATTERN I GO END IF NO COMPARE 1---- IS THIS A SOFT RESET PUSH DS PUSH BYTE PTR RSDA_PTR POP DS CMP PRESET_FLAG,1234H DS JNZ HOW_BIG_2A ; POINT TO SYSTEM DATA AREA ; SOFT RESET ; RESTORE DS ; GO IF NOT SOFT RESET 2800 08C8 IF 2801 08C8 175 2F 2808 2501 08C8 261 C7 05 0101 2811 08C8 261 C7 05 0101 2811 08C8 261 C7 05 0101 2811 08C8 261 08 05 2814 0800 261 68 05 2814 0800 261 68 05 2818 0807 261 89 05 2819 080A 75 3D 2820 08D 4 C0 0 2819 08D 261 C7 05 FFFF 2822 08E4 64 00 2826 08E5 64 60 2826 08E5 64 60 2826 08E5 64 60 2830 08E6 24 60 2830 08E6 24 60 2830 08E6 24 60 2830 08E6 24 60 2830 08E6 68 2832 08F8 68 2832 08F8 68 2832 08F8 68 2832 08F8 68 2832 08F8 68 :---- CHECK PARITY WITH PARITY BITS OFF IN AND MOV JNZ AL,PORT_8 AL,PARITY_ERR ES:[DI],AX HOW_BIG_END1 ; CHECK FOR PLANAR OR 1/0 PARITY CHECK ; CLEAR POSSIBLE PARITY ERROR ; GO IF PLANAR OR I/O PARITY CHECK ;---- CHECK ALL BITS WORD PTR ESI[DI], OFFFFH : TURN ON ALL BITS BYTE PTR 0 : PLACE GOGOOH IN STACK (BUS BITS OFF) AX, SI[DI] : CHECK FOR FFFFH AX, SISI[DI] : CHECK FOR FLANAR OR I/O PARITY CHECK AL. PORT B : CHECK FOR FLANAR OR I/O PARITY CHECK ESI[DI], AX : CLEAR POSSIBLE PARITY ERROR AX BIG ENDI : GET RESULTS CHECK AX, OFFFFH : GO IF FLANAR OR I/O PARITY CHECK AX, OFFFFH : GO IF FLANAR OR I/O PARITY CHECK AX, OFFFFH : GO IF FLANAR OR I/O PARITY CHECK MOV PUSH POP MOV PUSH IN AND MOV POP JNZ CMP JNZ 2533 08F7 75 22 2538 08F7 28 2539 08F7 28 2539 08F7 28 2539 08F7 28 2549 08F7 89 8000 2541 08FC F3 / AB 2544 28 2544 28 2544 28 2544 28 2544 28 2544 29 2544 29 2554 0901 89 8000 2550 0905 28 F6 2549 0902 89 8000 2550 0907 87 AD 2550 0907 87 AD 2551 0907 F7 AD 2551 0907 F7 AD 2551 0907 F8 AD 2554 0908 24 C0 2555 090F 26 C7 05 0000 2550 090F 26 C7 05 0000 2550 090F 80 80 2550 0918 C3 2560 C4 2560 0918 C4 2560 0918 C5 2560 0918 C5 2560 0918 C5 2560 0918 C5 2560 0918 C5 2577 0926 C5 2577 0926 C6 2577 0926 C7 2577 0926 C7 2577 0926 C7 2577 0927 0928 C7 2577 0927 C7 2577 0927 C7 2577 0927 C7 2577 0927 C7 2577 0928 C7 2577 0927 ;---- CLEAR 64K BLOCK OF MEMORY HOW_BIG_2A: SUB MOV REP ; WRITE ZEROS ; SET COUNT FOR 32K WORDS ; FILL 32K WORDS :---- CHECK 64K BLOCK FOR PARITY CHECK (VALID TEST DURING SOFT RESET ONLY) DS DS ES DS CX,2000H*4 SI,SI LOOSW DI,DI AL,PORT B AL,PARITY ERR WORD PTR ES:[DI],0 ES DS HOW_BIG_ENDI PUSH PUSH PUSH POP MOV SUB REP SUB IND MOV POP JNZ ; GET ES TO DS SET COUNT FOR 32K WORDS SET TO BEGINNING OF BLOCK CHECK FOR PLANAR OR 1/0 PARITY CHECK CLEAR POSSIBLE PARITY ERROR RESTORE SEGMENT ; GO IF PLANAR OR 1/0 PARITY CHECK RET HOW_BIG_END1: MOV AL,1EH OUT MFG_PORT,AL 1---- SET EXPANSION MEMORY SIZE DETERMINED IN CHOS AL, CMOS_U_M_S_LO+NMI : ADDRESS LOW BYTE : GET LOW MEMORY SIZE : SET LOW BYTE BELONK SIZE : SET LOW BYTE : SET LOW BYTE : SET LOW BELONK SIZE : SET LOW BYTE SE MOV MOV CALL MOV MOV CALL RET ;---- TEST ADDRESS LINES 19 - 23 AL. IFH IF DONE1: MOV OUT MOV SUB MOV CALL SUB 2584 093D 28 D2 2585 2586 093F C6 06 004C 08 2587 0944 E8 0969 R MOV CALL BYTE PTR DS: (ES_TEMP.BASE_HI_BYTE),08H SD0 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTI ---- 04/21/86 POWER ON SELF TEST (POST) 1-26 2588 0947 C6 06 004C 10 2599 094C E8 0969 R 2591 0947 C6 06 004C 20 2591 0947 C6 06 004C 20 2591 0947 C6 06 004C 20 2592 0957 C6 06 004C 40 2593 0956 C6 00 004C 80 2593 0956 C6 00 004C 80 2593 0956 C6 00 004C 80 2593 0956 C7 004C 80 2594 0959 C7 260 004C 80 2594 0959 C7 260 004C 80 2595 0950 BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),10H SD0 BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),20H SD0 BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),40H SD0 BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),60H SD0 MOV CALL MOV CALL MOV CALL MOV CALL JMP SHORT SD2 ; TEST PASSED CONTINUE SD0: BYTE PTR ES_TEMP ES ES:[DI],DX PUSH POP MOV POINT ES TO DATA POINT TO SEGMENT TO TEST WRITE THE PATTERN MOV BYTE PTR DS: (ES_TEMP.BASE_HI_BYTE),00H PUSH POP CMP JZ JMP SD1t RET :---- CAUSE A SHUTDOWN AL,20H MFG PORT,AL AL,FORT B AL,RAM PAR_OFF PORT B,AL AL,RAM_BAR_ON PORT B,AL PROC_SHUTDOWN MOV OUT IN OR OUT AND OUT JMP SD2: ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 20 ◆◆ ; TOGGLE PARITY CHECK ENABLES : CAUSE A SHUTDOWN (RETURN VIA JUMP) RETURN : FROM SHUTDOWN : AL,21H MFG_PORT,AL SP,ABSO SS,SP SP,OFFSET #TOS SHUT 1: 1---- SET DIVIDE 0 VECTOR OFFSET DI,DI ES,DI AX,OFFSET DII SUB MOY MOY STOSW ; POINT TO FIRST INTERRUPT LOCATION ; SET ES TO ABSO SEGMENT ; GET ADDRESS OF INTERRUPT OFFSET ; PLACE OFFSET IF NULL HANDLER IN VECTOR CALL ;---- GET THE CONFIGURATION FROM CMOS AX,X°(CMOS_DIAG+NMI) CMOS_READ AL,BAD_BAT+BAD_CKSUM M. DK BAD_MOS MOV CALL TEST JZ JMP CHECK CMOS GOOD GET THE STATUS VALID CMOS ? GO IF YES GO IF NOT AND XCHG CALL AL, ODFH AL, AH CMOS_WRITE ; CLEAR THE MINIMUM CONFIG BIT ; SAVE THE STATUS BYTE ; BACK INTO CMOS CHECK FOR CMOS RUN IN MODE PRESET_FLAG,1234H M_OK_64 CMP JE ; CHECK FOR SOFT RESET ; BYPASS IF SOFT RESET AL,CMOS_B_M_S_HI+NMI CMOS_READ AL,OCOH AL,OCOH M_OK_64 MOV CALL AND CMP JNE ; GET THE BASE MEMORY SIZE HIGH BYTE ; MASK FOR MANUFACTURING TEST BITS ; CHECK FOR MANUFACTURING TEST MODE SET ; SKIP IF NOT MANUFACTURING LINE TEST MOY BYTE PTR PRESET_FLAG, 64H; ELSE SET THE MFG TEST FLAG 1---- INSURE CONFIGURATION HAS CORRECT VIDEO TYPE M_OK_641 MOV CALL MOV TEST JNZ CALL JZ AL, CMOS EQUIP+NMI CMOS READ AH, AL AL, 030H MOS OK 1 CHK_VIDEO MOS_OK ; GET THE EQUIPMENT BYTE : SAVE VIDEO TYPE : ANY VIDEO? : CONTINUE : INSURE VIDEO ROM PRESENT : CONTINUE OMFG_TST,MFG_LOOP # EXCEPT IF MFG JUMPER IS INSTALLED TEST JZ SHORT BAD_MOS JMP : GO DEFAULT ---- ROUTINE CHECK FOR VIDEO FEATURE ROM PRESENT CHK_YIDEO: MOV CHK_YIDEOI: PUSH PUSH MOV MOV SUB MOV CMP POP POP POP JZ СХ.0С000Н : START OF FEATURE 1/0 ROM | START OF FEATURE 170 KUM | SAVE THE DATA SCOMENT | SAVE COMPARE REGISTER | OUT TON SEGMENT | OUT THE PRESENCE SIGNATURE | OUT THE PRESENCE SIGNATURE | OUT THE PRESENCE SIGNATURE | OUT THE PRESENCE SIGNATURE | OUT THE PRESENCE SIGNATURE | THE VIDEO FEATURE ROM PRESENT? | RESTORE DATA SEGMENT | RESTORE DATA SEGMENT | OUT THE CONFIGURATION | OUT THE CONFIGURATION | OUT THE CONFIGURATION | OUT THE CONFIGURATION ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST: --- 04/21/86 POWER ON SELF TEST (POST) 1-27 04-21-86 2702 2703 0A04 81 C1 0080 2704 0A08 81 F9 C800 2705 0A0C 7C E3 2706 0A0E 23 C9 2707 0A10 2708 0A10 C3 2709 ; POINT TO NEXT 2K BLOCK ; TOP OF VIDEO ROM AREA YET? ; TRY AGAIN ; SET NON ZERO FLAG JE AND CHK_VIDED2: RET : RETURN TO CALLER 2708 0A10 C3 2709 2710 2711 2712 0A11 2713 0A11 E8 09EE R 2714 0A14 74 26 2715 0A16 8A C4 2717 0A18 F6 06 0012 R 40 2718 0A1D 74 0A MOS_OK_1; CALL JZ ;---- CMOS VIDEO BITS NON ZERO (CHECK FOR PRIMARY DISPLAY AND NO VIDEO ROM) CHK_VIDEO BAD_MOS ; IS THE VIDEO ROM INSTALLED? ; WRONG CONFIGURATION IN CONFIG BYTE : RESTORE CONFIGURATION : CHECK FOR DISPLAY JUMPER : GO IF COLOR CARD IS PRIMARY DISPLAY AL,AH MAFG_TST,DSP_JMP MOS_OK_2 # MONOCHROME CARD IS PRIMARY DISPLAY (NO JUMPER INSTALLED) AL,30H AL,30H BAD_MOS AL,AH SHORT MOS_OK ; INSURE MONOCHROME IS PRIMARY : CONFIGURATION OK? : GO IF NOTO FIGURATION : RESTORE CONFIGURATION BYTE FOR DISPLAY : USE THE CONFIGURATION BYTE FOR DISPLAY AND CMP JNZ MOV JMP MOS_OK_2: AND CMP MOV JZ AL,30H AL,30H AL,AH BAD_MOS ; STRIP UNWANTED BITS ; MUST NOT BE MONO WITH JUMPER INSTALLED ; RESTORE CONFIGURATION ; GO IF YES ;---- CONFIGURATION MUST HAVE AT LEAST ONE DISKETTE MOS_OK; TEST AL,01H ; MUST HAVE AT LEAST ONE DISKETTE ; GO SET CONFIGURATION IF OK TEST ONE OF TEST, MFG LOOP ; EXCEPT IF MFG JUMPER IS INSTALLED ; GO IF INSTALLED 0A31 A8 01 0A33 75 26 0A35 F6 06 0012 R 20 0A3A 74 1F :---- MINIMUM CONFIGURATION WITH BAD CMOS OR NON VALID VIDEO BAD_MOS: MOV CALL TEST JNZ AX,CMOS_DIAG+NMI CMOS_READ AL,BAD_BAT+BAD_CKSUM BAD_MOSI ; GET THE DIAGNOSTIC STATUS : WAS BATTERY DEFECTIVE OR BAD CHECKSUM 2749 0A44 75 03 2750 0A46 E8 0000 E 2751 0A46 E8 0000 E 2752 0A49 2753 0A49 E8 09EE R 2754 0A46 B0 01 2755 0A4E 74 0B 2756 0A50 F6 06 0012 R 40 2758 0A55 B0 11 2759 0A57 74 02 2750 CALL CONFIG_BAD BAD_MOS1: CALL CHK_YIDEO MGY AL,01H JZ NORMAL_CONFIG ; SET THE MINIMUM CONFIGURATION FLAG CHECK FOR VIDEO ROM DISKETTE ONLY GO IF VIDEO ROM PRESENT OMFG_TST,DSP_JMP AL,11H NORMAL_CONFIG : CHECK FOR DISPLAY JUMPER : DEFAULT TO 40X25 COLOR : GO IP JUMPER IS INSTALLED TEST MOV JZ 760 761 0A59 B0 31 762 763 764 765 766 767 0A5B ; DISKETTE / B/W DISPLAY 80X25 MOV AL,31H CONFIGURATION AND MFG MODE : NORMAL_CONFIG: TEST JNZ AND OA5B OA5B F6 O6 OO1Z R 20 OA6O 75 OZ OA62 24 3E MFG_TST,MFG_LOOP NORM! AL,03EH ; IS THE MANUFACTURING JUMPER INSTALLED ; GO IF NOT ; STRIP DISKETTE FOR MFG TEST AH, AH •EQUIP_FLAG, AX •RESET_FLAG, 1234H E6 NORM1: SUB MOV CMP JZ 0A64 2A E4 0A66 A3 0010 R 0A69 81 3E 0072 R 1234 0A6F 74 2C ; SAVE SWITCH INFORMATION : BYPASS IF SOFT RESET :---- GET THE FIRST SELF TEST RESULTS FROM KEYBOARD AL, WR!TE_8042_LOC C8042 AL,4DH : ENABLE KEYBOARD I ISSUE WRITE BYTE COMMAND I ENABLE OUTPUT BUFFER FULL INTERRUPT, I SET SYSTEM FLAG, PC I COMPATIBILITY, INHIBIT OVERRIDE, ENABLE KEYBOARD MOV CALL MOV 2182 2183 0AT8 E6 60 2184 2185 0ATA 2B C9 2186 0ATC E8 03A2 R 2187 PORT_A,AL OUT SUB CALL CX.CX C42_1 ; WAIT FOR COMMAND ACCEPTED 2181 2188 OATF B9 TFFF MOY CX,07FFFH ; SET LOOP COUNT FOR APPROXIMATELY 100MS; TO RESPOND; WAIT FOR OUTPUT BUFFER FULL 2189 0APE 89 7FFF 2189 0APE 84 64 2791 0A84 A8 01 2792 0A86 E1 FA 2798 0A86 B8 0APE 87 0APE 89 TST6: IN AL,STATUS_PORT TEST AL,OUT_BUF_FULL LOOPZ TST6 : TRY AGAIN IF NOT PUSHF MOV CALL POPF JZ ; SAVE FLAGS ; DISABLE KEYBOARD ; ISSUE THE COMMAND ; RESTORE FLAGS ; CONTINUE WITHOUT RESULTS AL,DIS_KBD C8042 AL, PORT A ; GET INPUT FROM KEYBOARD BYTE PTR PRESET_FLAG, AL ; TEMPORARY SAVE FOR AA RECEIVED IN MOV :---- CHECK FOR MFG REQUEST ; LOAD MANUFACTURING TEST REQUEST? ; CONTINUE IF NOT ; ELSE GO TO MANUFACTURING BOOTSTRAP AL,065H E6 MFG_BOOT ``` ``` 2800 | 2810 | 2811 | 2812 | 2813 | 2814 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 2815 | 28 TEST. 14 INITIALIZE AND START CRT CONTROLLER (6845) TEST YIDEO READ/WRITE STORAGE. DESCRIPTION DESCRIPTION SELECT HE VIDEO EMABLE SIGNAL. SELECT ALPHANLMERIC MODE, 40 ° 25, B & W. READ/WRITE DATA PATTEMNS TO MEMORY. CHECK STORAGE ADDRESSABILITY. ERROR = 1 LONG AND 2 SHORT BEEPS I GET SENSE INFORMATION SAVE IT FORCE MONOCHROME TYPE INFORMEDITE FOR DEFAULT MODE SEND INITIALIZATION TO BYF CARD FORCE COLOR AT 80 BY 25 INTO EQUIPMENT FLAG TO CLEAR BUFFERS AND INITIALIZATION COLOR CARD 80X25 MODE SET 80 X 25 SET COLOR 40 X 25 SET COLOR 40 X 25 SET COLOR 40 X 25 SET OBFAULT COLOR MODE ISET DEFAULT ISOLATE VIDEO SWITCHES VIDEO SWITCHES SET TO 0? ISAVE THE DATA SEGMENT MOV PUSH MOV SUB INT MOV MOV INT POP MOV AND JNZ AND JNZ HOV MOV AND JNZ MOV MOV AND JNZ MOV MOV AND JNZ MOV AND JNZ MOV AND JNZ J B/W CARD ATTACHED? 1 YES - SET MODE FOR B/W CARD 1 SET COLOR MODE FOR COLOR CARD 1 SET SET WOLD MODE FOR COLOR CARD 1 SET SET MODE FOR 40X25 1 NO - SET MODE FOR 40X25 E7: CMP JE INC CMP JNE MOV AL,30H E8 AH AL,20H E8 AH,3 AH, 3 AH, AL AX AH, AH INT_VIDEO AX AX AX AX AX AX AX, 08000H DX, 388H CX, 2048 AH, 30H E9 BH, 088H DX, 308H DX, 308H E8: XCHG PUSH SUB INT POP PUSH MOY MOY CMP JE MOY MOY MOY I SAVE VIDEO MODE ON STACK I INITIALIZE TO ALPHANUMERIC MD CALL VIDEO IO RESTORE VIDEO SENSE SWITCHES IN AH SAVE VALUE I STARTING VIDEO MEMORY ADDRESS 8/W CARD MODE REGISTER FOR 8/W CARD MODE REGISTER FOR 8/W CARD MODE REGISTER FOR BOTH CARD VEST OF THE VIDEO STORAGE I STARTING MEMORY ADDRESS FOR COLOR CARD MODE REGISTER FOR COLOR CARD MODE REGISTER FOR COLOR CARD MODE REGISTER FOR COLOR CARD MODE REGISTER FOR COLOR CARD E9: AL. OCRT_MODE_SET AL. 037H DX. AL ES. BX DS. BX CX. I STGTST_CNT E17 GET CURRENT MODE SET YALUE SET YIDED BIT DEF 1 DISABLE VIDED FOR COLOR CARD POINT ES TO VIDED MEMORY 1 POINT ES TO VIDED MEMORY 1 DIVIDE BY 2 FOR WORD COLUT 1 OT YEST VIDED MEMORY 1 OF YIDED READER 1 R/W MEMORY FAILURE - BEEP SPEAKER MOV AND OUT MOV MOV ROR CALL JNE TEST.15 SETUP VIDEO DATA ON SCREEN FOR VIDEO LINE TEST. DESCRIPTION ENABLE VIDEO SIGNAL AND SET MODE. DISPLAY A HORIZONTAL BAR ON SCREEN. OCCOSOS (AM) CET VIDEO SENSE SWITCHES (AH) SAVE IT ENABLE VIDEO AND SET MODE VIDEO WRITE BLANKS IN REVERSE VIDEO SETUP STARTING LOCATION NUMBER OF BLANKS TO DISPLAY WRITE VIDEO STORAGE MFG_PORT,AL AX AH,0 INT VIDEO AX,7020H DI,DI CX,40 STOSW TEST.16 CRT INTERFACE LINES TEST DESCRIPTION SENSE ON/OFF TRANSITION OF THE VIDEO ENABLE AND MORIZONTAL SYNG LINES. AX AX AH,30H DX,03BAH E11 DX,03DAH POP PUSH CMP MOV JE MOV : GET VIDEO SENSE SWITCH INFORMATION : SAVE IT : B/W CARD ATTACHED? : SETUP ADDRESS OF B/W STATUS PORT : YES - GO TEST LINES : COLOR CARD IS ATTACHED E11: AH,8 MOV E12: SUB IN AND JNZ LOOP JMP CX,CX AL,DX AL,AH E14 E13 SHORT E17 PREAD CRT STATUS PORT CHECK VIDEO/HORIZONTAL LINE TS ON - CHECK IF IT GOES OFF LOOP UNTIL ON OR TIMEOUT GO PRINT ERROR MESSAGE E13: ``` SECTION ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST1 ---- 04/21/86 POWER ON SELF TEST (POST) 1-29 2922 0838 28 C9 2923 0838 22 C9 2924 0830 22 C4 2926 0844 7 04 2926 0842 E2 F9 2928 0844 E8 42 2930 0846 E8 1 03 2933 0848 08 1 03 2933 0848 08 1 03 2933 0848 08 1 03 2933 0846 08 1 03 2933 0846 08 1 03 2934 0846 68 00 2941 0847 68 1 03 2943 0851 BA 0000 2944 0856 67 06 007E R 0000 2944 0856 67 06 007E R 0000 2944 0856 67 06 007E R 0000 2944 0856 67 06 007E R 0000 2944 0856 68 07 2945 0857 80 23 2949 0861 E6 80 2950 0853 8E DA 2951 0856 08 07 2950 0853 8E DA 2951 0856 08 07 2952 0860 88 C7 2953 087E E8 0000 E 2954 0857 80 23 2956 0857 81 FA C800 2956 0856 08 07 2956 0857 81 FA C800 2956 0857 85 05 2956 0858 E8 0000 E 2951 0858 85 2 E14: CX,CX AL,DX AL,AH E16 E15 SHORT E17 SUB IN AND JZ LOOP JMP READ CRT STATUS PORT CHECK VIDEO/HORIZONTAL LINE ITS ON - CHECK NEXT LINE LOOP IF ON UNTIL IT GOES OFF GO ERROR BEEP E15: :---- CHECK HORIZONTAL LINE E16: CL,3 AH,CL E12 # GET NEXT BIT TO CHECK CONTINUE E18: AX AH,0 INT_VIDEO : GET VIDEO SENSE SWITCHES (AH) : SET MODE AND DISPLAY CURSOR : CALL VIDEO I/O PROCEDURE ;---- CHECK FOR THE ADVANCED VIDEO CARD ASSUME DS:ABS0 E18_1: MOV DX,0 MOV DS,DX MOV WORD PTR ФEXT_PTR+2,0 MOV DX,0C0000H ; SET DS TO VECTORS SEGMENT ; RESET SEGMENT VALUE ; FOR GRAPHIC CHARS 128 - 255 ; SET THE LOW SEGMENT VALUE AL,23H MFG PORT,AL DS,DX DI DI,0AA55H BX,BX AX,[BX] AX,DI DI E18A: MOV OUT MOV PUSH MOV SUB MOV CMP POP JNZ ◆◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 23 ◆◆ : SAVE WORK REGISTER PRESENCE SIGNATURE CLEAR POINTER GET FIRST 2 LOCATIONS PRESENT? RECOVER REGISTER NOT GO LOOK FOR OTHER MODULES CALL JMP ROM_CHECK SHORT E18C DX,0080H POINT TO NEXT 2K BLOCK ADD E18C: DX,0C800H E18A CMP JL : TOP OF VIDEO ROM AREA YET? AL,24H MFG_PORT,AL POST2 ; GO TO NEXT TEST ASSUME DS:DATA 3---- CRT ERROR SET MFG CHECKPOINT AND ERROR BEEP E17: CALL DDS POINT TO DATA 1---- CHECKPOINT OC # MONOCHROME FAILED MOV CMP JZ TEST JZ MOV CALL E19: PUSH DS MOV AX, PEQUIP_FLAG AND AL, 30H CMP AL, 30H JZ TRY_COLOR ; GET THE CURRENT VIDEO ; STRIP OTHER BITS ; IS IT MONOCHROME ? ; GO IF YES 1---- COLOR FAILED TRY MONOCHROME - CHECKPOINT OD = COLOR FAILED •MFG_ERR_FLAG,0DH ; <> CRT ERROR CHECKPOINT 0D <> <> MOV DX,386H 1 DISABLE B/W AL,1 DX,AL BX,0B000H DS,BX AX,0AA55H 1 OUTPUT THE DISABLE 1 CHECK FOR MONOCHROME VIDEO MEMORY WRITE AN AASS 8X.8X [8X].AX $+2 ALLOW BUS TO SETTLE READ THE FIRST LOCATION IS THE MONOCHROME VIDEO CARD THERE? RESTORE THE DATA SEGMENT CO IF NOT I TURN ON MONOCHROME BITS IN EQUIP FLAG ENABLE VIDEO ax,[ex] ax,0aassh ds DS E17 3 DEQUIP FLAG, 30H AX, DEQUIP_FLAG AH, AH INT VIDEO SHORT E17_1 CONTINUE :---- MONOCHROME FAILED TRY COLOR AL,01H AH,AH INT_VIDEO DX,3D8H AL,0 DX,AL BX,0B800H DS,BX AX,0AA55H BX,BX [BX],AX $+2 AX,[BY] ; SET MODE COLOR 40X25 ; DISABLE COLOR : OUTPUT THE DISABLE : CHECK FOR COLOR VIDEO MEMORY ; ALLOW BUS TO SETTLE ; READ THE FIRST LOCATION ; IS THE COLOR VIDEO CARD THERE? ; RESTORE THE DATA SEGMENT ; GO IF NOT $+2 AX,[BX] AX,0AA55H DS E17_3 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST! --- 04/21/86 POWER ON SELF TEST (POST) 1-30 04-21-86 3036 0C00 81 26 0010 R FFCF 3037 0C06 81 0E 0010 R 0010 3038 0C0C 80 01 3038 0C0C 2A E4 3040 0C10 C1 0 3041 0C12 58 3042 0C13 A1 0010 R 3043 0C13 A1 0010 R 3044 0C16 24 30 3045 0C16 24 24 30 3045 0C16 3C 30 3046 0C16 A2 C0 3047 0C16 T4 02 3048 0C16 TFE C0 3048 0C16 TFE C0 3048 0C16 TFE C0 3050 0C20 3051 0C21 3052 0C21 E9 0B4C R 3063 0C26 2B C0 3059 0C27 8E D8 3060 0C26 2B C0 3059 0C27 8E D8 3061 0C26 C7 9F 0040 R 3061 0C26 C7 9F 0040 R 3061 0C26 C7 0F 0040 R 3061 0C26 C7 0F 0040 R 3061 0C26 C7 0F 0040 R 3063 0C31 E9 0B61 R AND OR MOV SUB INT eEQUIP_FLAG,0FFCFH eEQUIP_FLAG,10H AL,01H AH,AH INT_VIDEO SET COLOR 40X24 AX AX, GEQUIP_FLAG AL, 30H AL, 3L EIT_2 AL_AX POP MOV AND CMP SUB JZ INC : IS IT THE B/W? GO IF YES INITIALIZE FOR 40X25 E17_2: PUSH E17_4: JMP JMP E18 E17_31 DS AX.AX S. AX DI. OFFSET OVIDEO INT BORD PTR [DI], OFFSET DUMMY_RETURN ; RETURN IF NO VIDEO CARD SS E18_! BYPASS REST OF VIDEO TEST PUSH SUB MOV MOV MOV POP JMP ``` ``` MANUFACTURING BOOT TEST CODE ROUTINE LOAD A BLOCK OF TEST CODE THROUGH THE KEYBOARD PORT FOR MANUFACTURING TESTS. THIS ROUTINE YILL LOAD A TEST (MAX LENGTH=FAFFH) THROUGH THE KEYBOARD CONTROL WILL BE LOADED ST LOCATION 00010500 AFTER LOADING UNITED TO THE CONTROL WILL BE TRANSFERRED TO TOO TO THE CONTROL WILL BE TRANSFERRED TO TOO THE THROUGH THE FIRST 2 BYTES TRANSFERRED AT 000010400. THIS ROUTINE ASSUMES THAT THE FIRST 2 BYTES TRANSFERRED CONTAIN THE COUNT OF BYTES TO BE LOADED (BYTE 1=COUNT LOW, BYTE 2=COUNT HI.) :---- DEGATE ADDRESS LINE 20 MFG_BOOT: MOV AH,DISABLE_BIT20 ; DEGATE COMMAND FOR ADDRESS LINE 20 CALL GATE_A20 ; ISSUE TO KEYBOARD ADAPTER AND CLI :---- SETUP HARDWARE INTERRUPT VECTOR TABLE LEVEL 0-7 AND SOFTWARE INTERRUPTS PUSH POP MOV MOV MOV MOV MFG_B1; MOVSW STOSW LOOP ; MOVE ONE ROUTINE OFFSET ADDRESS ; INSERT CODE SEGMENT VALUE ; MOVE THE NUMBER OF ENTRIES REQUIRED SETUP HARDWARE INTERRUPT VECTORS LEVEL 8-15 (VECTORS START AT INT 70 H) CX,08 ; GET VECTOR COUNT SI,OFFSET SLAVE_VECTOR TABLE DI,OFFSET $SLAVE_INT_PTR MOVSW STOSW LOOP ; MOVE ONE ROUTINE OFFSET ADDRESS ; INSERT CODE SEGMENT VALUE 1---- SET UP OTHER INTERRUPTS AS NECESSARY ASSUME DS:ABSO.ES:ABSO PUSH ES ; ES= ABSO POP DS ; SET DS TO ABSO MOV WORD PTR ONNI PTR,OFFSET NMI INT ; NMI INTERRUPT MOV WORD PTR ONTS PTR,OFFSET PRINT_SCREEN ; PRINT SCREEN MOV WORD PTR ONTS PTR.OFFSET PRINT_SCREEN ; PRINT SCREEN MOV WORD PTR ONTS PTR.OFFSET PRINT_SCREEN ; PRINT SCREEN MOV WORD PTR ONTS PTR.OFFSET PRINT_SCREEN ; PRINT SCREEN PR 3111 OCSC PG 6 COOR R OO. 3114 OCSC PG 6 COOR R OO. 3114 OCSC PG 70 60 0062 R F60 3114 OCSC PG 70 60 0062 R F60 3116 OCSC PG 70 60 0062 R F60 3117 OCSC PG 70 60 0062 R F60 3117 OCSC PG 70 60 0062 R F60 3117 OCSC PG 70 0090 R 3121 OCT6 PG 70 0090 R 3122 OCT6 PG 70 0090 R 3122 OCT6 PG 70 0090 R 3122 OCT6 PG 70 0090 R 3122 OCT6 PG 70 0090 R 3124 OCT6 PG 70 0090 R 3125 OCSC PG 70 0090 R 3126 OCT6 PG 70 0090 R 3127 OCSC PG 70 0090 R 3128 OCSC PG 70 0090 R 3129 OCSC PG 70 0090 R 3130 OCSC PG 70 0090 R 3130 OCSC PG 70 0090 R 3130 OCSC PG 70 0090 R 3130 OCSC PG 70 0090 R 3131 3140 3150 :---- ENABLE KEYBOARD PORT MOV CALL MOV OUT AL,60H C8042 AL,00001001B PORT_A,AL WRITE 8042 MEMORY LOCATION 0 I ISSUE THE COMMAND I SET INHIBIT OVERRIDE/ENABLE OBF I INTERRUPT AND NOT PC COMPATIBLE MFG B4 BH, AL MFG B4 CH, AL CL, BH GET COUNT LOW SAVE IT GET COUNT HI CALL MOV CALL MOV MOV CLD MOV CH, AL CL, BH ; CX NOW HAS COUNT ; SET DIRECTION FLAG TO INCREMENT DI, OFFSET OMFG_TEST_RIN ; SET TARGET OFFSET (DS=0000) AL, STATUS_PORT AL, OUT_BUF_FULL MFG_B3 AL, FORT_A GET 8042 STATUS PORT KEYBOARD REQUEST PENDING? LOOP TILL DATA PRESENT GET DATA STORE IT DISPLAY CHARACTER AT MFG PORT LOOP TILL ALL BYTES READ IN TEST JZ IN STOSB OUT LOOP MFG_PORT,AL MFG_B3 OMFG_TEST_RTN JMP ; FAR JUMP TO CODE THAT WAS JUST LOADED AL,STATUS_PORT AL,OUT_BUF_FULL MFG_B4 ; CHECK FOR OUTPUT BUFFER FULL ; HANG HERE IF NO DATA AVAILABLE AL,PORT_A ; GET THE COUNT IN RET POST1 ENDP ``` ``` SECTION ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES PAGE 118,121 TITLE TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES .286C .281 .LIST CODE SEGMENT BYTE PUBLIC SEGMENT BYTE PUBLIC PUBLIC C2: PUBLIC POST2 PUBLIC SHUT2 PUBLIC SHUT3 PUBLIC SHUT4 PUBLIC SHUT6 PUBLIC SHUT7 SHUT6 SHUT6 SHUT7 BLINK, INTINEAR CONGO ACTINEAR CMOSS READINEAR COMST BRITE: INEAR CONFTC BADINEAR DINEAR DINEAR DINEAR DISKESTUP: INEAR ENGISTER SETUP: INEAR ENGINEAR FOOLINEAR FOOLINEAR FOOLINEAR FOOLINEAR FOOLINEAR FOOLINEAR RED RESETI NEAR FOOLINEAR RED HEXALEAR RED HEXALEAR RED OUTH NEAR RED OUTH NEAR RED ONLECK NEAR RED OUTH NEAR STOTST ONT INEAR WALTET INEAR WALTET INEAR WALTET INEAR WALTET INEAR ELOT EXTRANA CONTRACTOR CON - INTERRUPT FAILURE - TIMER FAILURE - TIMER INTERRUPT - PROTECTIO MODE ERROR - ONA COMMAND FAILURE - ONA COMMAND FAILURE - ONA COMMAND FAILURE - ONA COMMAND FAILURE - NAIL ERROR - MEMORY SELECT ERROR - MEMORY SIZE WRONG - MEMORY SIZE WRONG - MEMORY SIZE WRONG - MEMORY DATA ERROR - KEYBOARD ERROR - KEYBOARD ERROR - KEYBOARD FLANAR ERROR - KEYBOARD FLANAR ERROR - MEYBOARD MONDCHROME ADAPTER - OCLUCK JOAPTER OLDSTEIL OLDST EXTRN E 101 I NEAR E 102 I NEAR E 103 I NEAR E 103 I NEAR E 106 I NEAR E 106 I NEAR E 106 I NEAR E 108 I NEAR E 108 I NEAR E 162 I NEAR E 164 I NEAR E 201 I NEAR E 202 I NEAR E 203 204 I NEAR E 204 I NEAR E 205 TEST. 17 8259 INTERRUPT CONTROLLER TEST BESCRIPTION READ/WRITE THE INTERRUPT MASK REGISTER (IMR) WITH ALL DNES AND ZERGES. ENABLE SYSTEM INTERRUPTS. MASK DEVICE INTERRUPTS OFF. CHECK FOR HOT INTERRUPTS (UMEAPECTED). ----- ASSUME CS:CODE,DS:DATA POST2 PROC NEAR MOV CALL CALL AL,10 PRT_HEX DDS 0000 B0 0A 0002 E8 0000 E 0005 E8 0000 E C21: LINE FEED ON DISPLAY SET DATA SEGMENT CLEAR ERROR FLAG REGISTER (BP) <=> 0 FLAGS ERROR SUB ;---- TEST THE INTERRUPT MASK REGISTER REGISTERS CLI MOV OUT OUT JMP IN MOV IN C21A: AL,0 INTA01,AL INTB01,AL $+2 AL,INTA01 AH,AL AL,INTB01 ; TURN OFF INTERRUPTS ; SET INTERRUPT MASK REGISTER TO ZERO ; SEND TO 2ND INTERRUPT CONTROLLER ALSO READ INTERRUPT MASK REGISTER SAVE RESULTS READ 2ND INTERRUPT MASK REGISTER AH, AL D6 BOTH IMR = 0? GO TO ERR ROUTINE IF NOT 0 AL,25H MFG_PORT,AL ``` **TEST2** 5-49 ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 --- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES ; DISABLE DEVICE INTERRUPTS I WRITE TO INTERRUPT MASK REGISTER I WRITE TO ZNO INTERRUPT MASK REGISTER I 1/0 DELAY I READ INTERRUPT MASK REGISTER I SAVE RESOLTS I READ ZHO INTERRUPT MASK REGISTER I READ ZHO INTERRUPT MASK REGISTER AL,OFFH INTAO1,AL INTBO1,AL $+2 AL,INTAO1 AH,AL AL,INTBO1 ADD JNZ AX.1 : ALL IMR BITS ON? :---- CHECK FOR HOT INTERRUPTS 3---- INTERRUPTS ARE MASKED OFF. CHECK THAT NO INTERRUPTS OCCUR. MOV OINTR FLAG, AL : CLEAR INTERRUPT FLAG AL,26H MFG_PORT,AL : ENABLE EXTERNAL INTERRUPTS : WAIT 100 MILLISECONDS FOR ANY : INTERRUPTS THAT OCCUR? : DID ANY INTERRUPTS OCCUR? : NO - GO TO NEXT TEST 003B FB 003C B9 19E4 003F E8 0000 E 0042 80 3E 006B R 00 0047 74 0D STI MOV CX.6628 CALL WAITF CMP GINTR_FLAG,00H JZ DT OCHECKPOINT 5 OO 0049 C6 06 0015 R 05 MOV OMFG ERR_FLAG, 05H 004E BE 0000 E 0051 E8 0000 E 0054 FA 0055 F4 MOY CALL CLI HLT SI,OFFSET E101 E_MSG HALT THE SYSTEM :---- CHECK THE CONVERTING LOGIC D7: AL,27H MFG_PORT,AL AX,0AA55H MFG PORT+2,AX AL,MFG PORT+2 AL,AH AL,MFG PORT+3 AX,85AAH DT_A MOV OUT IN XCHG IN CMP JZ WRITE A WORD GET THE FIRST BYTE SAVE IT GET THE SECOND BYTE IS IT OK? GO IF YES MOV JMP SI,OFFSET E106 : DISPLAY 106 ERROR 1---- CHECK FOR HOT NMI INTERRUPTS WITHOUT I/O-MEMORY PARITY ENABLED 006F 80 0F 0067 80 0F 0071 EA 70 0073 89 0007 0076 88 0000 E 0079 80 8F 0078 66 70 0070 80 3E 0068 R 00 0082 74 09 D7_A: AL,CMOS SHUT_DOWN CMOS PORT,AL CX.T WAITF AL,CMOS SHUT_DOWN+NMI CMOS PORT,AL eintr_FLAG,OOH D7_C : DID ANY INTERRUPTS OCCUR? MOV AL,28H MFG_PORT,AL ; DISPLAY 107 ERROR SI OFFSET E107 :---- TEST THE DATA BUS TO TIMER 2 AL,29H MFG PORT,AL AL,FORT_B AH,AL AL,0FCH PORT_B,AL MOV OUT IN MOV AND OUT D7_C: PORT_B,AL AL,1011000B TIMER*2,AL $+2 AX,0AA55H TIMER*2,AL $+2 AL,AH TIMER*2,AL $+2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 AL,TIMER*2 SELECT TIM 2,LSB,MSB,BINARY,MODE 0 WRITE THE TIMER MODE REGISTER 1/0 DELAY WRITE AN AA56 WRITE THER 2 COUNT - LSB 1/0 DELAY MOV OUT JMP MOV OUT JMP IN XCHG JMP IN CMP JZ WRITE TIMER 2 COUNT - MSB I I/O DELAY I GET THE LSB I SAYE IT I I/O DELAY I GET THE MSB I BUS OK? I GO IF OK MOY JMP SI OFFSET E108 ; DISPLAY 108 ERROR TEST.18 8254 TIMER CHECKOUT DESCRIPTION VENUELY THAT THE SYSTEM TIMER (0) DOESN'T COUNT TOO FAST OR TOO SLOW. D7_D: MGV OUT CL1 MOV OUT MOV OUT MOV MASK ALL INTERRUPTS EXCEPT LEVEL 0 WRITE THE 8289 IMR SELECT TIM 0, LSB, MODE 0, BINARY WRITE TIME CONTROL MODE REGISTER SET PROGRAM LOOP COUNT AL,2AH MFG_PORT,AL AL, OFEH INTAO1, AL AL, 00010000B TIMER+3, AL CX, 2CH $+2 ; I/O DELAY ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/86 POST TESTS AND INITIALIZATION ROUTINES 0000 8A C1 0002 E6 40 0004 FB 0005 F6 06 006B R 01 AL,CL TIMER+0,AL SET TIMER O COUNT REGISTER WRITE TIMER O COUNT REGISTER ●INTR_FLAG,01H ; DID TIMER O INTERRUPT OCCUR? I CHECK TIMER OPERATION FOR SLOW TIME I WAIT FOR INTERRUPT FOR SPECIFIED TIME JNZ LOOP MOV ♦♦♦♦♦♦♦♦♦♦♦ ♦♦ TIMER CHECKPOINT (2) ♦♦ 00E3 BE 0000 E 00E6 E9 0051 R D8_A: MOV JMP SI,OFFSET E102 D6A 1 DISPLAY 102 ERROR 1 TIMER 0 INTERRUPT DID NOT OCCUR= ERROR AL,28H MFG_PORT,AL MOV OOED FA 00EE 81 OC 00F0 80 FF 00F2 E6 40 00F4 C6 06 0068 R 00 00F9 80 FE 00F8 E6 21 00F0 F8 00F6 F6 06 0068 R 01 0103 E2 F7 CLI MOV MOV OUT MOV OUT STI TEST JNZ LOOP CL.12 AL,0FFH TIMER+0,AL •INTR FLAG,0 AL,0FEH INTA01,AL ; SET PROGRAM LOOP COUNT ; WRITE TIMER 0 COUNT REGISTER RESET INTERRUPT RECEIVED FLAG eINTR_FLAG,01H DB_A D10 ; DID TIMER 0 INTERRUPT OCCUR? ; YES - TIMER COUNTING TOO FAST, ERROR ; WAIT FOR INTERRUPT FOR SPECIFIED TIME D10: WAIT FOR INTERRUP sue CX,CX 0109 B0 2C 010B E6 80 010D 010D F6 06 006B R 01 0112 75 08 0114 E2 F7 AL,2CH MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 2C ◆◆ TEST JNZ LOOP OINTR_FLAG.01H D12 D110 ; DID TIMER 0 INTERRUPT OCCUR? ; GO IF YES ; TRY AGAIN SI,OFFSET E103 D6A 0116 BE 0000 E 0119 E9 0051 R ;---- SETUP TIMER 0 TO MODE 3 D12: CLI MOV OUT MOV OUT JMP OUT JMP AL, OFFH INTAO1, AL AL, 36H TIMER+3, AL $+2 AL, 0 TIMER+0, AL ; DISABLE ALL DEVICE INTERRUPTS ; SELECT TIMER 0,LSB,MSB,MODE 3 ; WRITE TIMER MODE REGISTER ; 1/0 DELAY ; WRITE LSB TO TIMER O REGISTER : I/O DELAY ; WRITE MSB TO TIMER O REGISTER $+2 TIMER+0.AL 1---- CHECK 8042 FOR LAST COMMAND CCEPTED CX,CX AL,2DH MFG PORT,AL AL,$TATUS PORT AL,$TATUS PORT AL,1NPT_BÜF_FULL E19 D13 SUB MOV OUT IN TEST JZ LOOP ERROR EXIT (MESSAGE 105) SI,OFFSET E105 D6A 013D BE 0000 E 0140 E9 0051 R PRINT 105 ERROR TEST.19 1 ADDITIONAL READ/WRITE STORAGE TEST 1 ++++ MUST RUN IN PROTECTED MODE ++++ CALL MOV OUT DDS AL,2FH MFG_PORT,AL 014A 81 3E 0072 R 1234 0150 75 03 0152 E9 0420 R PRESET_FLAG, 1234H WARM START? GO IF NOT GO TO NEXT TEST IF WARM START :---- SET SHUTDOWN RETURN 2 MOV OUT AL,30H MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 30 ◆◆ AX,2°H+CMOS_SHUT_DOWN+NMI ; ADDRESS FOR SHUTDOWN BYTE CMOS_WRITE ; SECOND ENTRY IN SHUTDOWN TABLE 0159 B8 028F 015C E8 0000 E ENABLE PROTECTED MODE MOV MOV SP.POST_SS SS.SP SP.POST_SP ; SET STACK FOR SYSINITI 015F BC 0000 0162 8E D4 0164 BC 8000 0167 E8 0000 E CALL SYSINITI : GO ENABLE PROTECTED MODE AL,31H MFG_PORT,AL MOV OUT ◆◆◆◆◆◆◆◆◆◆ :---- SET TEMPORARY STACK PUSH BYTE PTR GDT_PTR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES ESISS_TEMP.BASE_LO WORD.0 BYTE PTR ESI(SS_TEMP.BASE_HI_BYTE),0 SI,SS_TEMP SS,SI SP,MAX_SEG_LEN-2 MOV MOV MOV MDV :---- DATA SEGMENT TO SYSTEM DATA AREA PUSH BYTE PTR RSDA_PTR POP DS ; POINT TO DATA AREA MCV OUT AL, PARITY_CHECK DMA_PAGE+6, AL ;---- PRINT 64 K BYTES OK MOV AX,64 CALL PRT_OK STARTING AMOUNT OF MEMORY OK POST 65K OK MESSAGE ;---- GET THE MEMORY SIZE DETERMINED (PREPARE BX AND DX FOR BAD CMOS) ;---- IS CMOS GOOD? MOV AL,CMOS_DIAG+NMI CALL CMOS_READ ; DETERMINE THE CONDITION OF CMOS ; GET THE CMOS STATUS AL,BAD_BAT+BAD_CKSUM ; CMOS OK? E20B0 ; GO IF YES SHORT E20C ; DEFAULT IF NOT TEST JZ JMP :---- GET THE BASE 0->640K MEMORY SIZE FROM CONFIGURATION IN CMOS AX, (CMOS B M.S.LO+NMI) *H+CMOS B M.S.HI+NMI CMOS READ ; HIGH BYTE AL, 03FM ; MASK OFF THE MANUFACTURING TEST BITS AH, AL ; SAVE HIGH BYTE CMOS READ ; LOW BYTE OF BASE MEMORY SIZE DX, AX ; IS MEMORY SIZE GREATER THAN CONFIG? EZOBI ; GO IF EQUAL 1---- SET MEMORY SIZE DETERMINE NOT EQUAL TO CONFIGURATION AX X*(CMOS_DIAG+NMI) AX X*(CMOS_DIAG+NMI) CMOS_READ AL, W MEM_SIZE AL, AR CMOS_BRITE CMOS_BRITE WRITE_UPDATED STATUS WRIT PUSH MOV CALL OR XCHG CALL POP CMP JA : IS MEMORY SIZE GREATER THAN CONFIG ? : DEFAULT TO MEMORY SIZE DETERMINED ? MOV ; SET BASE MEMORY SIZE IN TOTAL REGISTER ; SAVE IN BASE SIZE REGISTER 1---- CHECK MEMORY SIZE ABOVE 640K FROM CONFIGURATION MOV AX, (CMOS EM S_LO+NMI)*++(CMOS E M S_H1+NMI) CALL CMOS READ "- LO+NMI)*++ (CMOS E M S_H1+NMI) XCHG AH, AL CALL CMOS READ | HIGH BYTE CALL CMOS READ | LOW BYTE CALL CMOS READ | LOW BYTE LOW BYTE ABOVE C+AS | LOW BYTE CALL CMOS READ | LOW BYTE CALL CMOS READ | LOW BYTE CALL CMOS READ | LOW BYTE CALL CMOS READ | LO+NMI)*++ (LOS U M S_H1+NMI) CALL CMOS READ | HIGH BYTE CALL CMOS READ | HIGH BYTE CALL CMOS READ | LOW CMP JZ CX,AX : IS CONFIGURATION EQUAL TO DETERMINED? SET_MEM! : GO :F EQUAL ;---- SET MEMORY SIZE DETERMINE NOT EQUAL TO CONFIGURATION PUSH MOV CALL OR XCHG CALL POP SET_MEMI: CMP JA MOV SET MEM: CX,AX SET_MEM CX,AX ; IS CONFIG GREATER THAN DETERMINED? ; GO IF YES ; USE MEMORY SIZE DETERMINE IF NOT SET_MEM: ADD SEI_... E20C: CMP JB BX,CX ; SET TOTAL MEMORY SIZE DX,513 NO_640 ; CHECK IF BASE MEMORY LESS 512K ; GO IF YES MOV CALL OR XCHG CALL AX, X° (CMOS_INFO128+NMI) ; SET 640K BASE MEMORY BIT CMOS_READ : GET THE CURRENT STATUS AL, M640K : TURN 00 +640K BIT IF NOT ALREADY ON AL, AM : SAVE THE CURRENT DIAGNOSTIC STATUS (MOS_WRITE ) RESTORE THE STATUS NO_640 : MOY SHR DEC SHR WORD PTR OKB_FLAG, BX BX, 6 BX DX, 6 ; SAVE TOTAL SIZE FOR LATER TESTING ; DIVIDE BY 64 ; IST 64K ALREADY DONE ; DIVIDE BY 64 FOR BASE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 --- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES --- SAVE COUNTS IN STACK FOR BOTH MEMORY AND ADDRESSING TESTS PUSH PUSH PUSH DX BYTE PTR 64 BX PUSH PUSH PUSH DX BYTE PTR 64 BX 1---- MODIFY DESCRIPTOR TABLES PUSH BYTE PTR GDT_PTR POP ES ; MODIFY THE DESCRIPTOR TABLE :---- SET TEMPORARY ES DESCRIPTOR 64K SEGMENT LIMIT STARTING AT 000000 MOV MOV MOV ESIES_TEMP.SEG_LIMIT,MAX_SEG_LEN ESIES_TEMP.BASE_LO_WORD,O BYTE_FRE_SSI(ES_TEMP_BASE_HI_BYTE),O BYTE_FRE_SSI(ES_TEMP.DATA_ACC_RIGHTS),CPLO_DATA_ACCESS SET TEMPORARY DS DESCRIPTOR 64K SEGMENT LIMIT AT FIRST 65K BLOCK ESIDS TEMP. SEG LIMIT, MAX SEG_LEN ESIDS TEMP. BASE_LO WORD, O BYTE FTR ESI (OS_TEMP. BASE_MI_BYTE), O BYTE PTR ESI (OS_TEMP. DATA_ACC_RIGHTS), CPL0_DATA_ACCESS MOV MOV MOV 024F 26: C7 06 0060 FFFF 0256 26: C7 06 0062 0000 025D 26: C6 06 0064 00 0263 26: C6 06 0065 93 TEMPORARY SEGMENT SAVE IN DMA PAGE REGISTER FOR SECOND 65K BLOCK ; INITIALIZE VALUES TO 010000 ; HIGH BYTE OF LOW WORD OF SEGMENT ; LOW BYTE OF LOW WORD OF SEGMENT ; SET HIGH BYTE OF SEGMENT WORD ; HIGH BYTE OF SEGMENT SUB OUT OUT INC OUT AL,AL DMA_PAGE+4,AL DMA_PAGE+5,AL AL DMA_PAGE+3,AL :---- MEMORY TEST LOOP - POINT TO NEXT BLOCK OF 32K WORDS (64K) E21: PUSH POP INC INC MEMORY TEST LOOP POINT TO START OF DESCRIPTOR TABLE BYTE PTR GDT_PTR ; POINT TO DS BYTE PTR DS: (DS_TEMP.BASE_HI_BYTE) BYTE PTR DS: (ES_TEMP.BASE_HI_BYTE) 1---- CHECK FOR END OF 256K PLANAR MEMORY CMP JB BYTE PTR DS:(DS_TEMP.BASE_HI_BYTE),04H E21_0 ; GO IF STILL FIRST 256K OF BASE MEMORY MOY OUT AL,PARITY_CHECK+IO_CHECK; CHECK FOR ANY TYPE OF PARITY ERROR DMA_PAGE+5.AL ; AFTER FIRST 256K BYTE PTR DS: (DS_TEMP.BASE_HI_BYTE), OAH NEXT ; CONTINUE IF ABOVE 1 MEG CMP JA --- CHECK FOR END OF BASE MEMORY TO BE TESTED POP POP PUSH PUSH PUSH CMP JB ;---- DO ADDITIONAL STORAGE ABOVE 1 MEG MOV BYTE PTR DS:(DS TEMP.BASE_HI_BYTE),10H MOV BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),10H 1---- SAVE BASE_HI_BYTE IN DMA PAGE REGISTERS 3 NEXT: MOY AL, BYTE PTR DS: (DS_TEMP.BASE_HI_BYTE) DMA_PAGE+3,AL ; SAVE THE HIGH BYTE OF SEGMENT ; POR POSSIBLE ERROR ;---- CHECK FOR TOP OF MEMORY (FE0000) 16 MEG CMP BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),0FEH ; TOP OF MEMORY? JE KB_LOOP3 ; EXIT NEXT TEST IF DONE PUSH POP PUSH POP BYTE PTR DS_TEMP DS BYTE PTR ES_TEMP ES MOV TUO AL,31H MFG_PORT,AL MOV CALL JZ JMP CX,8000H STGTST_CNT NI E21A ; SET COUNT FOR 32K WORDS POP POP WRITE THE CURRENT SIZE FOR (ADDRESS LINE 23-17 TEST) USED LATER POINT TO BEGINNING OR A BLOCK WRITE THE CURRENT SIZE AT THE STARTING ADDRESS ADVANCE COUNT TO NEXT BLOCK SAVE TESTED MEMORY SAVE LOOP COUNT DI,DI ADD AX,64 PUSH AX PUSH CX ``` PRT\_OK ``` IBM Personal Computer MACRO Assembler Version 2.00 1-6 TEST2 ---- 01/24/86 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 RECOVER 64K BLOCK COUNT DECREMENT BLOCK COUNT FOR LOOP CONTINUE TO NEXT TEST IF DONE 02D8 51 02D9 EB 98 PUSH JMP SAYE LOOP COUNT END MAIN TEST LOOP I CLEAR MAXIMUM BLOCK COUNT I CLEAR BASE SIZE COUNT FROM STACK I ADDRESS TEST VALUES ARE IN STACK ADDRESS LINE 16-23 TEST LET FIRST PASS BE SEEN COUNT FOR 250 MS FIXED TIME DELAY ALLOW SIX DISPLAY REFRESH CYCLES MOV CX.16571 CALL WAITF 02DD 89 4088 02E0 E8 0000 E :---- INITIALIZE DS DESCRIPTOR BYTE PTR GDT_PTR ES BYTE PTR ES: (DS TEMP.BASE_HI_BYTE),0 ES:0S_TEMP.BASE_LO_WORD,0 PUSH POP MOV MOV 02E3 6A 08 02E5 07 02E6 26: C6 06 0064 00 02EC 26: C7 06 0062 0000 TEMPORARY SEGMENT SAVE IN DMA PAGE REGISTER SUB OUT OUT MOY OUT AL,AL DMA_PAGE+4,AL DMA_PAGE+5,AL AL,01H DMA_PAGE+3,AL ---- POINT TO NEXT BLOCK OF 64K 02FD 02FD B0 33 02FF E6 80 0301 26: 80 06 0064 01 MOV OUT ADD CHECK FOR END OF BASE MEMORY TO BE TESTED CMP JA BYTE PTR ES: (DS_TEMP.BASE_HI_BYTE), 0AH NEXT_A ; CONTINUE IF ABOVE I MEG CX : GET COUNT BX : GET COUNT TESTED AX : GET COUNT OF BASE MEMORY BLOCKS AX : RECOVER COUNT OF BASE MEMORY BLOCKS AX : SAVE BASE COUNT BX : SAVE TESTED COUNT CX : SAVE TOTAL COUNT BYTE PTR ES: (DS_TEMP_BASE_HI BYTE) ALL I MAX BASE COUNT NEXT_A : MAX BASE COUNT NEXT_A : MAX BASE MEMORY 030F 59 0310 5B 0311 58 0312 50 0313 53 0314 51 0315 261 38 06 0064 031A 72 06 POP POP PUSH PUSH PUSH CMP JB 1---- DO ADDITIONAL STORAGE ABOVE 1 MEG NEXT_A2: MOV NEXT_A: MOV 031C 031C 26: C6 06 0064 10 0322 0322 26: A0 0064 BYTE PTR ES: (DS_TEMP.BASE_HI_BYTE),10H AL, BYTE PTR ES: (DS_TEMP.BASE_HI_BYTE) :---- DMA PAGE REGISTERS 3 OUT DMA_PAGE+3,AL 0326 E6 84 ;---- CHECK FOR TOP OF MEMORY (FE0000) 16 MEG 0328 3C FE 032A 74 34 CMP AL, OFEH KB_LOOP_3 ; TOP OF MEMORY? ; GO NEXT TEST IF IT IS ---- SET DS REGISTER 032C 6A 60 032E 1F 032F 29 FF 0331 8B 15 0333 8B F7 0335 2B C0 0337 89 05 PUSH BYTE PTR DS_TEMP POP DS DI.DI NOV DX.DS:[DI] MOV SI.DI SUB AX.AX MOV [DI].AX POINT TO START OF BLOCK GET THE VALUE OF THIS BLOCK SET SI FOR POSSIBLE ERROR CLEAR MEMORY LOCATION --- ALLOW DISPLAY TIME COUNT FOR 102 MS FIXED TIME DELAY ALLOW FIVE DISPAY REFRESH CYCLES GET THE LOOP COUNT FRECOVER TESTED MEMORY SAVE TESTED MEMORY SAVE TESTED MEMORY DOES THE BLOCK ID MATCH GET THE BLOCK ID FOR POSSIBLE ERROR OF PRINT ERROR CX,6761 WAITF CX AX AX CX AX.DX AX.DX E21A MOV CALL POP POP PUSH PUSH CMP MOV JNZ 0339 89 1A69 033C E8 0000 E 033F 69 0340 58 0341 50 0342 51 0343 3B C2 0345 8B C2 0347 75 1E CHECK FOR CHECK PARITY 0349 E4 61 0348 24 C0 034D 75 18 AL, PORT_B AL, PARITY_ERR E21A POP POP ADD PUSH PUSH CALL POP DEC JCXZ CX AX,64 AX,64 AX CX ; EALL IF FARTH ENROR ; POP CX TO GET AX ; RECOVER TESTED MEMORY ; 644: INCREMENTS ; SAVE TESTED MEMORY ; SAVE LOOP COUNT ; DISPLAY OK MESSACE ; RECOVER 644: BLOCK COUNT ; LOOP TILL ALL MEMORY CHECKED ; CONTINUE 034F 59 0350 58 0351 05 0040 0354 50 0355 51 0356 E8 09A0 R 0359 59 035A 49 035B E3 03 PUSH JMP CX E21_A ; SAVE LOOP COUNT : CONTINUE TILL DONE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 1-7 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 PAGE :---- BACK TO REAL MODE - MEMORY TESTS DONE KB_LOOP_3: MOV AL,34H OUT MFG_PORT,AL JMP PROC_SHUTDOWN OUT MOV OUT MOV OUT XCHG OUT DMA PAGE+1,AL AL,AH DMA PAGE+2,AL AX,31 DMA PAGE+5,AL AH,AL DMA_PAGE+4,AL $ SAVE FAILING BIT PATTERN (LOW BYTE) $ SAVE HIGH BYTE GET THE FAILING OFFSET ;---- CLEAR 1/0 CHANNEL CHECK OR R/W PARITY CHECK SUB SI,SI STOSW IN AL,PORT B OUT DMA PAGE+7,AL OR AL,RAM,PAR,OFF OUT PORT B,AL AND AL,RAM,PAR,ON OUT PORT_B,AL WRITE TO FAILING BLOCK ; GET PARITY CHECK LATCHES ; SAVE FOR ERROR HANDLER ; TOGGLE 1/0-PARITY CHECK ENABLE ; TO RESET CHECKS ;---- GET THE LAST OF GOOD MEMORY POP AX POP BX POP BX SHL BX,6 SUB AX,8X JAE E211 CLEAB BLOCK COUNT GET THE LAST OF GOOD MEMORY GET BASE MEMORY COUNTER CONVERT TO MEMORY SIZE COUNTS COMPARE LAST GOOD MEMORY WITH BASE IF ABOVE OR COULL, USE REMAINDER IN CMOS_U_M_S_(H/L) :---- ELSE SET BASE MEMORY SIZE PUSH BYTE PTR RSDA_PTR ; SET THE DATA SEGMENT POP DS ; IN PROTECTED MODE ADD AX,BX MOV **MEMORY_SIZE,AX ; CONVERT BACK TO LAST WORKING MEMORY; TO INDICATE HOW MUCH MEMORY WORKING 1---- RESET 512K --> 640K OPTION IF SET 0396 B8 B3B3 0399 E8 0000 E 039C 24 7F 039E 86 C900 E 03A3 33 C0 03A3 33 C0 03A5 BB C8 03A7 BB B1 03A7 E8 0000 E 03AC AA E1 03AE BB 0000 E MOY CALL AND XCHG CALL XOR AX, X°C(CMOS_INFO128+NMI) ADDRESS OPTIONS INFORMATION BYTE CMOS READ READ THE MEMORY INFORMATION FLAG AL. NOT MEMORY INFORMATION FLAG AL. NOT MEMORY INFORMATION FLAG SET 46NC OPTION OFF MOVE TO WORK REGISTER CMOS WRITE UPDATE STATUS IF IT WAS ON AX, AX IS CLEAR VALUE FOR EXTENSION MEMORY E211: MOV CX.AX ; SAVE ADJUSTED MEMORY SIZE CALL CMOS WRITE ; SAVE ADJUSTED MEMORY SIZE CALL CMOS WRITE ; SAVE HE HIGH BYTE MEMORY SIZE 1 SAVE THE HIGH BYTE MEMORY SIZE 1 DO THE LOW BYTE 1 DO THE LOW BYTE 1 WRITE IT ;---- SET SHUTDOWN 3 MOV AX,3"H+CMOS_SHUT_DOWN+NMI ; ADDRESS FOR SHUTDOWN RETURN CALL CMOS_WRITE ; SET RETURN 3 ;---- SHUTDOWN JMP PROC_SHUTDOWN ``` ``` MEMORY ERROR REPORTING (R/W/ MEMORY OR PARITY ERRORS) DESCRIPTION FOR ERRORS 201 (CMP ERROR OR PARITY) OR 202 (ADDRESS LINE 0-15 ERROR) *AABBCC DDEE 201* (OR 202) AABBCC DDEE 201* (OR 202) AAHIGH BYTE OF 24 BIT ADDRESS BB=MIDDLE BYTE OF 24 BIT ADDRESS CC-LOW BYTE OF 24 BIT ADDRESS DD=HIGH BYTE OF XOR FAILING BIT PATTERN EE=LOW BYTE OF XOR FAILING BIT PATTERN DESCRIPTION FOR ERROR 202 (ADDRESS LINE 00-15) A WORD OF FFFF IS WRITTEN AT THE FIRST WORD AND LAST WORD OF EACH 64K BLOCK WITH ZEROS AT ALL OTHER LOCATIONS OF THE BLOCK. A SCAN OF THE BLOCK IS MADE TO INSURE ADDRESS LINE 0-15 ARE FUNCTIONING. DESCRIPTION FOR ERROR 203 (ADDRESS LINE 16-23) AT THE LAST PASS OF THE STORAGE TEST, FOR EACH BLOCK OF 64K, THE CURRENT STORAGE SIZE (1D) IS WRITTEN AT THE FIRST WORD OF EACH BLOCK. IT IS USED TO FIND ADDRESSING FAILURES. "AABBCC DDEE 203" SAME AS ABOVE EXCEPT FOR DDEE GENERAL DESCRIPTION FOR BLOCK ID (DDEE WILL NOW CONTAINED THE ID) DD=HIGH BYTE OF BLOCK ID EE=LOW BYTE OF BLOCK ID BLOCK ID ADDRESS RANGE 0000 00000 --> 00FFFF 0040 010000 --> 01FFFF // 0200 09000 --> 09FFFF 090000 --> 09FFFF (512->576K) IF 640K BASE 100000 --> 10FFFF (1024->1088K) IF 512K BASE EXAMPLE (640K BASE MEMORY + 512K I/O MEMORY = 1152K TOTAL) NOTE: THE CORRECT BLOCK ID FOR THIS FAILURE IS 0280 MEX. DUE TO AN ADDRESS FAILURE THE BLOCK ID+128K OVERLAYED THE CORRECT BLOCK ID. IF A PARITY LATCH WAS SET THE CORRESPONDING MESSAGE WILL DISPLAY. "PARITY CHECK 1" (OR 2) DMA PAGE REGISTERS ARE USED AS TEMPORARY SAVE AREAS FOR SEGMENT DESCRIPTOR VALUES. SET REAL MODE DATA SEGMENT OMFG ERR FLAG+1, MEM_FAIL; CLEAR AND SET MANUFACTURING ERROR FLAG AL, CR PRT HEX AL, CR PRT HEX AL, DMA PAGE+3 AL, DMA PAGE+4 AL, DMA PAGE+5 AL, DMA PAGE+5 AL, DMA PAGE+5 AL, DMA PAGE+6 AL, DMA PAGE+6 AL, DMA PAGE+6 AL, DMA PAGE+7 AL, DMA PAGE+1 PAG ; ENTRY FROM PROCESSOR SHUTDOWN 3 ; SET REAL MODE DATA SEGMENT 03BC E8 0000 E 03BF C6 06 0016 R 01 03C4 80 0D 03C5 80 0D00 E 03C6 80 0000 E 03C8 80 0000 E 03C8 84 0000 E 03D0 86 0000 E 03D3 84 85 03D6 86 0000 E 03D8 86 0000 E 03D8 86 0000 E 03D8 86 0000 E 03D8 86 0000 E 03D8 86 0000 E 03D8 86 0000 E MOV MOV CALL MOV CALL IN CALL IN CALL MOV GALL IN GALL IN GALL IN CHECK FOR ADDRESS ERROR 03EC E4 80 03EE 3C 33 03F0 BE 0000 E 03F3 74 0A IN CMP MOV JZ AL,MFG_PORT AL,33H SI,OFFSET E203 ERR2 ; GET THE CHECKPOINT ; IS IT AN ADDRESS FAILURE? ; LOAD ADDRESS ERROR 16->23 ; GO 1F YES SI,OFFSET E202 AL,32H ERR2 ; LOAD ADDRESS ERROR 00->15 ; GO IF YES 03F5 BE 0000 E 03F8 3C 32 03FA 74 03 MOV CMP JZ 03FC BE 0000 E 03FF 03FF E8 0000 E 0402 E4 88 ; SETUP ADDRESS OF ERROR MESSAGE MOV SI,OFFSET E201 ERR2: CALL E_MSG AL,DMA_PAGE+7 ; PRINT ERROR MESSAGE ; GET THE PORT_B VALUE :---- DISPLAY "PARITY CHECK ?" ERROR MESSAGES AL, PARITY_CHECK TEST JZ 0404 A8 80 0406 74 0B 0408 50 0409 E8 0990 R 0400 BE 0000 E 0407 E8 0000 E 0412 58 0413 A6 40 0415 74 09 PUSH CALL MOY CALL POP ; SAVE STATUS ; INSERT BLANKS ; PLANAR ERROR, ADDRESS "PARITY CHECK 1" ; DISPLAY "PARITY CHECK 1" MESSAGE ; AND RECOVER STATUS AX PADING SI,OFFSET DI P MSG AX ; 1/0 PARITY CHECK ? ; SKIP IF CORRECT ERROR DISPLAYED TEST JZ PADING SI,OFFSET D2 P_MSG ; INSERT BLANKS ; ADDRESS OF "PARITY CHECK 2" MESSAGE ; DISPLAY "PARITY CHECK 2" ERROR 0417 E8 0990 R 041A BE 0000 E 041D E8 0000 E 0420 ; CONTINUE TESTING SYSTEM .... ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 1-9 04-21-86 PAGE :---- ENTRY FROM SHUTDOWN TEST. 20 TEST.20 ADDITIONAL PROTECTED (VIRTUAL MODE) TEST DESCRIPTION THE PROCESSOR IS PUT IN PROTECTED MODE AND THE FOLLOWING FUNCTIONS ARE VERIFIED RIPTION THE PROCESSOR IS PUT IN PROTECTED MODE AND THE POLLOWING FUNCTIONS ARE VERIFIED 1. VERIFY PROTECTED MODE THE MACHINE STATUS IS CHECK FOR VIRTUAL MODE 2. PROGRAMMED INTERRUPT TEST AN PROGRAMMED INTERRUPT 32 IS ISSUED AND AND VERIFIED 3. EXCEPTION INTERRUPT 13 TEST A DESCRIPTOR SEGMENT LIMIT IS SET TO ZERO AND A WRITE TO THAY SEGMENT IS STENDED 1. AND A WRITE TO THAY SEGMENT IS STENDED 1. LIMIT TO THAY SEGMENT IS STENDED 1. LOAD LOT REGISTER AND VERIFY CORRECT 1. LOAD LOT REGISTER AND VERIFY CORRECT 1. LOAD LOT REGISTER AND VERIFY CORRECT 1. THEY ARE VERIFIED VIA THE STORE INSTRUCTION 3. THEY ARE VERIFIED VIA THE STORE INSTRUCTION 1. ARE VERIFIED VIA THE STO AND CLD COMMANDS 1. IN PROTECTED MODE TEST (EXCEPTION INT 6) 6. SHOULD STATE AND VERIFY CORRECT 1. IN PROTECTED MODE TEST (EXCEPTION INT 6) 0. OUTSIDE THE LIMITS. CHECK THAT NO EXC INT 1. IF WITHIN LIMIT AND THAT AN EXC INT 6 1. OCCURS IF OUTSIDE THE LIMITS. 7. PUSH ALL POP ALL TEST SET GENERAL PURPOSE REGISTERS TO DIFFERENT 1. SET GENERAL FURPOSE REGISTERS TO DIFFERENT 1. CHECK THE VERRY VERRE INSTRUCTIONS 1. THE ACCESS BYTE IS SET TO READ ONLY THEN TO 1. A WRITE ONLY AND THE VERRY VERRE WISTRUCTIONS 1. THE ACCESS BYTE IS SET TO READ ONLY THEN TO 1. A WRITE ONLY AND THE VERRY VERRE WISTRUCTIONS 1. CHECK THE VERRY VERRE INSTRUCTION FUNCTIONS 2. CLUES AN INTERRUPT 13 VIA A WRITE TO A 2. SET ONLY AND THE VERRY VERRE WISTRUCTIONS 2. THE REPORT HELD OF A SELECTOR AND 2. VERIFY THE LAR INSTRUCTION FUNCTIONS 2. VERIFY THE LAR INSTRUCTION FUNCTIONS 2. LOW MEG CHIP SELECT TEST JMP POST3 1 GO TEST THE 286 0420 E9 0000 E POST3 1 GO TEST THE 286 PROTECTED MODE ;---- FAILURE ENTRY FROM A SHUTDOWN SHUT7: CALL DDS IN AL.MFG_PORT CMP AL.35H MOV SI.OFFSET E109 JZ SHUT7A: MOV SI,OFFSET E104 0423 E8 0000 E 0426 E4 80 0428 3C 35 042A BE 0000 E 042D 74 0D 042F BE 0000 E : ESTABLISH THE DATA SEGMENT PRINT ERROR 109 GO IF NOT PROTECTED MODE FAILED 0432 80 0E 0016 R 02 OR 0437 E8 0000 E 043A EB 08 043C E8 0000 E CALL E MSG JMP SHORT SHUT6 SHUT7B: CALL E_MSG 1 PRINT MESSAGE PRINT MESSAGE OMFG_ERR_FLAG+1,LMCS_FAIL; 043F 80 0E 0016 R 04 OR ♦♦♦♦♦♦♦♦♦♦♦♦♦ ♦♦ LOW MEG CHIP SELECT ♦♦ ;---- PROTECTED MODE TEST PASSED ENTRY FROM A SHUTDOWN 0444 E8 0000 E 0447 2B C0 0449 A3 0017 R 044C B9 000E 044F BA 0082 0452 0452 2A C0 0454 EE 0455 42 0456 E2 FA SHUT6: CALL SUB MOV MOV MOV DDS AX,AX WORD PTR #KB_FLAG,AX CX,OEH DX,DMA_PAGE+1 ; PROTECTED MODE TEST PASSED ; CLEAR KEYBOARD STATE FLAGS ; CLEAR PAGE REGISTERS CLR_LOOP: SUB OUT INC LOOP AL,AL DX,AL DX CLR_LOOP TEST.2! KEYBOARD TEST DESCRIPTION CODE "AA" IS RETURNED TO THE PROCESSOR, CHECK FOR STUCK KEYS. 0458 B0 35 045A E6 80 MOV AL,35H MFG_PORT,AL 0456 F6 06 0012 R 20 0461 T5 03 0462 E9 0516 R 0466 80 32 0072 R 64 0472 E6 80 0472 E6 80 0472 E6 80 0472 E6 80 0472 E7 E ; MANUFACTURING BURN IN TEST MODE? PRESET_FLAG, 1234H ; SOFT RESET? G10 BYTE PTR PRESET_FLAG, KB_OK ; CHECK FOR AA ALREADY RECEIVED G10 ; G0 IF YES ; ENABLE KEYBOARD : TRY 4 TIMES ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 1-10 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 OBF 42 G107 BH LOOP! AL,DIS_KBO C8042 AL,FORT_A AL,FORT_A AL,FORT_A AL,FORT_A AL,KYBO_CLK_DATA OBF 22 AL,FORT_A AL,KYBO_CLK G11 979 0488 E8 0000 E 980 049E 75 04 049E 80 0000 E 985 0499 E4 60 0000 E 985 0490 E4 60 0000 E 985 0490 E4 0000 E 985 0490 E4 0000 E 985 0490 E4 0000 E 985 0490 E4 0000 E 985 0490 E4 0000 E 985 0490 E4 0000 E 997 0485 E8 0000 E 997 0485 E8 0000 E 997 0485 E8 0000 E 997 0485 E8 0000 E 997 0488 000 CALL JNZ DEC JNZ MOV GALL IN CALL IN TEST JZ ; CHECK FOR OUTPUT BUFFER FULL ; GO IF BUFFER FULL : DISABLE KEYBOARD ; FLUSH ; GET THE CLOCK AND DATA LINES ; WAIT FOR OUTPUT BUFFER FULL ; GET THE RESULTS ; KEYBOARD CLOCK MUST BE LOW OR OMFG_ERR_FLAG+1,KYCLK_FAIL ; SI, OFFSET E304 SHORT F6D KBD RESET F6 AL, 37H MFG PORT, AL BU, KB_OK F6 ;---- CHECK FOR STUCK KEYS MOV AL,38H MFG_PORT,AL ◆◆ CHECKPOINT 38 ◆◆ AL ENA KBD C8042 CX 6628 WAITF AL, STATUS PORT AL, OUT BUF_FULL F7 ASSURE KEYBOARD ENABLED I ISSUE THE COMMAND COUNT FOR 100 MILLISECONDS DELAY FOR A WHILE CHECK FOR STUCK KEYS OUT BUFFER FULL! I YES - CONTINUE TESTING MOV CALL MOV CALL IN TEST JE MOY OUT AL,39H MFG_PORT,AL :---- KEYBOARD ERROR TRY TO DETERMINE IF 8042 INTERFACE IS WORKING AL, INTR FACE CK STATUS FORT, AL CX, CX BH, 05 AL, STATUS PORT AL, OUT BUFFFULL F6A BH F6B G0 CHECK RESULTS BH TRY AGAIN SHORT F6B H SHORT F6B H SHORT F6B CLI MOV OUT SUB MOV IN TEST LOOPZ JNZ DEC JNZ MOV JMP JMP JMP JZ OR F6: F6A: ; TRY AGAIN ; INDICATE PLANAR FAILURE ; (REMOVE KEYBOARD TRY AGAIN) ; GET THE RESULTS OF INTERFACE TEST ; IS THE INTERFACE OK? F6B: MOV JMP MOV F6C1 OR E_MSG PRINT MESSAGE ON SCREEN F6D: CALL ;---- INITIALIZE 8042 TO HONOR KEY LOCK F7: MOY AL,3AH MFG_PORT,AL MOV OUT CLI MOV CALL MOV OUT AL,OFFH AL,WRITE_8042_LOC C8042 AL,45H PORT_A,AL ; WRITE 8042 MEMORY COMMAND ; ISSUE THE COMMAND ; SET SYSTEM FLAG - OUTBUF INTERRUPT - ; PC I COMPATIBILITY ; RESET INHIBIT OVER RIDE ;---- DEGATE ADDRESS LINE 20 AH,DISABLE_BIT20 Gate_a20 MOV SET COMMAND IN AH ;---- SETUP HARDWARE INTERRUPT VECTOR TABLE LEVEL 0-7 SUB MOV MOV PUSH POP MOV MOV MOV INC INC LOOP AX,AX ES,AX CX,08 CS DS SI,OFFSET VECTOR TABLE DI,OFFSET ØINT_PTR GET VECTOR COUNT SETUP DS SEGMENT REGISTER F7A: SKIP OVER SEGMENT SETUP HARDWARE INTERRUPT VECTORS LEVEL 8-15 (VECTORS START AT INT 70H) ASSUME ES:ABSO SUB AX,AX MOV ES,AX MOV CX,08 PUSH CS POP DS # GET VECTOR COUNT # SETUP DS SEGMENT REGISTER ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 1-11 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 1093 054A BE 0000 E 1094 0540 BF 01C0 R 1095 0550 6551 47 1097 0552 47 1098 0553 E2 FB 1099 1100 1101 1102 1103 0555 2B CD 1104 0557 BE DB 1104 0557 BE DB MOV MOV MOVSW INC INC LOOP SI,OFFSET SLAVE VECTOR TABLE DI,OFFSET OSLAVE_INT_PTR DI DI F7A1 ; SKIP OVER SEGMENT SET UP OTHER INTERRUPTS AS NECESSARY ASSUME DISLADSO SUB AX.AX BOY DS.AX MOY BOS.AX MOY WORD PTR OFFSET NMI_INT | NMI INTERRUPT MOY WORD PTR OFFSET PRINT_SCREEN | PRINT SCREEN PRINT SCREEN | PRINT SCREEN MOY WORD PTR OFFSET PRINT SCREEN | SCR 0555 2B C0 0557 8E D8 0559 C7 06 0008 R 0000 E 055F C7 06 0014 R 0000 E 0565 C7 06 0062 R F600 1108 1109 1110 1111 056B BF 0180 1112 056E B9 0010 1113 0571 C7 05 0000 1114 0575 83 C7 02 1115 0578 E2 F7 ;---- ZERO RESERVED VECTORS MOV D1,60H*4 MOV CX,16 MOV WORD PTR DS:[D1],0 ADD D1,2 LOOP FTAZ ; FILL INTERRUPT 60 THRU 67 WITH ZERO ; CLEAR 16 WORDS F7A2: POINT TO NEXT LOCATION :---- SETUP TIMER 0 TO BLINK LED IF MANUFACTURING TEST MODE 118 119 119 119 1120 057A E8 0000 E 1121 1122 057D F6 06 0012 R 20 1123 0582 75 08 1124 0584 26; C7 06 0020 R 0000 E 1125 0588 B0 FE 1126 0585 E6 21 1127 058F F9 F9; ASSUME DS:DATA ### STABLISH DATA SEGMENT ##FG_TST,MFG_LOOP ; MFG. TEST MODE? ##FG TST,MFG_LOOP ; MFG. TEST MODE? ##FG TST,MFG_LOOP ; MFG. TEST MODE? ##FG TST,MFG_LOOP ; MFG. TEST MODE? ##FG TSTABLISH TIMER TO BLINK LED ##FG TSTABLISH TIMER TO BLINK LED ##FG TSTABLISH TIMER TO BLINK LED ##FG TSTABLISH DATA SEGMENT ## TEST JNZ MOV MOV OUT STI :---- ISSUE A RESET TO THE HARD FILE IF SOFT RESET CMP JNZ MOV MOV OUT LOOP SUB OUT TEST.23 TEST.23 DESCRIPTION DESCRIPTION OSKETTE ATTACHMENT TEST DESCRIPTION OFFICE OF IPL DISKETTE DRIVE IS ATTACHED TO SYSTEM. IF A RECALIBRATE AND SEEK COMMAND TO FOC AND CHECK STATUS. I COMPLETE SYSTEM INITIALIZATION THEN PASS CONTROL TO THE BOOT LOADER PROGRAM. 1150 1151 1152 1153 105A6 B0 3C 1154 105A B0 62 1155 05A6 B0 02 1155 05A6 B0 02 1155 05A6 B0 03T7 1157 05AF EE 1156 05A6 F0 60 0010 R 01 1159 05B7 74 55 1159 05B7 74 55 1164 05BE 1164 1165 05BE 42 1164 05C EB 00 1165 05C EB 00 1165 05C EB 00 1166 1167 05C EB 00 1168 05C EB 00 1169 05C EB 00 1169 05C EB 00 1169 05C EB 00 1169 05C EB 00 1169 05C EB 00 MOV AL,3CH MFG_PORT,AL MOV MOV OUT TEST JZ TEST JZ AL ,02H ; SET DATA RATE TO 250 K DX, AL BYTE PTR @EQUIP_FLAG, IH ; DISKETTE PRESENT? F15 @MCG_TST, MFG_LOOP ; MFG_JUMPER INSTALLED? GO IF YES 1 DISK_TEST: ; SET DATA RATE TO 250 K BITS PER SECOND F10: AL, INTAO1 $+2 AL, OBFH INTAO1, AL AH, O DL, AH 13H AH, OFFH F13 IN JMP AND OUT MOV MOV INT TEST JNZ : I/O DELAY ; ENABLE DISKETTE INTERRUPTS RESET NEC FDC ; SET FOR DRIVE 0 ; VERIFY STATUS AFTER RESET ; STATUS OK? ; NO - FDC FAILED 1169 05CA CD 13 1170 05CF C5 C4 FF 1170 05CF 75 25 1171 05CF 75 25 1172 1173 1174 1175 05D1 8A 03F2 1176 05D4 8D 1C 1176 05D5 8D 1C 1176 05D7 28 C9 1179 05D9 E5 0000 E 1180 05D2 85 01 05D3 85 01 1180 05D3 85 01 1180 05ED 72 07 1180 05ED 72 07 1180 05ED 73 07 1180 05ED 73 07 1191 05F6 80 0E 0016 R 40 1192 05F6 80 0E 0016 R 40 1192 05F6 80 0000 E 1194 05FE 80 0000 E 1194 05FE 80 0000 E 1194 05FE 80 0000 E 1195 05D3 05FB 8E 0000 E 1196 05D3 05FB 8E 0000 E 1197 05F6 8D 0E 0016 R 40 1197 05F6 8D 0E 0016 R 40 1191 05F6 8D 0E 0016 R 40 1192 0SF6 8D 0SF6 120 1200 0606 8D 05F2 1202 0608 8D 05F2 ---- TURN DRIVE 0 MOTOR ON DX,03F2H AL,1CH DX,AL CX.CX WAITF GET ADDRESS OF FDC CARD TURN MOTOR ON, ENABLE DMA, INTERRUPTS WRITE FDC CONTROL REGISTER WAITT COUNT FOR 0.988 SECONDS WAIT 1 SECOND FOR MOTOR WAITP DI,DI CH,1 **SEEK** STATUS,0 **SEEK** F13 CH,34 SEEK F14 XOR MOV MOV OR CALL JC MOV CALL JNC F13: OR OMFG_ERR_FLAG+1,DSK_FAIL MOY S1.OFFSET E601 CALL E_MSG TURN DRIVE 0 MOTOR OFF ; DRO_OFF; ; ALLOW FOR RTC WAIT ; TURN DRIVE 0 MOTOR OFF ; FDC CONTROLLER ADDRESS WRTC_WAIT_FLAG,0FEH AL,0GH DX,03F2H DX,AL AND MOV MOV OUT ``` IBM Personal Computer MACRO Assembler Version 2.00 1-12 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 ``` PAGE :---- CHECK FOR MULTIPLE DATA RATE CAPABILITY MOV IN AND CMP JZ DX,03F1H AL,DX AL,11111000B AL,01010000B J_0K3 ; D/S/P DIAGNOSTIC REGISTER ; READ D/S/P TYPE CODE ; KEEP ONLY UNIQUE CODE FOR D/S/P ; D/S/P CARD - MULTIPLE DATA RATE ? ; IF SO JUMP FIXED DISK DIAGNOSTIC REGISTER READ FIXED DISK TYPE CODE KEEP ONLY UNIQUE CODE FOR F/D FIXED DISK ADAPTER ? MUST BE COMBO ELSE ERROR MOV IN AND CMP JZ DX,05F7H AL,DX AL,11110000B AL,10100000B J_FAIL BL.OFH CX.CX DX,01F7H MOV SUB MOV : OUTER LOOP COUNT WAIT FOR BUSY OFF I HARD FILE STATUS PORT J_0K1: AL.DX AL.080H J. DK2 J. DK1 BE J. DK1 AL.0CH J. OK3 SHORT J_FAIL IN TEST JZ LOOP DEC JNZ AND JZ JMP ; GET THE STATUS ; IS THE CONTROLLER BUSY? ; IS THE CONTROLLER BUSY? ; CONTINUE IF NOT ; TRY AGAIN ; DECREMENT OUTER LOOP ; TRY AGAIN IF NOT ZERO ; BITS 2 8 3 0 0 IF MULTI DATA CAPABLE ; GO IF YES ; NO MULTIPLE DATA RATE CAPABILITY DX, IF4H AL, 055H DX, AL $+2 AL, 055H J FAIL AL, 005AH DX, AL $+2 AL, 0X AL, 0X AL, 0X AL, 0X MOY MOY JMP JMP JMP JMP JMP JMP JMP JMP ; VERIFY MULTIPLE DATA RATE CAPABLE ; WRITE TO THE CYLINDER BYTE ; I/O DELAY ; CHECK DATA WRITTEN = DATA READ GO IF NOT WRITE ANOTHER PATTERN 1/0 DELAY ; IS DATA PATTERN THE SAME? J_FAIL: OR OMFG_ERR_FLAG+1,DSK_FAIL; L; <>♦ ♦ O DISKETTE FAILED GET ADDRESS OF MESSAGE G O PRINT ERROR MESSAGE SKIP SETUP IF ERROR SI,OFFSET E601 E MSG SHORT F15C J_OK3: OR ;---- INITIALIZE FLOPPY FOR DRIVE TYPE AL,3DH MFG_PORT,AL DSKETTE_SETUP - CHECK FOR 2ND DISKETTE DRIVE DDS : INSURE DATA SEGMENT AH. #05K_STATE+1 : GET STATE OF SECOND DRIVE AH. AH : IS THERE A DRIVE 2 ATTACHED? FISC : SKIP IF NOT BYTE PTR #EQUIP_FLAG, 40H : ELSE SET SECOND DRIVE INSTALLED AH. OFFH : SET TEST MASK FOR DRIVE PRESENT CALL MOV OR JZ OR MOV F15C: MOV CALL TEST JNZ AL, CMOS DIAG+NMI ; GET THE CMOS DIAGNOSTIC STATUS CMOS_READ AL,BAD_BAT+BAD_CKSUM ROM_SCAN1 AL, AH FISD ADDRESS DISKETTE TYPE BYTE GET DISKETTE TYPES LOOK AT SECOND DRIVE TYPE DEFINED ARE BOTH INDICATORS ZERO SKIP IF NO SECOND DRIVE AND JNZ AL, AH F15D ; ARE BOTH INDICATORS NON-ZERO ; SKIP IF DRIVE FOUND AND DEFINED CONFIG_BAD ; SET BAD_CONFIG IN CMOS_DIAG INITIALIZE HARD FILE F15D: MOV OUT AL,3EH MFG_PORT,AL ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT 3E ◆◆ MOV CALL CMP JZ AL,CMOS_DISK+NMI CMOS_READ AL,OH ROM_SCANI INSURE CMOS DEFINES TYPE OF FIXED DISK : INSURE TYPE IS DEFINED : BYPASS DISK SETUP IF NOT CALL DISK SETUP : INITIALIZE HARD FILE(S) TEST.22 CHECK FOR OPTIONAL ROM FROM C800->E000 IN 2K BLOCKS (A VALID MODULE HAS '556A' IN THE FIRST 2 LOCATIONS: LENGTH INDICATOR (LENGTH-512) IN THE 3RD LOCATION : AND TEST/INIT. CODE STARTING IN THE 4TH LOCATION) : ``` 1-13 04-21-86 IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/86 POST TESTS AND INITIALIZATION ROUTINES ``` 1427 0766 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 | 1428 -- SET DMA MASK AND REQUEST REGISTERS SET IS USB OUT JMP OUT JMP OUT JMP OUT SEANCY SEANCY SUSB MOV CMP POP JNZ CALL JMP XT ROM: AL,AL DMA18+2,AL $+2 DMA18+4,AL DX,0C800H 1 SEND ZERO TO MASK REGISTER ; SEND ZERO TO REQUEST REGISTER ; SET BEGINNING ADDRESS DX, DCAUCH DS, DX D1 D1, DA65H BX, BX AX, BX AX, BX AX, D1 D1 NEXT, ROM ROM OHECK SHORT ARE_WE_DONE SAVE WORK REGISTER GET TEST PATTERN SET BEAGOOD GET 1ST WORD FROM MODULE "TO 1D WORD?" RECOVER WORK REGISTER PROCEED TO MEXT ROM IF NOT GO CHECK OUT MODULE CHECK FOR END OF ROM SPACE NEXT_ROM; ADD ARE_WE_DONE; CMP DX,0080H POINT TO NEXT 2K ADDRESS DX,0E000H ROM_SCAN2 : AT E0000 YET? : GO CHECK ANOTHER ADD. IF NOT TEST FOR KEYBOARD LOCKED CALL IN AND JZ JMP DDS AL,STATUS_PORT AL,KYBD_INH KEYI SHORT KEYIO SET DATA SEGMENT I NO - SET ERROR FLAGS AND PRINT MESSAGE GO IF OFF OMFG_ERR_FLAG+1,KEY_FAIL OR ASSUME DS:DATA MOV SI.OFFSET E302 CALL E_MSG PRINT LOCKED MESSAGE (302) KEY10: SETUP OPRINTER BASE DI.OFFSET F4 ; OFFSET OF PRINTER ADDRESS TABLE DX,CS:[DI] AL.QAAH DX;AL $2 DA,DX DX,DX DX,DX DX AL,OAAH FIT OPRINTER_BASE[SI],DX SI GET PRINTER BASE ADDRESS WRITE DATA TO PORT A I/O DELAY BUS SETTLING READ PORT A ; DATA PATTERN SAME ; NO - CHECK NEXT PRINTER CARD ; YES - STORE PRINTER BASE ADDRESS ; INCREMENT TO NEXT WORD F171 ; POINT TO NEXT BASE ADDRESS ; ALL POSSIBLE ADDRESSES CHECKED? ; PRT_BASE F16 R3232 : POINTER TO RS232 TABLE : CHECK IF RS232 CARD 1 ATTACHED ? : READ INTERRUPT ID REGISTER F191 MOV MOV ROR OR MOV :---- INSURE CMOS CLOCK HAS VALID HOURS.MINUTES.SECONDS CALL SET_TOD : INSURE CMOS CLOCK IS VALID :---- ENABLE HARDWARE INTERRUPT IF MATH PROCESSOR (80287) MOV MOV DIOFFSET PIO_ROX XOR AY, AX MOV PININI S-2 WORD PTR [DI], AX POPA AND CMF WORD PTR [DI], 00 CMF WORD PTR [DI], 00 WORD PTR [DI], 00 WORD PTR [DI], 00 WORD PTR [DI], 00 WORD PTR [DI], 00 WORD PTR [DI], 00 ADDRESS WORK STORAGE LOCATION CLEAR WORK REGISTER (AH)= 0 (NO 287) CLEAR THE WORK LOCATION INITIALIZE THE 80287 WITH NO WAIT DELAY WRITE THE CURRENT 80287 CONTROL WORD ITIME FOR 80287 TO RESPOND DI,OFFSET @IO_ROM_INIT AX,AX WORD PTR [DI],AX WORD PTR [DI],01F3FH WORD PTR [DI],0033FH NO_287 ; CLEAR UNUSED 80287 BITS ; IS THE 80287 INSTALLED? ; GO IF MATH PROCESSOR IS NOT INSTALLED ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 1541 0816 98 DO 3D 1542 0819 60 1543 081A 61 1544 0818 97 00 3D 1544 0818 157 05 888F 1545 081F 15 081 WORD PTR [DI] ; STORE THE STATUS WORD (WITH WAIT) ; TIME FOR 80287 TO RESPOND WORD PTR [DI],0888FH NO_287 IN AND MOV OUT NO_287: MOV AND CMP AL, INTBO! AL, ODFH AH, 002H INTBO!, AL GET THE SLAVE INTERRUPT MASK ENABLE 80287 INTERRUPTS SET WORK REGISTER FOR 80287 FOUND AL,BYTE PTR •EQUIP_FLAG ; GET LOW EQUIPMENT FLAG AL,002H ; STRIP OFF OTHER BITS AL,4M ; DOES CHOS MATCH HANDWARE ? OK_287 ; SKIP IF EQUIPMENT FLAG CORRECT XOR BYTE PTR **EQUIP_FLAG, 2H ; ELSE SET 80287 BIT TO CORRECT YALUE CONFIG_BAD ; AND SET THE CONFIGURATION ERROR FLAG OK_287: 1---- SET KEYBOARD STATE FLAGS MOV WORD PTR OKB_FLAG,0 ; RESET ALL KEYBOARD STATUS FLAGS ;---- ENABLE KEYBOARD/TIMER INTERRUPTS IN AND JMP TUO VOM AL, INTAO: AL, OFCH $+2 INTAO:,AL •MFG_ERR_FLAG,O ; ENABLE TIMER AND KEYBOARD INTERRUPTS; I/O DELAY ;---- READ KEYBOARD ID TO INITIALIZE KEYBOARD TYPE AND NUM LOCK STATE 1573 1574 084D C6 06 0096 R A0 1575 0852 B0 F2 1576 0854 E8 0000 E 1577 0857 B9 067A 1578 085A E8 0000 E 1579 085D 80 26 0096 R IF :---- CHECK FOR SECOND FIXED DISK PRESENT BUT NOT DEFINED ; CHECK FOR TWO DRIVES DEFINED BY CMOS ; SKIP TEST IF TWO DRIVES DEFINED AH.010H DL.081H HHF_NUM 13H HHF_NUM F16G GET TEST DRIVE READY COMMAND POINT TO SECOND FIXED DISK TELL BIOS IT HAS TWO DRIVES CHECK READY THROUGH BIOS RESTORE CORRECT COUNT (RETAIN CY) SKIP IF SECOND DRIVE NOT DEFINED SET CONFIGURATION BAD CALL CONFIG_BAD TEST FOR ANY ERRORS (8P NOT ZERO) 1 8P.8P F15A_0 ; CHECK (BP) = NON-ZERO (ERROR HAPPENED) ; SKIP PAUSE IF NO ERROR CMP BYTE PTR PRESET_FLAG,64H; MFG RUN IN MODE? MOV DX,2 JZ SHORT BEEP COUNT FOR ERROR(S) JNZ RR_BAIT ; GO IP NOT ---- MFG RUN IN MODE -> SET ERROR FLAG MOV IN AND JNZ OX,5 ERR_WAITI CALL MOV CALL TEST JZ ERR BEEP AL, CMOS DIAG CMOS READ AL, BAD CONFIG ERR_WKEY BEEPS FOR ERROR(S) ADDRESS COME GET THE DIAGNOSTIC STATUS BYTE CHECK FOR BAD HARDWARE CONFIGURATION SKIP IF NOT SET 1619 08A2 74 0C 1620 08A4 F7 C5 8000 1621 08A4 F7 C5 8000 1622 08A8 F5 06 1623 08A0 BE 0000 E 1624 08A0 BE 0000 E 1625 08A0 BE 0000 E 1626 08A0 BE 0000 E 1627 1628 1629 08B0 E4 64 1631 0882 24 10 1632 0884 F5 06 BP,08000H ERR_WKEY TEST JNZ ; ELSE CHECK FOR E161/E162 POSTED ; SKIP IF DISPLAYED BEFORE NOW SI,OFFSET E162 P_MSG 1---- CHECK FOR "UNLOCK SYSTEM UNIT KEYLOCK" MESSAGE REQUIRED ERR_WKEY: IN AL,STATUS_PORT AND AL,KYBD IÑH JNZ ERR_WAIT2 # CHECK IF RESUME MESSAGE NEEDED # IS THE KEYBOARD LOCKED # SKIP LOCK MESSAGE IF NOT 1633 1634 08B6 BE 0000 E 1635 08B9 E8 0000 E 1636 MOV SI,OFFSET F3D1 CALL P_MSG ; ERROR MESSAGE FOR KEYBOARD LOCKED 1835 0887 E8 0000 E 1836 1837 088C 1840 088C BE 0000 E 1841 088F E8 0000 E 1842 1844 088F E8 0000 E 1843 1844 0866 E8 000 1844 0866 BB 000 1844 0866 BB 000 1844 0866 BB 000 1845 0866 BB 000 1850 0866 BB 000 1850 0866 BB 000 1850 0866 BB 000 1851 0868 BB 000 1852 0868 BB 000 1853 0869 080 FF 388 :---- DISPLAY '(RESUME = "F(" KEY)' FOR ERRORS ERR_WAIT2: MOV SI,OFFSET F3D CALL P_MSG :---- INITIALIZE PRINTER (ALTERNATE DISPLAY DEVICE) MOV SUB INT ERR_WAITI: MOV OUT MOV INT CMP AH, I DX,DX 17H AL,3FH MFG PORT,AL AH, TO 16H AH,3BH ERR_WAIT1 FIRST PRINTER ; WAIT FOR 'FI' KEY ``` ``` 1655 08D5 1656 08D5 F6 06 0012 R 20 1657 08DA 75 03 1658 08DC E9 0000 E 1659 08DF 80 3E 0072 R 64 1660 08E4 74 06 •MFG_TST,MFG_LOOP ; MFG BURN IN MODE F15A ; GO IF NOT START | I GO LOOP POST BYTE PTR •RESET_FLAG,64H; MFG RUN IN? F15B ; SPYASS BEEP IF YES 1660 08E4 74 06 1661 08E9 E8 0000 E 1662 08E9 E8 0000 E 1663 08E9 E8 0000 E 1666 08EC E8 0000 E 1666 1667 1670 1671 08EF 2A E4 1673 08EF A0 0049 R 1674 08F4 CD 10 1675 1676 08F6 B9 01F4 1677 08F6 B9 01F4 1677 08F6 B9 01F4 1679 08F9 BF DOA0 1680 08FC 2B CO 1681 08F8 EC 1682 09F8 EC CO 1683 09F8 EC CO 1684 09F8 EC CO 1685 C : 1 SHORT BEEP (NO ERRORS) F15B: CALL SET_TOD :---- CLEAR DISPLAY SCREEN AH, AH AL, OCRT_MODE 10H CLEAR DESCRIPTOR TABLES F201 MOV MOV SUB MOV F20_A1 MOV ADD LOOP CX,0500 DI,5YS_IDT_LOC AX,AX ES,AX ES:[DI],AX DI,2 F20_A : CLEAR IK : POINT ES TO START OF DESCRIPTORS CLEAR POINT TO NEXT LOCATION CONTINUE TILL DONE -- SET POST SYSTEM STACK AX,ABS0 SS,AX SP,OFFSET @TOS :---- ENSURE THAT MASTER LEVEL 2 ENABLED IN AND JMP OUT AL, INTAO1 AL, OFBH $+2 INTAO1, AL # GET THE CURRENT MASK : 1/0 DELAY ;---- TEST FOR MFG RUN-IN TEST 0918 80 3E 0072 R 64 091D 75 02 091F EB 5C BYTE PTR PRESET_FLAG, 64H; IS THE THE MFG RUN-IN TEST? END 287 ; GO IF NOT SHORT SHUT4 ; BOOT LOAD IF YES CMP JNZ JMP ; BOOT LOAD : ;---- UNMASK SLAYE HARDWARE INTERRUPT 9 (LEVEL 71) END_287; ... IN AND JMP OUT AL, INTBOI AL, OFDH $+2 INTBOI, AL # GET THE CURRENT MASK TEST FOR SYSTEM CODE AT SEGMENT E000:0 FIRST WORD = AA55H LAST BYTE = CHECKSUM ENTRY POINT = FIRST BYTE + 3 IF TEST IS SUCCESSFUL A CALL FAR TO THE ENTRY POINT IS EXECUTED 718 1719 0929 B0 41 1720 0928 E6 80 MOV AL,CMOS_SHUT_DOWN+NMI ; INSURE NMI OFF AND CMOS AT DEFAULT CMOS_PORT,AL ENDIF BYTE PTR ORESET_FLAG, 0 ; CLEAR FLAG AX, 0E000M ; SEGMENT OF SYSTEM CODE ES, AX D1, D1 ; CHECK FOR AA55 BX ; SYSTEM CODE EX AX, 0AA55H ; SAYE FLAGS MOV MOV SUB MOV PUSH POP CMP PUSHF MOV IN OR OUT AND OUT POPF JNZ ES:[DI].AX AL,PORT B AL,RAM_PAR_OFF PORT B,AL AL,RAM_PAR_ON PORT_B,AL : SAVE FLAGS : CLEAR POSSIBLE PARITY CHECK ; TOGGLE 1/0-PARITY CHECK ENABLES RESTORE FLAGS SHUT4 ---- CHECKSUM SYSTEM CODE PUSH PUSH POP SUB CALL POP JNZ : SET SEGMENT TO TEST ; STARTING OFFSET ---- ENABLE NMI AND 1/0-MEMORY PARITY CHECKS MOV OUT AL, CMOS_SHUT_DOWN CMOS_PORT, AL ; ENABLE NMI AND SET DEFAULT ADDRESS IN AND OUT ; ENABLE PARITY ; ENABLE MEMORY PARITY CHECK / 1/0 CHECK 1763 1764 096B C7 06 0067 R 0003 1765 0971 8C 06 0069 R 1766 1767 0975 B0 42 1768 0977 E6 80 ; SET THE OFFSET ; SET THE SEGMENT ●10_ROM_INIT,0003H ●10_ROM_SEG,ES ``` AL,42H MFG\_PORT,AL IBM Personal Computer MACRO Assembler Version 2.00 TEST2 ---- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES ``` IBM Personal Computer MACRO Assembler Version 2.00 1-17 TEST2 --- 01/24/85 POST TESTS AND INITIALIZATION ROUTINES 04-21-86 ---- EXIT TO SYSTEM CODE CALL DWORD PTR *IO_ROM_INIT : GD TO SYSTEM CODE : VIA CALL THROUGH DATA AREA LOCATION ;----- ENABLE NMI INTERRUPTS + ENTRY FROM SHUTDOWN WITH BOOT REQUEST SHUT4: MOV CALL IN AND OUT AL,CMOS_SHUT_DOWN CMOS_READ 1 OPEN STANDBY LATCH 1.FÖRT 8 AL,RMF8RO 1 ENABLE PARITY 1 ENABLE MEMORY PARITY CHECK / 1/0 CHECK MOV OUT STI AL,43H MFG_PORT,AL 1NT ; GO TO BOOT LOADER HLT PADING PROC INSERT PADDING PAD1: MOV CALL LOOP MOV CALL RET PADING ENDP AL, PRT_HEX PADT AL, '-' PRT_HEX ; GET FILL SPACE ; WRITE A SPACE ; LOOP TILL INSERT DONE ; GET DASH CHARACTER ; WRITE TO DISPLAY NEAR AX BX,10 PRINT "00000 KB OK" SAVE WORK REGISTER SET DECIMAL CONVERT PRT_OK PROC PUSH MOV MOV SUB PRT_DIV: ;---- CONVERT AND SAVE CX,5 ; OF 5 NIBBLES XX,XXX KB ; DISPLAY REGEN BUFFER POSITION XOR DX,DX DIV BX OR DL,30H PUSH DX LOOP PRT_DIV : DIVIDE BY 10 : MAKE INTO ASCII : SAVE AX ; RECOVER A NUMBER PROT_PRT_HEX ; POINT TO DISPLAY REGEN BUFFER PRT_DEC CX, DFFSET F3B_PAD-OFFSET F3B ; LOAD MESSAGE LENGTH S1, OFFSET F3B ; POINT TO PRINT 'KB OK',' ' MESSAGE SI PROT_PRT_HEX DI PRT_LOOP AX : INCREMENT BUFF PTR ; RECOVER WORK REGISTERS OK MESSAGE PRINTER TABLE : F4 DW 03BCH DW 03T8H DW 0278H F4E LABEL WORD ; ADDRESS OF MONOCHROME PARALLEL ADAPTER ; BASE ADDRESS STANDARD PARALLEL ADAPTER ; ADDRESS OF ALTERNATE PARALLEL ADAPTER POST2 ENDP CODE ENDS ``` ``` PAGE 118,121 TITLE TESTS ---- 06/10/85 POST EXCEPTION INTERRUPT TESTS .288C | 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| TEST.20 ADDITIONAL PROTECTED (VIRTUAL MODE) TEST DESCRIPTION THE PROCESSOR IS PUT IN PROTECTED MODE AND THE FOLLOWING FUNCTIONS ARE VERIFIED RIPTION THE PROCESSOR IS PUT IN PROTECTED MODE AND THE PROCESSOR IS PUT IN PROTECTED MODE THE MACHINE FUNCTIONS ARE VERIFIED 1. VERIFY PROTECTED MODE THE MACHINE STATUS IS CHECK FOR VIRTUAL MODE 2. PROGRAMMED INTERRUPT 32 IS ISSUED AND AND VERIFIED 3. EXCEPTION INTERRUPT 32 IS ISSUED AND AND VERIFIED 3. EXCEPTION INTERRUPT 33 TEST A DESORIPTOR SEGMENT LIMIT IS SET TO ZERO AND A WRITTET OF THAT SEGMENT IS ATTEMPTED AND A WRITTET OF THAT SEGMENT IS ATTEMPTED LOAD LOT REGISTER AND VERIFY CORRECT LOAD LOT REGISTER AND VERIFY CORRECT LOAD TASK REGISTER AND VERIFY CORRECT THEY ARE VERIFIED VIA THE STORE INSTRUCTION ARE VERIFIED VIA THE STO AND CLD COMMANDS IN PROTECTED MODE TEST EXCEPTION INT 8) CHEATE A SIGNED ARRAY INDEX WITHIN AND OUTSIDE THE LIMITS. CHECK THAT NO EXC INT IF WITHIN LIMIT AND THAT AN EXC INT 6 COCCURS IF OUTSIDE THE LIMITS. 7. PUSH ALL POP ALL TEST SET GENERAL PURPOSE REGISTERS TO DIFFERENT SET GENERAL PURPOSE REGISTERS TO DIFFERENT IS SET GENERAL PURPOSE REGISTERS TO DIFFERENT IS SET GENERAL PURPOSE REGISTERS TO DIFFERENT IS SET GENERAL PURPOSE REGISTERS ISSUE A POP ALL AND VERIFY CORRECT THE ANCESS BYTE IS SET TO READ ONLY THEN TO A WRITE ONLY AND THE VERRY VERW INSTRUCTIONS THE ACCESS BYTE IS SET TO READ ONLY THEN TO A WRITE ONLY AND THE VERRY VERW INSTRUCTIONS SET THE REF. FIELD OF A SELECTOR AND VERIFY THE ARRAY INSTRUCTION FUNCTIONS SET THE REF. FIELD OF A SELECTOR FILE SET CORRECTLY. 11. VERIFY THE LAR INSTRUCTION FUNCTIONS 12. VERIFY THE LAR INSTRUCTION FUNCTIONS 13. LOW MEC CHIP SELECT TEST SECGMENT BYTE PUBLIC PUBLIC POSTS EXTRN CMOS WRITE:NEAR EXTRN DDS:NEAR EXTRN PROC SHUTDOWN:NEAR EXTRN SYSINITI:NEAR ASSUME CS:CODE PROC CALL DDS MOY AL.OFOH OUT MFG_PORT.AL POST3 --- SET SHUTDOWN RETURN 7 MOV AX,7°H+CMOS_SHUT_DOWN+NMI : ADDRESS FOR SHUTDOWN BYTE CALL CMOS WRITE : SET ERROR EXIT (DOUBLE EXCEPTION?) 0007 B8 078F 000A E8 0000 E :---- ENABLE PROTECTED MODE MOV MOV CALL SP.POST_SS SS.SP SP.POST_SP SYSINITT SET STACK FOR SYSINITI ; GO ENABLE PROTECTED MODE ---- SET TEMPORARY STACK AX,GDT_PTR ES,AX DS,AX DS,AX ES;AS TEMP-BASE_LO WORD,0 BYTE PTR ES:(SS_TEMP.BASE_HI_BYTE),0 SI,SS TEMP SS,SI SP,MAX_SEG_LEN-2 0018 B8 0008 0018 BE C0 001D BE D8 001F Z6: C7 06 005A 0000 002C 26: C6 06 005C 00 002C BE 0058 002F BE D6 MOV MOV MOV MOV MOV MOV MOV 1---- VERIFY PROTECTED MODE SMSW DB TEST JNZ JMP AX 00FH,001H,0E0H AX,VIRTUAL_ENABLE T7 1 ERROR_EXIT 0034 OF 01 E0 0037 A9 0001 003A 75 03 003C E9 02CD R ARE WE IN PROTECTED MODE ERROR IF NOT 003F B0 F1 0041 E6 80 T7_1: MOV OUT AL,OFIH MFG_PORT,AL INT MOV OUT INT SUB LOOP1: IN AND LOOPNZ JZ JMP INTERRUPT TEST (PROGRAMMED INTERRUPT 32) AL,080H DMA_PAGE+0AH,AL 32 CX.CX AL.0MA_PAGE+0AH AL.AL LOOP! ; SET EXCEPTION FLAG ; FOR INTERRUPT 10 ; INTERRUPT ; WAIT FOR INTERRUPT 0043 B0 B0 0045 E6 8B 0047 CD 20 0049 2B C9 0048 E4 8B 004D 22 C0 004F E0 FA 0051 74 03 0053 E9 02CD R ; DID THE INTERRUPT OCCUR? T7_2 ERROR_EXIT : MISSING INTERRUPT 1---- CAUSE AN EXCEPTION INTERRUPT (GENERAL PROTECTION INTERRUPT 13D) ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST3 --- 06/10/85 POST EXCEPTION INTERRUPT TESTS 1-2 MOV MOV OUT AL,0F2H MFG_PORT,AL AL,9DH DMA_PAGE+0AH,AL 111111122223455478901234567890123456678901234667890123466789012345656878901234556789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234566789012345667890123456678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345901234567890123456789012345678901234578901234578901234578901234578012345789012 T7_2: |---- MODIFY DESCRIPTOR TABLES |---- SET TEMPORARY ES DESCRIPTOR TO SEGMENT LIMIT 005E C7 06 0048 0000 MOY DS:ES_TEMP.SEG_LIMIT,0 ; SET SEGMENT TO 0 BYTE PTR DS:(ES_TEMP.DATA_ACC_RIGHTS),CPL0_DATA_ACCESS BYTE PTR DS:(ES_TEMP.BASE_HI BYTE),01 ; DO ALL TESTS ON 2ND 64K WORD PTR DS:(ES_TEMP.BASE_LO_WORD),0 BYTE PTR ES_TEMP ; LOAD ES REGISTER ES CPLO, DATA ACCESS RIGHTS PUSH POP CAUSE AN EXCEPTION 13 INTERRUPT SUB MOY SUB IN AND LOOPNZ JZ JMP 0017 28 FF 0079 26: 88 05 007C 28 C9 007E E4 88 0080 22 C0 0082 E0 FA 0084 74 03 0086 E9 02CD R DI.DI AX.ES:[DI] CX.CX AL.DMA_PAGE+0AH AL.AL LOOP2 T7 3 ERROR_EXIT ; THIS SHOULD CAUSE AND EXCEPTION ; WAIT FOR INTERRUPT LOOP2: ; DID THE INTERRUPT OCCUR? ; CONTINUE IF INTERRUPT ; MISSING INTERRUPT VERIFY 266 LDT/SDT LTR/STR INSTRUCTIONS DESCRIPTION LOAD LDT REGISTERS WITH A DESCRIPTOR AND VERIFY CORRECT 17_31 O 286 LDT REGISTER AL.0F3H MFG PORT,AL DI,FOST_LDTR DI 00FH SYTE DX,DI SYTE FFSET CS:770000 00FH 0FFSET CS:770001 177_3: MOV OUT MOV LLDT PARTIE 770000 LABEL MOV 7700001 LABEL DB ORG ◆◆◆◆◆◆◆◆◆◆ ◆◆ CHECKPOINT F3 ◆◆ 0090 OF 0091 OF 0091 OF 0093 0091 0091 0093 REGISTER FROM THIS AREA READ AND VERIFY 286 LDT SELECTOR AX,AX AX AX OOFH OOFH AX,AX OOFH OOFFSET CS:??0002 OOOH OFFSET CS:??0003 AX,OFAH AX,POST_LDTR ERROR 0093 2B C0 CLEAR AX 0095 OF 0096 O3 C0 0098 0096 0096 0096 0098 0098 0098 Z5 00F8 0098 3D 0078 009E 75 1B WRITE TO 286 TR DI.FOST_TR DI OOPH BYTE BY,DI BYTE OFFSET CS:770004 OFFSET CS:770005 MOY LTR DB LABEL MOY LABEL ORG DB ORG 00A3 0F 00A4 00A4 8B DF 00A6 00A4 00A4 00 00A6 : REGISTER FROM THIS AREA VERIFY 286 TR REGISTERS AX, AX AXOPH OPPH OPFSET CS:?70006 OOH OPFSET CS:?70007 AX. OPFSET CS:?70007 AX. PSH AX. POST_TR ERROR SUB STR DB LABEL MOY LABEL ORG DB ORG AND CMP JNZ 00A6 2B C0 00A8 0F 00A9 00A9 0B C8 00A9 00A9 00A9 00A9 00A8 25 00AB 25 00AB 25 00AB 3D 0068 00B1 75 08 GET THE TR REGISTER 770006 770007 TEST 286 CONTROL FLAGS 0083 FD 0084 9C 0086 58 0086 58 0086 74 0089 74 008E 29 008E 74 008E 30 0061 75 0061 75 0062 FD 0062 FD 0063 58 0069 89 0064 FD 0065 58 0069 89 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 74 0066 7 STD PUSHF POP TEST JZ JMP ; SET DIRECTION FLAG FOR DECREMENT ; GET THE FLAGS AX AX,0200H T7_4 ERROR_EXIT TEST JNZ JMP AX,0400H T7_5 ERROR_EXIT , GO IF NOT SET : CLEAR DIRECTION FLAG : INSURE DIRECTION FLAG IS RESET AX AX,0400H T7_6 ERROR_EXIT ``` ``` IBM Personal Computer MACRO Assembler Yersion 2,00 TEST3 --- 06/10/85 POST EXCEPTION INTERRUPT TESTS VERIFY 286 BOUND INSTRUCTION DESCRIPTION CREATE A SIGNED ARRAY INDEX WITHIN AND OUTSIDE THE LIMITS (EXPECT INT 5) 2222224444466726901234667789012246664667889012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123466789012346678901234667890123 AL, 0F4H MFG PORT, AL BYTE PTR ES_TEMP ES T7_6: ;---- CHECK BOUND FUNCTIONS CORRECTLY 00D8 2B FF 00DA 26: CT 05 0000 00DF 26: CT 45 02 7FFF 00E5 80 95 00E7 86 8B 00E9 88 1000 00EF 86: 050 00EF 82: 050 00F1 82: FE 00F3 84: 08 00F3 84: 08 00F7 175 03 00F9 87: 0200 R DI.DI WORD PTR ES:[DI],0 SET FIRST WORD TO ZERO WORD PTR ES:[DI+2],07FFF+ ; SET SECOND TO ZERO WORD PTR ES:[DI+2],07FFF+ ; SET SECOND TO JEFFO AL.098H AL.004A AX.1000H AX.1000H AX.1000PTR ES:[DI]; SET AX WITHIN BOUNDS AX.1000PTR ES:[DI]; SET AX WITHIN BOUNDS AX.1000PTR ES:[DI]; SET AX WITHIN BOUNDS AX.1000PTR AL.00A SUB MOV MOV OUT MOV BOUND SUB LOOP IN CMP JNZ JMP ; GO IF CHECK LOW BOUND WORD CAUSES INTERRUPT 5 77_7: 00FC 28 FF 05 3FF0 00FE 261 C7 05 3FF0 00FE 261 C7 05 3FF0 0106 261 62 05 0109 E4 68 0100 3C 00 010F E0 FA 03 0111 74 03 0113 E9 02CD R SUB MOY MOY BOUND SUB DI.DI WORD PTR ES:[DI],03FF0H AX.,1000H AX.,DBURD PTR ES:[DI] XX.DBURD PTR ES:[DI] XX.DBURD PTR ES:[DI] XX.DBURD PTR ES:[DI] XX.DBURD PTR ES:[DI] XX.DBURD PTR ES:[DI] LOOPB: AL,DMA_PAGE+0AH AL,0H LOOPB T7 8 ERROR_EXIT ; GET THE RESULTS ; DID AN INTERRUPT OCCUR? ; TRY AGAIN ; CONTINUE IF INTERRUPT ; GO IF NO INTERRUPT ;---- CHECK HIGH BOUND WORD CAUSES INTERRUPT 5 T7_8: AL,95H DMA_PAGE+0AH,AL # SET FLAG FOR INTERRUPT 0116 B0 95 0118 E6 88 MOV 011A 2B FF 011C 261 C7 05 0000 0121 261 C7 45 02 0FFF 0127 8B 1000 012A 261 62 05 012A 261 62 05 012A 261 62 05 012A 261 62 05 012A 261 62 05 012F 24 8B 0131 3C 00 0133 E0 FA 0135 74 03 0137 F9 02CD R DI.DI WORD PTR ES:[DI],0 SET FIRST WORD TO 0 WORD PTR ES:[DI+2],0FFFH; SET SECOND TO 0 OFFFH AX,1000H AX,1000H PTR ES:[DI] ; WAIT FOR POSSIBLE INTERRUPT CX,CX SUB MOV MOV MOV BOUND SUB LOOPC: IN CMP LOOPNZ JZ JMP AL.DMA_PAGE+0AH AL.0H LOOPC T7_9 ERROR_EXIT GET THE RESULTS DID AN INTERRUPT OCCUR? TRY AGAIN ; GO IF NO INTERRUPT VERIFY PUSH ALL AND POP ALL INSTRUCTIONS: DESCRIPTION : SET REGISTERS TO A KNOWN VALUE AND : PUSH ALL. RESET THE REGISTERS, POP ALL AND VERIFY : AL.OF5H NFG_PORT,AL AX.01 BX.AX CX.BX CX.BX CX.DX DX.CX DX.CX DI,DX DI,DX DI,DI SI,DI SI,DI SI,BP BP,SI BP 013A B0 F5 013C E08 80 013C E08 80 0141 88 B0 0144 84 B B 0144 84 B B 0144 84 D B 0147 88 D B 0147 88 D B 0147 88 F7 0149 88 F7 0149 88 F7 0149 88 F7 0151 88 F7 0151 88 F8 0153 85 F8 0153 85 F8 0153 85 F8 0153 85 F8 0154 85 F8 0155 88 F8 0155 88 F8 0156 88 F8 0157 88 F8 0158 88 D0 0157 88 F8 0158 88 D0 0157 88 F8 0158 88 F8 0158 87 F9 0158 75 18 0168 75 18 0168 75 18 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0168 75 19 0178 75 75 14 0178 75 75 14 T7_9: ; SET CX=3 ; SET DI=5 SET SI=6 SAVE THE (BP) ERROR FLAG REGISTER SET BP=7 ; ISSUE THE PUSH ALL COMMAND ; CLEAR ALL REGISTERS AX,AX BX.AX CX,AX DX,AX DI.AX SI,AX BP,AX I GET THE REGISTERS BACK I BP SHOULD BE 7 I RESTORE (BP) ERROR FLAG REGISTER I GO IF NOT I AX SHOULD BE 1 I GO IF NOT I BX SHOULD BE 2 I GO IF NOT I CX SHOULD BE 4 I GO IF NOT I DX SHOULD BE 4 I GO IF NOT I DI SHOULD BE 5 I GO IF NOT I DI SHOULD BE 5 I GO IF NOT I SI SHOULD BE 6 I CONTINUE IF IT IS BP, AX BP OT BP ERROR EXITI AX, 01 ERROR EXITI BX, 02 ERROR EXITI CX, 03 ERROR EXITI DX, 04 ERROR EXITI D1, 05 ERROR EXITI D1, 05 ERROR EXITI S1, 06 TT_10 1---- ERROR EXIT 0188 0188 E9 02CD R ERROR_EXIT1: ``` ERROR\_EXIT ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST3 --- 06/10/85 POST EXCEPTION INTERRUPT TESTS VERIFY ACCESS RIGHTS FUNCTION CORRECTLY : DESCRIPTION SET ACCESS RIGHTS OF DESCRIPTOR TO READ ONLY. VERIFY THE VERWIVERR INSTR : ACCESS A READ ONLY WITH A WRITE AND VERIFY AN EXCEPTION INTERRUPT 13 AL,0F6H #FG FORT,AL FORT, MOV MOV MOV MOV MOV MOV 018B B0 F6 018D E6 80 018F C7 06 0048 FFFF 0195 C6 06 004C 00 019A C7 06 004A F000 01A0 B8 0048 01A3 8E C0 T7_10: INSURE ACCESS RIGHTS MAY WRITTEN DS 03EH AX OOFH BYTE BP-,AX BYTE OFFSET CS:770009 000H CFFSET CS:77000A SEGOV DB VERW DB 01A5 3E 01A6 OF 01A7 8B E8 01A9 01A7 01A7 01A7 01A7 00 01A9 01A9 75 DD DB LABEL MOY LABEL ORG OB ORG JNZ + ??0009 + ??000A + + FERROR IF SEGMENT CAN NOT WRITE SET ACCESS RIGHTS TO READ ONLY | 1---- SET AG | MOV M SET SEGMENT OVERRIDE TO START OF TABLE 0185 3E CHECK THE ACCESS RIGHTS OF ES_TEMP 0186 OF 0187 OB ES 0189 0187 0187 0187 0187 OO 0189 0189 74 CD # ERROR IF SEGMENT IS WRITEABLE AX,ES_TEMP DS_EH DS_EH AVOFH BYTE SP,AX BYTE OFFSET CS:??000F OOH OFFSET CS:??0010 ERROR_EXIT! MOV SEGOV DB VERR DB LABEL MOV 0188 B8 0048 INSURE THAT SEGMENT IS READABLE OIBE SE 01BF 0F 01C0 01C0 8B E0 01C2 01C0 01C0 00 01C2 01C2 75 C4 † 77000F 770010 MOV LABEL ORG DB ORG JNZ ; GO IF SEGMENT NOT READABLE CAUSE AN EXCEPTION 13 INTERRUPT 01C4 B0 9D 01C6 E6 8B 01C8 2B F6 01CA 26: C6 04 00 01CE 2B C9 01D0 E4 8B 01D2 22 C0 01D4 E0 FA 01D6 75 B0 MOV OUT SUB MOV SUB IN AND LOOPNZ JNZ AL,09DH DMA PAGE+0AH,AL SI,51 BYTE PTR ES:[SI],00 CX,CX AL,DMA_PAGE+0AH AL,AL LOOPD ERROR_EXIT1 SET EXCEPTION FLAG FOR INTERRUPT 13 ; WRITE A BYTE THAT SHOULD LOOPD: ; DID THE INTERRUPT OCCUR? # MISSING INTERRUPT RESTORE THE ACCESS RIGHTS BYTE BYTE PTR DS:(ES_TEMP.DATA_ACC_RIGHTS),CPL0_DATA_ACCESS 01D8 C6 06 004D 93 MOV VERIFY ADJUST RPL FIELD OF SELECTOR INSTRUCTION (ARPL) FUNCTIONS DESCRIPTION RPL FIELD OF A SELECTOR SET THE THE ZERO FLAG IS SELECTOR AND THAT THE ZERO FLAG IS SET CORRECTLY AND THAT THE SELECTOR RPL FIELD IS SET CORRECTLY 01DD B0 F7 01DF E6 80 01E1 B8 0048 01E4 BB 0060 01E7 0D 0003 NOTE BX = FIRST OPERAND SECOND OPERAND AX.BX BYTE AX.BX BYTE OFFSET CS:770011 063H OFFSET CS:770012 ERROR EXITI BL.03H BL.03H BL.03H ERROR_EXITI ARPL LABEL MOV LABEL ORG DB ORG JNZ AND CMP JNZ + 770011 + 770012 + I ISSUE THE RPL COMMAND 01EA 01EA 8B C3 01EC 01EA 01EA 63 01EC 75 9A 01EC 80 93 03 01F1 80 FB 03 01F4 75 92 CHECK THAT ACCESS RIGHTS DO NOT CHANGE BX.DS_TEMP AX.ES_TEMP BL.03H ``` NOTE BX = FIRST OPERAND AX = SECOND OPERAND ``` 18M Personal Computer MACRO Assembler Version 2.00 TEST3 ---- 06/10/85 POST EXCEPTION INTERRUPT TESTS 1-6 04-21-86 AX.BX BYTE AX.BX BYTE OFFSET CS:770013 06SH OFFSET CS:770014 ERROR_EXIT1 BL.03H BL.03H BL.03H ERROR_EXIT2 ARPL + 770013 LABEL MOY + 770014 LABEL - ORG DB - JZ AND CMP JNZ I ISSUE THE RPL COMMAND 01FF 8B C3 0201 01FF 63 0201 01FF 63 0201 0201 74 85 0203 80 E3 03 0206 80 FB 03 0209 75 2F GO IF RPL WAS NOT CHANGED STRIP UNWANTED BITS AS EXPECTED? GO IF NOT ;---- VERIFY THE LAR (LOAD ACCESS RIGHTS) INSTRUCTION 020B B0 F8 020D E6 80 ;---- SET THE DESCRIPTOR TO LEVEL 3 MOY MOY SUB BYTE PTR DS:(ES_TEMP.DATA_ACC_RIGHTS),CPL3_DATA_ACCESS BX,ES_TEMP AX,AX ; CLEAR AX 1---- GET THE CURRENT DESCRIPTORS ACCESS RIGHTS ; ISSUE THE LAR COMMAND 0219 OF 021A SB C3 021C 021A 021A 021A OZ 021C :---- INSURE THE DESCRIPTOR WAS VISIBLE JNZ ERROR_EXITE ; GO IF LAR WAS NOT CHANGED ;---- THE DESCRIPTORS ACCESS RIGHTS MUST BE 3 CMP AH, CPL3 DATA_ACCESS | AS EXPECTED? JNZ ERROR_EXIT2 | GO IF NOT 1---- VERIFY THE LSL (LOAD SEGMENT LIMITS) INSTRUCTION DSIES_TEMP.SEG_LIMIT,OAAAH ; SET SEGMENT LIMIT TO OAAI BYTE PTR DSI (ES_TEMP_DATA_ACC RIGHTS),CPU_DATA_ACCESS AX ES_TEMP ; LOAD ES REGISTER OFF BYTE BYTE BY,AX BYTE BY,AX BYTE OFFSET CS:770017 OCSH OFSET CS:770018 RO7 ; GO IF OK MOV MOV LSL DB + 770017 LABEL MOV + 770018 LABEL ORG DB ORG JZ 022D C6 06 004D 93 0232 88 0048 0235 OF 0236 0B D8 0236 0B D8 0236 03 0236 03 0238 74 03 234567890123456789012345678901234567890123456789012345678901234567890 023A ERROR_EXIT2: 023A E9 02CD R JMP ERROR_EXIT ; GO IF NOT SUCCESSFUL R07: CMP MOV MOV LL DE COMP MOV MOV LL DE COMP MOV MOV MOV MOV MOV P7901A LABEL PROPERTIES DB CORG DB ORG JNZ ERROR_EXIT ; GO IF NOT SUCCESSFUL BX.0AAAAH I INSURE CORRECT SEGMENT LIMIT DS:ES TEMP.SEG_LIMIT,08656M ;SET THE SEGMENT LIMIT TO 05555M AX.ES TEMP BX.AX GET THE DESCRIPTOR SEGMENT LIMIT OFFSET CS:?70019 003M OFFSET CS:?7001A ERROR_EXIT2 ; GO IF NOT SUCCESSFUL 024A 0F 024B 8B D8 024B 8B D8 024D 024B 03 024B 03 024D 75 EB BX.05556H ERROR_EXIT2 024F 81 FB 5555 0253 75 E5 LOW MEG CHIP SELECT TEST : TEST THAT A WRITE TO ADDRESS 180000 DOES NOT WRITE TO 800010, OR 188000 DOES NOT WRITE TO 880010 : -- SET TEMPORARY ES DESCRIPTOR 64K SEGMENT LIMIT/CPLO DATA ACCESS DS:ES TEMP.SEG LIMIT, MAX_SEG LEN BYTE FTR DS:(ES_TEMP.DATA_ACC_RIGHTS), CPLO_DATA_ACCESS MOV 025C C7 06 0048 FFFF 0262 C6 06 004D 93 ;---- START WITH SEGMENT 180000 MOV MOV PUSH POP SUB MOV BYTE PTR DS:(ES TEMP.BASE_HI_BYTE),18H DS:ES TEMP.BASE_LO_WORD,0 BYTE PTR ES_TEMP LOAD ES REGISTER ES DI,DI WORD PTR ES:[DI],0AA55H; WRITE A TEST PATTERN 0267 C6 06 004C 1B 026C C7 06 004A 0000 0272 6A 48 0274 07 0275 2B FF 0277 26: C7 05 AA55 DO FOR SEGMENT 188000 027C CT 06 004A 8000 0282 6A 48 0284 07 0285 261 CT 05 AA55 DS:ES TEMP.BASE LO WORD,8000H BYTE PTR ES_TEMP ; LOAD ES REGISTER ES WORD PTR ES:[DI],0AA55H ; WRITE A TEST PATTERN ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST3 ---- 06/10/85 POST EXCEPTION INTERRUPT TESTS 1-6 04-21-86 1---- DO FOR SEGMENT 1A0000 MOV BYTE PTR DS:(ES_TEMP.BASE_HI_BYTE),IAH MOV DS:ES_TEMP.BASE_LO_WORD,O PUSH BYTE PTR ES_TEMP POP ES MOV WORD PTR ES:[DI],0AA55H; WRITE A TEST PATTERN 028A C6 06 004C 1A 028F C7 06 004A 0000 0295 6A 48 0297 07 0298 26: C7 05 AA55 ;---- B/W VIDEO CARD PUSH BYTE PTR C_BWCRT_PTR POP DS : SET DS TO B/W DISPLAY REGEN BUFFER STORE THE WORD FROM B/W VIDEO 029D 6A 20 029F 1F 02A0 8B 05 :---- COMPATIBLE COLOR PUSH DTTR C_CCRT_PTR ; SET DS TO COMPATIBLE COLOR MEMORY DS, DS1[D1] ; GET THE WORD FROM COLOR MEMORY ;---- EGA COLOR PUSH BYTE PTR E_CCRT_PTR POP DS MOV CX,DS:[D1] ; EGA COLOR CRT POINTER LOW 64K :---- TEST FOR ERROR 02AC 50 02AD 80 35 02AF E6 80 02B1 58 00 02B1 58 0A55 02B5 74 16 02B7 18 FB AA55 02B8 74 10 02B8 18 FP AA55 02CB 17 4 0A 02CB 80 34 02CS 80 34 02CS 86 80 AX AL,36H MFG_PORT,AL AX AX,0AA55H ERROR_EXIT BX,0A355H ERROR_EXIT CX,0A356H ERROR_EXIT AL,34H MFG_PORT,AL PUSH MOV OUT POP CMP JZ CMP JZ CMP JZ MOV DUT RESTORE CHECKPOINT 34 <><> NORMAL_EXIT: MOV CALL ERROR_EXIT: JMP 02C7 02C7 B8 068F 02CA E8 0000 E 02CD 02CD E9 0000 E PROC_SHUTDOWN 02D0 POST3 ENDP 0200 CODE ENDS END ``` ``` 1BM Personal Computer MACRO Assembler Version 2.00 TEST4 ---- 06/10/85 POST AND BIOS UTILITY ROUTINES 1-1 04-21-86 PAGE 118,121 TITLE TEST4 ---- 06/10/85 POST AND BIOS UTILITY ROUTINES .286C .LIST CODE SEGMENT BYTE PUBLIC 0000 SEGMENT BYTE PUBLIC PUBLIC BEEP UBLIC BLINK INT PUBLIC BLINK INT PUBLIC BLINK INT PUBLIC BLINK INT PUBLIC BLINK INT PUBLIC DOS WATE PUBLIC DOS PUBLIC DUS PUBLIC BLINK BEEP PUBLIC BLINK BEEP PUBLIC BLINK BEEP PUBLIC BROSEST PUBLIC BROSEST PUBLIC POST4 E163:NEAR OBF_42:NEAR ROM_ERR:NEAR XMIT_8042:NEAR EXTRN EXTRN EXTRN EXTRN ASSUME CS:CODE,DS:DATA POST4: |--- CMOS_READ | READ BYTE FROM CMOS SYSTEM CLOCK CONFIGURATION TABLE CMOS TABLE ADDRESS TO BE READ BIT 7 = 0 FOR NMI ENABLED AND I FOR NMI DISABLED ON EXIT BITS 6-0 = ADDRESS OF TABLE LOCATION TO READ BITS 6-0 # ADDRESS OF INBLE LOVATION TO READ OUTPUT: (AL) YALUE AT LOCATION (AL) MOVED INTO (AL). IF BIT 7 OF (AL) WAS ON THEN NWI LEFT DISABLED. OURING THE CMOS READ BOTH NMI AND NORMAL INTERRUPTS ARE DISABLED TO PROTECT CMOS DATA INTEGRITY. THE CMOS ADDRESS REGISTER IS POINTED TO A DEFAULT VALUE AND THE INTERRUPT FLAG RESTORED TO THE ENTRY STATE ON RETURN. ONLY THE (AL) REGISTER AND THE NMI STATE IS CHANGED. READ LOCATION (AL) INTO (AL) SAVE INTERRUPT ENABLE STATUS AND FLAGS MOVE MMI BIT TO LOW POSITION FORCE MMI BIT ON IN CARRY FLAG HIGH BIT ON IN CARRY FLAG HIGH BIT ON THE STABLE NMI - OLD IN CY ADDRESS LOCATION AND DISABLE NMI 1/O DELAY READ THE REQUESTED CMOS LOCATION SAVE (AH) REGISTER VALUE AND CMOS BYTE GET ADDRESS OF DEFAULT LOCATION FUT ORIGINAL NMI MASK BIT INTO ADDRESS 1/O DELAY OPEN STANDBY LATCH RESTORE (AH) AND (AL) E CMOS BYTE **PLACE CODE SEGMENT IN STACK AND **I HANDLE POPF FOR B- LEVEL 80286 RETURN WITH FLAGS RESTORED 0000 9C 0001 DD CO 0003 F9 0004 DD DB 0006 FA 0007 E6 70 0009 90 0004 E4 71 000C 50 IE 000F B0 DB 0018 E0 0039 R PROC NEAR AL. 1 AL,1 CMOS_PORT,AL AL,CMOS_DATA AX AL,CMOS_SHUT_DOWN*2 AL,I CMOS_PORT,AL AL,CMOS_DATA AX CS CMOS_POPF 001C CMOS READ ENDP :-- CMOS_WRITE STEE BYTE TO CMOS SYSTEM CLOCK CONFIGURATION TABLE INPUT: (AL) = CMOS TABLE ADDRESS TO BE WRITTEN TO BIT 7 = 0 FOR NMI ENABLED AND I FOR NMI DISABLED ON EXIT BITS 6-0 = ADDRESS OF TABLE LOCATION TO WRITE (AM) = NEW VALUE TO BE PLACED IN THE ADDRESSED TABLE LOCATION NEW YALUE TO BE PLACED IN ITE ADDRESSED THE EXCENSIVE TO SELECT TO SELECT THE AND ADDRESS TO SELECT THE SELECT TO SELECT THE WRITE (AH) TO LOCATION (AL) SAVE INTERRUPT ENNALE STATUS AND FLAGS SAVE WORK REGISTER VALUES MOVE NHI BIT TO LOW POSITION FORCE NHI BIT ON IN CARRY FLAG HIGH BIT ON TO DISABLE NHI - OLD IN CY DISABLE INTERRUPTS ADDRESS LOCATION AND DISABLENH FLAGE IN REQUESTED CHOS LOCATION GET ADDRESS OF DEFAULT LOCATION GET ADDRESS OF DEFAULT LOCATION FUL OR IGNAL NHI MASK BIT INTO ADDRESS SET DEFAULT TO READ ONLY REGISTER PERSONE WORK REGISTERS PLACE CODE SEGMENT IN STACK AND **HANDLE POPP FOR B LEVEL 80286 001C 9C 001D 9C 001D 50 001E D0 C0 002D P9 0021 D0 D8 0022 FA 0024 E6 70 0026 B0 TE 0026 B0 TE 003C D0 D8 003C D0 D8 003C D0 D8 003C D0 D8 003C P0 D8 003D 9D 0031 E4 71 0033 58 0034 6E 0036 E5 0039 R PROC NEAR AX,1 AL,1 CMOS PORT, AL AL, AH CMOS DATA, AL AL, CMOS_SHUT_DOWN*2 AL, 1 CMOS_PORT, AL AL,CMOS_DATA AX CS CMOS_POPF ``` CMOS\_WRITE ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST4 ---- 06/10/85 POST AND BIOS UTILITY ROUTINES 1-2 04-21-86 PAGE CMOS_POPF IRET 1134 0039 CF 1156 0039 CF 116 0039 CF 116 0039 CF 116 0034 CF 117 003A 118 0034 CF 128 0042 CF 122 003F C3 123 0040 CF 123 0040 CF 123 0040 CF 124 0040 CF 136 0047 CF 141 0040 004 PROC NEAR POPF FOR LEVEL B- PARTS RETURN FAR AND RESTORE FLAGS ENDP CMOS POPF 003A 003A 2E: 8E 1E 0040 R 003F C3 NEAR DS,CS:DDSDATA ; LOAD (DS) TO DATA AREA ; PUT SEGMENT VALUE OF DATA AREA INTO DS ; RETURN TO USER WITH (DS) = DATA 0040 ---- R ; SEGMENT SELECTOR VALUE FOR DATA AREA DDS ENDP THIS SUBROUTINE WILL PRINT A MESSAGE ON THE DISPLAY ENTRY REQUIREMENTS: S1 = OFFSET(ADDRESS) OF MESSAGE BUFFER CX = MESSAGE BYTE COUNT MAXIMUM MESSAGE LENGTH IS 36 CHARACTERS BP = BIT 0=E161/E162, BIT 1=CONFIG_BAD, 2-16= FIRST MSG OFFSET E_MSG PROC TEST JNZ 0042 0042 F7 C5 3FFF 0046 75 08 NEAR BP,03FFFH E_MSG1 ; CHECK FOR NOT FIRST ERROR MESSAGE; SKIP IF NOT FIRST ERROR MESSAGE 0048 56 0049 81 E6 3FFF 0040 08 EE 004F 5E 0050 E8 0069 R 0050 E8 0069 R 0053 EE 0054 E8 003A R 0057 F6 06 0010 R 01 , SAVE MESSAGE POINTER 1 USE LOW 14 BITS OF MESSAGE OFFSET 1 AS FIRST ERROR MESSAGE FLAG 1 (BIT 0 = E161/E162, BIT I = BAD_CONFIG PUSH AND OR POP SI SI,03FFFH BP,SI SI E_MSG1: P MSG : PRINT MESSAGE DS : SAVE CALLERS (DS) DOS : POINT TO POST/BIDS DATA SEGMENT BYTE PTR @EQUIP_FLAG,01H; LOOP/HALT ON ERROR SWITCH ON ? YES - THEN GO TO MANUFACTURING HALT CALL PUSH CALL TEST JZ POP RET 0060 0060 FA 0061 A0 0015 R 0064 E6 80 0066 F4 0067 EB F7 ; MANUFACTURING LOOP MODE ERROR TRAP ; DISABLE INTERRUPTS ; RECOVER ERROR INDICATOR ; SET INTO MANUFACTURING PORT ; HALL SYSTEM ; HOT NMI TRAP _HALT: CLI MOV OUT HLT JMP AL, #MFG_ERR_FLAG MFG_PORT, AL MFG_HALT E_MSG ENDP 0069 0069 2E: 8A 04 006C 46 006D 80 006E E8 012E R 0071 58 0072 3C 0A 0074 75 F3 0076 C3 I DISPLAY STRING FROM (CS:) I PUT CHARACTER IN (AL) I POINT TO NEXT CHARACTER I SAVE PRINT CHARACTER I CALL VIDEO 10 I RECOVER PRINT CHARACTER I WAS IT LINE FEED? I NO, KEEP PRINTING STRING PROC MOV INC PUSH CALL POP CMP JNE RET NEAR AL,CS:[SI] SI AX PRT_HEX AX AL,LF P_MSG P_MSG ENDP I CHR BEEP THIS PROCEDURE WILL ISSUE LONG TONES (1-3/4 SECONDS) AND ONE OR: MORE SHORT TONES (9/32 SECOND) TO INDICATE A FAILURE ON THE : PARAME BOARD, A BAD MEMORY MODULE, OR A PROBLEM WITH THE CRT. : ENTRY PARAMETERS: OH = NUMBER OF LONG TONES TO BEEP. : OL = NUMBER OF SHORT TONES TO BEEP. ; ERR_BEEP PUSHF CL1 OR JZ 0017 9C 0018 7A 0018 7A 0019 0A F6 0018 74 IE 0010 B3 T0 001F B9 0500 0022 26 0085 R 0085 E9 C233 0086 E6 CE 0080 75 EE I SAVE FLAGS I DISABLE SYSTEM INTERRUPTS I ANY LONG ONES TO BEEP I NO, DO THE SHORT ONES I COUNTER WORK ONES I DIVISOR FOR 932 HZ I OO THE BEEP I 2/3 SECOND DELAY AFTER LONG BEEP I ANY MORE LONG BEEPS I ANY MORE LONG BEEPS I ANY MORE LONG BEEPS I COO TILL DONE DH, DH G3 MDY MDY CALL MDY CALL DEC JNZ BL,112 CX,1280 BEEP CX,49715 WAITF DH G1 DS DDS •MFG_TST,01H 008F 1E 0090 E8 003A R 0093 80 3E 0012 R 01 0098 1F 0099 74 C5 PUSH CALL CMP POP JE : SAVE DS REGISTER CONTENTS ; MANUFACTURING TEST MODE? ; RESTORE ORIGINAL CONTENTS OF (DS) ; YES - STOP BLINKING LED OMFG_ DS MFG_HALT SHORT BEEPS COUNTER FOR A SHORT BEEP (9/32) DIVISOR FOR 93 HZ DO THE SOUND 1/2 SECOND DELAY AFTER SHORT BEEP DELAY BETWEEN BEEPS DONE WITH SHORT BEEPS COUNT LOOP TILL DONE BL.18 CX,1208 BEEP CX,33144 WAITF DL G3 : 1/2 SECOND DELAY AFTER LAST BEEP HAKE IT ONE SECOND DELAY BEFORE RETURN RESTORE FLAGS TO ORIGINAL SETTINGS RETURN TO CALLER 00AD B9 8178 00B0 E8 00FB R 00B3 9D 00B4 C3 CX.33144 ``` ERR\_BEEP ENDP ``` PAGE 1 BEEP ROUTINE TO SOUND THE BEEPER USING TIMER 2 FOR TONE (AX),(BL),(CX) MODIFIED. 0.085 9C 0.085 9C 0.085 67A 0.087 80 84 0.089 84 43 0.089 85 40 0.080 84 C1 0.087 84 C1 0.087 84 C0 0.062 84 C0 0.063 84 C0 0.063 84 C0 0.063 84 C0 0.069 80 0.060 SETUP TIMER 2 SAVE INTERRUPT STATUS BLOCK INTERRUPTS OUR ING UPDATE SELECT TIMER 2,LSB, MSB, BINARY WRITE THE TIMER MODE REGISTER I/O DELAY UNISOR FOR HZ (LOW) WRITE TIMER 2 COUNT - LSB DIVISOR FOR HZ (HIGH) WRITE TIMER 2 COUNT - MSB GET CURRENT SETTING OF PORT SAVE THAT SETTING GATE TIMER 2 AND TURN SPEAKER ON AND RESTORE INTERRUPT STATUS PROC PUSHF CLI MOV JMP MOY OUT JMP MOV OUT IN MOY OR OUT POPF AL,10110110B TIMER+3,AL $+2 AL,CL TIMER+2,AL $+2 AL,CH TIMER+2,AL AL,PORT_B AH,AL AL,GATE2+SPK2 PORT_B,AL 1/64 SECOND PER COUNT (BL) DELAY COUNT FOR 1/64 OF A SECOND GO TO BEEP DELAY 1/64 COUNT (BL) LENGTH COUNT EXPIRED? NO - CONTINUE BEEPING SPEAKER G7: MOV CALL DEC JN SHF CLI IN OR AND OUT POPF CALL IN OR OUT POPF CLI IN OR OUT POPF RET 00DA 76 F6 00DA 9C 00DB 74 61 00DE 24 61 00DE 25 61 00E2 84 C4 00E4 24 FC 00E6 85 61 00E3 90 040B 00E0 E6 00FB R 00F0 FA 00F1 E4 61 00F3 24 03 00F5 0A C4 00F7 E6 61 NO - CONTINUE BEEPING SPEAKER SAVE INTERRUPT STATUS BOCK INTERRUPT STATUS ISOLATE CURRENT SPEAKER BITS IN CASE ISOLATE CURRENT SPEAKER BITS IN CASE SOMEONE TURNED THEM OFF DURING BEEP RECOVER VALUE OF PORT FORCE SPEAKER DATA AND STOP SPEAKER TIMEF AND STOP SPEAKER TIMEF FORCE 1/44 SECOND DELAY (SHORT) MINIMUM DELAY BETWEEN ALL BEEPS SAVE INTERRUPTS DURING UPDATE BLOCK SPEAKER STATUS RESTORE AL,PORT_B AL,NOT (GATE2+SPK2) AH,AL AL,AH AL,NOT (GATE2+SPK2) PORT_B,AL CX,1035 WAITF ENDP ENTRY: (CX) = COUNT OF 15.085737 MICROSECOND INTERVALS TO WAIT MEMORY REFRESH TIMER I OUTPUT USED AS REFERENCE AFTER (CX) TIME COUNT (PLUS OR MINUS 16 MICROSECONDS) ; DELAY FOR (CX)*15.085737 US ; SAVE WORK REGISTER (AM) WAITFIE IN AND CMP JE USE TIMER I OUTPUT BITS READ CURRENT COUNTER OUTPUT STATUS MASK FOR REFRESH DETERMINE BIT DID IT JUST CHANGE WAIT FOR A CHANGE IN OUTPUT LINE AL,PORT B AL,REFRESH_BIT AL,AH WAITF1 MOV LOOP AH, AL ; SAVE NEW FLAG STATE : DECREMENT HALF CYCLES TILL COUNT END 0104 8A E0 0106 E2 F4 0108 58 0109 C3 POP RET AX RESTORE (AH) 010A ENDP WAITE CONFIG_BAD PUSH MOV CALL OR XCHG CALL POP OR RET 010A 010A 50 010B 88 8E8E 010E E8 0000 R 0111 0C 20 0113 86 E0 0115 E8 001C R 0118 58 0119 81 CD 4000 011D C3 ; ADDRESS CMOS DIAGNOSTIC STATUS BYTE ; GET CURRENT VALUE ; SET BAD CONFIGURATION BIT ; SETUP FOR WRITE ; UPDATE CMOS WITH BAD CONFIGURATION ; SET CONFIGURATION BAD FLAG IN (BP) 011E CONFIG_BAD ``` 0176 PROT\_PRT\_HEX ENDF ``` PAGE |--- XPC_BYTE -- XLATE_PR -- PRT_HEX --- CONVERT AND PRINT ASCII CODE CHARACTERS AL CONTAINS NUMBER TO BE CONVERTED. AX AND BX DESTROYED. XPC_BYTE PUSH SHR CALL POP AND PROC AX AL.4 XLAT_PR AX AL,0FH I DISPLAY TWO HEX DIGITS I SAVE FOR LOW NIBBLE DISPLAY INIBBLE SWAP I DO THE HIGH NIBBLE DISPLAY I RECOVER THE NIBBLE I SOLATE TO LOW NIBBLE I FALL INTO LOW NIBBLE CONVERS 011E 011E 50 011F C0 E8 04 0122 E8 0128 R 0125 58 0126 24 0F CONVERT 00-0F TO ASCII CHARACTER ADD FIRST CONVERSION FACTOR ADJUST FOR NUMERIC AND ALPHA RANGE ADD CONVERSION AND ADJUST LOW NIBBLE ADJUST HIGH NIBBLE TO ASCII RANGE XLAT_PR PROC ADD DAA ADC DAA NEAR AL,090H AL.040H 012E 012E B4 0E 0130 B7 00 0132 CD 10 0134 C3 PRT_HEX PROC MOV MOV INT RET NEAR AH, OEH BH, O 1 OH 1 DISPLAY CHARACTER IN (AL) COMMAND ; CALL VIDEO_10 0135 0135 0135 ENDP SEGMENT VALUE TO LOOK LIKE A 21 BIT ADDRESS : CONTAIN SEGMENT VALUE TO BE PRINTED : PRT_SEG PROC MOV CALL MOV CALL MOV CALL MOV CALL RET 0135 0135 8A C6 0137 E8 011E R 013A 8A C2 013C E5 011E R 013F B0 30 0141 E5 012E R 0144 B0 20 0146 E8 012E R 0149 C3 NEAR AL,DH XPC BYTE AL,DL XPC BYTE AL,TO' PRT HEX AL,T' PRT_HEX GET MSB DISPLAY SEGMENT HIGH BYTE LSB DISPLAY SEGMENT LOW BYTE PRINT A '0' ' TO MAKE LOOK LIKE ADDRESS ADD ENDING SPACE 014A PUT A CHARACTER TO THE DISPLAY BUFFERS WHEN IN PROTECTED MODE (AL)= ASCII CHARACTER (DI)= DISPLAY REGEN BUFFER POSITION PROT_PRT_HEX PUSH PUSH SAL PROC ES DI DI,1 014A 014A 06 014B 57 014C D1 E7 : SAVE CURRENT SEGMENT REGISTERS : MULTIPLY OFFSET BY TWO ---- MONOCHROME VIDEO CARD PUSH BYTE PTR C_BWCRT_PTR POP ES STOSB DEC D1 ; GET MONOCHROME BUFFER SEGMENT SELECTOR ; SET (ES) TO B/W DISPLAY BUFFER ; PLACE CHARACTER IN BUFFER ; ADJUST POINTER BACK ENHANCED GRAPHICS ADAPTER PUSH BYTE PTR E_CCRT_PTR POP ES STOSB DEC DI PUSH BYTE PTR E_CCRT_PTR2 POP ES STOSB DEC DI 0153 6A 30 0155 07 0156 AA 0157 4F 0158 6A 38 015A 07 015B AA 015C 4F ENHANCED COLOR DISPLAY POINTER LOW 64K LOAD SEGMENT SELECTOR I PLAGE CHARACTER IN BUFFER ADJUST POINTER BACK I ENHANCED COLOR DISPLAY POINTER HI 64K LOAD SEGMENT SELECTOR I PLAGE CHARACTER IN BUFFER ADJUST POINTER BACK DI BYTE PTR E_CCRT_PTR2 ES :---- COMPATIBLE COLOR 015D 6A 28 015F 07 0160 53 0161 52 0162 51 0163 32 C9 0165 8A 03DA 0168 93 0169 EC 016A A8 09 016C E1 FB 016C E1 FB BYTE PTR C_CCRT_PTR ES BX DX CX CX,CX DX,03DAH AX,BX PUSH POP PUSH PUSH PUSH XOR MOV XCHG ; SET (DS) TO COMPATIBLE COLOR MEMORY : SAVE WORK REGISTERS : TIMEOUT LOOP FOR "BAD" HARDWARE : STATUS ADDRESS OF COLOR CARD : SAYE IN (BX) REGISTER IN TEST LOOPZ XCHG STOSB AL,DX AL,RVRT+RHRZ PROT S AX,BX ; GET COLOR CARD STATUS ; CHECK FOR VERTICAL RETRACE (OR HORZ) ; TIMEOUT LOOP TILL FOUND ; REGOVER CHARACTERS ; PLACE CHARACTER IN BUFFER 0170 59 0171 5A 0172 5B 0173 5F 0174 07 0175 C3 POP POP POP POP RET CX DX BX DI ES : RESTORE REGISTERS ``` **TEST4** 5-75 SECTION 5 ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST4 ---- 06/10/85 POST AND BIOS UTILITY ROUTINES PAGE ROM CHECKSUM SUBROUTINE : ; NUMBER OF BYTES TO ADD IS 64K 0178 0178 32 C0 017A 017A 02 07 017C 43 017D E2 FB ; ENTRY FOR OPTIONAL ROM TEST ROM_CHECKSUM_CNT: XOR AL,AL AL,[BX] BX ROM_L ; GET (DS:BX) ; POINT TO NEXT BYTE ; ADD ALL BYTES IN ROM MODULE : SUM = 07 AL, AL 0182 ROM_CHECKSUM ROM_CHECK MOV MOV SUB MOV SHL MOV SHR ADD CALL JZ CAI THIS ROUTINE CHECKSUMS OPTIONAL ROM MODULES AND IF CHECKSUM IS OK, CALLS INITIALIZATION/TEST CODE IN MODULE PROC NEAR AX,DATA ES,AX AH,AH AL,[BX+2] AX,9 CX,AX AX,4 DX,AX ROM_CHECKSUM_CNT ROM_CHECK_I 0182 B8 ---- R 0182 B8 ---- R 0185 8E C0 0187 2A E4 0189 8A 47 02 018C C1 E0 09 018F 8B C8 0191 C1 E8 04 0194 03 D0 0196 E8 0178 R 0199 74 05 ZERO OUT AH GET LENGTH INDICATOR MULTIPLY BY 512 SET COUNT SET POINTER TO NEXT MODULE 019B E8 0000 E 019E EB 13 ROM_ERR SHORT ROM_CHECK_END 01A0 01A0 52 01A1 26: C7 06 0067 R 01A8 26: 8C 1E 0067 R 01AD 26: FF 1E 0067 R 01B2 5A DX. ES:010 ROM INIT,0003H ; SAVE POINTER ES:010 ROM SEG,DS ; LOAD OFFSET DWORD PTR ES:010 ROM_INIT; CALL INITIALIZE/TEST ROUTINE DX 01B3 C3 RETURN TO CALLER ROM_CHECK 01B4 THIS PROCEDURE WILL SEND A SOFTWARE RESET TO THE KEYBOARD, SCAN CODE OASH IS DEFINED FOR MANUFACTURING TEST KBD_RESET MOV CALL JCXZ PROC NEAR AL,0FFH XMIT_8042 G13 CMP JNZ 0188 3C FA 0180 75 1F AL,KB_ACK MOV OUT MOV STI MOV SUB : ENABLE KEYBOARD INTERRUPTS : WRITE 8269 INTERRUPT MASK REGISTER : RESET INTERRUPT INDICATOR : ENABLE INTERRUPTS : TRY FOR 400 MILLISECONDS : SETUP INTERRUPT TIMEOUT COUNT BL.10 CX,CX G11: DID A KEYBOARD INTERRUPT OCCUR E YES - READ SCAN CODE RETURNED NO - LOOP TILL TIMEOUT 01D6 FE CB 01D8 75 F3 01DA 01DA E4 60 01DC 8A D8 01DE 01DE C3 DEC JNZ BL G11 : TRY AGAIN G12: READ KEYBOARD SCAN CODE : RETURN TO CALLER RET OIDF BLINK LED PROCEDURE FOR MFG RUN-IN TESTS : IF LED IS ON, TURN IT OFF. IF OFF, TURN ON. : BLINK_INT STI PUSH IN XOR OUT MOV OUT POP IRET 01DF 01DF FB 01E0 50 01E1 E4 80 01E3 E6 80 01E7 B0 20 01E7 B0 20 01E9 58 01EC CF PROC AX AL,MFG_PORT AL,0100000B MFG_PORT,AL AL,EOI INTA00,AL AX ; SAVE AX REGISTER CONTENTS ; READ CURRENT VALUE OF MFG_PORT ; FLIP CONTROL BIT ; RESTORE AX REGISTER ``` OIED BLINK\_INT 0291 CVT\_BINARY ENDP ``` THIS ROUTINE INITIALIZES THE TIMER DATA AREA IN THE ROW BIOS DATA AREA. IT IS CALLED BY THE POWER ON ROUTINES. IT CONVERTS HRIMINISC FROM CMOS TO TIMER TICS. IF CMOS IS INVALID, TIMER IS SET TO ZERO. NONE PASSED TO ROUTINE BY CALLER CMOS LOCATIONS USED FOR TIME TIMER_LOW TIMER_HIGH TIMER_OFL ALL REGISTERS UNCHANGED OUTPUT COUNTS_SEC COUNTS_MIN COUNTS_HOUR UPDATE_TIMER EQU ; TIMER DATA CONVERSION EQUATES 18 1092 : 65543 - 65536 ; RTC UPDATE IN PROCESS BIT MASK 10000000B 0 IED 0 1ED 60 0 1EE 1E 0 1EF E8 003A R 0 1F2 2B C0 0 1F4 A2 0070 R 0 1F7 A3 006C R 0 1FD B0 8E 0 1FF E8 0000 R 0 202 24 C4 SET_TOD PROC PUSHA PUSH SUB MOV MOV MOV MOV CALL AND NEAR DS DDS AX, AX AX AT MER_OFL, AL AT MER_LOW, AX AT MER_HIGH, AX AL, CMOS DIAG+MMI CMOS READ AL, BAD_BAT+BAD_CKSU ; ESTABLISH SEGMENT ; RESET TIMER ROLL OVER INDICATOR ; CHECK CMOS VALIDITY ; READ DIAGNOSTIC LOCATION IN CMOS S CLK, FALL ; BAD BATTERY, CHKSUM ERROR, CLOCK ERROR ; CMOS NOT VALID -- TIMER SET TO ZERO 0204 75 68 0206 28 C9 0208 80 8A 0208 80 80 000 R 0200 AB 80 0200 AB 80 020F E1 F7 POD_DONE JNZ SUB UIP: MOV CALL TEST LOOPZ AL, CMOS_REG_A+NMI CMOS_READ AL, UPDATE_TIMER UIP ; ACCESS REGISTER A ; READ CMOS CLOCK REGISTER A : WAIT TILL UPDATE BIT IS ON CMOS CLOCK STUCK IF TIMEOUT 0211 E3 5B 0213 2B C9 0215 0215 B0 8A 0217 E8 0000 R 021A A8 80 021C E0 F7 JCXZ SUB POD DONE UIPOFF: MOV CALL TEST LOOPNZ AL,CMOS_REG_A+NMI CMOS_READ AL,UPDATE_TIMER UIPOFF ; ACCESS REGISTER A ; READ CMOS CLOCK REGISTER A NEXT WAIT TILL END OF UPDATE 021E E3 4E JÇXZ POD_DONE : CMOS CLOCK STUCK IF TIMEOUT 0220 B0 80 0222 E8 0000 R 0225 3C 59 0227 77 48 AL, CMOS_SECONDS+NMI CMOS_READ AL, 59H TOD_ERROR TIME JUST UPDATED ACCESS SECONDS VALUE IN CMOS ARE THE SECONDS WITHIN LIMITS? GO IF NOT MOV CALL CMP JA CONVERT IT TO BINARY MOVE COUNT TO ACCUMULATION REGISTER ADJUST FOR SYSTEMATIC SECONDS ERROR CALL MOY SHR MOUL ADD MOY CALL PUSH SHR ADD MOY MUL ADD MOY MUL ADD CALL CMP JA ; COUNT FOR SECONDS ACCESS MINUTES VALUE IN CMOS ARE THE MINUTES WITHIN LIMITS? GO IF NOT: CONVERT IT TO BINARY SAVE MINUTES COUNT ADJUST FOR SYSTEMATIC MINUTES ERROR ADD ADJUSTMENT TO COUNT RECOVER BCD MINUTES VALUE ; COUNT FOR MINUTES ; ADD TO ACCUMULATED VALUE CX.AX AL,CMOS_HOURS+NM! CMOS_READ AL,23H TOD_ERROR : ACCESS HOURS VALUE IN CMOS : ARE THE HOURS WITHIN LIMITS? : GO IF NOT 0259 E8 0287 R 0255 E8 020 R 025E B3 07 025E B3 07 0262 03 C1 0264 83 D2 00 0267 89 16 006E R 0268 A3 006C R 026E E 026E IF 026F 61 0270 C3 CALL MOV MOV MUL ADD ADC MOV MOV CVT_BINARY DX, AX BL, COUNTS_HOUR BL AX, CX DX, 0000H TIMER_HIGH, DX TIMER_LOW, AX ; CONVERT IT TO BINARY : COUNT FOR HOURS POD_DONE: POP POPA RET _OONE PL RE TOD_ERROR: POPP POPA MOV CAUL OR XCHG CALL RET EN' 05 0271 0271 1F 0272 61 0273 8E 0000 E 0276 E8 0004 R 0279 98 866E 027C E8 0000 R 027F 0C 04 0281 86 C4 0283 E8 001C R DS SI,OFFSET E163 E MSG AX,X*(CMOS_DIAG+NMI) CMOS READ AL,GH CMOS_CLK_FAIL AL,AH CMOS_WRITE SET CLOCK ERROR IN STATUS ; READ DIAGNOSTIC CMOS LOCATION ; SET NEW STATUS WITH CMOS CLOCK ERROR ; MOVE NEW STATUS TO WORK REGISTER ; UPDATE STATUS LOCATION 0287 SET_TOD ENDP 0287 0287 8A E0 0289 C0 EC 04 028C 24 0F 028E D5 0A 0290 C3 CVT_BINARY MOV SMR AND AAD RET PROC NEAR AH, AL AH, 4 AL, 0FH ; UNPACK 2 BCD DIGITS IN AL RESULT IS IN AX CONVERT UNPACKED BCD TO BINARY ``` ``` 18M Personal Computer MACRO Assembler Version 2.00 TEST4 --- 06/10/85 POST AND BIOS UTILITY ROUTINES 1-7 TEMPORARY INTERRUPT SERVICE ROUTINE FOR POST THIS ROUTINE IS ALSO LEFT IN PLACE AFTER THE POWER ON DIAGNOSTICS TO SERVICE UNUSED INTERFUET VECTORS. LOCATION "SINTE, FLAG" WILL CONTAIN EITHER NORMER INTERRUPT THAT CAUSED CODE TO BE EXECUTED, OR 21 FFF FOR A NON-HARDWARE INTERRUPT THAT WAS EXECUTED ACCIDENTALLY. NEAR AX AL.OBH INTAOO,AL $+2 AL.INTAOO AH,AL AL,AH HW_INT D11 PROC PUSH PUSH MOV OUT JMP IN MOV OR JNZ : SAVE REGISTER AX CONTENTS ! READ IN-SERVICE REGISTER ! (FIND OUT WHAT LEVEL BEING ! SERVICE ! SERVICE ! GET LEVEL ! SAVE !! ! SAVE !! ! 007 (NO HARDWARE ISR ACTIVE) 02A1 B4 FF 02A3 EB 2F 02A5 B0 0B 02A7 E6 A0 02A9 EB 00 02AB E4 A0 02AD 8A F8 02AF 0A FF 02B1 74 10 MOV JMP AH, OFFH SHORT SET_INTR_FLAG ; SET FLAG TO "FF" IF NON-HARDWARE AL,0BH INTB00,AL $+2 AL,INTB00 BH,AL BH,BH NOT_SEC MOV OUT JMP IN MOV OR JZ READ IN-SERVICE REGISTER FROM INTERRUPT CHIP #2 I/O DELAY CHECK THE SECOND INTERRUPT CHIP SAVE IT CONTINUE IF NOT 0281 74 10 0282 84 A1 0288 8A C7 0289 86 A1 0289 80 20 0289 86 A1 0289 80 00 0289 80 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0289 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 88 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 0299 68 00 AL, INTBO I AL, BH $+2 INTBO I, AL AL, EO I $+2 INTBO O, AL SHORT IS_SEC ; GET SECOND INTERRUPT MASK ; MASK OFF LEVEL BEING SERVICED ; 1/0 DELAY IX OMP OUT MMP OWP JMP SEND EOI TO SECOND CHIP GET CURRENT MASK VALUE 1/0 DELAY 1 DO NOT DISABLE SECOND CONTROLLER 1 MASK OFF LEVEL BEING SERVICED 1 SET NEW INTERRUPT MASK 1/0 DELAY AL, INTAO1 $+2 AH, OFBH AL, AH INTAO1, AL $+2 AL,EOI INTAGO,AL BX DS DDS #INTR_FLAG,AH DS AX : RESTORE (BX) FROM STACK : SAVE ACTIVE (DS) : SET DATA SEGMENT : SET FLAG ; RESTORE REGISTER AX CONTENTS ; NEED IRET FOR VECTOR TABLE 03E0 --- HARDWARE INT 71 H -- ( IRQ LEYEL 9 ) --- TO INT REDIRECT SLAVE INTERRUPT 9 TO INTERRUPT LEVEL 2 THIS ROUTINE FILEDS LEVEL 9 INTERRUPTS AND CONTROL IS PASSED TO MASTER INTERRUPT LEVEL 2 NEAR AX AL,EOI INTBOO,AL AX OAH 02E0 02E0 50 02E1 B0 20 02E3 E6 A0 02E5 58 02E6 CD 0A RE_DIRECT PROC PUSH MOY OUT POP INT : SAVE (AX) # EOI TO SLAVE INTERRUPT CONTROLLER # RESTORE (AX) # GIVE CONTROL TO HARDWARE LEVEL 2 02E8 CF IRET 02E9 RE_DIRECT ENDP INT_287 PROC PUSH XOR OUT NEAR AL AL, AL X287, AL I REMOVE THE INTERRUPT REQUEST 02EE B0 20 02F0 E6 A0 02F2 E6 20 02F4 58 02F6 CD 02 MOV OUT OUT POP INT AL,EOI INTBOO,AL INTAOO,AL AX OZH | ENABLE THE INTERRUPT | THE SLAVE | THE MASTER | RESTORE (AX) | GIVE CONTROL TO NMI 02F7 CF IRET 02F8 INT_287 ENDP 02F8 PROC SHUTDOWN COMMON 80286 SHUTDOWN WAIT 02F8 B0 FE 02FA E6 64 02FC 02FC F4 02FD EB FD MOV OUT PROC_S: HLT AL, SHUT_CMD STATUS_FORT, AL : SHUTDOWN COMMAND : SEND TO KEYBOARD CONTROL PORT ; WAIT FOR 80286 RESET ; INSURE HALT PROC_S 02FF 02FF ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTS --- 06/10/85 EXCEPTION INTERRUPT TEST HANDLERS 1-1 04-21-86 PAGE 118,121 TITLE TESTS ---- 06/10/85 EXCEPTION INTERRUPT TEST HANDLERS .284C .LIST CODE SEGMENT BYTE PUBLIC 7667891-11-1-11-12-12-13-15-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-45-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-678901-23-6 PUBLIC POSTS PUBLIC SYSINITS EXCEPTION INTERRUPT ROUTINE : ASSUME CS:CODE,DS:ABSO 0000 0000 0000 B0 90 0002 E9 00B2 R 0005 AL,90H TEST EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED EXC_01: AL,91H TEST_EXC EXC_02: MOY AL,92H TEST EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED 000F B0 93 001F B0 93 0011 E9 00B2 R 0014 0016 E9 00B2 R 0019 0019 06 0018 6A 48 001C 07 AL,93H TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED EXC_04: MOY JMP AL,94H TEST_EXC ; <><> SET CHECKPOINT <><> : GO TEST IF EXCEPTION WAS EXPECTED EXC_05: ES BYTE PTR ES_TEMP ; LOAD ES REGISTER WITH SELECTOR FIX BOUND PARAMETERS 001D 2B FF 001F 261 C7 05 0000 0024 26: C7 45 02 TFFF 002A 07 002B B0 95 002D E9 00B2 R SUB MOV MOV POP MOV JMP DI,DI ; POINT BEGINNING OF THE BLOCK WORD PTR ES:[DI].0 ; SET FIRST WORD TO ZERO WORD PTR ES:[DI+2].07FFFH ; SET SECOND TO 07FFFH ES AL,95H TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED EXC_06: MOV JMP 0030 . 0030 B0 96 0032 EB 7E 0034 . 0034 B0 97 0036 EB 7A AL,96H SHORT TEST_EXC $ <> SET CHECKPOINT <> <> GO TEST IF EXCEPTION WAS EXPECTED EXC_07: AL.97H SHORT TEST_EXC $ <><> SET CHECKPOINT <><> ## GO TEST IF EXCEPTION WAS EXPECTED 0036 EB 7A 0038 B0 98 003A EB 76 003C B0 99 003E EB 72 0040 EXC_08: AL.98H SHORT TEST EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED EXC_09: MOY JMP AL,99H SHORT TEST EXC ; <><> SET CHECKPOINT <><> : GO TEST IF EXCEPTION WAS EXPECTED EXC_10: 0040 B0 9A 0042 EB 6E 0044 B0 9B 0044 B0 9B 0046 EB 6A 0048 B0 9C 004A EB 66 MOV AL,9AH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> : GO TEST IF EXCEPTION WAS EXPECTED EXC_11: ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL,98H SHORT TEST_EXC EXC_12: EXC_13: MOV MOV AL,9CH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED 004C 004C B0 9D 004E EB 62 0050 B0 9E 0052 EB 5E 0054 B0 9F 0056 EB 5A 0058 B0 A0 0058 EB 56 AL,90H SHORT TEST_EXC EXC_14: MOV ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED ; <> SET CHECKPOINT <> GO TEST IF EXCEPTION WAS EXPECTED AL,9EH SHORT TEST_EXC EXC_15: AL,9FH SHORT TEST_EXC : <> SET CHECKPOINT <>> ; GO TEST IF EXCEPTION WAS EXPECTED MOV EXC_16: MOV EXC_17: AL,0A0H SHORT TEST EXC # <><> SET CHECKPOINT <><> ## GO TEST IF EXCEPTION WAS EXPECTED 005C B0 A1 005C B0 A1 005C B0 A1 005C E8 52 0064 B0 A2 0064 B0 A3 0066 E8 4A 0068 B0 A4 0068 B0 A4 0068 B0 A4 0068 B0 A4 AL,0A1H SHORT TEST_EXC : <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED EXC_18: AL, OAZH SHORT TEST_EXC MQY JMP GO TEST IF EXCEPTION WAS EXPECTED EXC_19: AL,0A3H SHORT TEST_EXC EXC_20: ; <><> SET CHECKPOINT <><> 1 GO TEST IF EXCEPTION WAS EXPECTED AL.0A4H SHORT TEST EXC EXC_SS: ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL,0A5H SHORT TEST_EXC AL,0A6H SHORT TEST_EXC 0070 BO A6 MOY JMP ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED 0074 0074 BO A7 EXC_23: AL,0A7H SHORT TEST_EXC : <><> SET CHECKPOINT <><> : GO TEST IF EXCEPTION WAS EXPECTED 0074 EB 3A 0078 B0 AB 007A EB 3A 007C B0 A9 007C B0 A9 0080 B0 AA 0082 EB 2E 0084 B0 AA 0084 ED AA 0088 EB AA 0088 B0 AC 0088 B0 AC EXC_24: AL, DASH SHORT TEST_EXC ; ⇒⇒ SET CHECKPOINT ; GO TEST IF EXCEPTION WAS EXPECTED AL,0A9H SHORT TEST_EXC ; <><> SET CHECKPOINT <><> : GO TEST IF EXCEPTION WAS EXPECTED EXC_26: MOV JMP AL.OAAH SHORT TEST EXC ; <><> SET CHECKPOINT <><> 1 GO TEST IF EXCEPTION WAS EXPECTED EXC_27: EXC_27: MOV JMP EXC_28: MOV JMP AL, DABH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL, OACH SHORT TEST EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED ``` **TEST5** 5-79 ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTS ---- 06/10/85 EXCEPTION INTERRUPT TEST HANDLERS 1-2 008C B0 AD 008C B0 AD 008C B0 AD 0092 B0 AD 0092 B0 AD 0094 B0 AD 0096 BD EXC_29: AL, DADH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL, OAEH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL,0AFH SHORT TEST_EXC MOV JMP ; <><> SET CHECKPOINT <><> ; GO TEST IF EXCEPTION WAS EXPECTED AL, 0B0H SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF INTERRUPT WAS EXPECTED AL, OBIH SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF INTERRUPT WAS EXPECTED AL,082H SHORT TEST_EXC AL,083H SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST 1F INTERRUPT WAS EXPECTED AL, 0B4H SHORT TEST_EXC MOV JMP AL,085H SHORT TEST_EXC ; <><> SET CHECKPOINT <><> ; GO TEST IF INTERRUPT WAS EXPECTED ; <> SET CHECKPOINT <> ; GO TEST IF INTERRUPT WAS EXPECTED TEST_EXC: OUT CMP JA ; OUTPUT THE CHECKPOINT ; CHECK FOR EXCEPTION ; GO IF A SYSTEM INTERRUPT 0086 15 008 16 008 008 16 008 16 008 16 008 008 008 008 008 008 002 06 004 004 003 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 06 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 000 07 : SAVE THE CURRENT DATA SEGMENT PUSH PUSH POP MOV POP POP POP POP POP PUSH CMP JNZ DS BYTE PTR GDT_PTR DS RESTORE REGISTERS CHECK IF CODE SEGMENT SECOND ON STACK JNZ PUSH TEST_EXCO! XCHG IN CMP JZ TEST_EXCI: IN CMP JB IRET 00D3 52 00D4 86 E0 00D6 E4 80 00D8 3A C4 00DA 74 0E 00DC E4 80 00DC E4 80 00DC 72 01 00E2 CF DX ; WAS THE EXCEPTION EXPECTED? AL,AH TEST_EXC3 AL,MFG_PORT AL,03BH TEST_EXC2 TEST_EXC2: XCHG OUT HLT JMP ; OUTPUT THE CURRENT CHECKPOINT ; <><> CHECKPOINT 90 THRU B5 <><> AH,AL MFG_PORT,AL TEST_EXC2 ; INSURE SYSTEM HALT 00EA 00EA 2A CO 00EC E6 8B 00EE B8 0100 00F1 CF 1 CLEAR DMA PAGE : FOR BOUND INSTRUCTION EXPECTED (INT 5): RETURN CS:CODE,DS:NOTHING,ES:NOTHING,SS:NOTHING PROC BP AL,81H MFG PORT,AL SIDT BLD SP,DT SAVE THE POINTER TO JUST PAST THE IDT AS WE HAVE NO SDA, USE THE SIX BYTES HERR TO LOAD THE IDTR. WE WILL SIDT WHEN WE GET TO SDA INITIALIZATION. SEGMENT LIMIT = LENGTH OF IDT STORE THAT AS IDT LIMIT IDT ADDRESS AND ACCESS RIGHTS BYTE (UNDEFINED) 00FD B8 0800 0100 AB 0101 B8 D0A0 0104 AB 0105 B8 0000 0108 AB AX, SYS_IDT_LEN MOV STOSW MOV STOSW MOV STOSW SEGOV OB LIDT DB LABEL MOV LABEL ORG DB MOV AX,SYS_IDT_LOC AX,0 ES 026H (BP) 00FH BYTE BYTE 00FFSET CS:770001 001H 00FFSET CS:770002 D1,8P : LOAD THE IDT 0109 26 : REGISTER FROM THIS AREA 010A OF 010B 010B 8B 5E 00 010E 010B 010B 01 010E 010E 8B FD ??0002 ; ES;DI NOW --> END OF IDT AGAIN BUILD THE GDT. DI,GDT_LOC GDT_BLD BP,DI AX,GDT_LEN 0110 BF D8A0 0113 E8 0140 R 0116 8B EF 0118 B8 0088 MOV CALL MOV MOV ; SAVE THE ES:DI POINTER ; AX = LENGTH OF THE GDT ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST5 ---- 06/10/85 EXCEPTION INTERRUPT TEST HANDLERS PUT THAT IN THE LIMIT FIELD 1 XX = LOW WORD OF GOT ADDRESS 1 XX = NIT THAT IN BASE FIELD SILOW 1 XX = HIGH BYTE OF ADDRESS AND 1 ACCESS RIGHTS BYTE IS UNDEFINED LOAD THE GOTR MOV STOSW MOV SEGOV DB LGDT DB LABEL MOV LABEL ORG DB ORG MOV STOSW MOV AX,GDT LOC AX.O CA, V ES 026H [Bg] 00FH BYTE DY, WORD PTR [BP] BYTE 00FFSET CS:770004 001H 001H 00FSET CS:770005 DI,BP 0124 26 0125 0F 0126 8B 56 00 0129 0126 01 0129 0129 01 0129 8B FD 012B AB 012C AB ; RESTORE THE ES:DI POINTER 01,8P :---- SWITCH TO VIRTUAL MODE POP MOV LMSW DB BP AX,VIRTUAL_ENABLE AX 00FH,001H,0F0H 0133 OF 01 F0 DW DW DB ; JUMP FAR TO PURGE PRE-FETCH QUEUE ; TO OFFSET ; IN SEGMENT MOV OUT RET AL,85H MFG_PORT,AL 0140 0140 BE 01AF R 0143 B9 0044 0146 F3/ A5 0148 C3 0149 GDT_BLD PROC MOV REP RET GDT_BLD ENDP NEAR $1,0FFSET GDT_DATA_START $1,DFSET GDT_DATA_START $2,DS1S1 --> GDT CX,(OFFSET GDT_DATA_END-OFFSET GDT_DATA_START)/2 # WORD COUNT MOVSW _____; COPY GDT INTO MEMORY SIDT_BLD 3---- BUILD THE IDT. THE IDT WILL CONTAIN VECTORS FOR EXCEPTION HANDLERS SI, OFFSET SYS_IDT_OFFSETS; MAKE DS:SI POINT TO AX, CS DS, ASS ; INTERRUPT ENTRY POINTS DS:ASS ; INTERRUPT ENTRY POINTS DS:ASS ; POINT TO SYS_IDT_LOC X:XX ; WHERE THE IDT WILL BE. BX, SYS ROM CS ; CS IS THE SAME FOR ALL INI DH. TRAF GATE ; ACCESS RIGHTS BYTE FOR THE DL. Q ; THE WORD COUNT FIELD IS U CX, 32 ; THERE ARE 32 RESERVED INTE ; THIS LOOP BUILDS 32 DESCRIP 0149 BE 0237 R 014C &C C8 014E &E D8 0150 BF D0A0 0153 2B C0 0155 &E C0 0157 BB 0040 015A B6 87 015C B2 00 016E B9 0020 MOV MOV MOV SUB MOV MOV MOV MOV POINT TO SYS_IDT_LOC WHERE THE IDT WILL BE. CS IS THE SAME FOR ALL INTERRUPTS ACCESS RIGHTS BYTE FOR THE GATE THE WORD COUNT FIELD IS UNUSEDS THIS LOOP BUILDS 32 DESCRIPTORS IN THE IDT FOR THE RESERVED INTERRUPTS GET A ROUTINE ENTRY POINT AND PUT IT IN THE OFFSET FIELD GET THE SYSTEM CODE SEGMENT SELECTOR AND PUT IT IN THE SELECTOR FIELD IN THE ACCESS RIGHTS FIELD ZERO OUT THE RESERVED POSITIONS AND REPEAT AS DIRECTED 250 TOTAL - 32 DONE & WHATEVER IS LEFT THERE IS A COPY OF AN UNIVITIALIZED INTERRUPT DESCRIPTOR AT FREE_INTS DSISI --> FREE DESCRIPTOR LOW_IDT: MOV STOSW MOV STOSW MOV STOSW LOOP MOV MOV 0162 8B C3 0164 AB 0165 8B C2 0167 AB 0168 8B 0000 0168 AB 016C EZ F3 016E B9 00E0 0171 BD 0277 R AX,DX AX,0 LOW IDT CX,256-32 BP,OFFSET FREE_INTS HIGH_IDT: | DSISI --> FREE DESCRIPTOR | (ESIDI LEFT OFF AT INT 32) | MOVE OFFSET OF THE IRET INSTRUCTION | MOVE THE CS SELECTOR | MOVE THE CS SELECTOR | MOVE THE ACCESS RIGHTS BYTE | ZERO QUI THE RESERVED WORD | FILL THE REMAINDER OF THE TABLE MOVSW MOVSW MOVSW STOSW LOOP HIGH IDT INITIALIZE THE ENTRY POINTS FOR POST TEST 017C 261 CT 06 D1A0 0098 R 0183 261 CT 06 D1A8 009C R 018A 261 CT 06 D1AB 00A0 R 019A 261 CT 06 D1BB 00AA R 019B 261 CT 06 D1BB 00A4 R 019B 261 CT 06 D1C8 00AC R 019F 261 CT 06 D1C8 00AC R 01A6 261 CT 06 D1D0 00B0 R ES:(SYS_IDT_LOC+(032*DESC_LEN).ENTRY_POINT), OFFSET SYS_32 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_33 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_34 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_35 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_35 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_35 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_37 ES:(SYS_IDT_LOC+(033*DESC_LEN).ENTRY_POINT), OFFSET SYS_37 MOV MOV MOV MOV MOV MOV RET ; FOR UN-INITIALIZED INTERRUPTS ; NULL RETURN IRET_ADDR IRET ``` ``` THE FOLLOWING DATA DEFINES THE PRE-INITIALIZED GDT FOR POST TESTS. THESE MUST BE INITIALIZED IN THE ORDER IN WHICH THEY APPEAR IN THE GDT_DEF STRUCTURE DEFINITION AS IT IS IN "SYSDATA.INC". GDT_DATA_START EQU $ :---- FIRST ENTRY UNUSABLE - (UNUSED_ENTRY) ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO :---- THE GDT ITSELF - (GDT_PTR) DW GDT_LEN DW GDT_LOC DB 0 DB 0 CPL0_DATA_ACCESS DW 0 ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO CPLO_DATA_ACCESS |---- THE SYSTEM IDT DESCRIPTOR - (SYS_IDT_PTR) SYS_IDT_LEN SYS_IDT_LOC 0 CPL0_DATA_ACCESS ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO DW DB DB DW ;---- THE SYSTEM DATA AREA DESCRIPTOR - (RSDA_PTR) | DW | SDA_LEN | SEGMENT LIMIT | SEGMENT LIMIT | SEGMENT BASE ADDRESS - LOW WORD | SO | SEGMENT BASE ADDRESS - HIGH BYTE | SEGMENT BASE ADDRESS - HIGH BYTE | ACCESS RIGHTS BYTE | RESERVED - MIJST BE ZERO :---- COMPATIBLE MONOCHROME DISPLAY REGEN BUFFER - (C_BWCRT_PTR) DW MCRT SIZE | SEGMENT LIMIT DW MCRT LO | SEGMENT BASE ADDRESS - LOW WORD DB MCRT HI | SEGMENT BASE ADDRESS - HIGH BYTE DB CFL0 DATA_ACCESS | ACCESS RIGHTS BYTE | ACCESS RIGHTS BYTE | RESERVED - MAIST BE ZERO ;---- COMPATIBLE COLOR DISPLAY REGEN BUFFER - (C_CCRT_PTR) ;---- ENHANCED GRAPHIC ADAPTER REGEN BUFFER - (E_CCRT_PRT) ECCRT 51ZE : SEGMENT LIMIT ECCRTS-LO_0 : SEGMENT BASE ADDRESS - LOW WORD ECCRTS-LO_HI : SEGMENT BASE ADDRESS - HIGH BYTE CPLO_DXTA_ACCESS : ACCESS RIGHTS BYTE : RESERVED - MUST BE ZERO DW DB DB DW ;---- SECOND PART OF EGA - (E_CCRT_PTR2) ECCRT_SIZE CCCRT_G HI_O ECCRT_G HI_H CPLO_DATA_ACCESS CREEN ECCRT_G HI_H CPLO_DATA_ACCESS ECCRT_G HI_H CPLO_DATA_ACCESS ECCRT_G HI_H CPLO_DATA_ACCESS ECCRT_G HI_H H DW DB DW DW ;---- CODE SEGMENT FOR POST CODE, SYSTEM IDT - (SYS_ROM_CS) DW DB DB DW MAX_SEG_LEN ; SEGMENT LIMIT CSEG®_LO : SEGMENT BASE ADDRESS - LOW WORD CSEG®_HI CPLO_GODE_ACCESS ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO :---- TEMPORARY DESCRIPTOR FOR ES - (ES TEMP) MAX_SEG_LEN ; SEGMENT LIMIT NSEG® LO ; SEGMENT BASE ADDRESS - LOW WORD NSEG® THI ACCESS ; SEGMENT BASE ADDRESS - HIGH BYTE CPL_0_DATA_ACCESS ; ACCESS RIGHTS BYTE 1 RESERVED - MUST BE ZERO DM DB DM DA CS AS A DATA SEGMENT - (CS_TEMP) MAX SEC LEN | SECMENT LIMIT | NSEGO LO SECMENT BASE ADDRESS - LOW WORD | NSEGO HI | SECMENT BASE ADDRESS - HIGH BYTE | CPLO_DATA_ACCESS | ACCESS RIGHTS BYTE | RESERVED - MUST BE ZERO :---- TEMPORARY DESCRIPTOR FOR SS - (SS_TEMP) MAX SEG_LEN ; SEGMENT LIMIT NSEGS_LO ; SEGMENT BASE ADDRESS - LOW WORD NSEGS_HI ACCESS ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO DM DB DM DM ``` 1---- TEMPORARY DESCRIPTOR FOR DS - (DS\_TEMP) MAX\_SEG\_LEN ; SEGMENT LIMIT NSEG=LD ; SEGMENT BASE ADDRESS - LOW WORD NSEG= HI ; SEGMENT BASE ADDRESS - HIGH BYTE ON\_DATA\_ACCESS ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO 1-4 IBM Personal Computer MACRO Assembler Version 2.00 TEST5 --- 06/10/85 EXCEPTION INTERRUPT TEST HANDLERS ``` IBM Personal Computer MACRO Assembler Version 2.00 TESTS ---- 06/10/85 EXCEPTION INTERRUPT TEST MANDLERS 1-5 04-21-86 PAGE (POST_TR) TR_LOC: 0217 0217 0800 0219 C000 0218 00 021C 81 021D 0000 DW 00800H DW 0C000H DB 0 DB FREE_TS ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO FREE_TSS ;---- (POST_TSS_PTR) ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO 00800H TR_LOC CPLO_DATA_ACCESS POST_LDTR) LDT_LOC: DW GDT_LEN DW GD00H DB LDT_DESC 0227 0088 0229 0000 0220 E2 0220 E2 GDT_LEN ODOGOH O LDT_DESC O SEGMENT LIMIT SEGMENT BASE ADDRESS - LOW WORD SEGMENT BASE ADDRESS - HIGH BYTE ACCESS RIGHTS BYTE RESERVED - MUST BE ZERO :---- (POST_LDT_PTR) GDT_LEN LDT_LOC 0 CPLO_DATA_ACCESS 0 DW DB DW DW ; SEGMENT LIMIT ; SEGMENT BASE ADDRESS - LOW WORD ; SEGMENT BASE ADDRESS - HIGH BYTE ; ACCESS RIGHTS BYTE ; RESERVED - MUST BE ZERO GDT_DATA_END EQU $ = 0237 :---- END OF PRE-ALLOCATED GDT ;---- ENTRY POINTS FOR THE FIRST 32 SYSTEM INTERRUPTS INTERRUPTS AS DEFINED EXCPT 00 - DIVIDE ERROR EXCPT 01 - SINGLE STEP EXCPT 01 - SINGLE STEP EXCPT 02 - NMI, SYSTEM REQUEST FOR DI EXCPT 03 - BREAKPOINT EXCPT 04 - INTO DETECT EXCPT 05 - BOUND EXCPT 05 - BOUND EXCPT 07 - PROCESSOR EXT NOT AVAIL EXCPT 06 - DOUBLE EXCEPTION EXCPT 07 - PROCESSOR EXT NOT AVAIL EXCPT 08 - DOUBLE EXCEPTION EXCPT 09 - PROCESSOR EXT SEGMENT ERR EXCPT 10 - TSS BAD IN GATE TRANSFER EXCPT 11 - SEGMENT NOT PRESENT EXCPT 11 - SEGMENT NOT PRESENT EXCPT 13 - GENERAL PROTECTION 0237 SYS_IDT_OFFSETS LABEL WORD 0237 0005 R 0238 0005 R 0238 0005 R 0238 0005 R 0238 0006 R 0238 0019 R 0241 0019 R 0245 0036 R 0245 0036 R 0245 0046 R 0245 0046 R 0245 0046 R 0255 0056 0059 0 OFFSET EXC 00 OFFSET EXC 02 OFFSET EXC 02 OFFSET EXC 02 OFFSET EXC 03 OFFSET EXC 03 OFFSET EXC 03 OFFSET EXC 03 OFFSET EXC 03 OFFSET EXC 03 OFFSET EXC 12 OFFSET EXC 13 OFFSET EXC 14 OFFSET EXC 14 OFFSET EXC 14 OFFSET EXC 14 OFFSET EXC 14 OFFSET EXC 16 OFFSET EXC 16 OFFSET EXC 16 OFFSET EXC 16 OFFSET EXC 16 OFFSET EXC 16 OFFSET EXC 20 : EXCPT 16 - PROCESSOR EXTENSION ERROR INTERRUPT DESCRIPTORS (GATES) 32 - 255 OFFSET IRET_ADDR ; DESTINATION OFFSET ; DESTINATION SEGMENT 0,1NT_GATE ; UNUSED AND ACCESS RIGHTS BYTE FREE_INTS SIDT_BLD 027D CODE ENDS ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST6 ---- 06/10/85 POST TESTS AND SYSTEM BOOT STRAP PAGE 118,121 TITLE TEST6 ---- 06/10/85 POST TESTS AND SYSTEM BOOT STRAP. .286C .LIST CODE SEGMENT BYTE PUBLIC PUBLIC BOOT STRAP_1 PUBLIC POST6 PUBLIC STGTST_CNT PUBLIC ROM_ERR PUBLIC XMIT_8042 EXTRN CMOS READ: NEAR EXTRN DDS: NEAR EXTRN DISK BASE: NEAR EXTRN E602T NEAR EXTRN ERR BEEP; NEAR EXTRN E MSGINEAR EXTRN F31: NEAR EXTRN PRT_SEG: NEAR POST6 PROC NEAR THIS SUBROUTINE PERFORMS A READ/WRITE STORAGE TEST ON A BLOCK OF STORAGE SEGMENT BEING TESTED DS = ADDRESS OF STORAGE SEGMENT BEING TESTED DS = ADDRESS OF STORAGE SEGMENT BEING TESTED EXIT PARAMETERS: EXIT PARAMETERS: CHECK): AL=0 DENOTES A PARITY CHECK. ELSE AL=XOR*ED BIT PARAMETERS: AX, BX, CX, DX, DI. AND SI ARE ALL DESTROYED. AX, BX, CX, DX, DI. AND SI ARE ALL DESTROYED. TOTST_CNT PROC NEAR MOV BX, CX AL, PORT B OR AL, RAM PAR_OFF ON AL, RAM PAR_OFF ON AL, RAM PAR_OFF ON AL, RAM PAR_ON ON ONT B, ALR_ON ONT 0000 POST6 PROC NEAR STGTST_CNT MOV IN OR OUT AND OUT 0000 0000 8B D9 0002 E4 61 0004 0C 0C 0006 E6 61 0008 24 F3 000A E6 61 ; SAVE WORD COUNT OF BLOCK TO TEST ; TOGGLE PARITY CHECK LATCHES ; TO RESET ANY PENDING ERROR ;---- ROLL A BIT THROUGH THE FIRST WORD 000C 33 D2 000E B9 0010 0011 2B FF 0013 2B F6 0015 F9 0016 D1 D2 0016 D1 D2 0016 B9 15 001A 8B 05 001C 33 C2 001E E1 F6 : CLEAR THE INITIAL DATA PATTERN : ROLL 16 BIT POSITIONS : START AT BEGINNING OF BLOCK : INITIALIZE DESTINATION POINTER : SET CARRY FLAG ON FOR FIRST BIT XOR MOV SUB SUB STC DX,DX CX,16 D1,D1 S1,S1 MOVE BIT OVER LEFT TO NEXT POSITION STORE DATA PATTERN GET THE DATA WRITTEN SINSURE DATA AS EXPECTED (CLEAR CARRY) LOOP TILL DONE OR ERROR RCL MOV MOV XOR LOOPZ C13 0020 75 66 JNZ EXIT IF ERROR :---- CHECK CAS LINES FOR HIGH BYTE LOW BYTE DX,OFFGGH [DI],AX [DI+1],DH AX,[DI] AX,DX CI3 0022 BA FF00 0025 89 05 0027 88 75 01 002A 88 05 002C 33 C2 002E 75 58 : TEST DATA - AX* 0000H : STORE DATA PATTERN = 0000H : WRITE A BUTE OF FFH AT ODD LOCATION : GET THE DATA - SHOULD BE OFFO0H : CHECK THE FIRST WRITTEN : ERROR EXIT IF NOT ZERO MOV MOV MOV MOV XDR JNZ [DI],AX [DI],DH DH,DL AX,[DI] AX,DX C13 ; STORE DATA PATTERN OF 0000H; WRITE A BYTE OF FFH AT EVEN LOCATION; SET DX. 000FFH AND BUS SETTLE; CHECK THE TRIST WRITTEN; EXIT IF NOT 0030 89 05 0032 88 35 0034 86 F2 0036 8B 05 0038 33 C2 003A 75 4C MOV MOV XCHG MOV XOR JNZ CHECK FOR 1/0 OR BASE ; CHECK FOR 1/O - PARITY CHECK ; SAVE ERROR ; CHECK FOR R/W OR 1/O ERROR ; MASK FOR ERROR EXPECTED AL,PORT_B AL,AH AL,DMA_PAGE+6 AH,AL IN XCHG IN AND ----- PARITY ERROR EXIT MOY JNZ AX.0 RESTORE AX TO 0000 ; EXIT IF PARITY ERROR 0044 B8 0000 0047 75 3F 0047 75 3F 0049 BA AA55 004C 004C 28 FF 004E 28 F6 0050 8B C8 0052 8B C2 0054 F3/ AB 0056 8B C8 0056 8B C8 0056 8B C8 0056 8B C8 0056 BC C8 0056 AD 0050 AD 0050 BI FB MOV DX. GAASSH . WRITE THE INITIAL DATA PATTERN C3: I START AT BEGINNING OF BLOCK I INITIALIZE DESTINATION POINTER SETUP BYTE COLUMN FOR LOOP I GET THE PATTERN I STORE 64K BYTES (32K WORDS) I SET COLUMN START AT BEGINNING SUB SUB MOV MOV REP MOV SUB DI,DI SI,SI CX,BX AX,DX STOSW CX,BX SI,SI LODSW XOR LOOPZ GET THE FIRST WRITTEN INSURE DATA AS EXPECTED LOOP TILL DONE OR ERROR AX,DX C6 006F 75 27 C13 ; EXIT IF NOT EXPECTED (ERROR BITS ON) JNZ CHECK FOR I/O OR BASE MEMORY ERROR IN XCHG IN AND AL.PORT_B AL.AH AL.DMA_PAGE+6 AH.AL ; CHECK FOR I/O -PARITY CHECK ; SAVE ERROR ; CHECK FOR R/W OR I/O ERROR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 TEST6 ---- 06/10/86 POST TESTS AND SYSTEM BOOT STRAP 1-2 04-21-86 116718991223456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567 ---- PARITY ERROR EXIT 0069 B8 0000 006C 75 1A MOV AX.0 JNZ C13 ; RESTORE AX TO 0000 ; GO IF YES ;---- CHECK FOR END OF 64K BLOCK AND JZ DX,DX C13 ; ENDING ZERO PATTERN WRITTEN TO MEMORY? ; YES - RETURN TO CALLER WITH AL=0 ;---- SETUP NEXT PATTERN 0072 81 FA 65AA 0076 74 0B 0078 81 FA 0101 007C 74 0B 007E BA 55AA 0081 EB C9 DX,055AAH C9 DX,0101H C10 DX,055AAH C3 CMP JZ CMP JZ MOY JMP ; CHECK IF LAST PATTERN =55AA ; GO IF NOT ; LAST PATTERN 0101? ; GO IF YES ; WRITE 55AA TO STORAGE ;---- INSURE PARITY BITS ARE NOT STUCK ON ; WRITE 0101 TO STORAGE 0083 BA 0101 0086 EB C4 MOV DX,0101H EXIT STORAGE TEST 0088 0088 C3 ;---- CHECKER BOARD TEST 0089 28 FF 008B 8B CB 008D DI E9 008F 88 AAAA 0092 8E 5555 0095 0095 96 0096 AB 0097 96 0098 AB 0099 E2 FA C10: SUB D1,D1 MOV CX,BX SHR CX,1 MOV AX,101010101010101010 M MOV S1,0101010101010101010 XCHG AX,SI STOSW XCHG AX,SI STOSW LOOP C11 : FIRST CHECKER PATTERN TO AX : WRITE IT TO MEMORY : SECOND CHECKER PATTERN TO AX : WRITE IT TO MEMORY : DO IT FOR CX COUNT 009B 2B F6 009D 8B CB 009F D1 E9 00A1 BF 5555 00A4 BA AAAA 00A7 00A7 AD 00A8 33 C7 00AA 75 DC SUB MOV SHR MOV MOV SI,SI CX,BX CX,I DI,010101010101010101B DX,1010101010101010B ; POINT TO START OF BLOCK ; GET THE BLOCK COUNT ; DIVIDE BY 2 ; CHECK CORRECT C12: LODSW XOR JNZ AX,DI C13 ; GET NEXT DATA ; CHECK SECOND PATTERN ; CONTINUE TILL DONE LODSW XOR LOOPZ 00AC AD 00AD 33 C2 00AF E1 F6 00B1 75 D5 JNZ CI3 ; ERROR EXIT IF NOT CORRECT :---- CHECK FOR I/O OR BASE MEMORY PARITY CHECK IN XCHG IN AND AL.PORT_B AL.AH AL.DMA_PAGE+6 AH.AL ; CHECK FOR I/O-PARITY CHECK ; SAVE ERROR ; CHECK FOR R/W OR I/O ERROR ;---- CHECKPOINT 32 FOR ADDRESS LINE 0->15 FAILURE 0088 80 32 0080 E6 80 008F 98 0000 00C2 75 C4 MOV OUT MOV JNZ AL.32H MFG PORT,AL AX,0 C13 ;---- 64K ADDRESS TEST AND FILL WITH ZERO 00C4 48 00C5 29 FF 00C7 89 C9 00C7 89 C9 00C6 85 E9 02 00C6 80 00C6 F3/ AB 00D1 AB 00D1 AB 00D2 28 F6 00D4 89 C9 00D4 89 C9 00D4 83 E9 02 00D9 AD 57 00D7 AD 60 00E7 AD 60 00E7 AD 60 00E4 75 A2 00E6 AD 60 00E7 35 FFFF 00EA 75 9C WRITE FIRST AND LAST LOCATION#FFFF POINT TO START OF BLOCK GET THE BLOCK COURT DO ALL LOCATIONS BUT LAST WRITE FIRST LOCATION AS FFFFH WRITE ZERO WRITE IT LAST WORD IS FFFF DEC SUB MOV SUB STOSW INC REP DEC STOSW SUB MOV SUB LODSW XOR JNZ SI,SI CX,BX CX,2 ; POINT TO START OF BLOCK ; GET THE BLOCK COUNT GET THE DATA CHECK CORRECT XIT IF NOT GET NEXT DATA ANY BIT ON ? CONTINUE TILL LAST WORD GO IF NOT CORRECT GET LAST WORD S/B FFF EXIT IF NOT LODSW OR LOOPZ JNZ LODSW XOR JNZ SUB STOSW MOV STOSW 10,10 : CLEAR FIRST WORD DI,OFFFEH : CLEAR TOP WORD AL,PORT_B AL,AH AL,DMA_PAGE+6 AH,AL AX,0 C13 ENDP 00F3 E4 61 00F5 86 C4 00F7 E4 87 00F9 22 E0 00FB B8 0000 00FE EB 88 0100 IN XCHG IN AND MOV JMP STGTST_CNT ; CHECK FOR I/O - PARITY CHECK ; SAVE ERROR ; CHECK FOR R/W OR I/O ERROR ; SET AX EQUAL ZERO ; ERROR EXIT IF ZF NOT SET ``` ``` IBM Personal Computer MACRO Assembler Version 2,00 TEST6 --- 06/10/85 POST TESTS AND SYSTEM BOOT STRAP 1-3 PAGE PRINT ADDRESS AND ERROR MESSAGE FOR ROM CHECKSUM ERRORS I 0100 52 0101 06 0102 50 0102 50 0103 88 ---- R 0106 5E CO 0102 50 0108 55 0109 50 0108 5C AC DA O10C 26: 58 36 0015 R : SAVE POINTER ; SET ES TO DATA SEGMENT : RESTORE AX DX,0C800H ROM_ERR_BEEP PRT_SEG_ SI,OFFSET FSA E_MSG CMP JL CALL MOV CALL END: POP POP POP RET BEEP: MOV CALL DX,0102H ERR_BEEP SHORT ROM_ERR_END ; BEEP ! LONG, 2 SHORT OM ERR ENDP THIS SUBROUTINE SENDS AN OUTPUT COMMAND TO THE KEYBOARD AND RESPONSE. ENTRY REQUIREMENTS: AL & COMMAND/DATA TO BE SENT EXIT PARAMETERS: ZERO FLAG & I IF ACK RECEIVED FROM THE KEY BOARD AL & RESPONSE XMIT_8042 PROC NEAR ---- CHECK INPUT BUFFER FULL 012C 86 E0 012E 2B C9 0130 E4 64 0132 E4 64 0134 E0 FA 0136 E3 34 0138 86 E0 XCHG AH, AL SUB CX, CX SAVE COMMAND SET LOOP TIME-OUT XM1TLOOP IN AL, STATUS PORT TEST AL, INPT BUF FULL LOPPNZ XMITLOOP JCXZ SHORT XMIT_EXIT XCHG AM, AL ; CHECK INPUT BUFFER FULL ; RESTORE COMMAND ;---- ISSUE THE COMMAND 013A E6 60 013C 2B C9 OUT PORT_A,AL SUB CX,CX SEND THE COMMAND j---- CHECK OUTPUT BUFFER FULL XMIT_I: IN AL.STATUS_PORT MOV AH.AL TEST AL.OUT BUF_FULL JZ XMIT_Z IN AL.FORT_A XMIT_Z: TEST AH.INPT_SUF_FULL LONZ XHIT! LONZ SHORT XMIT_EXIT 013E E4 64 0140 8A E0 0142 A8 01 0144 74 02 0146 E4 60 0148 F6 C4 02 014B E0 F1 014D 75 1D ; SAVE STATUS ; CHECK IP 8042 HAS DATA ; GO IF NOT ; FLUSH DATA ; CHECK COMMAND ACCEPTED MOV SUB XMIT_3I IN TEST LEGTZ DEC UNIZ INC JMP GET NO FLUSH OR COMMAND NOT ACCEPTED 1---- CHECK OUTPUT BUFFER FULL BL,6 CX,CX AL,STATUS PORT AL,OUT_BUF_FULL XMIT_3 XMIT_4 BL SHORT XMIT_3 BL SET COUNT ; CHECK IF HAS DATA ; WAIT TILL DONE ; DECREMENT OUTER LOOP ; TRY AGAIN ; SET ERROR FLAG ; 8042 STUCK BUSY BL SHORT XMIT_EXIT ;---- GET THE DATA XMIT 4: SUB cx,cx 0163 2B C9 : ALLOW TIME FOR POSSIBLE : ERROR -> SYSTEM UNIT OR KEYBOARD XMIT_5 AL.PORT_A CX,01H 0165 E2 FE 0167 E4 60 0169 83 E9 01 016C 016C C3 016D XMIT_6: LOOP IN SUB XMIT_EXIT: RET XMIT_8042 ENDP ; SET CX OTHER THAN ZERO IF THERE IS A HARDWARE ERROR CONTROL IS TRANSFERRED TO THE ROM BASIC ENTRY POINT ASSUME CS:CODE,DS:ABSO,ES:ABSO 016D BOOT_STRAP I PROC NEAR MOV MOV AX,ABSO DS,AX ES,AX : ESTABLISH ADDRESSING RESET THE DISK PARAMETER TABLE VECTOR 0174 C7 06 0078 R 0000 E 017A 8C 0E 007A R MOV WORD PTR ODISK_POINTER, OFFSET DISK_BASE MOV WORD PTR ODISK_POINTER+2,CS ``` ``` IBM Personal Computer MACRO Assembler Version 2,00 TEST6 ---- 06/10/85 POST TESTS AND SYSTEM BOOT STRAP XOR MOV MOV REP AX,AX CX,256 DI,OFFSET #BOOT_LOCN STOSW ; CLEAR 256 WORDS LOAD SYSTEM FROM DISKETTE -- CX HAS RETRY COUNT STI MOV PUSH MOV INT JC 0188 FB 0189 B9 0004 018C 51 018D B4 00 018F CD 13 0191 72 0F CX,4 CX AH,0 13H H2 ; SET RETRY COUNT ; IPL SYSTEM ; RESET THE DISKETTE SYSTEM ; DISKETTE_IO ; IF ERROR, TRY AGAIN 0193 B8 0201 0196 28 D2 0198 BE C2 0198 BB CCOO R 019D B9 0001 01A0 CD 13 01A2 59 01A3 73 09 01A5 30 FC 80 01A6 74 22 01A6 EB 1E AX,20 IH DX,DX ES,DX ES,DX ES,DX ES,DX CX,1 194 CX HAH,80H H6 H1 SHORT H5 MOY SUB MOY MOY MOY INT POP JNC CMP JZ LOOF JMP READ IN THE SINGLE SECTOR DRIVE 0, HEAD 0 SECTOR 1, TRACK 0 DISKETTE 10 RECOVER RETRY COUNT CARRY FLAG SET BY UNSUCCESSFUL READ IF TIME OUT, MO RETRY TRY FIXED DISK DO 11 FOR RETRY TIMES TRY FIXED DISK H2: # BOOT RECORD READ SUCCESSFUL INSURE FIRST BYTE OF LOADED BOOT RECORD IS VALID (NOT ZERO) BYTE PTR *BOOT_LOCN, 06H ; CHECK FOR FIRST INSTRUCTION INVALID HI0 ; IF BOOT NOT VALID PRINT MESSAGE HALT 01AE 80 3E 7C00 R 06 01B3 72 71 INSURE DATA PATTERN FIRST 8 WORDS NOT ALL EQUAL DI OFFSET OBOOT_LOCN CX.8 AX, WORD PTR OBOOT_LOCN MOA WOA DI,2 AX,[DI] H4A H10 01BE 83 C7 02 01C1 3B 05 01C3 E1 F9 01C5 74 5F ADD CMP LOOPZ JZ POINT TO NEXT LOCATION CHECK DATA PATTERN FOR A FILL PATTERN JMP 01C7 EA 7C00 ---- R ●BOOT_LOCN H4_A: ;---- ATTEMPT BOOTSTRAP FROM FIXED DISK MOV OUT ASSUME CALL TEST ASSUME MOV JZ AL,044H MFG_PORT,AL DS:DATA DDS 0LASTRATE,DUAL DS:ABSO AX,ABSO DS,AX H9 H5: 01CC B0 44 01CE E6 80 01D0 E8 0000 E 01D3 F6 06 008B R 01 : FLOPPY/FIXED DISK CARD INSTALLED CHECK FOR FIXED DISK INITIALIZA AL, CMOS DIAG CMOS READ AL, HF_FAIL H9 MOV CALL TEST JNZ 01E6 75 34 01E8 28 C0 01EA 28 D2 01EC CD 13 01EE 89 0003 01F1 51 01F2 BA 0080 01F5 88 0201 01F6 8B D8 01FA 8E C3 01FC BB TC00 R 02C C 13 02C T 90 02C T 8 3E TDFE R AA55 02CD 74 BB AX,AX DX,DX 13H CX,3 SUB SUB INT MOY RESET DISKETTE RETRY COUNT PUSH MOY SUB MOY MOY MOY INT POP JC CMP JZ 020F 61 0210 BA 0080 0213 BB C0 0215 CD 13 0217 59 0218 T2 08 021A E2 D5 PUSH MOV SUB INT POP JC LOOP FIXED DISK ZERO RESET THE FIXED DISK FILE 1/0 CALL RESTORE LOOP COUNT IF ERROR, TRY AGAIN DO IT FOR RETRY TIME: UNABLE TO IPL FROM THE DISKETTE OR FIXED DISK MOY OUT 021C B0 45 021E E6 80 AL,045H MFG_PORT,AL 1 SH ; GO TO RESIDENT BASIC 0220 CD 18 INT :---- HARD FILE RESET FAILURE HIOA: LOOP 0222 E2 EB 0224 EB F6 TRY RESET AGAIN IF DISKETTE READ OK BUT BOOT RECORD IS NOT STOP SYSTEM ALLOW SOFT RESET MOV SI,OFFSET E602 CALL E_MSG UMP HTI STRAP I ENDP ENDP ENDS END HIO: PRINT DISKETTE BOOT ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS PAGE 118,121 TITLE DSKETTE -- 04/21/86 DISKETTE BIOS .286C .LIST SUBTTL (DSKI.ASM) .LIST | 1234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 234567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567890| 23567 (AH)=00H RESET DISKETTE SYSTEM HARD RESET TO NEC, PREPARE COMMAND, RECALIBRATE REQUIRED ON ALL DRIVES (AH)=01H READ THE STATUS OF THE SYSTEM INTO (AH) + ODISKETTE_STATUS FROM LAST OPERATION IS USED (ES:BX) - ADDRESS OF BUFFER (NOT REQUIRED FOR VERIFY) (AH)=02H READ THE DESIRED SECTORS INTO MEMORY (AH)=03H WRITE THE DESIRED SECTORS FROM MEMORY (AH)=04H VERIFY THE DESIRED SECTORS FORMAT THE DESIRED TRACK (ESSEX) MUST POINT TO THE COLLECTION OF DESIRED ADDRESS FIELDS FOR THE TRACK. EACH FIELD IS COMPOSED OF 4 BYTES. (C.H.R.N), WHERE C = TRACK NUMBER, H-HEAD NUMBER, R = SECTOR NUMBER, N. NUMBER OF BYTES PER SECTOR (00-128,01=256,02=812,03=1024). THERE MUST BE ONE ENTRY FOR EVERY SECTOR ON THE TRACK. THIS INFORMATION IS USED TO FIND THE REQUESTED SECTOR DURING READ/WRITE ACCESS. PRIOR TO FORMATTING A DISKETTE, IF THERE EXISTS MORE THAN ONE SUPPORTED MEDIA FORMAT TYPE WITHIN THE DRIVE IN QUESTION, THEN "SET ADAD TYPE" (INT 13H, AH = 17H) OR "SET MEDIA TYPE" (INT 13H, AH = 17H) OR "SET MEDIA TYPE" (INT 13H, AH = 16H) MUST BE CALLED TO SET THE DISKETTE TYPE" THAT IS TO BE FORMATED. IF "SET DASD TYPE" OR "SET MEDIA TYPE" IS NOT CALLED, THE FORMAT ROUTINE WILL ASSUME THE MEDIA FORMAT TO BE THE MAXIMUM CAPACITY OF THE DRIVE. - WHEN FORMAT OPERATIONS ARE COMPLETE, THE PARAMETERS NOULD BE RESTORED TO THEIR RESPECTIVE INITIAL VALUES IAHI-08H READ DRIVE PARAMETERS REGISTERS INPUT (DL) - DRIVE NUMBER (0-1 ALLOWED, VALUE CHECKED) OUTPUT (ESIDI) POINTS TO DRIVE PARAMETERS TABLE (CH) - LOW ORDER 8 OF 10 BITS MAXIMUM NUMBER OF TRACKS (CL) - BITS 1 8 8 - HIGH OFDER TWO BITS DO FAXIMUM TRACKS (CL) - BITS 1 8 8 - HIGH OFDER TWO BITS OF MAXIMUM TRACKS (CL) - HAXIMUM HEAD NUMBER (DL) - NUMBER OF DISKETTE DRIVES INSTALLED (BH) - 0 (BL) - BITS 7 HRU 0 - VALID DRIVE TYPE VALUE IN CMOS (AX) BITS 3 THRU 0 - VALID DRIVE TYPE VALUE IN CMOS (AX) UNDER THE FOLLOWING CIRCUMSTANCES: (1) THE DRIVE TYPE IS UNKNOWN AND CMOS IS NOT PRESENT, (2) THE DRIVE TYPE IS UNKNOWN AND CMOS IS BAD, (4) OR THE DRIVE TYPE IS UNKNOWN AND THE CMOS DRIVE TYPE IS INVALID THEN ESIAX, BX, CX, DX, DH, DIE O; DL-MUMBER OF DRIVES. IF ND DRIVES ARE PRESENT THEN: ES, AX, BX, CX, DX, DI = 0. **CONSETTE_STATUS.** 0 AND CY IS RESET.** (AH)-15M READ DASD TYPE OUTPUT REGISTERS. (AH)=15H READ DASD TYPE OUTPUT REGISTERS ``` ``` IBM Personal Computer MACRO Assembler Yersion 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK1.ASM) (AH) - ON RETURN IF CARRY FLAG NOT SET, OTHERWISE ERROR 00 - DRIVE NOT PRESENT 01 - DISKETTE, ON CHANGE LINE AVAILABLE 02 - DISKETTE, CHANGE LINE AVAILABLE 03 - RESERVED (DL) - DRIVE NUMBER (0-1 ALLOWED, VALUE CHECKED) (AH)=16H DISK CHANGE LINE STATUS OUTPUT REGISTERS (AH) - 00 - DISK CHANGE LINE NOT ACTIVE 06 - DISK CHANGE LINE ACTIVE & CARRY BIT ON (DL) - DRIVE NUMBER (0-1 ALLOWED, VALUE CHECKED) (AH) = 17H SET DASD TYPE FOR FORMAT INPUT RESTREAS (AL) - 00 - NOT USED 01 - DISKETTE 320/360K IN 360K DRIVE 02 - DISKETTE 320/360K IN 1.2M DRIVE 03 - DISKETTE 1.2M IN 1.2M DRIVE 04 - DISKETTE 1.2M IN 1.2M DRIVE (DL) - DRIVE NUMBER (0-1 ALLOWED, VALUE CHECKED; DD NOT USE WHEN DISKETTE ATTACH CARD USED) ON TOTUSE WHEN DISKETTE ATTACH CARD USED) TO NOT USE WHEN DISKETTE ATTACH CARD USED) (AH)=18H SET MEDIA TYPE FOR FORMAT INPUT REGISTERS (CH) - LOW ORDER 8 OF 10 BITS MAXIMUM NUMBER OF TRACKS (CL) - BITS 7 8 4 - HIGH ORDER TWO BITS OF MAXIMUM TRACKS (DL) - BRIVE NUMBER (0-1 ALLOWED, VALUE CHECKED) (DL) - ROTIVE NUMBER (0-1 ALLOWED, VALUE CHECKED) (USTUTUR REGISTERS (0-1 ALLOWED, VALUE CHECKED) (LESIDI) - POINTER TO DRIVE PARAMETERS TABLE FOR THIS MEDIA TYPE, (LESIDI) - POINTER TO DRIVE PARAMETERS TABLE FOR THIS MEDIA TYPE, (LAH) - OOH, CY = 0, TRACK AND SECTORS/TRACK COMBINATION IS SUPPORTED - OCH, CY = 1, TRACK AND SECTORS/TRACK COMBINATION IS NOT SUPPORTED - OCH, CY = 1, TRACK AND SECTORS/TRACK COMBINATION IS NOT SUPPORTED - OCH, CY = 1, THACTION IS NOT AYARABLE - OCH, CY = 1, THE OUT CONSCIPLINATION TO SUPPORTED DISK CHANGE STATUS IS ONLY OFFICERED WHEN A MEDIA SPECIFIED IS OTHER THAN 360 KB DRIVE. NOT THE OIS KCHANGE LINE IS FOUND TO BE ACTIVE THEMPT TO RESET DISK CHANGE LINE TO INACTIVE STATE. IF ATTEMPT SUCCEEDS SET DASD TYPE FOR FORMAT AND RETURN DISK CHANGE ERROR COPE IF ATTEMPT FALLS RETURN TIMEOUT ERROR CODE AND SET DASD TYPE IF THE DISK CHANGE LINE IN INACTIVE PERFORM SET DASD TYPE FOR FORMAT. DATA VARIABLE -- GOISK POINTER DOUBLE WORD POINTER TO THE CURRENT SET OF DISKETTE PARAMETERS DOUBLE WORD POINTER TO THE CURRENT SET OF DISKETTE PARAMETERS OUTPUT FOR ALL FUNCTIONS AH = STATUS OF OPERATION YARIABLE IN THE DATA SEGMENT OF THIS MODULE CY = 0 SUCCESSFUL OPERATION (AH=0 ON RETURN, EXCEPT FOR READ DASD TYPE AMP(B)) CY = 1 THE EMPERATION (AH=0 ON RETURN, EXCEPT FOR READ DASD CY = 1 SUCCESSFUL OPERATION (AH=0 ON RETURN, EXCEPT FOR READ DASD CY = 1 THE EMPERATION (AH=0 ON RETURN, EXCEPT FOR READ DASD CY = 1 COUNT OF SECTORS TRANSFERRED DS, BX, DX, CX PRESERVED NOTE: IF AN ERROR IS REPORTED BY THE DISKETTE CODE, THE APPROPRIATE ACTION IS TO RESET THE DISKETTE, THEN RETRY THE OPERATION. ON READ ACCESSES, NO MOTOR START DELAY IS TAKEN, SO THAT THREE RETRIES ARE REQUIRED ON READS TO ENSURE THAT THE PROBLEM IS NOT DUE TO MOTOR START-UP. z SERVED 1 000: 360K IN 360K DRIVE UNESTABLISHED 001: 360K IN 1.2M DRIVE UNESTABLISHED 001: 360K IN 1.2M DRIVE UNESTABLISHED 011: 360K IN 360K DRIVE USTABLISHED 101: 360K IN 360K DRIVE ESTABLISHED 101: 1.2M IN 1.2M DRIVE ESTABLISHED 1101: RESERVED 111: NONE OF THE ABOVE DRIVE) ------ DATA TRANSFER RATE FOR THIS DRIVE: 00: 500 KBS 01: 300 KBS 10: 250 KBS 11: RESERVED STATE OPERATION STARTED - ABSOLUTE ADDRESS 40:92 (DRIVE A) 4 93 (DRIVE B) PRESENT CYLINDER NUMBER - ABSOLUTE ADDRESS 40:94 (DRIVE A) 4 95 (DRIVE B) ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-3 PAGE 46674901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8901-234-667-8 MD STRUC MD SPECI MD SPECI MD SPECI MD SPECI MD SPECZ MD BYT SEC MD GAP MD TL MD GAP MD TL MD FIL BYT MD TD TIM MD STR TIM MD STR TIM MD STR TIM MD STR TRUC I SRT#D, HO UNLOAD=OF - IST SPECIFY BYTE HO LOAD=1. MODE#DMA - 2ND SPECIFY BYTE 1 WAIT TIME AFTER OPERATION TILL MOTOR OFF I 512 BYTES/SECTO OF RATA EOT (LAST SECTOR ON TRACK) I GAP LENGTH OTL I GALL BYTE FOR FORMAT HEAD SETTLE TIME (HILLI SECONDS) MOTOR START TIME (1/8 SECONDS) MAX. TRACK NUMBER I DATA TRANSFER RATE 0000 77 0001 77 0002 77 0003 77 0004 77 0006 77 0006 77 0008 77 0008 77 0008 77 = 007F = 0080 BITTOFF BITTON EQU 7FH 80H DISK_INT_I SEEK DSKETTE_SETUP DISKETTE_10_1 CMOS_READ:NEAR DDS:NEAR DISK_BASE:NEAR WA!TF:NEAR 0000 SEGMENT BYTE PUBLIC ASSUME CS:CODE.DS:DATA.ES:DATA DRIVE TYPE TABLE OI DRIVE TYPE, MEDIA TABLE OFFSET MD_TBL1 02+BITTON OFFSET MD_TBL3 03 OFFSET MD_TBL3 03 OFFSET MD_TBL4 04+BITTON OFFSET MD_TBL6 OFFSET MD_TBL6 OFFSET MD_TBL6 OFFSET MD_TBL6 OFFSET MD_TBL6 0000 01 0001 0012 R 0003 82 0004 001F R 0006 02 0007 002C R 0009 03 000A 0039 R 000C 84 000C 84 000F 04 0010 0053 R = 0012 = 0015 DR_DEFAULT DR_TYPE_E DR_CAT_ EQU (DR_TYPE_E-DR_TYPE)/3 MEDIA/DRIVE PARAMETER TABLES ; END OF TABLE (DR_TYPE_E-DR_TYPE)/3 360 KB MEDIA IN 360 KB DRIVE LABEL BYTE 210111118 MOTOR_WAIT 29 02AH 0FFH 050H 050H 15 39 RATE_250 0012 0012 DF 0013 02 0014 25 0016 02 0017 2A 0018 F6 0019 F0 0014 F6 001B 08 001D 27 I SRT=D, MD UNLOAD=OF - IST SPECIFY BYTE HO LOAD=I, MODGEDMA - 2ND SPECIFY BYTE 1 WAIT TIME AFTER OPERATION TILL MOTOR OFF 512 BYTES/SECTOR EOT (LAST SECTOR ON TRACK) I GAP LENGTH OF LENGTH FOR FORMAT I FILL BYTE FOR FORMAT I FILL BYTE FOR FORMAT I HEAD SETTLE TIME (HILLISECONDS) MOTOR START TIME (1/8 SECONDS) MAX. TRACK NAMBER I DATA TRANSFER RATE DB 340 KB MEDIA IN 1.2 MB DRIVE : LABEL BYTE 11011111B 2 MOTOR_WAIT 2 09 02AH 050H 056H 115 89 RATE_300 001F 001F DF 0020 02 0021 25 0022 02 0023 09 0024 2A 0025 FF 0026 50 0027 F6 0028 08 0029 08 0024 27 SRTED, MD UNLOADEDF - IST SPECIFY BYTE MD LOADEI. MODE-DMA - 2ND SPECIFY BYTE 9 19 12 BYTES/SECTO PERATION TILL MOTOR OFF 512 BYTES/SECTO ON TRACK) GAP LENGTH OF LENGTH OF FORMAT OF LENGTH FOR FORMAT HEAD SETTLE TIME (MILLISECONDS) MOTOR START TIME (1/8 SECONDS) MAX. TRACK MAMBER DATA TRANSFER RATE i 1.2 MB MEDIA IN 1.2 MB DRIVE : 002C 002C DF 002D 02 002E 25 002F 02 0033 0F 0031 1B 0032 FF 0033 54 0034 F6 0036 08 0037 4F 0038 00 LABEL BYTE 1101111118 2 MOTOR_WAIT 2 15 01BH 0FFH 054H 0F6H 15 I SRT-D, MO UNLOAD-OF - IST SPECIFY BYTE HO LOAD-I, MODE-DMA - 2ND SPECIFY BYTE 1 WAIT TIME AFTER OPERATION TILL MOTOR OFF 1 512 BYTES/SECTOR ON TRACK) I GAP LENGTH DTL I GAP LENGTH FOR FORMAT 1 ILAS TECTOR ON TRACK) I GAP LENGTH FOR FORMAT 1 ILAS TECTOR OF TOWN 1 ILAS TECTOR OF TOWN 1 ILAS TECTOR OF TOWN 1 IMOTOR START TIME (1/8 SECONDS) 1 MAX. TRACK NUMBER 1 DATA TRANSFER RATE 8 79 RATE_500 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE =- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-4 720 KB MEDIA IN 720 KB DRIVE LABEL BYTE 110111118 2 MOTOR_WAIT 2 09 02AH 0FFH 050H 0F6H 15 8 79 RATE_250 0039 0039 DF 003A 02 003B 25 003C 02 003D 09 003E 2A 003F 0040 50 0041 F6 0042 08 0044 4F 0045 80 ; SRT=D, HO UNLOAD=OF - IST SPECIFY BYTE HO LOAD=1, MODE=DMA - 2ND SPECIFY BYTE 1 WAIT TIME AFTER OPERATION TILL MOTOR OFF 5 12 BYTES/SECTOR 1 GAP LENGTH 1 GAP LENGTH 1 FILL BYTE FOR FORMAT 1 FILL BYTE FOR FORMAT 1 HEAD SETTLE TIME (1/8 SECONDS) 1 MAX. TRACK NUMBER 1 DATA TRANSFER RATE 08 08 08 08 08 08 08 08 08 720 KB MEDIA IN 1.44 MB DRIVE LABEL SYTE 11011111B 2 MOTOR_WAIT 2 09 02AH 0FFH 050H 0F6H 15 8 79 RATE_250 0046 0046 DF 0047 02 0048 25 0049 02 0048 2A 004C FF 004D 50 004E F6 004F 0F 0050 08 0051 4F 0052 80 SRTED, HD UNLOAD=OF - IST SPECIFY BYTE HD LOAD=1, MODE=DMA - 2ND SPECIFY BYTE WAIT THE AFTER OPERATION TILL MOTOR OF 1 512 BYTES/SECTOR 1 GAP LENGTH 1 GAP LENGTH 1 DT LENGTH FOR FORMAT 1 CPL 1 HEAD SETTLE TIME (MILLISECONDS) 1 MAX. TRACK NUMBER 1 DATA TRANSFER RATE 08 08 08 08 08 08 08 08 08 08 08 1.44 MB MEDIA IN 1.44 MB DRIVE : LABEL BYTE 10101111B 2 MOTOR_WAIT 2 18 01BH 0FFH 06CH 0F6H 15 8 79 RATE_500 SRTEA, MD UNLOAD-OF - IST SPECIFY BYTE HD LCAD-1. MODE-DMA - 2ND SPECIFY BYTE 1912 BYTE 1914 AFTER OFFER IN TILL MOTOR OFF 1912 BYTES/SECTOR ON TRACK) 1 GAP LENGTH 10 AFTER INTERPRETATION TRACK) 1 GAP LENGTH FOR FORMAT 1 FILL BYTE FOR FORMAT 1 FILL BYTE FOR FORMAT 1 HEAD SETTLE TIME (1/8 SECONDS) 1 MAX. TRACK NUMBER 1 DATA TRANSFER RATE 08 08 08 08 08 08 08 08 08 08 08 ;>>> ENTRY POINT FOR ORG GEC89H ; INTERRUPTS BACK ON USER REGISTER ; USER REGISTER ; USER REGISTER ; BUFFER OFFSET PARAMETER OR REGISTER ; BUFFER OFFSET PARAMETER OR REGISTER ; BUFFER OFFSET PARAMETER OR REGISTER ; BAP | SECTOR # [BP+] SECTOR # [BP+] SECTOR # [BP+2] SUFFER OFFSET ; CL/[BP] BITS TAGE HAS SECONS ARACK [CH/[BP+] BITS TAGE HAS SECONS ARACK [CH/[BP+]] BITS TAGE HAS SECONS ARACK [BL/[BP+2] BITS TAGE HAS SECONS ARACK [BL/[BP+3] SORIVES INSTALLED [BL/[BP+3] ORIVES INSTALLED [BL/[BP+4] SORIVES INSTALLED [BL/[BP+4] SORIVES INSTALLED [BL/[BP+3] ORIVES INSTALLED [BL/[BP+4] SORIVES INSTALLED [BL/[BP+5] SORIVES INSTALLED [BL/[BP+6] SOFFSET TO DISK BASE [BUFFER SECUMENT PARM OR USER REGISTER USER REGISTERS USER REGISTERS SECUMENT OF BIOS DATA AREA TO DS CHECK FOR > LARGEST FUNCTION ; REPLACE WITH KNOWN INVALID FUNCTION PROC 0060 DISKETTE_IO_1 :>>> ENTRY POINT FOR ORG DEC59H 0060 FB 0061 55 0062 57 0063 52 0064 53 0065 51 0066 8B EC STI PUSH PUSH PUSH PUSH PUSH MOV 0068 1E 0069 56 006A E8 0000 E 006D 80 FC 19 0070 72 02 0072 B4 14 PUSH PUSH CALL CMP JB MOV 0074 80 FC 01 0071 76 0C 0079 80 FC 08 007C 74 07 007E 80 FA 01 0081 76 02 0083 B4 14 CMP JBE CMP JZ CMP JBE MOV RESET OR STATUS ? IF RESET OR STATUS DRIVE ALWAYS OK READ DRIVE PARMS ? IF SO DRIVE CHECKED LATER DRIVES O AND I OK IF O OR I THEM JUMP REPLACE WITH KNOWN INVALID FUNCTION 0085 8A CC 0087 32 ED 0087 9D E1 0088 HB 0085 R 0088 BB 0095 R 0088 BB 0095 R 0090 8A E6 0092 32 F6 0094 8B F0 0096 8B FA 0098 8A 26 0041 R 0098 C6 06 0041 R CL = FUNCTION CX = FUNCTION CX = FUNCTION TIMES 2 LOAD START OF FUNCTION TABLE ADD OFFST INTO TABLE => ROUTINE AX = HEAD 0, 0 OF SECTORS OR DASD TYPE DI = SECTORS OR DASD TYPE DI = DIVE 0 LOAD STATUS TO AH FOR STATUS FUNCTION INITIALIZE FOR ALL OTHERS CL, AH CH, CH CL, I BX, OFFSET FNC_TAB BX, CX AH, DH DH, DH SI, AX DI, DX MOV XOR SHL MOV ADD MOV XOR MOV MOV MOV AH, ODSKETTE_STATUS ODSKETTE_STATUS, 0 THROUGHOUT THE DISKETTE BIOS, THE FOLLOWING INFORMATION IS CONTAINED IN THE FOLLOWING MEMORY LOCATIONS AND REGISTERS. NOT ALL DISKETTE BIOS FUNCTIONS REQUIRE ALL OF THRES PARAMETERS. ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-5 04-21-86 DI : DRIVE # SI-HI : HEAD # SI-HI : HEAD # SI-LOW : F OF SECTORS OR DASD TYPE FOR FORMAT ES : BUFFER SEGMENT [BP] : SECTOR # [BP] : TRACK # [BP+2] : DFFER OFFSET \frac{44454556789012345567890123345567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334567890123345678901233456789012334 ACROSS CALLS TO SUBROUTINES THE CARRY FLAG (CY=1), WHERE INDICATED IN SUBROUTINE PROLOGUES, REPRESENTS AN EXCEPTION RETURN (NORMALLY AN ERROR COMDITION). IN MOST CASES, WHEN CY = 1, **OBSKETTE_STATUS CONTAINS THE SPECIFIC ERROR CODE. ; (AH) = ODSKETTE_STATUS : CALL THE REQUESTED FUNCTION CALL WORD PTR CS:[BX] 00A1 2E: FF 17 00A4 5E 00A5 1F 00A6 59 00A7 5B 00A9 5F 00A9 5F 00A0 8B EC 00AC 50 00AD 9C 00AD 9C 00AD 56 SI DS CX BX DX DI BP, SP POP POP POP POP POP MOV PUSH PUSHF POP MOV POP POP IRET : RESTORE ALL REGISTERS AX [BP+6],AX AX BP AH = 00H; RESET; AH = 00H; STATUS; AH = 02H; READE; AH = 02H; READE; AH = 03H; BEIFY; AH = 05H; FORMAT; AH = 05H; FORMAT; AH = 05H; FORMAT; AH = 05H; FORMAT; AH = 05H; INVALID; 10H; INVALID; AH = 10H; INVALID; AH = 10H; INVALID; AH = 15H; SET MEDIA TYPE; AH = 15H; SET MEDIA TYPE; AH = 15H; SET MEDIA TYPE; AND SHATEMATICAL STATUS; STAT 0085 00E7 R 0087 R 1 0087 R 1 0087 R 1 0088 R 1 0154 R 1 0088 R 1 0154 R 1 0087 DISK RESET DISK STATUS TO DISK STATUS DISK STATUS DISK STATUS DISK STORMAT FOR ERR ENDP (AH = 00H) THE DISKETTE SYSTEM. ON EXIT: ODSKETTE_STATUS, CY REFLECT STATUS OF OPERATION PROC NEAR DX, 03F2H IND INTERRUPTS IND INTERRUPTS DISK_RESET MOV CLI MOV AND ROL : ADAPTER CONTROL PORT IN INTERRUP'S INTERRUP 00E7 00E7 BA 03F2 00EA FA 00EB AO 003F R 00EE 24 3F 00F0 CO CO 04 AL, OMOTOR_STATUS AL,001111T1B AL,4 AL,00001000B DX,AL •SEEK_STATUS,0 $+2 $+2 00F3 0C 08 00F5 EE 00F6 C6 06 003E R 00 00FB EB 00 00FD EB 00 OR OUT MOV JMP JMP 00FD EB 00 00FF 0C 04 0101 EE 0102 FB 0103 E8 0AC1 R 0106 72 2D 0108 B9 00C0 OR OUT STI CALL JC MOV AL,00000100B DX,AL WAIT_INT DR_ERR CX,11000000B 0108 89 00C0 0108 51 010C B8 0134 R 010F 50 0110 B4 08 0112 E8 09F8 R 0116 56 0AE9 R 0119 59 117 0110 34 0E 0042 R 0120 75 C1 NXT_DRV: PUSH MOV PUSH MOV CALL POP CALL POP JC CMP JNZ INC CMP JBE CX. OFFSET DR_POP_ERR AX. OFFSET DR_POP_ERR AX. AH, 00H NEC_OUTPUT AX RESULTS CX DR_ERR CL_TOMEC_STATUS DR_ERR CL_(L, | 1000011B NXT_DRY ; SAVE FOR CALL ; LOAD NEC_OUTPUT ERROR ADDRESS SENSE INTERRUPT STATUS COMMAND I THROW AWAY ERROR RETURN I READ IN THE RESULTS RESTORE AFTER CALL I ERROR RETURN I TEST FOR DRIVE READY TRANSITION I EVERTIFIED ONCE STATUS ILL POSSIBLE DRIVES CLEARED I FALL THRU IF II000100B OR > 0129 E8 03D8 R : SEND SPECIFY COMMAND TO NEC CALL SEND_SPEC 012C 012C E8 0854 R 012F 8B DE 0131 8A C3 0133 C3 RESBAC: ; VARIOUS CLEANUPS ; GET SAVED AL TO BL ; PUT BACK FOR RETURN 0134 0134 59 0135 0135 80 0E 0041 R 20 013A EB F0 013C DR_POP_ERR: CX ; CLEAR STACK ODSKETTE STATUS, BAD_NEC ; SET ERROR CODE SHORT RESBAC ; RETURN FROM RESET ENDP DR_ERR: OR JMP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-6 04-21-86 DISK_STATUS (AH = 01H) DISKETTE STATUS. ON ENTRY: AH = STATUS OF PREVIOUS OPERATION PROC NEAR OSKETTE_STATUS, CY REFLECT STATUS OF OPERATION: PROC NEAR OSKETTE STATUS, AH SETUP_END STUP_END STUP_END HE GET SAYED AL TO SIL FUT BACK FOR RETURN ON EXIT: DISK_STATUS MOV CALL MOV MOV RET DISK_STATUS ENDP PROC NEAR MOTOR STATUS, CY REFLECT STATUS OF OPERATION: PROC NEAR MOTOR STATUS, 01111111B; INDICATE A READ OPERATION AX, 0E6786H; AX = NEC COMMAND, DMA COMM RD_WR_VF; COMMON READ/WRITE/VERIFY ON EXIT: DISK_READ AND CALL RET DISK_READ 1 DISK_WRITE 1 DISKETT 1 DISKETT 1 DISKETT ENDP (AH = 03H) TE WRITE. 01 = DRIVE # 01 = DRIVE # SI-LOW = # OF SECTORS EEP1 = BUFFER SEGMENT [BP+1] = RECORE BP+2] = BUFFER OFFSET DISK_WRITE MOV AX.0. OR MONTON CALL RD WR_VF RET DISK_WRITE END I DISK_VERF (AM = 04H) I ON ENTRY: SI-HI = HEAD # BUFFER SEMENT [SP] = BUFFER OFFSET ### BP+2] = BUFFER OFFSET ### BP+2] = BUFFER OFFSET ### BP+2] = BUFFER OFFSET ** STATUS, 01111111 PROC NEAR AX,0054AH RD GATTUS,10000000B INDICATE WRITE OPERATION COMMON READ/WRITE/VERIFY PROC NEAR MOTOR STATUS, CY REFLECT STATUS OF OPERATION: PROC NEAR MOTOR STATUS, 011111118; INDICATE A READ OPERATION AX, 0267421 AX = NEC COMMAND, DMA COMMAND RD_WR_VF; COMMON READ/WRITE/VERIFY OISK_VERF AND MOV CALL CALL DISK_VERF DISK_FORMAT DISKET ON ENTRY: ENDP (AH = 05H) E FORMAT. DI = 1 HEAD $ SI-LOW = 6 OF SECTORS ES = BUFFER SEGMENT [BP] = SECTOR $ [BP+1] = TRACK $ FOR SECTOR $ ES = BUFFER OFFSET FOR SECTOR $ THIS DRIVE **SOSKETTE STATUS, CY REFLECT STATUS OF OPERATION: PROC NEAR KLAT NEW : TRANSLATE STATE TO PRESS FMT TNIT **MOTOR STATUS, 10000000 B: INDICATE WRITE OPERATION MED CHÂNGE : CHECK MEDIA CHANGE AND F **MOTOR STATUS, 10000000 B: INDICATE WRITE OPERATION MED CHÂNGE : CHECK MEDIA CHANGE AND F **MOTOR STATUS, 10000000 B: INDICATE WRITE OPERATION MED CHÂNGE : CHECK MEDIA CHANGE AND F **MOTOR STATUS, 10000000 B: INDICATE WRITE OPERATION CHECK STATUS, 100000000 B: INDICATE WRITE STATE CHECK STATUS, 100000000 B: INDICATE WRITE STATE SEND DATA RATE I SEND DATA RATE TO CONTROL **MOTOR STATUS STATE ST ON EXIT: 016C 53 040F R 019C 53 049F R 019C 53 049F R 019T 28 0 0509 R 017T 0500 R 018C 54 050 R 018C 54 050 R 018C 55 070 R 018C 55 070 R 019C 55 050 DISK_FORMAT CALL CALL OR CALL JC CALL JC CALL JZ CALL FM WR: I TRANSLATE STATE TO PRESENT ARCH. I ESTABLISH STATE IF UNESTABLISHED I INDICATE WRITE OFFERATION CHECK MEDIA CHANGE AND RESET IF SO MEDIA CHANGED, SKIP SEND SPECIFY COMMAND TO NEC I ZFI ATTEMPT RATE IS SAME AS LAST RATE I YEI, SKIP STECIFY COMMAND. SEND_RATE FMTDMA_SET FM_DON ANI_O4DH NEC_INIT FM_DON AX, OFFSET FM_DON AX, OFFSET FM_DON DL, 4 GET_PARM NEC_OUTPUT DL, 7 GET_PARM NEC_OUTPUT DL, 7 GET_PARM NEC_OUTPUT DL, 7 GET_PARM NEC_OUTPUT DL, 7 SET UP THE DMA FOR FORMAT RETURN WITH ERROR ESTABLISH THE FORMAT COMMANO INITIALIZE THE NEC ERROR - EXIT LOAD ERROR ADDRESS PUSH NEC OUT ERROR RETURN BYTES/SECTOR VALUE TO NEC CALL JC MOV PUSH MOV CALL CALL MOV CALL MOV CALL 5 ; SECTORS/TRACK VALUE TO NEC ; GAP LENGTH VALUE TO NEC ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE 8:0S (DSK2.ASM) 01AF 82 08 01B1 E8 0995 R 01B4 E8 0996 R 01B7 58 01B8 E8 075B R 01B8 E8 075B R 01BB E8 0435 R 01BB E8 0435 R 01BB E8 0435 C 01C1 80 DE 01C3 8A C3 01C5 C3 MOV CALL CALL POP CALL DL,8 GET_PARM NEC_OUTPUT AX NEC_TERM : FILLER BYTE TO NEC ; THROW AWAY ERROR ; TERMINATE, RECEIVE STATUS, ETC. FM_DONI CALL XLAT OLD ; TRANSLATE ST CALL SETUF_END ; VARIOUS CLEA MOV BX SI ; GET SAVED AA MOV AL BL ; PUT BACK FOR DISK_FORMAT ENDP FNC_ERR INVALID FUNCTION REQUESTED OR INVALID DRIVE; SET BAD COMMAND IN STATUS. TRANSLATE STATE TO COMPATIBLE MODE VARIOUS CLEANUPS GET SAVED AL TO BL PUT BACK FOR RETURN ODSKETTE_STATUS, CY REFLECT STATUS OF OPERATION : NEAR AX, STATE ADA COMMAND ERROR ODSKETTE_STATUS, AH SET CARRY INDICATING ERROR I SET DA COMMAND ERROR I STORE IN DATA AREA I SET CARRY INDICATING ERROR ON EXIT: FNC_ERR PROC MOV MOV STC RET FNC_ERR ENDP PROC NEAR XLAT NEW : TRANSLATE STATE TO PRES WORD PTR [8P+2],0 AX, **eGUIP FLAG AL, 11000001B CAL, 1000001B 10000001B CAL, 1000001B DISK_PARMS CALL MOV MOV AND MOV CMP JZ 01D0 01D0 E8 040F R 01D3 C7 46 02 0000 01D8 A1 0010 R 01DB 24 C1 01DD 82 02 01DF 3C 41 01E1 74 06 : TRANSLATE STATE TO PRESENT ARCH. : DRIVE TYPE = 0 : LOAD EQUIPMENT FLAG FOR # DISKETTES : KEEP DISKETTE DRIVE BITS : DISKETTE DRIVES : : 2 DRIVES : INFALLED 7 : IF YES JUMP 01E3 FE CA 01E5 3C 01 01E7 75 6A DEC CMP JNZ ; DISKETTE DRIVES = 1 ; 1 DRIVE INSTALLED ? ; IF NO JUMP DL AL,00000001B NON_DRY I IF NO JUMP STORE NUMBER OF DRIVES; CHECK FOR VALID DRIVE DRIVE INVALID MAXIMM HEAD NUMBER = 1 RETURN DRIVE TYPE IN AL ON CMOS BAD CHECK ESTABLISHED THE FOR MO DRIVE TYPE I THE FOR MO DRIVE TYPE RTH CS:EX = MEDIA/DRIVE PARAM TBL TYPE NOT IN TABLE (POSSIBLE BAD CMOS) STORE VALID CMOS DRIVE TYPE GET MAX. TRACK NUMBER CMOS GOOD, USE CMOS STO_DL: MOV CMP JA MOV CALL JC CALL JC CALL JC JC MOV MOV MOV MOV JMP NON_DRY [BP+4],DL D1,1 NON DRY! BYE PTR[BP+6],1 CMC EYF CMC EYF CMC EYF CMC EYF CMC EYF CMC EYF CHC EST 01E7 75 6A 01E9 88 66 04 01EC 83 FF 01 01EF 77 66 05 01 01FF 72 16 01FA 72 16 01FA 72 16 01FC 74 12 01FE E8 03BR 7 0201 72 00 0203 88 46 02 0206 2E: 8A 4F 04 020A 2E: 8A 6F 0B CHK_EST: MOV TEST JZ 0210 0210 8A A5 0090 R 0214 F6 C4 10 0217 74 3E LOAD STATE FOR THIS DRIVE CHECK FOR ESTABLISHED STATE CMOS BAD/INVALID AND UNESTABLISHED ; ISOLATE STATE ; RATE 250 ? ; NO, GO CHECK OTHER RATE TABLE FIRST :--- DATA RATE IS 250 KBS, DRIVE TYPE ! (360KB) ; RTN C$;BX = MEDIA/DRIVE PARAM TBL ; GET SECTOR/TRACK ; GET MAX, TRACK NUMBER ; 80 TRACK ? ; MUST BE 360KB DRIVE 0221 B0 01 0223 E8 03B8 R 0226 2E: 8A 4F 04 022A 2E: 8A 6F 0B 022E F6 85 0090 R 01 0233 74 0D PARM1441 MOV CALL MOV MOV 0235 0235 B0 04 0237 E8 03B8 R 023A 2E: 8A 4F 04 023E 2E: 8A 6F 0B ; DRIVE TYPE 4 (1.44MB) ; RTN CS:BX = MEDIA/DRIVE PARAM TOL ; GET SECTOR/TRACK ; GET MAX. TRACK NUMBER 0242 0242 89 4E 00 0245 89 5E 06 0248 8C C8 024A 8E C0 ; SAVE IN STACK FOR RETURN ; ADDRESS OF MEDIA/DRIVE PARM TABLE ; SEGMENT MEDIA/DRIVE PARAMETER TABLE ; ES IS SEGMENT OF TABLE ; TRANSLATE STATE TO COMPATIBLE MODE ; CLEAR 024C E8 0435 R 024F 33 C0 0251 F8 0252 C3 XLAT_OLD ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-8 04-21-86 177797779901234566171990123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456617090123456 0253 0253 C6 46 04 00 SYTE PTR [SP+4],0 ; CLEAR NUMBER OF DRIVES XLAT_OLD AX,ST AH,BAD_CMD : ELSE TRANSLATE TO COMPATIBLE MODE : RESTORE AL : SET BAD COMMAND ERROR : SET ERROR RETURN CODE 0266 0266 33 CO 0268 89 46 00 0268 88 66 05 026E 89 46 06 0271 8E CO 0273 EB D7 NON_DRV2: XOR MOV MOV MOV MOV JMP : CLEAR PARMS IF NO DRIVES OR CMOS BAD ; TRACKS, SECTORS/TRACK = 0 ; HEAD = 0 ; OFFSET TO DISK BASE = 0 ; ES IS SÉGMENT OF TABLE :--- DATA RATE IS EITHER 300 KBS OR 500 KBS, TRY 1.2 MB TABLE FIRST USE_EST2: MOV CALL MOV MOV CMP JE JMP 0275 0275 B0 02 0277 E6 03858 R 027A 2E: 8A 4F 04 027E 2E: 8A 6F 0B 0282 80 FC 40 0285 74 BB 0287 EB AC DRIVE TYPE 2 (1.2MB) IRTH CS:BX = MEDIA/DRIVE PARAM TBL GET SECTOR/TRACK GET MAX. TRACK NUMBER RATE 300 : ZMB DRIVE ELSE, IT SI -4.4MB DRIVE ENDP 0289 DISK_PARMS DISK_TYPE (AH = 15H) THIS ROUTINE RETURNS THE TYPE OF MEDIA INSTALLED. ON ENTRY: DI = DRIVE # ON EXIT: AH = DRIVE TYPE, CY=0 DISK_TYPE CALL MOV OR JZ MOV TEST JZ MOV PROC NEAR XLAT NEW AL, #OSK_STATE[D!] AL, AL NO_DRV AH, NOCHGLN AL, TRK CAPA DT_BACK AH, CHGLN NO CHANGE LINE FOR 40 TRACK DRIVE IS THIS DRIVE AN 80 TRACK DRIVE? IF NO JUMP CHANGE LINE FOR 80 TRACK DRIVE 029C 50 029C 50 029D E6 0435 R 02A0 56 02A1 F8 02A2 80 DE 02A4 6A C3 02A6 C3 02A7 32 E4 02A7 32 E4 ; SAVE RETURN VALUE ; TRANSLATE STATE TO COMPATIBLE MODE ; RESTORE RETURN VALUE ; MO ERROR ; GET SAVED AL TO BL ; PUT BACK FOR RETURN AX XLAT_OLD AX AH,AH SHORT DT_BACK DISK_CHANGE (AH = 16H) THIS ROUTINE RETURNS THE STATE OF THE DISK CHANGE LINE. DI = DRIVE # AH = ## ODSKETTE STATUS 00 - DISK CHANGE LINE INACTIVE, CY = 0 : 06 - DISK CHANGE LINE ACTIVE, CY = 1 : PROC NEAR XLAT NEW XLAT NEW LITERANSLATE STATE TO PRESE AL, AL LOSK STATE[DI] AL, AL CON STATE INFORMAT LITERANSLATE STATE INFORMAT LITERANSLATE STATE INFORMAT I DRIVE PRESENT SETIT | JUMP IF NO DRIVE ALTRK CAPA | 180 TRACK DRIVE? SETIT | 18 TRACK DRIVE? DISK_CHANGE CALL MOV OR JZ TEST JZ DC0: READ_DSKCHING FINIS DOSKETTE_STATUS, MEDIA_CHANGE ; INDICATE MEDIA REMOVED 02BF C6 06 0041 R 06 SETIT: MOV 02C4 E8 0435 R 02C7 E8 0854 R 02CA 88 DE 02CC 8A C3 02CE C3 XLAT_OLD SETUP_END BX,SI AL,BL FINIS: CALL CALL MOV MOV RET TRANSLATE STATE TO COMPATIBLE MODE VARIOUS CLEANUPS GET SAVED AL TO BL PUT BACK FOR RETURN 02CF 02CF 80 0E 0041 R 80 02D4 EB EE 02D6 ODSKETTE STATUS, TIME_OUT ; SET TIMEOUT, NO DRIVE SHORT FIRIS ENDP FORMAT SET (AH = 17H) THIS ROUTINE IS USED TO ESTABLISH THE TYPE OF MEDIA TO BE USED FOR THE FOLLOWING FORMAT OPERATION. SI LOW = DASD TYPE FOR FORMAT DI = DRIVE # ON ENTRY: ODSKETTE STATUS REFLECTS STATUS AH = ODSKETTE STATUS CY = 1 IF ERRÖR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 908 02D6 E8 040F R 910 02D6 E8 040F R 911 02DA 88 C6 911 02DA 88 C6 912 02DC 82 E6 914 02E0 82 A8 0090 R 0P 914 02E0 82 A8 0090 R 0P 915 02E0 82 A8 0090 R 0P 916 02E6 78 07 917 02E6 82 05EP R 920 02E7 80 3E 0041 R 80 921 02E7 80 3E 0041 R 80 922 02E7 80 3E 0090 R 70 923 02E7 15 07 924 02E7 80 00 0090 R 70 925 02E7 15 07 927 02E7 15 07 927 02E7 15 07 927 02E7 15 07 927 02E7 15 07 928 02E7 15 07 928 02E7 15 07 929 FORMAT_SET CALL PUSH MOV XOR MOV AND DEC JNZ OR JMP MED_CHANGE ODSRETTE_STATUS, TIME_OUT S0 ; IF TIME OUT TELL CALLER CALL CMP JZ SI : CHECK FOR 920/360K IN 1.2M DRIVE NOT 320 12 ; BYPASS IF NOT ODSK_STĀTE[DI],MED_DET+DBL_STEP+RATE_300 ; SET STATE SHORT 50 DEC JNZ OR JMP NOT_320_12: DEC JNZ OR JMP $1 ; CHECK FOR 1.2M MEDIA IN 1.2M DRIVE NOT 12 ; BYPASS IF NOT 000K STATE[DI], MED_DET+RATE 500 ; SET STATE VARIABLE SHORT SO ; RETURN TO CALLER NOT_12: DEC : CHECK FOR SET DASD TYPE 04 : BAD COMMAND EXIT IF NOT VALID TYPE TEST JZ MOV TEST JNZ OSK_STATE[DI], DRY_DET ; DRIVE DETERMINED ? ASSUME ASSUME: MOV AL, MED_DET+RATE_250 ODSK_STATE[DI],AL OR IN THE CORRECT STATE CALL CALL POP MOV RET ; TRANSLATE STATE TO COMPATIBLE MODE ; VARIOUS CLEANUPS ; GET SAYED AL TO BL ; PUT BACK FOR RETURN XLAT_OLD SETUP_END ex AL,BL *DSKETTE_STATUS, BAD_CMD ; UNKNOWN STATE, BAD COMMAND SHORT SO SET_MEDIA (ALT 18H) THIS ROTTINE SETS THE TYPE OF MEDIA AND DATA RATE TO BE USED FOR THE FOLLOWING FORMAT OPERATION. ON ENTRY! [BP] = SECTOR PER TRACK [BP+1] = TRACK # ON EXITY SET_MEDIA CALL TEST JZ CALL CMP JE MOV PROC NEAR KLAT NEW 9DSK STATE[DI], TRK_CAPA; TRANSLATE STATE TO PRESENT ARCH. 9M CMOS; JUMP IF 40 TRACK DRIVE MED CHANGE; RESET CHANGE LINE 9DSKETTE_STATUS, TIME_OUT; IF TIME OUT TELL CALLER SM RTN SM_RTN OSKETTE_STATUS,0 : CLEAR STATUS CMOS_TYPE MD_NOT_FND AL_AL SM_RTN DR_TYPE_CHECK MD_NOT_FND DI ; RETURN DRIVE TYPE IN (AL) ; ERROR IN CMOS ; ERROR IN CMOS ; TEST FOR NO DRIVE ; RETURN IF SO ; RTN CSIS = MEDIA/DRIVE PARAM TBL ; TYPE NOT IN TABLE (BAD CMOS) ; SX = RNDEX TO DR_TYPE TABLE ; CX = LOOP COUNT CALL JC OR JZ CALL JC PUSH XOR MOV BX.BX CX,DR_CNT ; GET DRIVE TYPE ; MASK OUT MSB ; DRIVE TYPE MATCH ? ; NO, CHECK NEXT DRIVE TYPE AH,CS:DR_TYPE[BX] AH,BITTOFF MOY AH,CS:[DI].MD_SEC_TRK | GET_SECTOR/TRACK | GPT].AH | MATCH ? | NO. CHECK NEXT MEDIA AH,CS:[DI].MD_MAX_TRK | GET_MAX. TRACK # | MATCH ? | MD_FND | MAX_TRK | GET_MAX. TRACK # | MATCH ? | YES, GO GET_RATE MOV CMP JNE MOV CMP JE BX.3 DR_SEARCH DI ; CHECK NEXT DRIVE TYPE RESTORE REG. *DSKETTE_STATUS,MED_NOT_FND ; ERROR, MEDIA TYPE NOT FOUND SHORT SM RTN ; RETURN ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-10 04-21-86 1022 0394 1026 0394 102 0394 102 0394 102 0394 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 102 0395 1 AL,CS:[DI].MD_RATE AL,RATE_300 MD_SET AL,DBL_STEP GET RATE DOUBLE STEP REQUIRED FOR RATE 300 MD_SET: MOV OR POP AND OR MOV MOV SM_RTN: CALL CALL SET_MEDIA | TRANSLATE STATE TO COMPATIBLE MODE XLAT_OLD SETUP_END RET SET_MEDIA ENDP I DR TYPE CHECK CHECK IT THE GIVEN DRIVE TYPE IN REGISTER (AL) CHECK IT THE GIVEN DRIVE TYPE IN REGISTER (AL) CHECK IT THE GIVEN DRIVE TYPE IN REGISTER (AL) CHECK IT THE GIVEN DRIVE TYPE TABLE ON EXIT: ON EXIT: CHECK IT DRIVE TYPE CHECK PROC C ENDP ; GET DRIVE TYPE ; DRIVE TYPE MATCH ? ; YES, RETURN WITH CARRY RESET ; CHECK NEXT DRIVE TYPE | SEND_SPEC | SEND THE SPECIFY COMMAND TO CONTROLLER USING DATA FROM | THE DRIVE PARAMETER TABLE POINTED BY #DISK_POINTER | ON ENTRY | #DISK_POINTER | DRIVE PARAMETER TABLE | NO EXIT | NOWELL | REGISTERS ALTERED; CX, DX REGISTENS A: SEND_SPEC USH MOSY VOUSH MOSY CALL SUB CALL CALL CALL CALL SPECBACI SEND_SPEC PROC NEAR AX, OFFSET SPECBAC AX ENDP SEND_SPEC MD SEND_SPEC MD SEND THE SPECIFY COMMAND TO CONTROLLER USING DATA PROM : THE MEDIA/DRIVE PARAMETER TABLE POINTED BY (CS:BX) : ON ENTRY: CS:BX = MEDIA/DRIVE PARAMETER TABLE ON EXIT : NOME : NEXIT : NOME : REGISTERS ALTERED: AX : PROC NEAR AX, OFFSET SPEC_ESBAC AX, OFFSET SPEC_ESBAC AX OSTPUT NEC_CUTPUT AH_CSUTPUT AH_CSI_BX].MD_SPEC1 AXCOUTPUT AX AX I REGISTERS ALIE SEND_SPEC_MD MOSH MOV CALL MOV CALL MOV CALL MOV CALL SPEC_ESBAC SPEC_ESBAC SEND_SPEC_MD ; SAVE RATE DATA LOAD ERROR ADDRESS PUSH NEC OUT ERROR RETURN SET OF THE COMMAND GET 1ST SPECIFY BYTE OUTPUT THE COMMAND GET SECOND SPECIFY BYTE OUTPUT THE COMMAND GET SECOND SPECIFY BYTE OUTPUT THE COMMAND POP ERROR RETURN AX : RESTORE RATE ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) DI : DRIVE : PROC NEAR ; VALID DRIVE ? IF INVALID BACK OOSK STATE[D:],0 : NO DRIVE ? OO DET : NO DRIVE ATTEMPT DETERMINE CX,DI : CX = DRIVE NAMBER CL,2 : CL = SHIFT COUNT, A=0, B=4 AL, GL : DRIVE NEORMATION AL, CL NEORMAT XN_OUT: RET DRIVE_DET : TRY TO DETERMINE PROC NEAR DI.I XO_OUT #DSK_STATE[DI],0 XO_OUT ; VALID DRIVE ? ; IF INVALID BACK ; NO DRIVE ? ; IF NO DRIVE TRANSLATE DONE ---- TEST FOR SAVED DRIVE INFORMATION ALREADY SET 174 175 1176 1177 1177 0450 84 07 1178 0452 02 02 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 0456 ;---- ACCESS CURRENT DRIVE BITS AND STORE IN OHF_CNTRL 1185 0460 02 C6 1186 0462 08 06 008F R 1186 0462 08 06 008F R 1187 0466 8A A5 0090 R 1192 0466 8A A5 0090 R 1193 0466 8A A5 0090 R 1193 0466 8A A5 0090 R 1194 0467 80 FC 00 1195 0467 80 FC 00 1195 0467 80 FC 00 1196 0472 74 10 1197 0474 80 07 1198 0476 80 FC 40 1199 0479 75 16 1200 0478 75 17 1200 0478 75 17 1200 0478 75 17 1200 0486 8B 20 1204 0480 80 07 1205 0482 8B 20 1206 0482 8B 20 1206 0482 8B 20 1210 0489 75 75 1210 0489 75 75 1211 0488 75 75 1212 0489 75 75 1213 0487 8B 00 1214 0491 80 00 1215 0491 80 00 1216 0491 80 00 1217 0493 80 FC 80 1218 0496 75 88 1218 0496 75 88 1219 0498 76 C7 01 1220 0499 76 C3 01 1218 0496 75 88 1218 0496 75 88 1218 0496 75 88 1218 0496 75 88 1218 0496 75 88 1218 0496 75 88 1218 0496 75 88 ;---- TRANSLATE TO COMPATIBILITY MODE SAVE_SET: MOV MOV AND CMP JZ MOV CMP JNZ TEST JNZ AH, POSK_STATE[DI] BH, AH AH, RATE_MSK AH, RATE_500 CHK_144 AL, M3D1U AH, RATE_300 CHK_250 BH, DBL, STEP TST_DET ACCESS STATE TO BH FOR LATER KEEP ONLY RATE RATE 500 ? YES, 1,2/1,2 OR 1.44/1.44 AL = 360 IN 1.2 UNESTABLISHED RATE 300 ? NO, 360/360 ,720/720 OR 720/1.44 YES, DOUBLE STEP? YES, MUST BE 360 IN 1.2 CMOS_TYPE UNKNÖ AL,02 UNKNO AL,MIDIU SHORT TST_DET ; RETURN DRIVE TYPE IN (AL) ; ERROR, SET 'NONE OF THE ABOVE' ; 1.2MB DRIVE ? ; NO. GO SET 'NONE OF THE ABOVE' ; AL = 1.2 IN 1.2 UNESTABLISHED CHK_250; MOV CMP JNZ TEST JNZ AL,M3D3U AH,RATE_250 UNKNO BH,TRK_CAPA UNKNO ; AL = 360 IN 360 UNESTABLISHED ; RATE 250 ? ; IF 50 FALL THRU ; 80 TRACK CAPABILITY ? ; IF SO JUMP, FALL THRU TEST DET TST_DET: TEST JZ ADD 1221 0490 1223 0490 F6 C7 10 1224 0440 74 02 1224 0440 74 02 1225 0442 04 03 1226 1226 1227 0444 1227 0444 80 A5 0090 R F8 1229 0449 08 85 0090 R 1230 0440 C3 1230 0440 C3 1230 0440 C3 ; DETERMINED ? ; IF NOT THEN SET ; MAKE DETERMINED/ESTABLISHED AL_SET: AND OR XO_DUT: RET XLAT_OLD ODSK_STATE[DI], NOT DRY_DET+FMT_CAPA+TRK_CAPA ; CLEAR DRIVE ODSK_STATE[DI], AL ; REPLĀCE WITH COMPATIBLE MODE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) PAGE RO_WR_YF COMMON READ, WRITE AND VERIFY; MAIN LOOP FOR STATE RETRIES. ON ENTRY: AH : READ/WRITE/VERIFY NEC PARAMETER AL : READ/WRITE/VERIFY DMA PARAMETER PROC NEAR AX I SAYE DMA, NEC PARAMETER X I SAYE DMA, NEC PARAMETER X I SAYE TO ME STATE TO PRESS SETUP_STATE INITIALIZE STATE AND EM I RESTORM READ/WRITE/VERTI PUSH CALL CALL POP DO_AGAIN: PUSH CALL POP JOC JNC JMC AX MED_CHANGE AX RWV_END RWV_END : SAVE READ/WRITE/VERIFY PARAMETER : MEDIA CHANGE AND RESET IF CHANGED : RESTORE READ/WRITE/VERIFY : MEDIA CHANGE ERROR OR TIME-OUT PUSH AX SAVE READ/WRITE/VERIFY PARAMETER GET RATE STATE OF THIS DRIVE KEEP ONLY RATE OF THIS DRIVE RETURN DRIVE TYPE IN (AL) ERROR IN CMOS 1 40 TRACK DRIVE; 1 NO, BYFASS CMOS VALIDITY CHECK 1 YES, CMOS IS CORRECT 1 CHANGE TO 1.2 M 1 CONTINUE MOV AND CALL JC CMP JNE TEST JZ MOV JMP RWV_1: JB TEST JNZ MOY RWY 2 OSK STATE[DI],TRK_CAPA ; NO DRIVE SPECIFIED, CONTINUE STATE | IS IT REALLY 40 TRACK? NO 80 TRACK INO 80 TRACK IT'S 40 TRACK, FIX CHOS VALUE RWV_2: OR JZ CALL JC : TEST FOR NO DRIVE : ASSUME TYPE, USE MAX TRACK : RTN CS:BX = MEDIA/DRIVE PARAM TBL : TYPE NOT IN TABLE (BAD CMOS) AL, AL RWY ASSUME DR TYPE_CHECK RWV_ASSUME 1219 04E9 74 28 1279 04E9 E8 03B8 R 1280 04EE 72 23 1281 1281 1282 1283 04F0 57 DB 1286 04F1 33 DB 1286 04F3 39 0006 1287 04F6 2E: 8A A7 0000 R 1289 04F8 80 E4 7F 0500 75 DB 1299 0500 75 DB 1299 0500 75 DB 1294 0507 12 E1 3B BF 0001 R 1294 0507 2E1 3B BF 0001 R 1294 0507 2E1 3A 75 0C 1296 050B 74 16 1297 050D 1298 050B 05 E2 E4 1300 0512 9F 1300 0512 9F 1300 0512 9F 1300 0513 BB 0012 R 1300 0510 BB 002C R 1300 0510 BB 002C R 1300 0510 BB 002C R 1300 0510 BB 002C R - SEARCH FOR MEDIA/DRIVE PARAMETER TABLE PUSH XOR MOV RWY_DR_SEARCH1 MOV AND CMP JNE RWY_DR_FND1 MOV CMP RWY_MC_SEARCH1 CMP RWY_MC_SEARCH1 CMP RWY_MC_SEARCH1 CMP RWY_MC_SEARCH1 CMP DI BX,BX CX,DR_CNT ; SAVE ORIVE # ; BX = INDEX TO DR_TYPE TABLE ; CX = LOOP COUNT GET DRIVE TYPE MASK OUT MSB DRIVE TYPE MATCH ? NO, CHECK NEXT DRIVE TYPE AH,CS:DR_TYPE[BX] AH,BITTOFF AL,AH RWV_NXT_MD DI, WORD PTR CS:DR_TYPE[BX+1] ; DI = MEDIA/DRIVE PARAMETER TABLE DH,CS:[DI].MD_RATE RWV_MD_FND ; CHECK NEXT DRIVE TYPE ; RESTORE DRIVE # ;--- ASSUME PRIMARY DRIVE IS INSTALLED AS SHIPPED RWY_ASSUME: MOV TEST JZ MOV JMP BX.OFFSET MD_TBLI : POINT TO 40 TK 250 KBS 405K STATE[OT],TRK_CAPA RAW MD_FND_TBLS : TEST FOR 80 TRACK I MUST BE 40 TRACK I MUST BE 40 TRACK STATE POINT TO 80 TK 500 KBS GO SET SPECIFY PARAMETERS ;--- C5:BX POINTS TO MEDIA/DRIVE PARAMETER TABLE RWV_MD_FND: MÖY POP RWY_MD_FND1: ; BX = MEDIA/DRIVE PARAMETER TABLE ; RESTORE DRIVE # ;--- SEND THE SPECIFY COMMAND TO THE CONTROLLER CALL SEND SPEC_MD CALL CHK_LASTRATE JZ RWY DBL CALL SEND_RATE ; ZF=1 ATTEMPT RATE IS SAME AS LAST RATE ; YES, SKIP SEND RATE COMMAND ; SEND DATA RATE TO NEC SAVE MEDIA/DRIVE FARAM ADDRESS CHECK FOR DDUBLE STEP CHESTORE ADDRESS ERFOR FROM READ ID, POSSIBLE RETRY ERSTORE NEC, DMA COMMAND SAVE NEC COMMAND SAVE NEC COMMAND SAVE NEC COMMAND SAVE NEC COMMAND SAVE MEDIA/DRIVE PARAM ADDRESS SET UP THE DMA RESTORE NEC COMMAND CHECK FOR DMA BOUNDARY ERROR SAVE NEC COMMAND SA BX SETUP_DBL BX SETUP_DBL BX CHK_RET AX AX BX DMA_SETUP BX AX AX BX BX CHK_RET RWY-COM CHK_RET NEC_TERM ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK2.ASM) 1-13 CHK_RET: CALL POP JNC JMP 1347 1348 0552 1349 0552 E8 07E5 R 1350 0555 58 1351 0556 73 03 1352 0558 E9 0486 R RETRY AX RWY_END DO_AGAIN CHECK FOR, SETUP RETRY RESTORE READ/WRITE/VERIFY PARAMETER CY = 0 NO RETRY CY = 1 MEANS RETRY RWV_END: Call Call 1352 0558 E9 0496 R 1353 0558 E9 07AD R 1356 0558 E8 07AD R 1356 0558 E8 0827 R 1357 0561 50 0540 R 1358 0561 50 0554 R 1358 0561 50 0554 R 1359 0565 E8 0435 R 1361 0565 58 0564 R 1362 0565 E8 0435 R 1364 0566 58 0564 R 1365 0566 F6 85 0090 R 1365 0566 F7 52 99 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0571 80 040 1373 0577 F6 85 0090 R 1371 0586 80 A5 0090 R 1372 0586 80 A5 0090 R 1373 0586 80 A5 0090 R 1380 0587 80 0580 0098 R 1381 0585 80 26 0098 R 1381 0585 80 26 0098 R 1382 0583 80 A5 0090 R 1383 0584 80 0580 87 3 1384 0585 80 26 0098 R 1385 0594 80 06 0098 R 1386 0594 80 06 0098 R 1387 0588 76 80 0098 R 1388 0594 80 06 0098 R 1389 0587 80 06 0098 R 1389 0587 80 06 0098 R 1389 0587 80 06 0098 R 1389 0587 80 06 0098 R 1389 0587 80 06 0098 R 1399 0587 80 06 0098 R 1399 0588 80 0099 R 1400 0588 F6 80 0099 R 1419 0588 80 0098 R 1419 0588 80 0099 R 1419 0588 80 0099 R 1420 0589 F6 80 0099 R 1421 0585 80 0099 R 1421 0585 80 0099 R 1422 0580 80 0099 R 1423 0586 80 0099 R 1424 0580 80 0099 R 1424 0580 80 0099 R 1425 0580 80 0099 R 1426 0580 80 0099 R 1427 0580 80 0099 R 1428 0580 80 0099 R 1429 0588 80 0099 R 1429 0588 80 0099 R 1429 0588 80 0099 R 1420 0588 80 0099 R 1421 0589 80 0099 R 1422 0580 80 0099 R 1423 0585 80 0099 R 1424 0580 80 0099 R 1425 0580 80 0099 R 1426 0580 80 0099 R 1427 0580 80 0099 R 1428 0580 80 0099 R 1429 0580 80 0099 R 1449 0580 80 0099 R DSTATE NUM_TRANS ; ESTABLISH STATE IF SUCCESSFUL ; AL = NUMBER TRANSFERRED ; BAD DMA ERROR ENTRY ; SAVE NUMBER TRANSFERRED ; TRANSLATE STATE TO COMPATIBLE MODE ; RESTORE NUMBER TRANSFERRED ; VARIOUS CLEANUPS AX XLAT_OLD AX SETUP_END ENDP INITIALIZES START AND END RATES. : SETUP_STATE TEST JNZ MOY TEST JZ TEST JNZ MOY MEDIA DETERMINED ? NO STATES IF DETERMINED H * 18 TART RATE, AL = END RATE OR IVE DO NOT KNOW DRIVE MULTI-RATE ? JUMP IF YES START & END RATE = 250 FOR 360 DRIVE AX_SET: OSK_STATE[DI], NOT RATE_MSK+DBL_STEP; TURN OFF THE RATE OSK_STATE[DI], AH; RATE FIRST TO TRY CLASTRATE, NOT STRT_MSK; ERASE LAST TO TRY RATE BITS AL,4 TO OPERATION LAST RATE LOCATION CLASTRATE, AL JICI RET SETUP_STATE FMT_INIT: ESTABLISH STATE IF UNESTABLISHED AT FORMAT TIME. : FMT_INITI FMT_INIT TEST JNZ CALL JC DEC JS MOV AND OR JNZ OR JMP PROC NEAR PDSK STATE[DI], MED_DET ; IS MEDIA ESTABLISHED FI OUT ; IF SO RETURN CMDS TYPE ; RETURN DRIVE TYPE IN AL CL_DRV ; RETURN DRIVE TYPE IN AL CL_DRV ; MAKE ZERO ORIGIN CL_ORV ; NO DRIVE IF AL AH, POSK STATE[DI] ; MAKE ZERO ORIGIN CL_ORV ; NO DRIVE IF AL IN DRIVE IF AL CLEAR CLEA 109E_M N_360: DEC JNZ FI_RATE:OR JMP AL N 12 AH,MED_DET+RATE_500 SHORT SKP_STATE ; 1.2 M DRIVE ; JUMP IF NOT ; SET FORMAT RATE ; SKIP OTHER STATE PROCESSING N_12: CHECK FOR TYPE 3 JUMP IF NOT IS DRIVE DETERMINED TREAT AS NON 1.2 DRIVE IS 1.28 JUMP IF NOT RATE 300 CONTINUE DEC JNZ TEST JZ TEST JZ OR JMP AL N 720 AH,DRY_DET ISNT 12 AH,FMT CAPA ISNT 12 AH,MED_DET+RATE_300 SHORT SKP_STATE N_720: DEC JNZ JMP ; CHECK FOR TYPE 4 ; NO DRIVE, CMOS BAD ISNT_12: OR AH,MED_DET+RATE_250 ; MUST BE RATE 250 ODSK STATE[D1].AH . STORE AWAY FI_OUT: RET CL_DRV: XOR JMP FMT_INIT AH, AH CLEAR STATE SHORT SKP_STATE SAVE IT ENDP MED_CHANGE CHECKS FOR MEDIA CHANGE, RESETS MEDIA CHANGE, CHECKS MEDIA CHANGE AGAIN. CY = I MEANS MEDIA CHANGE OR TIMEOUT **DOSKETTE_STATUS = ERROR CODE ON EXIT: MED_CHANGE CALL JZ AND VGE PROC NEAR CALL READ DISKCHING ; READ DISK CHANGE LINE STATE JZ MC GUT ; BYPASS HANDLING DISK CHANGE LINE AND 905K_STATE[DI],NOT MED_DET ; CLEAR STATE FOR THIS DRIVE THIS SEQUENCE ENSURES WHENEVER A DISKETTE IS CHANGED THAT ON THE NEXT OPERATION THE REQUIRED MOTOR START UP TIME WILL BE WAITED. (DRIVE MOTOR MAY GO OFF UPON DOOR OPENING). 1446 05FC 20 06 003F R CL = DRIVE # MOTOR ON BIT MASK TO APPROPRIATE POSITION KEEP ALB BUT MOTOR ON NO INTERRUPTS TURN MOTOR OFF INDICATOR CX,DI AL,I AL,CL AL MOV MOV SHL NOT CLI AND ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) PAGE DMA_SETUP THIS ROUTINE SETS UP THE DMA FOR READ/WRITE/VERIFY OPERATIONS. PROC NEAR I DISABLE INTERRUPTS DURING DMA SET-UP I SET THE FIRST/LAST F/F I WAIT FOR I/O I OUTPUT THE MODE BYTE DMA VERIFY COMMAND NO I START ADDRESS DMA+12,AL $+2 DMA+11,AL AL,42H NOT_VERF AX,AX SHORT_J33 AX,ES AX,4 CH,AL AL,11110000B AX,[BP+2] J33 CH GET THE ES VALUE ROTATE LEFT GET HIGHEST NIBBLE OF ES TO CH ZERO THE LOW NIBBLE FROM SEGMENT TEST FOR CARRY FROM ADDITION AX DMA+4,AL $+2 AL,AH DMA+4,AL AL,CH $+2 AL,00001111B 081H,AL SAVE START ADDRESS OUTPUT LOW ADDRESS WAIT FOR I/O PUSH OUT JMP MOV OUT MOV JMP AND OUT OUTPUT HIGH ADDRESS GET HIGH 4 BITS 1 1/0 WAIT STATE : OUTPUT HIGH 4 BITS TO PAGE REGISTER #---- DETERMINE COUNT AX, SI AL, AH AL, AL AX, 1 AX DL, 3 GET PARM CL, AH AX, CL AX DMA*5, AL S*2 AL, AH DMA*5, AL AL = 8 OF SECTORS AH = 8 OF SECTORS AL = 9, AX = 8 OF SECTORS * 256 AX = 8 SECTORS * 128 SAVE 8 OF SECTORS * 128 GET BYTES/SECTOR PARAMETER SHIFT COUNT (0=128, 1=256 ETC) AX = 8 OF SECTORS * 128 SHIFT BY PARAMETER VALUE I SAVE COUNT VALUE I SAVE COUNT VALUE I LOW BYTE OF COUNT WALT FOR I/O HIGH BYTE OF COUNT I RE-ENABLE INTERRUPTS RECOVER COUNT VALUE RECOVER ADDRESS VALUE ADD, TEST FOR 64K OVERFLOW MODE FOR 8227 WALT FOR 1/0 INITIALIZE THE DISKETTE CHANNEL CX AX AX,CX AL,2 $+2 DMA+10,AL JNC MOY NO BAD ; CHECK FOR ERROR PDSKETTE_STATUS,DMA_BOUNDARY ; SET ERROR NO_BAD: RET DMA_SETUP ; CY SET BY ABOVE IF ERROR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) FMTDMA SET THIS ROUTINE SETS UP THE DMA CONTROLLER FOR A FORMAT OPERATION. ON ENTRY: NOTHING REQUIRED ON EXIT: DSKETTE_STATUS, CY REFLECT STATUS OF OPERATION : FMTDMA_SET MOV CL I OUT JMP OUT PROC NEAR ; WILL WRITE TO THE DISKETTE ; DISABLE INTERRUPTS DURING DMA SET-UP ; SET THE FIRST/LAST F/F ; WAIT FOR I/O ; OUTPUT THE MODE BYTE DMA+12,AL $+2 DMA+11,AL MOV ROL MOV AND ADD JNC INC AX,ES AX,4 CH,AL AL,11110000B AX,[BP+2] J33A CH GET THE ES VALUE ROTATE LEFT GET HIGHEST NIBBLE OF ES TO CH ZERO THE LOW NIBBLE FROM SEGMENT TEST FOR CARRY FROM ADDITION : CARRY MEANS HIGH 4 BITS MUST BE INC AX DMA+4,AL $+2 AL,AH DMA+4,AL AL,CH $+2 AL,00001111B 081H,AL PUSH OUT JMP MOV OUT MOV JMP AND OUT SAVE START ADDRESS OUTPUT LOW ADDRESS WAIT FOR I/O OUTPUT HIGH ADDRESS GET HIGH 4 BITS 1/0 WAIT STATE : OUTPUT HIGH 4 BITS TO PAGE REGISTER --- DETERMINE COUNT DL,4 GET PARM AL,AH AH,AH AX,2 AX AX DMA+6,AL $+2 AL,AH DMA+5,AL ; SECTORS/TRACK VALUE IN PARM TABLE ; AL = SECTORS/TRACK VALUE ; AX = SECTORS/TRACK VALUE ; AX SECOTOR OF OFFSET FOR C,H,R,N) ; TO COMPANY OF SET SET FOR C,H,R,N) ; LOW BYTE OF EVIES TO BE TRANSFERED ; LOW BYTE OF COUNT ; WAIT FOR I/O MOV CALL SUB SUB DEC PUSH JMP MOV OUT POP ADD JMP OUT HIGH BYTE OF COUNT RE-ENABLE INTERRUPTS RECOVER COUNT VALUE RECOVER ADDRESS VALUE ADD. TEST FOR 64K OVERFLOW MODE FOR 8237 WAIT FOR 1/O INITIALIZE THE DISKETTE CHANNEL CX AX AX,CX AL,2 $+2 DMA+10.AL ON ENTRY: AH : NEC COMMAND TO BE PERFORMED ON EXIT: +DSKETTE_STATUS, CY REFLECT STATUS OF OPERATION I NEC_INIT PROC NE PUSH AX CALL MOTOR_ON ; SAVE NEC COMMAND : TURN MOTOR ON FOR SPECIFIC DRIVE ---- DO THE SEEK OPERATION MOV CH, (BP+1) CALL SEEK POP AX JC ER_1 MOV BX-OFFSET ER_1 PUSH BX ; CH = TRACK # ; MOVE TO CORRECT TRACK ; RECOVER COMMAND ; ERROR ON SEEK ; LOAD ERROR ADDRESS ; PUSH NEC_OUT ERROR RETURN 3---- SEND OUT THE PARAMETERS TO THE CONTROLLER NEC_OUTPUT AX, 31 BX, D1 AH, 2 AH, 00000100B AH, BL NEC_OUTPUT BX CALL MOV MOV SAL AND OR CALL POP ER_1: RET I OUTPUT THE OPERATION COMMAND | AH = HEAD # BL = RRIVE # | BUYE IT TO BIT 2 | MOVE IT TO BIT 2 | ISOLATE THAT BIT | OR IN THE ORIVE MUMBER | FALL THRU CY SET IF ERROR | THROW ARAY ERROR RETURN ER_1: RET NEC_INIT ENDP RWY_COM THIS ROUTINE SENDS PARAMETERS TO THE NEC SPECIFIC TO THE READ/WRITE/VERIFY OPERATIONS. ROUTINE SENDS PARAMETERS TO THE NEC SPECIFIC 1 HE READ/WRITE/VERIFY OPERATIONS. 1 READ/BRIIE/TERTIF GENERAL STATUS STATUS OF OPERATION : CS:BX = ADDRESS OF MEDIA/DRIVE PARAMETER TABLE : PDSKETTE_STATUS, CY REFLECT STATUS OF OPERATION : RWY_COM PROC MOV PUSH MOV CALL MOV CALL MOV NEAR AX,OFFSET ER_2 AX AH,[BP+1] NEC OUTPUT AX,S1 NEC OUTPUT AH,[BP] : OUTPUT HEAD # : OUTPUT SECTOR # ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) NEC_OUTPUT DL.3 GET_PARM NEC_OUTPUT DL.4 GET_PARM NEC_OUTPUT 1712 0737 E8 09F8 R 1713 073A B2 03 1714 073C E8 0905 R 1716 073F E8 09F8 R 1716 0742 B2 04 1717 0744 E8 0905 R 1718 0747 E8 09F8 R CALL MOV CALL CALL MOV CALL CALL ; BYTES/SECTOR PARAMETER FROM BLOCK : TO THE NEC : OUTPUT TO CONTROLLER : EOT PARAMETER FROM BLOCK : TO THE NEC : OUTPUT TO CONTROLLER AH,CS1[BX].MD_GAP NEC_OUTPUT DL.5 GET_PARM NEC_OUTPUT AX 1719 0744 2E1 8A 6T 05 1721 0744 2E1 8A 6T 05 1721 0746 E8 0978 R 1722 0751 E8 0908 R 1723 0758 E8 0908 R 1724 0758 E8 0908 R 1725 0758 E8 0908 R 1726 0758 E8 0908 R 1726 0758 E8 0908 R 1727 0758 E8 MOV CALL MOV CALL CALL POP ; GET GAP LENGTH : DTL PARAMETER FROM BLOCK : TO THE NEC : OUTPUT TO CONTROLLER : THROW AWAY ERROR EXIT ER_2: ER_2: RET REV_COM ENDP THIS ROUTINE WAITS FOR THE OPERATION THEN ACCEPTS THE STATUS FROM THE NEC FOR THE READ/WRITE/VERIFY/ FORMAT OPERATION. ON EXIT: ODSKETTE_STATUS, CY REFLECT STATUS OF OPERATION: EC_TERM PROC NEAR ***** LET THE OPERATION HAPPEN PUSH SI CALL WAIT_INT PUSHF CALL, RESULTS JC SET_END_POF DOFF JC SET_END ; SAVE HEAD #, # OF SECTORS ; WAIT FOR THE INTERRUPT RESULTS SET_END_POP SET_END CLD MOV LODS AND JZ CMP JNZ ; SET THE CORRECT DIRECTION ; POINT TO STATUS FIELD ; GET STO ; TEST FOR NORMAL TERMINATION S1,OFFSET MNEC_STATUS MNEC STATUS AL,1T000000B SET_END AL,0T000000B J18 : TEST FOR ABNORMAL TERMINATION : NOT ABNORMAL, BAD NEC 1---- ABNORMAL TERMINATION, FIND OUT WHY PMEC_STATUS AL_I AH RECORD_NOT_FND J19 AL_1 AH, BAD_CRC J19 AL_1 AH, BAD_DMA J19 AL_1 AH, BAD_DMA LODS SAL MOV JC MO ; GET STI ; TEST FOR EOT FOUND ; TEST FOR DMA OVERRUN : TEST FOR WRITE PROTECT ; TEST MISSING ADDRESS MARK -- NEC MUST HAVE FAILED J18: MOV SET_END: CMP CMC POP RET SET_END_POP; POPF JMP NEC_TERM ; DSTATE: SHORT SET_END ENDP DESTABLISH STATE UPON SUCCESSFUL OPERATION. : NEAR **OSKETTE_STATUS.0** **OSKETTE_STATUS.0** **OSK.STATE[DI], MED_DET **ODSK.STATE[DI], MED_DET **ODSK.STATE[DI], MED_DET **ODSK.STATE[DI]* **AL_RATE **OSK.STATE[DI]* **LOAD STATE **AL_RATE_200** **LOAD STATE **LOAD STATE **AL_RATE_200** **LOAD STATE **LOAD STATE **LOAD STATE **LOAD STATE **AL_RATE_200** **LOAD STATE * DSTATE PROC CMP JNZ OR TEST JNZ MOV AND CMP JNE ;--- CHECK IF IT 15 1.44M RETURN DRIVE TYPE IN (AL) CMOS BAD 1.44MB DRIVE ? YES CALL JC CMP JE CMOS_TYPE M_12 AL,04 M_12 *DSK_STATE[DI],NOT FMT_CAPA ; TURN OFF FORMAT CAPA **OSK_STATE[DI],DRV_DET ; MARK DRIVE DETERMINED SHORT SETBAC ; BACK 1810 1820 1821 07DF 80 8D 0090 R 06 1821 07DF 80 8D 0090 R 06 1822 07E4 1824 07E4 C3 1825 07E5 DSK_STATE[DI],DRV_DET+FMT_CAPA ; TURN ON DETERMINED & FMT CAPA SETBAC: RET DSTATE ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) 1825 | 1826 | 1827 | 1828 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 1829 | 18 DETERMINES WHETHER A RETRY IS NECESSARY. IF RETRY IS REQUIRED THEN STATE INFORMATION IS UPDATED FOR RETRY. NEAR POSKETTE STATUS, 0 NEAR ODSKETTE STATUS, 1 ME OUT POSKETTE STATUS, TIME OUT NO RETRY AH, POSK STATE[D1] AH, MED DET NO RETRY NO RETRY IN RETRY NO RETRY IN RETRY IN RETRY IN RETRY IF ESTABLISHED/DETRMINED? IF ESTABLISHED/DETRMINED? IF ESTABLISHED STATE THEN TRU AH, RATE MSK CH, PALASTRATE CH, PALASTRATE CH, AH IN CORRESPONDING BITS CH, AH IN CORRESPONDING BITS IN CHARTE MSK IN CORRESPONDING BITS IN CHARTE MSK CH GET MEDIA STATE OF DRIVE | GET MEDIA STATE OF DRIVE | ESTABLISHED/DETERMINED ? | IF ESTABLISHED STATE THEN TRUE ERROR | ISOLATE RATE | GET START OPERATION STATE | TO CORRESONADING BITS | ISOLATE RATE BITS | ALL RATES TRIED | IF YES, THEN TRUE ERROR SETUP STATE INDICATOR FOR RETRY ATTEMPT TO NEXT RATE 00000000 (500) -> 10000000B (250) 10000000B (250) -> 01000000B (300) 01000000B (300) -> 00000000B (500) AH,RATE_500+1 | SET_CY_FOR_RATE_500 | AH,RATE_MSK | TO_NEXT_STATE | AH,RATE_MSK | KEEP_ONLY_RATE_BITS | POSK_STATE[D1],AND RATE_MSK+OBL_STEP | RATE, OBL_STEP_OFF | POSK_STATE[D1],AND | TURNON NEW_RATE | POSK_STATE[D1],AND | TURNON NEW_RATE | POSK_STATE[D1],AND NUM_TRANS THIS ROUTINE CALCULATES THE NUMBER OF SECTORS THAT WERE ACTUALLY TRANSFERRED TO/FROM THE DISKETTE. [BP+1] = TRACK SI-HI = HEAD [BP] = START SECTOR ON EXIT: AL = NUMBER ACTUALLY TRANSFERRED NUM_TRANS XOR CMP JNZ MOV CALL MGV CMP JNZ I CLEAR FOR ERROR I CHECK FOR ERROR I FEROR 0 TRANSFERRED I SECTORS/TRACK OFFSET TO DL I AH = SECTORS/TRACK I GET ENDING SECTOR I CH = HEAD B STATED I GET HEAD ENDED UP ON I FON SAME HEAD, THEN NO ADJUST ; GET TRACK ENDED UP ON ; 15 IT ASKED FOR TRACK ; IF SAME TRACK NO INCREASE CH, MEC_STATUS+3 CH, [BP+T] SAME_TRK ADD BL,AM DIF_HD: ADD BL,AH SAME_TRK: SUB BL,[BP] MOY AL,BL BL, AH ; ADD SECTORS/TRACK BL.[8P] AL.BL NT_OUT: RET NUM_TRANS SETUP END RESTORES OMOTOR COUNT TO PARAMETER PROVIDED IN TABLE AND LOADS OBSETTE_STATUS TO AH, AND SETS CY. I CAN EXIT. AH, ODSETTE_STATUS, CY REFLECT STATUS OF OPERATION PROC. NEAR SETUP_END MOY PUSH CALL MOY POP MOY OR JZ XOR RETTE_STATUS, CY REFL PROC NEAR DL,2 AX THE PARM MAINTER PARM MAINTER PARM AN ADSKETTE_STATUS AN,ADM AL,AU AL,AU AL,AL STORE UPON RETURN RESTORE NUMBER TRANSFERRED GET STATUS OF OPERATION CHECK FOR ERROR NO ERROR CLEAR NUMBER RETURNED NUN_ERR: CMP CMC RET SETUP_END : SET THE CARRY FLAG TO INDICATE : SUCCESS OR FAILURE ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) 1-19 04-21-86 PAGE SETUP_DBL CHECK DOUBLE STEP. ON ENTRY: ON ENTRY: DI = DRIVE CY = 1 MEANS ERROR CY = 1 MEANS ERROR SETUP_DBL PROC NEAR OY AH, GOSK STATE[DI] TEST AI, MED_DET JNZ NO_DBL 1 FESTABLISHED STATE 7 LONG THEN DOUBLE DONE ;---- CHECK FOR TRACK 0 TO SPEED UP ACKNOWLEDGE OF UNFORMATTED DISKETTE MOV SEEK STATUS, 0 CALL MOTOR_ON CALL SEEK CALL READ ID C SD_ERR SET RECALIBRATE REQUIRED ON ALL DRIVES ENSURE MOTOR STAY ON LOAD TRACK 0 SEEK TO TRACK 0 READ ID FUNCTION IF ERROR NO TRACK 0 ;---- INITIALIZE START AND MAX TRACKS (TIMES 2 FOR BOTH HEADS) ATTEMPT READ ID OF ALL TRACKS, ALL HEADS UNTIL SUCCESS; UPON SUCCESS, MUST SEE IF ASKED FOR TRACK IN SINGLE STEP MODE = TRACK ID READ; IF NOT THEN SET DOUBLE STEP ON. : ENSURE MOTOR STAYS ON FOR OPERATION SAVE TRACK, COUNT CLEAR STATUS, EXPECT ERRORS CLEAR STATUS, EXPECT ERRORS CLEAR STATUS, EXPECT ERRORS CLEAR STACK, CY = MEAD AX = MEAD IN CORRECT BIT SAVE HEAD SEEK TO TRACK RESTORE HEAD DI = HEAD OR TO REVE READ IN HEAD OR READ ID SEEK TO HEAD OR READ ID STATE OF THE SAVE HEAD RESTORE ERROR RETURN RESTORE ERROR RETURN RESTORE COUNT RESTORE COUNT IF OK, ASKED = RETURNED TRACK 7 INC FOR NEXT TRACK REACHED MAXIMUM YET CONTINUE TILL ALL TRIED MOTOR_COUNT, OFFH CX POSKETTE_STATUS, 0 AX, AX CH, 1 AL, 3 AX SEEK AX DI, AX READ_ID D1,11111011B CX DO_CHK CH CH,CL CNT_OK :---- FALL THRU. READ ID FAILED FOR ALL TRACKS SD_ERR: STC RET SET CARRY FOR ERROR EXIT CL, ONEC STATUS-3 | LOAD RETURNED TRACK OSK_TRK[DI],CL | STORE TRACK NUMBER CH, | SAME AS ASKED FOR TRACK NO DBL | IF SAME THEN ON DOUBLE STEP OSK_STATE[DI],DBL_STEP | TURN ON DOUBLE STEP REQUIRED DO_CHK: MOV MOV SHR CMP JZ OR NO_DBL: CLC RET SETUP_DBL ENDP READ ID FUNCTION. ON ENTRY: DI = BIT 2 = HEAD; BITS 1,0 = DRIVE DI = BIT 2 = HEAD; BITS 1,0 = DRIVE : DI = BIT 2 IS RESET, BITS 1,0 = DRIVE : ODSKETTE_STATUS, CY REFLECT STATUS OF OPERATION : NEAR AX, OFFSET ER_3 ; MOVE NEC OUTPUT ERROR ADDRESS AX, A4, A4H ; READ ID COMMAND ; DRIVE F TO AH, HEAD 0 AH, AL NEC OUTPUT : TO CONTROLLER ; TO CONTROLLER ; TO CONTROLLER ; TO CONTROLLER ; TO CONTROLLER ; THROW AWAY ERROR ADDRESS TATUS AX ; THROW AWAY ERROR ADDRESS TATUS ON EXIT: READ_ID PROC MOV PUSH MOV CALL MOV CALL POP ER_3: RET READ_ID ENDP ON ENTRY: DI = DRIVE # ON EXIT: AL = TYPE; CY REFLECTS STATUS CMOS_TYPE MOV CALL TEST STC JNZ PROC NEAR AL,CMOS DIAG CMOS READ AL,BAD_BAT+BAD_CKSUM ; CMOS DIAGNOSTIC STATUS BYTE ADDRESS ; GET CMOS STATUS ; BATTERY GOOD AND CHECKSUM VALID ? ; SET CY = 1 INDICATING ERROR FOR RETURN ; ERROR IF EITHER BIT ON BAD_CM AL, CMOS DISKETTE CMOS READ DI, DT TB AL, 4 ; ADDRESS OF DISKETTE BYTE IN CMOS ; GET DISKETTE BYTE ; SEE WHICH DRIVE IN QUESTION ; IF DRIVE I, DATA IN LOW NIBBLE ; EXCHANGE NIBBLES IF SECOND DRIVE BAD_CM: RET ; KEEP ONLY DRIVE DATA, RESET CY = 0 AL,00FH ``` ENDP ``` 1BM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) 1-20 GET_PARM THIS ROUTINE FETCHES THE INDEXED POINTER FROM THE DISK BASE BLOCK POINTED TO BY THE DATA VARIABLE ODISK POINTER, A BYTE FROM THAT TABLE IS THEN MOVED INTO XH, THE INDEX OF THAT BYTE BEING THE PARAMETER IN DL. ON ENTRY: DL = INDEX OF BYTE TO BE FETCHED AH = THAT BYTE FROM BLOCK AL, DH DESTROYED ON EXIT: ; DS = 0 , BIOS DATA AREA ; POINT TO BLOCK ; GET THE WORD ; RESTORE BX RET ASSUME DSIDATA GET PARM ENDP MOTOR ON MOTOR ON AND WAIT FOR MOTOR START UP TIME. THE SMOTOR COUNT: TURN MOTOR ON AND WAIT FOR MOTOR START UP TIME. THE SMOTOR COUNT: HERPICED IT A SUFFIC LENTY IN NUMBER OFFIT TO ENSURE: MOTOR NEEDED TO BE TURNED ON, THE MULTITASKING HOOK FUNCTION IN (AX=00FDH, INT 15H) IS CALLED TELLING THE OPERATING SYSTEM INT THAT THE BIOS IS ABOUT TO WAIT FOR MOTOR START UP. IF THIS INTERPRETATION OF THE OPERATING SYSTEM IN THAT THE MOTOR WITH TO WAIT FOR MOTOR START UP. IF THIS IN HAME SEEN COMPLETED. AT THIS POINT A CHECK IS MADE TO ENSURE IN THAT THE MOTOR WASN'T TURNED OFF BY THE TIMER. IF THE HOOK DID IN PRESCRIBED AMOUNT OF THE FOR THE TIMER. IS STAN RETURN, IT MEANS THAT THE MOTOR WASN'T TURNED OFF BY THE TIMER. IS STAN RETURN, IT MEANS THAT THE FUNCTION IS IN USE AND DID NOT PERFORM THE WAIT. A TIMER I WAIT LOOP WILL THEN DO THE WAIT. ON EXIT: AX,CX,DX DESTROYED MOTOR_ON PUSH CALL JC CALL MOY INT PUSHF CALL POFF JNC CALL JC PROC NEAR BX TURN ON MOT TS ON XLAT OED AX,090FDH 15H XLAT_NEW M_WAIT TURN_ON MOT_TS_ON MOV CALL MOV XOR CMP JAE MOV DL.10 GET_PARM AL.AH AH.AH AL.8 GP2 AL.8 ; GET THE MOTOR WAIT PARAMETER I AL = MOTOR WAIT PARAMETER I AX = MOTOR WAIT PARAMETER I SEE IF AT LEAST A SECOND IS SPECIFIED I IF YES, CONTINUE I ONE SECOND WAIT FOR MOTOR START UP 2109 094F 90 02 2109 094F 80 08 2110 094F 80 08 2111 2111 2112 0947 90 2113 0947 90 F24 2116 094F 98 CA 2116 094F 98 BD 2116 094F 98 BD 2116 094F 98 BD 2118 094F DD 2120 0952 90 BD 2120 0952 90 BD 2120 0952 90 BD 2120 0957 73 0A 2125 0957 73 0A AX CONTAINS NUMBER OF 1/8 SECONDS (125000 MICROSECONDS) TO WAIT SAVE WAIT PARAMETER LOAD LARGEST POSSIBLE MULTIPLIER LOAD LARGEST POSSIBLE MULTIPLIER MALTIPLY BY HALF OF WHAT'S NECESSARY CX. DX = 1/2 ° (8 OF MICROSECONDS) CLEAR CARRY FOR ROTATE DOUBLE COW WORD, CY CONTAINS OVERFLOW DOUBLE HI, INCLUDING LOW WORD OVERFLOW LOAD WAIT CODE PERFORM WAIT RESTORE WAIT PARAMETER CY MEANS WAIT COULD NOT BE DONE AX DX.62500 DX CX,DX DX,AX DX,1 CX,1 AH,86H 15H AX MOT_IS_ON :---- FOLLOWING LOOPS REQUIRED WHEN RTC WAIT FUNCTION IS ALREADY IN USE WAIT FOR 1/8 SECOND PER (AL) COUNT FOR 1/8 SECOND AT 15.08573T US GO TO FIXED WAIT ROUTINE DECREMENT TIME VALUE ARE WE DONE YET ARE WE DONE YET J13: CX,8286 WAITF AL J13 MOT_IS_ON: POP RET ВΧ MOTOR_ON ENDP I ON EXIT: CY = 0 MEANS WAIT STATE, CY = 0 MEANS WAIT REQUIRED CY = 1 MEANS NO WAIT REQUIRED AX, BX, CX, DX DESTROYED TURN_ON PROC NEAR MOV BX, DI 1 BX = DP ROL BL, 4 ; BX = DRIVE # ; CL = DRIVE # ; BL = DRIVE # ; NO INTERRUPTS WHILE DETERMINING STATUS ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 I-21 DSKETTE -- 04/21/86 DISKETTE BIOS 04-21-86 (DSK3.ASM) 096D C6 06 0040 R FF 0972 A0 003F R 0975 24 30 0977 B4 01 0979 D2 E4 OMOTOR_COUNT,OFFH AL,OMOTOR_STATUS AL,00110000B AH,1 AH,CL : ENSURE MOTOR STAYS ON FOR OPERATION : GET DIGITAL OUTPUT REGISTER REFLECTION : KEEP ONLY DRIVE SELECT BIS : MASK FOR DETERMINING MOTOR BIT : AH = MOTOR ON, A=00000001, B=00000010 2157 0979 D2 E4 2158 0978 3A C3 2154 0970 75 40 60 03F R 2156 0983 75 2C 2156 0983 75 2C 2156 0983 75 2C 2156 0983 75 2C 2156 0983 75 2C 2157 0997 AA 3E 003F R 2171 0988 80 E7 0F 2172 0987 80 26 003F R 2171 0988 80 E7 0F 2173 0993 80 26 003F R 2171 0998 80 E7 0F 2173 0993 80 E3 0F 2173 0993 80 E3 0F 2173 0994 0995 : AL = DRIVE SELECT FROM OMOTOR_STAT : BL = DRIVE SELECT DESIRED : AH = MOTOR ON MASK DESIRED AL,BL TURN IT_ON AH,OMOTOR_STATUS NO_MOT_WAIT ; REQUESTED DRIVE ALREADY SELECTED ? ; IF NOT SELECTED JUMP ; TEST MOTOR ON BIT ; JUMP IF MOTOR ON AND SELECTED AH, BL BH, MOTOR STATUS BH, 000011T1B MHOTOR STATUS BH, 000011T1B MHOTOR STATUS, AH MHOTOR STATUS BH, 000011T1B MHOTOR STATUS, AH L, 000011T1B BL, 000011T1B BL, 000011T1B CEAR OUT DRIVE SELECT ON DRIVE SELECTED AND MOTOR ON GET MOTOR STATUS BL, 000011T1B CEAR OUT DRIVE SELECTED AND MOTOR ON GET MOTOR BITS BL, 000011T1B CEAR OUT DRIVE SELECTED AND MOTOR ON GET MOTOR BITS CHABLE INTERRUPTS AGAIN STRIP AWAY LUMWANTED BITS AL. 4. 00001100B COURT OF AWAY LUMWANTED BITS AW AL,000111111B AL,4 AL,00001100B DX,03F2H DX,AL BL,BH NO_MOT_WAIT ; " ; NEW MOTOR TURNED ON ? ; NO WAIT REQUIRED IF JUST SELECT ; SET CARRY MEANING WAIT NO_MOT_WAIT: STC STI RET TURN_ON ENDP : SET NO WAIT REQUIRED HD_WAIT WAIT FOR HEAD SETTLE TIME. ON ENTRY: DI : DRIVE # ON EXIT: AX, BX, CX, DX DESTROTED PROC NEAR DL, PARM GENTOR STATUS, 10000000B | SEE IF A WRITE OPERATION | ISNT WRITE | FNOT, DO NOT ENFORCE ANY VALUES | AN AND STATE | FNOT, DO NOT ENFORCE ANY VALUES | AL, HOIZ SETILE | LOAD 1.2M HEAD SETTLE MINIMUM | AL, POSK, STATE[DI] | LOAD STATE | AL, RATE_MSK | KEEP ONLY RATE | AL, RATE_SO | 1,2 M DRIVE | DO_WAT | DEFAULT HEAD SETTLE LOADED MOV CALL TEST JZ OR JNZ MOV MOV AND CMP JNZ GP3: MOV AM, HD320_SETTLE : USE 320/360 HEAD SETTLE SHORT DO_BAT : ISNT_WRITE: OR JZ :---- AH CONTAINS NUMBER OF MILLISECONDS TO WAIT ; I MILLISECOND LOOP ; COUNT AT 15.086737 US PER COUNT ; DELAY FOR I MILLISECOND ; DECREMENT THE COUNT ; DO AL MILLISECOND # OF TIMES J291 CX,66 WAITF AL JZ9 UNEX JP9 JOE AL SIDER INECCOMP OF HD WAIT ENOP NEC_OUTPUT TESTING FOR CORRECT DIRECTION AND CONTROLLER AFTER : ROUTINE WILL TIME OUT IF THE BYTE IS NOT ACCEPTED WITHIN: A REASONABLE AMOUNT OF TIME, SETTING THE DISKETTE STATUS; ON COMPLETION. ON EXIT: ON EXIT: CY = 0 SUCCESS CY = 1 FAILURE -- DISKETTE STATUS UPDATED IF A FAILURE HAS OCCURRED. THE RETURN 15 MADE IF A FREWOYES THE REQUIREMENT OF TESTING AFTER EVERY CALL OF NEC OUTPUT. AX,CX,DX DESTROYED MEC CHIPPLY PROC NEAR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) 1-22 IN AND CMP JZ LOOP ; GET STATUS ; KEEP STATUS AND DIRECTION ; STATUS ; AND DIRECTION 0 ? ; STATUS AND DIRECTION OK ; CONTINUE TILL CX EXHAUSTED DEC JNZ ; DECREMENT COUNTER ; REPEAT TILL DELAY FINISHED, CX = 0 POSKETTE_STATUS, TIME_OUT BX : RESTORE REG. AX : DISCARD THE RETURN ADDRESS : INDICATE ERROR TO CALLER :---- DIRECTION AND STATUS OK; OUTPUT BYTE AL.AH DX DX,AL PUSHF MOY CX.3 CALL WAITF POPF WAITF POP BX RET NEC_OUTPUT ENDP : SAVE FLAGS : 30 TO 45 MICROSECOND WAIT FOR : NEC FLAGS UPDATE CYCLE : RESTORE FLAGS FOR EXIT : RESTORE REG. : CY = 0 FROM TEST INSTRUCTION ON ENTRY: DSKETTE_STATUS, CY REFLECT STATUS OF OPERATION. AX,BX,CX,DX DESTROYED PROC MOV MOV XCHG ROL XCHG TEST JNZ NEAR BX,D1 AL,1 CL,BL AL,CL CL,BL AL,SEEK_STATUS J28A I BX = DRIVE # I ESTABLISH MASK FOR RECALIBRATE TEST GET DRIVE VALUE INTO CL I SHIFT MASK BY THE DRIVE VALUE RECOVER TRACK VALUE I TEST FOR RECALIBRATE REQUIRED JUMP IF RECALIBRATE ROT REQUIRED 2324 0A38 E0 0A63 R 2324 0A38 E0 0A63 R 2326 0A32 E0 0A63 R 2327 0A30 C6 06 0041 R 00 2326 0A45 E2 0A63 R 2327 0A47 C6 85 0094 R 00 2331 0A47 C6 85 0094 R 00 2333 0A47 C6 85 0094 R 00 2334 0A62 T4 2D 2333 0A55 T4 02 2334 0A65 T4 02 2336 0A56 T4 02 2337 0A57 T0 E5 2340 0A57 T0 E5 2340 0A57 T0 E5 2341 0A58 T4 02 2341 0A59 T4 23 2344 0A59 T4 23 2345 0A56 E0 DF 2351 0A66 0A67 E0 0A98 R 2352 0A70 E0 0A98 R 2353 0A83 51 2377 0A83 E0 0A98 R 2377 0A83 E1 2377 0A84 E0 0A98 R 2377 0A85 E1 0A98 R 2377 0A85 E1 0A98 R 2377 0A85 E0 0A98 R 2377 0A85 E0 0A98 R 2377 0A86 E0 0FF R ISSUE RECALIBRATE FOR 80 TRACK DISKETTES POSKETTE_STATUS,0 RECAL | RECALIBRATE DRIVE RB | RECALIBRATE FAILS TWICE THEN ERROR AFT_RECAL: MOV OR JZ DRIVE IS IN SYNCHRONIZATION WITH CONTROLLER, SEEK TO TRACK ODSK_STATE[D1],OBL_STEP; CHECK FOR DOUBLE STEP REQUIRED; SINGLE STEP REQUIRED BYPASS DOUBLE CH,1 ; DOUBLE NUMBER OF STEP TO TAKE CMP JE ; SEE IF ALREADY AT THE DESIRED TRACK ; IF YES, DO NOT NEED TO SEEK CH, ODSK_TRK[DI] DE NB OV DX, OFFSET NEC_ERR DX OV D : LOAD RETURN ADDRESS ; ON STACK FOR NEC OUTPUT ERROR ; SAVE NEW CYLINDER AS PRESENT POSITION ; SEEK COMMAND TO NEC : BX = DRIVE # : OUTPUT DRIVE NUMBER # GET CYLINDER NUMBER ; ENDING INTERRUPT AND SENSE STATUS :---- WAIT FOR HEAD SETTLE ; SAVE STATUS ; WAIT FOR HEAD SETTLE TIME ; RESTORE STATUS RB: NEC_ERR RET SEEK ENDP ! RECAL BRATE DRIVE ; RECALIBRATE DRIVE # ON EXIT: PROC NEAR PUSH CX MOV AX,OFFSET RC_BACK PUSH AX MOV AH,07H CALL NEC_OUTPUT ; LOAD NEC_OUTPUT ERROR ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE BIOS (DSK3.ASM) 2381 0A8D 8B DF3 2382 0A9F 8A E3 2383 0A9F 8A E3 2384 0A94 E8 0A9A R 2385 0A99 C3 2386 0A99 C3 2380 0A99 C3 2390 0A99 C3 2391 0A99 E8 0AE 0 ; OUTPUT THE DRIVE NUMBER I GET THE INTERRUPT AND SENSE INT STATUS ; THROW AWAY ERROR DSKETTE_STATUS, CY REFLECT STATUS OF OPERATION.: PUSNETTE STATUS AX, OFFSET CS_BACK AX, OFFSET CS_BACK AXITINT J34 AH, 08H AH, 08H AH, 08H AL, 001FUT AL, 001FUT AL, 1010000B AL, 1010000B J35 ; READ IN THE RESULTS ; GET THE FIRST STATUS BYTE ; ISOLATE THE BITS ; TEST FOR CORRECT VALUE ; IF ERROR, GO MARK IT ; GOOD RETURN ODSKETTE_STATUS, BAD_SEEK SHORT J34 ENDP ON EXIT: DSKETTE_STATUS, CY REFLECT STATUS OF OPERATION. WAIT_INT STI CLC MOV INT JC MOV XOR AX,09001H 15H J36A BL,10 CX,CX TEST JNZ LOOP DEC JNZ esek_status,int_flag | test for interrupt occurring | 136 | count down while waiting | second level counter | 336 | count down while waiting | second level counter | DSKETTE_STATUS.TIME_OUT : NOTHING HAPPENED : ERROR RETURN PUSHF AND POPF RET SEEK_STATUS,NOT INT_FLAG ; TURN OFF INTERRUPT FLAG ; TURN OFF INTERRUPT FLAG ; RECOVER CARRY ; GOOD RETURN CODE RESULTS THIS ROUTINE WILL READ ANYTHING THAT THE NEC CONTROLLER RETURNS FOLLOWING AN INTERRUPT. RESULTS PROC PUSH MOV MOV MOV NEAR DI DI,OFFSET ONEC_STATUS ; POINTER TO DATA AREA BL, ; MAX STATUS BYTES DX,03F4H ; 3TATUS FORT 2461 2468 2469 2470 0AF2 BT 02 2471 0AF2 BT 02 2471 0AF6 EC ;---- WAIT FOR REQUEST FOR MASTER MOV XQR IN AND CMP JZ LOOP AL.11000000B AL.11000000B J42 J39 0803 80 0E 0041 R 80 0808 F9 0809 EB 18 ODSKETTE_STATUS,TIME_OUT 2483 0808 F9 2484 0809 EB 18 2486 2487 2488 0808 2489 0808 42 2491 080C EC 2492 0800 88 05 2493 0807 47 2494 0807 47 ; I/O DELAY ; POINT AT DATA PORT ; GET THE DATA ; STORE THE BYTE ; INCREMENT THE POINTER ``` ## **5-110 DSKETTE** ``` IBM Personal Computer MACRO Assembler Version 2.00 DSKETTE -- 04/21/86 DISKETTE 810S (DSK3.ASM) 1-24 04-21-86 2495 0810 89 0000 E 2499 0818 61 0 2499 0818 64 10 2501 0816 75 08 2502 0816 75 08 2502 0816 75 08 2503 0816 75 08 2504 0826 75 08 2509 0826 75 08 2509 0826 75 08 2510 0826 75 08 2511 0827 C3 2512 0828 80 0914 R 2513 0828 80 0914 R 2514 0827 C3 2514 0827 C3 2514 0828 80 0914 R 2514 0828 80 0914 R 2529 0828 80 0914 R 2529 0828 80 0914 R 2529 0828 80 0914 R 2529 0828 80 0914 R 2520 0828 80 0914 R 2521 2522 0828 80 0914 R 2523 0828 80 0914 R 2523 0828 80 0914 R 2524 0838 80 0914 R 2525 083 MOV CALL DEC IN TEST JZ I MINIMUM 24 MICROSECONDS FOR NEC I WAIT 30 TO 45 MICROSECONDS I POINT AT STATUS PORT I CET STATUS I TEST FOR NEC STILL BUSY I RESULTS DONE ? AL,DX AL,00010000B POPRES BL ; DECREMENT THE STATUS COUNTER 10 BACK FOR MORE 90SKETTE_STATUS,BAD_NEC; TOO MANY STATUS BYTES 1 SET ERROR FLAG 1 SET ERROR FLAG DEC JNZ OR STC :---- RESULT OPERATION IS DONE POPRES: POP DI RET : RETURN WITH CARRY SET RESULTS ENDP : READ_DSKCHING READS THE STATE OF THE DISK CHANGE LINE. ON ENTRY: DI = DRIVE # | DRIVE_DET | DETERMINES WHETHER DRIVE IS 80 OR 40 TRACKS AND UPDATES STATE INFORMATION ACCORDINGLY. I ON ENTRY: I ON ENTRY: I ON ENTRY: I ON ENTRY: I CALL JC MOV SK_GIN: DEC PUSH CALL JC MOV MOV CALL CALL MOV MOV CALL CALL OP POP POP TEST JOR JZ ORIVE ON ENTRY: DI = DRIVE # PROC NEAR MOTOR ON RECAL DD BAC CH,TRK_SLAP SEEK DD BAC CH,QUIET_SEEK+1 TURN ON MOTOR IF NOT ALREADY ON RECALIBRATE DRIVE SASSUME NO DRIVE PRESENT SEEK TO TRACK 48 3 DECREMENT TO NEXT TRACK 3 SAVE TRACK POP AND RETURN LOAD NEC OUTPUT ERROR ADDRESS LOAD NEC OUTPUT ERROR ADDRESS SENSE DRIVE STATUS COMMAND BYTE OUTPUT TO NEC AL = DRIVE AH = DRIVE CUTPUT TO NEC GO COM STATUS GO COM STATUS RESTORE NACK TRACK O T IS HOME AT TRACK O ? MUST BE 80 TRACK DRIVE DRIVE IS A 360; SET DRIVE TO DETERMINED; SET MEDIA TO DETERMINED AT RATE 250. ODSK_STATE[DI],DRV_DET+MED_DET+RATE 250 1 ALL INFORMATION SET 15_80: OR DD_BAC: RET ODSK_STATE[DI].TRK_CAPA ; SETUP 80 TRACK CAPABILITY POP_BAC: POP RET DRIVE_DET ENDP DISK_INT THIS ROUTINE MANDLES THE DISKETTE INTERRUPT. ON EXIT: THE INTERRUPT FLAG IS SET IN OSEEK_STATUS. AX,09101H 15H AX ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK 8105 PAGE 118.12! TITLE DISK ---- 09/25/85 FIXED DISK BIOS .286C .LIST CODE SEGMENT BYTE PUBLIC CMOS_READ:NEAR CMOS_WRITE:NEAR DOS:NEAR E_MSGINEAR FT780:NEAR F1781:NEAR F1782:NEAR F1790:NEAR F1791:NEAR F1791:NEAR F1791:NEAR EXTRN -- INT 13H ----- :--- INT 13H ------ ; ; FIXED DISK I/O INTERFACE THIS INTERFACE PROVIDES ACCESS TO 5 1/4° FIXED DISKS THROUGH THE IBM FIXED DISK CONTROLLER. THE BIOS ROUTINES ARE MEANT TO BE ACCESSED THROUGH SOFTWARE INTERRUPTS ONLY. ANY ADDRESSES PRESENT IN THESE LISTINGS ARE INCLUDED ONLY FOR COMPLETENESS, NOT FOR REFERENCE. APPLICATIONS WHICH REFERENCE ANY ABSOLUTE ADDRESSES WITHIN THE CODE SEGMENTS OF BIOS VIOLATE THE STRUCTURE AND DESIGN OF BIOS. (AH)= HEX COMMAND VALUE (AH)= 00H RESET DISK (DL = 80H,81H) / DISKETTE (AH)= 01H READ THE STATUS OF THE LAST DISK OPERATION INTO (AL) NOTE: DL < 80H - DISKETTE DL > 80H - DISK (AH)= 02H READ THE DESIRED SECTORS INTO MEMORY (AH)= 03H WRITE THE DESIRED SECTORS FROM MEMORY (AH)= 04H VERBUT THE DESIRED SECTORS FROM MEMORY (AH)= 04H VERBUT THE DESIRED SECTORS FROM MEMORY (AH)= 05H UNUSED (AH)= 05H UNUSED (AH)= 07H UNUSED (AH)= 07H UNUSED (AH)= 09H INITIALIZE DRIVE CHARACTERISTICS (AH)= 09H INITIALIZE DRIVE CHARACTERISTICS (AH)= 04H WRITE LONG (READ & WRITE LONG ENCOMPASS 512 + 4 BYTES ECC) (AH)= 04H WRITE LONG (READ & WRITE LONG ENCOMPASS 512 + 4 BYTES ECC) (AH)= 07H UNUSED (AH)= 07H UNUSED (AH)= 07H UNUSED (AH)= 07H UNUSED (AH)= 17H RECALIBRATE (AH)= 17H RECALIBRATE (AH)= 17H RECALIBRATE (AH)= 17H RECALIBRATE (AH)= 17H RECALIBRATE (AH)= 17H READ UNUSED) (AH)= 17H READ UNUSED (AH)= 17H READ UNUSED) (AH)= 17H READ ONSO TYPE INPUT (AH) = HEX COMMAND VALUE REGISTERS USED FOR FIXED DISK OPERATIONS (DL) - DRIVE NUMBER (80H-81H FOR DISK, VALUE CHECKED) (DH) - HEAD NUMBER (0-15 ALLOWED, NOT VALUE CHECKED) (CH) - CYLINDER NUMBER (0-1023, NOT VALUE CHECKED) (SEE CL (CL) - SECTOR NUMBER (1-17, NOT VALUE CHECKED) - NUMBER OF SECTORS (MAXIMUM POSSIBLE RANGE 1-80H, FOR READ/WRITE LONG 1-79H) (AL) (ES:BX) - ADDRESS OF BUFFER FOR READS AND WRITES, (NOT REQUIRED FOR VERIFY) FORMAT (AH=8) E3:BX POINTS TO A 512 BYTE BUFFER. THE FIRST 2°(SECTORS/TRACK) BYTES CONTAIN F,N FOR EACH SECTOR. F = 00H FOR A GOOD SECTOR SOH FOR A BAD SECTOR N SECTOR SUMBER OF 2 AND 17 SECTORS/TRACK THE TABLE SMOULD BE! 00H,01H,00H,0AH,00H,02H,00H,0BH,00H,03H,00H,0CH 00H,04H,00H,0DH,00H,05H,00H,0EH,00H,0M,0OH,0FH 00H,07H,00H,10H,00H,08H,00H,11H,00H,09H ``` ``` DUTPUT AM = STATUS D'ETS AND DEFINED IN THE COUNTES BELOW OF STATUS BITS AND DEFINED IN THE COUNTES BELOW OF STATUS BITS AND DEFINED IN THE COUNTES BELOW OF STATUS BITS AND DEFINED IN THE COUNTES BELOW OF STATUS BITS AND DEFINITION OF AND THE COUNTES BELOW OF STATUS BITS AND DEFINITION OF AND THE COUNTES TH ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK BIOS FIXED DISK I/O SETUP - ESTABLISH TRANSFER VECTORS FOR THE FIXED DISK - PERFORM POWER ON DIAGNOSTICS SHOULD AN ERROR OCCUR A "1701" MESSAGE IS DISPLAYED ASSUME CS:CODE,DS:ABSO ; WORK OFF DS REGISTER PROC NEAR PROC NEAR AX, ABSO DS, AX AX, WORD PTR **ORG **VECTOR** AX, WORD PTR **ORISK **VECTOR.AX AX, WORD PTR **ORISK **VECTOR.AX AX, WORD PTR **ORISK **VECTOR.2.AX WORD PTR **ORISK **VECTOR.2.AX WORD PTR **ORG **VECTOR.0FFSET DISK_IO WORD PTR **ORG **VECTOR.0FFSET DISK_IO WORD PTR **ORG **VECTOR.2.AX WORD PTR **ORG **VECTOR.2.AX WORD PTR **ORG **VECTOR.2.CFSET PD_TBL WORD PTR **OFFT TEL_VEC.2.CFSET FD_TBL WORD PTR **OFFT TEL_VEC.2.CFSET FD_TBL WORD PTR **OFFT TEL_VEC.2.CFSET FD_TBL AL, INTBO! AL, INTBO! AL, INTBO! AL, INTBO! AL, OFFDH ; SECOND CHIP INTAO!, AL INTAO!, AL INTAO!, AL # GET ABSOLUTE SEGMENT # SET SEGMENT REGISTER # GET DISKETTE VECTOR # INTO INT 40H ; FIXED DISK HANDLER ; FIXED DISK INTERRUPT ; PARM TABLE DRIVE 80 ; PARM TABLE DRIVE 81 : TURN ON SECOND INTERRUPT CHIP ; LET INTERRUPTS PASS THRU TO ; SECOND CHIP STI ASSUME PUSH POP CALL MOV MOV MOV CALL MOV AND JZ JMP DSIDATA, ESIABSO DS ES DDS ODISK_STATUSI, 0 ODISK_STATUSI, 0 OFF NUM, 0 OCORTROL BYTE, 0 AL, CMOS DIAC+NMI CMOS REĀD AH, AL AL, BAD_BAT+BAD_CKSUM LI POD_DONE 004A FB 0044 FB 0046 07 0046 07 0046 07 0046 07 0050 06 06 0014 R 00 0055 06 06 0015 0064 07 005 R 0064 07 005 R 0064 07 005 R 0065 07 005 R 0060 0070 070 ; MOVE ABSO POINTER TO ; EXTRA SEGMENT POINTER ; ESTABLISH DATA SEGMENT ; RESET THE STATUS INDICATOR ; ZERO NUMBER OF FIXED DISKS ; CHECK CMOS VALIDITY ; SAVE CMOS FLAG ; CHECK FOR VALID CMOS : CMOS NOT VALID -- NO FIXED DISKS AND MOV CALL MOV CALL MOV MOV AND JZ AH, NOT HE FAIL AL, CMOS DTAG+NMI CMOS WRTTE AL, CMOS DISK+NMI CMOS READ PPORT OFF, 0 BL, AL AX, 000F0H POD_DONE ; ALLOW FIXED DISK IPL ; WRITE IT BACK ; ZERO CARD OFFSET ; SAVE FIXED DISK BYTE ; GET FIRST DRIVE TYPE AS OFFSET ; NO FIXED DISKS AL,OFOH L2 : CHECK FOR EXTENDED DRIVE TYPE BYTE USE ; USE DRIVE TYPE 1 --> 14 IF NOT IN USE 0086 3C F0 0088 75 10 CMP JNE 008A 75 10 008A 80 99 000F 3C 000 0097 3C 000 0093 3C 2F 0095 17 61 0097 16 00 4 0097 16 00 4 0098 16 00 175 R 01 0094 16 00 175 R 01 0040 60 60 175 R 01 0040 60 60 60 04 0040 60 60 60 04 AL,CMOS_DISK_1+NMI CMOS_READ AL,0 POD_DONE AL,47 POD_DONE AX,4 GET EXTENDED TYPE FOR DRIVE C: I FROM CMOS I STYPE SET TO ZERO EXIT IF NOT VALID AND NO FIXED DISKS IS TYPE WITHIN VALID RANCE IEXIT WITH NO FIXED DISKS IF NOT VALID ADJUST TYPE TO HIGH NIBBLE MOV CALL CMP JE CMP JA SHL AX, OFFSET FD_TBL=16D ; COMPUTE OFFSET OF FIRST DRIVE TABLE WORD PIR OHF_TBL_VEC_AX ; SAVE IN VECTOR POINTER ; AI_EAST ONE ORIVE AI_AL AL_4 ; GET SECOND DRIVE TYPE SHORT L4 ; ONLY ONE DRIVE ADD MOV MOV SHL JZ MOV AL,0F0H 00AF 3C F0 00B1 75 10 ; CHECK FOR EXTENDED DRIVE TYPE BYTE USE ; USE DRIVE TYPE 1 --> 14 IF NOT IN USE 0081 75 10 0082 80 9A 0085 E8 0000 E 0086 3C 00 009A 74 1B 008C 3C 2F 008C 77 17 0000 61 E0 04 0000 82 E8 33 F 00 0000 74 08 00 0000 74 08 00 0000 74 08 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 78 00 0000 7 : GET EXTENDED TYPE FOR DRIVE D: FROM CMOS : IS TYPE SET TO ZERO : SKIP IF SECOND FIXED DISK NOT VALID : IS TYPE WITHIN VALID RANGE : SKIP IF NOT VALID : ADJUST TYPE TO HIGH NIBBLE MOY CALL CMP JE CMP JA SHL AL,CMOS DISK_2+NMI CMOS_READ AL,0 L4 AL,47 L4 AX,4 L3: AX,OFFSET FD_TBL-16D BX,AX WORD PTR CS:[BX],0 L4 WORD PTR OHF1_TBL_VEC,AX OHF_NUM,2 ADD MOV CMP JE MOV MOV ; COMPUTE OFFSET FOR SECOND FIXED DISK : CHECK FOR ZERO CYLINDERS IN TABLE ; SKIP DRIVE IF NOT A VALID TABLE ENTRY TWO DRIVES PARTY THE CONTROLLER USE CONTROLLER DIAGNOSTIC COMMAND CALL BIOS WITH DIAGNOSTIC COMMAND DISPLAY ERROR MESSAGE IF BAD RETURN GET START TIMER COUNTS MOV MOV INT JC MOV MOV ADD MOV CALL CMP JBE MOV CALL : 60 SECONDS* 18.2 ; SET UP DRIVE 0 ; WERE THERE TWO DRIVES? ; NO-ALL DONE ; SET UP DRIVE I POD_DONE: ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK BIOS 1-5 04-21-86 ;----, CTL_ERRX: MOV CALL CALL JMP :---- POD ERROR SI,OFFSET F1782 SET FAIL E_MSG POD_DONE : CONTROLLER ERROR ; DO NOT IPL FROM DISK ; DISPLAY ERROR AND SET (BP) ERROR FLAG 0104 53 0105 51 0106 53 0106 51 0106 51 0106 51 0106 51 0107 0108 CD 13 0116 ES 0000 E 0117 BE 0000 E 0117 BE 0000 E 0127 BH 003 0127 BH 003 0127 BH 003 0127 BH 003 0127 BH 003 0127 BH 003 0128 BH 004 0127 BH 003 0128 BH 004 0127 BH 003 0137 BH 003 0138 BH 004 0137 BH 003 0138 BH 004 0137 BH 003 0138 BH 004 0137 BH 003 0138 BH 004 0138 BH 004 0138 BH 004 0139 0146 BH 004 0146 BH 004 0146 BH 004 0146 BH 004 0146 BH 004 0147 BH 004 0148 BH 004 0149 ; SAVE TIMER LIMITS ; SET DRIVE PARAMETERS ; RECALIBRATE DRIVE : DRIVE OK ; INDICATE DISK 1 FAILURE ; INDICATE DISK O FAILURE ; DO NOT TRY TO IPL DISK O RESET THE DRIVE ; GET MAX CYLINDER, HEAD, SECTOR ; SAVE DRIVE CODE ; SAVE MAX CYLINDER, SECTOR ; RESTORE DRIVE CODE ; VERIFY THE LAST SECTOR ; VERIFY OK ; OK ALSO IF JUST ID READ CHECK FOR TIME OUT FAILED: GET SECTOR ADDRESS, AND CYLINDER SEPARATE OUT SECTOR NUMBER ; JET ARRIE USI SELECTORS ON TRACK ; WE'VE TRIED ALL SECTORS ON TRACK KEEP CYLINDER BITS ; MERGE SECTOR WITH CYLINDER BITS ; SAVE CYLINDER, NEW SECTOR NUMBER ; TRY AGAIN ; INDICATE DISK ! ERROR : INDICATE DISK 0 ERROR CALL E_MSG : DISPLAY ERROR AND SET (BP) ERROR FLAG _L. **D_RESET_I SET_FAIL OR XCHG CALL CALL CALL RET RES_OK: POP POP RET HD_RESET_I | RESTORE TIMER LIMITS ENDP 017C B8 8E8E 017F E8 0000 E 0182 0C 08 0184 86 E0 0184 E8 0000 E 0189 C3 PROC NEAR AX, X*(CMOS_DIAG+NMI) CMOS READ AL, HF_FAIL AH, AL CMOS_WRITE ; SET DO NOT IPL FROM DISK FLAG ; SAYE IT ; PUT IT OUT ENDP 018A 018A 58 018B 59 018C 5B 018D 53 018E 51 018F 50 0190 A1 006C R POD_TCHK POP POP POP PUSH PUSH MGY PROC NEAR AX CX BX BX CX AX AX, ФT: MER_LOW ; CHECK FOR 30 SECOND TIME OUT ; SAVE RETURN ; GET TIME OUT LIMITS : AND SAVE THEM AGAIN ; RESTORE RETURN ; AX = CURRENT TIME ; BX = START TIME ; CX = END TIME 0193 3B D9 0195 72 06 0197 3B D8 0199 72 0C 0198 EB 04 019D 3B C3 019F 72 04 01A1 3B C1 01A3 72 02 BX,CX TCHK1 BX,AX TCHKG SHORT TCHK2 AX,BX TCHKNG AX,CX TCHKG CMP JB JMP CMP JB CMP JB CMP JB ; START < END ; END < START < CURRENT ; END, CURRENT < START TCHK1: TCHK2: $ START < CURRENT < END $ OR CURRENT < END < START $ CARRY SET INDICATES TIME OUT 01A5 F9 01A6 C3 01A7 F8 01A8 C3 01A9 TCHKNG: STC RET TCHKG: CLC RET 1 INDICATE STILL TIME POD_TCHK ENDP ``` DISK\_SETUP ENDP ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK 810S 1-6 04-21-86 PAGE | FIXED DISK BIOS ENTRY POINT : DISK_IO PROC ASSUME CMP JAE INT FAR DS:DATA,ES:NOTHING DL,80H A1 40H 01A9 01A9 80 FA 80 01AC 73 05 01AE CD 40 01B0 01B0 CA 0002 RET_2: 2 RET BACK TO CALLER 0183 FB 0183 FB 0184 OA E4 0186 75 OP 0188 CD 40 0186 CD 40 0186 A 2A E4 0186 F7 OF 010 01 A1: STI OR JNZ INT SUB CMP JA ; ENABLE INTERRUPTS AH,AH A2 40H AH,AH DL,(80H + S_MAX_FILE RET_2 : RESET NEC WHEN AH=0 42: AH,08H A3 GET_PARM_N AH,15H A4 READ_DASD_TYPE CMP JNZ JMP CMP JNZ JMP GET PARAMETERS IS A SPECIAL CASE 43: : READ DASD TYPE IS ALSO OICE 75 0353 R OIDI C8 0008 00 OIDS 63 OIDS 63 OIDS 63 OIDS 61 OIDS 63 OIDS 61 OIDS 63 OIDS 63 OIDS 64 OIDS 65 OIDS 65 OIDS 66 OIDS 66 OIDS 67 OIDS 67 OIDS 68 6 A41 ENTER PUSH PUSH PUSH PUSH PUSH PUSH OR JUZ MAY A51 CALL CALL CALC CALC POP POP POP POP POP POP POP POP POP LEAVE DISK_IO ENDP : SAVE REGISTERS DURING OPERATION : SAVE (BP) AND MAKE ROOM FOR GOMD BLOCK : IN THE STACK. THE COMMAND BLOCK IS: | COMD_BLOCK == BYTE PTR [BP]-8 8,0 8X CX CX DS ES SI DI AH,AH AL,80H DISK_IO_CONT DA,0H_OOISK_STATUSI AH,0I 1 CHECK FOR RESET FORCE DRIVE 80 FOR RESET PERFORM THE OPERATION ESTABLISH SEGMENT GET STATUS FROM OPERATION SET THE CARRY FLAG TO INDICATE SUCCESS ON FAILURE RESTORE REGISTERS DI SI ES DS DX CX BX ; ADJUST (SP) AND RESTORE (BP) ; THROW AWAY SAVED FLAGS 2 DISK RESET RETURN STATUS DISK READ DISK WEIP DISK WEIP DISK WEIP BAD COMMAND BAD COMMAND BAD COMMAND DISK SEEST SEES 01FB 02C1 R 01FB 02C1 R 01FB 02C1 R 01FF 031E R 02C1 031 | FUNCTION TRANSFER TABLE | 1000H | 1001H | 1001H | 1005H | 1006H 10 MI MEMORY DIAGNOSTIC DRIVE DIAGNOSTIC CONTROLLER DIAGNOSTIC 0225 E8 0000 E 0226 E8 0000 E 0228 80 FC 01 0228 76 02 0228 76 02 0228 76 02 0228 76 02 0228 76 02 0228 76 02 0228 76 02 0228 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 0236 76 02 MIL. DISK_IO_CONT CALL CMP JNZ JMP PROC NEAR DDS AH,01H SU0 RETURN_STATUS : ESTABLISH SEGMENT : RETURN STATUS WETURN_STATUS ODISK_STATUSI,0 $\text{Status}$; $\text{S MOVSH PUSY H MOVSH MOVSH AMPLIANT SHOVE SH PCONTRUL___ AX PCMD_BLOCK+1+AL : SECTOR COUNT ; GET SECTOR NUMBER ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/26/85 FIXED DISK BIOS 1-10 PAGE TEST DISK READY (AH = 10H) 1 TST_ROY PROC CALL JNZ MOV MOV OUT CALL JNZ LALL JNZ TR EX: RET TST_RDY ENDP 044F E8 05F3 R 0452 75 11 0454 8A 46 FD 0457 8A 01F6 0450 AE 0454 EE 0450 E8 0642 R 0450 E6 0642 R 0450 C5 06 0074 R 00 NEAR NOT BUSY TR EX AL, DeCMD BLOCK+5 DX, HF PORT+6 DX, AL CHECK ST TR EX PDTSK_STATUS1,0 ; SELECT DRIVE ; CHECK STATUS ONLY RECALIBRATE (AH = 11H) & 0466 C6 46 FE 10 0466 E8 055C R 0466 E8 055C R 0466 E8 05C2 R 0472 T4 05 0474 E8 05C2 R 0477 T5 0F 0479 E8 0630 R 0470 E8 050 O74 R 40 0481 T5 05 0488 80 SE 0074 R 00 0480 C3 HDISK_RECAL MOV CALL JNZ CALL JZ CALL JNZ RECAL X1 PROC NEAR OCMD BLOCK+6, RECAL_CMD COMMAND RECAL_EXIT RECAL_X WAIT RECAL_EXIT START THE OPERATION ERROR WAIT FOR COMPLETION TIME OUT ONE OK ? WAIT FOR COMPLETION LONGER TIME OUT TWO TIMES IS ERROR CALL CMP JNE MOV RECAL_EXIT: CMP MOV RECAL_EXIT: CMP RET HDISK_RECAL CHECK STATUS ODISK_STATUS1,BAD_SEEK ; SEEK NOT COMPLETE RECAL_EXIT ; IS OK ODISK_STATUS1,0 ODISK_STATUS: ,0 ENDP CONTROLLER DIAGNOSTIC (AH = 14H) : 048E FA 048F E4 A1 048F E4 A1 0491 24 BF 00 0493 E8 01 0493 E8 01 0499 E8 21 0499 E9 00 049D E6 21 0496 E9 00 049D E6 21 0496 E9 05F3 R 04A6 B0 9D 04A6 B0 9D 04A6 B0 9D 04A6 B0 9D 04A6 B0 05F3 R 04A6 B0 9D 04A6 B0 0F1 04A6 B0 9D 04A6 B0 0F1 04A6 B0 9D 04A6 B0 9D 04A6 B0 05F3 R 04A6 B0 9D 3 DISABLE INTERRUPTS WHILE CHANGING MASK 5 TURN ON SECOND INTERRUPT CHIP # LET INTERRUPTS PASS THRU TO INTAO1, AL NOT BUSY CD_ERR DX_HF_PORT+1 AL,DIAG_CMD DX,AL NOT BUSY AH,TIME_OUT CO_EXIT DX_HF_PORT+1 AL,DX CHF_ERROR, AL AH,0 AL,DX SHORT CD_EXIT AH,BAD_CNTLR # WAIT FOR CARD START DIAGNOSE # WAIT FOR IT TO COMPLETE S TIME OUT ON DIAGNOSTIC SAVE IT 3 CHECK FOR ALL OK 04C6 E8 06A1 R 04C9 72 39 04C9 E8 08C2 R 04C9 E8 08C2 R 04C9 E8 08C2 C 04D2 E8 08C2 C 04D2 E8 08C2 C 04D3 T8 20 04D4 B9 0100 04D3 T8 20 04D4 B9 0100 04D4 BA 01F0 04D4 F8 061A R 04E2 F8 061A R 04E3 F8 061A R 04E3 E8 COMMANDII CALL JC MOV CALL JNZ # CHECK 64K BOUNDARY ERROR & OUTPUT COMMAND WAIT TM_OUT CX,256D DX,HF_PORT # WAIT FOR DATA REQUEST INTERRUPT TIME OUT SECTOR SIZE IN WORDS ; GET THE SECTOR INSW CMD BLOCK+6,ECC_MODE CMD T3 DRQ WITTOUT CX.+F.PORT CMD 12 CMD 12 CMECK.STATUS CMD ABORT CMD BLOCK+1 SHORT CMD_11 ; CHECK FOR NORMAL INPUT # WAIT FOR DATA REQUEST # GET ECC BYTES ; GO SLOW FOR BOARD # ERROR RETURNED ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK BIOS 1-12 PAGE | WAIT FOR INTERRUPT 1 | WAIT PROC NEAR | 1110 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1111 | ; MAKE SURE INTERRUPTS ARE ON ; SET INITIAL DELAY BEFORE TEST cx,cx AX.9000H 15H WT2 ; DEVICE WAIT INTERRUPT ; DEVICE TIMED OUT MQV BL,DELAY_1 : SET DELAY COUNT ;---- WAIT LOOP TEST LOOPZ JNZ DEC JNZ OMF_INT_FLAG,80H WT1 WT3 BL WT1 WTI: WT2: MOV JMP WT3: MOV MOV WT4: CMP RET WAIT ENDP ODISK_STATUSI,TIME_OUT ; REPORT TIME OUT ERROR SMORT WT4 ODISK_STATUSI,0 OHF_INT_FLAC,0 OSISK_STATUSI,0 ; SET CONDITION CODE FOR ; SET CONDITION CODE FOR CALLER ; SET CONDITION CODE FOR CALLER : CHECK THE STATUS BYTE : AN ERROR WAS FOUND : WERE THERE ANY OTHER ERRORS : NO ERROR REPORTED : ERROR REPORTED 1192 0539 E8 0676 R 1193 053C 1194 053C 80 3E 0074 R 1195 0541 C 1195 0541 C 1196 0542 C 1196 0542 C 1197 0542 C 1201 0642 BA 01F7 1200 0645 EC 1203 0646 AZ 008C R 1204 0649 BA 01F7 1204 0645 EC 1203 0646 AZ 008C R 1204 0647 F7 1AC 1204 0647 AZ 008C R 1204 0647 AZ 008C R 1205 0648 AZ 008C R 1204 0645 AZ 008C R 1204 0645 AZ 008C R 1204 0645 AZ 008C R 1214 0645 AZ 008C R 1212 0655 B4 AZ 008C R 1212 0655 B4 AZ 008C R 1213 0658 B4 AZ 008C R 1214 0655 AZ 008C R 1214 0655 AZ 008C R 1215 0655 AZ 008C R 1216 0656 AZ 008C R 1217 0657 B4 AZ 008C R 1218 0656 AZ 008C R 1219 0657 B4 00 R 1219 0657 B4 00 R 1219 0657 B4 00 R 1219 0657 B4 00 R 1210 0657 B5 AZ 0074 R 1222 0659 B5 CC 011 1222 0659 BZ 00 CC 00 1222 0657 BZ 00 CC 00 1222 0657 C 03 CHECK_ER ; ERROR REPORTED ODISK_STATUS1,0 ; SET STATUS FOR CALLER CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHECK_ST_CHE ; GET THE STATUS ; IF STILL BUSY ; REPORT OK ; CHECK FOR WRITE FAULT ; CHECK FOR NOT READY : CHECK FOR CORRECTED ECC ODISK STATUSI, AH AH, DATA CORRECTED CKST EXT AH, 0 SET ERROR FLAG KEEP GOING WITH DATA CORRECTED CKST_EX1 CHECK_ST ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK ---- 09/25/85 FIXED DISK BIOS 1-13 04-21-86 | 1228 | 1239 | 1230 | 1231 | 1232 | 1231 | 1232 | 1231 | 1232 | 1231 | 1232 | 1231 | 1232 | 1231 | 1232 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | 1231 | CHECK FIXED DISK ERROR REGISTER : PROC NEAR DX.HF PORT+1 AL, DX HF PORT+1 AL, DX HF ERROR, AL BX CX, 8 CX, 8 AC, 1 CX, 8 AC, 1 ; GET THE ERROR REGISTER ; TEST ALL & BITS ; MOVE NEXT ERROR BIT TO CARRY ; FOUND THE ERROR ; KEEP TRYING ; COMPUTE ADDRESS OF ; ERROR CODE ; GET ERROR CODE ; SAYE ERROR CODE ; SAYE ERROR CODE CK2: CKEX: NO ERR BAĎ ADDR MARK, BAD SEEK, BAD CMD, UNDEF_ERR RECÖRD_NÖT_FND, UNDEF_ERR, BAD_ECC, BAD_SECTOR ENDP CHECK_ER CHECK_DMA PUSH MOV TEST JE CKD1: GMP JB CKMP JB CKMP CKD0K: CLC CKDCRR: STC ; SAVE REGISTERS ; AH = MAX # SECTORS AL = MAX OFFSET ; ECC IS 4 MORE BYTES ; NUMBER OF SECTORS ; IT WILL FIT ; TOO MANY; ; CHECK OFFSET ON MAX SECTORS ; ERROR ; CLEAR CARRY , NORMAL RETURN ; NORMAL RETURN ; INDICATE ERROR AND A SOUNDARY AND A SOUNDARY ENDP SET UP ES1BX-> DISK PARMS : NEAR ; AX,AX ; ES.AX ; ES.ABS0 DL.1 DL.1 SHORT GV_EXTT ; SHORT GV_EXTT ; SET UP GET_VEC PROC SUB ASSUME TEST Z LES JMP GV_0: LES GV_EXIT: GET_VEC ENDP ; ES:BX -> DRIVE PARAMETERS BX, OHF_TBL_VEC ; ES:BX -> DRIVE PARAMETERS -- HARDWARE INT 76H -- ( IRQ LEVEL 14 ) ------ FIXED DISK INTERRUPT ROUT! FIXED DISK INTERRUPT ROUTINE NEAR AX DS DDS DDS HF INT_FLAG,0FFH AL,E01 INTB00,AL $+2 INTA00,AL DS HD_INT PROC PUSH FUSH CALL MOV GUT JMP POP STI MOY INT POP IRET ENDP : ALL DONE : NON-SPECIFIC END OF INTERRUPT : FOR CONTROLLER #2 : WAIT ; FOR CONTROLLER #1 RE-ENABLE INTERRUPTS DEVICE POST INTERRUPT AX,9100H 15H AX ; RETURN FROM INTERRUPT DB 11/15/85 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBO ---- 03/06/86 KEYBOARD BIOS 1-1 PAGE 118,121 TITLE KYBO ---- 03/06/86 KEYBOARD BIOS LIST CODE SEGMENT NAME --- 0000 PUBLIC PUBLIC PUBLIC PUBLIC K16 KEYBOARD_IO_1 KB_INT_1 SND_DATA SND_DATA BEEP!NEAR DOS:NEAR START !:NEAR K6:1871E K6:1871E K1:18871E K1:1871E EXTRN THESE ROUTINES PROVIDE READ KEYBOARD SUPPORT (AH) = 00H READ THE NEXT ASCII CHARACTER ENTERED FROM THE KEYBOARD, RETURN THE RESULT IN (AL), SCAN CODE IN (AH). THIS IS THE COMPATIBLE READ INTERFACE, EQUIVALENT TO THE STANDARD FO OR PCAT KEYBOARD (AH) = 01H SET THE Z FLAG TO INDICATE IF AN ASCII CHARACTER IS AVAILABLE TO BE READ. (ZF) = 1 -- NO CODE AVAILABLE (AX) = CHARACTER IS AVAILABLE (AX) = CHARACTER IN THE BUFFER TO BE READ IS IN (AX), AND THE ENTRY REMAINS IN THE BUFFER TO BE READ IS IN (AX), AND THE ENTRY REMAINS IN THE BUFFER. THIS WILL RETURN CHAPT YERMINS IN THE BUFFER. (AH) = 02H RETURN THE CURRENT SHIFT STATUS IN AL REGISTER THE BIT SETTINGS FOR THIS CODE ARE INDICATED IN THE THE EQUATES FOR WEB FLAG (AH) = 03H SET TYPAMATIC RATE AND DELAY (AH) = 05H AND THE ENTRY FROM THE REGISTER RATE REGISTER RATE REGISTER RATE TYPAMATIC R/ REGISTER VALUE 00H 01H 02H 03H 06H 06H 07H 08H 09H 00H 00H 00H RATE SELECTED 30.0 26.7 24.0 21.8 20.0 18.5 17.1 16.0 13.3 10.9 10.9 10.9 28.6 7.576.05.66.5544.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.33.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.30.075.00.075.30.075.30.075.30.075.30.075.00.075.00.075.00.00.00.00.00 . TYPAMATIC DELAY (BITS 2 7 MUST BE RESET TO 0) DELAY VALUE 250 ms 500 ms 750 ms REGISTER VALUE 03H 1000 ms PLACE ASCII CHARACTER/SCAN CODE COMBINATION IN KEYBOARD BUFFER AS IF STRUCK FROM KEYBOARD ENTRY! (C) = ASCI CHARACTER EXIT: (AL) = 00H = SUCCESSFUL OPERATION (AL) = 00H = UNSUCCESSFUL - BUFFER FULL FLAGS! CARRY IF ERROR EXTENDED READ INTERFACE FOR THE ENHANCED KEYBOARD, OTHERNISE SAME AS FUNCTION AND CTHERNISE SAME AS FUNCTION AND OTHERNISE (AH) = 05H (AH) = 11H (AH)= 12H OUTPUT AS NOTED ABOVE, ONLY (AX) AND FLAGS CHANGED ALL REGISTERS RETAINED ASSUME CS:CODE,DS:DATA >>> ENTRY POINT FOR ORG DESCHI INTERRUPTS BACK ON SAVE DIKTENT DS SAVE BX. TEMPORARILY SAVE DX. TEMPORARILY ESTABLISH POINTER TO DATA REGIO CHECK FOR (AH) = 01H ASCII READ CHECK FOR (AH) = 01H ASCII STATUS CHECK FOR (AH) = 02H SHIFT_STATUS 0000 FB 0001 FB 0001 FB 0002 53 0003 51 0004 E8 0000 E 0007 OA E4 0009 74 20 0008 FE CC 000D 74 3E 000F FE CC 000F 74 6B DS BX CX DDS AH, AH K1 AH K2 AH DATA REGION ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-2 04-21-86 0013 FE CC 0015 74 6C 02 0017 8C 02 0010 F9 0004 R 0016 F9 0004 R 0012 74 00 0022 74 00 0024 FE CC 0026 74 14 0028 FE CC 0024 74 39 0020 59 0020 59 0021 FF 0021 FF 0022 00 CHECK FOR (AH)= 03H SET TYPAMATIC RATE/DELAY CHECK FOR (AH)= 05H AH K300 AH,2 K101 K500 AH,11 K1E AH K2E AH K3E KEYBOARD WRITE AH = 10 EXTENDED ASCII READ CHECK FOR (AH) = 11H EXTENDED ASCII STATUS CHECK FOR (AH) = 12H EXTENDED_SHIFT_STATUS RECOVER REGISTER RECOVER REGISTER RECOVER SEGMENT NVALID COMMAND KIS KIO_E_XLAT KIO_EXIT K1E: ; GET A CHARACTER FROM THE BUFFER (EXTENDED) ; ROUTINE TO XLATE FOR EXTENDED CALLS ; GIVE IT TO THE CALLER 0038 E8 00C7 R 003B E8 0130 R 003E 72 F8 0040 EB EA CALL CALL JC JMP ; GET A CHARACTER FROM THE BUFFER ; ROUTINE TO XLATE FOR STANDARD CALLS ; CARRY SET MEANS THROW CODE AWAY ; RETURN TO CALLER K1: KIS KIO_S_XLAT KI _ _ KIO_EXIT KIAt :---- ASCII STATUS 0042 E8 0103 R 0045 74 18 0047 9C 0048 E8 0125 R 0048 EB 11 : TEST FOR CHARACTER IN BUFFER (EXTENDED) : RETURN IF BUFFER EMPTY : SAVE ZF FROM TEST : ROUTINE TO XLATE FOR EXTENDED CALLS : GIVE IT TO THE CALLER K2E: CALL K25 K28 JZ PUSHF CALL JMP KIO_E_XLAT SHORT K2A 004D E8 0103 R 0050 74 0D 0052 9C 0053 E8 0130 R 0056 73 06 0058 9D 0059 E8 00CT R 005C EB EF TEST FOR CHARACTER IN BUFFER RETURN IF BUFFER EMPTY SAVE ZF FROM TEST ROUTINE TO XLATE FOR STANDARD CALLS CARRY CLEAR MEANS PASS VALID CODE INVALID CODE FOR THIS TYPE OF CALL THROW THE CHARACTER WAY GO LOOK FOR NEXT CHAR, IF ANY CALL JZ PUSHF CALL JNC POPF CALL JMP K25 K2B KIO_S_XLAT K1S K2 005E 9D 005F 59 0060 5B 0061 1F 0062 CA 0002 POPF POP POP RET RESTORE ZF FROM TEST RECOVER REGISTER RECOVER REGISTER RECOVER SEGMENT THROW AWAY FLAGS K2A: K2B: - SHIFT STATUS 0065 8A 26 0018 R 0069 80 E4 04 006C B1 05 006E D2 E4 0073 24 13 0015 0A E076 R 0017 A4 0096 R 0017 A4 0096 R 0017 C4 E0 007E A4 0017 R GET THE EXTENDED SHIFT STATUS FLAGS GET SYSTEM SHIFT KEY STATUS JASK ALL BUT SYS KEY BIT SHIFT THE SYSTEM KEY BIT OVER TO SHIFT THE SYSTEM KEY BIT OVER TO GET SHIFT STATES BACK LIFE STATES SACK SACK LIFE STATES STATUS FLAGS RETURN TO CALLER AH, OKB FLAG I AH, SYS SHIFT CL, 5 AH, CL AL, OKB FLAG I AL, OHITOOH I AL, OKB FLAG 3 AL, OKB FLAG 3 AL, OKB FLAG 3 AL, OKB FLAG KIO_EXTI K3E: K3: :---- SET TYPAMATIC RATE AND DELAY AMATIC RATE AND AL, S KIO EXIT BL, GEON KIO EXIT BH, OF CH NAL, RE TYPA_RD CX, S BH, GL AL, BH AL, BH AL, BH AL, BH KIO EXIT DELAY CORRECT FUNCTION CALL? NO. RETURN TOF CONTOF-RANGE RATE THE FOR OUT-OF-RANGE DELAY TEST FOR OUT-OF-RANGE DELAY RETURN IF SO COMMAND FOR TYPAMATIC RATE/DELAY SHIFT COUNT SHIFT COUNT SHIFT DELAY OVER PUT IN RATE AND DELAY SEND TO KEYBOARD RETURN TO CALLER 0083 3C 05 0085 75 A5 0087 76 A5 0080 77 A5 0080 76 A7 0080 76 A7 0091 B0 F3 0091 B0 F3 0099 B0 A64B R 0096 B9 0005 0099 D2 ET 0090 B0 AC3 0090 AC C7 0097 E0 044B R 0042 EB 88 K300: CMP JNE TEST TEST TEXT MOV CALL MOV SHU MOV CALL JMP WRITE TO KEYBOARD BUFFER 00A4 56 00A5 FA 00A6 8B IE 001C R 00AC EB 016B R 00AF 3B IE 001A R 00B3 74 00 00B3 00 00 00B3 18 1E 001C R 00B 2A CO 00B0 EB 03 90 00C0 BD 01 00C2 FB 00C3 5E 00C4 E9 002C R ; SAVE SI K500: PUSH CLI MOV GALL CMP JE MOV MOV SUB JMP 51 K502: MOV AL,01H I BUFFER FULL INDICATION SI KIO_EXIT : RECOVER SI : RETURN TO CALLER WITH STATUS IN AL ``` KEYBOARD\_10\_1 ENDP ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-4 04-21-86 2230 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 2331 INCREMENT BUFFER POINTER ROUTINE PROC INC INC 0168 0168 43 0169 43 016A 3B 1E 0082 R 016E 75 04 0170 8B 1E 0080 R 0174 C3 0175 CMP JNE MOV RET ENDP BX, DBUFFER_END K5 BX, DBUFFER_START HARDWARE INT 09 H -- ( IRQ LEVEL ! ) ----- KEYBOARD INTERRUPT ROUTINE DDS WAIT FOR KEYBOARD DISABLE COMMAND TO BE ACCEPTED MOV AL.DIS KBD CALL SHIP_IT CLI SUB CX.CX KB_INT_OII TEST AL,INPT_BUF_FULL LOOPNZ KB_INT_OI 0183 B0 AD 0185 E8 063C R 0188 FA 0189 2B C9 0188 E4 64 018D A8 02 018F E0 FA ; DISABLE THE KEYBOARD COMMAND ; EXECUTE DISABLE ; DISABLE INTERRUPTS ; SET MAXIMUM TIMEOUT ; READ ADAPTER STATUS ; CHECK INPUT BUFFER FULL STATUS BIT ; WAIT FOR COMMAND TO BE ACCEPTED :---- READ CHARACTER FROM KEYBOARD INTERFACE 0191 E4 60 IN AL,PORT_A READ IN THE CHARACTER ;---- SYSTEM HOOK INT 16H - FUNCTION 4FH (ON HARDWARE INTERRUPT LEYEL 9H) ; SYSTEM INTERCEPT - KEY CODE FUNCTION I SET C'= 1 (IN CASE OF IRET) I CASSETTE CALL (AL) = KEY SCAN CODE I RETURNS C'= 1 FOR INVALID FUNCTION I CONTINUE IF CARRY FLAG SET (AL) = CODE I EXIT IF SYSTEM HANDLED SCAN CODE I EXIT HANDLES HARDLED SCAN AND ENABLE AH,04FH 15H 0198 72 03 0198 E9 03A0 R KB_INT_02: STI CMP JE 019D 019D FB 019E 3C FE 01A0 74 0D ; (AL)= SCAN CODE ; ENABLE INTERRUPTS AGAIN ; IS THE INPUT A RESEND ; GO IF RESEND CHECK FOR RESPONSE TO A COMMAND TO KEYBOARD CMP AL, KB_ACK JNZ KB_INT_2 01A2 3C FA 01A4 75 12 ;----- A COMMAND TO THE KEYBOARD WAS ISSUED eKB_FLAG_2,KB_FA K26 01AF 01AF FA 01BO 80 0E 0097 R 20 01B5 E9 03A0 R KB_INT_4; CLI OR JMP | DISABLE INTERRUPTS | INDICATE RESEND RECEIVED | RETURN IF NOT (ACK RETURNED FOR DATA) ♥KB_FLAG_2,KB_FE K26 :----- UPDATE MODE INDICATORS IF CHANGE IN STATE KB_INT_2: PUSH CALL MOV XOR AND JZ CALL UP0: FOP 0188 50 0188 50 0189 E8 06D8 R 018C 8A 1E 0097 R 01C2 32 D8 01C2 80 E3 07 01C5 74 03 01C7 E8 0687 R 01CA 58 ; SAVE DATA IN ; GO GET MODE INDICATOR DATA BYTE ; GO GET REVIOUS BITS ; SEE IF ANY DIFFERENT ; ISOLATE INDICATOR BITS ; IF NO CHANGE BYPASS UPDATE ; GO TURN ON MODE INDICATORS ; RESTORE DATA IN AX MAKE LED BL, ORB FLAG_2 BL, AL BL, KB LEDS UP0 SND_LED AX ``` | 426<br>427<br>428<br>429 | | PAGE | | | |-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 428 | | ļ | START OF KEY PROCESSING | | | 430<br>431<br>432 | OICH SA EO | MOY | AH, AL | ; SAVE SCAN CODE IN AH ALSO | | 433 | | : TEST FOR OVERRUN SCAN CODE FROM KEYBOARD | | | | 435<br>436<br>437<br>438<br>439 | 01CD 3C FF<br>01CF 75 03<br>01D1 E9 062D R | CMP<br>JNZ<br>JMP | AL,KB_OVER_RUN<br>K16<br>K62 | ; IS THIS AN OVERRUN CHAR?<br>; NO, TEST FOR SHIFT KEY<br>; BUFFER_FULL_BEEP | | | 01D4 0E<br>01D5 07<br>01D6 8A 3E 0096 R | K16: PUSH<br>POP<br>MOY | CS<br>ES<br>BH, #KB_FLAG_3 | : ESTABLISH ADDRESS OF TABLES : LOAD FLAGS FOR TESTING | | 443 | ; TEST TO SEE IF A READ_ID IS IN PROGRESS | | | | | 440<br>441<br>442<br>443<br>444<br>445<br>446<br>447<br>448<br>449<br>450<br>451<br>452 | 01DA F6 C7 C0<br>01DD 74 34<br>01DF 79 10<br>01E1 3C AB<br>01E3 75 AB<br>01E5 80 0E 0096 R 40<br>01EA<br>01EA 80 26 0096 R 7F<br>01EF EB 1F | TEST JZ JNS CMP JNE OR RST_RD_ID: | BH,RD_ID+LC_AB NOT ID TST_ID 2 AL,TD_T RST_RD_ID OKB_FLAG_3,LC_AB OKB_FLAG_3,NOT_RD_ID | I ARE WE DOING A READ ID? I CONTINUE IF NOT IS THE RD ID FLAG ON? I S THIS THE IST ID CHARACTER? I INDICATE IST ID WAS ON RESET THE READ ID FLAG | | 453<br>454 | OIEF EB IF | AND<br>JMP | OKB_FLAG_3,NOT RD_ID<br>SHORT ID_EX | ; RESET THE READ ID FLAG<br>; AND EXIT | | 455<br>456<br>457<br>458<br>459<br>460<br>461<br>462<br>463 | 01F1<br>01F1 80 26 0096 R BF<br>01F6 3C 54<br>01F8 74 11<br>01FA 3C 41<br>01FC 75 12 | TST_ID_2:<br>AND<br>CMP<br>JE<br>CMP<br>JNE | OKB FLAG_3,NOT LC_AB<br>AL,TD_2A<br>KX_BIT<br>AL,TD_2<br>ID_EX | RESET FLAG IS THIS THE 2ND ID CHARACTER? JUMP IF SO IS THIS THE 2ND ID CHARACTER? LEAVE IF NOT | | 462<br>463 | : A READ ID SAID THAT IT WAS ENHANCED KEYBOARD | | | | | 4666789012345677890123<br>44777767890123 | 01FE F6 C7 20<br>0201 74 08<br>0203 80 0E 0017 R 20<br>0208 E8 0687 R<br>0208 80 0E 0096 R 10<br>0210 E9 03A0 R | TEST JZ OR CALL KX_BIT: OR ID_EX: JMP | BH,SET_NUM_LK KX BIT ekB_Flag,num_State SND_LED ekB_Flag_3,kbx K26 | ; SHOULD WE SET NUM LOCK?<br>; EXIT IF NOT<br>; FORCE NUM LOCK ON<br>; GO SET THE NUM LOCK INDICATOR<br>; INDICATE ENHANCED KEYBOARD WAS FOUND<br>; EXIT | | | 0213<br>0213 3C E0<br>0215 75 07<br>0217 80 0E 0096 R 12<br>021C EB 09 | NOT_ID:<br>CMP<br>JNE<br>OR<br>JMP | AL,MC_E0<br>TEST_E1<br>*KB FLAG_3,LC_E0+KBX<br>SHORT EXTT | ; IS THIS THE GENERAL MARKER CODE?<br>! SET FLAG BIT, SET KBX, AND<br>! THROW AWAY THIS CODE | | | 021E<br>021E 3C E1<br>0220 75 08<br>0222 80 0E 0096 R 11<br>0227 E9 03A5 R | TEST_E1: CMP JNE OR EXIT: JMP | AL,MC_E1<br>NOT HC<br>ekb <sup>-</sup> flag_3,Lc_E1+kbx<br>K26A | ; IS THIS THE PAUSE KEY? SET FLAG, PAUSE KEY MARKER CODE THROW AWAY THIS CODE | | 484<br>485<br>486<br>487<br>488 | 022A<br>022A 24 7F<br>022C F6 C7 02<br>022F 74 0C | NOT_HC:<br>AND<br>TEST<br>JZ | AL,07FH<br>BH,LC_E0<br>Not_LC_E0 | ; TURN OFF THE BREAK BIT<br>; LAST CODE THE EO MARKER CODE?<br>; JUMP IF NOT | | 489<br>490<br>491<br>492 | 0231 B9 0002<br>0234 BF 0006 E<br>0237 F2/ AE<br>0239 75 65<br>0238 EB 49 | MOV<br>MOV<br>REPINE<br>JIME<br>JIMP | CX,2<br>D1,0FFSET K6+6<br>SCASB<br>K16A<br>SHORT K16B | ; LENGTH OF SEARCH<br>; 1S THIS A SHIFT KEY?<br>; CHECK IT<br>I NO, CONTINUE KEY PROCESSING<br>; YES, THROW AWAY & RESET FLAG | | 493<br>494<br>495<br>496<br>497<br>498<br>499 | 023D<br>023D F6 C7 01<br>0240 74 1D | NOT_LC_EO:<br>TEST<br>JZ | BH.LC_E1<br>T_SYS_KEY | ; LAST CODE THE E1 MARKER CODE?<br>; JUMP IF NOT | | 500<br>102<br>502 | 0242 B9 0004<br>0245 BF 0004 E<br>0248 F2/ AE<br>024A 74 DB | MOV<br>MOV<br>REPNE<br>JE | CX,4<br>D!,OFFSET K6+4<br>SCASB<br>EXIT | ; LENGTH OF SEARCH<br>; IS THIS AN ALT, CTL, OR SHIFT?<br>; CHECK IT<br>; THROW AWAY IF SO | | 503<br>504<br>505<br>506<br>507<br>508<br>509<br>510<br>512<br>613 | 024C 3C 45<br>024E 75 36<br>0250 F6 C4 80<br>0250 F6 C0 80<br>0253 75 31<br>0255 F6 06 0018 R 08<br>025A 75 2A<br>025C E9 040B R | CMP<br>JNE<br>TEST<br>JNZ<br>TEST<br>JMP | AL, NUM_KEY K 168 AH, 80H K 168 OKB FLAG_1, HOLD_STATE K 168 K 39P OR SYSTEM KEY | I S IT THE PAUSE KEY? NO, THROW ANAY A RESET FLAG YES, IS IT THE BREAK OF THE KEY? YES, THROW THIS AWAY, TOO NO, ARE WE PAUSED ALREADY? YES, THROW AWAY NO, THIS IS THE REAL PAUSE STATE | | 613 | 025F | T_SYS_KEY: | OR STSTEM NET | | | 514<br>515<br>516<br>517 | 025F<br>025F 3C 54<br>0261 75 3D | JNE | AL, SYS_KEY<br>K16A | ; IS IT THE SYSTEM KEY?<br>; CONTINUE IF NOT | | 519 | 0263 F6 C4 80<br>0266 75 21 | TEST<br>JNZ | AH,080H<br>K16C | ; CHECK IF THIS A BREAK CODE<br>; DON'T TOUCH SYSTEM INDICATOR IF TRUE | | 520<br>521<br>522<br>523<br>524 | 0268 F6 06 0018 R 04<br>026D 75 17 | TEST<br>JNZ | OKB_FLAG_1,SYS_SHIFT | ; SEE IF IN SYSTEM KEY HELD DOWN<br>; IF YES, DON'T PROCESS SYSTEM INDICATOR | | 525<br>526 | 026F 80 0E 0018 R 04<br>0274 B0 20<br>0276 E6 20 | OR<br>MOV<br>OUT | ekb flag_1,sys_shift<br>al,e01<br>020h,al | I INDICATE SYSTEM KEY DEPRESSED END OF INTERMENT COMMAND SEMENTAL | | 527<br>528<br>529<br>530 | 0278 B0 AE<br>027A E8 063C R<br>027D B8 8500<br>0280 FB<br>0281 CD 15 | MOV<br>CALL<br>MOV<br>STI | AL,ENA_KBD<br>Ship_it<br>ax,08500h | ; INSURE KEYBOARD IS ENABLED<br>; EXECUTE ENABLE<br>; FUNCTION VALUE FOR MAKE OF SYSTEM KEY | | 530<br>531<br>532<br>533 | 0280 FB<br>0281 CD 15<br>0283 E9 03AF R | STI<br>INT<br>JMP | 15H<br>K27A | I USER INTERRUPTS ENABLED I USER INTERRUPT I END PROCESSING | | 534<br>536 | 0286 E9 03A0 R | K16Bt JMP | K26 | ; IGNORE SYSTEM KEY | | 536<br>537<br>538<br>539 | 0289 80 26 0018 R FB<br>028E B0 20<br>0290 E6 20 | K16C: AND<br>MOV<br>OUT | OKB FLAG_1,NOT SYS_SHIFT<br>AL,EO!<br>020H,AL | T ;TURN OFF SHIFT KEY HELD DOWN<br>; END OF INTERRUPT COMMAND<br>; SEND COMMAND TO INTERRUPT CONTROL PORT | ``` ISM Personal Computer MACRO Assembler Version 2.00 KYSO ---- 03/06/86 KEYBOARD BIGS I INTERRUPT-RETURN-NO-E01 I INSURE KEYBOARD IS ENABLED EXECUTE ENABLE I FUNCTION VALUE FOR BREAK OF SYSTEM KEY MAKE SURE INTERRUPT USER INTERRUPT I GROME SYSTEM KEY IGNORE SYSTEM KEY 0292 B0 AE 0294 E8 063C R 0297 B8 8501 029A FB 029B CD 15 029D E9 03AF R 15H K27A 1---- TEST FOR SHIFT KEYS 02A0 8A 1E 0017 R 02A4 BF 0000 E 02A7 B9 0000 E 02AA F2/ AE 02AC 8A C4 02AE 74 03 02B0 E9 038C R KIGA: MOV MOV MOV REPNE MOV JE JMP BL, MKB_FLAG DI, OFFSET K6 CX, OFFSET K6L SCASB AL, AH K17 K25 ; PUT STATE FLAGS IN BL ; SHIFT KEY TABLE ! LENGTH ! LOOK THROUGH THE TABLE FOR A MATCH ! RECOVER SCAN CODE ! JUMP IF MATCH FOUND ! IF NO MATCH, THEN SHIFT NOT FOUND :---- SHIFT KEY FOUND D1,OFFSET K6+1 AH,CS:K7[D1] CL,2 AL,80H K17C K23 SUB MOV MOV TEST JZ JMP ; ADJUST PTR TO SCAN CODE MTCH ; GET MASK INTO AH ; SET UP COUNT FOR FLAG SHIFTS ; TEST FOR BREAK KEY K17: ; JUMP IF BREAK ;----- SHIFT MAKE FOUND, DETERMINE SET OR TOGGLE 02C5 80 FC 10 02C8 73 21 K17C: CMP AH,SCROLL_SHIFT JAE K18 ; IF SCROLL SHIFT OR ABOVE, TOGGLE KEY :----- PLAIN SHIFT KEY, SET SHIFT ON 02CA 08 26 0017 R 02CE F6 C4 0C 02D1 75 03 02D3 E9 03A0 R 02D6 F6 C7 02 02D9 74 07 02D0 08 26 0096 R 02E2 02 EC 02E4 08 26 0018 R 02E6 E9 03A0 R K170: 1----- TOGGLED SHIFT KEY, TEST FOR 1ST MAKE OR NOT 02EB F6 C3 04 02EE 74 03 02FC E7 403 02FS 35 03E R 02FS 35 03E R 02FF 75 21 02FF 76 C3 08 02FA 74 03 08 02FC E9 03EC R 03EC F6 C3 20 03EC F6 C3 20 03EC F6 C3 20 03EC F6 C3 20 03EC F6 C3 03 Kist KIBA: K188: K19: K20: 0313 F6 C3 03 0316 74 F6 K21: TEST JZ BL,LEFT_SHIFT+RIGHT_SHIFT ; MIGHT BE NUMERIC K20 ; IS NUMERIC, STD. PROC. 0318 84 26 0018 R 031C 74 03 031E E9 03A0 R 0321 08 26 0018 R 0325 30 26 0017 R ; SHIFT TOGGLE KEY HIT; PROCESS IT ; 15 KEY ALREADY DEPRESSED? AH, PKB_FLAG_1 K22A K26 PKB_FLAG_1, AH PKB_FLAG, AH ; JUMP IF KEY ALREADY DEPRESSED ; INDICATE THAT THE KEY IS DEPRESSED ; TOGGLE THE SHIFT STATE K22A: :---- TOGGLE LED IF CAPS, NUM, OR SCROLL KEY DEPRESSED TEST JZ AH, CAPS_SHIFT+NUM_SHIFT+SCROLL_SHIFT ; SHIFT TOGGLE? K22B ; GO IF NOT AX ; SAVE SCAN CODE AND SHIFT MASK SNO_LED ; GO TURN MODE INDICATORS ON X ; RESTORE SCAN CODE 0329 F6 C4 T0 032C 74 05 032E 50 032F E8 0687 R 0332 58 PUSH CALL POP AL, INS_KEY TEST FOR IST MAKE OF INSERT KEY JUMP IF NOT INSERT KEY SCAN CODE IN BOTH HALVES OF AX FLAGS UPDATED, PROC. FOR BUFFER 0333 3C 52 0335 15 69 0337 8A E0 0339 EB TF 90 CMP JNE MOV JMP K228: KZ6 AH,AL KZ8 033C 033C 80 FC 10 033F F6 D7 0341 73 43 0343 20 26 0017 R 0347 80 FC FB 034A 77 26 ; BREAK-SHIFT-FOUND ; IS THIS A TOGGLE KEY? ; INVERT MASK ; YES, HANDLE BREAK TOGGLE ; TURN OFF SHIFT BIT ; IS THIS ALT OR CTL? ; NO, ALL DONE K23: AH, SCROLL_SHIFT AH K24 •KB FLAG, AH AH, NOT CTL_SHIFT K23D K23D H.LC_EO K23A FLAG 3, AH SHORT K23B AH, CL OKB FLAG 1, AH AL, AL, OKB FLAG 3 AL, CL AL, OKB FLAG 1 AL, CL AL, AL, CL AL, AL, AL 034A 77 26 034C 76 C7 02 034F 74 06 0351 20 26 0096 R 0350 26 D6 0350 26 C6 0355 26 C6 0355 A6 0018 R 0355 A6 0096 R 0355 A6 0096 R 0362 02 28 0364 0A 06 0018 R 0364 02 26 0365 26 06 0365 26 06 0366 00 06 0017 R 0370 8A C4 I NO, ALL DONE I ZND ALT OR CTL? I NO, HANDLE NORMALLY I RESET BIT FOR RIGHT ALT OR CTL CONTINUE MASK BIT TWO POSITIONS IN THE MASK BIT TWO POSITIONS SAYE SACH CODE GET RIGHT ALT & CTRL FLAGS MOVE TO BITS 1 & 0 I PUT IN LEFT ALT & CTL FLAGS MOVE TO BITS 3 & 2 I FILTER OUT OTHER GABBAGE I PUT RESULT IN THE REAL FLAGS I RECOVER SAVED SCAN CODE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-7 04-21-86 654 0372 3C 88 655 0374 75 2A 656 0374 75 2A 656 0374 75 2A 656 0379 84 00 661 0378 88 26 662 0378 3C 00 661 0388 77 10 663 0381 77 10 664 0388 78 14 665 0384 EB 14 667 0386 2C 26 668 0384 EB 14 669 0384 EB 14 669 0384 EB 14 669 0384 EB 14 671 038C 3C 80 674 0386 73 0386 26 675 0390 76 039 676 0390 76 678 0397 73 26 678 0397 73 26 678 0397 73 26 678 0398 80 26 680 0384 EB 26 680 0384 EB 26 680 0384 EB 26 680 0384 EB 26 680 0384 EB 26 681 0386 20 682 0384 EB 26 683 0385 EB 26 684 0386 80 20 685 0386 EB 26 686 0386 EB 26 687 0386 EB 26 687 0386 EB 26 688 0386 EB 26 689 0388 EB 26 689 0388 EB 26 689 0388 EB 26 689 0388 EB 26 689 0388 EB 26 699 690 03 AL,ALT_KEY+80H K26 K23D: CMP JNE : IS THIS ALTERNATE SHIFT RELEASE : INTERRUPT_RETURN :---- ALTERNATE SHIFT KEY RELEASED, GET THE VALUE INTO BUFFER 0376 A0 0019 R 0379 B4 00 037B 88 26 0019 R 037F 3C 00 0381 74 1D 0383 E9 0601 R MOV MOV CMP JE JMP AL, FALT_INPUT AH, 0 FALT_INPUT, AH AL, 0 K26 K61 SCAN CODE OF 0 ZERO OUT THE FIELD SAS THE IMPUT = 0? INTERRUPT RETURN IT WASN'T, SO PUT IN BUFFER # BREAK-TOGGLE # INDICATE NO LONGER DEPRESSED # INTERRUPT_RETURN 0386 0386 20 26 0018 R 038A EB 14 K24: AND OKB_FLAG_1,AH SHORT K26 :---- TEST FOR HOLD STATE I AL, AH = SCAN CODE I NO-SHIFT-FOUND I TEST FOR BREAK KEY I NOTHING FOR BREAK CHARS FROM HERE ON I ARE WE IN HOLD STATE I BRANCH AROUND TEST IF NOT 038C 038C 3C 80 038E 73 10 0390 F6 06 0018 R 08 0395 74 23 0397 3C 45 0399 74 05 0398 80 26 0018 R F7 AL, 80H : NOS-SHIFT-FOUND AL, 80H : TEST FOR BREAK KEY K26 : NOTHING FOR BREAK CHARS FROM HE K26 : NAE WE IN HOLD STATE K26 : RRANCH AROUND TEST IF NOT ALLNUM_KEY K26 : RANCH AROUND TEST IF NOT ALLNUM_KEY : CAN'T END HOLD ON NUM_LOCK H36 FLAG_I, NOT HOLD_STATE : TURN OFF THE HOLD STATE BIT CMP JAE TEST JZ CMP JE AND 03A0 03A0 80 26 0096 R FC K26: AND •KB_FLAG_3,NOT LC_E0+LC_E1 ; RESET LAST CHAR H.C. FLAG : INTERRUPT-RETURN : TURN OFF INTERRUPTS : END OF INTERRUPT COMMAND : SEND COMMAND TO INTERRUPT CONTROL PORT K26A: CL I MOV OUT AL,EOI 020H,AL : INTERRUPT-RETURN-NO-EOI : INSURE KEYBOARD IS ENABLED : EXECUTE ENABLE 03AA 03AA B0 AE 03AC E8 063C R K27: AL,ENA_KBD SHIP_IT K27A: ; DISABLE INTERRUPTS ; RESTORE REGISTERS ES DS DI SI DX CX BX AX BP : RETURN ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-8 04-21-86 PAGE 1---- NOT IN HOLD STATE ; AL, AH = SCAN CODE (ALL MAKES); NO-HOLD-STATE; TEST FOR OUT-OF-RANGE SCAN CODES; IGNORE IF OUT-OF-RANGE 03BA 03BA 3C 58 03BC 77 E2 K28: 03BE F6 C3 08 03C1 74 0C TEST JZ BL,ALT_SHIFT K28A ; ARE WE IN ALTERNATE SHIFT? ; JUMP IF NOT ALTERNATE ; IS THIS THE ENHANCED KEYBOARD? ; NO, ALT STATE IS REAL 03C3 F6 C7 10 03C6 74 0A TEST JZ BH,KBX K29 03C8 F6 06 0018 R 04 03CD 74 03 03CF E9 04A3 R ; YES, IS SYSREQ KEY DOWN?; NO, ALT STATE IS REAL; YES, THIS IS PHONY ALT STATE; DUE TO PRESSING SYSREQ TEST JZ JMP K28A: TEST FOR RESET KEY SEQUENCE (CTL ALT DEL) ; TEST-RESET : ARE WE IN CONTROL SHIFT ALSO? : NO RESET : SHIFT STATE IS THERE, TEST KEY : NO_RESET, IGNORE 03D2 03D2 F6 C3 04 03D5 74 31 03D7 3C 53 03D9 75 2D K29: TEST JZ CMP JNE BL,CTL_SHIFT K31 AL,DEL_KEY K31 --- CTL-ALT-DEL HAS BEEN FOUND, DO I/O CLEANUP ORESET_FLAG, 1234H START_T ; SET FLAG FOR RESET FUNCTION ; JUMP TO POWER ON DIAGNOSTICS MOV JMP 03DB C7 06 0072 R 1234 03E1 E9 0000 E 03E4 03E4 52 4F 50 51 4B 03E9 4C 4D 47 48 49 ; 10 NUMBERS ON KEYPAD 03EE 10 11 12 13 14 15 03F4 16 17 18 19 1E 1F 03FA 20 21 22 23 24 25 0400 26 2C 2D 2E 2F 30 0406 31 32 ; A-Z TYPEWRITER CHARS 0408 30 39 0408 30 39 0400 75 05 0400 80 20 040E EP 05F6 R 0411 30 0F 0413 15 06 0418 82 05F5 R 0410 74 79 041F 30 44 64 65 04 77 79 041F 30 45 ; NO-RESET ; TEST FOR SPACE KEY ; NOT THERE ; SET SPACE CHAR ; BUFFER_FILL K31: CMP JNE MOY JMP AL.57 K311 AL. ' ' ; TEST FOR TAB KEY ; NOT THERE ; SET SPECIAL CODE FOR ALT-TAB ; BUFFER_FILL CMP JNE MOV JMP AL,15 K312 AX,0A500h K57 K312: AL,74 K378 AL,78 K378 ; TEST FOR KEYPAD - ; GO PROCESS ; TEST FOR KEYPAD + ; GO PROCESS CMP JE CMP JE 0423 BF 03E4 R 0424 B9 000A 0429 F2/AE 0420 T0 61 02 0420 T0 68 01 02 0430 T5 68 0432 61 EF 03E5 R 0436 A0 0019 R 0439 B4 0A 0439 B4 0A 0439 B4 0A 0439 B4 0A 0439 B4 0A ALT-KEYTPAD ALT-KEYTPAD ALT-KEYTPAD ALT-KEYTPAD LOOK FOR MATCH NO ALT-KEYPAD IS-THIS ONE OF THE NEW KEYS? YES, JUMP, NOT NUMPAD KEY D NOW HAS ENTRY VALUE GULTIPLY TIO K32: DI, OFFSET K30 CX,10 SCASB K33 BH,LC_E0 K37C DI, OFFSET K30+1 AH,10 AL, GALT_INPUT AH,10 AX,DI AZE MOV MOV REPNE JNE TEST JNZ SUB MOV MOV MOV MOD MOD JMP ADD IN THE LATEST ENTRY STORE IT AWAY THROW AWAY THAT KEYSTROKE K32A: LOOK FOR SUPERSHIFT ENTRY 1---- 0445 0445 C6 06 0019 R 00 044A B9 001A 044D F2/ AE 044F 74 42 K33: NO-ALT-KEYPAD ZERO ANY PREVIOUS ENTRY INTO INPUT DI,ES ALREADY POINTING LOOK FOR MATCH IN ALPHABET MATCH FOUND, GO FILL THE BUFFER ealt_INPUT,0 CX,26 SCASB K37A LOOK FOR TOP ROW ; ALT-TOP-ROW ; KEY WITH 'I' ON IT ; MUST BE ESCAPE ; IS IT IN THE REGION ; NO, ALT-SOMETHING ELSE ; CONVERT PSEUDO SCAN CODE TO RANGE GO FILL THE BUFFER 0451 0451 3C 02 0453 72 43 0455 3C 0D 0457 77 05 0459 80 C4 045C EB 35 K34: AL,2 K37B AL,13 K35 AH,118 SHORT K37A CMP JB CMP JA ADD JMP TRANSLATE ALTERNATE SHIFT PSEUDO SCAN CODES 045E 045E 3C 57 0460 72 09 0462 3C 68 0464 77 06 0466 80 C4 34 0469 EB 28 ! ALT-FUNCTION ! IS IT F!!? ! NO, BRANCH ! IS IT F!2? ! NO, BRANCH ! CONVERT TO SCAN CODE ! CO FILL THE BUFFER K35: AL,FII_M K35A AL,FI2_M K35A AH,52 SHORT K37A CMP JB CMP JA ADD JMP 046B F6 C7 02 046E 74 18 0470 3C 1C 0472 75 06 0474 88 A600 0471 E9 05F5 R 047A 3C 53 047C 74 1F TEST JZ CMP JNE MOV JMP CMP JE BH,LC_E0 K37 AL,28 K35B AX,0A600h K57 AL,83 K37C DO WE HAVE ONE OF THE NEW KI NO, JUMP TEST FOR KEYPAD ENTER NOT THERE SPECIAL CODE BUFFER FILL TEST FOR DELETE KEY HANDLE WITH OTHER EDIT KEYS K35B1 ``` ``` ISM Personal Computer MACRO Assembler Version 2.00 KYBO ---- 03/06/86 KEYBOARD BIOS 1-9 04-21-86 : TEST FOR KEYPAD / : NOT THERE, NO OTHER EO SPECIALS : SPECIAL CODE : BUFFER FILL TEST FOR FUNCTION KEYS (FI) NO FN, HANDLE W/OTHER EXTENDED IN KEYPAD REGION? OR NUMLOCK, SCROLLOCK? IF SO, IGNORE CONVEXT TO PSEUDO SCAN CODE CMP JB CMP 0488 3C 3B 048A 72 0C 048C 3C 44 048E 77 B2 0490 80 C4 2D JA ADD K32A AH.45 K37A: AL,0 K57 0493 B0 00 0495 E9 05F5 R ; USE SPECIAL ASCII CODE ; PUT IT IN THE BUFFER 0498 B0 F0 049A E9 05F5 R K378: AL, OFOh K57 CONVERT SCAN CODE (EDIT KEYS); (SCAN CODE NOT IN AH FOR INSERT); PUT IT IN THE BUFFER AL,80 AH,AL K37A K37C: :---- NOT IN ALTERNATE SHIFT ; NOT-ALT-SHIFT ; BL STILL HAS SHIFT FLAGS ; ARE WE IN CONTROL SHIFT? ; YES, START PROCESSING ; NOT-CTL-SHIFT K38: ;----- CONTROL SHIFT, TEST SPECIAL CHARACTERS 1---- TEST FOR BREAK K38A: CMP AL,SCROLL_KEY UNE K39 TEST BH,KBX UZ K38B TEST BH,LC_E0 UZ K38B ; TEST FOR BREAK ; JUMP, NO-BREAK ; IS THIS THE ENHANCED KEYBOARD? ; NO, BREAK IS VALID ; YES, WAS LAST CODE AN EO? ; NO-BREAK, TEST FOR PAUSE K38B: MOV BX, •BUFFER_HEAD MOV •BUFFER_TATL, BX MOV •B10S_BREAK, 80H 0489 88 1E 001A R 0480 89 1E 001C R 04C1 C6 06 0071 R 80 , RESET BUFFER TO EMPTY TURN ON BIOS_BREAK BIT 1----- ENABLE KEYBOARD MOV AL,ENA_KBD CALL SHIP_IT INT IBH SUB AX,AX JMP K57 04C6 B0 AE 04C8 E8 063C R 04CB CD 1B 04CD 2B C0 04CF E9 05F5 R : ENABLE KEYBOARD : EXECUTE ENABLE : BREAK INTERRUPT VECTOR : PUT OUT DUMMY CHARACTER : BUFFER_FILL K39: : NO-BREAK : IS THIS THE ENHANCED KEYBOARD? : YES, THEN THIS CAN'T BE PAUSE : LOOK FOR PAUSE KEY : NO-PAUSE : TURN ON THE HOLD FLAG 04D2 04D2 F6 C7 10 04D5 75 2A 04D7 3C 45 04D9 75 26 04D8 80 0E 0018 R 08 TEST JNZ CMP JNE OR BH,KBX K41 AL,NUM_KEY K41 ФKB_FLAG_1,HOLD_STATE K39P: ----- ENABLE KEYBOARD MOV CALL MOV OUT AL.ENA_KBD SHIP_IT AL.EOI 020H.AL : ENABLE KEYBOARD : EXECUTE ENABLE : END OF INTERRUPT TO CONTROL PORT : ALLOW FURTHER KEYSTROKE INTS 04E0 B0 AE 04E2 E8 063C R 04E5 B0 20 04E7 E6 20 |----- DURING PAUSE INTERVAL, TURN CRT BACK ON 04E9 80 3E 0049 R 07 04EE 74 07 04F0 BA 03D8 04F3 A0 0065 R 04F6 EE 04F7 F6 06 0018 R 08 04FC 75 F9 04FE E9 03AA R ; IS THIS BLACK AND WHITE CARD ; YES, NOTHING TO DO ; PORT FOR COLOR CARD ; GET THE VALUE OF THE CURRENT MODE ; SET THE CAT MODE, SO THAT CRT IS ON ; PAUSE-LOOP CMP JE MOV MOV OUT PCRT_MODE,7 K40 DX,03D8H AL,PCRT_MODE_SET DX,AL K40: OKB_FLAG_1,HOLD_STATE K40 K27 ; LOOP UNTIL FLAG TURNED OFF ; INTERRUPT_RETURN_NO_EOI :---- TEST SPECIAL CASE KEY 55 CMP JME TEST JZ TEST JZ K41A: MOY JMP 0501 0501 3C 37 0503 75 10 0505 F6 C7 10 0508 74 05 050A F6 C7 02 050D 74 20 050F B8 7200 0512 E9 05F5 R I NO-PAUSE I TEST FOR "/PRTSC KEY I NOT-KEY-55 I S THIS THE ENHANCED KEYBOARD? NO, CTL-PRTSC IS VALID I YES, WAS STOODE AMERO? START/STOOP FINTING SWITCH BUFFER_FILL AL,55 K42 BH,KBX K41A BH,LC_E0 K42B AX,114*256 K57 |----- SET UP TO TRANSLATE CONTROL SHIFT ; NOT-KEY-55 ; IS 17 THE TAB KEY? ; YES, XLATE TO FUNCTION CODE ; IS 11 THE / KEY? ; NO, NO MORE SPECIAL CASES ; YES, 15 IT FROM THE KEYPAD? NO, 100T TRANSLATE ; YES, SPECIAL CODE FOR THIS ONE ; BUFFER FILL 0515 0515 3C 0F 0517 74 16 0519 3C 35 0518 75 0B 051D F6 C7 02 0520 74 06 0522 B8 9500 0525 E9 05F5 R AL, 15 K42B AL, 53 K42A BH,LC_E0 K42A AX,9500h K57 CMP JE CMP JNE TEST JZ MOV JMP 0528 BB 0000 E 0528 3C 3B 052D 72 5E 052F BB 0000 E 0532 E9 05E4 R BX,OFFSET K8 AL,59 K45F BX,OFFSET K8 K64 : SET UP TO TRANSLATE CTL : IS IT IN CHARACTER TABLE? : YES, GO TRANSLATE CHAR : SET UP TO TRANSLATE CTL : NO, GO TRANSLATE_SCAN K42B: :---- NOT IN CONTROL SHIFT K44: CMP ; PRINT SCREEN KEY? 0535 3C 37 AL,55 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-10 04-21-86 K45 ; BH,KBX ; K44A ; K44A ; SH,LC_E0 ; K44B ; SHORT K45C ; SHORT K45C ; BL,LEFT_SMIFT+RIGHT_SHIFT K45C NOT-PRINT-SCREEN IS THIS ENHANCED KEYBOARD? NO, TEST FOR SHIFT STATE YES, LAST CODE A MARKER? YES, IS PRINT SCREEN NO, XLATE TO "" CHARACTER HOT TOIL RID, SHIFT KEY DOBY; IND, XLATE TO "" CHARACTER IND YOU KNOWN TO CHARACTER IND YOU KNOWN TO CHARACTER IND YOU KNOWN TO CHARACTER IND YOU KNOWN TO CHARACTER IND YOU KNOWN TO CHARACTER IND YOU KNOWN TO CHARACTER 932 0537 F6 C7 10 934 0537 F6 C7 10 935 0537 F6 C7 10 936 05387 F6 C7 02 936 0541 F6 C7 02 936 0545 F6 C3 03 937 0545 E6 C3 03 938 0545 F6 C3 03 940 0545 E8 08 941 0546 E8 063C R 942 0546 E8 063C R 943 0546 E8 063C R 944 0547 E8 020 945 0555 E6 20 945 0555 E6 20 946 0555 E7 02 C6 03 950 055C E9 03AA R 950 055C E9 03AA R 951 055C E9 03AA R 952 055C E9 03AA R 953 055C E9 03AA R 953 055C E9 03AA R 954 055C E9 03AA R 955 055C E9 03AA R 956 055C E9 03AA R 957 055C E9 03AA R 958 03 JNE TEST JZ TEST JNZ JMP TEST JZ 054A BO AE 054C E8 063C R 054F B0 20 0551 E6 20 0558 E0 0554 CD 05 0556 DD 05 0557 B0 26 0096 R FC 055C E9 03AA R HANDLE THE IN-CORE KEYS K45: ; NOT-PRINT-SCREEN ; TEST FOR IN-CORE AREA ; JUMP IF NOT CMP JA AL,58 K46 CMP JNE TEST JNZ AL,53 K45A BH,LC_E0 K45C : IS THIS THE "/" KEY? : NO, JUMP : WAS LAST CODE THE MARKER? ; YES, TRANSLATE TO CHARACTER ; LENGTH OF SEARCH ; POINT TO TABLE OF A-Z CHARS ; IS THIS A LETTER KEY? ; NO, SYMBOL KEY 056C 89 001A 056F BF 03EE R 0572 F2/ AE 0574 75 05 MOV MOV REPNE JNE CX,26 DI,OFFSET K30+10 SCASB K45B K45A: ; NO, STHEME TO CAPS LOCK? | TEST FOR SURE LOCK? | TEST FOR SURE SUBSTITUTE TO TATE? | TAME NE UPPERCASE | NO, LOWERCASE | TRANSLATE TO LOWERCASE LETTERS TEST JNZ TEST JNZ BL,CAPS_STATE : K45D : BL,LEFT_SHIFT+RIGHT_SHIFT K45E K45B: 0580 BB 0000 E 0583 EB 50 0585 0685 F6 C3 03 0588 75 F6 058A BB 0000 E 058D EB 46 K45C: BX,OFFSET KIO SHORT K56 BL, LEFT_SHIFT+RIGHT_SHIFT ; CL ON. 15 SHIFT ON, TOO? K45C ; SHIFTED TEMP OUT OF CAPS STATE BX, OFFSET KII ; TRANSLATE TO UPPERCASE LETTERS K45D: TEST JNZ MOV JMP K45E: K45F: ---- TEST FOR KEYS F1 - F10 1---- K46: ; NOT IN-CORE AREA ; TEST FOR F1 - F10 ; JUMP IF NOT ; YES, GO DO FN KEY PROCESS AL,68 K47 SHORT K53 :----- HANDLE THE NUMERIC PAD KEYS ; NOT F1 - F10 ; TEST FOR NUMPAD KEYS ; JUMP IF NOT CMP JA K48: TEST JNZ TEST JNZ BL,NUM_STATE ; ARE WE IN NUM_LOCK? ; TEST FOR SURE ; TEST FOR SURE ; ARE WE IN SHIFT STATE? ; IF SHIFTED, REALLY NUM STATE BL,LEFT_SHIFT+RIGHT_SHIFT BASE CASE FOR KEYPAD CMP AL.76 JNE K49A MOV AL.0F0h JMP K51 MOV BX,OFFSET K10 JMP SHORT K64 1---- K49: 05B0 3C 4C 05B2 75 05 05B4 B0 F0 05B6 EB 3D 90 05B9 BB 0000 E 05BC EB 26 ; SPECIAL CASE FOR BASE STATE 5 ; CONTINUE IF NOT KEYPAD 5 ; SPECIAL ASCII CODE ; BUFFER FILL ; BASE CASE TABLE ; CONVERT TO PSEUDO SCAN K49A: MIGHT BE NUM LOCK, TEST SHIFT STATUS TEST BL,LEFT_SHIFT+RIGHT_SHIFT JNZ K49 1 SHIFTI JMP SHORT K45E 1 REALL' STATUS FT :ALMOST-NUM-STATE : SHIFTED TEMP OUT OF NUM STATE : REALLY_NUM_STATE K50: 05BE F6 C3 03 05C1 75 ED 05C3 EB C5 K51: ;----- TEST FOR THE NEW KEY ON WT KEYBOARDS ; NOT A NUMPAD KEY ; IS IT THE NEW WT KEY? ; JUMP IF NOT ; HANDLE WITH REST OF LETTER KEYS K52: AL,86 K53 SHORT K45B K53: TEST BL.LEFT_SHIFT+RIGHT_SHIFT IFST SHIFT STATE JZ K49 ; JUMP, LOWERCASE PSEUDO SC'S MOV : UPPER CASE PSEUDO SCAN CODES : TRANSLATE_SCAN BX,OFFSET K11 SHORT K64 ;---- TRANSLATE THE CHARACTER I TRANSLATE-CHAR I CONVERT ORIGIN I CONVERT THE SCAN CODE TO ASCII I IS THIS A NEW KEY? I NO, GO FILL BUFFER I YES, PUT SPECIAL MARKER IN AH PUT II NITO THE BUFFER AL CS:K11 OKB_FLAG_3,LC_EO K57 AH,MC_EO SHORT_K57 DEC XLAT TEST JZ MOV JMP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 KYBD ---- 03/06/86 KEYBOARD BIOS 1-11 04-21-86 1----- TRANSLATE SCAN FOR PSEUDO SCAN CODES ; TRANSLATE-SCAN-ORGD ; CONVERT ORIGIN ; CTL TABLE SCAN ; PUT VALUE INTO AH ; ZERO ASCII CODE ; IS THIS A NEW KEY? ; NO, GO FILL BUFFER ; YES, PUT SPECIAL MARKER IN AL K64: AL CS:K8 AH,AL AL,0 6KB_FLAG_3,LC_E0 K57 AL,MC_E0 JZ MOV :---- PUT CHARACTER INTO BUFFER ; BUFFER-FILL ; IS THIS AN IGNORE CHAR ; YES, DO NOTHING WITH IT LOOK FOR -! PSEUDO SCAN ; NEAR_INTERRUPT_RETURN : NEAR-INTERRUPT-RETURN : INTERRUPT_RETURN K59: GET THE END POINTER TO THE BUFFER SAVE THE VALUE ADVANCE THE TAIL BEEP AS THE MEAPPED AROUND BUFFER WRAPPED AROUND BUFFER FULL BEEP STORE THE POINTER UP THEN OFF INTERRUPTS COMMAND TO INTERRUPT CONTROL PORT INSURE KEYBOARD IS ENABLED EXECUTE ENABLE DESCRIPTE ENABLE OF THE PERFORM OTHER FUNCTION I; RESET LAST CHAR H.C. FLAG INTERRUPT_RETURN K4 BX, OBUFFER_HEAD K62 [SI], AX OBUFFER_TAIL, BX AL_EOI | 1 INTAOO, AL | 1 INTAOO, AL | 1 INTAOO, AL | 1 AL_ENA_KBD | 1 SHIP 1 | 1 SAL_ENA_KBD | 1 SHIP 1 S ;----- BUFFER IS FULL SOUND THE BEEPER K62: : ENABLE INTERRUPT CONTROLLER CHIP I DIVISOR FOR 1760 HZ I SHORT BEEP COUNT (1/16 + 1/64 DELAY) I GO TO COMMON BEEP HANDLER ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 PRT ----- 06/10/85 PRINTER ADAPTER BIOS 1-2 04-21-86 005A 5B 005B B0 005D 42 005F FA 005F EE 0060 EB 00 0064 B0 0C 0066 EE 0067 FB 0068 58 SEND STROBE PULSE RESTORE (BX) WITH TIMEOUT COUNT STROBE LOW (BIT ON) OUTPUT STROBE TO CONTROL PORT PREVENT INTERRUPT PULSE STRETCHING OUTPUT STROBE BIT USE STRETCHING OUTPUT STROBE BIT OF CLIME OADING AND FOR CORRECT PULSE WIDTH SET THE -STROBE HIGH B40: 16-67-8-90-1-23-45-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-4-5-67-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90-1-23-8-90- BX AL, ODH DX POP MOV INC CLI OUT JMP JMP MOV OUT STI POP DX,AL $+2 $+2 AL,OCH DX,AL : INTERRUPTS BACK ON : RECOVER THE DUTPUT CHAR AX ;---- PRINTER STATUS 0069 50 0069 50 0064 8B 94 0008 R 0066 42 0066 EC 0071 8A EC 0071 8A EC 0073 8D 64 F8 0076 5A 20079 8D 674 48 007C EB AC B50: AX ; SAVE (AL) REGISTER PUSH B60: GET PRINTER ATTACHMENT BASE ADDRESS POINT TO CONTROL PORT PRE-CHARGE -BUSY LINE IF FLOATING GET PRINTER STATUS HARDWARE BITS SAVE T URN OFF UNUSED BITS MOV INC IN IN MOV AND DX, PPRINTER_BASE[SI] DX AL.DX AL.DX AH,AL AH,OF8H B70: POP MOV XOR JMP DX AL,DL AH,48H B10 PRECOVER (AL) REGISTER HOVE CHARACTER INTO (AL) FILIP A COUPLE OF BITS RETURN FROM ROUTINE WITH STATUS IN AH INITIALIZE THE PRINTER PORT 007E 50 007E 50 007E 42 0080 42 0080 82 0083 8E 0084 88 0FA0 0087 0087 87 FD 008A 80 0C 008D EB DB 008D PUSH INC INC MOY OUT MOY SAVE (AL) ; SET INIT LINE LOW ; ADJUST FOR INITIALIZATION DELAY LOOP ; INIT LOOP ; LOOP FOR RESET TO TAKE ; INIT LOOP ; NO INTERRUPTS, NON AUTO LF, INIT HIGH B90: DEC JNZ MOY OUT JMP AX B90 AL,OCH DX,AL B60 ; EXIT THROUGH STATUS ROUTINE ENDP PRINTER_IO_1 008F CODE ENDS ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 RS232 --- 06/10/85 COMMUNICATIONS BIOS (RS232) 1-1 04-21-86 PAGE 118,121 TITLE RS232 ---- 06/10/85 COMMUNICATIONS BIOS (RS232) .286C .LIST CODE SEGMENT BYTE PURP IO SEGMENT BYTE PUBLIC PUBLIC RS232 IO 1 EXTRN A1:NEĀR EXTRN DDS:NEAR 0000 (AH) = 00H INITIALIZE THE COMMUNICATIONS PORT (AL) HAS PARAMETERS FOR INITIALIZATION 4 3 -PARITY-- 2 1 0 STOPBIT --WORD LENGTH- 7 6 5 ---- BAUD RATE -- (AH) = 01H SEND THE CHARACTER IN (AL) OVER THE COMMO STATUS (AH=03H) (AH) = 01H SEND THE CHARACTER IN (AL) OVER THE COMMO LINE (AL) REGISTER IS PRESERVED ON EXIT, BIT 7 OF AH IS SET IF THE ROUTINE WAS UNABLE TO TO TRANSMIT THE BYTE OF DATA OVER THE LINE. IF BIT 7 OF AH IS NOT SET, THE REMAINDER OF (AH) IS SET AS IN A STATUS REQUEST, (AH) = 02H RECEIPTING THE CURRENT STATUS OF THE LINE. (AE) RECEIPTING THE CURRENT STATUS OF THE LINE. RETURNING TO ALLER TO ALLER TO SET ON EXIT, (AH) HAS THE CURRENT LINE STATUS, AS SET BY THE THE STATUS ROUTINE, EXCEPT THAT THE ONLY BITS LEFT ON ARE THE ERROR BITS (7,4,3,2,1) IF (AH) HAS BIT 7 ON (TIME OUT) THE REMAINING BITS ARE NOT PREDICTABLE. (AH) = 03H RETURN THE COMMO POTY STATUS IN (AX) (AH) IS NON ZERO ONLY WHEN AN ERROR OCCURRED. (AH) BIT 5 = TRANSMIT SHIFT REGISTER EMPTY BIT 6 = TRANSMIT SHIFT REGISTER EMPTY BIT 6 = TRANSMIT SHIFT REGISTER EMPTY BIT 6 = TRANSMIT SHIFT REGISTER EMPTY BIT 6 = TRANSMIT SHIFT REGISTER EMPTY BIT 7 = RECEIVE LINE SIGNAL DETECT BIT 7 = RECEIVE LINE SIGNAL DETECT BIT 6 = RING INDICATOR BIT 7 = RECEIVE LINE SIGNAL DETECT BIT 6 = RING INDICATOR BIT 7 = CLEAR TO SEND BIT 3 = DELTA RECEIVE LINE SIGNAL DETECT BIT 4 = CLEAR TO SEND BIT 3 = DELTA RECEIVE LINE SIGNAL DETECT BIT 1 = DELTA ACCOUNTED THE PROTECTION 2 = DELTA ACCOUNTED THE PROTECTION BIT (DX) = PARAMETER INDICATING WHICH RS232 CARD (0 - 3 ALLOWED) AREA 9RS232 BASE CONTAINS THE BASE ADDRESS OF THE 8250 ON THE CARD LOCATION 400H CONTAINS UP TO 4 RS232 ADDRESSES POSSIBLE DATA AREA LABEL 9RS232 TIM OUT (BYTE) CONTAINS OUTER LOOP COUNT VALUE FOR TIMEOUT (DEFAULTS) AX MODIFIED ACCORDING TO PARAMETERS OF CALL ALL OTHERS UNCHANGED ASSUME CS:CODE, DS:DATA RS232_10_1 CS:CODE, DS:DATA PROC FAR 0000 FB 0001 1E 0002 52 0003 56 0004 57 0005 51 0006 53 0009 58 FA 0009 58 FA 0009 58 FA 0000 58 FA 0000 15 80 PA 0010 15 80 PA 0010 15 80 PA 0011 58 PA 0011 58 PA 0012 ES 0000 E 0015 58 PA 0012 ES 0000 E 0015 58 PA 0016 74 184 0021 FE CC 0023 74 48 0025 FE CC 0023 74 48 0025 FE CC 0021 74 10 0021 FE CC 0023 75 03 0020 EP 008B R 0031 59 0031 59 0031 59 0031 59 0031 59 0031 59 0031 59 0031 59 DS DX SI SI CX SI, DX DI, DX DX, 2 SI, I DDS, PRS232_BASE[SI] DX, DX AAA, AH AAA AH AAA AH : INTERRUPTS BACK ON ; SAVE SEGMENT STI HEREN STILL PUSH PUSH PUSH PUSH PUSH MON STALL OR JUST COLUMN ; RS232 VALUE TO (SI) ; AND TO (DI) (FOR TIMEOUTS) ; TEST PARAMETER ; RETURN IF NOT IN RANGE ; WORD OFFSET ; GET BASE ADDRESS ; TEST FOR 0 BASE ADDRESS ; TEST FOR (AH) = 00H ; TEST FOR (AH) = 01H ; TEST FOR (AH) = 01H ; TEST FOR (AH) = 02H ; TEST FOR (AH) = 02H ; TEST FOR (AH) = 02H A2: DEC JNZ JMP ; TEST FOR (AH)= 03H COMMUNICATION STATUS 43 t 1 RETURN TO CALLER, NO ACTION ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 RS232 --- 06/10/85 COMMUNICATIONS BIOS (RS232) 1-2 04-21-86 PAGE :---- INITIALIZE THE COMMUNICATIONS PORT 0037 0037 8A E0 0039 83 C2 03 003C B0 80 003E EE MDY ADD MOY OUT AH,AL DX,3 AL,80H DX,AL 1---- DETERMINE BAUD RATE DIVISOR NE BAUD RATE DIVISOR DL,AH DL,CEL DL,CEL DL,OEN DL,OFSET AI DI,OFSET AI DX,AN AL,CS:[DI]+1 DX,AL S+2 AL,CS:[DI] DX,AL DX,A 003F 8A D4 0041 81 04 0043 30 C2 0045 30 C2 0049 8P 0000 E 0040 8P 0000 R 0052 42 0053 221 8A 45 01 0058 EE 0058 2E1 8A 05 MOY MOY AND MOY THE CONTROL MOY AND DEC JMP MOY AND DEC DEC JMP MOY AND DEC JMP JMP JMP : GET PARAMETERS TO (DL) ; ISOLATE THEM : BASE OF TABLE : PUT INTO INDEX REGISTER : POINT TO HIGH ORDER OF DIVISOR GET HIGH ORDER OF DIVISOR : 1/O DELAY : OET LOW ORDER OF DIVISOR : SET LOW OF DIVISOR : GET PARAMETERS BACK : STRIP OFF THE BAUD BITS : LINE CONTROL TO 8 BITS : 1/0 DELAY : INTERRUPT ENABLES ALL OFF COM_STATUS SEND CHARACTER IN (AL) OVER COMMO LINE 0070 50 22 04 0074 80 03 02 04 0074 80 03 02 04 0076 82 0078 82 0078 82 0078 82 0078 82 0078 83 0078 83 0078 83 0078 83 0078 83 0078 83 0078 83 0078 83 0078 83 0078 83 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 84 0078 8 A5: SAYE CMAR TO SEND MODEM CONTROL REGISTER DTR AND RTS DATA TERMINAL READY, REQUEST TO SEND MODEM STATUS REGISTER PUSH ADD MOY OUT INC INC MOY CALL JE ; DATA SET READY & CLEAR TO SEND ; ARE BOTH TRUE ; YES, READY TO TRANSMIT CHAR A7: CX AL,CL A8: 0088 48 A8 0088 4A 0089 87 20 0088 E8 00CA R 008E 75 F0 0090 83 EA 05 0093 59 0094 8A C1 0096 EE 0097 EB 97 CLEAR TO SEND LINE STATUS REGISTER WAIT SEAD IS TRANSMITTER READY IS TRANSMITTER READY I STATUS CONTRANSMITTER READY OUT CHAR OUT CHAR OUT CHAR I CHAR I CATE RECOVER IN CX TEMPORARILY MOVE CHAR TO AL FOR OUT, STATUS IN AH OUTPUT CHARACTER RETURN A9: DΧ DEC A10: BH.20H WAIT_FOR_STATUS A7 SUB POP MOV OUT JMP DX.6 CX AL,CL DX,AL RECEIVE CHARACTER FROM COMMO LINE 0099 83 C2 04 009C 80 01 009E 8E 00 009F 42 00A0 42 00A1 87 20 00A3 8B 00CA R 00A6 75 D8 00A8 4A 00A9 8T 01 00A8 88 00CA R 00A8 75 D3 DX,4 AL,1 DX,AL DX DX ADD MOV OUT INC INC | MODEM STATUS RECISIER | MAIT_DST READY | DATA SET READY | TATA SET READY | TEST FOR DSR | TATUSH WITH ERROR | MAIT_DSR END | MAIT_DSR END | MAIT_DSR END | TATUSH WITH ERROR | MAIT RECY | RECETVE BUFFER FULL | SET TIME OUT ERROR | SET TIME OUT ERROR | TEST FOR ERROR CONDITIONS ON RECEIVE A13: A15: DEC ĐΧ A161 A17: AND DATA FORT GET CHARACTER FROM LINE RETURN 0083 88 94 0000 R 0087 EC 0088 E9 0030 R 0088 88 94 0000 R 0088 88 92 05 0002 EC 0003 8A EO 0005 42 0006 EC 0007 E9 0030 R A18; DX, @RS232_BASE[SI] DX, 5 AL, DX AH, AL DX AL, DX AL, DX A3 ; CONTROL PORT ; GET LINE CONTROL STATUS ; PUT IN (AH) FOR RETURN ; POINT TO MODEM STATUS REGISTER ; GET MODEM CONTROL STATUS ; RETURN ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO: --- 03/24/86 VIDEO DISPLAY BIOS 1-1 04-21-86 PAGE 118,121 TITLE VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS LIST CODE SEGMENT BYTE PUBLIC 134567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345078901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567 SEGMENT BYTE PUBLIC PUBLIC ACT DISP PAGE PUBLIC READ_AC CURRENT PUBLIC READ_LEN PUBLIC SCROLL_DOWN PUBLIC SCROLL_DUP PUBLIC SCROLL_UP PUBLIC SET_CPOS WRITE_OF PUBLIC WRITE_OF PUBLIC VIDEO_STĀTE EXTRN BEEP:NEAR EXTRN CRT_CHAR GEN:NEAR EXTRN DDSINEAR EXTRN MS:WORD EXTRN M6:BYTE EXTRN M7:BYTE ; SPEAKER BEEP ROUTINE ; CHARACTER GENERATOR GRAPHICS TABLE ; LOAD LOS WITH DATA SEGMENT SELECTOR ; REGEN BUFFER LENGTH TABLE ; COLUMNS PER MODE TABLE ; MODE SET VALUE PER MODE TABLE --- INT 10 H ----- VIDEO_IO THESE ROUTINES PROVIDE THE CRT DISPLAY INTERFACE THE FOLLOWING FUNCTIONS ARE PROVIDED: CHARACTER HANDLING ROUTINES CHARACTER HANDLING ROUTINES (AH) = 08H READ ATTRIBUTE/CHARACTER AT CURRENT CURSOR POSITION (BH) = 015PLAY PAGE (YALID FOR ALPHA MODES ONLY) (AL) = CHAR READ (AH) = ATTRIBUTE/CHARACTER READ (ALPHA MODES ONLY) (AH) = 09H WRITE ATTRIBUTE/CHARACTER AT CURRENT CURSOR POSITION (BH) = DISPLAY PAGE (YALID FOR ALPHA MODES ONLY) (BH) = DISPLAY PAGE (YALID FOR ALPHA MODES ONLY) (BL) = ATTRIBUTE/OF CHARACTER TO WRITE (BL) = ATTRIBUTE OF CHARACTER (ALPHA)/COLOR OF CHAR (GRAPHICS): SEE NOTE ON WRITE OTF OR BIT TO FOR BIT TO FE L = 1. (AH) = 0AH WRITE CHARACTER ONLY AT CURRENT CURSOR POSITION (CX) = COUNT OF CHARACTERS TO WRITE (AL) = CHARACTER INTERFACE WHILE IN GRAPHICS MODES FOR READ/WRITE CHARACTER INTERFACE WHILE IN GRAPHICS MODES. FOR READ/WRITE CHARACTER INTERFACE WHILE IN GRAPHICS MODES. ARE CONTAINED THERE TO MAIN THE SECOND 128 CHARS. ARE CONTAINED THERE TO READ WRITE TES SECOND 128 CHARS. THE USER MUST INITIALIZE THE POINTER AT INTERRUPT 1FH (LOCATION GOOTCH) TO POINT TO THE IS $12.8 CHARS. FOR WRITE CODE POINTS FOR THE SECOND 128 CHARS. FOR WRITE CODE POINTS FOR THE SECOND 128 CHARS (128-265). ATTOR CONTAINED IN CONTAINED ON CENTRY WILL PRODUCE VALID RESULTS ONLY FOR CHARACTERS CONTAINED ON THE SAME ROW. CONTINUATION TO SUCCEEDING LINES WILL NOT PRODUCE CORRECTLY. ``` ``` 111111222222346647890123466478901234664789012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123456489012345648901234564890123 GRAPHICS INTERFACE (AH) = OCH WRITE DOT THE HIGH INTENSITY BACKGROUND SET. (DX) = ROW NUMBER (CX) = COLUMN NUMBER (AL) = COLOR VALUE | FBIT 7 OF AL = I, THEN THE COLOR VALUE IS EXCLUSIVE OR WITH THE CURRENT CONTENTS OF THE DOT (AH) = ODH READ DOT (DX) = ROW NUMBER (CX) = COLUMN NUMBER (AL) RETURNS THE DOT READ ASCI! TELETYPE ROUTINE FOR OUTPUT ASCII TELETYPE ROUTINE FOR OUTPUT (AH) = 0EH WRITE TELETYPE TO ACTIVE PAGE (AL) = CHAR TO WRITE (BL) = FOREGROUND COLOR IN GRAPHICS MODE NOTE -- SCREEN WIDTH IS CONTROLLED BY PREVIOUS MODE SET (AH) = 0FH CURRENT VIDEO STATE (AL) = MODE CURRENTLY SET (SEE (AH) = 00H FOR EXPLANATION) (AH) = 10H RESERVED (AH) = 10H RESERVED (AH) = 12H RESERVED (AH) = 13H WRITE STRING CS - LENGTH OF CHARACTER STRING TO BE WRITTEN DX - CURSOR POSITION FOR STRING TO BE WRITTEN CX - LENGTH OF CHARACTER STRING TO BE WRITTEN DX - CURSOR POSITION FOR STRING TO BE WRITTEN CHARACTER OF CHARACTER STRING TO BE WRITTEN DX - CURSOR POSITION FOR STRING TO BE WRITTEN DX - PAGE NUMBER RESERVED WRITE STRING CX - LENGTH OF CHARACTER STRING TO BE WRITTEN CX - LENGTH OF CHARACTER STRING TO WRITTEN CX - LENGTH OF CHARACTER STRING TO WRITTEN CX - LENGTH OF CHARACTER STRING TO BE WRITTEN WRITE CHARACTER STRING BL - ATTRIBUTE STRING IS < CHARA, CHAR, . . , CHAR> CURSOR NOT WOVED STRING IS < CHARACHAR, . . , CHAR> CURSOR IS MOVED (AL) = 01H WRITE CHARACTER STRING AND MOVE CURSOR BL CHARACTER AND ATTRIBUTE STRING (AL) = 02H WRITE CHARACTER AND ATTRIBUTE STRING (AL) = 03H WRITE CHARACTER AND ATTRIBUTE STRING (VALID FOR ALPHA MODES ONLY) STRING IS NOT MOVED (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTE STRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTE STRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTE STRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS < CHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTE STRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY) STRING IS SCHARACTER AND ATTRIBUTES TRING AND MOVE CURSOR (VALID FOR ALPHA MODES ONLY BX,CX,DX,SI,DI,BP,SP,DS,ES,SS PRESERVED DURING CALLS EXCEPT FOR BX,CX,DX RETURN VALUES ON FUNCTIONS 03H,04H,00H AND 0DH. ON ALL CALLS AX 15 MODIFIED. CSICODE, DSIDATA, ESINOTHII OFFSET OF 0000 005F R 0002 0145 R 0004 0145 R 0006 0165 R 0006 0165 R 0006 0216 R 0006 0218 R 0006 0218 R 0010 0303 R 0012 0340 R 0014 0392 R 0016 0167 R 0020 013D R 0022 013D R 0024 013D R 0024 013D R RESERVED RESERVED RESERVED CASE 13H, WRITE STRING 0028 0028 FB 0029 FC 002A 80 FC 14 002D 73 2F PROC AH,M1L/2 ES SS SS ; SAVE WORK AND PARAMETER REGISTERS DX CX DX SI D1 BP SI,DATA DS; SI SI SI,DATA SS, SI SI SS, SAVE WORK AND PARAMETER REGISTERS D1 BP SI,DATA SS, SI S ``` SECTION 5 ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEOI --- 03/24/86 VIDEO DISPLAY BIOS 1-3 04-21-86 0048 75 03 004A BF B000 004D 004D 8E C7 004F 8A C4 0051 98 0052 D1 E0 0054 96 ; SKIP IF NOT MONOCHROME CARD ; ELSE GET SEGMENT FOR MONOCHROME CARD M2 DI,0B000H 233232324444466716901234667690012346677690123466769002346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234667690123466769012346676901234 ; SET UP TO POINT AT VIDEO MEMORY AREAS ; PLACE COMMAND IN LOW BYTE OF (AX) ; AND FORM BYTE OFFSET WITH COMMAND ; TIMES 2 FOR WORD TABLE LOOKUP ; MOVE OFFSET INTO LOOK UP REGISTER (SI) ; AND RESTORE COMMAND/DATA INTO (A) ; MOVE CURRENT MODE INTO (AH) REGISTER MOV MOV CBW SAL XCHG AX,1 SI,AX 0055 8A 26 0049 R MOV AH, GCRT_MODE WORD PTR CS:[SI+OFFSET MI] ; GO TO SELECTED FUNCTION COMMAND NOT VALID DO NOTHING IF NOT IN VALID RANGE M4 : M4: IRET VIDEO_IO_! ENDP SET_MODE THIS ROUTINE INITIALIZES THE ATTACHMENT TO THE SELECTED MODE. THE SCREEN IS BLANKED. eEQUIP_FLAG BITS 6-4 = MODE/WIDTH | II = MONOCHROME (FORCES MODE 7) | 01 = COLOR ADAPTER 40x25 (MODE 0 DEFAULT) | 10 = COLOR ADAPTER 80x25 (MODE 2 DEFAULT) | (AL) = COLOR MODE REQUESTED (RANGE 0 - 6) | (AL) | COL 005F 8A 03D4 0062 8B 3E 0010 R 0066 81 ET 0030 006A 83 FF 30 006A 83 FF 30 006F 80 07 0071 82 B4 0071 82 B7 83 B7 0071 83 B7 0071 83 B7 0071 83 B7 0071 83 B7 0071 85 C2 C4 0071 85 C2 C4 : ADDRESS OF COLOR CARD ; GET EQUIPMENT FLAGS SETTING ; ISOLATE CAT SWITCHES ; IS 8W CARD INSTALLED AS PRIMARY ; SKIP AND CHECK IF COLOR ; ELSE INDICATE INTERNAL 8W CARD MODE ; SET ADDRESS OF 8W (MONOCHORME) CARD ; CONTINUE WITH FORCED MODE 7 AL,7 MB AL,0 DI,10H MB AL,2 I ELSE FORCE MODE 2 I SAVE MODE IN GLOBAL VARIABLE I SAVE ADDRESS OF BASE I INITIAL IZE DEFAULT ROW COUNT OF 25 I SAVE POINTER TO DATA SEGMENT I SAVE MODE NUMBER ALL. I SAVE MODE NUMBER ALL. I SAVE MODE SET VALUE FROM TABLE I SET TABLE POINTER, INDEXED BY MODE I GET THE MODE SET VALUE FROM TABLE I SAVE THE MODE SET VALUE FROM TABLE I VIDEO OFF, SAVE HIGH RESOLUTION BIT I SAVE OFF, SAVE HIGH RESOLUTION BIT I SAVE OUTPUT PORT VALUE I POINT TO CONTROL REGISTER I RESET VIDEO TO OFF TO SUPPRESS ROLLING I BACK TO BASE REGISTER SI, AX SI, AX SI, AX AL, CSS[SI + OFFSET MT] eCRT MODE_SET, AL AL, 037H DX, 4 DX, 4A DX, 4A DX, 4B DX, 4BSO BX, BX DX, 9PARM_PTR DS: COOE AX CX, 16 AA, 2 BX, CX AL, 4 M9 BX, CX AL, 1 M9 BX, CX NTS TO CORRECT ROW OF IN ; SET UP FOR ABSO SEGMENT ; ESTABLISH VECTOR TABLE ADDRESSING ; GET POINTER TO VIDEO PARMS 00A3 28 D8 00A5 8E D8 00A7 C5 IE 0074 R 00AF 25 (2 00 00AC 89 0010 00AF 3C 02 00B1 72 0E 00B3 03 D9 00B5 3C 04 00B7 12 08 00B9 03 D9 00B8 3C 07 00BD 72 02 00BF 03 D9 ; RECOVER MODE NUMBER IN (AL) ; LENGTH OF EACH ROW OF TABLE ; DETERMINE WHICH ONE TO USE ; MODE IS 0 OR 1 ; NEXT ROW OF INITIALIZATION TABLE 1 MODE IS 2 OR 3 1 MOVE TO GRAPHICS ROW OF INIT TABLE # MODE IS 4,5, OR 6 # MOVE TO BW CARD ROW OF INIT_TABLE 1---- BX POINTS TO CORRECT ROW OF INITIALIZATION TABLE PUSH AX MOY AX, [BX+10] XCHG AH, AL PUSH DS ASSUME DS IDATA OS ASSUME DS ICODE POP DS XOR AH, AH ; OUT INIT ; SAVE MODE IN (AL) ; GET THE CURSOR MODE FROM THE TABLE ; PUT CURSOR MODE IN CORRECT POSITION ; SAVE TABLE SEGMENT POINTER M9 t 00C8 E8 0000 E 00CB A3 0060 R RESTORE THE TABLE SEGMENT POINTER AH IS REGISTER NUMBER DURING LOOP 00CE 1F 00CF 32 E4 J---- LOOP THROUGH TABLE, OUTPUTTING REGISTER ADDRESS, THEN VALUE FROM TABLE 00D1 00D1 8A C4 00D3 EE 00D4 42 00D5 FE C4 00D7 8A 07 00D9 EE 00DA 43 00DB 4A 00DC E2 F3 00DE 58 00DF 1F MOY AL, AH OUT DX, AL INC DX MOY A, [BX] OVER DX A, [BX] OVER DX DEC DX LOOP MIO POP AX POP DS ASSUME DS:DATA M10: ; INITIALIZATION LOOP ; GET 6845 REGISTER NUMBER POINT TO DATA PORT NEXT REGISTER VALUE GET TABLE VALUE OUT TO CHIP NEXT IN TABLE BACK TO POINTER REGISTER GET MODE BACK INTO (ALI REGOVER SEGMENT VALUE DI,DI OCRT_START,DI OACTIVE_PAGE,0 CX,8192 AL,4 : SET UP POINTER FOR REGEN ; START ADDRESS SAVED IN GLOBAL ; SET PAGE VALUE ; NUMBER OF WORDS IN COLOR CARD ; TEST FOR GRAPHICS 00E0 33 FF 00E2 89 3E 004E R 00E6 C6 06 0062 R 00 00EB B9 2000 00EE 3C 04 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEOI --- 03/24/86 VIDEO DISPLAY BIOS 00F0 72 0A 00F2 3C 07 00F4 74 04 00F6 33 C0 00F8 B0 05 00FA 00FA B6 08 00FC 00FC B6 0720 00FF 73/ AB I NO GRAPHICS INIT I TEST FOR 89 CARD 1 89 CARD INIT I FILL FOR GRAPHICS MODE I CLEAR SUFFER 1 89 CARD INIT I NO GRAPHICS IS OF CARD I NO GRAPHIC FOR ALPHA + ATTRIBUTE I FLEAR SUFFER SUFFER SUFFER SUFFER SUFFER SUFFER S M12 AL,T M11 AX,AX SHORT M13 344 00F2 3C 0A 346 00F2 3C 0A 347 00F6 3B 05 348 00F6 3B 05 348 00F6 3B 05 348 00F6 3B 05 348 00F6 3B 05 350 00FF B 0 07 351 00FF B 0 07 352 00FF F3/A 353 00FF F3/A 353 00FF B 07 354 010B 8A 00 361 MOY CH,08H MOV AX.1 1+7*H M13: REP STOSW DX, 0ADDR_6845 DX,4 AL, 0CRT_MODE_SET DX, AL ; PREPARE TO OUTPUT TO VIDEO ENABLE PORT ; POINT TO THE MODE CONTROL REGISTER ; GET THE MODE SET VALUE ; SET VIDEO ENABLE PORT 0101 8B 16 0063 R 0105 83 CZ 04 0108 A0 0065 R 010B EE ;---- DETERMINE NUMBER OF COLUMNS, BOTH FOR ENTIRE DISPLAY AND THE NUMBER TO BE USED FOR TTY INTERFACE AL,CS:[SI + OFFSET M6] ; GET NUMBER OF COLUMNS ON THIS SCREEN ; CLEAR HIGH BYTE ; INITIALIZE NUMBER OF COLUMNS COUNT MOV CBW MOV :---- SET CURSOR POSITIONS 0115 81 E6 000E 0119 2E: 88 84 0000 E 011E A3 004C R 0121 89 0008 0124 8F 0050 R 0127 1E 0128 07 0129 33 C0 0128 F3/ AB SI,000EH AX,CSI[SI + OFFSET MS] AX,CSI[SI + OFFSET MS] CKT_LEN,AX CX.6 DI,0FFSET OCURSOR_POSN DS CS AX,AX STOSW ST AND MOV MOV MOV PUSH POP XOR REP SET UP OVERSCAN REGISTER INC MOV CMP JNZ MOV 012D 42 012E 80 30 0130 80 3E 0049 R 06 0135 75 02 0137 80 3F 0139 01 0139 EE 013A AZ 0066 R DX AL,30H CRT_MODE,6 M14 AL,3FH ; SET OYERSCAN PORT TO A DEFAULT ; 30H YALUE FOR ALL MODES EXCEPT 640X200 ; SEE IF THE MODE IS 640X200 BW ; IF NOT 640X200, THEN GO TO REGULAR ; IF IT IT 36 640X200, THEN DUT IN 3FH OUT ; OUTPUT THE CORRECT VALUE TO 3D9 PORT ; SAVE THE VALUE FOR FUTURE USE DX,AL OCRT_PALETTE,AL NORMAL RETURN FROM ALL VIDEO RETURNS VIDEO_RETURN: POP POP POP POP BP D! S! BX | VIDEO_RETURN_C I NPUT OUTPUT OUTPUT SET_CITYPE MOY AH, 10 MOY CALL MIS JMP VIDEO_RETURN I CX) HAS GURSOR VALUE CH-START LINE, CL-STOP LINE CX ALL MOY CX ALL MIS CALL C ; 6845 REGISTER FOR CURSOR SET ; SAVE IN DATA AREA ; OUTPUT CX REGISTER ;---- THIS ROUTINE OUTPUTS THE CX REGISTER TO THE 6845 REGISTERS NAMED IN (AH) M16: MOV OUT INC JMP MOV OUT DEC MOV INC OUT INC JMP HOY OUT SET_CTYPE DX, $ADDR_6845 AL, AH DX, AL DX $+2 CH DX, AL, CH DX, AL DX, AL DX, AL DX, AL DX, AL DX, AL ; POINT TO OTHER DATA REGISTER ; SET FOR SECOND REGISTER SECTION 5 SET_CPOS THIS ROUTINE SETS THE CURRENT CURSOR POSITION TO THE NEW X-Y VALUES PASSED I INPUT NEW AT VALUES PASSES I NPUT NEW AT VALUES PASSES DV - ROW, COLUND OF NEW CURSOR OUTPUT CURSOR IS SET AT 6845 IF DISPLAY PAGE IS CURRENT DISPLAY SET_CPOS PROC NEAR MOV AL, BH CBW I CONVERT PAGE TO WORD VA SAL AX, I WORD OFFSET XCHG AX, SI I USE INDEX REGISTER I MOVE PAGE NUMBER TO WORK REGISTER I CONVERT PAGE TO WORD VALUE I WORD OFFSET I USE INDEX REGISTER ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDE01 --- 03/24/86 VIDEO DISPLAY BIOS 0171 89 94 0050 R 0175 38 3E 0062 R 0179 75 05 017B 8B C2 017D E5 0182 R 0180 CB B6 ; SAVE THE POINTER M17: SET_CPOS VIDEO_RETURN ;---- SET CURSOR POSITION, AX HAS ROW/COLUMN FOR CURSOR 1 READ_CURSOR I READ 0182 E5 0204 R 0185 8B C8 0187 03 0E 004E R 018B D1 F9 018D 84 0E 018F E8 0181 R 0192 C3 ; DETERMINE LOCATION IN REGEN BUFFER ; ADD IN THE START ADDRESS FOR THIS PAGE ; DIVIDE BY 2 FOR CHAR ONLY COUNT ; REGISTER NUMBER FOR CURSOR ; OUTPUT THE VALUE TO THE 6845 INPUT BH - PAGE OF CURSOR OUTPUT DX - ROW, COLUMN OF THE CURRENT CURSOR POSITION CX - CURRENT CURSOR MODE READ_CURSOR PROC NEAR WORK BL, BH SAL, BX, CX - CURRENT CURSOR MODE READ_CURSOR PROC NEAR MOV BL, BH SAL BX, 1 MOY DX, [BX+0FFSET & CURSOR_POSN] DX, [BX+0FFSET & CURSOR_POSN] POP BY POP BY POP SI POP BX POP AX I DISCARD SAVED CX AND DX POP BX 0193 8A DF 0193 8A DF 0195 32 FF 0197 DI E3 0199 8B 9T 0050 R 0190 8B 0E 0060 R 0140 5B 0144 5B 0144 5B 0145 55 0146 58 0147 1F 0148 0T 0148 0T 0148 OF THIS ROUTINE SETS THE ACTIVE DISPLAY PAGE, ALLOWING THE FULL USE OF THE MEMORY SET AS IDE FOR THE VIDEO ATTACHMENT INPUT AL HAS THE NEW ACTIVE DISPLAY PAGE OUTPUT THE 6845 IS RESET TO DISPLAY THAT PAGE ACT_DISP_PAGE PROC. VALUE CONVERT (AL) TO WORD CONVERT (AL) TO WORD I CONVERT (AL) TO WORD I CONVERT (AL) TO WORD I CONVERT (AL) TO WORD CALL MICH PAGE VALUE I CONVERT (AL) TO WORD CX_AX IS AVE START ADDRESS FOR LATER MOV CX_AX ISTART ADDRESS TO CX AND CX_AX ISTART ADDRESS TO CX ACT_DISP_PAGE PAGE VALUE I CALL MICH PAGE PAGE VALUE I CALL MICH PAGE PAGE VALUE I CALL MICH PAGE PAGE VALUE I SET_COVER PAGE VALUE I SET_COLOR THIS ROUTINE WILL ESTABLISH THE BACKGROUND COLOR, THE OVERSOAN COLOR, INPUT INPUT IF BH-I THE PAGE TO BELT OF BLIO OF GREEN, RED, YELLOW FOR COLORS 1,2,3 I = BLUE, CYAN, MAGENTA FOR COLORS 1,2,3 OUTPUT THE COLOR SELECTION IS UPDATED OUTPUT THE COLOR SELECTION IS UPDATED 01AA A2 0062 R 01AD 98 01AE 50 004C R 01AE 57 26 004C R 01AE 57 26 004C R 01B6 80 F 01B6 80 F 01B6 80 F 01B6 80 F 01B6 80 F 01B6 B0 01 OUTPUT THE COLOR SELECTION IS UPDATED SET_COLOR PROC NEAR MOV DX, $ADDR 6845 ; 1/0 PC ADD DX,5 ; 0VERSC MOV AL, $CRT PALETE ; GET TH OR BH, BH ; IS THI ON M2 M20 ; 0UTPUT 01CC 01CC 8B 16 0063 R 01D0 83 C2 05 01D3 A0 0066 R 01D6 0A FF 01D8 75 0E : I/O PORT FOR PALETTE ; OVERSCAN PORT ; GET THE CURRENT PALETTE VALUE ; IS THIS COLOR 0? ; OUTPUT COLOR 0 ;---- HANDLE COLOR 0 BY SETTING THE BACKGROUND COLOR AL,0E0H BL,01FH AL,BL DX,AL OCAT PALETTE,AL VIDEO_RETURN 01DA 24 E0 01DC 80 E3 IF 01DF 0A C3 01E1 01E1 EE 01E2 A2 0066 R 01E5 E9 013D R ; TURN OFF LOW 5 BITS OF CURRENT 1 TURN OFF HIGH 3 BITS OF INPUT VALUE 2 PUT VALUE INTO REGISTER 2 OUTPUT THE PALETTE 3 OUTPUT COLOR SELECTION TO 3D9 PORT 3 SAYE THE COLOR VALUE AND AND OR 01E8 01E8 24 DF 01EA DO EB 01EC 73 F3 01EC 0C 20 01F0 EB EF 01F2 AL,ODFH BL,1 M19 AL,20H M19 ENDP : TURN OFF PALETTE SELECT BIT : TEST THE LOW ORDER BIT OF BL : ALREADY DONE : TURN ON PALETTE SELECT BIT : GO DO IT ``` ``` IBM Personal Computer MACRQ Assembler Version 2.00 VIDEOI --- 03/24/86 VIDEO DISPLAY BIOS 1-6 04-21-86 ; VIDEO STATE ; RETURNS THE CURRENT VIDEO STATE IN AX ; AH = NUMBER OF COLUMNS ON THE SCREEN ; AL = CURRENT VIDEO MODE ; BH = CURRENT VIDEO MODE ; BH = CURRENT MODE ; GET NUMBER OF COLUMNS MOV AL, SORT MODE ; GET CURRENT MODE MOV BH, SACTTYE_PAGE ; GET CURRENT MODE ; GET CURRENT MODE POP BP ; RECOVER REGISTERS POP SI S 01F2 01F2 8A 26 004A R 01F6 AO 0049 R 01F9 8A 3E 0062 R 01FD 5D 01FE 5F 0200 59 0201 E9 0141 R POSITION THIS SERVICE ROUTINE CALCULATES THE REGEN BUFFER ADDRESS OF A CHARACTER IN THE ALPHA MODE INPUT AX = ROW, COLUMN POSITION 0204 0204 53 0205 93 0205 00 004A R 0209 F6 E7 0208 32 FF 020D 03 C3 020F D1 E0 0211 58 0212 C3 0213 POSITION ENDP SCROLL UP THIS ROUTINE MOVES A BLOCK OF CHARACTERS UP ON THE SCREEN SUBSTITUTE OF THE MODE SCROLL ON THE SCREEN INPUT (AH) = CURRENT CRT MODE (AL) = NUMBER OF ROWS TO SCROLL (CX) = ROW/COLUMN OF LUPPER LEFT CORNER (DX) = ROW/COLUMN OF LUPPER RIGHT CORNER (BH) = ATTRIBUTE TO BE USED ON BLANKED LINE (DS) = DATA SEGMENT OUTPUT (ES) = REGEN BUFFER SEGMENT OUTPUT ASSUME DS:DATA_ES:DATA ASSUME DS:DATA,ES:DATA SCROLL_UP PROC NEAR 0213 88 02EE R 0219 80 FC 004 0219 80 FC 004 0219 80 FC 004 0218 70 004 0218 70 004 0218 70 004 0223 3 0224 80 C1 0223 80 C1 0224 80 C2 0225 80 C2 0226 80 C2 0227 80 C2 0228 FC C2 0238 FC CC 0230 80 C2 0213 TEST_LINE_COUNT AH,4 N1 AH,7 N1 GRAPHICS_UP CALL CMP JC CMP JE JMP ; UP CONTINUE ; SAVE FILL ATTRIBUTE IN BH ; SAVE FILL ATTRIBUTE IN BH ; UPPER LEFT POSITION ; DO SETUP FOR SCROLL ; BLANK FIELD ; FROM XDORESS ; # ROWS IN BLOCK ; # ROWS TO BE MOYED ; MOVE ONE ROW N1: BX AX,CX SCROLL_POSITION N7 SI,AX AH,DH AH,BL PUSH MOY CALL JZ ADD MOY SUB CALL ADD ADD DEC JNZ N10 S1,BP D1,BP AH N2 ; MOVE ONE ROW ; POINT TO NEXT LINE IN BLOCK ; COLNT OF LINES TO MOVE ; COLNT OF LINES TO MOVE ; COLLEAR ENTRY ; RECOVER ATTRIBUTE IN AH ; FILL WITH BLANKS ; CLEAR LOOP ; CLEAR THE ROW ; POINT TO NEXT LINE ; COUNTER OF LINES TO SCROLL ; CLEAR LOOP ; SCROLL_END N3: CALL ADD DEC JNZ NII DI,BP BL N4 CALL CMP JE MOV MDV OUT DDS #CRT_MODE,7 N6 AL,#CRT_MODE_SET DX,03DBH DX,AL ; IS THIS THE BLACK AND WHITE CARD ; IF SO, SKIP THE MODE RESET ; GET THE YALUE OF THE MODE SET ; ALWAYS SET COLOR CARD PORT ; VIDEO_RET_HERE VIDEO_RETURN JMP ; BLANK FIELD ; GET ROW COUNT ; GO CLEAR THAT AREA MOV JMP SCROLL_UP BL,DH N3 ENDP 1---- HANDLE COMMON SCROLL SET UP HERE SCROLL_POSITION PROC NAR CALL POSITION ADD AX, PORT_START MOV DI, AX SUB DX, CX INC DH INC DL XOR CH, CH MOY BP, PCRT_COLS ADD BP, PCRT_COLS ADD BP, PCRT_COLS ADD AX, AX 0260 E8 0204 R 0263 03 06 004E R 0267 88 F5 0269 88 F0 0268 28 D1 0260 FE C6 026F FE C6 0213 32 ED 004A R 0213 32 ED 004A R 0217 30 004A R 0217 30 004A R 0217 30 004A R 0217 30 004A R 0218 03 C0 0280 50 CONVERT TO REGEN POINTER OFFSET OF ACTIVE PAGE TO ADDRESS FOR SCROLL FROM ADDRESS FOR SCROLL DX = #ROWS, #COLS IN BLOCK I INCREMENT FOR O ORIGIN SET HIGH BYTE OF COUNT TO ZERO GET NUMBER OF COLUMNS IN DISPLAY TIMES 2 FOR ATTRIBUTE BYTE GET CHARACTERS PER LIME COUNT DETERMINE OFFSET TO FROM ADDRESS 2 FOR ATTRIBUTE BYTE SAVE LINE COUNT ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO: --- 03/24/86 VIDEO DISPLAY BIOS 1-7 0281 A0 00- 0284 06 0285 1F 0286 3C 02 0288 72 13 028A 3C 03 028C 77 0F AL, CRT_MODE ES DS AL, 2 N9 AL, 3 MOV PUSH POP CMP JB CMP JA GET CURRENT MODE ESTABLISH ADDRESSING TO REGEN SUFFER FOR BOTH POINTERS TEST FOR COLOR CARD SPECIAL CASES HERE HAVE TO HANDLE SOXES SEPARATELY 028E 52 028F BA 03DA 0292 EC 0293 A8 08 0295 74 FB 0297 80 25 0299 82 D8 0299 EE 0290 5A 0290 5A 0290 5A 0290 C3 0200 C3 ; 80X25 COLOR CARD SCROLL DX DX,3DAH GUARANTEED TO BE COLOR CARD HERE WAIT DISP_ENABLE GET FORT - WAIT FOR VERTICAL RETRACE WAIT_DISP_ENABLE IN TEST JZ MOV MOV OUT POP AL,DX AL,RVRT N8 AL,25H DL,0D8H DX,AL DX : ADDRESS CONTROL PORT : TURN OFF VIDEO DURING VERTICAL RETRACE RESTORE LINE COUNT 0 SCROLL MEANS BLANK FIELD RETURN WITH FLAGS SET MOVE_ROW PROC MOV PUSH PUSH REP POP POP RET ENOP N10 02A1 02A1 8A CA 02A3 56 02A4 57 02A5 F3/ A5 02A7 5F 02A8 5E 02A9 C3 02AA | GET # OF COLS TO MOVE ; SAVE START ADDRESS ; MOVE THAT LINE ON SCREEN ; RECOVER ADDRESSES NIO 02AA 8A CA 02AA 8A CA 02AC 57 02AD F3/ AB 02AF 5F 02B0 C3 02B1 NI I # GET # COLUMNS TO CLEAR : STORE THE FILL CHARACTER SCROLL DOWN SCROLL DOWN THIS ROUTINE MOVES THE CHARACTERS WITHIN A DEFINED BLOCK DOWN ON THE SCREEN, FILLING THE TOP LINES WITH A DEFINED CHARACTER INPUT (AH) a CURRENT CAT MODE (AL) NUMBER OF LINES TO SCROLL (CX) = UPPER LEFT CORNER OF REGION (DX) = LOWER RIGHT CORNER OF REGION (BH) = FILL CHARACTER (BH) = FILL CHARACTER (S) = DATA SCOMENT OUTPUT -- SCREEN IS SCROLLED OUTPUT (ES) - SCREEN IS SCROLLED CROLL_DOWN PROC NEAR 0281 FD 0282 E8 02EE R 0283 E9 0FC 04 0286 80 FC 04 0286 80 FC 07 0280 72 08 0280 80 FC 07 0280 74 03 0280 80 C2 0280 80 C2 0262 80 0260 R 0262 88 0260 R 0262 88 0260 R 0262 88 0260 R 0262 88 0260 R 0262 88 F0 0262 88 F0 0262 88 F0 0262 88 F0 0262 88 F0 0260 89 02A1 R 0260 89 02A1 R 0260 89 02A1 R 0260 80 TEST_LINE_COUNT AH, 4 N12 AH, 7 N12 GRAPHICS_DOWN DIRECTION FOR SCROLL DOWN TEST FOR GRAPHICS ; TEST FOR BW CARD ; CONTINUE DOWN ; SAVE ATTRIBUTE IN BH ; LOWER RIGHT CORNER ; GET REGEN LOCATION PUSH MOY CALL JZ SUB MOY SUB BX AX,DX SCROLL N16 SI,AX AH,DH AH,BL ; SI IS FROM ADDRESS ; GET TOTAL # ROWS ; COUNT TO MOVE IN SCROLL N13: N10 SI,BP DI,BP AH N13 AX AL, . . : RECOVER ATTRIBUTE IN AH N15: NII DI,BP BL NIS NS CLEAR ONE ROW ; SCROLL_END MOV JMP _DOWN ;---- IF AMOUNT OF LINES TO BE SCROLLED = AMOUNT OF LINES IN WINDOW ;---- THEN ADJUST AL; ELSE RETURN; 02EE TEST_LINE_COUNT PROC NEAR 02EE 8A D8 02F0 0A C0 02F0 74 0E 02F4 50 02F5 8A C6 02F9 FE C0 02FB 3A C3 02FB 3A C3 02FB 58 02FE 75 02 03FB 75 02 0300 2A D8 0302 0303 C3 BL, AL AL, AL BL_SET AX, DH AL, CH AL, BL AX BL_SET BL, BL ; SAYE LINE COUNT IN BL ; TEST IF AL IS ALREADY ZERO ; IF IT IS THEN RETURN... ; SAYE AX ; SUBTRACT LOWER ROW FROM UPPER ROW MOV OR JZ PUSH MOV SUB INC CMP POP JNE SUB ADJUST DIFFERENCE BY I LINE COUNT = AMOUNT OF ROWS IN WINDOW? RESTORE AX IF NOT THEN WE'RE ALL SET OTHERWISE SET BL TO ZERO RET TEST_LINE_COUNT ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO! --- 03/24/86 VIDEO DISPLAY BIOS AGE READ AC CURRENT THIS ROUTINE READS THE ATTRIBUTE AND CHARACTER AT THE CURRENT CURSOR POSITION AND RETURNS THEM TO THE CALLER (AH) = CURRENT CRT MODE (BH) = DISPLAY PAGE ( ALPHA MODES ONLY ) (DS) = DATA SEGMENT (ES) = REGEN SEGMENT (AL) = CHARACTER READ (AH) = ATTRIBUTE READ ASSUME DS:DATA,ES:DATA READ_AC_CURRENT PROC NEAR CMP AH,4 JC P10 CMP JE AH,7 P10 ; IS THIS BW CARD 030D E9 0642 R 0310 0310 E8 032C R 0313 8B F7 0315 06 0316 1F JMP GRAPHICS_READ ; READ AC CONTINUE ; GET REGEN LOCATION AND PORT ADDRESS E ESTABLISH ADDRESSING IN SI ; GET REGEN SEGMENT FOR QUICK ACCESS CALL MOV PUSH POP ;---- WAIT FOR HORIZONTAL RETRACE OR VERTICAL RETRACE IF COLOR 80 0317 0A DB 0319 75 0D 0318 FB 031C 90 031C 90 031C 90 031F AS 01 0321 75 FB 0323 EC 0324 AS 09 0326 T4 FB 0328 AD 0329 ED 013D R CHCHOAL NETRACE IF COLOR CARD IN 80 ELSE SKIP RETRACE WAIT - DO FAST READ WAIT FOR HORZ RETRACE LOW OF VERTICAL ENABLE INTERRUPTS FIRST ALLOW FOR SMALL INTERRUPT WINDOW BLOCK INTERRUPTS FOR SINGLE LOOP GET STATUS FROM THE ADAPTER IS HORIZONTAL RETRACE LOW NOW WAIT FOR EITHER RETRACE HIGH GET STATUS IS HORIZONTAL OR VERTICAL RETRACE HIGH IS TOWN THE STATUS IS HORIZONTAL OR VERTICAL RETRACE HIGH IS HORIZONTAL OR VERTICAL RETRACE HIGH IN THE STATUS IS HORIZONTAL OR VERTICAL RETRACE HIGH WAIT UNTIL EITHER IS ACTIVE OR JNZ P11: STI NOP CLI IN TEST JNZ P12: IN TEST JZ GET THE CHARACTER AND ATTRIBUTE EXIT WITH (AX) LODSW JMP READ_AC_CURRENT FIND_POSITION XCHG MOV SUB SHR MOV CBW MOV SAL MOV JZ SETUP FOR BUFFER READ OR WRITE SWAP MODE TYPE WITH ATTRIBUTE SAVE CHARACTER/ATTR IN (BP) REGISTER CONVERT DISPLAY MODE TYPE TO A ZERO VALUE FOR COLOR IN 80 COLUMN MOVE DISPLAY FAGE TO LOW BYTE CLEAR HIGH BYTE FOR BYTE OF STREAM TO BYTE OF STREAM OF THE S PROC AH,BL BP,AX BL,2 BL,1 AL,BH 0342 33 FF 0344 0344 03 3E 004C R 0348 48 0349 75 F9 P20: ADD LENGTH OF BUFFER FOR ONE PAGE DECREMENT PAGE COUNT LOOP TILL PAGE COUNT EXHAUSTED DI, OCRT_LEN AX P20 0349 75 F9 0348 A0 004A R 034E F6 E6 0350 32 F6 0352 32 F6 0354 D1 E0 0355 03 F5 0356 03 F5 0356 88 15 0063 R 0357 C3 DETERMINE LOCATION IN REGEN IN PAGE GET COLUMNS PER ROW COUNT DETERMINE BYTES TO ROW P21: AL,BYTE PTR #CRT_COLS DH DH,DH,OH AX,DX AX,I DX,#ADDR_6845 DX,6 MOV MUL XOR ADD SAL ADD MOV ADD RET ADD IN COLUMN VALUE *2 FOR ATTRIBUTE BYTES ADD LOCATION TO START OF REGEN PAGE GET BASE ADDRESS OF ACTIVE DISPLAY D/S STATUS PORT ADDRESS OF ADPTER BP= ATTRIBUTE/CHARACTER (FROM BL/AL) DI= POSITION (OFFSET IN REGEN BUFFER) BL= MODE FLAG (ZERO FOR 80X25 COLOR) 0360 FIND_POSITION ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEOI --- 03/24/86 VIDEO DISPLAY BIOS WRITE AC CURRENT THIS ROUTINE WRITES THE ATTRIBUTE AND CHARACTER AT THE CURRENT CURSOR POSITION (AH) = CURRENT CRT MODE (BH) = DISPLAY PAGE (CX) = COUNT OF CHARACTERS TO WRITE (AL) = CHAR TO WRITE (BL) = ATTRIBUTE OF CHAR TO WRITE (DS) = DATA SEGMENT (ES) = REGEN SEGMENT (ES) = REGEN SEGMENT OUTPUT DISPLAY REGEN BUFFER UPDATED FE_AC_CURRENT CMP JC CMP JE JE JMP 0360 0360 80 FC 04 0363 72 08 0365 80 FC 07 0368 74 03 036A E9 058E R 036D E8 032C R AH,4 P30 AH,7 P30 GRAPHICS_WRITE 1 IS THIS GRAPHICS : IS THIS BW CARD WRITE AC CONTINUE GET REGEN-LOCATION AND PORT ADDRESS ADDRESS IN (DI) REGISTER CHECK MODE FLAG FOR COLOR CARD AT 80 SKIP TO RETRACE WAIT IF COLOR AT 80 P30: CALL FIND_POSITION 0370 0A DB 0372 74 06 OR JZ BL,BL P32 AX,BP STOSW SHORT P35 GET THE ATTR/CHAR SAVED FOR FAST WRITE STRING WRITE THE ATTRIBUTE & CHARACTER EXIT FAST WRITE ROUTINE 0374 95 0375 F3/ AB 0377 EB 16 03179 95 03174 FB 03174 FB 03174 FB 03174 FB 03175 FC 031 RTICAL RETRACE IF COLOR 80 LOOP FOR EACH ATTRICHAE WRITE PLACE ATTRICHAE WRITE PLACE ATTRICHAE WRITE PLACE ATTRICHAE SAVE REGISTER WAIT FOR HORZ RERACK SAVE REGISTER ENABLE INTERRUPTS FIRST ALLOW FOR INTERRUPT WINDOW BLOCK INTERRUPTS FOR SINGLE LOOP GET STATUS FORM THE ADAPTER CHECK FOR VERTICAL RETRACE FIRST OF FAST WITTE NOW IF VERTICAL RETRACE IN HORIZONTAL RETRACE LOW THEN WAIT FOR EITHER RETRACE HIGH GET STATUS AGAIN SHORIZONTAL OR VERTICAL RETRACE HIGH WAIT UNTIL EITHER IS ACTIVE CET THE ATTRICHAE ANDEL IN [DR] P31: XCHG P32; STI NOP CLI IN TEST JNZ TEST JNZ P33: P34: # GET THE ATTR/CHAR SAVED IN (BP) #WRITE THE ATTRIBUTE AND CHARACTER AS MANY TIMES AS REQUESTED - TILL CX=0 AX,BP P31 VIDEO_RETURN 0392 WRITE C CURRENT THE SOUTHER WRITES THE CHARACTER AT THE CURRENT CURSOR POSITION, ATTRIBUTE UNCHANGED INE CURRENT CRT MODE (BH) = DISPLAY PAGE (BK) = DISPLAY PAGE (BK) = DISPLAY PAGE (AL) = CHAR TO WRITE (BS) = DATA SEGMENT (ES) = REGEN SEGMENT 0392 0392 80 FC 04 0395 72 08 0397 80 FC 07 039A 74 03 039C E9 058E R 039F E8 032C R WRITE_C_CURRENT PROC NEAR CMP AH,4 CC P40 CMP AH,7 JE P40 GRAPHICS_WRITE CALL FIND_POSITION WAIT FOR HORIZONTAL RETRACE OR JERTICAL RETRACE IF COLOR 80 J WAIT FOR HORZ RETRACE LOW OR VERTICAL ENABLE INTERRUPTS FIRST CARD. IN 80 IN 10 P41: AL,DX AL,RVRT P43 AL,RHRZ P41 GET THE CHARACTER SAVE IN (BP) PUT THE CHARACTER INTO REGEN BUFFER BUMP POINTER PAST ATTRIBUTE AS MANY TIMES AS REQUESTED AX,BP ``` 03BC E9 013D R 039F JMP WRITE C CURRENT ENDP VIDEO RETURN ``` 991 992 993 994 995 996 996 997 997 998 998 999 1000 1001 1002 1006 0367 1007 0367 55 1008 03C0 88 EC 1009 03C2 03C WRITE_STRING THIS ROUTINE WRITES A STRING OF CHARACTERS TO THE CRT. THIS ROUTINE WRITES A STRING OF CHARACTERS TO THE CRT. | (AL) = WRITE STRING COMMAND 0 - 3 | (BH) = DISFALY PAGE (ACTIVE PAGE) | (CX) = COUNT OF CHARACTERS TO WRITE, IF (CX) = 0 THEN RETURN | (CX) = COUNT OF CHARACTERS TO WRITE IF (AL) = 0 OR (AL) = 1 | (BL) = ATTRIBUTE OF CHARACTER TO WRITE IF (AL) = 0 OR (AL) = 1 | (BP) = SOURCE STRING OFFSET | (BP) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (DUTPUT | (DOT) | (FOR USE IN (ES) IN STACK +14) | (DUTPUT | (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STACK +14) | (BC) = SOURCE STRING SEGMENT (FOR USE IN (ES) IN STA ; SAVE BUFFER OFFSET (BP) IN STACK ; GET POINTER TO STACKED REGISTERS ; RECOVER ENTRY (ES) SEGMENT REGISTER ; RESTORE BUFFER OFFSET ; CLEAR (AH) REGISTER ; SAVE (AL) COMMAND IN (DI) REGISTER ; TEST FOR INVALID WHITE STRING OPTION ; IF OPTION INVALID THEN RETURN SI,BX P59 P50: AL,ES:[BP] BP TEST FOR SPECIAL CHARACTER'S AL,08H P51 AL,CR P51 AL,LF P51 AL,07H P52 ; IS IT A BACKSPACE ! BACK SPACE ! IS IT CARRIAGE RETURN ! CAR RET ! IS TT A LINE FEED ! LINE FEED ! IS IT A BELL ! IS IT A BELL ! IF NOT THEN DO WRITE CHARACTER P51: AH.0EH ; TTY CHARACTER WRITE 10H ; WRITE TTY CHARACTER TO THE CRT DX,[SI+0FFSET **OURSOR_POSH]; GET CURRENT CURSOR POSITION AND CONTINUE SET CURSOR POSITION AND CONTINUE P52: CX 8X CX, I DI, 2 P53 BL, ES: [BP] BP PUSOYP YOU STORE CHEST OF ; SET CHARACTER WRITE AMOUNT TO ONE ; IS THE ATTRIBUTE IN THE STRING ; IF NOT THEN SKIP ; ELSE GET NEW ATTRIBUTE ; BUMP STRING POINTER AH,09H 10H 8X CX DL DL:BYTE PTR @CRT_COLS DH:DL DH:25 DH:25 : GOT CHARACTER : WRITE CHARACTER TO THE CRT : RESTORE REGISTERS INCREMENT COLUMN COUNTER IF COLS ARE WITHIN RANGE FOR THIS MODE THEN GO TO COLUMNS SET BUMP ROW COUNTER BY ONE SET COLUMN COUNTER TO ZERO IF ROWS ARE LESS THAN 25 THEN GO TO ROWS_COLUMNS_SET AX,0E0AH 10H DH ; ELSE SCROLL SCREEN ONE LINE ; RESET ROW COUNTER TO 24 : ROW COLUMNS SET ; SET NEW CURSOR POSITION COMMAND ; ESTABLISH NEW CURSOR POSITION ; DO IT ONCE MORE UNTIL (CX) = ZERO MOV INT LOOP AX,0200H 10H P50 POP XCHG TEST JNZ MOV INT ; RESTORE OLD CURSOR COORDINATES ; RECOVER WRITE STRING COMMAND ; IF CURSOR WAS NOT TO BE MOVED THEN ; THEN EXIT WITHOUT RESETTING OLD VALUE ; ELSE RESTORE OLD CURSOR POSITION DX AX,DI AL,01H P59 AX,0200H 10H : DONE - EXIT WRITE STRING : RETURN TO CALLER JMP VIDEO_RETURN ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS 1085 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 1086 | 10 PAGE READ DOT -- WRITE DOT THESE ROUTINES WILL WRITE A DOT, OR READ THE THESE ROUTINES WILL WRITE A DOT, OR READ THE ENTRY ENTRY CX = ROULINH (0-59) (THE ACTUAL VALUE DEPENDS ON THE MODE) AL = DOT VALUE TO WRITE (1,2 OR 4 BITS DEPENDING ON MODE, REQUIRED FOR WRITE DOT ONLY, RIGHT JUSTIFIED) BIT 7 OF AL = I INDICATES XOR THE VALUE INTO THE LOCATION DS = DATA SEGMENT EXIT AL = DOT VALUE READ, RIGHT JUSTIFIED, READ ONLY READ_OOT SCHOOL SCHOOL READ, RIGHT READ_OOT SCHOOL READ, RIGHT READ_OOT SCHOOL READ RIGHT READ_OOT SCHOOL READ_RIGHT READ_RIGHT READ_OOT SCHOOL READ_RIGHT READ_OOT SCHOOL READ_RIGHT READ_R : DETERMINE BYTE POSITION OF DOT I GET THE BYTE I MASK OFF THE OTHER BITS IN THE BYTE ! LEFT JUSTIFY THE VALUE I GET NUMBER OF BITS IN RESULT ! RIGHT JUSTIFY THE RESULT ! RETURN FROM VIDEO 1/0 PROC NEAR AX AX AX AX AX AL, CL AL, AH CL, ES; [SI] BX, BOH R2 AH AL, CL AH AL, CL READ_DOT WRITE_DOT PUSH PUSH CALL SHR AND MOV POP TEST JNZ NOT AND OR RII ! SAVE DOT VALUE ! TWICE ! TWICE ! DETERMINE BYTE POSITION OF THE DOT ! SHIFT TO SET UP THE BITS FOR OUTPUT ! SHIFT TO SET UP THE BITS ! GET THE CURRENT BYTE ! RECOVER YOR FLAG ! IS IT ON ! YES, XOR THE DOT ! SET MASK TO REMOVE THE INDICATED BITS OR IN THE NEW VALUE OF THOSE BITS FINISH DOT RESTORE THE BYTE IN MEMORY MOV POP JMP ES:[SI],AL AX VIDEO_RETURN RETURN FROM VIDEO 1/0 XOR_DOT EXCLUSIVE OR THE DOTS FINISH UP THE WRITING AL,CL R1 ENDP XOR JMP XOR AL, CL | EACHS E 134 135 136 137 138 139 140 141 142 144 145 146 147 0477 148 PROC NEAR ;---- DETERMINE IST BYTE IN INDICATED ROW BY MULTIPLYING ROW VALUE BY 40 ( LOW BIT OF ROW DETERMINES EVEN/ODD, 80 BYTES/ROW ) XCHG SI.AX MOV AL.40 MAL. DL TEST AL.008H JZ R4 ADD AX.2000H-40 | 151 | 152 0477 96 | 153 0478 B0 28 | 154 0474 B0 28 | 155 047C A6 08 | 156 047C 74 03 | 157 0480 05 | FD8 | 158 0483 | 159 0483 96 | 1160 0484 8B D1 : WILL SAVE AL AND AH DURING OPERATION AX= ADDRESS OF START OF INDICATED ROW I TEST FOR EVEN/ODD ROW CALCULATED JUMP IF EVEN ROW I OFFSET TO LOCATION OF ODD ROWS ADJUST EVEN ROW I MOYE POINTER TO (SI) AND RECOVER (AX) I COLLINI VALUE TO DX XCHG MOV 162 163 164 1165 1166 1167 1167 1170 0486 88 02C0 1171 0486 88 02C0 1172 0486 89 03C2 1172 0486 80 36 0049 R 06 1174 0443 86 0180 1175 0496 89 07O3 :---- DETERMINE GRAPHICS MODE CURRENTLY IN EFFECT ; SET UP THE REGISTERS ACCORDING TO THE MODE 1 CH = MASK FOR LOW OF COLUMN ADDRESS (7/3 FOR HIGH/MED RES ) 1 CL = 0 OF ADDRESS BITS IN COLUMN VALUE (9/2 FOR H/M) 1 BL = MASK TO SELECT BITS FROM POINTED BYTE (80H/COH FOR H/M) 1 BH = NAMBER OF VALID BITS IN POINTED BYTE (1/2 FOR H/M) BX,2COH CX,302H PCRT_MODE,6 R6 BX,180H CX,703H MOV MOV CMP JC MOV MOV $ SET PARMS FOR HIGH RES DETERMINE BIT OFFSET IN BYTE FROM COLUMN MASK AND CH.DL : ADDRESS OF PEL WITHIN BYTE TO CH DETERMINE BYTE OFFSET FOR THIS LOCATION IN COLUMN : SHIFT BY CORRECT AMOUNT : INCREMENT THE POINTER ; GET THE # OF BITS IN RESULT TO DH SHR ADD MOY MULTIPLY BH (VALID BITS IN BYTE) BY CH (BIT OFFSET) SUB CL,CL ; ZERO INTO STORAGE LOCATION LEFT JUSTIFY VALUE IN AL (FOR WRITE) ADD IN THE BIT OFFSET VALUE LOOP CONTROL ON EXIT, CL HAS COUNT TO RESTORE BITS GET MASK TO AH MOVE THE MASK TO CORRECT LOCATION RETURN WITH EVERTTHING SET UP ROR ADD DEC JNZ MOV SHR RET ENOP AL,1 CL,CH BH R6 AH,BL AH,CL ``` ``` 1199 1200 1201 1202 1202 1203 1204 1205 1206 1206 1207 1207 1207 1208 1207 1208 1209 1210 1211 1212 1213 0480 1215 0482 88 C1 1215 0482 88 C1 SCROLL UP SCROLL UP STATE SCROLL UP STATE STATE STATE STATE SCROLL UP STATE STATE STATE SCROLL SC ; SAYE LINE COUNT IN BL ; GET UPPER LEFT POSITION INTO AX REG 1216 0482 58 C1 1216 1217 1218 1229 1220 0484 E8 04F0 R 1221 0497 58 F8 1222 0487 28 D1 1223 0468 B1 C2 0101 1226 0468 B1 C2 0101 1228 04C1 D0 E6 1228 04C2 D0 E6 1228 04C2 D0 E7 1228 04C2 D0 E7 1229 04C2 D0 E7 1231 04C2 D0 E7 1231 04C2 D0 E7 1231 04C2 D0 E7 1232 04C2 D0 E7 1233 04C3 E0 SE 1234 04C2 D0 E7 1235 04C4 D0 E7 1236 04C4 D0 E7 1237 04CC D1 E7 1238 04C6 1239 04C6 D1 E7 1240 ;---- USE CHARACTER SUBROUTINE FOR POSITIONING ADDRESS RETURNED IS MULTIPLIED BY 2 FROM CORRECT VALUE CALL GRAPH_POSN MOV DI,AX ; SAVE RESULT AS DESTINATION ADDRESS ;---- DETERMINE SIZE OF WINDOW ; ADJUST VALUES ; MULTIPLY ROWS BY 4 AT 8 VERT DOTS/CHAR ; AND EVEN/ODD ROWS :---- DETERMINE CRT MODE ●CRT_MODE,6 R7 : TEST FOR MEDIUM RES MEDIUM RES UP SAL DL,1 SAL DI,1 # COLUMNS * 2, SINCE 2 BYTES/CHAR # OFFSET *2 SINCE 2 BYTES/CHAR THE SOURCE ADDRESS IN THE BUFFER FIND SOURCE PUSH ES FROM SOURCE FOR SEGMENTS BOTH POINTING TO REGEN ES DS CH, CH BL, 1 BL, 1 AL, 80 BL SI, DI SI, AX AH, DH AH, BL PUSH POP SUB SAL JZ MOV MUL MOV ADD MOV SUB ### LOOP THROUGH, MOVING ONE ROW AT A TIME, BOTH EVEN AND ODD FIELDS ### ROW LOOP CALL RI7 | MOVE ONE ROW SUB $1,2000H-80 | MOVE TO NEXT ROW ; NUMBER OF ROWS TO MOVE ; CONTINUE TILL ALL MOVED ;---- FILL IN THE VACATED LINE(S) R10: MOV AL,BH : CLEAR ENTRY : ATTRIBUTE TO FILL WITH CALL SUB DEC JNZ JMP R18 DI,2000H-80 BL R10 VIDEO_RETURN CLEAR THAT ROW POINT TO NEXT LINE NUMBER OF LINES TO FILL CLEAR LOOP EVERYTHING DONE ; BLANK FIELD ; SET BEANK COUNT TO EYERYTHING IN FIELD ; CLEAR THE FIELD R11: GRAPHICS_DOWN PROC NEAR STD MOY BL,AL MOY AX,DX ; SET DIRECTION ; SAVE LINE COUNT IN BL ; GET LOWER RIGHT POSITION INTO AX REG ;---- USE CHARACTER SUBROUTINE FOR POSITIONING ADDRESS RETURNED IS MULTIPLIED BY 2 FROM CORRECT VALUE CALL GRAPH_POSN DI,AX ; SAVE RESULT AS DESTINATION ADDRESS :---- DETERMINE SIZE OF WINDOW SUB DX,CX ADD DX,101H SAL DH,1 SAL DH,1 ;---- DETERMINE CRT MODE 1311 0518 80 3E 0049 R 06 1312 0520 73 05 ; TEST FOR MEDIUM RES ; FIND_SOURCE_DOWN ``` SECTION 5 ``` ISM Personal Computer MACRO Assembler Version 2.00 VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS ;---- MEDIUM RES DOWN SAL DL,I SAL DI,I INC DI ; # COLUMNS * 2, SINCE 2 BYTES/CHAR ; OFFSET *2 SINCE 2 BYTES/CHAR ; POINT TO LAST BYTE 1---- DETERMINE THE SOURCE ADDRESS IN THE BUFFER R12: ; FIND_SOURCE_DOWN ; BOTH SEGMENTS TO REGEN PUSH POP SUB ADD SAL JZ MOV MUL MOV SUB MOV SUB ZERO TO HIGH OF COUNT REGISTER POINT TO LAST ROW OF PIXELS MULTIPLY NUMBER OF LINES BY 4 I IF ZERO, THEN BLANK ENTIRE FIELD 80 BYTES/ROW DETERNINE OFFSET TO SOURCE SET UP SOURCE SET UP SOURCE SUBTRACT THE OFFSET NUMBER OF ROWS IN FIELD DETERNINE NUMBER TO MOVE :---- LOOP THROUGH, MOVING ONE ROW AT A TIME, BOTH EVEN AND ODD FIELDS R13: R17 SI,2000H+80 DI,2000H+80 AH R13 CALL SUB SUB DEC JNZ : NUMBER OF ROWS TO MOVE : CONTINUE TILL ALL MOVED CLEAR ENTRY DOWN ATTRIBUTE TO FILL WITH CLEAR LOOP DOWN CLEAR A ROW POINT TO NEXT LINE NUMBER OF LINES TO FILL CLEAR_LOOP_DOWN JMP ; EVERYTHING DONE BLANK FIELD DOWN SET BLANK COUNT TO EVERYTHING IN FIELD CLEAR THE FIELD R16: MOV BL,DH JMP R14 GRAPHICS_DOWN ENDP ---- ROUTINE TO MOVE ONE ROW OF INFORMATION RIT PROCE MOY PUSH PUSH PUSH POP POP ADO ADO ADO ADO PUSH PUSH PUSH PUSH REP POP POP RIT ENDP NEAR CL,DL SI DI SI,2000H DI,2000H SI,2000H SI,2000H SI,2000H SI,2000H SI,2000H SI,2000H SI,2000H SI,2000H ; POINT TO THE ODD FIELD SAVE THE POINTERS COUNT BACK MOVE THE ODD FIELD ; POINTERS BACK : RETURN TO CALLER R17 ;---- CLEAR A SINGLE ROW NEAR CL,DL DI STOSB DI DI,2000H DI,2000H DI,2000H DI OCL,DD R18 PROC MOV PUSH REP POP ADD PUSH MOV REP POP RET ENDP ; NUMBER OF BYTES IN FIELD ; SAYE POINTER ; STORE THE NEW VALUE ; POINTER BACK ; POINT TO ODD FIELD R18 RIS EMOP GRAPHICS WRITE THIS ROUTINE WRITES THE ASCII CHARACTER TO THE CURRENT POSITION ON THE SCREEN. ENTRY AL CHARACTER TO WRITE BL COLOR ATTRIBUTE TO BE USED FOR FOREGROUND COLOR IF BIT 7 IS SET, THE CHAR IS XOR'D INTO THE REGEN BUFFER ( IS USED FOR THE BACKGOUND COLOR) CX = NUMBER OF CHARS TO WRITE DS = DATA SEGMENT EXIT --- NOTHING IS RETURNED CRAPHICS READ THIS ROUTINE READS THE ASCII CHARACTER AT THE CURRENT CURSOR POSITION ON THE SCREEN BY MATCHING THE DOTS ON THE SCREEN TO THE CHARACTER GENERATOR CODE POINTS ENTRY -- NONE (0 IS ASSUMED AS THE BACKGROUND COLOR) EXIT -- AL a CHARACTER READ AT THAT POSITION (0 RETURNED IF NONE FOUND) FOR BOTH ROUTINES, THE IMAGES USED TO FORM CHARS ARE CONTAINED IN ROM FOR THE 1ST 128 CHARS. TO ACCESS CHARS IN THE SECOND HALF, THE USER MUST INITIAL IZE THE VECTOR AT INTERRUPT IFH (LOCATION 000TCH) TO POINT TO THE USER SUPPLIED TABLE OF GRAPHIC HAGES (8X8 BOXES). FAILURE TO DO SO WILL CAUSE IN STRAME RESULTS ``` SECTION 5 ``` 1427 | 1428 | 058E | 84 | 00 | 1430 | 0590 | 50 | 1431 | 1432 | 1432 | 0591 | E8 | 06ED | R | 1436 | 0591 | E8 | 06ED | R | 1437 | 1438 | 0594 | 88 | F8 | 1439 | 0596 | 58 | 1440 | 0597 | 30 | 60 | 1441 | 0597 | 30 | 60 | 1442 | 0596 | 1441 | 0597 | 1442 | 0596 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 | 0597 | 1441 ASSUME DS:DATA,ES:DATA GRAPHICS WRITE PROC NEAR MOY AH.0 PUSH AX # ZERO TO HIGH OF CODE POINT :---- DETERMINE POSITION IN REGEN BUFFER TO PUT CODE POINTS CALL 526 MOV DI,AX ; FIND LOCATION IN REGEN BUFFER ; REGEN POINTER IN DI ;---- DETERMINE REGION TO GET CODE POINTS FROM POP AX CMP AL.80H JAE $1 RECOVER CODE POINT IS IT IN SECOND HALF YES ;---- IMAGE IS IN FIRST HALF, CONTAINED IN ROM MOV SI,OFFSET CRT_CHAR_GEN ; OFFSET OF IMAGES PUSH C5 ; SAVE SEGMENT ON STACK JMP SHORT S2 ; DETERMINE_MODE ;---- IMAGE IS IN SECOND HALF, IN USER MEMORY S1: SUB AL,80H PUSH DS.1,51 MV DS.5,15 MV DS.5,16 ASSUME DS.1,6EXT_PTR MOV DX.05 ASSUME DS.10ATA POP DS.7 PUSH DX OR DX,51 JNZ 52 ; ESTABLISH VECTOR ADDRESSING ; GET THE OFFSET OF THE TABLE ; GET THE SEGMENT OF THE TABLE ; RECOVER DATA SEGMENT ; SAVE TABLE SEGMENT ON STACK ; CHECK FOR VALID TABLE DEFINED ; CONTINUE IF DS:SI NOT 0000;0000 POP AX SI,OFFSET CRT_CHAR_GEN ; ELSE SET (AX) = 0000 FOR "NULL" ; POINT TO DEFAULT TABLE OFFSET ; IN THE CODE SEGMENT 1---- DETERMINE GRAPHICS MODE IN OPERATION AX,1 AX,1 AX,1 SI,AX PCRT_MODE,6 DS S7 52: DETERMINE MODE HULTIPLY CODE POINT VALUE BY 8 SAL SAL SAL ADD CMP POP JC ; SI HAS OFFSET OF DESIRED CODES RECOVER TABLE POINTER SEGMENT #---- HIGH RESOLUTION MODE : HIGH_CHAR ; SAVE_REGEN POINTER ; SAVE_CODE_POINTER ; NUMBER_OF_TIMES_THROUGH_LOOP 53: ; GET BYTE FROM CODE POINTS ; SHOULD WE USE THE FUNCTION ; TO PUT CHAR IN ; STORE IN REGEN BUFFER LODSB TEST JNZ STOSB LODSB 35: ES:[D1+2000H-1],AL D1,79 DH S4 S1 D1 D1 D1 S3 VIDEO_RETURN MOV ADD DEC JNZ POP INC LOOP JMP ; STORE IN SECOND HALF ; MOVE TO NEXT ROW IN REGEN ; DONE WITH LOOP RECOVER REGEN POINTER POINT TO NEXT CHAR POSITION MORE CHARS TO WRITE 561 571 MEDIUM RESOLUTION WRITE MED. RES WRITE | SAVE HIGH COLOR | SAVE HIGH COLOR | SAVE HIGH COLOR | EXPAND BL TO FULL WORD OF COLOR | EXPAND BL TO FULL WORD OF COLOR | SAVE HIGH COLOR BITS ( LOW 2 BITS ) | GET BIT CONVERSION MULTIPLIER | EXPAND 2 COLOR BITS TO 4 REPLICATIONS | PLACE BACK IN WORK REGISTER | PLACE BACK IN WORK REGISTER | FULL CATIONS OF COLOR BITS | MED. HIGH COLOR BITS | SAVE THE COOE POINTER | SAVE THE COOE POINTER | NUMBER OF LOOPS MOV SAL 58: PUSH PUSH MOV ! GET CODE POINT ! DOUBLE UP ALL THE BITS ! CONVERT TO FOREGROUND COLOR ( 0 BACK ) ! SWAP HIGH/LOW BYTES FOR WORD MOYE ! IS THIS XOR FUNCTION ! NO, STORE IT IN AS IT IS ! DO FUNCTION WITH LOW/HIGH LODSB CALL AND XCHG TEST JZ XOR $21 AX,BX AH,AL DL,80H $10 AX,ES:[DI] S10: ES:[DI],AX : STORE FIRST BYTE HIGH, SECOND LOW : GET CODE POINT S21 AX,BX AH,AL DL.80H S11 AX,ES:[DI+2000H] ! CONVERT TO COLOR ! SWAP HIGH/LOW BYTES FOR WORD MOVE ! AGAIN, IS THIS XOR FUNCTION ! NO. JUST STORE THE VALUES ! FUNCTION WITH FIRST HALF LOW ``` 1-14 IBM Personal Computer MACRO Assembler Version 2.00 VIDEOI --- 03/24/86 VIDEO DISPLAY BIOS ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS 1541 062D 264 89 85 2000 1542 062D 264 89 85 2000 1543 0632 53 C7 50 1544 0637 FE CE 1546 0637 5E 1547 0633 6F 1547 0633 6F 1547 0633 6F 1549 0632 47 1550 0632 62 1550 0632 62 1551 0642 1552 0642 1557 0642 65 0642 1557 0642 65 0645 R 1558 0646 88 FO 1559 0644 88 EC : STORE SECOND PORTION HIGH ; KEEP GOING ; RECOVER CODE POINTER ; RECOVER REGEN POINTER ; POINT TO NEXT CHAR POSITION ; MORE TO WRITE PROC $26 $1.AX $P,8 BP,SP GRAPHICS_READ CALL MOV SUB MOV ; CONVERTED TO OFFSET IN REGEN ; SAVE IN SI ; ALLOCATE SPACE FOR THE READ CODE POINT ; POINTER TO SAVE AREA 1859 0647 83 EC 08 1850 0644 88 EC 1851 0642 80 3E 0049 R 06 1854 0651 06 1854 0651 06 1854 0652 1F 1856 0652 1F 1856 0652 1F 1856 0652 1F 1856 0652 1F 1856 0652 1F 1856 0652 1F 1857 0657 8A 04 1873 0659 86 46 00 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 45 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 18 16 1874 0656 PUSH ES POP DS JC S13 # POINT TO REGEN SEGMENT |----- HIGH RESOLUTION READ | GET VALUES FROM REGEN BUFFER AND CONVERT TO CODE POINT MOV DH.4 NUMBER OF PASSES AL,[SI] [BP],AL ; GET FIRST BYTE ; SAVE IN STORAGE AREA ; NEXT LOCATION ; GET LOWER REGION BYTE ; ADJUST AND STORE BP AL, ($1+2000H) [BP], AL BP SI,80 DH ; POINTER INTO REGEN : LOOP CONTROL : DO IT SOME MORE ; GO MATCH THE SAVED CODE POINTS S12 SHORT S15 MEDIUM RESOLUTION READ SAL SI,1 MOV DH,4 313: OFFSET*2 SINCE 2 BYTES/CHAR NUMBER OF PASSES $23 $1,2000H-2 $23 $1,2000H-80+2 DH $14 ; GET BYTES FROM REGEN INTO SINGLE SAVE ; GO TO LOWER REGION ; GET THIS PAIR INTO SAVE ; ADJUST POINTER BACK INTO UPPER CALL ADD CALL SUB DEC JNZ ; KEEP GOING UNTIL ALL 8 DONE | SAVE AREA HAS CHARACTER IN IT, MATCH IT | FINO CHAR CHARACTER | CODE POINTS IN CS | ADJUST POINTER TO STAN CHARACTER | FINO C ; CODE POINTS IN CS ; ADJUST POINTER TO START OF SAVE AREA ; CURRENT CODE POINT BEING MATCHED PUSH POP MOV SS DS DX,128 S1 DI CX,4 CMPSW DI S1 S18 AL DI,8 DX : SAVE SAVE AREA POINTER : SAVE CODE POINTER : NUMBER OF WORDS TO MATCH : COMPARE THE 8 BYTES AS WORDS ; RECOVER THE POINTERS PUSH PUSH MOV REPE POP JZ INC ADO DEC JNZ : IF ZERO FLAG SET, THEN MATCH OCCURRED : NO MATCH, MOVE ON TO NEXT : NEXT CODE POINT : LOOP CONTROL : DO ALL OF THEM CHAR NOT MATCHED, MIGHT BE IN USER SUPPLIED SECOND HALF CHAR NOT MATCHED, MIGHT BE IN USER SUPPLIED SECOND HALF CHAR NOT MATCHED, MIGHT BE IN USER SUPPLIED SECOND HALF SUB AX,AX | 1 F= 0, THEN ALL MAS BEEN SCANNED SUB AX,AX | 1 F= 0, THEN ALL MAS BEEN SCANNED SUB AX,AX | 1 F= 0, THEN ALL MAS BEEN SCANNED SUB AX,AX | 1 ESTABLISH ADDRESSING TO VECTOR ASSUME DIABASET | 1 ESTABLISH ADDRESSING TO VECTOR MOV AX,ES | 1 ESTABLISH ADDRESSING TO VECTOR MOV AX,ES | 1 ESTABLISH ADDRESSING TO VECTOR MOV AL. 128 | 1 CO SECOND HALF MOV AL. 128 | 1 CO SIGIN FOR SECOND HALF SUB BIOLATA MOV AL. 128 | 1 CO SIGIN FOR SECOND HALF SUB BIOLATA MOV BIOLATE SECOND (ALL DO LE MAY FOR IT ASSUME DSIDATA 1---- CHARACTER IS FOUND ( AL=0 IF NOT FOUND ) 518: ADD SP.8 10: ADD SP.8 10: READJUST THE STACK, THROW AWAY SAVE 10: ALL DONE 06BE 83 C4 08 06C1 E9 013D R 06C4 ; SAVE REGISTER ; SHIFT COUNT REGISTER FOR ONE BYTE 522: AL, 1 BP, 1 BP, 1 S22 AX, BP SMIFT BITS, LOW BIT INTO CARRY FLAG I MOVE CARRY FLAG (LOW BIT) INTO RESULTS SIGN EXTEMD HIGH BIT (DOUBLE IT) I REPEAT FOR ALL 8 BITS MOVE RESULTS TO PARAMETER REGISTER I RECOVER REGISTER I ALL DONE ``` :---- DETERMINE VALUE TO FILL WITH DURING SCROLL # GET THE CURRENT MODE ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS 1-17 04-21-86 AX,0601H CX,CX DH,25-1 DL,BYTE PTR @CRT_COLS DL ; VIDEO-CALL-RETURN I SCROLL UP THE SCREEN TITY-RETURN I RESTORE THE ENTRY CHARACTER FROM (DI) I RETURN TO CALLER INT 1 OH AX,DI VIDEO_RETURN XCHG JMP SET-CURSOR-INC NEXT ROW SET-CURSOR U6: U7: AH,02H U4 MOV JMP ; ESTABLISH THE NEW CURSOR 1---- CHECK FOR CONTROL CHARACTERS U9 AL,LF U10 AL,07H U11 AL,08H U0 ; WAS IT A CARRIAGE RETURN ; IS IT A LINE FEED ; GO TO LINE FEED ; IS IT A BELL ; GO TO BELL ; IS IT A BACKSPACE ; IF NOT A CONTROL, DISPLAY IT JE CMP JE CMP JE CMP :---- BACK SPACE FOUND : IS IT ALREADY AT START OF LINE : SET_CURSOR : NO -- JUST MOVE IT BACK : SET_CURSOR CARRIAGE RETURN FOUND MOV DL,0 JMP U7 LINE FEED FOUND CMP DH,25-1 JNE U6 JMP U1 LIGHT PEN THIS ROUTINE TESTS THE LIGHT PEN SWITCH AND THE LIGHT PEN TRIGGER. IF BOTH ARE SET, THE LOCATION OF THE LIGHT PEN IS DETERMINED. OTHERWISE, A RETURN WITH NO INFORMATION IS MADE. PER 13 MADE. ON EXIT! (AH) = 0 IF NO LIGHT PEN INFORMATION IS AVAILABLE (BX,CX,DX ARE DESTROYED (AH) = 1 IF LIGHT PEN IS AVAILABLE (CH, DL) = ROW,COLUMN OF CURRENT LIGHT PEN POSITION (CH) = RASTER POSITION (BX) = BEST OGLESS AT PIXEL HORIZONTAL POSITION 1 OSCILLER DISCOULS AT PIXEL HORIZONTAL POSITION :---- WAIT FOR LIGHT PEN TO BE DEPRESSED PROC NEAR AH,0 DX.@ADDR_6845 DX.6 AL.DX AL.DX AL.DX AL.OX4H V6_A ; SET NO LIGHT PEN RETURN CODE ; GET BASE ADDRESS OF 6845 ; POINT TO STATUS REGISTER ; GET STATUS REGISTER ; TEST LIGHT PEN SWITCH ; GO IF YES ; NOT SET, RETURN 1---- NOW TEST FOR LIGHT PEN TRIGGER ;---- TRIGGER HAS BEEN SET, READ THE VALUE IN V7A: MOV AH,16 AND CONVERT TO ROW COLUMN IN (DX) ; POINT TO DATA REGISTER ; I/O DELAY ; GET SECOND DATA VALUE ; AX HAS INPUT VALUE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 VIDEO1 --- 03/24/86 VIDEO DISPLAY BIOS 1-18 04-21-86 | 1881 | 1882 | 1883 | 1884 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | 1895 | PAGE ----- AX HAS THE VALUE READ IN FROM THE 6845 BL, GERT_MODE BH, BH, CS; V1 [BX] AX, BX BX, GERT_START BX, 1 AX, BX V2 AX, AX MOY SUB MOY SUB MOY SHR SUB JNS SUB ; MODE VALUE TO BX ; DETERMINE AMOUNT TO SUBTRACT ; TAKE IT AWAY ;---- DETERMINE MODE OF OPERATION ; DETERMINE_MODE ; SET *8 SHTFT COUNT ; DETERMINE IF GRAPHICS OR ALPHA ; ALPHA_PEN V2: MDY CMP JB CMP JE CL,3 OCRT_MODE,4 V4 OCRT_MODE,7 V4 ; ALPHA_PEN :---- GRAPHICS MODE DIVISOR FOR GRAPHICS DETERMINE ROW(AL) AND COLUMN(AH) AL RANGE 0-99, AH RANGE 0-39 MOV DL,40 :---- DETERMINE GRAPHIC ROW POSITION CH,AL CH,CH BL,AH BH,BH GCT_MODE,6 V3T_MODE,4 CL,4 AH,1 ; SAVE ROW VALUE IN CH ; *2 FOR EVEN/ODD FIELD COLUMN VALUE TO BEX ; MULTIPLY BY 8 FOR MEDIUM RES ; DETERMINE MEDIUM OR HIGH RES ; NOT HIGH RES ; SHIFT VALUE FOR HIGH RES ; COLUMN VALUE TIMES 2 FOR HIGH RES ; MULTIPLY**16 FOR HIGH RES ; MULTIPLY**16 FOR HIGH RES MDY ADD MDY SUB CMP JNE MOY SAL SHL BX,CL :---- DETERMINE ALPHA CHAR POSITION MOY MOY SHR SHR JMP DL,AH DH,AL DH,1 DH,1 SHORT V5 ; COLUMN VALUE FOR RETURN ; ROW VALUE ; DIVIDE BY 4 ; FOR VALUE IN 0-24 RANGE ; LIGHT_PEN_RETURN_SET ; ALPHA PEN ; DETERMINE ROW, COLUMN VALUE ; ROWS TO DH ; COLS TO DL ; MULTIPLY ROWS * 8 ; GET RASTER VALUE TO RETURN REGISTER ; COLUMN VALUE ; TO BN V4: BYTE PTR *CRT_COLS DH,AL DL,AH AL,CL CH,AL BL,AH BH,BH BX,CL DIV MOV MOV SAL MOV MOV XOR SAL ; LIGHT PEN RETURN SET ; INDICATE EVERY THING SET ; LIGHT PEN RETURN ; SAVE RETURN VALUE (IN CASE) ; GET 835E ADDRESS ; POINT TO RESET PARM APPROVED TO RESET PARM ; RETURN NO FORTANT ; RETURN NO FESET V5: MOV AH,1 V6: PUSH MOY ADD OUT POP DX DX, @ADDR_6845 DX, 7 DX, AL DX V7: ; DISCARD SAVED BX,CX,DX ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS ---- 06/10/85 BIOS ROUTINES 1-1 PAGE 118,121 TITLE BIOS ---- 06/10/85 BIOS ROUTINES .286C .LIST CODE SEGMENT BYTE PUBLIC PUBLIC EQUIPMENT | PUBLIC MEMORY SIZE_DET_1 PUBLIC NMI_INT_1 NMI_INT_I C80421NEAR CMOS READ1NEAR D11NEAR D21NEAR D22NEAR D241NEAR DD51NEAR OBF 421NEAR PRT_HEX1NEAR PRT_HEX1NEAR PMTGEGINEAR PMGGINEAR POST SEND 8042 COMMAND ROUTINE READ CMOS LOCATION ROUTINE 'PARITY CHECK I' MESSAGE 'PARITY CHECK 2" MESSAGE 'PARITY CHECK 2" MESSAGE 'PARITY CHECK 2" MESSAGE 'PARITY CHECK 2" MESSAGE LOAD (DS) WITH DATA SEGMENT SELECTOR POST WAIT 8042 RESPONSE ROUTINE DISPLAY CHARACTER ROUTINE DISPLAY CHARACTER ROUTINE DISPLAY MESSAGE STRING ROUTINE NO REGISTERS THE **MEMORY SIZE VARIABLE IS SET DURING POWER ON DIAGNOSTICS ACCORDING TO THE FOLLOWING ASSUMPTIONS: CONFIGURATION RECORD IN NON-VOLATILE MEMORY EQUALS THE ACTUAL MEMORY SIZE INSTALLED. 2. ALL INSTALLED MEMORY IS FUNCTIONAL. IF THE MEMORY TEST DURING POST INDICATES LESS, THEN THIS VALUE BECOMES THE DEFAULT. IF NON-VOLATILE MEMORY IS NOT VALID (NOT INITIALIZED OR BATTERY FAILURE) THEN ACTUAL MEMORY DETERMINED BECOMES THE DEFAULT. 3. ALL MEMORY FROM 0 TO 640K MUST BE CONTIGUOUS. OUTPUT (AX) = NUMBER OF CONTIGUOUS IK BLOCKS OF MEMORY ASSUME CSICODE, DSIDATA MEMORY_SIZE_DET_1 PROC FAR ; INTERRUPTS BACK ON ; SAYE SEGMENT ; ESTABLISH ADDRESSING ; GET VALUE ; RECOVER SEGMENT ; RETURN TO CALLER STI--- PUSH DS CALL DDS MOV AX, OMEMORY_SIZE POP DS IRET MEMORY_SIZE_DET_I ENDP --- INT 11 H I DEVICES ARE ATTACHED TO THE STSTEM. NO REGISTERS THE GEQUIP FLAG VARIABLE IS SET DURING THE POWER ON DIAGNOSTICS USING THE FOLLOWING HARDWARE ASSUMPTIONS: PORT OSFA = INTERRUPT ID REGISTER OF 8250 (PRIMARY) OFFA = INTERRUPT ID REGISTER OF 8250 (SECONDARY) PORT 038 11 SUTPUT PORT OF PRINTER (PRIMARY) 0278 = OUTPUT PORT OF PRINTER (SECONDARY) 038C = OUTPUT PORT OF PRINTER (MONOCHROME-PRINTER) UT OUTPUT PORT OF PRINTER (MONOCHROME-PRINTER) AND 15 SET, BIT SIGNIFICANT, TO INDICATE ATTACHED I/O BIT 18,44 = NUMBER OF PRINTERS ATTACHED BIT 12 = INTERNAL MODEM INSTALLED BIT 12 NOT USED BIT 11,10,9 = NUMBER OF RS232 CARDS ATTACHED BIT 8 = NOT USED BIT 7,6 = NUMBER OF DISKETTE DRIVES 00=1,01=2 ONLY IF BIT 0 = 1 BIT 5,4 = INITIAL VIDEO MODE 01 - 40X25 BW USING COLOR CARD 10 - 40X25 BW USING COLOR CARD 11 - 60X25 BW USING COLOR CARD BIT 3 = NOT USED BIT 2 = NOT USED BIT 1 = MATH COPROCESSOR BIT 0 = 1 (|PL DISKETTE INSTALLED) NO OTHER REGISTERS AFFECTED ENTRY POINT FOR ORG OF840H INTERRUPTS BACK ON SAVE SEGMENT REGISTER ESTABLISH ADDRESSING GET THE CURRENT SETTINGS RECOVER SEGMENT RETURN TO CALLER DS DDS AX, DEQUIP_FLAG DS ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOSI ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-1 PAGE 118,121 TITLE BIOS1 ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES .286C .LIST CODE SEGMENT BYTE PUBLIC SEGMENT BYTE PUBLIC 0000 PUBLIC CASSETTE_IO_1 PUBLIC GATE_A20 PUBLIC SHUT9 EXTRN CMOS_READ:NEAR EXTRN CMOS_WR!TE:NEAR EXTRN CONF_TBL:NEAR EXTRN DDS:NEAR EXTRN PROC_SHUTDOWN:NEAR INPUT - CASSETTE 1/O FUNCTIONS (AH) = 00H (AH) = 01H (AH) = 02H (AH) = 03H RETURNS FOR THESE FUNCTIONS ALWAYS (AH) = 86H, CY = 1) IF CASSETTE PORT NOT FRESENT INPUT - UNUSED FUNCTIONS (AH) = 04H THROUGH TFH RETURNS FOR THESE FUNCTIONS ALWAYS (AH) = 86H, CY = 1) (UNLESS INTERCEPTED BY SYSTEM HANDLERS INTERRUPTED BY SYSTEM HANDLERS INTERRUPTED BY SYSTEM HANDLERS INTERRUPTED BY SYSTEM HANDLERS INTERRUPTS WITH AH=4FH TENSIONS EXTENSIONS (AH) = 80H DEVICE OPEN (BX) = DEVICE ID (CX) = PROCESS ID (AH) = 81H DEVICE CLOSE (BX) = DEVICE ID (CX) = PROCESS ID (AH) = 82H PROGRAM TERMINATION (BX) = DEVICE ID (AH) = 83H EVENT WAIT (AL) = 00H SET INTERVAL (ES:BX) POINTER TO A BYTE IN CALLERS MEMORY THAT WILL HAVE THE HIGH ORDER BIT SET AS SOON AS POSSIBLE AFTER THE INTERVAL EXPIRES. (CX,DX) NUMBER OF MICROSECONDS TO ELAPSE BEFORE POSTING. (AL) = 01H CANCEL RETURNS: CARRY IF AL NOT = 00H OR 01H OR IF FUNCTION AL=0 ALREADY BUSY OR IF FUNCTIONS (AH) = 84H JOYSTICK SUPPORT (DX) = 00H - READ THE CURRENT SWITCH SETTINGS (DX) = 01H - READ THE ESTITING STITINGS (DX) = 01H - READ THE RESISTIVE INPUTS RETURNS AX = A(x) VALUE BX = A(y) VALUE CX = B(x) VALUE DX = B(y) VALUE (AH) = 85H SYSTEM REQUEST KEY PRESSED (AL) = 00H MAKE OF KEY (AL) = 01H BREAK OF KEY (AH) = 86H WAIT (CX,DX) NUMBER OF MICROSECONDS TO ELAPSE BEFORE RETURN TO CALLER (AH) = 87H MOVE BLOCK (CX) NUMBER OF WORDS TO MOVE (ES:SI) POINTER TO DESCRIPTOR TABLE EXTENDED MEMORY SIZE DETERMINE PROCESSOR TO VIRTUAL MODE (AH) = 90H DEVICE BUSY LOOP (AL) SEE TYPE CODE (AL) SEE TYPE CODE INTERRUPT COMPLETE FLAG SET (ALI) TYPE CODE 00 -> TFH SERIALLY REUSABLE DEVICES OPERATING SYSTEM MUST SERIALIZE ACCESS 80H -> BFH REENTRANT DEVICES; ES:BX IS USED TO DISTINGUISH DIFFERENT CALLS (MULTIPLE I/O CALLS ARE ALLOWED SIMULTANEOUSLY) COH -> FFH WAIT DAY CALLS -- FFH WAIT ONLY CALLS -- THERE IS NO COMPLEMENTARY 'POST' FOR THESE WAITS. THESE ARE TIMEOUT ONLY TIMES ARE FUNCTION NUMBER DEPENDENT. TYPE DESCRIPTION TIMEOUT 00M = DISK 01M = DISKETTE YES 02M = KEYBOARD NO 80H = NETWORK NO E518X --> NOB FDH = DISKETTE MOTOR START YES YES YES YES NO NO ``` ECTION 5 ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS1 ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-3 0080 E4 A1 0080 E9 00 0080 E9 00 0080 E9 A1 0080 E9 A1 0086 E6 A1 0088 &C 08 009A R 009C 89 IE 0098 R 0090 89 0E 009E R 0090 E9 009E B1 009C 89 0E 009C 80 0080 E E9 0080 E 0080 E9 0080 E 0080 E9 E EVENT_WAIT_II AND AND OUT MOV MOV MOV MOV CALL AND POP STI CLC JMP ISST AL, INTBO! $+2 AL, OFEN INTBO!, AL SEG, ES OUSER FLAG, SEG, ES OUSER FLAG, SE OUSER FLAG, SE OUSER FLAG, SE OUSER FLAG, SE OUSER FLAG, SE AL, OH AL, CMOS REG B CMOS REG AL, OH AL, CMOS REG B C CMOS REG B C CMOS REG B C CMOS REG B C CMOS REG # ENSURE INTERRUPT UNMASKED SET UP TRANSFER TABLE ; SET ON FUNCTION ACTIVE SWITCH ENABLE PIE READ CHOS LOCATION CLEAR SET ENABLE PIE SAVE AH PLACE DATA INTO DATA REGISTER ADDRESS ALARM REGISTER PLACE DATA IN AH INTO ALARM REGISTER RESTORE AH : ENABLE INTERRUPTS C1_F CANCEL 0084 0084 FA 0085 F6 06 00A0 R 02 008A 74 05 EVENT_WAIT_3; CLT TEST JZ ; DISABLE INTERRUPTS ; CHECK FOR "WAIT" IN PROGRESS ; SKIP TO CANCEL CURRENT "EVENT_WAIT" ORTC WAIT FLAG, 02H : ENABLE INTERRUPTS : CLEAR STACK : AND SET CARRY FLAG FOR ERROR REQUEST : EXIT 00BC FB 00BD 1F 00BE F9 00BF EB 94 C1_F 00BF EB 94 00C1 00C2 B8 0B0B 00C2 B8 0B0B 00C5 EB 0000 E 00C6 E4 BF 00C0 E 00CF EB 00C0 E 00CF EB 00C0 E 00CF EB 00C0 EVENT_WAIT_4: PUSH MOV CALL AND XCHG CALL POP MOV STI POP CLC JMP I SAVE (WITH INTERRUPTS DISABLED) I TURN OFF PIE GET ALARN RECISTER I CLEAR PIE PACE INTO WRITE REGISTER RESTORE AN SET FUNCTION ACTIVE FLAG OFF ENABLE INTERRUPTS RESTOREDATA RESTOREDATA SET FUNCTION ACTIVE FLAG OFF ENABLE INTERRUPTS RESTOREDATA SECONDATA SECONDATA SET CARRY OFF RETURN AX AX,X°CMOS_REG_B CMOS_READ AL,0BFH AH,AL CMOS_WRITE AX ORTC_WAIT_FLAG,0 DS C1_F INPUT (DX)=0 READ THE CURRENT SWITCHES RETURNS (AL)= SWITCH SETTINGS IN BITS 7-4 (DX)=1 READ THE RESISTIVE INPUTS RETURNS (AX)=A(x) VALUE (BX)=A(y) VALUE (CX)=B(x) VALUE (DX)=B(y) VALUE CY FLAG ON IF NO ADAPTER CARD OR INVALID CALL 00DB FB 00DB FB 00DC 8B C2 00DE BA 0201 00E1 0A C0 00E3 74 0B 00E5 FE C8 00E7 74 0C 00E9 E9 0052 R 00EC FB 00ED E9 0055 R PROC NEAR JOY_3 C1 ; READ SWITCHES ; READ RESISTIVE INPUTS ; GO TO ERROR RETURN JOY 1: C1_F ; GO TO COMMON RETURN ; STRIP UNWANTED BITS OFF ; FINISHED OOFS BS FT OOFS BS OI OOFS ER OII3 R OOFA 51 OOFB BS O2 OOFD ES OII3 R OII00 51 OII00 51 OII07 ES OII3 R J0Y_3: BL, I TEST_CORD CX MOY PUSH MOYLL PUSH MOYLL PUSH MOYLL MOY CALL MOYPOP POP POP JMP BL.2 TEST_CORD CX SAVE A(Y) VALUE CX - BL,4 TEST_CORD CX BL,8 TEST_CORD DX,CX CX CX BX AX JOY_1 : SAVE B(X) VALUE ; SAVE B(Y) VALUE ; GET B(X) VALUE ; GET A(Y) VALUE ; GET A(X) VALUE ; FINISHED - RETURN 0111 EB D9 0113 52 0114 FA 0115 80 00 0117 E6 43 0119 EB 00 011B E4 40 011D EB 00 011F 8A E0 0121 E4 40 0123 56 E0 TEST_CORD PUSH CLI MOV OUT JMP IN JMP MOV IN XCHG PROC NEAR ; SAVE ; BLOCK INTERRUPTS WHILE READING ; SET UP TO LATCH TIMER 0 AL,0 TIMER+3,AL $+2 AL,TIMER $+2 AM,AL AL,TIMER AH,AL : READ LOW BYTE OF TIMER 0 ; READ HIGH BYTE OF TIMER 0 ; REARRANGE TO HIGH, LOW ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 B105: ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-4 04-21-86 0125 50 0126 98 04FF 0129 EE 00 0120 EC 0120 0120 EC 020 0134 59 0135 T5 04 0137 EB 02 0138 ED 02 0138 ED 02 0145 EB 02 0145 EB 02 0145 EB 02 0147 E4 40 0147 E4 40 PHOUTE TOPP STORE AL,DX AL,BL TEST_CORD_1 CX,0 CX SHORT TEST_CORD_2 CX,CX SHORT TEST_CORD_3 READ VALUES HAS PULSE ENDED? ORIGINAL COUNT ; SET 0 COUNT FOR RETURN ; EXIT WITH COUNT = 0 AL,0 TIMER+3,AL $+2 AL,TIMER AH,AL $+2 AL,TIMER AH,AL SET UP TO LATCH TIMER O READ LOW BYTE OF TIMER O ; READ HIGH BYTE OF TIMER OF REARRANGE TO HIGH, LOW 014B 3B C8 014D 73 0B 014F 52 0150 BA FFFF CX, AX TEST_CORD_4 DX DX,-1 ; CHECK FOR COUNTER WRAP 0153 2B D0 0155 03 CA 0157 5A 0158 EB 02 SUB ADD POP JMP DX,AX CX,DX DX SHORT TEST_CORD_5 ; ADJUST FOR WRAP 015A 015A 2B C8 015C 015C 81 E1 1FF0 0160 C1 E9 04 TEST_CORD_4: SUB TEST_CORD_5: AND SHR CX,AX CX, IFFOH CX,4 ; ADJUST 0163 FB 0163 FB 0164 BA 0201 0167 51 0168 50 0169 B9 04FF 016C 016C EC 016C EC 016D AB OF 016F EO FB DX,201H CX AX CX,4FFH TEST_CORD 6: 1N TEST LOOPN AL,DX AL,OFH TEST_CORD_6 0174 C3 RET 0175 TEST_CORD ENDP ENDP PROC PUSH CALL CLI TEST JZ STI POP STC JMP : ENABLE INTERRUPTS PRIOR TO RETURN DS C1_F ; SET_ERROR ; RETURN AL_,INTB01 ; ENSURE INTERRUPT UNMASI $+2 AL_,OFEM INTB01,AL GUSER FLAG_SEG,DS ; SET_UP_TRANSFER TABLE GUSER FLAG_OFFSET GRTC_WAIT_FLAG GRTC_FLOW,DX GRTC_FLOW,DX GRTC_WAIT_FLAG,OS : SET_ON "WAIT" FUNCTION AX_,XYCMOS_REG_B : SET_ON "WAIT" FUNCTION AX_,XYCMOS_REG_B : SEN_BULE_PIE GRAD_ALARN BYTE AL_,O40H : CLEAR SIT_BIT SIT_BIT_AL_,O40H SIT_BIT_ IN JMP AND OUT MOV MOV MOV MOV PUSH GALD OR HELPOP ; ENSURE INTERRUPT UNMASKED : SET ON "WAIT" FUNCTION ACTIVE SWITCHES : SAVE (AH) : ENABLE PIE : READ ALARM BYTE : CLEAR SIT BIT : ENABLE PIEST : ENABLE PIEST : ENABLE PIEST : WRITE NEW ALARM BYTE : RESTORE (AH) WAIT TILL RTC TIMEOUT POSTED (WITH ERROR TIMEOUT) O 187 FB 0 188 51 0 188 52 0 188 57 D1 0 18C F6 06 00AD R 80 0 1C1 E1 F9 0 1C3 75 05 0 1C5 53 EA 01 0 1C5 73 F2 0 1C6 C6 06 00AD R 00 0 1C7 E4 06 06 00AD R 00 0 1C7 54 0 1C7 55 0 1C7 56 0 1C7 57 0 1C7 57 0 1C7 57 0 1C7 57 ; ENABLE INTERRUPTS SAVE CALLERS PARAMETERS SWAP COUNT WORK REGISTERS TEST LOOPZ JNZ SUB JNC PRTC_WAIT_FLAG,080H WAIT_9 DX,1 WAIT_2 CHECK FOR END OF WAIT - CLEAR DECREMENT TIMEOUT DELAY TILL EXIT IF RTC TIMER WAIT ENDED DECREMENT ERROR TIMEOUT COUNT LOOP TILL COUNTERS TIMEOUT MOY POP POP CLC JMP eRTC_WAIT_FLAG,0 DX CX DS : SET FUNCTION INACTIVE : RESTORE CALLERS PARAMETERS ; CLEAR CARRY FLAG C1_F WAIT ``` CALL DDS ; SET DS TO DATA AREA 1-5 04-21-86 IBM Personal Computer MACRO Assembler Version 2.00 BIOS1 --- 06/10/85 INTERRUPT 15H BIOS ROUTINES ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOSI ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-6 04-21-86 ●10_ROM_SEG,SS ●10_ROM_INIT,SP SAVE USERS STACK SEGMENT SAVE USERS STACK POINTER ;==== SET UP THE PROTECTED MODE DEFINITIONS ===== :---- MAKE A 24 BIT ADDRESS OUT OF THE ES:SI FOR THE GDT POINTER ASSUME DS:NOTHING MOV AX,ES MOV DS,AX MOV DH,AH SHR DH,4 SHL AX,4 ADD AX,SI ADC DH,0 ; POINT (DS) TO USERS CONTROL BLOCK ; GET THE GDT DATA SEGMENT ; MOVE THE GDT SCAMENT POINTER TO (DS) ; BUILD HIGH BYTE OF THE 24 BIT ADDRESS USE ONLY HIGH NIBBLE SHIFT - RIGHT 4 ; STRIP HIGH NIBBLE FROM (AX) ; ADD THE GDT OFFSET TO DEVELOP LOW WORD ; ADJUST HIGH BYTE IF CARRY FROM LOW ;---- SET THE GDT_LOC [SI].CGDT_LOC.SEG_LIMIT,MAX_SEG_LEN [SI].CGDT_LOC.BASE_LO_WORD,ĀX _ ; SET THE LOW WORD [SI].CGDT_LOC.BASE_HI BYTE,DH ; SET THE HIGH BYTE [SI].CGDT_LOC.DATA_RESERVED,0 ; RESERVED SET UP ;---- MAKE A 24 BIT ADDRESS OUT OF THE (SS) - ( (SP) REMAINS USER (SP) ) ; GET THE CURRENT STACK SEGMENT ; FORM HIGH BYTE OF 24 BIT ADDRESS ; FORM HIGH BYTE - SHIFT RIGHT 4 ; STRIP HIGH NIBBLE FROM (AX) MOV MOV SHR SHL AX,SS DH,AH DH,4 AX,4 :---- SS IS NOW IN POSITION FOR A 24 BIT ADDRESS --> SETUP THE (SS) DESCRIPTOR SI].TEMP SS.SEG LIMIT, MAX SEG LEN ; SET THE SS SEGMENT LIMIT (SI).TEMP SS.BASE LO WORD XX ; SET THE LOW WORD (SI).TEMP SS.BASE HIB BYTE OF STATE HIGH BYTE (SI).TEMP SS.DATA_ACC_RIGHTS,CPLo_DATA_ACCESS ; SET CPL 0 MOY MOY MOY ;---- GATE ADDRESS BIT 20 ON (DISABLE INTERRUPTS) : GET ENABLE MASK : ENABLE A20 AND CLEAR INTERRUPTS : WAS THE COMMAND ACCEPTED? : GO IF YES ; SET THE ERROR FLAG IF NOT : EARLY ERROR EXIT ;---- SET SHUTDOWN RETURN ADDRESS AND DISABLE NMI BL4: MOY CALL AX,9"H+CMOS_SHUT_DOWN+NMI CMOS_WRITE ; SET THE SHUTDOWN BYTE LOCATION ; TO SHUT DOWN 9 AND DISABLE NMI :---- CLEAR EXCEPTION ERROR FLAG SUB AL,AL MFG_PORT,AL ; SET ERROR FLAG LOCATION TO O 3---- LOAD THE IDT AND GDT BP,OFFSET ROM_IDT_LOC CS O2EH [BP] OOFH BYTE BF,SET CS:??0001 O01H OFFSET CS:??0002 MOV SEGOV DB LIDT + 770001 LABEL + 770002 LABEL + 770002 LABEL DB - ORG REGISTER FROM THIS AREA + 770003 LABEL + 770004 LABEL + ORG + DB + ORG [S1].GGDT_LOC 1 00FH BYTE DX.WORD PTR [S1].GGDT_LOC BYTE OFFSET CS1?70003 001H OFFSET CS1?70004 : LOAD GLOBAL DESCRIPTOR TABLE REGISTER :---- SWITCH TO VIRTUAL MODE AX, VIRTUAL_ENABLE AX OFFH, OOIH, OFOH OEAH OFFSET VIRT BIOS_CS MOY LMSW DB DB DW DW MACHINE STATUS WORD NEEDED TO SWITCH TO VIRTUAL MODE ; PURGE PRE-FETCH QUEUE WITH FAR JUMP - TO OFFSET - IN SEGMENT -PROTECTED MODE SELECTOR VIRT: IN PROTECTED MODE - SETUP STACK SELECTOR AND SOURCE/TARGET SELECTORS AX,TEMP_SS $5.AX AX,SOURCE DS.AX AX,TARGET ES.AX SI,SI DI,DI USER'S SS-SP IS NOT A DESCRIPTOR LOAD STACK SELECTOR GET THE SOURCE ENTRY LOAD SOURCE SELECTOR GET THE TARGET ENTRY LOAD TARGET SELECTOR SET SOURCE SELECTOR SET SOURCE INDEX REGISTER TO ZERO SET TARGET INDEX REGISTER TO ZERO REP MOVSW : MOVE THE BLOCK COUNT PASSED IN (CX) ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS1 ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES :---- CHECK FOR MEMORY PARITY BEFORE SHUTDOWN :---- CLEAR PARITY BEFORE SHUTDOWN AX.DSI[DI] DSI[DI],AX AL.DI MFG PORT,AL AL.FORT B AL.RAM PAR_OFF PORT B.AL AL.RAM PAR_ON PORT_B.AL ; FETCH CURRENT SOURCE DATA ; WRITE IT BACK ; SET PARITY CHECK ERROR = 01 : TOGGLE PARITY CHECK LATCHES : TO CLEAR THE PENDING ERROR : AND ENABLE CHECKING ;---- CAUSE A SHUTDOWN DONET: JMP PROC_SHUTDOWN 0293 0293 E9 0000 E GO RESET PROCESSOR AND SHUTDOWN SHUT9: ASSUME DS:DATA MOV AX,DATA MOV DS,AX MOV S$,e10_ROM_INIT RESTORE USERS STACK 0296 B8 ---- R 0299 BE D8 0298 BE 16 0069 R 029F 8B 26 0067 R ; SET DS TO DATA AREA ; GET USER STACK SEGMENT ; GET USER STACK POINTER ;---- GATE ADDRESS BIT 20 OFF MOV AH,DISABLE_BIT20 CALL GATE_A20 CMP AL,0_ JZ DONES : DISABLE MASK : GATE ADDRESS 20 LINE OFF : COMMAND ACCEPTED? : GO IF YES CMECK FOR ANY OTHER ERROR FIRST WAS THERE AN ERROR? REPORT FIRST ERROR IF YES ELSE SET GATE A20 ERROR FLAG AL,MFG_PORT AL,0 DONE3 AL,03H MFG_PORT,AL IN CMP JNZ MOV OUT ;---- RESTORE THE USERS REGISTERS AND SET RETURN CODES DONES I MOV OUT POP POP IN IN MOV MOV MOV STI DONE4 PROC RED DONE4 ENDP AX,CMOS_SHUT_DOWN CMOS_PORT,AL DS ES AL,CMOS_DATA : CLEAR (AH) TO ZERO AND (AL) TO DEFAULT : ENABLE NM! INTERRUPTS : RESTORE USER DATA SEGMENT : PESTORE USER EXTRA SEGMENT : OPEN CMOS STANDBY LATCH 02BF E4 80 02C1 8B EC 02C3 88 46 0F 02C6 3A E0 02C8 61 02C9 FB 02CA 02CA CA 0002 GET THE ENDING STATUS RETURN CODE POINT TO REGISTERS IN THE STACK PLACE ERROR CODE INTO STACK AT (AH) SET THE ZF & CY FLAGS WITH RETURN CODE RESTORE THE CENERAL PURPOSE REGISTERS TURN INTERRUPTS ON AL,MFG_PORT BP,SP [BP+15],AL AH,AL RETURN WITH FLAGS SET -- (AM) = CODE (CY=0,ZF=1) = OK (CY=1,ZF=0) = ERROR ;---- BLOCK MOVE EXCEPTION INTERRUPT HANDLER 1 GET EXCEPTION ERROR CODE 1 SET EXCEPTION INTERRUPT OCCURRED FLAG 1 CAUSE A EARLY SHUTDOWN :---- ROM IDT LOCATION ROM_IDT_END-ROM_IDT ROM_IDT CSEGO_HI 0 02D4 02D4 0100 02D6 02DA R 02D8 0F 02D9 00 ROM_IDT_LOC: DW DW DB DB OR GATES FOR BLOCK MOVE EXCEPTION OF DESTINATION OFFSET DESTINATION OFFSET DESTINATION OFFSET GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION SEGMENT SELECTOR DESTINATION SEGMENT SELECTOR OFFSET DESTINATION SEGMENT SELECTOR OFFSET DESTINATION SEGMENT RESERVED DESTINATION SEGMENT RESERVED DESTINATION SEGMENT SELECTOR OFFSET ORSTINATION SEGMENT SELECTOR ORSTINATION SEGMENT RESERVED DESTINATION SEGMENT RESERVED DESTINATION SEGMENT RESERVED DESTINATION SEGMENT DESTINATION SEGMENT SELECTOR ORSTINATION SEGMENT GATE TYPE - ACCESS RIGHTS BYTE RESERVED ORSTINATION SEGMENT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION SEGMENT SELECTOR ORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION SEGMENT GATE TYPE - ACCESS RIGHTS BYTE RESERVED ORSTINATION SEGMENT GATE TYPE - ACCESS RIGHTS BYTE RESERVED RESERVED EXCEPTION 05 ;---- THE ROM EXCEPTION INTERRUPT VECTOR GATES FOR BLOCK MOVE ROM_IDT: DW DW DB DB 02DA 02DA 02CD R 02DC 0020 02DE 00 02DF 87 02E0 0000 TRAP_GATE EX_INT BIOS_CS 02E2 02CD R 02E4 0020 02E6 00 02E7 87 02E8 0000 DW DB DW DW DB DB DW DB DW DB DW DB DB DW BIOS_CS 0 TRAP_GATE 0 02EA 02CD R 02EC 0020 02EE 00 02EF 87 02F0 0000 EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS 0 TRAP_GATE 0 02FA 02CD R 02FC 0020 02FE 00 02FF 87 0300 0000 ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS1 ---- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-8 04-21-86 DESTINATION OFFSET DESTINATION OFFSET DESTINATION SEGMENT SELECTOR WORD COOPY COUNT RESERVED EXCEPTION 06 DESTINATION OFFSET DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION OFFSET DESTINATION OFFSET DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION OFFSET DEST | 1916 | 0302 | 0300 | 0307 | 0308 | 0308 | 0307 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | 0308 | EX_INT BIDS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE DW DB DB DB EX_INT BIOS_CS 0 TRAP_GATE 0 D# D# D# D# EX_INT BIOS_CS TRAP_GATE DW DW DW EX_INT BIOS_CS TRAP_GATE DW DB DB DW EX_INT BIOS_CS TRAP_GATE DB DB DW DW EX_INT BIOS_CS TRAP_GATE DW DW DB DB EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE DW DB DB EX_INT BIOS_CS TRAP_GATE DW DB DB DB EX_INT BIOS_CS TRAP_GATE DW DW DB DB DW EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE DW DW DB DB EX_INT BIOS_CS O TRAP_GATE GATE TYPE - ACCESS RIGHTS BYTE RESERVED. DESTINATION OFFSET: DESTINATION OFFSET: DESTINATION SEGMENT SELECTOR WORD COPY COUNT: GATE TYPE - ACCESS RIGHTS BYTE RESERVED. DESTINATION SEGMENT SELECTOR WORD COPY COUNT: GATE TYPE - ACCESS RIGHTS BYTE RESERVED. DESTINATION OFFSET: DESTINATION SEGMENT SELECTOR WORD COPY COUNT: GATE TYPE - ACCESS RIGHTS BYTE RESERVED. 0372 02CD R 0374 0020 0376 00 0377 87 0378 0000 EX_INT BIOS_CS TRAP_GATE 03TA 02CD R 03TC 0020 03TE 00 03TF 8T 0380 0000 DW DB DB DB EX_INT BIOS_CS TRAP_GATE DW DW DW DW 0382 02CD R 0384 0020 0386 00 0387 87 0388 0000 EX_INT BIOS_CS TRAP_GATE RESERVED. RESERVED. DESCRIPTION 22: ESTINATION OFFSET DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION OFFSET DESTINATION OFFSET DESCRIPTION 23: DESTINATION OFFSET DESTINATION OFFSET DESCRIPTION 24: RESERVED GATE TYPE - ACCESS RIGHTS BYTE RESERVED EXCEPTION 24 038A 02CD R 038C 0020 038E 00 038F 87 0390 0000 EX_INT BIOS_CS TRAP_GATE 0392 02CD R 0394 0020 0396 00 0397 87 0398 0000 EX_INT BIOS_CS TRAP_GATE ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS1 --- 06/10/85 INTERRUPT 15H BIOS ROUTINES 1-9 04-21-86 SESTINATION OFFSET DESTINATION OFFSET DESTINATION SEGMENT SELECTOR WORD COPY COUNT GATE TYPE - ACCESS RIGHTS BYTE RESERVED DESTINATION OFFSET OFFSE EX_INT BIOS_CS 0 TRAP_GATE 0 905 039A 02CD R 906 039C 0020 906 039C 0020 907 03PC 0020 908 03PC 0020 908 03PC 0020 911 03A0 0000 911 03A0 0000 911 03A0 0000 911 03A0 0000 912 03A7 0020 913 03A6 0020 914 03A7 87 915 03A8 0000 922 03B2 02CD R 918 03A0 0000 922 03B5 0000 922 03B5 0000 922 03B5 0000 922 03B5 0000 922 03B5 0000 922 03B5 0000 923 03BC 0020 924 03C 0020 925 03B6 0000 926 03B7 87 927 03B8 0000 928 03C 0000 929 03BC 93B 03BC 0000 944 945 03BC 0000 946 03BC 0000 947 03BC 0000 EX_INT BIOS_CS TRAP_GATE EX_INT BIDS_CS 0 TRAP_GATE 0 EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS O Trap_gate O EX_INT BIOS_CS TRAP_GATE EX_INT BIOS_CS TRAP_GATE BLOCKMOVE ENDP ``` ``` 955 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | 959 | GATE_A20 THIS ROUTINE CONTROLS A SIGNAL WHICH GATES ADDRESS BIT 20. THE GATE A20 SIGNAL IS AN OUTPUT OF THE 8042 SLAVE PROCESSOR. ADDRESS BIT 20 SHOULD BE GATED ON BEFORE ENTERING PROTECTED MODE. IT SHOULD BE GATED OFF AFTER ENTERING REAL MODE FROM PROTECTED MODE. INTERRUPTS ARE LEFT DISABLED ON EXIT. INPUT (AH) = DDH ADDRESS BIT 20 GATE OFF, (A20 ALWAYS ZERO) (AH) = DFH ADDRESS BIT 20 GATE ON. (A20 CONTROLLED BY 80286) OUTPUT (AL) = 00H OPERATION SUCCESSFUL. 8042 HAS ACCEPTED COMMAND. (AL) = 02H FAILURE--8042 UNABLE TO ACCEPT COMMAND. GATE_A2O PROC PROC CLI CALL EMPTY 5042 UNABLI CALL EMPTY 5042 CLI CALL EMPTY 5042 SAVE USERS (CX) DISABLE INTERRUPTS WHILE USING 8042 INSURE 8042 INPUT BUFFER EMPTY EXIT IF 8042 UNABLE TO ACCEPT COMMAND 18042 COMMAND TO 8012 UNITFUT COMMAND TO 8042 UNITFUT COMMAND TO 8042 UNITFUT COMMAND TO 8042 I WAIT FOR 8042 TO ACCEPT COMMAND 18042 PORT AZ UNABLE TO ACCEPT COMMAND 10042 PORT AZ UNABLE TO ACCEPT COMMAND 10047 UNITFUT DORT ATA TO 8042 10047 UT TORT DATA TO 8042 10047 UNITFUT TORT ATA TO 8042 ;---- 8042 OUTPUT WILL SWITCH WITHIN 20 MICRO SECONDS OF ACCEPTING PORT DATA EMPTY_8042 THIS ROUTINE WAITS FOR THE 8042 INPUT BUFFER TO EMPTY. NONE OUTPUT ENDP THE I/O MEMORY SIZE VARIABLE IS SET DURING POWER ON DIAGNOSTICS ACCORDING TO THE FOLLOWING ASSUMPTIONS: 1. ALL INSTALLED MEMORY IS FUNCTIONAL. 2. ALL MEMORY FROM 0 TO 640K MUST BE CONTIGUOUS. OUTPUT (AX) = NUMBER OF CONTIGUOUS IK BLOCKS OF MEMORY A AVAILABLE STARTING AT ADDRESS 1024K. EXT_MEMORY PROC MOY CALL XCHG CALL IRET AX,CMOS_U_M_S_LO*H+CMOS_U_M_S_HI; ADDRESS HIGH/LOW BYTES CMOS_READ ; GET THE HIGH BYTE OF 1/0 MEMORY AL,AH ; PUT HIGH BYTE IN POSITION (AH) CMOS_READ ; GET THE LOW BYTE OF 1/0 MEMORY ; RETURN TO USER EXT_MEMORY ENDP ``` ``` AGE -- INT 15 H ( FUNCTION 89 H ) ----- PURPOSE: THIS BIOS FUNCTION PROVIDES A MEANS TO THE USER TO SWITCH INTO VIRTUAL (PROTECTED) MODE. UPON COMPLETION OF THIS FUNCTION THE PROCESSOR WILL BE IN VIRTUAL (PROTECTED) MODE AND CONTROL WILL BE TRANSFERRED TO THE CODE SEGMENT THAT WAS SPECIFIED BY THE USER. ENTRY REQUIREMENTS: (ESISI) POINTS TO A DESCRIPTOR TABLE (GOT) BUILT BEFORE INTERRUPTING TO THIS FUNCTION. THESE DESCRIPTORS ARE USED BY THIS FUNCTION TO INITIALIZE THE IDTR. THE GOTR AND THE STACK SEGMENT SELECTOR THE DATA SEGMENT (DS) SELECTOR AND THE EXTRA SEGMENT (ES) SELECTOR WILL. BE INITIALIZE TO DESCRIPTORS BUILT BY THE ROUTINE USING THIS FUNCTION. BH - OFFSET INTO THE INTERRUPT DESCRIPTOR TABLE STATING WHERE THE DESCRIPTOR THE INTERRUPT DESCRIPTOR TABLE STATING WHERE THE SECOND EIGHT HARDWARE INTERRUPTS BEGIN. (INTERRUPT LEVEL 2) DESCRIPTORS ARE DEFINED AS FOLLOWS: 1. THE FIRST DESCRIPTOR IS THE REQUIRED DUMMY. (USER INITIALIZED TO 0) 2. THE SECOND DESCRIPTOR POINTS TO THE GOT TABLE AS A DATA SEGMENT. (USER INITIALIZED) 3. THE THIRD DESCRIPTOR POINTS TO THE USER DEFINED HIS DESCRIPTOR POINTS TO THE USER DEFINED HIS DESCRIPTOR POINTS TO THE USER'S DATA SEGMENT (DS). (USER INITIALIZED) 5. THE FIGHTH DESCRIPTOR POINTS TO THE USER'S EXTRA SEGMENT (DS). (USER INITIALIZED) 6. THE SIXTH DESCRIPTOR POINTS TO THE USER'S STACK SEGMENT (SS). (USER INITIALIZED) 7. THE SEVENTH DESCRIPTOR POINTS TO THE CODE SEGMENT HIS DESCRIPTOR POINTS TO THE CODE SEGMENT HIS DESCRIPTOR TO THE USER'S CODE SEGMENT, DESCRIPTOR TO THE USER'S CODE SEGMENT, DESCRIPTOR TO THE USER'S CODE SEGMENT, DESCRIPTOR THE USER SEGMENT, DESCRIPTOR THE USER SEGMENT, DESCRIPTOR THE USER SEGMENT, DESCRIPTOR THE USER SEGMENT, DESCRIPTOR THIS PUNCTION TO ESTABLISH A CODE SEGMENT FOR ITSELF. THIS IS NEEDED SO THAT THIS FUNCTION CAN COMPLETE IT'S EXECUTION WHILE IN PROTECTED MODE. THEN CONTROL GETS USEDED TO THAT THIS FUNCTION CAN COMPLETE IT'S EXECUTION WHILE IN PROTECTED MODE. THEN CONTROL GETS USEDED TO THAT THIS FUNCTION CAN COMPLETE IT'S EXECUTION WHILE IN PROTECTED MODE. THEN CONTROL GETS USES TO THE USER'S CODE MOSS DESCRIPTOR CAN BE USED BY THIS PUNCTION CAN COMPLETE IT'S EXECUTION WHILE IN PROTECTED MODE. THEN CONTROL GETS SUSSED TO THE USER'S CODE MOSS DESCRIPTOR CAN BE USED BY THIS FUNCTION CAN COMPLETE IT'S DESCRIPTOR MUST CONTROL AND THE CHOOSES. THE DESCRIPTORS ARE DEFINED AS FOLLOWS: NOTE - EACH DESCRIPTOR MUST CONTAIN ALL THE NECESSARY DATA I.E. THE LIMIT, BASE ADDRESS AND THE ACCESS RIGHTS BYTE. AH= 89H (FUNCTION CALL) ES:SI = LOCATION OF THE GOT TABLE BUILD BY ROUTINE USING THIS FUNCTION. EXIT PARAMETERS: AH = 0 IF SUCCESSFUL ALL SEGMENT REGISTERS ARE CHANGED, (AX) AND (BP) DESTROYED CONSIDERATIONS: 1. NO BIOS AVAILABLE TO USER. USER MUST HANDLE ALL 1/O COMMANDS. 2. INTERRUPTS - INTERRUPT VECTOR LOCATIONS MUST BE MOVED, DUE TO THE 286 RESERVED AREAS. THE HARDWARE INTERRUPT CONTROLLERS MUST BE REINITIALIZED TO DEFINE LOCATIONS THAT DO NOT RESIDE IN THE 286 RESERVED AREAS. 3. EIGHT LOCATIONS THAT DO NOT RESIDE IN THE 286 INITIALIZED BY THE USER. 4. THE INTERRUPT DESCRIPTOR TABLE MUST NOT OVERLAP THE REAL MODE BIOS INTERRUPT DESCRIPTOR TABLE. 5. THE FOLLOWING GIVES AN IDEA OF WHAT THE USER CODE SHOULD LOOK LIKE WHEN INVOKING THIS FUNCTION. VIRTUAL MODE - DESCRIPTION: DESCRIPTION: 1. CLI INO INTERRUPTS ALLOWED WHILE THIS FUNCTION IS EXECUTING. 2. ADDRESS INE USER STATE SACTURE. 3. THE GOTR IS LOADED WITH THE GOT BASE ADDRESS. 5. THE IDTR IS LOADED WITH THE GOT BASE ADDRESS. 6. THE BOTR IS LOADED WITH THE FOR BASE ADDRESS. 1. THE PROCESSOR IS PUT IN THE LOADED WITH THE CODE SEGMENT DESIGNATED FOR THIS FUNCTION. 2. SECRET OF THE STATE OF THE USER DEFINED 3. SELECTOR FOR THE DS REGISTER. 4. SELECTOR FOR THE SERGISTER. 5. STACK SEGMENT IS LOADED WITH THE USER DEFINED SELECTOR FOR THE SERGISTER. 10. STACK SEGMENT IS LOADED WITH THE USER DEFINED SELECTOR FOR THE SERGISTER. 11. CODE SEGMENT DESCRIPTOR SELECTOR VALUE IS SESSIONED TO SEGMENT DESCRIPTOR SELECTOR VALUE IS SESSIONED TO SECRET WITH INTERRUPTS DISABLED. ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS2 ---- 06/10/85 BIOS INTERRUPT ROUTINES 0000 0031 PUBLIC PRINT SCREEN\_I PUBLIC RTC INT PUBLIC TIME OF DAY\_I PUBLIC TIME TIME OF DAY\_I EXTRN CMOS READINEAR EXTRN CMOS WAITE: NEAR EXTRN DDSINEAR :--- INT 'A H -- (TIME OF DAY) -----THIS BIOS ROUTINE ALLOWS THE CLOCKS TO BE SET OR READ (AH) = 01H SET THE CURRENT CLOCK USING. (CX) = HIGH PORTION OF COUNT. (DX) = LOW PORTION OF COUNT. NOTE: COUNTS OCCUR AT THE RATE OF 1193180/65536 COUNTS/SECOND (OR ABOUT 18.2 PER SECOND -- SEE EQUATES) (AH) = 02H READ THE REAL TIME CLOCK AND RETURN WITH, (CH) = HOURS IN BCD (00-23) (CL) = MINUTES IN BCD (00-59) (DH) = SCONDS IN BCD (00-59) (DL) = DATLIGHT SAVINGS EMBLE (00-0) (AH) = 03H SET THE REAL TIME CLOCK USING, (CH) = HOURS IN BCD (00-23) (CL) = MINUTES IN BCD (00-59) (DH) = SECONDS IN BCD (00-59) (DL) = 01 IP DAYLIGHT SAVINGS ENABLE OPTION, ELSE 00. NOTE: (OL)= 00 IF DAYLIGHT SAVINGS TIME ENABLE IS NOT ENABLED (OL)= 01 ENABLES TWO SPECIAL UPDATES THE LAST SUNDAY IN AFRIL (1:59:59 --> 3:00:00 AM) AND THE LAST SUNDAY IN CTOBER (1:59:59 --> 1:00:00 AM) THE FIRST TIME. (AH) = 04H READ THE DATE FROM THE REAL TIME CLOCK AND RETURN WITH, (CH) = CENTURY IN BOD (10-90) (CL) = YEAR IN BOD (00-99) (DH) = MONTH IN BCD (01-131). (AH) = 05H SET THE DATE INTO THE REAL TIME CLOCK USING, (CH) = CENTURY IN BCD (19 OR 20) (CL) = YEAR IN BCD (00 - 9) (OH) = MONTH IN BCD (01 - 12) (OL) = DAY IN B CD (01 - 31). (AH) = 06H SET THE ALARM TO INTERRUPT AT SPECIFIED TIME, (CH) = HOURS IN BCD (00-23 (OR FFH)) (CL) = MINNITES IN BCD (00-59 (OR FFH)) (OH) = SECONDS IN BCD (00-59 (OR FFH)). (AH) = 07H RESET THE ALARM INTERRUPT FUNCTION. (AM) = 0.1M MESEL THE ALARM INTERDET FORCETORS. NOTES: FOR ALL RETURNS CY'S OF POS SUCCESSIVE OFFERATION. FOR IAMIS 2, 4, 5 - CARRY FLAG SET IF REAL TIME CLOCK NOT OPERATING. FOR IAMIS 2, 2, 4, 5 - CARRY FLAG SET IF ALARM ALREADY ENABLED. FOR THE ALARM FUNCTION (AH = 6) THE USER MUST SUPPLY A ROUTINE AND INTERCEPT THE CORRECT ADDRESS IN THE VECTOR TABLE FOR INTERRUPT AND USE OFFH FOR ANY "DO NOT CARRY POSITION FOR INTERVAL INTERRUPTS. INTERRUPTS AND NOT CARRY POSITION FOR INTERVAL INTERRUPTS. AND ALL ALL ARE RETURNED MODIFICAT MODIFICATION THERE INDICATED. ASSUME CS-CORD.S.DATA ASSUME CS: CODE, DS: DATA ``` TIME_OF_DAY_I PROC FAR ST! CMP AH,(RTC_TBE: CMC JC TIME_9 AH, (RTC_TBE-RTC_TB)/2 ; EXIT WITH CARRY * I IF NOT VALID ; SAVE USERS (DS) SEGMENT ; GET DATA SEGMENT SELECTOR ; SAVE WORK REGISTER BY OF SECOND SECO DS DDS 51 AX,8 AX,AX S1,AX 0007 1E 0008 E8 0000 E 0008 56 000C C1 E8 08 000F 03 C0 0011 8B F0 0013 FA 0014 ZE: FF 94 0021 R PUSH CALL PUSH SHR ADD MOY CLI CALL CS:[SI]+OFFSET RTC_TB 0019 FB 001A B4 00 001C SE 001D 1F 001E 001E CA 0002 STI MOV POP POP AH,0 SI DS 0021 0031 R 0023 0042 R 0025 0050 R 0027 0075 R 0029 0008 R 0029 0008 R 0020 0104 R 0020 0104 R ``` TIME OF\_DAY\_1 ENDP ROUTINE VECTOR TABLE (AH) = 1 0 = READ CURRENT CLOCK COUNT | 1 = SET CLOCK COUNT | 2 = READ THE REAL TIME CLOCK TIME | 3 = SET REAL TIME CLOCK TIME | 4 = READ THE REAL TIME CLOCK DATE | 5 = SET REAL TIME CLOCK DATE | 6 = SET THE REAL TIME CLOCK ALARM | 7 = RESET ALARM 1-3 04-21-86 0154 RTC\_00 ENDP RTC\_DO EMDF RTC\_STA PROC MOV CALL MOV CALL MOV CALL MOV CALL RET 0154 BB 260A 0157 EB 0000 E 015A BB 220B 015D EB 0000 E 016A BB 00C 0162 EB 0000 E 0165 BO 000 E 0167 EB 0000 E 0167 EB 0000 E 016A C3 NEAR AX 264\*\*H+CMOS\_REG\_A CMOS\_WRITE AX, 324\*\*H+CMOS\_REG\_B CMOS\_WRITE CMOS\_REG\_C CMOS\_READ AL, CMOS\_REG\_D CMOS\_READ UPD IPR ENDP 0168 0168 51 0162 59 0320 016F B0 0A 0171 FA 0171 FA 0177 IBM Personal Computer MACRO Assembler Version 2.00 BIOS2 ---- 06/10/85 BIOS INTERRUPT ROUTINES PAGE RTC\_60: I INITIALIZE REAL TIME CLOCK ADDRESS REGISTER A AND LOAD DATA MASK INITIALIZE STATUS REGISTER A SET "SET BIT" FOR CLOCK INITIALIZATION AND 24 HOUR MODE TO REGISTER B ADDRESS REGISTER C READ REGISTER C TO INITIALIZE ADDRESS REGISTER D READ RTC STA ENDP UPD\_IPR PROC PUSH MOY NEAR CX CX,800 UPD\_10: MOV CLI CALL TEST JZ STI LOOP XOR STC AL, CMOS\_REG\_A CMOS\_READ AL,80H UPD\_90 UPD\_10 UPD\_90: POP CL! RET # WAIT TILL UPDATE NOT IN PROGRESS # SAVE CALLERS REGISTER # SET TIMEOUT LOOP COUNT : ADDRESS STATUS REGISTER A IND TIMER INTERRUPTS DURING UPDATES READ UPDATE IN PROCESS FLAG I IF UIP BIT IS ON I CANNOT READ TIME ) EXIT WITH CYB O IF CAN READ CLOCK NOW I ALLOW INTERRUPTS WHILE WAITING I CLOPF TILL READY OF TIMEOUT I CLEAR RESULTS IF ERROR SET CARRY FOR ERROR RESTORE CALLERS REGISTER INTERRUPTS OFF DURING SET RETURN WITH CY FLAG SET ``` INTERRUPTS ARE ENABLED WHEN THE EVENT OR ALARM FUNCTION IS ACTIVATED. FOR THE EVENT INTERRUPT, THE HANDLER WILL DECREMENT THE WAIT COUNTER AND WHEN IT EXPIRES WILL SET THE DESIGNATED LOCATION TO 80H. FOR THE ALARM INTERRUPT, THE USER MUST PROVIDE A ROUTINE TO INTERCEPT THE CORRECT ADDRESS FROM THE VECTOR TABLE INVOKED BY INTERRUPT 4AH PRIOR TO SETTING THE REAL TIME CLOCK ALARM (INT 1AH, AH= 86H). ; ALARM INTERRUPT ; LEAVE INTERRUPTS DISABLED ; SAVE REGISTERS RTC_INT PROC PUSH PUSH PUSH 0185 0185 B8 8B8C 0188 E6 70 018A 90 018B E4 71 018D A8 60 018F 74 5C AX, (CMOS REG_B+NMI) *H+CMOS REG_C+NMI ; ALARM AND STATUS CMOS_PORT, AL. ; WRITE ALARM FLAG MASK ADDRESS ; I/O DELAY AL, CMOS_DATA AL, 011000009 ; CHECK FOR EITHER INTERRUPT PENDING RIC_1_9 ; EXIT IF NOT A VALID RTC INTERRUPT. RTC_I_1: MOY OUT NOP IN TEST JZ 0191 86 E0 0193 E6 T0 0195 90 0196 E4 T1 0198 22 C4 019A A8 40 019C T4 3F : SAVE FLAGS AND GET ENABLE ADDRESS : WRITE ALARM ENABLE MASK ADDRESS : I/O DELA : I/O DELA : READ CURRENT ALARM ENABLE MASK : ALLOW ONLY SOURCES THAT ARE ENABLED : CHECK FOR PERIODIC INTERRUPT : SKIP IF NOT A PERIODIC INTERRUPT XCHG OUT NOP IN AND TEST JZ AH,AL CMOS_PORT,AL AL,CMOS_DATA AL,AH AL,01000000B RTC_1_5 :---- DECREMENT WAIT COUNT BY INTERRUPT INTERVAL : ESTABLISH DATA SEGMENT ADDRESSABILITY : DECREMENT COUNT LOW BY 1/1024 : ADJUST HIGH WORD FOR LOW WORD BORROW : SKIP TILL 32 BIT WORD LESS THAN ZERO 019E E8 0000 E 01A1 81 2E 009C R 03D0 01A7 83 1E 009E R 00 01AC 73 2F CALL SUB SBB JNC DDS PRTC_LOW,0976 PRTC_HIGH,0 RTC_T_5 :---- TURN OFF PERIODIC INTERRUPT ENABLE 01AE 50 01AF B8 8B8B 01B2 65 70 01B5 64 71 01B5 64 71 01B7 24 BF 01B9 66 C4 01BB 66 C4 01BB 66 C4 01BB 66 C4 01BF E6 71 01C1 58 01C2 F6 06 00AO R 02 01C7 C6 06 00AO R 00 01CC C5 3E 0098 R 01CD C5 3E 0098 R PUSH MOY OUT NOP IN AND XCHG OUT POP TEST MOY JZ 01D5 E8 0000 E 01D8 C6 06 00A0 R 83 01DD 01DD A8 20 01DF 74 0A CALL MOV DDS PRTC_WAIT_FLAG,083H : ESTABLISH DATA SEGMENT ADDRESSABILITY : AND SET "WAIT" BACK TO BUSY & POSTED TEST JZ AL,00100000B RTC_I_7 : TEST FOR ALARM INTERRUPT : SKIP USER INTERRUPT CALL IF NOT ALARM 01E1 B0 0F 01E3 E6 70 01E5 FB 01E6 52 01E7 CD 4A 01E9 5A 01EA FA 01EB 01EB EB 98 MOY OUT ST! PUSH INT POP CL! : POINT TO DEFAULT READ ONLY REGISTER : ENABLE NMI AND CMOS ADDRESS TO DEFAULT : INTERRUPTS BACK ON NOW AL,CMOS_SHUT_DOWN CMOS_PORT,AL DX 4AH DX : TRANSFER TO USER ROUTINE BLOCK INTERRUPT FOR RETRY RESTART ROUTINE TO HANDLE DELAYED RETRY AND SECOND EVENT BEFORE DONE RTC_I_7: RTC_I_I RTC_1_9: MOV OUT NOP IN MOV OUT POP POP POP POP RTC INT 01ED 80 0F 01EF E6 70 01F1 90 01F4 B0 20 01F6 E6 20 01F6 5F 01FD CF 01FD CF EXIT - NO PENDING INTERRUPTS POINT TO DEFAULT READ ONLY REGISTER ENABLE MINI AND CMOS ADDRESS TO DEFAULT I/O DELAY OPEN STANDBY LATCH END OF INTERRUPT MASK TO 8259 - 2 I TO 8259 - 2 I TO 8259 - 2 I TO 8259 - 2 I TO 8259 - 2 I TO 8259 - 2 AL,CMOS_SHUT_DOWN CMOS_PORT,AL AL, CMOS_DATA AL, EO1 INTBOO, AL INTAOO, AL DI AX DS : END OF INTERRUPT OIFE RTC_INT_ENDP ``` AGE INT 08 H PRINT SCREEN THE CURSOR POSITION AT THE TIME THIS ROUTINE IS INVOKED BY INTERRUPT 05H TO PRINT THE SCREEN. THE CURSOR POSITION AT THE TIME THIS ROUTINE IS INVOKED BY BLL BE SAVED AND RESTORED UPON COMPLETION. THE ROUTINE IS INTENDED TO RUN WITH INTERRUPTS ENABLED. IF A SUBSEQUENT PRINT SCREEN KEY IS DEPRESSED WHILE THIS ROUTINE IS PRINTING IT WILL BE IGNORED. THE BASE PRINTERS STATUS IS CHECKED FOR NOT BUSY AND NOT OUT OF PAPER. AN INITIAL STATUS ERROR WILL ABEND THE PRINT REQUEST. ADDRESS 000510000 CONTAINS THE STATUS OF THE PRINT SCREEN! PRINT\_SC ENDP : EXIT ROUTINE ; RESTORE ALL THE REGISTERS USED ; RETURN WITH INITIAL INTERRUPT MASK ``` IBM Personal Computer MACRO Assembler Version 2.00 BIOS2 ---- 06/10/85 BIOS INTERRUPT ROUTINES $ 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 | 200 :---- CARRIAGE RETURN, LINE FEED SUBROUTINE CRLF PROC NEAR 0287 33 D2 0289 B8 000D 028C CD 17 028E B8 000A 0291 CD 17 0293 C3 0294 XOR MOV INT MOV INT RET ENOP ;- HARDWARE INT 08 H -- ( IRQ LEVEL 0 ) ------- THE INTERRUPT HANDLER MAINTAINS A COUNT (4016C) OF INTERRUPTS SINCE POWER ON TIME, WHICH MAY BE USED TO ESTABLISH TIME OF DAY. THE INTERRUPT HANDLER ALSO DECREMENTS THE MOTOR CONTROL COUNT (40140) OF THE DISKETTE, AND WHEN IT EXPIRES, WILL TURN OFF THE DISKETTE, AND WHEN IT EXPIRES, WILL TURN OFF THE DISKETTE MOTOR(1), AND RESET THE MOTOR MANNING FLASE. THE INTERRUPT HANDLER WILL ALSO INVOKE A USER ROUTINE THROUGH INTERRUPT 10H AT EVERY TIME TICK. THE USER MUST CODE A ROUTINE AND PLACE THE CORRECT ADDRESS IN THE VECTOR TABLE. TIMER_INT_I STI PUSH PUSH PUSH CALL INC JNZ INC T4: : INTERRUPTS BACK ON DS AX DX DDS OTIMER_LOW T4 OTIMER_HIGH I SAYE MACHINE STATE I ESTABLISH ADDRESSABILITY INCREMENT TIME I GO TO TEST DAY INCREMENT FIICH WORD OF TIME TEST DAY TEST DAY TEST DAY TEST FOR COUNT EQUALING 24 HOURS I GO TO DISKETTE_CTL CMP JNZ CMP JNZ OT!MER_HIGH,018H TS PTIMER_LOW, OBOH GO TO DISKETTE_CTL TIMER HAS GONE 24 HOURS AX,AX OTIMER_HIGH,AX OTIMER_LOW,AX OTIMER_OFL,1 SUB MOY MOY MOY 02C1 02C1 FE 0E 0040 R 02C5 75 0B 02C7 80 26 003F R F0 02CC 80 0C 02CE 8A 03F2 02D1 EE T5: OMOTOR_COUNT T6 OMOTOR_STATUS,OFOH AL,OCH DX,03F2H DX,AL DEC JNZ AND MOY MOY OUT DECREMENT DISKETTE MOTOR CONTROL RETURN IF COUNT NOT OUT TURN OFF MOTOR RUNNING BITS FDC CTL PORT : TIMER TICK INTERRUPT : TRANSFER CONTROL TO A USER ROUTINE POP MOV CL1 OUT POP POP IRET : RESTORE (DX) : GET END OF INTERRUPT MASK : DISABLE INTERRUPTS TILL STACK CLEARED : END OF INTERRUPT TO 8259 - I DX AL,EOI INTAGO,AL AX DS RESET MACHINE STATE TIMER INT I ENDP CODE ENDS ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-1 04-21-86 PAGE 118,121 TITLE ORGS ----- 04/21/86 COMPATIBILITY MODULE LIST CODE SEGMENT BYTE PUBLIC 01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012 SEGMENT BYTE PUBLIC PUBLIC CONT TBL PUBLIC CONT TBL PUBLIC CRT TCHAR GEN PUBLIC CRT TCHAR GEN PUBLIC D12 PUBLIC D2A PUBLIC D2A PUBLIC D2A PUBLIC D2A PUBLIC D2A PUBLIC D13K BASE PUBLIC D105 PUBLIC E101 PUBLIC E101 PUBLIC E105 PUBLIC E105 PUBLIC E105 PUBLIC E105 PUBLIC E105 PUBLIC E106 PUBLIC E107 PUBLIC E108 PUBLIC E108 PUBLIC E109 PUBLIC E109 PUBLIC E201 PUBLIC E201 PUBLIC E201 PUBLIC E201 PUBLIC E201 PUBLIC E201 PUBLIC E303 PUBLIC E303 PUBLIC E303 PUBLIC E301 PUBLIC E301 PUBLIC E301 PUBLIC E301 PUBLIC E301 PUBLIC E501 PUBLIC E501 PUBLIC E71790 PUBLIC F17791 PUBLIC F1780 K10 PUBLIC K12 K14 PUBLIC K16 PUBLIC K16 PUBLIC K16 PUBLIC K16 PUBLIC K16 PUBLIC M4 M6 PUBLIC C M7 PUBLIC C M6 PUBLIC C M6 PUBLIC C M7 PUBLIC C M6 PUBLIC C M6 PUBLIC C M6 PUBLIC C M7 PUBLIC C M6 PUBLIC C M7 PUBLIC C M6 PUBLIC C M7 PUBLIC C M7 PUBLIC C M6 PUBLIC C M7 PUBLIC C M7 PUBLIC C M7 PUBLIC C M6 PUBLIC C M7 PUBLIC VECTOR TABLE PUBLIC VIDEO FARMS EXTRN BOOT STRAP | INEAR EXTRN CASSETTE IO | INEAR EXTRN DIN MAR | EXTRN DISK SETUPINEAR EXTRN DISK SETUPINEAR EXTRN DISK SETUPINEAR EXTRN DISK SETUPINEAR EXTRN DISK SETUPINEAR EXTRN MINITER SETUPINEAR EXTRN KEYBOARD IO INEAR EXTRN KEYBOARD IO INEAR EXTRN KEYBOARD IO INEAR EXTRN KEYBOARD IO INEAR EXTRN MINITER SETUPINEAR EXTRN MINITER SETUPINEAR EXTRN MINITER SETUPINEAR EXTRN PRINTER IO INEAR EXTRN PRINTER IO INEAR EXTRN MINITER IO INEAR EXTRN MINITER IO INEAR EXTRN MINITER IO INEAR EXTRN MINITER IO INEAR EXTRN MINITER OF THIS MODULE HAS BEEN ADDED TO FACILITATE THE EXPANSION OF THIS PROGRAM. IT ALLOWS FOR THE FIXED ORG STATEMENT ENTRY POINTS THAT HAVE TO REMAIN AT THE AME ADDRESSES THE SE OF ENTRY POINTS AND TABLES WITHEN HIS MODULE SHOULD BE NOTICED AND ARE INCLUDED ONLY TO SUPPORT EXISTING CODE THAT YIGHATE THE STRUCTURE AND DESIGN OF BIOS. USE THE DOCUMENTED INTERRUPT VECTOR INTERFACE FOR COMPATIBILITY. ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-2 04-21-86 109012111146676701223456476290123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676701234667676701234667676701234667676701234667676701234667676701234667676701234667676701234667676701234667676701234667676701234667670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767670123466767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346676767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346676701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346677670123466776701234667767012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234670123467012346701234 0E000H 0000 PARITY ERROR MESSAGES : 0020 60 41 52 49 54 59 20 43 48 45 43 48 20 31 0D 0A 0030 50 41 52 49 54 59 20 32 0D 0A 38 45 43 48 20 32 0D 0A 3F 3F 3F 0D 0040 3F 3F 3F 3F 3F 0D 0047 DB DI *PARITY CHECK 1*, CR, LF ; PLANAR BOARD PARITY CHECK LATCH SET IP 005B 005B 005B E9 0000 E RESET: RESET START VECTOR ON TO THE MOVED POST CODE START_1 POST ERROR MESSAGES : EIOI DB * 101-System Board Error*, CR, LF; INTERRUPT FAILURE E102 DB * 102-System Board Error*, CR, LF ; TIMER FAILURE E103 * 103-System Board Error*, CR, LF ; TIMER INTERRUPT FAILURE DB E104 DB * 104-System Board Error*, CR, LF ; PROTECTED MODE FAILURE E106 DB * 106-System Board Error*, CR, LF ; CONVERTING LOGIC TEST * 107-System Board Error*, CR, LF ; HOT NMI TEST E107 DB E109 DB E161 DB * 161-System Options Not Set-(Run SETUP) *.CR.LF : DEAD BATTERY E162 DB 1 162-System Options Not Set-(Run SETUP) '.CR.LF :CHECKSUM/CONFIG E163 DB * 163-Time & Date Not Set-(Run SETUP)*, CR.LF :CLOCK NOT UPDATING * 164-Memory Size Error-(Run SETUP) *. CR.LF : CMOS DOES NOT MATCH E164 DB E201 DB ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-3 04-21-86 E203 08 * 203-Memory Address Error*, CR, LF ; LINE ERROR 16->23 E301 DB ' 301-Keyboard Error', CR, LF : KEYBOARD ERROR E302 DB * 302-System Unit Keylock is Locked*,CR,LF ; KEYBOARD LOCK ON F3D ' (RESUME = "F1" KEY)',CR.LF ----- NMI ENTRY = 0273 IP 11- IP = ORG ORG ORG OMI_INT EQU JMP $ 0E2C3H 002C3H $ NMI_INT_1 02C3 = 02C3 02C3 E9 0000 E : VECTOR ON TO MOVED NMI CODE 02C6 20 33 30 33 2D 4B 65 79 62 6F 61 72 64 20 4F 72 20 53 79 73 74 65 6D 20 55 6E 69 74 20 45 72 72 6F 72 0D 0A E303 DB ' 303-Keyboard Or System Unit Error', CR, LF 55 66 97 42 20 45 72 72 69 71 20 00 02EA 20 33 30 34 20 48 65 79 73 79 62 67 61 72 64 20 47 12 20 53 79 73 74 65 60 20 55 66 69 74 20 45 65 72 20 00 00 030E 20 35 30 31 20 43 65 72 20 00 00 031E 20 35 30 31 20 43 65 72 20 00 00 031E 20 35 30 31 20 43 65 72 00 00 00 031E 20 35 30 31 20 43 65 73 00 00 57 72 72 032E 20 35 30 31 20 44 65 72 00 00 57 72 72 032E 20 35 30 31 20 44 65 72 00 00 57 72 72 0346 20 45 74 74 04 20 45 74 74 04 20 45 74 74 05 20 45 74 74 05 20 45 74 74 05 20 45 74 74 06 20 45 74 74 06 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 20 45 74 07 2 KEYBOARD/SYSTEM ERROR E304 B '304-Keyboard Or System Unit Error', CR, LF ; KEYBOARD CLOCK HIGH E401 E501 DB ' 501-CRT Error', CR.LF ; COLOR ' 601-Diskette Error',CR,LF : DISKETTE ERROR ;---- DISKETTE BOOT RECORD IS NOT VALID E602 DB '602-Diskette Boot Record Error', CR, LF 72 00 0A 0364 31 37 38 30 20 44 69 73 68 20 30 20 46 61 69 6C 75 72 0379 30 38 31 20 44 61 69 6C 15 72 65 00 0A 0385 31 37 38 32 20 44 69 73 68 20 43 67 65 72 20 46 61 69 03AC 37 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 43 67 73 68 20 31 03BF 31 37 39 31 20 44 69 73 68 20 31 20 45 72 72 67 72 00 0A ;---- HARD FILE ERROR MESSAGE F1780 DB '1780-Disk 0 Failure',CR,LF '1781-Disk 1 Failure',CR,LF F1782 DB '1782-Disk Controller Failure', CR, LF '1790-Disk 0 Error', CR, LF F1791 DB '1791-Disk 1 Error', CR, LF 03D2 52 4F 4D 20 20 45 72 72 6F 72 20 0D 03DF 20 20 20 2D 55 6E 6C 6F 63 6B 20 53 79 73 74 65 6D 20 55 6E 69 74 20 48 65 79 6C 6F 63 6B 20 0D 0A F3A F3D1 DR -Unlock System Unit Keylock ',CR,LF ``` ``` IBM Personal Computer MACRO Assemblar Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-4 04-21-86 INITIALIZE DRIVE CHARACTERISTICS THE TABLE IS COMPOSED OF A BLOCK DEFINED AS: (1 WORD) - MAXIMAM NUMBER OF CYLINDERS (1 BYTE) - MAXIMAM NUMBER OF FEADS (1 WORD) - NOT USED/SEE PC-XT (1 WORD) - STARTING WRITE PRECOMPENSATION CYL (1 BYTE) - NOT USED/SEE PC-XT (1 BYTE) - CONTROL BYTE BIT 7 DIABLE RETRIES BIT 6 DIABLE RETRIES BIT 7 DIABLE RETRIES BIT 7 DIABLE RETRIES (1 WORD) - LANDING ZONE (1 WORD) - LANDING ZONE (1 BYTE) - RESERVED FOR FUTURE USE - TO DYNAMICALLY DEFINE A SET OF PARAMETERS BUILD A TABLE FOR UP TO 15 TYPES AND PLACE THE CORRESPONDING VECTOR INTO INTERRUPT 41 FOR DRIVE O AND INTERRUPT 46 FOR DRIVE 1. 0401 FD_TBL: ---- DRIVE TYPE 01 0401 0132 0403 04 0404 0000 0406 0080 0408 00 0409 00 0400 00 00 0400 0131 040F 11 0410 00 0306D 04D 0128D 0 0,0,0 0305D 17D DW DW DW DB DB DB DB DB : CYLINDERS ; HEADS ; WRITE PRE-COMPENSATION CYLINDER ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK DRIVE TYPE 02 0411 0267 0413 04 0414 0000 0416 012C 0418 00 0419 00 0419 00 0410 0267 0417 01 0417 01 0615D 04D 0 0300D DW DW DW DB DB DB DW DB : CYLINDERS ; WRITE PRE-COMPENSATION CYLINDER ; CONTROL BYTE : LANDING ZONE : SECTORS/TRACK DRIVE TYPE 03 0421 0267 0423 06 0424 0000 0426 012C 0428 00 0429 00 0429 00 0420 0267 0421 0267 0430 00 0615D 06D 0300D 0 0,0,0 0615D 17D ; CYLINDERS ; HEADS DW DW DB DB DB DW DB DB ; WRITE PRE-COMPENSATION CYLINDER ; CONTROL BYTE : LANDING ZONE : SECTORS/TRACK DRIVE TYPE 04 0431 03AC 0433 08 0434 0000 0436 0200 0438 00 0439 00 043A 00 00 00 043D 03AC 045F 11 0440 00 0940D 08D 0 0512D DW DW DW DB DB DB DW DB DB ; CYLINDERS ; HEADS ; WRITE PRE-COMPENSATION CYLINDER ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK DRIVE TYPE 05 0441 03AC 0443 06 0444 0000 0446 0200 0448 00 0449 00 0444 00 00 044D 03AC 044F 11 DW DW DB DB DB DB DB DB 0940D 06D | CYLINDERS | HEADS 0512D # WRITE PRE-COMPENSATION CYLINDER 0,0,0 0940D 17D ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK DRIVE TYPE 06 0451 026T 0453 04 0454 0000 0456 FFFF 0458 00 0459 00 0450 00 0450 026T 0451 11 0460 00 0615D 04D 0 0FFFFH ; CYLINDERS ; HEADS ; NO WRITE PRE-COMPENSATION t CONTROL BYTE : LANDING ZONE : SECTORS/TRACK ``` | I BM<br>ORGS | Personal Computer MACRO | Assemble<br>BILITY MO | r Ver<br>DDULE | sion 2.00 | 1-5<br>04-21-86 | | |---------------------------------|-----------------------------------------------------------------------------------|-----------------------|----------------|------------------------|---------------------------------------|---------| | 423<br>424 | | PAGE | DRIVE | TYPE 07 | | | | 425<br>426 | 0461 01CE | | DW | 0462D | ; CYLINDERS | | | 427<br>428 | 0463 08<br>0464 0000<br>0466 0100 | | DB<br>DW | 08D | ; HEADS | | | 429<br>430 | 0466 0100<br>0468 00 | | DW<br>DB | 0256D | WRITE PRE-COMPENSATION C | YLINDER | | 431<br>432 | 0468 00<br>0469 00<br>046A 00 00 00<br>046D 01FF | | DB<br>DB | 0<br>0,0,0<br>0511D | ; CONTROL BYTE | | | 433<br>434 | 046D 01FF<br>046F 11<br>0470 00 | | DB | 170 | : LANDING ZONE<br>: SECTORS/TRACK | | | 435<br>436 | 0470 00 | | 08 | 0 | | | | 437<br>438 | | 1 | | TYPE 08 | | | | 439<br>440<br>441 | 0471 0200<br>0473 05 | | DW<br>DB | 0733D<br>05D | CYLINDERS HEADS | | | 441<br>442 | 0474 0000<br>0476 FFFF | | D#<br>D# | 0<br>Offfh | NO WRITE PRE-COMPENSATIO | N | | 442<br>443<br>444<br>445 | 0476 FFFF<br>0478 00<br>0479 00<br>0470 00 00<br>0470 02DD | | DB<br>DB | 0 | ; CONTROL BYTE | | | 445<br>446 | 047A 00 00 00<br>047D 02DD | | DB<br>DW | 0,0,0<br>0733D | | | | 446<br>447<br>448<br>449 | 047F 11<br>0480 00 | | DB<br>DB | 170 | : LANDING ZONE<br>: SECTORS/TRACK | | | 449<br>450 | | , | DRIVE | TYPE 09 | | | | 451<br>452 | 0481 0384<br>0483 0F | • | DW | 0900D | ; CYLINDERS | | | 453<br>454 | 0484 0000 | | DB<br>DW | 15D<br>0 | HEADS | | | 455<br>456<br>457 | 0486 FFFF<br>0488 00 | | DW<br>DB | OFFFFH<br>O | ; NO WRITE PRE-COMPENSATIO | N | | 458 | 0489 08<br>048A 00 00 00 | | DB<br>DB | 008H<br>0,0,0<br>0901D | ; CONTROL BYTE | | | 459<br>460 | 048A 00 00 00<br>048D 0385<br>048F 11 | | DW<br>DB | 170 | : LANDING ZONE<br>: SECTORS/TRACK | | | 461<br>462<br>463 | 0490 00 | | DB | 0 | | | | 464 | | 1 | DRIVE | | | | | 465<br>466<br>467 | 0491 0334<br>0493 03<br>0494 0000 | | DB<br>DB | 0820D<br>03D | CYLINDERS HEADS | | | 468 | 0496 FFFF | | DW<br>DW | O<br>Offffh | ; NO WRITE PRE-COMPENSATIO | N | | 469<br>470 | 0498 00<br>0499 00 | | DB<br>DB | 0 | ; CONTROL BYTE | | | 471 | 049A 00 00 00<br>049D 0334<br>049F 11<br>04A0 00 | | D# | 0,0,0<br>0820D | ; LANDING ZONE | | | 473<br>474 | 049F 11<br>04A0 00 | | DB<br>DB | 17D<br>0 | ; SECTORS/TRACK | | | 475<br>476 | | ; | DRIVE ' | TYPE 11 | | | | 476<br>477<br>478<br>479 | 04A1 0357 | | DW<br>DW | 0855D<br>05D | ; CYLINDERS<br>; HEADS | | | 480<br>481 | 04A3 05<br>04A4 0000<br>04A6 FFFF | | DM<br>DM | 0<br>OFFFFH | NO WRITE PRE-COMPENSATIO | | | 482 | 04A8 00<br>04A9 00 | | 08 | 0 | CONTROL BYTE | N | | 483<br>484<br>485 | 04AA 00 00 00<br>04AD 0357 | | DB<br>DW | 0.0.0<br>0866D | • | | | 486<br>487 | 04A8 00<br>04A8 00<br>04A9 00<br>04AA 00 00 00<br>04AD 0357<br>04AF 11<br>04B0 00 | | DB<br>DB | 17D | : LANDING ZONE<br>: SECTORS/TRACK | | | 488 | | , | DRIVE | TYPE 12 | | | | 489<br>490<br>491<br>492<br>493 | 0481 0357 | • | D₩ | 0855D | ; CYLINDERS | | | 492 | 0481 0357<br>0483 07<br>0484 0000<br>0486 FFFF | | DB<br>DW | 07D | ; HEADS | | | 494<br>495 | 0488 00 | | DB<br>DW | ÖFFFFH<br>O | ; NO WRITE PRE-COMPENSATIO | N | | 496<br>497 | 0489 00<br>048A 00 00 00<br>048D 0357 | | DB<br>DB | 0<br>0,0,0<br>0855D | ; CONTROL BYTE | | | 498<br>499 | 04BD 0357<br>04BF 11<br>04C0 00 | | DW<br>DB | 17D | ; LANDING ZONE<br>; SECTORS/TRACK | | | 500<br>501 | 0400 00 | | DB | 0 | | | | 502<br>503 | | 1 | DRIVE ' | | | | | 504<br>505 | 04C1 0132<br>04C3 08 | | DB | 08D<br>0306D | ; CYLINDERS<br>; HEADS | | | 506<br>507 | 04C4 0000<br>04C6 0080 | | DW | 0<br>0128D | # WRITE PRE-COMPENSATION C | YLINDER | | 508<br>509 | 04C8 00<br>04C9 00 | | DB<br>DB | 0 | ; CONTROL BYTE | | | 510<br>511 | 04C9 00<br>04CA 00 00 00<br>04CD 013F<br>04CF 11 | | DB<br>DW | 0,0,0<br>0319D | ; LANDING ZONE<br>; SECTORS/TRACK | | | 512<br>513<br>514 | 04D0 00 | | DB<br>DB | 17D<br>0 | ; SECTORS/TRACK | | | 515 | | ţ | DRIVE | TYPE 14 | | | | 517 | 04D1 02DD<br>04D3 07 | | DW<br>DB | 0733D<br>07D | 1 CYLINDERS<br>1 HEADS | | | 518<br>519<br>520 | 04D4 0000<br>04D6 FFFF | | DM<br>DM | O<br>O<br>OFFFFH | ; HEADS<br>; NO WRITE PRE-COMPENSATIO | | | 521<br>522 | 04D8 00 | | DB<br>DB | 0<br>0<br>0 | : CONTROL BYTE | | | 523<br>524 | 04D9 00<br>04DA 00 00 00<br>04DD 02DD | | DB<br>DW | 0,0,0<br>0733D | • | | | 525<br>526 | 04DF 11<br>04E0 00 | | DB<br>DB | 17D | ; LANDING ZONE<br>; SECTORS/TRACK | | | | | | | - | | | ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-6 04-21-86 **** DO NOT USE**** DRIVE TYPE 15 0000D 0000D 0000D 0000D 0000D 04E1 0000 04E3 00 04E4 0000 04E6 0000 04E8 00 04E9 00 04EA 00 00 00 04ED 0000 04F0 00 DW DW DW DB DB DB DB DB ; WRITE PRE-COMPENSATION CYLINDER ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK DRIVE TYPE 16 04F1 0264 04F3 04 04F4 0000 04F6 0000 04F8 00 04F9 00 04FA 00 00 00 04FA 00 00 00 04FF 019 04FF 11 0612D 04D 0000D 0 0,0,0 0663D 17D ; CYLINDERS ; HEADS DW DW DW DB DB DB DB DB | WRITE PRE-COMPENSATION ALL CYLINDER ; CONTROL BYTE : LANDING ZONE : SECTORS/TRACK DRIVE TYPE 17 0501 03D1 0503 05 0504 0000 0506 012C 0508 00 0509 00 050A 00 00 00 050D 03D1 050F 11 0510 00 DW 09777D DW 050 DW 0300D DB 0,0,0 0 DB 0,0,0 DB 0 DB 0,0,0 DB 0 DB 0,0,0 DB 0 DB 0,0,0 DB 0 DB 0,0,0 DB 0 DB 0,0,0 D : CYLINDERS : WRITE PRE-COMPENSATION CYL ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK 0511 03D1 0513 07 0514 0000 0516 FFFF 0518 00 0519 00 051A 00 00 00 051D 03D1 051F 11 0520 00 0977D 07D 0 0FFFFH 0 0 0,0,0 0977D 17D ; CYLINDERS ; HEADS NO WRITE PRE-COMPENSATION : CONTROL BYTE : LANDING ZONE : SECTORS/TRACK 0521 0400 0523 07 0524 0000 0526 0200 0528 00 0529 00 052A 00 00 00 052B 03FF 052F 11 0530 00 ; CYLINDERS ; HEADS ; WRITE PRE-COMPENSATION CYLINDER ; LANDING ZONE ; SECTORS/TRACE DRIVE TYPE 20 0733D 05D 0300D 0 0,0,0 0732D 17D 0531 02DD 0533 05 0534 0000 0536 012C 0538 00 0539 00 053A 00 00 00 053B 02DC 053F 11 0540 00 DW DW DW DB DB DB DB DB ; CYLINDERS ; HEADS ; WRITE PRE-COMPENSATION CYL ; LANDING ZONE ; SECTORS/TRACK DRIVE TYPE 21 0733D 07D 0300D 0 0,0,0 0732D 17D 0541 02DD 0543 07 0544 0000 0546 012C 0548 00 0549 00 054A 00 00 00 054B 02DC 054F 11 0550 00 DW DW DW DB DB DB DB DB ; CYLINDERS ; HEADS ; CONTROL BYTE : LANDING ZONE : SECTORS/TRACK DRIVE TYPE 22 0551 02DD 0553 05 0554 0000 0556 012C 0558 00 0559 00 0550 02DD 055F 11 0560 00 0733D 05D 0300D 0 0,0,0 0733D 17D DW DW DW DB DB DB DB : CYLINDERS # WRITE PRE-COMPENSATION CYL ; CONTROL BYTE ; LANDING ZONE ; SECTORS/TRACK ``` | I BM<br>ORGS | Personal Compe | uter MACRO Assemble<br>6 COMPATIBILITY MO | DULE | raion 2.00 | ) | 1-7<br>04-21-8 | 6 | |-------------------|-----------------------------------------------------------|-------------------------------------------|----------|---------------------|-----|----------------|--------------------------------| | 631<br>632 | | PAGE | DRIVE | TYPE 23 | | | | | 633<br>634 | 0561 0132 | • | DW | 0306D | | | CYLINDERS | | 635 | 0563 04<br>0564 0000 | | DW<br>DW | 04D | | i | | | 636<br>637<br>638 | 0566 0000<br>0568 00 | | DW<br>DB | 0000D | | 1 | WRITE PRE-COMPENSATION ALL CYL | | 639 | 0540 00 | | DB | | | 1 | CONTROL BYTE | | 640<br>641<br>642 | 056A 00 00 00<br>056D 0150 | | D# | 0,0,0<br>0336D | | ; | LANDING ZONE | | 643 | 056F 11<br>0570 00 | | DB<br>DB | 17D | | ; | SECTORS/TRACK | | 644<br>645 | | ; | DRIVE | TYPE 24 | | | | | 646<br>647 | 0671 0244 | • | DW | 0612D | | | CYLINDERS | | 648<br>649 | 0571 0264<br>0573 04<br>0574 0000 | | DB<br>DW | 04D | | i | HEADS | | 650 | 0576 0131 | | D₩ | 0305D | | | WRITE PRE-COMPENSATION CYL | | 651<br>652 | 0578 00<br>0579 00 | | DB | 0 | | | CONTROL BYTE | | 653<br>654<br>655 | 057A 00 00 00<br>057D 0297<br>057F 11 | | DB<br>DW | 0,0,0<br>0663D | | | LANDING ZONE<br>SECTORS/TRACK | | 655<br>656 | 057F 11<br>0580 00 | | DB<br>DB | 170 | | i | SECTORS/TRACK | | 657<br>658 | | 1 | | TYPE 25 | ••• | RESERVED*** | | | 659 | 0501 0000 | • | DW | 00000 | | | CYLINDERS | | 660<br>661 | 0583 00 | | DB<br>DW | OOD | | ; | HEADS | | 662<br>663 | 0581 0000<br>0583 00<br>0584 0000<br>0586 0000<br>0588 00 | | DW | 00000 | | ; | WRITE PRE-COMPENSATION CYL | | 664<br>665 | 0588 00<br>0589 00 | | DB | ô | | : | CONTROL BYTE | | 666<br>667 | 0589 00<br>058A 00 00 00<br>058D 0000<br>058F 00 | | DØ<br>DØ | 0,0,0<br>0000D | | | LANDING ZONE | | 668<br>669<br>670 | 058F 00<br>0590 00 | | DB<br>DB | 000 | | ; | SECTORS/TRACK | | 671 | | , | DRIVE | TYPE 26 | ••• | RESERVED*** | | | 672<br>673 | 0591 0000 | • | DW | 0000D | | | CYLINDERS | | 674<br>675 | 0593 00<br>0594 0000<br>0596 0000 | | DB<br>DW | 00D | | í | HEADS | | 676<br>677 | 0596 0000<br>0598 00 | | DB<br>DW | 0000 | | : | WRITE PRE-COMPENSATION CYL | | 678<br>679 | 0599 00 | | DB<br>DB | ō | | : | CONTROL BYTE | | 680 | 059A 00 00 00<br>059D 0000<br>059F 00 | | Ď₩ | 0.0.0<br>0000D | | | LANDING ZONE<br>SECTORS/TRACK | | 681<br>682 | 059F 00<br>05A0 00 | | DB<br>DB | 00D | | ; | SECTORS/TRACK | | 683<br>684 | | 1 | DRIVE | TYPE 21 | ••• | RESERVED*** | | | 685<br>686 | 05A1 0000 | | DW | 0000D | | | CYLINDERS | | 687<br>688 | 05A1 0000<br>05A3 00<br>05A4 0000 | | DB | 00D | | i | HEADS | | 689 | 05A6 0000<br>05A8 00 | | DW<br>DB | 00000 | | , | WRITE PRE-COMPENSATION CYL | | 690<br>691<br>692 | 05A9 00<br>05AA 00 00 00 | | DB<br>DB | 0,0,0 | | : | CONTROL BYTE | | 693<br>694 | 05AD 0000<br>05AF 00 | | DW | 0000D | | | LANDING ZONE<br>SECTORS/TRACK | | 695<br>696 | 05B0 00 | | DB | 000 | | , | SECTORS/TRACK | | 697<br>698 | | 1 | DRIVE | TYPE 28 | ••• | RESERVED*** | | | 699 | 05B1 0000 | | DW | 0000D | | ; | CYLINDERS | | 700<br>701<br>702 | 05B3 00<br>05B4 0000<br>05B6 0000 | | DW<br>DB | 0 OD | | • | HEADS | | 703 | 05B8 00 | | DW<br>DB | 00000 | | | WRITE PRE-COMPENSATION CYL | | 704<br>705 | 0589 00<br>058A 00 00 00 | | DB<br>DB | 0<br>0,0,0<br>0000D | | : | CONTROL BYTE | | 706<br>707 | 05BA 00 00 00<br>05BD 0000<br>05BF 00 | | D# | 0000D<br>00D | | : | LANDING ZONE<br>SECTORS/TRACK | | 708 | 0500 00 | | DB | 0 | | • | | | 710<br>711 | | 1 | DRIVE | TYPE 29 | ••• | RESERVED*** | | | 712<br>713 | 0501 0000 | | DW<br>DW | 0000D | | : | CYLINDERS<br>HEADS | | 714 | 05C3 00<br>05C4 0000 | | DW<br>DW | 0 | | | | | 716<br>717 | 05C6 0000<br>05C8 00 | | DB | 0000D | | | WRITE PRE-COMPENSATION CYL. | | 718 | 05C9 00<br>05CA 00 00 00 | | DB<br>DB | 0.0.0 | | • | CONTROL BYTE | | 719<br>720<br>721 | 05CA 00 00 00<br>05CD 0000<br>05CF 00 | | DB<br>DW | 0000D<br>00D | | ; | LANDING ZONE<br>SECTORS/TRACK | | 722 | 05D0 00 | | DB | 0 | | • | | | 723 | | 1 | | TYPE 30 | ••• | RESERVED*** | | | 724<br>725<br>726 | 05D1 0000<br>05D3 00 | | DW<br>DB | 0000D | | ! | CYL INDERS<br>HEADS | | 121 | 05D4 0000 | | DW<br>DW | 0000D | | | WRITE PRE-COMPENSATION CYL | | 728<br>729 | 05D6 0000<br>05D8 00 | | DB | 0 | | | | | 730<br>731 | 05D9 00<br>05DA 00 00 00 | | DB<br>DB | 0,0,0<br>0000D | | - | CONTROL BYTE | | 732<br>733 | 05DD 0000<br>05DF 00 | | D# | OOD | | į | LANDING ZONE<br>SECTORS/TRACK | | 734 | 05E0 00 | | DB | 0 | | | | | I EM<br>ORGS | Personal Computer MACR | O Assemble<br>IBILITY MO | r Version 2.00<br>COULE | 1-8<br>04-21-86 | |--------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------|-------------------------------------------------------------------|-----------------------------------| | 735<br>736 | | PAGE | DRIVE TYPE 31 | *** RESERVED*** | | 736<br>737<br>738<br>739<br>740<br>741<br>742<br>743<br>744<br>745 | 05E1 0000 | | DW 0000D | t CYLINDERS | | 739 | 05E1 0000<br>05E3 00<br>05E4 0000 | | DB 00D<br>DW 0000D | HEADS | | 741 | 98E6 9999 | | DW 0000D | # WRITE PRE-COMPENSATION CYL | | 742<br>743 | 05E8 00<br>05E9 00 | | DB 0 | ; CONTROL BYTE | | 744 | 05EA 00 00 00<br>05ED 0000<br>05EF 00 | | DB 0,0,0<br>DW 0000D<br>DB 00D<br>DB 0 | I AND ING ZONE | | 746 | 05EF 00<br>05F0 00 | | DB 00D | ; LANDING ZONE<br>; SECTORS/TRACK | | 746<br>747<br>748<br>749<br>750 | 9579 90 | | | | | 749<br>750 | | 1 | ORIVE TYPE 32 | *** RESERVED*** | | 181<br>762<br>753 | 05F1 0000<br>05F3 00<br>05F4 0000<br>05F6 0000 | | DW 0000D | CYLINDERS | | 753 | 05F4 0000 | | DW 0 | WRITE PRE-COMPENSATION CYL | | 754<br>756 | 05F8 00<br>05F9 00<br>05FA 00 00<br>05FA 00 00<br>05FF 00 | | DB 0 | | | 756<br>757 | 05F9 00<br>05FA 00 00 00 | | DB 0,0,0<br>DB 0,0,0<br>DW 0000D | : CONTROL BYTE | | 768<br>769 | 05FD 0000 | | DW 0000D | : LANDING ZONE<br>: SECTORS/TRACK | | 760 | 0600 00 | | DB 00D | y sacroner man | | 761<br>762<br>763<br>764<br>766<br>766<br>767<br>768<br>769<br>770 | | ; | DRIVE TYPE 33 | *** RESERVED*** | | 763<br>764 | 0601 0000 | | DW 0000D | ; CYLINDERS | | 766 | 0603 00<br>0604 0000 | | DB 00D | HEADS | | 767 | | | OW 0000D<br>DB 0<br>DB 0 | # WRITE PRE-COMPENSATION CYL | | 769 | 0608 00<br>0607 00<br>0607 00<br>0600 00<br>0600 00<br>0610 00 | | 08 0 | CONTROL BYTE | | 771 | 060D 0000 | | DW 0000D | : LANDING ZONE<br>: SECTORS/TRACK | | 112<br>113 | 060F 00<br>0610 00 | | DB 00D<br>DB 0 | ; SECTORS/TRACK | | 774<br>775<br>776<br>777 | | , | DRIVE TYPE 34 | *** RESERVED*** | | 776 | 0611 0000 | • | DW 0000D | ; CYLINDERS | | 778<br>779 | 0613 00<br>0614 0000 | | DB 00D<br>DW 0<br>DW 0 | HEADS | | 780<br>781 | 0616 0000 | | DW 0000D | WRITE PRE-COMPENSATION CYL | | 782 | 0616 0000<br>0618 00<br>0618 00<br>0619 00<br>0610 0000<br>0610 0000 | | DB 0 | ; CONTROL BYTE | | 783<br>784<br>785 | 061A 00 00 00<br>061D 0000 | | DB 0,0,0<br>DW 0000D | | | 785 | 061F 00<br>0620 00 | | DB 00D | ; LANDING ZONE<br>; SECTORS/TRACK | | 786<br>787<br>788<br>789 | V020 VV | , | DRIVE TYPE 35 | *** RESERVED*** | | 789 | | , | | | | 790<br>791<br>792<br>793 | 062: 0000<br>0623 00<br>0624 0000 | | DW 0000D<br>DW 0 | ; CYLINDERS<br>; HEADS | | 792<br>793 | 0624 0000<br>0626 0000 | | OW 00000 | # WRITE PRE-COMPENSATION CYL | | 794<br>795<br>796 | 0628 00<br>0629 00 | | DB 0 | : CONTROL BYTE | | 796 | 062A 00 00 00 | | OB 0<br>OB 0<br>OB 0,0,0<br>OW 00000 | I LANDING ZONE | | 797<br>798<br>799 | 062F 00 | | DB 000 | ; LANDING ZONE<br>; SECTORS/TRACK | | 800 | 0024 0000<br>0628 00<br>0628 00<br>0629 00<br>0620 00 00<br>0620 0000<br>0620 00 | | | *** | | 802 | | 1 | DRIVE TYPE 36 | *** RESERVED*** | | 803<br>804 | 0631 0000<br>0632 00 | | DW 0000D | ; CYLINDERS<br>: HEADS | | 806 | 0631 0000<br>0632 00<br>0634 0000<br>0626 0000 | | DB 00D<br>DW 0000D<br>DB 0 | : WRITE PRE-COMPENSATION CYL | | 807 | 0638 00 | | DB 0 | 2 CONTROL BYTE | | 808 | 0639 00<br>063A 00 00 00 | | 0.0.0 | , | | 810 | 063A 00 00 00<br>063D 0000<br>063F 00 | | DB 00D | ; LANDING ZONE<br>; SECTORS/TRACK | | 812 | 0640 00 | | DB 0 | | | 813<br>814<br>816 | | 1 | DRIVE TYPE 37 | *** RESERVED*** | | 816 | 0641 0000 | | DW 0000D<br>DW 0 | CYLINDERS | | 816<br>817<br>818 | 0641 0000<br>0643 00<br>0644 0000<br>0646 0000 | | D# 0 | | | 819<br>820<br>821 | 0646 0000<br>0648 00 | | <b>UB</b> V | WRITE PRE-COMPENSATION CYL | | 821<br>822 | 0648 00<br>0649 00<br>0649 00<br>0640 0000<br>0640 000<br>0650 00 | | DB 0,0,0 | ; CONTROL BYTE | | 823 | 064D 0000 | | DB 0,0,0<br>DW 0000D<br>DB 00D | LANDING ZONE<br> SECTORS/TRACK | | 824<br>826 | 0650 00 | | DB 0 | * APPLACE LIVER | | 826<br>827 | | ; | DRIVE TYPE 38 | *** RESERVED*** | | 828<br>829 | 0651 0000 | | DW 0000D | ; CYLINDERS | | 830<br>831 | 00 E2AD | | DB 00D<br>DW 0000D<br>DB 0000<br>DB 0,0,0<br>DW 0000D<br>DB 0000D | HEADS | | 832<br>833 | 0654 0000<br>0656 0000<br>0658 00 | | DW 0000D | #RITE PRE-COMPENSATION CYL | | 834 | 0489 00 | | 00 | ; CONTROL BYTE | | 835<br>836 | 065A 00 00 00<br>065D 0000<br>065F 00 | | DB 0.0.0<br>DW 0000D | : LANDING ZONE<br>: SECTORS/TRACK | | 837<br>838 | 065F 00<br>0660 00 | | DB 00D | # SECTORS/TRACK | | 18M<br>ORGS | Personal Computer MACRO | Assemble<br>BILITY MO | er Version 2.00<br>DOULE | 1-9<br>04-21-86 | |--------------------------|--------------------------------------------------|-----------------------|--------------------------------|-----------------------------------------------------| | 839<br>840<br>841 | | PAGE | DRIVE TYPE 39 | *** RESERVED*** | | 842 | 0661 0000 | • | DW 0000D | ; CYLINDERS | | 843<br>844<br>845 | 0663 00<br>0664 0000<br>0666 0000 | | DB 00D<br>DW 0<br>DW 0000D | : HEADS<br>: WRITE PRE-COMPENSATION CYL | | 846<br>847<br>848<br>849 | 0668 00<br>0669 00 | | DB 0<br>DB 0 | ; CONTROL BYTE | | 848<br>849 | 066A 00 00 00<br>066D 0000<br>066F 00 | | DB 0,0,0<br>DW 0000D<br>DB 00D | ; LANDING ZONE | | 850<br>851<br>852 | 066F 00<br>0670 00 | | DB 0 | ; SECTORS/TRACK | | 853<br>854 | | 1 | DRIVE TYPE 40 | *** RESERVED*** | | 855<br>856<br>857 | 0671 0000<br>0673 00<br>0674 0000<br>0676 0000 | | DW 0000D<br>DB 00D<br>DW 0 | ; CYLINDERS<br>; HEADS | | 858<br>869 | 0678 00 | | DW 0000D<br>DB 0 | ; WRITE PRE-COMPENSATION CYL | | 860<br>861<br>862 | 0679 00<br>067A 00 00 00<br>067D 0000 | | DB 0,0,0<br>DW 0000D | ; CONTROL BYTE<br>: LANDING ZONE | | 863 | 067F 00<br>0680 00 | | DB 00D<br>DB 0 | \$ LANDING ZONE<br>\$ SECTORS/TRACK | | 865<br>865 | | , | DRIVE TYPE 41 | *** RESERVED*** | | 867<br>868<br>869 | 0681 0000<br>0683 00 | | DW 0000D<br>DB 00D | ; CYLINDERS<br>; HEADS | | 870<br>871<br>872 | 0684 0000<br>0686 0000<br>0688 00 | | DW 0000D | # WRITE PRE-COMPENSATION CYL | | 873 | 0689 00 | | DB 0 | 3 CONTROL BYTE | | 874<br>876<br>876 | 068A 00 00 00<br>068D 0000<br>068F 00<br>0690 00 | | DW 0000D<br>DB 00D<br>DB 0 | ; LANDING ZONE<br>; SECTORS/TRACK | | 877<br>878<br>879 | 0690 00 | 1 | DRIVE TYPE 42 | *** RESERVED*** | | 880<br>881<br>882 | 0691 0000<br>0693 00 | · | DW 0000D | ; CYLINDERS | | 883<br>884 | 0694 0000<br>0696 0000 | | DB 00D<br>DW 0000D<br>DB 0 | ; HEADS<br>; WRITE PRE-COMPENSATION CYL | | 885<br>886 | 0698 00<br>0699 00 | | DB 0 | ; CONTROL BYTE | | 887<br>888<br>889 | 069A 00 00 00<br>069D 0000<br>069F 00 | | DB 0,0,0<br>DW 0000D<br>DB 00D | ; LANDING ZONE<br>; SECTORS/TRACK | | 890 | 06A0 00 | | DB 0 DRIVE TYPE 43 | *** RESERVED*** | | 891<br>892<br>893<br>894 | 06A1 0000 | ; | DW 0000D | ; CYLINDERS | | 894<br>895<br>896 | 06A1 0000<br>06A3 00<br>06A4 0000 | | DB 00D<br>DW 0 | ; HEADS<br>; WRITE PRE-COMPENSATION CYL | | 897<br>898<br>899 | 06A6 0000<br>06A8 00<br>06A9 00 | | DB 0 | : CONTROL BYTE | | 900<br>901 | 06A9 00<br>06AA 00 00 00<br>06AD 0000 | | DB 0,0,0<br>DW 0000D | # LANDING ZONE<br># SECTORS/TRACK | | 902<br>903<br>904<br>905 | 06AF 00<br>06B0 00 | | DB 0 | | | 906 | | , | DRIVE TYPE 44 | *** RESERVED*** | | 907<br>908<br>909 | 0681 0000<br>0683 00<br>0684 0000<br>0686 0000 | | DW 0000D<br>DW 0<br>DW 0 | ; CYLINDERS<br>; HEADS | | 910<br>911 | 06B8 00 | | DW 0000D<br>DB 0<br>DB 0 | : WRITE PRE-COMPENSATION CYL | | 912<br>913<br>914 | 06B9 00<br>06BA 00 00 00<br>06BD 0000<br>06BF 00 | | DB 0.0.0<br>DW 0000D | ; CONTROL BYTE<br>; LANDING ZONE<br>; SECTORS/TRACK | | 915<br>916 | 06BF 00<br>06C0 00 | | DB 00D | : SECTORS/TRACK | | 917<br>918<br>919 | | 3 | DRIVE TYPE 45 | *** RESERVED*** | | 920<br>921<br>922 | 06C1 0000<br>06C3 00<br>06C4 0000 | | DB 000D<br>DW 0 | : CYLINDERS<br>: MEADS | | 923 | 0404 0000 | | DW COOOD<br>DB 0 | # WRITE PRE-COMPENSATION CYL | | 925<br>926<br>927 | 06CB 00<br>06CP 00<br>06CA 00 00<br>06CD 0000 | | DB 0.0.0<br>DW 0000D | : CONTROL BYTE | | 928<br>929 | 06CF 00<br>06D0 00 | | DB 00D<br>DB 0 | ; LANDING ZONE<br>; SECTORS/TRACK | | 930<br>931<br>932 | | 1 | DRIVE TYPE 46 | *** RESERVED*** | | 933<br>934 | 06D1 0000<br>06D3 00 | | DW 0000D<br>DB 00D | ; CYLINDERS<br>; HEADS | | 935<br>936<br>937 | 04D4 0000<br>04D6 0000<br>06D8 00 | | DW 0 | ; WRITE PRE-COMPENSATION CYL | | 938<br>939 | 06D8 00<br>06D9 00<br>06DA 00 00 00<br>06DD 0000 | | DB 0,0,0 | ; CONTROL BYTE | | 940<br>941 | 06DF 00 | | DW 0000D<br>DB 00D | : LANDING ZONE<br>; SECTORS/TRACK | | 942 | 06E0 00 | | DB 0 | | ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-12 04-21-86 PAGE :---- DISKETTE I/O FF ORG ORG ORG DISKETTE 10 0EC59H 00C59H EQU $ DISKETTE_IO_1 1113 1114 0C6> 1114 0C6> 1115 1116 1116 1116 1117 1117 0F67 1120 = 0F67 1121 0F67 E9 0000 E I VECTOR ON TO MOVED DISKETTE CODE ---- DISKETTE INTERRUPT II- ORG ORG DISK_INT OEF57H OOF57H EQU $ DISK_INT_1 ; VECTOR ON TO MOVED DISKETTE HANDLER ;---- DISKETTE PARAMETERS ORG OFFCTH DISK BASE THIS IS THE SET OF PARAMETERS REQUIRED FOR DISKETTE OPERATION. THEY ARE POINTED AT BY THE DATA VARIABLE POISK POINTER. TO MODIFY THE PARAMETERS, I BUILD ANOTHER PARAMETER BLOCK AND POINT AT IT : SRT=D, HO UNLOAD=OF - IST SPECIFY BYTE : HO LOAD=1, MODE=DMA - 2ND SPECIFY BYTE : WAIT TIME AFTER OPERATION TILL MOTOR OFF : 512 BYTES/SECTOR : GAP LENGTH : DTL : GAP LENGTH : DTL : GAP LENGTH FOR FORMAT : FILL BYTE FOR FORMAT : HEAD SETTLE TIME (MILLISECONDS) : MOTOR START TIME (1/8 SECONDS) 1101111118 2 MOTOR_WAIT 2 15 01BH 0FFH 054H 056H 15 1---- PRINTER 1/0 0EFD2H 00FD2H EQU $ PRINTER_IO_1 1 VECTOR ON TO MOVED PRINTER CODE FOR POSSIBLE COMPATIBILITY ENTRY POINTS ORG 0F045H ORG 01045H ASSUME CS:CODE,DS:DATA ASSUME CSTCODE, DSTDATA EXTRN EXTRN EXTRN EXTRN EXTCTYPE INEAR EXTRN EXTCTYPE INEAR EXTRN EXTCTYPE INEAR EXTRN EX OFFSET SET MODE OFFSET SET CTYPE WHITE AC CURRENT OFFSET WHITE AC CURRENT OFFSET WHITE AC CURRENT OFFSET WHITE AC CURRENT OFFSET WHITE AC CURRENT OFFSET WHITE AC CURRENT OFFSET WHITE TTY TABLE OF ROUTINES WITHIN YIDEO 1/O EXIT STACK VALUES MAY BE DIFFERENT DEPENDING ON THE SYSTEM AND MODEL 0F065H 01065H EQU $ VIDEO_10_1 II- ORG ORG VIDEO_10 JMP ; VECTOR ON TO MOVED VIDEO CODE :---- VIDEO PARAMETERS --- INIT_TABLE ORG ORG 0F0A4H 010A4H LABEL BYTE 38H,28H,2DH,0AH,1FH,6,19H VIDEO_PARMS DB ; SET UP FOR 40X25 1210 19 10 20 07 06 07 DB 1211 108B 1C 02 07 06 07 DB 1212 1080 00 00 00 00 M4 EQU 1214 1080 10 00 00 00 00 M4 EQU 1214 1215 1084 71 50 5A 0A 1F 06 DB 1216 100 00 00 00 00 DB 1218 10C0 00 00 00 00 DB 1218 10C0 00 00 00 00 DB 1218 10C0 10C4 38 28 20 0A 7F 06 DB 1221 64 1CH,2.7.6.7 0.0.0.0 $-VIDEO_PARMS 71H,50H,5AH,0AH,1FH,6,19H 1CH,2,7,6,7 0,0,0,0 ; SET UP FOR GRAPHICS 38H, 28H, 2DH, 0AH, 7FH, 6, 64H ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-13 70H,2,1,6,7 10D4 61 50 52 0F 19 06 DB 61H,50H,52H,0FH,19H,6,19H ; SET UP FOR SOXES BAW CARD 19H,2,0DH,0BH,0CH 0,0,0,0 TABLE OF REGEN LENGTHS 40X25 80X26 GRAPHICS 2048 4096 16384 16384 10EC 28 28 50 50 28 28 50 50 08 40,40,80,80,40,40,80,80 C REG TAB 10F4 2C 28 2D 29 2A 2E 1E 29 M7 08 2CH, 28H, 2DH, 29H, 2AH, 2EH, 1EH, 29H; TABLE OF MODE SETS MEMORY SIZE OF841H 01841H EQU $ MEMORY_SIZE_DET_1 ORG ORG RY_SIZE_DET JMP 2 VECTOR ON TO MOVED BIOS CODE -- EQUIPMENT DETERMINE 0F84DH 0184DH EQUIPMENT_: 1 VECTOR ON TO MOVED BIOS CODE 1255 1840 EY 0000 E 1256 1257 1258 1259 1260 1859 1261 = 1859 1262 1859 E9 0000 E 1263 CASSETTE (NO BIOS SUPPORT) 0F859H 01859H EQU $ CASSETTE_IO_1 II- ORG ORG CASSETTE 10 JMP I VECTOR ON TO MOVED BIOS CODE CHARACTER GENERATOR GRAPHICS FOR 320X200 AND 640X200 GRAPHICS OFA6EH 01A6EH LABEL BYTE 000H,000H,000H,000H,000H,000H,000H; D_00 SMILING FACE DB 07EH,0FFH,0DBH,0FFH,0C3H,0E7H,0FFH,07EH : D_02 SMILING FACE N 06CH, 0FEH, 0FEH, 0FEH, 07CH, 038H, 010H, 000H ; D_03 HEART DB 010H,038H,07CH,0FEH,07CH,038H,010H,000H ; D_04 DIAMOND DB 038H.07CH.038H.0FEH.0FEH.07CH.038H.07CH ; D_05 CLUB DB 010H,010H,038H,07CH,0FEH,07CH,038H,07CH ; D_06 SPADE DB 000H,000H,018H,03CH,03CH,018H,000H,000H ; D_07 BULLET DB BULLET NEG DB CIRCLE 000H,03CH,066H,042H,042H,066H,03CH,000H ; D_09 CIRCLE NEG DB 00FH,007H,00FH,07DH,0CCH,0CCH,0CCH,078H ; D_0B MALE 03CH,066H,066H,066H,03CH,018H,07EH,018H ; D_0C FEMALE EIGHTH NOTE 03FH.033H,03FH,030H.030H.070H,0F0H,0E0H ; D_0D 07FH.063H,07FH,063H,063H,067H,0E6H,0C0H ; D_0E TWO 1/16 NOTE DB 099H,05AH,03CH,0E7H,0E7H,03CH.05AH,099H ; D_0F 080H,0E0H,0F8H,0FEH,0F8H,0E0H,080H,000H 1 D_10 R ARROWHEAD 002H, 00EH, 03EH, 0FEH, 03EH, 00EH, 002H, 000H ; D_11 L ARROWHEAD ARROW 2 VERT 018H,03CH,07EH,018H,018H,07EH,03CH,018H ; D_12 DB 066H, 066H, 066H, 066H, 066H, 000H, 066H, 000H : D 13 2 EXCLAMATIONS DB 07FH, 0DBH, 0DBH, 07BH, 01BH, 01BH, 01BH, 000H ; D_14 PARAGRAPH SECTION DB 03EH,063H,038H,06CH,06CH,038H,0CCH,078H ; D_15 SECTION DB RECTANGLE 018H,03CH,07EH,018H,07EH,03CH,018H,0FFH ; D_17 018H,03CH,07EH,018H,018H,018H,018H,000H ; D_18 ARROW VRT UP G 018H,018H,018H,018H,07EH,03CH,018H,000H ; D_19 ARROW VRT DOWN DB ARROW RIGHT 000H,018H,00CH,0FEH,00CH,018H,000H,000H ; D_1A DB 000H,030H,060H,0FEH,060H,030H,000H,000H : D_18 ARROW LEFT DB 000H,000H,0C0H,0C0H,0C0H,0FEH,000H,000H : D_1C NOT INVERTED DB 000H,024H,066H,0FFH,066H,024H,000H,000H ; D_1D ARROW 2 HORZ 000H,018H,03CH,07EH,0FFH,0FFH,000H,000H ; D_1E ARROWHEAD UP ARROWHEAD DOWN 000H,0FFH,0FFH,07EH,03CH,018H,000H,000H ; D_1F ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 ORGS ---- 04/21/86 COMPATIBILITY MODULE 1-15 осен,осен,оесн,озан,озан,оесн,осен,ооон ; D_58 X оссн,оссн,оссн,отан,озон,озон,отан,озон ; D_59 Y OFEH, OC6H, O8CH, 018H, 032H, 066H, 0FEH, 000H ; D_5A Z DB DB 078H,060H,060H,060H,060H,078H,000H ; D_5B [ LEFT BRACKET DB 0C0H,060H,030H,018H,00CH,006H,002H,000H : D 5C $ BACKSLASH DB 078H,018H,018H,018H,018H,018H,078H,000H ; D_5D ] RIGHT BRACKET DB 010H,038H,06CH,0C6H,000H,000H,000H; D_5E $ CIRCUMFLEX DB 000H,000H,000H,000H,000H,000H,0FFH ; D_5F _ UNDERSCORE 030H.030H.018H.000H.000H.000H.000H.000H : D 60 * APOSTROPHE REV DB DB 000H,000H,078H,00CH,07CH,0CCH,076H,000H ; D 61 a DB 0E0H,060H,060H,07CH,066H,066H,0DCH,000H ; D_62 b 000H,000H,078H,0CCH,0CCH,0CCH,078H,000H ; D_63 c DB DB 01CH,00CH,00CH,07CH,0CCH,07CH,076H,000H; D 64 d DB 000H.000H.078H.0CCH.0FCH.0C0H.078H.000H : D 65 e DB 038H.06CH.060H.0F0H.060H.060H.0F0H.000H : D 66 f DB 000H,000H,076H,0CCH,0CCH,07CH,00CH,0F8H : D_67 g OEOH, 060H, 06CH, 076H, 066H, 066H, 0E6H, 000H ; D_68 030H,000H,070H,030H,030H,078H,000H ; D_69 ; 00СН,000Н,00СН,00СН,00СН,0ССН,0ССН,078Н ; D_6A ј 0E0H,060H,066H,06CH,078H,06CH,0E6H,000H ; D_68 k 070H,030H,030H,030H,030H,078H,000H ; D_6C I DB 000H,000H,0CCH,0FEH,0FEH,0D6H,0C6H,000H ; D_6D m DB 000H,000H,0F8H,0CCH,0CCH,0CCH,0CCH,000H ; D 6E n DB DB 000H.000H.078H.0CCH.0CCH.0CCH.078H.000H : D 6F o 000H,000H,0DCH,066H,066H,07CH,060H,0F0H ; D_70 p DB 000H,000H,076H,0CCH,0CCH,07CH,00CH,01EH ; D 71 q DB 000H.000H.0DCH.076H.066H.060H.0F0H.000H : D 72 r DB DB 000H,000H,07CH,0C0H,078H,00CH,0F8H,000H ; D_T3 a DB 010H,030H,07CH,030H,030H,034H,018H,000H ; D 74 t DB 000H,000H,0CCH,0CCH,0CCH,076H,000H : D_75 u DB 000H,000H,0CCH,0CCH,0CCH,078H,030H,000H : D_76 v 000H,000H,0C6H,0D6H,0FEH,0FEH,06CH,000H : D_77 w 000H,000H,0C6H,06CH,038H,06CH,0C6H,000H ; D_78 x 000H,000H,0CCH,0CCH,0CCH,07CH,00CH,0F8H ; D_79 y DB 000H,000H,0FCH,098H,030H,064H,0FCH,000H ; D_TA z DB 01CH,030H,030H,0E0H,030H,030H,01CH,000H : D 78 & LEFT BRACE DΒ DB 018H.018H.018H.000H.018H.018H.018H.000H : D 7C | BROKEN STROKE 08 OEOH, 030H, 030H, 01CH, 030H, 030H, 0E0H, 000H ; D_TD } RIGHT BRACE DB 076H, 0DCH, 000H, 000H, 000H, 000H, 000H ; D_TE $ TILDE DB 000H,010H,038H,06CH,0C6H,0C6H,0FEH,000H ; D_7F :---- TIME OF DAY ##- ORG ORG TIME_OF_DAY JMP EQU $ TIME_OF_DAY_1 ; VECTOR ON TO MOVED BIOS CODE :---- TIMER INTERRUPT .. ORG ORG TIMER_INT OFEA5H 01EA5H EQU $ TIMER_INT_1 ; VECTOR ON TO MOVED BIOS CODE ``` # **SECTION 6. INSTRUCTION SET** | 80286 Instruction Set | . 6-3 | |-----------------------------------|-------| | Data Transfer | 6-3 | | Arithmetic | 6-6 | | Logic | 6-9 | | String Manipulation | 6-11 | | Control Transfer | 6-13 | | Processor Control | 6-17 | | Protection Control | 6-18 | | 80287 Coprocessor Instruction Set | 6-22 | | Data Transfer | 6-22 | | Comparison | 6-23 | | Constants | | | Arithmetic | 6-25 | | Transcendental | 6-26 | # **80286 Instruction Set** # **Data Transfer** #### MOV = move Register to Register/Memory 1000100w mod reg r/w Register/Memory to Register 1000101w mod reg r/w Immediate to Register/Memory 1100011w mod 000 r/w data data if w = 1 Immediate to Register 1011wreg data data if w = 1 Memory to Accumulator 1010000w addr-low addr-high Accumulator to Memory 1010001w addr-low addr-high Register/Memory to Segment Register 10001110 mod0reg r/w reg ≠ 01 Segment Register to Register/Memory 10001100 mod0reg r/w #### PUSH = Push Memory 11111111 mod110 r/w Register 01010reg Segment Register 000reg110 Immediate 011010s0 data data if s = 0PUSHA = Push All 01100000 POP = PopMemory 10001111 mod000 r/m Register 01011reg Segment Register 000reg111 reg ≠ 01 POPA = Pop All01100001 XCHG = Exchange Register/Memory with Register 1000011w mod reg r/m Register with Accumulator 10010reg #### 6-4 Instruction Set 10011110 #### **PUSHF** = **Push Flags** 10011100 #### **POPF** = **Pop** Flags 10011101 # **Arithmetic** #### ADD = Add Register/Memory with Register to Either | 0000000w | mod reg r/m | |----------|-------------| Immediate to Register Memory | 100000sw | mod000 r/m | data | data if sw = 01 | |----------|------------|------|-----------------| | £ | | | | Immediate to Accumulator | 0000010w | data | data if w = 1 | |-----------|------|---------------| | 000001011 | | | #### ADC = Add with Carry Register/Memory with Register to Either | , | | | |---|----------|-------------| | ı | 000100dw | mod reg r/m | Immediate to Register/Memory | 100000sw | mod000 r/m | data | data if sw = 01 | |----------|------------|------|-----------------| Immediate to Accumulator | 0001010w | data | data if w = 1 | | |----------|------|---------------|--| #### INC = Increment Register/Memory | 1111111w | mod000 r/m | |----------|------------| #### 6-6 Instruction Set | - 1 | | | |-----|----------|----------------| | И | | 1004 | | 3 | 1111111w | mod001 r/m | | | | 11100001 17111 | | u | | 1 | Register 01001reg #### CMP = Compare Register/Memory with Register | 0011101w | mod reg r/m | |----------|-------------| | | | #### Register with Register/Memory | | | <br> | | |----------|-------------|------|--| | 0011100w | mod reg r/m | | | #### Immediate with Register/Memory | 100000sw | mod111 r/m | data | data if sw = 01 | |----------|------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | The state of s | #### Immediate with Accumulator | 0001110w | data | data if w = 1 | |----------|------|---------------| #### NEG = Change Sign | 1111011w | mod011 | r/m | | |----------|--------|-----|---| | _ | | | 1 | #### AAA = ASCII Adjust for Add 00110111 #### DAA = Decimal Adjust for Add 00100111 #### **AAS = ASCII Adjust for Subtract** 00111111 #### DAS = Decimal Adjust for Subtract 00110111 #### MUL = Multiply (Unsigned) | 1111011w | mod 100 | r/m | |----------|---------|-----| # IMUL = Integer Multiply (Signed) | | | <br><del></del> | |----------|------------|-----------------| | 1111011w | mod101 r/m | | ### IIMUL = Integer Immediate Multiply (Signed) | 011010s1 | mod reg r/m | Data | Data if s = 0 | |----------|-------------|------|---------------| | | | | | #### DIV = Divide (Unsigned) | 1111011w | mod110 | r/m | |----------|--------|-----------------------------------------| | 1 | | • • • • • • • • • • • • • • • • • • • • | ### IDIV = Integer Divide (Signed) | 1111011w | mod111 r/m | | |----------|------------|--| #### AAM = ASCII Adjust for Multiply | | | _ | |----------|----------|---| | 444444 | | | | 11010100 | 00001010 | 1 | | | | 1 | | | | | #### AAD = ASCII Adjust for Divide | 11010101 | 00001010 | |-----------|----------| | 1 1010101 | | | 1 | 1 | #### **CBW** = Convert Byte to Word 10011000 #### **CWD** = Convert Word to Double Word 10011001 # Logic #### Shift/Rotate Instructions Register/Memory by 1 | 1101000w | mod TTT r/m | | |----------|-------------|--| | | | | Register/Memory by CL | | l 1101001w l | mod TTT r/m | |-----|---------------|---------------------| | | . 11n1nn1w ! | mod TTT r/m | | | i iluluulwi i | 1 1110U 111 17111 I | | - 1 | | | Register/Memory by Count | 1 | | | <del></del> | |---|----------|-------------|-------------| | | 1100000w | mod TTT r/m | count | | TTT | Instruction | |------------|-------------| | 000 | ROL | | 001 | ROR<br>RCL | | 011 | RCR | | 100 | SHL/SAL | | 101<br>111 | SHR<br>SAR | #### AND = And Register/Memory and Register to Either | 001000dw | mod reg r/m | |----------|----------------------| | Immediat | e to Register/Memory | | 1000000w | mod000 r/m | data | data if w = 1 | | |----------|------------|------|---------------|--| | | | | | | #### Immediate to Accumulator | 0010010w | data | data if w = 1 | |----------|------|---------------| | | | | # TEST = AND Function to Flags; No Result Register/Memory and Register | 1 | | | |---|----------|-------------| | | 1000010w | mod reg r/m | #### Immediate Data and Register/Memory | 1111011w | mod000 r/m | data | data if w = 1 | |----------|------------|------|---------------| #### Immediate to Accumulator | 0000110w | data | data if w = 1 | |----------|------|---------------| | 0000110# | 4414 | 40L0 11 W 1 | #### Or = Or Register/Memory and Register to Either | 000010dw | mod reg r/m | | |----------|-------------|--| #### Immediate to Register/Memory | 1000000w | mod001 r/m | data | data if w = 1 | |----------|------------|------|---------------| | | | | | ### 6-10 Instruction Set #### Immediate to Accumulator | 0000110w | data | data if w = 1 | |----------|------|---------------| #### XOR = Exclusive OR Register/Memory and Register to Either | 0011004. | | | |----------|-------------|--| | 001100dw | mod reg r/m | | | | | | #### Immediate to Register/Memory | 1000000w | mod110 r/m | data | data if w = 1 | |----------|------------|------|---------------| #### Immediate to Accumulator | | | · · · · · · · · · · · · · · · · · · · | |----------|------|---------------------------------------| | 0010010w | data | data if w = 1 | #### **NOT** = Invert Register/Memory | 1111011w | mod010 r/m | |----------|------------| # **String Manipulation** #### MOVS = Move Byte Word 1010010w #### CMPS = Compare Byte Word 1010011w #### SCAS = Scan Byte Word 1010111w #### LODS = Load Byte Word to AL/AX 1010110w | 1010101w | | |--------------|----------------------------| | | | | NS = Input B | yte from DX Port | | 0110110w | | | | | | OUTS = Outp | out Byte Word to DX Port | | 0110111w | | | | | | EP/REPNE, | REPZ/REPNZ = Repeat String | | Repeat | Move String | | 11110011 | 1010010w | | Repeat | Compare String (z/Not z) | | 1111001z | 1010011w | | Repeat | Scan String (z/Not z) | | 1111001z | 1010111w | | Repeat | Load String | | 11110011 | 1010110w | | Repeat | Store String | | 11110011 | 1010101w | | Repeat | Input String | | 11110011 | 0110110w | | Repeat | Output String | 11110011 1010011w # **Control Transfer** #### CALL = Call Direct Within Segment | 11101000 | disp-low | disp-high | |----------|----------|-----------| | | | | Register/Memory Indirect Within Segment 11111111 mod010 r/m Direct Intersegment | 10011010 | Segment Offset | Segment Selector | |----------|-----------------|------------------| | Indire | ct Intersegment | | | 11111111 | mod011 r/m (mod | l ≠ 11) | # JMP = Unconditional Jump Short/Long | | | <br> | |----------|----------|------| | 11101011 | disp-low | | Direct within Segment | 11101001 | disp-low | disp-high | |----------|----------|-----------| Register/Memory Indirect Within Segment 11111111 mod100 r/m Direct Intersegment | ſ | 11101010 | Segment Offset | Segment Selector | |---|----------|----------------|------------------| | | | | | Indirect Intersegment | 11111111 | mod101 r/m (mod ≠ 11) | |----------|---------------------------| | , | 110010117111 (11100 7 117 | | | | #### **RET** = **Return from Call** Within Segment 11000011 #### Within Segment Adding Immediate to SP | 11000010 data-low | data-high | |-------------------|-----------| |-------------------|-----------| #### Intersegment | | <br> | <br> | | |----------|------|------|---| | 11001011 | | | 1 | #### Intersegment Adding Immediate to SP | 11001010 | data-low | data-high | |----------|----------|-----------| #### JE/JZ = Jump on Equal/Zero | - 1 | <del></del> | | | |-----|-------------|------|--| | | 01110100 | disp | | #### JL/JNGE = Jump on Less/Not Greater, or Equal | <del></del> | | <br> | |-------------|------|------| | 01111100 | disp | l | # JLE/JNG = Jump on Less, or Equal/Not Greater | 1 01111110 | disp | |------------|------| | | 2.36 | #### JB/JNAE = Jump on Below/Not Above, or Equal | 01110010 | disp | |----------|------| #### JBE/JNA = Jump on Below, or Equal/Not Above | 01110110 | disp | | |----------|------|--| #### JP/JPE = Jump on Parity/Parity Even | 01111010 | disp | | |----------|------|--| #### JO = Jump on Overflow | 01110000 | disp | | |----------|------|--| #### JS = Jump on Sign | • | • | |----------|------| | | | | 01111000 | disp | #### 6-14 Instruction Set | JNE/JNZ = Jump on Not Equal/Not Zero | JNE/JNZ : | = Jump | on Not | Equal/ | Not Zero | |--------------------------------------|-----------|--------|--------|--------|----------| |--------------------------------------|-----------|--------|--------|--------|----------| | 01110101 | disp | |----------|------| # JNL/JGE = Jump on Not Less/Greater, or Equal | | | <br> | | |----------|------|------|--| | 01111101 | disp | | | #### JNLE/JG = Jump on Not Less, or Equal/Greater | 01111111 | disp | | | | |----------|------|--|--|--| #### JNB/JAE = Jump on Not Below/Above, or Equal | | | | <br> | <br> | | |---|----------|------|------|------|--| | ĺ | 01110011 | disp | | | | | | | | | | | #### JNBE/JA = Jump on Not Below, or Equal/Above | | | <br> | <br> | | |----------|------|------|------|--| | 01110111 | disp | | | | #### JNP/JPO = Jump on Not Parity/Parity Odd | | | <br> | <br> | |----------|--------|------|------| | | 1 | | | | 01111011 | disp | | | | 01111011 | 1 4136 | | | | | 1 | | | #### JNO = Jump on Not Overflow | 01110001 | disp | |----------|------| | | | #### JNS = Jump on Not Sign | 01111011 | disp | |----------|------| #### LOOP = Loop CX Times | ı | | | <br> | <br> | |---|----------|------|------|------| | | 11100010 | disp | | | #### LOOPZ/LOOPE = Loop while Zero/Equal | 11100001 | disp | |----------|------| # LOOPNZ/LOOPNE = Loop while Not Zero/Not Equal | 11100000 | disp | | | |----------|------|--|--| | | | | | #### JCXZ = Jump on CX Zero | | | <br> | <br>_ | |----------|------|------|-------| | 11100011 | disp | | | | | | | | #### **ENTER** = **Enter Procedure** | 11001000 | data-low | data-high | |----------|----------|-----------| #### **LEAVE** = Leave Procedure 11001001 ### INT = Interrupt Type Specified | | _ | |------------|--------| | 11001101 | Type | | 1 11001101 | l lype | | 1 | · · | | | | Type 3 11001100 #### **INTO** = Interrupt on Overflow 11001110 ### IRET = Interrupt Return 11001111 #### **BOUND** = Detect Value Out of Range | 01100010 | mod reg r/m | | |----------|-------------|--| | | | | # **Processor Control** | 11111000 | | |----------------------------------------------------------------------------|---------------------------------------| | CMC = Complement Carry | | | 11110101 | | | STC = Set Carry | | | 11111001 | | | CLD = Clear Direction | | | 11111100 | | | STD = Set Direction | | | 11111101 | · · · · · · · · · · · · · · · · · · · | | CLI Clear Interrupt | | | 11111010 | · · · · · · · · · · · · · · · · · · · | | 11111010 | · · · · · · · · · · · · · · · · · · · | | 11111010 | | | 11111010 STI = Set Interrupt 11111011 | | | 11111010 STI = Set Interrupt 11111011 | | | 11111010 STI = Set Interrupt 11111011 HLT = Halt 11110100 | | | 11111010 STI = Set Interrupt 11111011 HLT = Halt | | | 11111010 STI = Set Interrupt 11111011 HLT = Halt 11110100 WAIT = Wait | | #### CTS = Clear Task Switched Flag | 00001111 | 00000110 | |----------|----------| #### **ESC** = **Processor** Extension Escape | _ | | | |----|----------|------------| | ı | 11011TTT | modLLL r/m | | -1 | | 1 | ### **Protection Control** #### **LGDT** = Load Global Descriptor Table Register | 00001111 | 00000001 | mod010 r/m | |----------|----------|----------------| | 00001111 | 0000001 | 11100010 17111 | #### **SGDT** = Store Global Descriptor Table Register | 00001111 | 00000001 | mod000 r/m | |------------|----------|----------------| | 1 00001111 | 0000001 | 11100000 17111 | #### **LIDT** = Load Interrupt Descriptor Table Register | 00001111 | 00000001 | mod011 r/m | |----------|----------|------------| | | | | #### **SIDT** = Store Interrupt Descriptor Table Register | 00001111 | 00000001 | mod001 r/m | |----------|----------|------------| # LLDT = Load Local Descriptor Table Register from Register/Memory | 0 | 0001111 | 00000000 | mod010 r/m | |---|---------|----------|------------| # **SLDT** = Store Local Descriptor Table Register from Register/Memory | _ | | | | |---|----------|----------|------------| | 1 | 00001111 | 00000000 | mod000 r/m | #### LTR = Load Task Register from Register/Memory | 1 | 00001111 | 00000000 | mod011 r/m | |---|----------|----------|------------| | i | 00001111 | 00000000 | mod011 r/m | #### STR = Store Task Register to Register/Memory | 00001111 | 00000000 | mod001 r/m | |----------|----------|------------| | | | | # LMSW = Load Machine Status Word from Register/Memory | 00001111 | 00000001 | mod110 r/m | |----------|----------|---------------| | 00001111 | 00000001 | 1110011017111 | #### SMSW = Store Machine Status Word | 00001111 | 00000001 | mod100 r/m | |----------|----------|------------| #### LAR = Load Access Rights from Register/Memory | 00001111 | 00000010 | mod reg r/m | | | |----------|----------|-------------|--|--| #### LSL = Load Segment Limit from Register/Memory | 00001111 | 00000011 | mod reg r/m | |----------|----------|-------------| ### ARPL = Adjust Requested Privilege Level from Register/Memory | | 01100011 | mod reg r/m | |---|----------|-------------| | 1 | | | # VERR = Verify Read Access; Register/Memory | 00001111 | 00000000 | mod100 r/m | |----------|----------|------------| #### **VERR** = Verify Write Access | 00001111 | 00000000 | mod101 r/m | |----------|----------|------------| The effective address (EA) of the memory operand is computed according to the mod and r/m fields: If mod = 00, then disp = 0, disp-low and disp-high are ``` absent. If mod = 01, then disp = disp-low sign-extended to 16 bits, disp-high is absent. If mod = 10, then disp = disp-high:disp-low. If r/m = 000, then EA = (BX) + (SI) + DISP If r/m = 001, then EA = (BX) + (SI) + DISP If r/m = 010, then EA = (BP) + (SI) + DISP If r/m = 011, then EA = (BP) + (DI) + DISP If r/m = 100, then EA = (SI) + DISP If r/m = 101, then EA = (DI) + DISP If r/m = 101, then EA = (BP) + DISP If r/m = 110, then EA = (BP) + DISP If r/m = 111, then EA = (BX) + DISP ``` If mod = 11, then r/m is treated as a reg field. DISP follows the second byte of the instruction (before data if required). Note: An exception to the above statements occurs when mod=00 and r/m=110, in which case EA = disp-high; disp-low. #### **Segment Override Prefix** 001reg001 The 2-bit and 3-bit reg fields are defined as follows: 2-Bit reg Field | reg | Segment Register | reg | Segment Register | |-----|------------------|-----|------------------| | 00 | ES | 10 | SS | | 01 | CS | 11 | DS | 3-Bit reg Field | 16-bit (w = 1) | 8-bit (w = 0) | |----------------|---------------| | 000 AX | 000 AL | | 001 CX | 001 CL | | 010 DX | 010 DL | | 011 BX | 011 BL | | 100 SP | 100 AH | | 101 BP | 101 CH | | 110 SI | 110 DH | | 111 DI | 111 BH | The physical addresses of all operands addressed by the BP register are computed using the SS segment register. The physical addresses of the destination operands of the string primitive operations (those addressed by the DI register) are computed using the ES segment, which may not be overridden. # **80287 Coprocessor Instruction Set** The following is an instruction set summary for the 80287 coprocessor. In the following, the bit pattern for escape is 11011. # **Data Transfer** #### FLD = Load Integer/Real Memory to ST(0) | escape MF 1 mod 000 r/m | | |-------------------------|--| Long Integer Memory to ST(0) | escape 111 | mod 101 r/m | |------------|-------------| | | | Temporary Real Memory to ST(0) | escape 011 | mod 101 r/m | | |------------|-------------|--| | | | | BCD Memory to ST(0) | 111 | mod 100 r/m | | |------------|-------------|--| | escape 111 | mod 100 F/m | | ST(i) to ST(0) | escape 001 | 11000ST(i) | ٦ | |------------|------------|---| | | | | #### FST = Store ST(0) to Integer/Real Memory | ME 1 | mad 010 m/m | | |-------------|-------------|--| | escape MF 1 | mod 010 r/m | | ST(0) to ST(i) | escape 101 | 11010 ST(i) | |------------|-------------| #### **FSTP** = Store and Pop ST(0) to integer/Real Memory | escape MF 1 | mod 011 | r/m | | |-------------|---------|-----|--| #### 6-22 Instruction Set escape 111 mod 111 r/m ST(0) to Temporary Real Memory escape 011 mod 111 r/m ST(0) to BCD Memory escape 111 | mod 110 r/m ST(0) to ST(i) #### FXCH = Exchange ST(i) and ST(0) escape 001 | 11001 ST(i) # **Comparison** #### FCOM = Compare Integer/Real Memory to ST(0) escape MF 0 mod 010 r/m ST(i) to ST(0) escape 000 | 11010 ST(i) #### FCOMP = Compare and Pop Integer/Real Memory to ST(0) escape MF 0 | mod 011 r/m ST(i) to ST(0) escape 000 11010 ST(i) #### FCOMPP = Compare ST(i) to ST(0) and Pop Twice | escape 110 | 11011001 | <br> | | |------------|----------|------|--| # FTST = Test ST(0) | | | <br> | | |------------|----------|------|--| | escape 001 | 11100100 | | | #### FXAM = Examine ST(0) | escape 001 | 11100101 | |------------|----------| | | | # **Constants** # FLDZ = Load + 0.0 into ST(0) | escape 000 | 11101110 | | | |------------|----------|--|--| #### FLD1 = Load + 1.0 into ST(0) | | | <br> | | |------------|----------|------|--| | escape 001 | 11101000 | | | #### FLDP1 = Load $\pi$ into ST(0) | | | <br> | |------------|----------|------| | escape 001 | 11101011 | | # $FLDL2T = Load log_2 10 into ST(0)$ | escape 001 | 11101001 | | |------------|----------|--| | | | | # $FLDLG2 = Load log_{10} 2 into ST(0)$ | F | | <br> | | |------------|----------|------|--| | escape 001 | 11101100 | | | | I | | <br> | | ### $FLDLN2 = Load log_e 2 into ST(0)$ | escape 001 | 11101101 | | |------------|----------|--| | | | | # **Arithmetic** #### FADD = Addition Integer/Real Memory with ST(0) | escape MF 0 | mod 000 r/m | | |-------------|-------------|--| | | | | ST(i) and ST(0) | escape dPO | 11000 ST( | 1) | |------------|-----------|----| #### FSUB = Subtraction Integer/Real Memory with ST(0) | escape MF 0 | mod 10R r/m | <br> | | |-------------|-------------|------|--| | | | | | ST(i) and ST(0) | | | <br> | | |------------|-----------|------|--| | | | | | | escape dPO | 1110R r/m | | | #### FMUL = Multiplication Integer/Real Memory with ST(0) | escape MF 0 | mod 001 r/m | |-------------|-------------| ST(i) and ST(0) | | | , , , | |------------|-----------|-------| | escape dPO | 11001 r/m | | ### FDIV = Division Integer/Real Memory with ST(0) | escape MF 0 | mod 11R r/m | | |-------------|-------------|--| ST(i) and ST(0) | escape dPO | 1111R r/m | | |------------|-----------|--| #### FSQRT = Square Root of ST(0) | escape 001 | 11111010 | | |------------|----------|--| #### FSCALE = Scale ST(0)by ST(1) | escape 001 | 11111101 | |------------|----------| | | | #### FPREM = Partial Remainder of ST(0) + ST(1) | escape 001 | 11111000 | |------------|----------| #### FRNDINT = Round ST(0) to Integer | escape 001 | 11111100 | |------------|----------| #### FXTRACT = Extract Components of ST(0) | escape 001 | 11110100 | | | |------------|----------|--|--| #### FABS = Absolute Value of ST(0) | escape 001 | 11100001 | | ĺ | |------------|----------|--|---| #### FCHS = Change Sign of ST(0) | 1 | | <del></del> | <br> | | |---|------------|-------------|------|--| | ı | escape 001 | 11100000 | | | # **Transcendental** #### FPTAN = Partial Tangent of ST(0) | escape 001 | 11110010 | |------------|----------| #### $FPATAN = Partial Arctangent of ST(0) \div ST(1)$ | | | <br> | | |------------|----------|------|--| | escape 001 | 11110011 | | | #### $F2XM1 = 2^{ST(0)} - 1$ | escape 001 | 11110000 | |------------|----------| # $FYL2X = ST(1) \times Log_2 [ST(0)]$ | escape 001 | 11110001 | |------------|----------| | | | #### 6-26 Instruction Set ## $FYL2XP1 = ST(1) \times Log_2 [ST(0) + 1]$ | escape 001 | 11111001 | | |------------|----------|--| | | | | ## FINIT = Initialize NPX | escape 011 | 11100011 | ٦ | |------------|----------|---| | escape on | 11100011 | | ## **FSETPM** = Enter Protected Mode | escape 011 | 11100100 | | |------------|----------|--| ## **FSTSWAX** = Store Control Word | ١ | | | | |---|------------|----------|--| | | escape 111 | 11100000 | | ## FLDCW = Load Control Word | escape 001 | mod 101 r/m | | |------------|-------------|--| #### **FSTCW** = Store Control Word | escape 001 mod 111 r/m | |--------------------------| |--------------------------| #### **FSTSW** = Store Status Word | escape 101 | mod 101 r | /m | |------------|-----------|----| ## **FCLEX** = Clear Exceptions | escape 011 | 11100010 | | |------------|----------|--| ## **FSTENV** = Store Environment | escape 001 | mod 110 r/m | |------------|-------------| ## FLDENV = Load Environment | escape 001 | mod 100 r/m | | |------------|-------------|--| | <b>FSAVE</b> | = Save | State | |--------------|--------|-------| |--------------|--------|-------| | escape 101 | mod 110 r/m | | | |------------|-------------|--|--| | escape ioi | 11100 1711 | | | #### **FRSTOR** = **Restore** State | escape 101 | mod 100 r/m | |------------|-----------------| | escape ioi | lilod 100 17iii | ## **FINCSTP** = **Increment Stack Pointer** | | | <br> | $\neg$ | |------------|----------|------|--------| | escape 001 | 11110111 | | | ## FDECSTP = Decrement Stack Pointer | escape 001 | 111100110 | | | |------------|-----------|--|--| ## FFREE = Free ST(i) | escape 101 | 11000ST(i) | | | | |------------|------------|--|--|--| |------------|------------|--|--|--| ## FNOP = No Operation | escape 101 | 11010000 | | |------------|----------|------| | • | · · | <br> | ## MF is assigned as follows: | MF | Memory Format | |----|----------------| | 00 | 32-bit Real | | 01 | 32-bit Integer | | 10 | 64-bit Real | | 11 | 16-bit Integer | ## The other abbreviations are as follows: | | | Bit ≠ 0 | |-----------|--------------------------|-------------------------------------------------------| | Stack top | Stack top | (i)= ith register from | | | Dest. is ST(0)<br>No pop | the top<br>Dest. is ST(i)<br>Pop<br>Source (op) dest. | | | | Destination Dest. is ST(0) | ## **Notes:** # SECTION 7. CHARACTERS, KEYSTROKES, AND COLORS | Character Codes | <br>7-3 | |-----------------|----------| | Quick Reference | <br>7-14 | ## **Character Codes** | | | | | | | tes | | | |-----|-----|-----------------|---------------------------------------------|-------|-----------------------------------|------------------|------------------------------|--| | Val | lue | A | s Characters | | Color/Graphics<br>Monitor Adapter | | IBM<br>Monochrome<br>Display | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | 00 | 0 | Blank<br>(Null) | Ctrl 2 | | Black | Black | Non-Display | | | 01 | 1 | <b>©</b> | Čtrl A | | Black | Blue | Underline | | | 02 | 2 | • | Ctrl B | | Black | Green | Normal | | | 03 | 3 | * | Ctrl C | | Black | Cyan | Normal | | | 04 | 4 | <b>♦</b> | Ctrl D | | Black | Red | Normal | | | 05 | 5 | * | Ctrl E | | Black | Magenta | Normal | | | 06 | 6 | <b>^</b> | Ctrl F | | Black | Brown | Normal | | | 07 | 7 | • | Ctrl G | | Black | Light Grey | Normal | | | 08 | 8 | • | Ctrl H,<br>Backspace,<br>Shift<br>Backspace | | Black | Dark Grey | Non-Display | | | 09 | 9 | 0 | Ctrl I | | Black | Light Blue | High Intensity<br>Underline | | | OA | 10 | $\bigcirc$ | Ctrl J,<br>Ctrl | | Black | Light Green | High Intensity | | | ОВ | 11 | ď | Ctrl K | | Black | Light Cyan | High Intensity | | | ос | 12 | Ş | Ctrl L | | Black | Light Red | High Intensity | | | OD | 13 | \$ | Ctrl M,,<br>Shift | | Black | Light<br>Magenta | High Intensity | | | 0E | 14 | Ą | Ctrl N | | Black | Yellow | High Intensity | | | OF | 15 | ✡ | Ctrl O | | Black | White | High Intensity | | | 10 | 16 | <b>•</b> | Ctrl P | | Blue | Black | Normal | | | 11 | 17 | A | Ctrl Q | | Blue | Blue | Underline | | | 12 | 18 | 1 | Ctrl R | | Blue | Green | Normal | | | 13 | 19 | !! | Ctrl S | | Blue | Cyan | Normal | | | 14 | 20 | 9T | Ctrl T | | Blue | Red | Normal | | | 15 | 21 | § | Ctrl U | | Blue | Magenta | Normal | | | 16 | 22 | | Ctrl V | | Blue | Brown | Normal | | | 17 | 23 | 1 | Ctrl W | | Blue | Light Grey | Normal | | | | | | | | , | ites | | | |-----|-----|----------------|------------------------------------------------------------|--------|-----------------------------------|------------------|-----------------------------|--| | Va | lue | | s Characters | | Color/Graphics<br>Monitor Adapter | | | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | 18 | 24 | 1 | Ctrl X | | Blue | Dark Grey | High Intensity | | | 19 | 25 | 1 | Ctrl Y | | Blue | Light Blue | High Intensity<br>Underline | | | 1A | 26 | 1 | Ctrl Z | | Blue | Light Green | High Intensity | | | 1B | 27 | 1 | Ctrl [,<br>Esc, Shift<br>Esc, Crtl<br>Esc | | Blue | Light Cyan | High Intensity | | | 1C | 28 | _ | Ctrl \ | | Blue | Light Red | High Intensity | | | 1D | 29 | <b>-</b> | Ctrl ] | | Blue | Light<br>Magenta | High Intensity | | | 1E | 30 | | Ctrl 6 | | Blue | Yellow | High Intensity | | | 1F | 31 | ▼ | Ctrl — | | Blue | White | High Intensity | | | 20 | 32 | Blank<br>Space | Space Bar,<br>Shift,<br>Space,<br>Ctrl Space,<br>Alt Space | | Green | Black | Normal | | | 21 | 33 | ! | ! | Shift | Green | Blue | Underline | | | 22 | 34 | " | " | Shift | Green | Green | Normal | | | 23 | 35 | # | # | Shift | Green | Cyan | Normal | | | 24 | 36 | \$ | \$ | Shift | Green | Red | Normal | | | 25 | 37 | % | % | Shift | Green | Magenta | Normal | | | 26 | 38 | & | & | Shift | Green | Brown | Normal | | | 27 | 39 | , | , | | Green | Light Grey | Normal | | | 28 | 40 | ( | ( | Shift | Green | Dark Grey | High Intensity | | | 29 | 41 | ) | ) | Shift | Green | Light Blue | High Intensity<br>Underline | | | 2A | 42 | * | * | Note 1 | Green | Light Green | High Intensity | | | 2B | 43 | + | + | Shift | Green | Light Cyan | High Intensity | | | 2C | 44 | , | , | | Green | Light Red | High Intensity | | | 2D | 45 | _ | - | | Green | Light<br>Magenta | High Intensity | | | 2E | 46 | | • | Note 2 | Green | Yellow | High Intensity | | ## 7-4 Characters, Keystrokes, and Colors | | | | | | , | ıtes | | |-----|-----|--------|---------------|--------|------------|------------------------------|-----------------------------| | Va | lue | A | As Characters | · 1 | | IBM<br>Monochrome<br>Display | | | Нех | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | 2F | 47 | / | / | | Green | White | High Intensity | | 30 | 48 | 0 | 0 | Note 3 | Cyan | Black | Normal | | 31 | 49 | 1 | 1 | Note 3 | Cyan | Blue | Underline | | 32 | 50 | 2 | 2 | Note 3 | Cyan | Green | Normal | | 33 | 51 | 3 | 3 | Note 3 | Cyan | Cyan | Normal | | 34 | 52 | 4 | 4 | Note 3 | Cyan | Red | Normal | | 35 | 53 | 5 | 5 | Note 3 | Cyan | Magenta | Normal | | 36 | 54 | 6 | 6 | Note 3 | Cyan | Brown | Normal | | 37 | 55 | 7 | 7 | Note 3 | Cyan | Light Grey | Normal | | 38 | 56 | 8 | 8 | Note 3 | Cyan | Dark Grey | High Intensity | | 39 | 57 | 9 | 9 | Note 3 | Cyan | Light Blue | High Intensity<br>Underline | | ЗА | 58 | : | : | Shift | Cyan | Light Green | High Intensity | | 3B | 59 | ; | ; | | Cyan | Light Cyan | High Intensity | | зс | 60 | ٧ | < | Shift | Cyan | Light Red | High Intensity | | 3D | 61 | 11 | = | | Cyan | Light<br>Magenta | High Intensity | | 3E | 62 | > | > | Shift | Cyan | Yellow | High Intensity | | 3F | 63 | ? | ? | Shift | Cyan | White | High Intensity | | 40 | 64 | 0 | @ | Shift | Red | Black | Normal | | 41 | 65 | Α | Α | Note 4 | Red | Blue | Underline | | 42 | 66 | В | В | Note 4 | Red | Green | Normal | | 43 | 67 | ¢ | · C | Note 4 | Red | Cyan | Normal | | 44 | 68 | D | D | Note 4 | Red | Red | Normal | | 45 | 69 | E | E | Note 4 | Red | Magenta | Normal | | 46 | 70 | F | F | Note 4 | Red | Brown | Normal | | 47 | 71 | G | G | Note 4 | Red | Light Grey | Normal | | 48 | 72 | Н | Н | Note 4 | Red | Dark Grey | High Intensity | | 49 | 73 | l | l | Note 4 | Red | Light Blue | High Intensity<br>Underline | | 4A | 74 | J | J | Note 4 | Red | Light Green | High Intensity | | | | | | | , | As Text Attribu | ites | | |-----|-----|------------|---------------------------------------|--------|------------|---------------------|------------------------------|--| | Va | lue | į | à Characters | | | iraphics<br>Adapter | IBM<br>Monochrome<br>Display | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | 4B | 75 | K | K | Note 4 | Red | Light Cyan | High Intensity | | | 4C | 76 | L | L | Note 4 | Red | Light Red | High Intensity | | | 4D | 77 | М | M | Note 4 | Red | Light<br>Magenta | High Intensity | | | 4E | 78 | N | N | Note 4 | Red | Yellow | High Intensity | | | 4F | 79 | . 0 | 0 | Note 4 | Red | White | High Intensity | | | 50 | 80 | Р | P | Note 4 | Magenta | Black | Normal | | | 51 | 81 | Q | Q | Note 4 | Magenta | Blue | Underline | | | 52 | 82 | R | R | Note 4 | Magenta | Green | Normal | | | 53 | 83 | S | S | Note 4 | Magenta | Cyan | Normal | | | 54 | 84 | T | Т | Note 4 | Magenta | Red | Normal | | | 55 | 85 | Ų | Ü | Note 4 | Magenta | Magenta | Normal | | | 56 | 86 | ٧ | ٧ | Note 4 | Magenta | Brown | Normal | | | 57 | 87 | W | W | Note 4 | Magenta | Light Grey | Normal | | | 58 | 88 | X | Х | Note 4 | Magenta | Dark Grey | High Intensity | | | 59 | 89 | Y | Ϋ́ | Note 4 | Magenta | Light Blue | High Intensity<br>Underline | | | 5A | 90 | Ż | Z | Note 4 | Magenta | Light Green | High Intensity | | | 5B | 91 | 1 | | | Magenta | Light Cyan | High Intensity | | | 5C | 92 | \ <u>\</u> | , , , , , , , , , , , , , , , , , , , | | Magenta | Light Red | High Intensity | | | 5D | 93 | Ì | ] | | Magenta | Light<br>Magenta | High Intensity | | | 5E | 94 | ^ | ^ | Shift | Magenta | Yellow | High Intensity | | | 5F | 95 | | <del>.</del> . | Shift | Magenta | White | High Intensity | | | 60 | 96 | . • | | , | Brown | Black | Normal | | | 61 | 97 | а | a | Note 5 | Brown | Blue | Underline | | | 62 | 98 | ь | Ь | Note 5 | Brown | Green | Normal | | | 63 | 99 | С | С | Note 5 | Brown | Cyan | Normal | | | 64 | 100 | d | d | Note 5 | Brown | Red | Normal | | | 65 | 101 | е | е | Note 5 | Brown | Magenta | Normal | | | 66 | 102 | f | f | Note 5 | Brown | Brown | Normal | | ## 7-6 Characters, Keystrokes, and Colors | | | | | | | ites | | | |-----|-----|--------|---------------|--------|------------------|---------------------|------------------------------|--| | Va | lue | , | As Characters | | | iraphics<br>Adapter | IBM<br>Monochrome<br>Display | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | 67 | 103 | g | g | Note 5 | Brown | Light Grey | Normal | | | 68 | 104 | h | h | Note 5 | Brown | Dark Grey | High Intensity | | | 69 | 105 | i | i | Note 5 | Brown | Light Blue | High Intensity<br>Underline | | | 6A | 106 | j | j | Note 5 | Brown | Light Green | High Intensity | | | 6B | 107 | k | k | Note 5 | Brown | Light Cyan | High Intensity | | | 6C | 108 | 1 | 1 | Note 5 | Brown | Light Red | High Intensity | | | 6D | 109 | m | m | Note 5 | Brown | Light<br>Magenta | High Intensity | | | 6E | 110 | n | n | Note 5 | Brown | Yellow | High Intensity | | | 6F | 111 | 0 | 0 | Note 5 | Brown | White | High Intensity | | | 70 | 112 | р | р | Note 5 | Light Grey Black | | Reverse Video | | | 71 | 113 | q | q | Note 5 | Light Grey Blue | | Underline | | | 72 | 114 | r | r | Note 5 | Light Grey | Green | Normal | | | 73 | 115 | s | s | Note 5 | Light Grey | Cyan | Normal | | | 74 | 116 | t | t | Note 5 | Light Grey | Red | Normal | | | 75 | 117 | u | J | Note 5 | Light Grey | Magenta | Normal | | | 76 | 118 | V | ٧ | Note 5 | Light Grey | Brown | Normal | | | 77 | 119 | w | w | Note 5 | Light Grey | Light Grey | Normal | | | 78 | 120 | × | x | Note 5 | Light Grey | Dark Grey | Reverse Video | | | 79 | 121 | У | У | Note 5 | Light Grey | Light Blue | High Intensity<br>Underline | | | 7A | 122 | Z | z | Note 5 | Light Grey | Light Green | High Intensity | | | 7B | 123 | { | { | Shift | Light Grey | Light Cyan | High Intensity | | | 7C | 124 | ļ<br>ļ | 1 | Shift | Light Grey | Light Red | High Intensity | | | 7D | 125 | } | } | Shift | Light Grey | Light<br>Magenta | High Intensity | | | 7E | 126 | ~ | ~ | Shift | Light Grey | Yellow | High Intensity | | | 7F | 127 | Δ | Ctrl ← | | Light Grey | White | High Intensity | | | | | As Text Attribu | ites | | | | | |-----|-------|-----------------|---------------|-----------|---------------|---------------------|------------------------------| | Va | lue | A | s Characters | | | iraphics<br>Adapter | IBM<br>Monochrome<br>Display | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | * 1 | * * * | 80 to FF | Hex are Flasi | ning in b | oth Color & I | BM Monochi | ome * * * * | | 80 | 128 | Ç | Alt 128 | Note 6 | Black | Black | Non-Display | | 81 | 129 | ü | Alt 129 | Note 6 | Black | Blue | Underline | | 82 | 130 | é | Alt 130 | Note 6 | Black | Green | Normal | | 83 | 131 | â | Alt 131 | Note 6 | Black | Cyan | Normal | | 84 | 132 | ä | Alt 132 | Note 6 | Black | Red | Normal | | 85 | 133 | à | Alt 133 | Note 6 | Black | Magenta | Normal | | 86 | 134 | å | Alt 134 | Note 6 | Black | Brown | Normal | | 87 | 135 | ç | Alt 135 | Note 6 | Black | Light Grey | Normal | | 88 | 136 | ê | Alt 136 | Note 6 | Black | Dark Grey | Non-Display | | 89 | 137 | ë | Alt 137 | Note 6 | Black | Light Blue | High Intensity<br>Underline | | 8A | 138 | è | Alt 138 | Note 6 | Black | Light Green | High Intensity | | 8B | 139 | ï | Alt 139 | Note 6 | Black | Light Cyan | High Intensity | | 8C | 140 | î | Alt 140 | Note 6 | Black | Light Red | High Intensity | | 8D | 141 | ì | Alt 141 | Note 6 | Black | Light<br>Magenta | High Intensity | | 8E | 142 | Ä | Alt 142 | Note 6 | Black | Yellow | High Intensity | | 8F | 143 | Å | Alt 143 | Note 6 | Black | White | High Intensity | | 90 | 144 | É | Alt 144 | Note 6 | Blue | Black | Normal | | 91 | 145 | æ | Alt 145 | Note 6 | Blue | Blue | Underline | | 92 | 146 | Æ | Alt 146 | Note 6 | Blue | Green | Normal | | 93 | 147 | ô | Alt 147 | Note 6 | Blue | Cyan | Normal | | 94 | 148 | ö | Alt 148 | Note 6 | Blue | Red | Normal | | 95 | 149 | ò | Alt 149 | Note 6 | Blue | Magenta | Normal | | 96 | 150 | û | Alt 150 | Note 6 | Blue | Brown | Normal | | 97 | 151 | ù | Alt 151 | Note 6 | Blue | Light Grey | Normal | | 98 | 152 | ÿ | Alt 152 | Note 6 | Blue | Dark Grey | High Intensity | | 99 | 153 | Ö | Alt 153 | Note 6 | Blue | Light Blue | High Intensity<br>Underline | | 9A | 154 | Ü | Alt 154 | Note 6 | Blue | Light Green | High Intensity | ## 7-8 Characters, Keystrokes, and Colors | | | | | | , | As Text Attribu | ites | |------------|-----|-----------------|---------------|--------|-------------------------|---------------------|------------------------------| | Va | lue | A | As Characters | | | iraphics<br>Adapter | IBM<br>Monochrome<br>Display | | Hex | Dec | Symbol | Keystrokes | Modes | s Background Foreground | | Adapter | | 9B | 155 | ¢ | Alt 155 | Note 6 | Blue | Light Cyan | High Intensity | | 9C | 156 | £ | Alt 156 | Note 6 | Blue | Light Red | High Intensity | | 9D | 157 | ¥ | Alt 157 | Note 6 | Blue | Light<br>Magenta | High Intensity | | 9E | 158 | Pt | Alt 158 | Note 6 | Blue | Yellow | High Intensity | | 9F | 159 | f | Alt 159 | Note 6 | Blue | White | High Intensity | | AO | 160 | á | Alt 160 | Note 6 | Green | Black | Normal | | A1 | 161 | í | Alt 161 | Note 6 | Green | Blue | Underline | | A2 | 162 | ó | Alt 162 | Note 6 | Green | Green | Normal | | АЗ | 163 | ú | Alt 163 | Note 6 | Green | Cyan | Normal | | A4 | 164 | ñ | Alt 164 | Note 6 | Green | Red | Normal | | A5 | 165 | Ñ | Alt 165 | Note 6 | Green | Magenta | Normal | | A6 | 166 | <u>a</u> | Alt 166 | Note 6 | Green | Brown | Normal | | Α7 | 167 | <u>o</u> _ | Alt 167 | Note 6 | Green | Light Grey | Normal | | A8 | 168 | i | Alt 168 | Note 6 | Green | Dark Grey | High Intensity | | A9 | 169 | | Alt 169 | Note 6 | Green | Light Blue | High Intensity<br>Underline | | AA | 170 | J | Alt 170 | Note 6 | Green | Light Green | High Intensity | | AB | 171 | 1/2 | Alt 171 | Note 6 | Green | Light Cyan | High Intensity | | AC | 172 | 1/4 | Alt 172 | Note 6 | Green | Light Red | High Intensity | | AD | 173 | i | Alt 173 | Note 6 | Green | Light<br>Magenta | High Intensity | | AE | 174 | <b>&lt;&lt;</b> | Alt 174 | Note 6 | Green | Yellow | High Intensity | | AF | 175 | >> | Alt 175 | Note 6 | Green | White | High Intensity | | ВО | 176 | ::: | Alt 176 | Note 6 | Cyan | Black | Normal | | B1 | 177 | <b>888</b> | Alt 177 | Note 6 | Cyan | Blue | Underline | | B2 | 178 | | Alt 178 | Note 6 | Cyan | Green | Normal | | <b>B</b> 3 | 179 | | Alt 179 | Note 6 | Cyan | Cyan | Normal | | B4 | 180 | | Alt 180 | Note 6 | Cyan | Red | Normal | | <b>B</b> 5 | 181 | | Alt 181 | Note 6 | Cyan | Magenta | Normal | | В6 | 182 | | Alt 182 | Note 6 | Cyan | Brown | Normal | | | | | | | | ites | | | |------------|-----|--------|---------------|--------|------------|---------------------|------------------------------|--| | Va | iue | A | As Characters | | | iraphics<br>Adapter | IBM<br>Monochrome<br>Display | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | B7 | 183 | | Alt 183 | Note 6 | Cyan | Light Grey | Normal | | | <b>B</b> 8 | 184 | | Alt 184 | Note 6 | Cyan | Dark Grey | High Intensity | | | B9 | 185 | | Alt 185 | Note 6 | Cyan | Light Blue | High Intensity<br>Underline | | | ВА | 186 | | Alt 186 | Note 6 | Cyan | Light Green | High Intensity | | | BB | 187 | | Alt 187 | Note 6 | Cyan | Light Cyan | High Intensity | | | ВС | 188 | | Alt 188 | Note 6 | Cyan | Light Red | High Intensity | | | BD | 189 | | Alt 189 | Note 6 | Cyan | Light<br>Magenta | High Intensity | | | BE | 190 | | Alt 190 | Note 6 | Cyan | Yellow | High Intensity | | | BF | 191 | | Alt 191 | Note 6 | Cyan | White | High Intensity | | | CO | 192 | | Alt 192 | Note 6 | Red | Black | Normal | | | C1 | 193 | | Alt 193 | Note 6 | Red | Blue | Underline | | | C2 | 194 | | Alt 194 | Note 6 | Red | Green | Normal | | | СЗ | 195 | | Alt 195 | Note 6 | Red | Cyan | Normal | | | C4 | 196 | | Alt 196 | Note 6 | Red | Red | Normal | | | C5 | 197 | | Alt 197 | Note 6 | Red | Magenta | Normal | | | C6 | 198 | | Alt 198 | Note 6 | Red | Brown | Normal | | | C7 | 199 | | Alt 199 | Note 6 | Red | Light Grey | Normal | | | C8 | 200 | | Alt 200 | Note 6 | Red | Dark Grey | High Intensity | | | C9 | 201 | | Alt 201 | Note 6 | Red | Light Blue | High Intensity<br>Underline | | | CA | 202 | | Alt 202 | Note 6 | Red | Light Green | High Intensity | | | СВ | 203 | | Alt 203 | Note 6 | Red | Light Cyan | High Intensity | | | CC | 204 | | Alt 204 | Note 6 | Red | Light Red | High Intensity | | | CD | 205 | | Alt 205 | Note 6 | Red | Light<br>Magenta | High Intensity | | | CE | 206 | | Alt 206 | Note 6 | Red | Yellow | High Intensity | | | CF | 207 | | Alt 207 | Note 6 | Red | White | High Intensity | | | DO | 208 | | Alt 208 | Note 6 | Magenta | Black | Normal | | ## 7-10 Characters, Keystrokes, and Colors | | | | | | - | As Text Attribu | tes | | |------------|-----|--------|--------------|--------|------------|--------------------|------------------------------|--| | Va | lue | A | s Characters | | | raphics<br>Adapter | IBM<br>Monochrome<br>Display | | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | | D1 | 209 | | Alt 209 | Note 6 | Magenta | Blue | Underline | | | D2 | 210 | | Alt 210 | Note 6 | Magenta | Green | Normal | | | D3 | 211 | Ш | Alt 211 | Note 6 | Magenta | Cyan | Normal | | | D4 | 212 | | Alt 212 | Note 6 | Magenta | Red | Normal | | | D5 | 213 | F=== | Alt 213 | Note 6 | Magenta | Magenta | Normal | | | D6 | 214 | П | Alt 214 | Note 6 | Magenta | Brown | Normal | | | D7 | 215 | | Alt 215 | Note 6 | Magenta | Light Grey | Normal | | | D8 | 216 | | Alt 216 | Note 6 | Magenta | Dark Grey | High Intensity | | | D9 | 217 | | Alt 217 | Note 6 | Magenta | Light Blue | High Intensity<br>Underline | | | DA | 218 | | Alt 218 | Note 6 | Magenta | Light Green | High Intensity | | | DB | 219 | | Alt 219 | Note 6 | Magenta | Light Cyan | High Intensity | | | DC | 220 | | Alt 220 | Note 6 | Magenta | Light Red | High Intensity | | | DD | 221 | | Alt 221 | Note 6 | Magenta | Light<br>Magenta | High Intensity | | | DE | 222 | | Alt 222 | Note 6 | Magenta | Yellow | High Intensity | | | DF | 223 | | Alt 223 | Note 6 | Magenta | White | High Intensity | | | EO | 224 | α | Alt 224 | Note 6 | Brown | Black | Normal | | | E1 | 225 | β | Alt 225 | Note 6 | Brown | Blue | Underline | | | E2 | 226 | Γ | Alt 226 | Note 6 | Brown | Green | Normal | | | E3 | 227 | π | Alt 227 | Note 6 | Brown | Cyan | Normal | | | E4 | 228 | Σ | Alt 228 | Note 6 | Brown | Red | Normal | | | E5 | 229 | σ | Alt 229 | Note 6 | Brown | Magenta | Normal | | | <b>E</b> 6 | 230 | μ | Alt 230 | Note 6 | Brown | Brown | Normal | | | E7 | 231 | τ | Alt 231 | Note 6 | Brown | Light Grey | Normal | | | E8 | 232 | Φ | Alt 232 | Note 6 | Brown | Dark Grey | High Intensity | | | E9 | 233 | θ | Alt 233 | Note 6 | Brown | Light Blue | High Intensity<br>Underline | | | EA | 234 | Ω | Alt 234 | Note 6 | Brown | Light Green | High Intensity | | | EB | 235 | δ | Alt 235 | Note 6 | Brown | Light Cyan | High Intensity | | | | | | | | , | ites | | |-----|-----|----------|--------------|--------|-----------------------------|---------------------|------------------------------| | Va | lue | A | s Characters | | | iraphics<br>Adapter | iBM<br>Monochrome<br>Display | | Hex | Dec | Symbol | Keystrokes | Modes | Background | Foreground | Adapter | | EC | 236 | 80 | Alt 236 | Note 6 | Brown | Light Red | High Intensity | | ED | 237 | φ | Alt 237 | Note 6 | Brown | Light<br>Magenta | High Intensity | | EE | 238 | € | Alt 238 | Note 6 | Brown | Yellow | High Intensity | | EF | 239 | 0 | Alt 239 | Note 6 | Brown | White | High Intensity | | FO | 240 | = | Alt 240 | Note 6 | Light Grey | Black | Reverse Video | | F1 | 241 | ± | Alt 241 | Note 6 | Light Grey | Blue | Underline | | F2 | 242 | ≥ | Alt 242 | Note 6 | Light Grey | Green | Normal | | F3 | 243 | ≤ | Alt 243 | Note 6 | Light Grey | Cyan | Normal | | F4 | 244 | <u>ر</u> | Alt 244 | Note 6 | Light Grey | Red | Normal | | F5 | 245 | J | Alt 245 | Note 6 | Light Grey | Magenta | Normal | | F6 | 246 | ÷ | Alt 246 | Note 6 | Light Grey | Brown | Normal | | F7 | 247 | * | Alt 247 | Note 6 | Light Grey | Light Grey | Normal | | F8 | 248 | 0 | Alt 248 | Note 6 | Light Grey | Dark Grey | Reverse Video | | F9 | 249 | • | Alt 249 | Note 6 | Light Grey | Light Blue | High Intensity<br>Underline | | FA | 250 | • | Alt 250 | Note 6 | Light Grey | Light Green | High Intensity | | FB | 251 | \ | Alt 251 | Note 6 | Light Grey Light Cyan | | High Intensity | | FC | 252 | n | Alt 252 | Note 6 | Light Grey Light Red | | High Intensity | | FD | 253 | 2 | Alt 253 | Note 6 | Light Grey Light<br>Magenta | | High Intensity | | FE | 254 | | Alt 254 | Note 6 | Light Grey | Yellow | High Intensity | | FF | 255 | BLANK | Alt 255 | Note 6 | Light Grey | White | High Intensity | ## **Notes** - 1. Asterisk (\*) can be typed using two methods: press the (\*) key or, in the shift mode, press the 8 key. - 2. Period (.) can be typed using two methods: press the . key or, in the shift or Num Lock mode, press the Del key. - 3. Numeric characters 0-9 can be typed using two methods: press the numeric keys on the top row of the keyboard or, in the shift or Num Lock mode, press the numeric keys in the keypad portion of the keyboard. - 4. Uppercase alphabetic characters (A-Z) can be typed in two modes: the shift mode or the Caps Lock mode. - 5. Lowercase alphabetic characters (a-z) can be typed in two modes: in the normal mode or in Caps Lock and shift mode combined. - 6. The three digits after the Alt key must be typed from the numeric keypad. Character codes 1-255 may be entered in this fashion (with Caps Lock activated, character codes 97-122 will display uppercase). # **Quick Reference** | DECIMAL<br>VALUE | • | 0 | 16 | 32 | 48 | 64 | 80 | 96 | 112 | |------------------|---------------------------|-----------------|-------------------|------------------|----|----------|----|----|-----| | - | HEXA-<br>DECIMAL<br>VALÚE | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | 0 | 0 | BLANK<br>(NULL) | • | BLANK<br>(SPACE) | 0 | <u>@</u> | P | 6 | p | | 1 | 1 | $\odot$ | <b>V</b> | ! | 1 | A | Q | a | q | | 2 | 2 | • | 1 | Ξ | 2 | B | R | b | r | | 3 | 3 | • | !! | # | 3 | C | S | C | S | | 4 | 4 | <b>♦</b> | ¶ | \$ | 4 | D | T | d | t | | 5 | 5 | * | Ş | % | 5 | E | U | е | u | | 6 | 6 | • | | & | 6 | F | V | f | V | | 7 | 7 | • | $\leftrightarrow$ | , | 7 | G | W | ø | W | | 8 | 8 | • | <b>←</b> | ( | 8 | H | X | h | X | | 9 | 9 | 0 | <b>→</b> | ) | 9 | I | Y | i | У | | 10 | A | $\circ$ | 1 | * | • | J | Z | j | Z | | 11 | В | ъ | Ų. | + | • | K | [ | k | { | | 12 | С | Q | <u></u> | , | / | L | / | 1 | | | 13 | D | 5 | <b></b> | | = | M | ] | m | } | | 14 | E | 4 | <b>A</b> | • | / | N | ^ | n | 7 | | 15 | F | ⇔ | ▼ | / | ? | O | | 0 | Δ | 7-14 Characters, Keystrokes, and Colors | DECIMAL<br>VALUE | • | 128 | 144 | 160 | 176 | 192 | 208 | 224 | 240 | |------------------|---------------------------|-----|-----|-----------------|-----------------------------------------|-----|-----|---------------------|---------------| | • | HEXA-<br>DECIMAL<br>VALUE | 8 | 9 | A | В | С | D | E | F | | 0 | 0 | Ç | É | á | ••• | | | 8 | | | 1 | 1 | ü | æ | í | *** | | | β | +1 | | 2 | 2 | é | Æ | ó | *************************************** | | | Γ | Λl | | 3 | 3 | â | ô | ú | | | | $\pi$ | VI | | 4 | 4 | ä | Ö | ñ | | | | Σ | | | 5 | 5 | à | ò | Ñ | | | | σ | J | | 6 | 6 | å | û | <u>a</u> | | | | μ | + | | 7 | 7 | Ç | ù | <u>O</u> | | | | Υ | × | | 8 | 8 | ê | ÿ | ? | | | | Φ | 0 | | 9 | 9 | ë | Ö | Г | | | | θ | • | | 10 | Α | è | Ü | | | | | $\Omega$ | • | | 11 | В | ï | ¢ | 1/2 | | | | δ | <b>~</b> | | 12 | С | î | £ | 1/4 | | | | 8 | n | | 13 | D | 1 | ¥ | i | | | | $\boldsymbol{\phi}$ | 2 | | 14 | E | Ä | Pt | <b>~</b> | | | | $\subseteq$ | | | 15 | F | Å | f | <b>&gt;&gt;</b> | | | | $\bigcap$ | BLANK<br>'FF' | Characters, Keystrokes, and Colors 7-15 **Notes:** ## **SECTION 8. IBM PERSONAL COMPUTER COMPATIBILITY** | Hardware Considerations 8-3 | |-----------------------------------------------------| | System Board 8-3 | | Fixed Disk Drive 8-5 | | Diskette Drive Compatibility 8-5 | | Copy Protection 8-5 | | Bypassing BIOS 8-6 | | Diskette Drive Controls 8-6 | | Write Current Control 8-6 | | Application Guidelines 8-7 | | High-Level Language Considerations 8-7 | | Assembler Language Programming Considerations . 8-8 | | Multitasking Provisions 8-15 | | Interfaces 8-15 | | Classes 8-17 | | Time-Outs 8-18 | | Machine-Sensitive Code | This section describes the differences among the members of the IBM Personal Computer family. It also contains information necessary to design hardware and programs that will be compatible with all members of the IBM Personal Computer family. ## **Hardware Considerations** To design compatible hardware or programs, you must consider hardware differences among the IBM Personal Computers. The following are hardware features of the IBM Personal Computer XT Model 286 that are not supported by all of the IBM Personal Computer family. ## **System Board** The IBM Personal Computer XT Model 286 system board uses an Intel 80286-6 Microprocessor. This microprocessor uses the 80287 Math Coprocessor and is generally compatible with the Intel 8088 Microprocessor used in other IBM Personal Computers. The following table identifies the microprocessor and describes the I/O channel used with each type of IBM Personal Computer. | System Name | System Unit<br>Microprocessor | I/O Channel Description | | | | |-----------------------------------|-------------------------------|----------------------------------------|--|--|--| | Personal Computer | 8088 | 5 62-Pin | | | | | PCjr | 8088 | Not Compatible | | | | | Personal Computer XT | 8088 | 8 62-Pin | | | | | Portable Personal<br>Computer | 8088 | 8 62-Pin | | | | | Personal Computer XT<br>Model 286 | 80286-6 | 3 62-pin<br>5 98-Pin (62 Pin + 36 Pin) | | | | | Personal Computer AT | 80286(-6 or -8) | 2 62-pin<br>6 98-Pin (62 Pin + 36 Pin) | | | | **System Hardware Identification Chart** The faster processing capability of the 80286, compared to the 8088, creates special programming considerations, which are discussed later in this section under "Application Guidelines." Adapters designed to use all 98 pins on the 98-pin connectors are not compatible with all members of the IBM Personal Computer family. Some options not supported by the IBM Personal Computer XT Model 286 are: **Expansion Unit** AT 128KB Memory Expansion AT 512KB Memory Expansion AT 128/640KB Memory Expansion AT Fixed Disk And Diskette Drive Adapter 256KB Memory Expansion 64/256KB Memory Expansion 64KB Memory Module Kit Full-high diskette drives AT 30MB Fixed Disk Drive AT 20MB Fixed Disk Drive 10MB Fixed Disk Drive AT Prototype Card Diskette Drive Adapter Fixed Disk Adapter 8087 Math Coprocessor Professional Graphics Adapter and Display Game Control Adapter Color Printer Other keyboards #### On the I/O channel: - The system clock signal should be used only for synchronization and not for applications requiring a fixed frequency. - The 14.31818-MHz oscillator is not synchronous with the system clock. - The ALE signal remains high during DMA cycles. - Pin B04 supports IRQ 9. #### 8-4 Compatibility ## **Fixed Disk Drive** Reading from and writing to this drive is initiated in the same way as with other IBM Personal Computers; however, the Fixed Disk and Diskette Drive Adapter may be addressed from different BIOS locations. ## **Diskette Drive Compatibility** The following chart shows the read, write, and format capabilities for each of the diskette drives used by IBM Personal Computers. | Diskette | 160/180K | 320/360K | 1.2M | 720K | |----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-------------------------------------|---------------|-------------------| | Drive Name | Mode | Mode | Mode | Mode | | 5-1/4 In. Diskette Drive Type 1 Type 2 Type 3 Slimline Diskette Drive Double Sided Diskette Drive High Capacity Diskette Drive 3-1/2 In 720K Drive | R W F<br>R W F<br>R W F<br>R W F<br>R W* | <br>R W F<br>R W F<br>R W F<br>R W* | <br><br>R W F | <br><br><br>R W F | formatted in either 160/180K mode or 320/360K mode and written on by a High Capacity Drive, that diskette may be read by only a High Capacity Drive. #### **Diskette Drive Compatibility Chart** Note: Diskettes designed for the 1.2M mode may not be used in either a 160/180K or a 320/360K diskette drive. ## **Copy Protection** The following methods of copy protection may not work on systems using the High Capacity Diskette Drive: - **Bypassing BIOS** - Diskette drive controls - Write current control ## **Bypassing BIOS** Copy protection that tries to bypass the following BIOS routines will not work on the High Capacity Diskette Drive: Track Density: The High Capacity Diskette Drive records tracks at a density of 96 tracks per inch (TPI). This drive has to double-step in the 48 TPI mode, which is performed by BIOS. **Data Transfer Rate:** BIOS selects the proper data transfer rate for the media being used. **Disk\_Base:** Copy protection, which creates its own disk\_base will not work on the High Capacity Diskette Drive. #### **Diskette Drive Controls** Copy protection that uses the following will not work on the High Capacity Diskette Drive: **Rotational Speed:** The time between two events on a diskette is controlled by the Fixed Disk and Diskette Drive Adapter. Access Time: Diskette BIOS routines must set the track-to-track access time for the different types of media used on the IBM Personal Computer XT Model 286. **Head Geometry:** See "Diskette Drive Compatibility" on page 8-5. **Diskette Change Signal:** Copy protection may not be able to reset this signal. #### **Write Current Control** Copy protection that uses write current control will not work because the Fixed Disk and Diskette Drive Adapter selects the proper write current for the media being used. ## **Application Guidelines** The following information should be used to develop application programs for the IBM Personal Computer family. ## **High-Level Language Considerations** The IBM-supported languages of BASIC, FORTRAN, COBOL, Pascal, and APL are the best choices for writing compatible programs. If a program uses specific features of the hardware, that program may not be compatible with all IBM Personal Computers. Specifically, the use of assembler language subroutines or hardware-specific commands (In, Out, Peek, Poke, ...) must follow the assembler language rules (see "Assembler Language Programming Considerations" on page 8-8). Any program that requires precise timing information should obtain it through a DOS or language interface; for example, TIME\$ in BASIC. If greater precision is required, the assembler techniques in "Assembler Language Programming Considerations" are available. The use of programming loops may prevent a program from being compatible with other IBM Personal Computers. # **Assembler Language Programming Considerations** The following OP codes work differently on systems using the 80286 microprocessor than they do on systems using the 8088 microprocessor. • If the system microprocessor executes a POPF instruction in either the real or the virtual address mode with CPL≤IOPL, then a pending maskable interrupt (the INTR pin active) may be improperly recognized after executing the POPF instruction even if maskable interrupts were disabled before the POPF instruction and the value popped had IF=0. If the interrupt is improperly recognized, the interrupt is still correctly executed. This errata has no effect when interrupts are enabled in either real or virtual address mode. This errata has no effect in the virtual address mode when CPL>IOPL. The POPF instruction may be simulated with the following code macro: ``` POPFF ; use POPFF instead of POPF Macro ; simulate popping flags ; using IRET ; jump around IRET ; POP CS, IP, flags JMP $+3 EB 01 CF IRET PUSH CS 0E E8 FB FF CALL $-2 ; CALL within segment ; program will continue here ``` PUSH SP 80286 microprocessor pushes the current stack pointer. 8088 microprocessor pushes the new stack pointer. • Single step interrupt (when TF=1) on the interrupt instruction (OP code hex CC,CD): 80286 microprocessor does not interrupt on the INT instruction. 8088 microprocessor does interrupt on the INT instruction. • The divide error exception (interrupt 0): 80286 microprocessor pushes the CS:IP of the instruction, causing the exception. 8088 microprocessor pushes the CS:IP following the instruction, causing the exception. • Shift counts are masked to five bits. Shift counts greater than 31 are treated mod 32. For example, a shift count of 36, shifts the operand four places. The following describes anomalies which may occur in systems which contain 80286 processors with 1983 and 1984 date codes (\$40172, \$54036, \$40093, \$54012). In protected mode, the contents of the CX register may be unexpectedly altered under the following conditions: Note: The value in parenthesis indicates the type of error code pushed onto the exception handler's stack. ``` Exception #NP() = Exception #11 = Not-present Fault Exception #SS() = Exception #12 = Stack Fault Exception #GP() = Exception #13 = General Protection Fault ``` - Exception #GP(0) from attempted access to data segment or extra segment when the corresponding segment register holds a null selector. - Exception #GP(0) from attempted data read from code segment when code segment has the "execute only" attribute. - Exception #GP(0) from attempted write to code segment (code segments are not writable in protected mode), or to data segment of extra segment if the data or extra segment has the read only attribute. - Exception #GP(0) from attempted load of a selector referencing the local descriptor table into CS, DS, ES or SS, when the LDT is not present. - Exception #GP(0) from attempted input or output instruction when CPL > IOPL. - Exception #GP(selector) from attempted access to a descriptor is GDT, LDT, or IDT, beyond the defined limit of the descriptor table. - Exception #GP(0) from attempted read or write (except for "PUSH" onto stack) beyond the defined limit of segment. - Exception #SS(0) from attempted "PUSH" below the defined limit of the stack segment. Restarting applications which generate the above exceptions may result in errors. In the protected mode, when any of the null selector values (0000H, 0001H, 0002H, 0003H) are loaded into the DS or ES registers via a MOV or POP instruction or a task switch, the 80286 always loads the null selector 0000H into the corresponding register. If a coprocessor (80287) operand is read from an "executable and readable" and conforming (ERC) code segment, and the coprocessor operand is sufficiently near the segment's limit that the second or subsequent byte lies outside the limit, no protection exception #9 will be generated. The following correctly describes the operation of all 80286 parts: - Instructions longer than 10 bytes (instructions using multiple redundant prefixes) generate exception #13 (General Purpose Exception) in both the real and protected modes. - If the second operand of an ARPL instruction is a null selector, the instruction generates an exception #13. Assembler language programs should perform all I/O operations through ROM BIOS or DOS function calls. • Program interrupts are used for access to these functions. This practice removes the absolute addressing from the program. Only the interrupt number is required. • The coprocessor detects six different exception conditions that can occur during instruction execution. If the appropriate exception mask within the coprocessor is not set, the coprocessor sets its error signal. This error signal generates a hardware interrupt (interrupt 13) and causes the 'busy' signal to the coprocessor to be held in the busy state. The 'busy' signal may be cleared by an 8-bit I/O Write command to address hex F0 with D0 through D7 equal to 0. The power-on-self-test code in the system ROM enables hardware IRQ 13 and sets up its vector to point to a routine in ROM. The ROM routine clears the 'busy' signal latch and then transfers control to the address pointed to by the NMI interrupt vector. This allows code written for any IBM Personal Computer to work on an IBM Personal Computer XT Model 286. The NMI interrupt handler should read the coprocessor's status to determine if the NMI was caused by the coprocessor. If the interrupt was not generated by the coprocessor, control should be passed to the original NMI interrupt handler. Back to back I/O commands to the same I/O ports will not permit enough recovery time for I/O chips. To ensure enough time, a JMP SHORT \$+2 must be inserted between IN/OUT instructions to the same I/O chip. Note: MOV AL, AH type instruction does not allow enough recovery time. An example of the correct procedure follows: OUT IO\_ADD,AL JMP SHORT \$+2 MOV AL,AH OUT IO\_ADD,AL - In systems using the 80286 microprocessor, IRQ 9 is redirected to INT hex 0A (hardware IRQ 2). This insures that hardware designed to use IRQ 2 will operate in the IBM Personal Computer XT Model 286. - The system can mask hardware sensitivity. New devices can change the ROM BIOS to accept the same programming interface on the new device. - In cases where BIOS provides parameter tables, such as for video or diskette, a program may substitute new parameter values by building a new copy of the table and changing the vector to point to that table. However, the program should copy the current table, using the current vector, and then modify those locations in the table that need to be changed. In this way, the program will not inadvertently change any values that should be left the same. - Disk\_Base consists of 11 parameters required for diskette operation. They are pointed at by the data variable, Disk\_Pointer, at absolute address 0:78. It is strongly recommended that the values supplied in ROM be used. If it becomes necessary to modify any of the parameters, build another parameter block and modify the address in Disk\_Pointer to point to the new block. The parameters were established to operate both the High Capacity Diskette Drive and the Double Sided Diskette Drive. Three of the parameters in this table are under control of BIOS in the following situations. The Gap Length Parameter is no longer retrieved from the parameter block. The gap length used during diskette read, write, and verify operations is derived from within diskette BIOS. The gap length for format operations is still obtained from the parameter block. Special considerations are required for formatting operations. See the prolog of Diskette BIOS for the required details. If a parameter block contains a head settle time parameter value of 0 milliseconds, and a write operation is being performed, at least 15 milliseconds of head settle time will be enforced for a High Capacity Diskette Drive and 20 milliseconds will be enforced for a Double Sided Diskette Drive. If a parameter block contains a motor start wait parameter of less than 1 second for a write or format operation of 625 milliseconds for a read or verify operation, Diskette BIOS will enforce those times listed above. - The following procedure is used to determine the type of media inserted in the High Capacity Diskette Drive: - 1. Read Track 0, Head 0, Sector 1 to allow diskette BIOS to establish the media/drive combination. If this is successful, continue with the next step. - 2. Read Track 0, Sector 15. If an error occurs, a double sided diskette is in the drive. Note: Refer to the *DOS Technical Reference* manual for the File Allocation Table (FAT) parameters for single-and double-sided diskettes. If a successful read occurs, a high capacity diskette is in the drive. 3. If Step 1 fails, issue the reset function (AH=0) to diskette BIOS and retry. If a successful read cannot be done, the media needs to be formatted or is defective. ROM BIOS and DOS do not provide for all functions. The following are the allowable I/O operations with which IBM will maintain compatibility in future systems. • Control of the sound, using port hex 61, and the sound channel of the timer/counter. A program can control timer/counter channels 0 and 2, ports hex 40, 42, and 43. A program must not change the value in port hex 41, because this port controls the dynamic-memory refresh. Channel 0 provides the time-of-day interrupt, and can also be used for timing short intervals. Channel 2 of the timer/counter is the output for the speaker and cassette ports. This channel may also be used for timing short intervals, although it cannot interrupt at the end of the period. **Note:** Programs should use the timer for delay on the paddle input rather than a program loop. • Interrupt Mask Register (IMR), port hex 21, can be used to selectively mask and unmask the hardware features. The following information pertains to absolute memory locations. - Interrupt Vectors Segment (hex 0)—A program may change these to point at different processing routines. When an interrupt vector is modified, the original value should be retained. If the interrupt, either hardware or program, is not directed toward this device handler, the request should be passed to the next item in the list. - Video Display Buffers (hex B0000 and B8000)—For each mode of operation defined in the video display BIOS, the memory map will remain the same. For example, the bit map for the 320 x 200 medium-resolution graphics mode of the Color/Graphics Monitor adapter will be retained on any future adapter that supports that mode. If the bit map is modified, a different mode number will be used. - ROM BIOS Data Area (hex 40:0)--Any variables in this area will retain their current definition, whenever it is reasonable to do so. IBM may use these data areas for other purposes when the variable no longer has meaning in the system. In general, ROM BIOS data variables should be read or modified through BIOS calls whenever possible, and not with direct access to the variable. A program that requires timing information should use either the time-of-day clock or the timing channels of the timer/counter. The input frequency to the timer will be maintained at 1.19 MHz, providing a constant time reference. Program loops should be avoided. Programs that use copy protection schemes should use the ROM BIOS diskette calls to read and verify the diskette and should not be timer dependent. Any method can be used to create the diskette, although manufacturing capability should be considered. The verifying program can look at the diskette controller's status bytes in the ROM BIOS data area for additional information about embedded errors. More information about copy protection may be found on page 8-5 under "Copy Protection". Any DOS program must be relocatable and insensitive to the size of DOS or its own load addresses. A program's memory requirement should be identified and contiguous with the load module. A program should not assume that all of memory is available to it. There are several 80286 instructions that, when executed, lock out external bus signals. DMA requests are not honored during the execution of these instructions. Consecutive instructions of this type prevent DMA activity from the start of the first instruction to the end of the last instruction. To allow for necessary DMA cycles, as required by the diskette controller in a multitasking system, multiple lock-out instructions must be separated by JMP SHORT \$+2. ## **Multitasking Provisions** The IBM Personal Computer XT Model 286 BIOS contains a feature to assist multitasking implementation. "Hooks" are provided for a multitasking dispatcher. Whenever a busy (wait) loop occurs in the BIOS, a hook is provided for the program to break out of the loop. Also, whenever BIOS services an interrupt, a corresponding wait loop is exited, and another hook is provided. Thus a program may be written that employs the bulk of the device driver code. The following is valid only in the microprocessor's real address mode and must be taken by the code to allow this support. The program is responsible for the serialization of access to the device driver. The BIOS code is not reentrant. The program is responsible for matching corresponding wait and post calls. #### **Interfaces** There are four interfaces to be used by the multitasking dispatcher: ## Startup First, the startup code hooks interrupt hex 15. The dispatcher is responsible to check for function codes of AH= hex 90 or 91. The "Wait" and "Post" sections describe these codes. The dispatcher must pass all other functions to the previous user of interrupt hex 15. This can be done by a JMP or a CALL. If the function code is hex 90 or 91, the dispatcher should do the appropriate processing and return by the IRET instruction. #### **Serialization** It is up to the multitasking system to ensure that the device driver code is used serially. Multiple entries into the code can result in serious errors. #### Wait (Busy) Whenever the BIOS is about to enter a busy loop, it first issues an interrupt hex 15 with a function code of hex 90 in AH. This signals a wait condition. At this point, the dispatcher should save the task status and dispatch another task. This allows overlapped execution of tasks when the hardware is busy. The following is an outline of the code that has been added to the BIOS to perform this function. ``` MOV AX, 90XXH ; wait code in AH and ; type code in AL INT 15H ; issue call JC TIMEOUT ; optional: for time-out or ; if carry is set, time-out ; occurred NORMAL TIMEOUT LOGIC ; normal time-out ``` ## Post (Interrupt) Whenever the BIOS has set an interrupt flag for a corresponding busy loop, an interrupt 15 occurs with a function code of hex 91 in AH. This signals a post condition. At this point, the dispatcher should set the task status to "ready to run" and return to the interrupt routine. The following is an outline of the code added to BIOS that performs this function. MOV AX, 91XXH ; post code AH and ; type code AL ; issue call ### Classes The following types of wait loops are supported: - The class for hex 0 to 7F is serially reusable. This means that for the devices that use these codes, access to the BIOS must be restricted to only one task at a time. - The class for hex 80 to BF is reentrant. There is no restriction on the number of tasks that may access the device. - The class for hex C0 to FF is non-interrupt. There is no corresponding interrupt for the wait loop. Therefore, it is the responsibility of the dispatcher to determine what satisfies this condition to exit the loop. ### **Function Code Classes** | Type Code (AL) | Description | |----------------|-----------------------------------------------------------------------------------------------------------------| | 00H->7FH | Serially reusable devices; operating system must serialize access | | 80H->0BFH | Reentrant devices; ES:BX is used to distinguish different calls (multiple I/O calls are allowed simultaneously) | 0C0H->0FH Wait only calls; there is no complementary POST for these waits--these are time-out only. Times are function-number dependent. ### **Function Code Assignments** The following are specific assignments for the IBM Personal Computer XT Model 286 BIOS. Times are approximate. They are grouped according to the classes described under "Function Code Classes". | Type Code (AL) | Time-out | Description | |----------------|----------------------|----------------------| | 00H | yes (6 second) | fixed disk | | 01H | yes (2 second) | diskette | | 02H | no (2 second) | keyboard | | 0FDH | yes (1 second-write) | diskette motor start | | | (625 ms-read) | | | 0FEH | yes (18 second) | printer | The asynchronous support has been omitted. The Serial/Parallel Adapter will generate interrupts, but BIOS does not support it in the interrupt mode. Therefore, the support should be included in the multitasking system code if that device is to be supported. ### **Time-Outs** To support time-outs properly, the multitasking dispatcher must be aware of time. If a device enters a busy loop, it generally should remain there for a specific amount of time before indicating an error. The dispatcher should return to the BIOS wait loop with the carry bit set if a time-out occurs. # **Machine-Sensitive Code** Programs may select machine specific features, but they must test for specific machine type. Location of the specific machine identification codes can be found through interrupt 15 function code AH (See 'Configuration Parameters' in BIOS Listing). The code is two bytes. The first byte shows the machine type and the second byte shows the series type. They are as follows: | First<br>Byte | Second<br>Byte | Machine Identification | | |----------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | FF<br>FE<br>FD<br>FC<br>FC<br>FB | 00<br>00<br>00<br>00<br>00<br>02<br>00 | IBM Personal Computer IBM Personal Computer XT IBM Portable Personal Computer IBM PCjr IBM Personal Computer AT IBM Personal Computer XT Model 286 IBM Personal Computer XT with 256/640 system board | | ### **Machine Identification Code** IBM will define methods for uniquely determining the specific machine type or I/O feature for any new device. # **Notes:** # Glossary This glossary includes terms and definitions from the *IBM* Vocabulary for Data Processing, Telecommunications, and Office Systems, GC20-1699. - $\mu$ . Prefix micro; 0.000 001. - $\mu$ s. Microsecond; 0.000 001 second. - A. Ampere. - ac. Alternating current. accumulator. A register in which the result of an operation is formed. active high. Designates a signal that has to go high to produce an effect. Synonymous with positive true. active low. Designates a signal that has to go low to produce an effect. Synonymous with negative true. adapter. An auxiliary device or unit used to extend the operation of another system. address bus. One or more conductors used to carry the binary-coded address from the processor throughout the rest of the system. algorithm. A finite set of well-defined rules for the solution of a problem in a finite number of steps. all points addressable (APA). A mode in which all points of a displayable image can be controlled by the user. alphameric. Synonym for alphanumeric. alphanumeric (A/N). Pertaining to a character set that contains letters, digits, and usually other characters, such as punctuation marks. Synonymous with alphameric. alternating current (ac). A current that periodically reverses its direction of flow. American National Standard Code for Information Interchange (ASCII). The standard code, using a coded character set consisting of 7-bit coded characters (8 bits including parity check), used for information exchange between data processing systems, data communication systems, and associated equipment. The ASCII set consists of control characters and graphic characters. ampere (A). The basic unit of electric current. ### A/N. Alphanumeric analog. (1) Pertaining to data in the form of continuously variable physical quantities. (2) Contrast with digital. AND. A logic operator having the property that if P is a statement, Q is a statement, R is a statement,..., then the AND of P, Q, R,...is true if all statements are true, false if any statement is false. AND gate. A logic gate in which the output is 1 only if all inputs are 1. **AND operation.** The boolean operation whose result has the boolean value 1, if and only if, each operand has the boolean value 1. Synonymous with conjunction. **APA.** All points addressable. **ASCII.** American National Standard Code for Information Interchange. assemble. To translate a program expressed in an assembler language into a computer language. assembler. A computer program used to assemble. assembler language. A computer-oriented language whose instructions are usually in one-to-one correspondence with computer instructions. asynchronous transmission. (1) Transmission in which the time of occurrence of the start of each character, or block of characters, is arbitrary; once started, the time of occurrence of each signal representing a bit within a character, or block, has the same relationship to significant instants of a fixed time frame. (2) Transmission in which each information character is individually transmitted (usually timed by the use of start elements and stop elements). audio frequencies. Frequencies that can be heard by the human ear (approximately 15 hertz to 20,000 hertz). auxiliary storage. (1) A storage device that is not main storage. (2) Data storage other than main storage; for example, storage on magnetic disk. (3) Contrast with main storage. **BASIC.** Beginner's all-purpose symbolic instruction code. basic input/output system (BIOS). The feature of the IBM Personal Computer that provides the level control of the major I/O devices, and relieves the programmer from concern about hardware device characteristics. baud. (1) A unit of signaling speed equal to the number of discrete conditions or signal events per second. For example, one baud equals one bit per second in a train of binary signals, one-half dot cycle per second in Morse code, and one 3-bit value per second in a train of signals each of which can assume one of eight different states. (2) In asynchronous transmission, the unit of modulation rate corresponding to one unit of interval per second; that is, if the duration of the unit interval is 20 milliseconds, the modulation rate is 50 baud. BCC. Block-check character. beginner's all-purpose symbolic instruction code (BASIC). A programming language with a small repertoire of commands and a simple syntax, primarily designed for numeric applications. binary. (1) Pertaining to a selection, choice, or condition that has two possible values or states. (2) Pertaining to a fixed radix numeration system having a radix of 2. binary digit. (1) In binary notation, either of the characters 0 or 1. (2) Synonymous with bit. **binary notation.** Any notation that uses two different characters, usually the binary digits 0 and 1. binary synchronous communications (BSC). A uniform procedure, using a standardized set of control characters and control character sequences for synchronous transmission of binary—coded data between stations. BIOS. Basic input/output system. bit. Synonym for binary digit bits per second (bps). A unit of measurement representing the number of discrete binary digits transmitted by a device in one second. **block.** (1) A string of records, a string of words, or a character string formed for technical or logic reasons to be treated as an entity. (2) A set of things, such as words, characters, or digits, treated as a unit. block-check character (BCC). In cyclic redundancy checking, a character that is transmitted by the sender after each message block and is compared with a block-check character computed by the receiver to determine if the transmission was successful. **boolean operation.** (1) Any operation in which each of the operands and the result take one of two values. (2) An operation that follows the rules of boolean algebra. **bootstrap.** A technique or device designed to bring itself into a desired state by means of its own action; for example, a machine routine whose first few instructions are sufficient to bring the rest of itself into the computer from an input device. bps. Bits per second. X-4 Glossary **BSC.** Binary synchronous communications. **buffer.** (1) An area of storage that is temporarily reserved for use in performing an input/output operation, into which data is read or from which data is written. Synonymous with I/O area. (2) A portion of storage for temporarily holding input or output data. bus. One or more conductors used for transmitting signals or power. byte. (1) A sequence of eight adjacent binary digits that are operated upon as a unit. (2) A binary character operated upon as a unit. (3) The representation of a character. #### C. Celsius. capacitor. An electronic circuit component that stores an electric charge. Cartesian coordinates. A system of coordinates for locating a point on a plane by its distance from each of two intersecting lines, or in space by its distance from each of three mutually perpendicular planes. CAS. Column address strobe. cathode ray tube (CRT). A vacuum tube in which a stream of electrons is projected onto a fluorescent screen producing a luminous spot. The location of the spot can be controlled. cathode ray tube display (CRT display). (1) A CRT used for displaying data. For example, the electron beam can be controlled to form alphanumeric data by use of a dot matrix. (2) Synonymous with monitor. **CCITT.** International Telegraph and Telephone Consultative Committee. Celsius (C). A temperature scale. Contrast with Fahrenheit (F). central processing unit (CPU). Term for processing unit. **channel.** A path along which signals can be sent; for example, data channel, output channel. character generator. (1) In computer graphics, a functional unit that converts the coded representation of a graphic character into the shape of the character for display. (2) In word processing, the means within equipment for generating visual characters or symbols from coded data. character set. (1) A finite set of different characters upon which agreement has been reached and that is considered complete for some purpose. (2) A set of unique representations called characters. (3) A defined collection of characters. characters per second (cps). A standard unit of measurement for the speed at which a printer prints. **check key.** A group of characters, derived from and appended to a data item, that can be used to detect errors in the data item during processing. clipping. In computer graphics, removing parts of a display image that lie outside a window. closed circuit. A continuous unbroken circuit; that is, one in which current can flow. Contrast with open circuit. CMOS. Complementary metal oxide semiconductor. code. (1) A set of unambiguous rules specifying the manner in which data may be represented in a discrete form. Synonymous with coding scheme. (2) A set of items, such as abbreviations, representing the members of another set. (3) To represent data or a computer program in a symbolic form that can be accepted by a data processor. (4) Loosely, one or more computer programs, or part of a computer program. coding scheme. Synonym for code. collector. An element in a transistor toward which current flows. color cone. An arrangement of the visible colors on the surface of a double-ended cone where lightness varies along the axis of the cone, and hue varies around the circumference. Lightness includes both the intensity and saturation of color. **column address strobe (CAS).** A signal that latches the column addresses in a memory chip. compile. (1) To translate a computer program expressed in a problem-oriented language into a computer-oriented language. (2) To prepare a machine-language program from a computer program written in another programming language by making use of the overall logic structure of the program, or generating more than one computer instruction for each symbolic statement, or both, as well as performing the function of an assembler. **complement.** A number that can be derived from a specified number by subtracting it from a second specified number. complementary metal oxide semiconductor (CMOS). A logic circuit family that uses very little power. It works with a wide range of power supply voltages. computer. A functional unit that can perform substantial computation, including numerous arithmetic operations or logic operations, without human intervention during a run. computer instruction code. A code used to represent the instructions in an instruction set. Synonymous with machine code. computer program. A sequence of instructions suitable for processing by a computer. computer word. A word stored in one computer location and capable of being treated as a unit. configuration. (1) The arrangement of a computer system or network as defined by the nature, number, and the chief characteristics of its functional units. More specifically, the term configuration may refer to a hardware configuration or a software configuration. (2) The devices and programs that make up a system, subsystem, or network. conjunction. Synonym for AND operation. **contiguous.** Touching or joining at the edge or boundary; adjacent. **control character.** A character whose occurrence in a particular context initiates, modifies, or stops a control operation. control operation. An action that affects the recording, processing, transmission, or interpretation of data; for example, starting or stopping a process, carriage return, font change, rewind, and end of transmission. control storage. A portion of storage that contains microcode. coordinate space. In computer graphics, a system of Cartesian coordinates in which an object is defined. cps. Characters per second. CPU. Central processing unit. CRC. Cyclic redundancy check. CRT. Cathode ray tube. CRT display. Cathode ray tube display. CTS. Clear to send. Associated with modem control. cursor. (1) In computer graphics, a movable marker that is used to indicate position on a display. (2) A displayed symbol that acts as a marker to help the user locate a point in text, in a system command, or in storage. (3) A movable spot of light on the screen of a display device, usually indicating where the next character is to be entered, replaced, or deleted. cyclic redundancy check (CRC). (1) A redundancy check in which the check key is generated by a cyclic algorithm. (2) A system of error checking performed at both the sending and receiving station after a block-check character has been accumulated. cylinder. (1) The set of all tracks with the same nominal distance from the axis about which the disk rotates. (2) The tracks of a disk storage device that can be accessed without repositioning the access mechanism. daisy-chained cable. A type of cable that has two or more connectors attached in series. data. (1) A representation of facts, concepts, or instructions in a formalized manner suitable for communication, interpretation, or processing by human or automatic means. (2) Any representations, such as characters or analog quantities, to which meaning is, or might be assigned. data base. A collection of data that can be immediately accessed and operated upon by a data processing system for a specific purpose. data processing system. A system that performs input, processing, storage, output, and control functions to accomplish a sequence of operations on data. data transmission. Synonym for transmission. dB. Decibel. dBa. Adjusted decibels. dc. Direct current. debounce. (1) An electronic means of overcoming the make/break bounce of switches to obtain one smooth change of signal level. (2) The elimination of undesired signal variations caused by mechanically generated signals from contacts. decibel. (1) A unit that expresses the ratio of two power levels on a logarithmic scale. (2) A unit for measuring relative power. decoupling capacitor. A capacitor that provides a low impedance path to ground to prevent common coupling between circuits. **Deutsche Industrie Norm (DIN).** (1) German Industrial Norm. (2) The committee that sets German dimension standards. digit. (1) A graphic character that represents an integer; for example, one of the characters 0 to 9. (2) A symbol that represents one of the non-negative integers smaller than the radix. For example, in decimal notation, a digit is one of the characters 0 to 9. digital. (1) Pertaining to data in the form of digits. (2) Contrast with analog. DIN. Deutsche Industrie Norm. **DIN connector.** One of the connectors specified by the DIN committee. DIP. Dual in-line package. **DIP switch.** One of a set of small switches mounted in a dual in-line package. direct current (dc). A current that always flows in one direction. direct memory access (DMA). A method of transferring data between main storage and I/O devices that does not require processor intervention. disable. To stop the operation of a circuit or device. disabled. Pertaining to a state of a processing unit that prevents the occurrence of certain types of interruptions. Synonymous with masked. disk. Loosely, a magnetic disk. diskette. A thin, flexible magnetic disk and a semirigid protective jacket, in which the disk is permanently enclosed. Synonymous with flexible disk. diskette drive. A device for storing data on and retrieving data from a diskette. display. (1) A visual presentation of data. (2) A device for visual presentation of information on any temporary character imaging device. (3) To present data visually. (4) See cathode ray tube display. display attribute. In computer graphics, a particular property that is assigned to all or part of a display; for example, low intensity, green color, blinking status. display element. In computer graphics, a basic graphic element that can be used to construct a display image; for example, a dot, a line segment, a character. display group. In computer graphics, a collection of display elements that can be manipulated as a unit and that can be further combined to form larger groups. display image. In computer graphics, a collection of display elements or display groups that are represented together at any one time in a display space. display space. In computer graphics, that portion of a display surface available for a display image. The display space may be all or part of a display surface. display surface. In computer graphics, that medium on which display images may appear; for example, the entire screen of a cathode ray tube. **DMA.** Direct memory access. dot matrix. (1) In computer graphics, a two-dimensional pattern of dots used for constructing a display image. This type of matrix can be used to represent characters by dots. (2) In word processing, a pattern of dots used to form characters. This term normally refers to a small section of a set of addressable points; for example, a representation of characters by dots. dot printer. Synonym for matrix printer. dot-matrix character generator. In computer graphics, a character generator that generates character images composed of dots. drawing primitive. A group of commands that draw defined geometric shapes. **DSR.** Data set ready. Associated with modem control. **DTR.** In the IBM Personal Computer, data terminal ready. Associated with modem control. dual in-line package (DIP). A widely used container for an integrated circuit. DIPs have pins in two parallel rows. The pins are spaced 1/10 inch apart. See also DIP switch. duplex. (1) In data communication, pertaining to a simultaneous two-way independent transmission in both directions. (2) Contrast with half-duplex. duty cycle. In the operation of a device, the ratio of on time to idle time. Duty cycle is expressed as a decimal or percentage. dynamic memory. RAM using transistors and capacitors as the memory elements. This memory requires a refresh (recharge) cycle every few milliseconds. Contrast with static memory. EBCDIC. Extended binary-coded decimal interchange code. ECC. Error checking and correction. edge connector. A terminal block with a number of contacts attached to the edge of a printed-circuit board to facilitate plugging into a foundation circuit. EIA. Electronic Industries Association. **electromagnet.** Any device that exhibits magnetism only while an electric current flows through it. enable. To initiate the operation of a circuit or device. end of block (EOB). A code that marks the end of a block of data. end of file (EOF). An internal label, immediately following the last record of a file, signaling the end of that file. It may include control totals for comparison with counts accumulated during processing. end-of-text (ETX). A transmission control character used to terminate text. end-of-transmission (EOT). A transmission control character used to indicate the conclusion of a transmission, which may have included one or more texts and any associated message headings. end-of-transmission-block (ETB). A transmission control character used to indicate the end of a transmission block of data when data is divided into such blocks for transmission purposes. EOB. End of block. EOF. End of file. **EOT.** End-of-transmission. EPROM. Erasable programmable read-only memory. erasable programmable read-only memory (EPROM). A PROM in which the user can erase old information and enter new information. error checking and correction (ECC). The detection and correction of all single-bit errors, plus the detection of double-bit and some multiple-bit errors. ESC. The escape character. escape character (ESC). A code extension character used, in some cases, with one or more succeeding characters to indicate by some convention or agreement that the coded representations following the character or the group of characters are to be interpreted according to a different code or according to a different coded character set. ETB. End-of-transmission-block. ETX. End-of-text. extended binary-coded decimal interchange code (EBCDIC). A set of 256 characters, each represented by eight bits. F. Fahrenheit. Fahrenheit (F). A temperature scale. Contrast with Celsius (C). falling edge. Synonym for negative-going edge. FCC. Federal Communications Commission. fetch. To locate and load a quantity of data from storage. **FF.** The form feed character. field. (1) In a record, a specified area used for a particular category of data. (2) In a data base, the smallest unit of data that can be referred to. field-programmable logic sequencer (FPLS). An integrated circuit containing a programmable, read-only memory that responds to external inputs and feedback of its own outputs. FIFO (first-in-first out). A queuing technique in which the next item to be retrieved is the item that has been in the queue for the longest time. fixed disk drive. In the IBM Personal Computer, a unit consisting of nonremovable magnetic disks, and a device for storing data on and retrieving data from the disks. flag. (1) Any of various types of indicators used for identification. (2) A character that signals the occurrence of some condition, such as the end of a word. (3) Deprecated term for mark. flexible disk. Synonym for diskette. flip-flop. A circuit or device containing active elements, capable of assuming either one of two stable states at a given time. font. A family or assortment of characters of a given size and style; for example, 10 point Press Roman medium. foreground. (1) In multiprogramming, the environment in which high-priority programs are executed. (2) On a color display screen, the characters as opposed to the background. form feed. (1) Paper movement used to bring an assigned part of a form to the printing position. (2) In word processing, a function that advances the typing position to the same character position on a predetermined line of the next form or page. form feed character. A control character that causes the print or display position to move to the next predetermined first line on the next form, the next page, or the equivalent. format. The arrangement or layout of data on a data medium. FPLS. Field-programmable logic sequencer. frame. (1) In SDLC, the vehicle for every command, every response, and all information that is transmitted using SDLC procedures. Each frame begins and ends with a flag. (2) In data transmission, the sequence of contiguous bits bracketed by and including beginning and ending flag sequences. ### g. Gram. - G. (1) Prefix giga; 1,000,000,000. (2) When referring to computer storage capacity, 1,073,741,824. (1,073,741,824 = 2 to the 30th power.) - gate. (1) A combinational logic circuit having one output channel and one or more input channels, such that the output channel state is completely determined by the input channel states. (2) A signal that enables the passage of other signals through a circuit. **Gb.** 1,073,741,824 bytes. general-purpose register. A register, usually explicitly addressable within a set of registers, that can be used for different purposes; for example, as an accumulator, as an index register, or as a special handler of data. giga (G). Prefix 1,000,000,000. gram (g). A unit of weight (equivalent to 0.035 ounces). graphic. A symbol produced by a process such as handwriting, drawing, or printing. graphic character. A character, other than a control character, that is normally represented by a graphic. half-duplex. (1) In data communication, pertaining to an alternate, one way at a time, independent transmission. (2) Contrast with duplex. hardware. (1) Physical equipment used in data processing, as opposed to programs, procedures, rules, and associated documentation. (2) Contrast with software. head. A device that reads, writes, or erases data on a storage medium; for example, a small electromagnet used to read, write, or erase data on a magnetic disk. hertz (Hz). A unit of frequency equal to one cycle per second. hex. Common abbreviation for hexadecimal. Also, hexadecimal can be noted as X''. hexadecimal. (1) Pertaining to a selection, choice, or condition that has 16 possible different values or states. These values or states are usually symbolized by the ten digits 0 through 9 and the six letters A through F. (2) Pertaining to a fixed radix numeration system having a radix of 16. high impedance state. A state in which the output of a device is effectively isolated from the circuit. highlighting. In computer graphics, emphasizing a given display group by changing its attributes relative to other display groups in the same display field. high-order position. The leftmost position in a string of characters. See also most-significant digit. hither plane. In computer graphics, a plane that is perpendicular to the line joining the viewing reference point and the view point and that lies between these two points. Any part of an object between the hither plane and the view point is not seen. See also yon plane. housekeeping. Operations or routines that do not contribute directly to the solution of the problem but do contribute directly to the operation of the computer. #### Hz. Hertz image. A fully processed unit of operational data that is ready to be transmitted to a remote unit; when loaded into control storage in the remote unit, the image determines the operations of the unit. immediate instruction. An instruction that contains within itself an operand for the operation specified, rather than an address of the operand. index register. A register whose contents may be used to modify an operand address during the execution of computer instructions. indicator. (1) A device that may be set into a prescribed state, usually according to the result of a previous process or on the occurrence of a specified condition in the equipment, and that usually gives a visual or other indication of the existence of the prescribed state, and that may in some cases be used to determine the selection among alternative processes; for example, an overflow indicator. (2) An item of data that may be interrogated to determine whether a particular condition has been satisfied in the execution of a computer program; for example, a switch indicator, an overflow indicator. inhibited. (1) Pertaining to a state of a processing unit in which certain types of interruptions are not allowed to occur. (2) Pertaining to the state in which a transmission control unit or an audio response unit cannot accept incoming calls on a line. initialize. To set counters, switches, addresses, or contents of storage to 0 or other starting values at the beginning of, or at prescribed points in, the operation of a computer routine. input/output (I/O). (1) Pertaining to a device or to a channel that may be involved in an input process, and, at a different time, in an output process. In the English language, "input/output" may be used in place of such terms as "input/output data," "input/output signal," and "input/output terminals," when such usage is clear in a given context. (2) Pertaining to a device whose parts can be performing an input process and an output process at the same time. (3) Pertaining to either input or output, or both. **instruction.** In a programming language, a meaningful expression that specifies one operation and identifies its operands, if any. **instruction set.** The set of instructions of a computer, of a programming language, or of the programming languages in a programming system. intensity. In computer graphics, the amount of light emitted at a display point interface. A device that alters or converts actual electrical signals between distinct devices, programs, or systems. interleave. To arrange parts of one sequence of things or events so that they alternate with parts of one or more other sequences of the same nature and so that each sequence retains its identity. interrupt. (1) A suspension of a process, such as the execution of a computer program, caused by an event external to that process, and performed in such a way that the process can be resumed. (2) In a data transmission, to take an action at a receiving station that causes the transmitting station to terminate a transmission. (3) Synonymous with interruption. I/O. Input/output. I/O area. Synonym for buffer. irrecoverable error. An error that makes recovery impossible without the use of recovery techniques external to the computer program or run. joystick. In computer graphics, a lever that can pivot in all directions and that is used as a locator device. k. Prefix kilo; 1000. **K.** When referring to storage capacity, 1024. (1024 = 2 to the 10th power.) X-18 Glossary **KB.** 1024 bytes. **key lock.** A device that deactivates the keyboard and locks the cover on for security. kg. Kilogram; 1000 grams. kHz. Kilohertz; 1000 hertz. kilo (k). Prefix 1000 kilogram (kg). 1000 grams. kilohertz (kHz). 1000 hertz latch. (1) A simple logic-circuit storage element. (2) A feedback loop in sequential digital circuits used to maintain a state. **least-significant digit.** The rightmost digit. See also low-order position. LED. Light-emitting diode. **light-emitting diode (LED).** A semiconductor device that gives off visible or infrared light when activated. load. In programming, to enter data into storage or working registers. look-up table (LUT). (1) A technique for mapping one set of values into a larger set of values. (2) In computer graphics, a table that assigns a color value (red, green, blue intensities) to a color index. low power Schottky TTL. A version (LS series) of TTL giving a good compromise between low power and high speed. See also transistor-transistor logic and Schottky TTL. **low-order position.** The rightmost position in a string of characters. See also least-significant digit. luminance. The luminous intensity per unit projected area of a given surface viewed from a given direction. - LUT. Look-up table. - m. (1) Prefix milli; 0.001. (2) Meter. - M. (1) Prefix mega; 1,000,000. (2) When referring to computer storage capacity, 1,048,576. (1,048,576 = 2 to the 20th power.) - mA. Milliampere; 0.001 ampere. - machine code. The machine language used for entering text and program instructions onto the recording medium or into storage and which is subsequently used for processing and printout. - machine language. (1) A language that is used directly by a machine. (2) Deprecated term for computer instruction code. - magnetic disk. (1) A flat circular plate with a magnetizable surface layer on which data can be stored by magnetic recording. (2) See also diskette. - main storage. (1) Program-addressable storage from which instructions and other data can be loaded directly into registers for subsequent execution or processing. (2) Contrast with auxiliary storage. - mark. A symbol or symbols that indicate the beginning or the end of a field, of a word, of an item of data, or of a set of data such as a file, a record, or a block. - mask. (1) A pattern of characters that is used to control the retention or elimination of portions of another pattern of characters. (2) To use a pattern of characters to control the retention or elimination of portions of another pattern of characters. - masked. Synonym for disabled. - matrix. (1) A rectangular array of elements, arranged in rows and columns, that may be manipulated according to the rules of matrix algebra. (2) In computers, a logic network in the form of an array of input leads and output leads with logic elements connected at some of their intersections. matrix printer. A printer in which each character is represented by a pattern of dots; for example, a stylus printer, a wire printer. Synonymous with dot printer. **MB.** 1,048,576 bytes. mega (M). Prefix 1,000,000. megahertz (MHz). 1,000,000 hertz. memory. Term for main storage. meter (m). A unit of length (equivalent to 39.37 inches). MFM. Modified frequency modulation. MHz. Megahertz; 1,000,000 hertz. **micro** ( $\mu$ ). Prefix 0.000,001. microcode. (1) One or more microinstructions. (2) A code, representing the instructions of an instruction set, implemented in a part of storage that is not program-addressable. microinstruction. (1) An instruction of microcode. (2) A basic or elementary machine instruction. microprocessor. An integrated circuit that accepts coded instructions for execution; the instructions may be entered, integrated, or stored internally. microsecond ( $\mu$ s). 0.000,001 second. **milli (m).** Prefix 0.001. milliampere (mA). 0.001 ampere. millisecond (ms). 0.001 second. mnemonic. A symbol chosen to assist the human memory; for example, an abbreviation such as "mpy" for "multiply." mode. (1) A method of operation; for example, the binary mode, the interpretive mode, the alphanumeric mode. (2) The most frequent value in the statistical sense. modeling transformation. Operations on the coordinates of an object (usually matrix multiplications) that cause the object to be rotated about any axis, translated (moved without rotating), and/or scaled (changed in size along any or all dimensions). See also viewing transformation. modem (modulator-demodulator). A device that converts serial (bit by bit) digital signals from a business machine (or data communication equipment) to analog signals that are suitable for transmission in a telephone network. The inverse function is also performed by the modem on reception of analog signals. modified frequency modulation (MFM). The process of varying the amplitude and frequency of the 'write' signal. MFM pertains to the number of bytes of storage that can be stored on the recording media. The number of bytes is twice the number contained in the same unit area of recording media at single density. modulation. The process by which some characteristic of one wave (usually high frequency) is varied in accordance with another wave or signal (usually low frequency). This technique is used in modems to make business-machine signals compatible with communication facilities. modulation rate. The reciprocal of the measure of the shortest nominal time interval between successive significant instants of the modulated signal. If this measure is expressed in seconds, the modulation rate is expressed in baud. module. (1) A program unit that is discrete and identifiable with respect to compiling, combining with other units, and loading. (2) A packaged functional hardware unit designed for use with other components. **modulo check.** A calculation performed on values entered into a system. This calculation is designed to detect errors. modulo-N check. A check in which an operand is divided by a number N (the modulus) to generate a remainder (check digit) that is retained with the operand. For example, in a modulo-7 check, the remainder will be 0, 1, 2, 3, 4, 5, or 6. The operand is later checked by again dividing it by the modulus; if the remainder is not equal to the check digit, an error is indicated. modulus. In a modulo-N check, the number by which the operand is divided. monitor. Synonym for cathode ray tube display (CRT display). most-significant digit. The leftmost (non-zero) digit. See also high-order position. ms. Millisecond; 0.001 second. multiplexer. A device capable of interleaving the events of two or more activities, or capable of distributing the events of an interleaved sequence to the respective activities. multiprogramming. (1) Pertaining to the concurrent execution of two or more computer programs by a computer. (2) A mode of operation that provides for the interleaved execution of two or more computer programs by a single processor. n. Prefix nano; 0.000,000,001. NAND. A logic operator having the property that if P is a statement, Q is a statement, R is a statement,..., then the NAND of P, Q, R,... is true if at least one statement is false, false if all statements are true. **NAND gate.** A gate in which the output is 0 only if all inputs are 1. nano (n). Prefix 0.000,000,001. **nanosecond (ns).** 0.000,000,001 second. negative true. Synonym for active low. **negative-going edge.** The edge of a pulse or signal changing in a negative direction. Synonymous with falling edge. non-return-to-zero change-on-ones recording (NRZI). A transmission encoding method in which the data terminal equipment changes the signal to the opposite state to send a binary 1 and leaves it in the same state to send a binary 0. **non-return-to-zero (inverted) recording (NRZI).** Deprecated term for non-return-to-zero change-on-ones recording. **NOR.** A logic operator having the property that if P is a statement, Q is a statement, R is a statement,..., then the NOR of P, Q, R,... is true if all statements are false, false if at least one statement is true. **NOR gate.** A gate in which the output is 0 only if at least one input is 1. NOT. A logical operator having the property that if P is a statement, then the NOT of P is true if P is false, false if P is true. NRZI. Non-return-to-zero change-on-ones recording. ns. Nanosecond; 0.000,000,001 second. **NUL.** The null character. null character (NUL). A control character that is used to accomplish media-fill or time-fill, and that may be inserted into or removed from, a sequence of characters without affecting the meaning of the sequence; however, the control of the equipment or the format may be affected by this character. odd-even check. Synonym for parity check. offline. Pertaining to the operation of a functional unit without the continual control of a computer. one-shot. A circuit that delivers one output pulse of desired duration for each input (trigger) pulse. open circuit. (1) A discontinuous circuit; that is, one that is broken at one or more points and, consequently, cannot conduct current. Contrast with closed circuit. (2) Pertaining to a no-load condition; for example, the open-circuit voltage of a power supply. ### X-24 Glossary open collector. A switching transistor without an internal connection between its collector and the voltage supply. A connection from the collector to the voltage supply is made through an external (pull-up) resistor. operand. (1) An entity to which an operation is applied. (2) That which is operated upon. An operand is usually identified by an address part of an instruction. operating system. Software that controls the execution of programs; an operating system may provide services such as resource allocation, scheduling, input/output control, and data management. OR. A logic operator having the property that if P is a statement, Q is a statement, R is a statement,..., then the OR of P, Q, R,...is true if at least one statement is true, false if all statements are false. **OR gate.** A gate in which the output is 1 only if at least one input is 1. **output.** Pertaining to a device, process, or channel involved in an output process, or to the data or states involved in an output process. output process. (1) The process that consists of the delivery of data from a data processing system, or from any part of it. (2) The return of information from a data processing system to an end user, including the translation of data from a machine language to a language that the end user can understand. overcurrent. A current of higher than specified strength. overflow indicator. (1) An indicator that signifies when the last line on a page has been printed or passed. (2) An indicator that is set on if the result of an arithmetic operation exceeds the capacity of the accumulator. **overrun.** Loss of data because a receiving device is unable to accept data at the rate it is transmitted. overvoltage. A voltage of higher than specified value. parallel. (1) Pertaining to the concurrent or simultaneous operation of two or more devices, or to the concurrent performance of two or more activities. (2) Pertaining to the concurrent or simultaneous occurrence of two or more related activities in multiple devices or channels. (3) Pertaining to the simultaneous processing of the individual parts of a whole, such as the bits of a character and the characters of a word, using separate facilities for the various parts. (5) Contrast with serial. parameter. (1) A variable that is given a constant value for a specified application and that may denote the application. (2) A name in a procedure that is used to refer to an argument passed to that procedure. parity bit. A binary digit appended to a group of binary digits to make the sum of all the digits either always odd (odd parity) or always even (even parity). parity check. (1) A redundancy check that uses a parity bit. (2) Synonymous with odd-even check. PEL. Picture element. personal computer. A small home or business computer that has a processor and keyboard and that can be connected to a television or some other monitor. An optional printer is usually available. **phototransistor.** A transistor whose switching action is controlled by light shining on it. picture element (PEL). The smallest displayable unit on a display. polling. (1) Interrogation of devices for purposes such as to avoid contention, to determine operational status, or to determine readiness to send or receive data. (2) The process whereby stations are invited, one at a time, to transmit. port. An access point for data entry or exit. positive true. Synonym for active high. **positive-going edge.** The edge of a pulse or signal changing in a positive direction. Synonymous with rising edge. potentiometer. A variable resistor with three terminals, one at each end and one on a slider (wiper). **power supply.** A device that produces the power needed to operate electronic equipment. **printed circuit.** A pattern of conductors (corresponding to the wiring of an electronic circuit) formed on a board of insulating material. **printed-circuit board.** A usually copper-clad plastic board used to make a printed circuit. **priority.** A rank assigned to a task that determines its precedence in receiving system resources. **processing program.** A program that performs such functions as compiling, assembling, or translating for a particular programming language. **processing unit.** A functional unit that consists of one or more processors and all or part of internal storage. processor. (1) In a computer, a functional unit that interprets and executes instructions. (2) A functional unit, a part of another unit such as a terminal or a processing unit, that interprets and executes instructions. (3) Deprecated term for processing program. (4) See microprocessor. **program.** (1) A series of actions designed to achieve a certain result. (2) A series of instructions telling the computer how to handle a problem or task. (3) To design, write, and test computer programs. **programmable read-only memory (PROM).** A read-only memory that can be programmed by the user. programming language. (1) An artificial language established for expressing computer programs. (2) A set of characters and rules with meanings assigned prior to their use, for writing computer programs. **programming system.** One or more programming languages and the necessary software for using these languages with particular automatic data-processing equipment. **PROM.** Programmable read-only memory. propagation delay. (1) The time necessary for a signal to travel from one point on a circuit to another. (2) The time delay between a signal change at an input and the corresponding change at an output. protocol. (1) A specification for the format and relative timing of information exchanged between communicating parties. (2) The set of rules governing the operation of functional units of a communication system that must be followed if communication is to be achieved. **pulse.** A variation in the value of a quantity, short in relation to the time schedule of interest, the final value being the same as the initial value. radio frequency (RF). An ac frequency that is higher than the highest audio frequency. So called because of the application to radio communication. radix. (1) In a radix numeration system, the positive integer by which the weight of the digit place is multiplied to obtain the weight of the digit place with the next higher weight; for example, in the decimal numeration system the radix of each digit place is 10. (2) Another term for base. radix numeration system. A positional representation system in which the ratio of the weight of any one digit place to the weight of the digit place with the next lower weight is a positive integer (the radix). The permissible values of the character in any digit place range from 0 to one less than the radix. RAM. Random access memory. Read/write memory. random access memory (RAM). Read/write memory. **RAS.** In the IBM Personal Computer, row address strobe. raster. In computer graphics, a predetermined pattern of lines that provides uniform coverage of a display space. read. To acquire or interpret data from a storage device, from a data medium, or from another source. **read-only memory (ROM).** A storage device whose contents cannot be modified. The memory is retained when power is removed. read/write memory. A storage device whose contents can be modified. Also called RAM. recoverable error. An error condition that allows continued execution of a program. **red-green-blue-intensity (RGBI).** The description of a direct-drive color monitor that accepts input signals of red, green, blue, and intensity. **redundancy check.** A check that depends on extra characters attached to data for the detection of errors. See cyclic redundancy check. register. (1) A storage device, having a specified storage capacity such as a bit, a byte, or a computer word, and usually intended for a special purpose. (2) A storage device in which specific data is stored. retry. To resend the current block of data (from the last EOB or ETB) a prescribed number of times, or until it is entered correctly or accepted. reverse video. A form of highlighting a character, field, or cursor by reversing the color of the character, field, or cursor with its background; for example, changing a red character on a black background to a black character on a red background. RF. Radio frequency. **RF modulator.** The device used to convert the composite video signal to the antenna level input of a home TV. **RGBI.** Red-green-blue-intensity. Glossary X-29 rising edge. Synonym for positive-going edge. ROM. Read-only memory. **ROM/BIOS.** The ROM resident basic input/output system, which provides the level control of the major I/O devices in the computer system. row address strobe (RAS). A signal that latches the row address in a memory chip. **RS-232C.** A standard by the EIA for communication between computers and external equipment. RTS. Request to send. Associated with modem control. run. A single continuous performance of a computer program or routine. **saturation.** In computer graphics, the purity of a particular hue. A color is said to be saturated when at least one primary color (red, blue, or green) is completely absent. scaling. In computer graphics, enlarging or reducing all or part of a display image by multiplying the coordinates of the image by a constant value. **schematic.** The representation, usually in a drawing or diagram form, of a logical or physical structure. Schottky TTL. A version (S series) of TTL with faster switching speed, but requiring more power. See also transistor-transistor logic and low power Schottky TTL. SDL. Shielded Data Link SDLC. Synchronous Data Link Control. sector. That part of a track or band on a magnetic drum, a magnetic disk, or a disk pack that can be accessed by the magnetic heads in the course of a predetermined rotational displacement of the particular device. **SERDES.** Serializer/deserializer. X-30 Glossary serial. (1) Pertaining to the sequential performance of two or more activities in a single device. In English, the modifiers serial and parallel usually refer to devices, as opposed to sequential and consecutive, which refer to processes. (2) Pertaining to the sequential or consecutive occurrence of two or more related activities in a single device or channel. (3) Pertaining to the sequential processing of the individual parts of a whole, such as the bits of a character or the characters of a word, using the same facilities for successive parts. (4) Contrast with parallel. serializer/deserializer (SERDES). A device that serializes output from, and deserializes input to, a business machine. setup. (1) In a computer that consists of an assembly of individual computing units, the arrangement of interconnections between the units, and the adjustments needed for the computer to operate. (2) The preparation of a computing system to perform a job or job step. Setup is usually performed by an operator and often involves performing routine functions, such as mounting tape reels. (3) The preparation of the system for normal operation. short circuit. A low-resistance path through which current flows, rather than through a component or circuit. signal. A variation of a physical quantity, used to convey data. sink. A device or circuit into which current drains. software. (1) Computer programs, procedures, and rules concerned with the operation of a data processing system. (2) Contrast with hardware. source. The origin of a signal or electrical energy. square wave. An alternating or pulsating current or voltage whose waveshape is square. square wave generator. A signal generator delivering an output signal having a square waveform. SS. Start-stop. start bit. (1) A signal to a receiving mechanism to get ready to receive data or perform a function. (2) In a start-stop system, a signal preceding a character or block that prepares the receiving device for the reception of the code elements. **start-of-text (STX).** A transmission control character that precedes a text and may be used to terminate the message heading. start-stop system. A data transmission system in which each character is preceded by a start bit and is followed by a stop bit. start-stop (SS) transmission. (1) Asynchronous transmission such that a group of signals representing a character is preceded by a start bit and followed by a stop bit. (2) Asynchronous transmission in which a group of bits is preceded by a start bit that prepares the receiving mechanism for the reception and registration of a character and is followed by at least one stop bit that enables the receiving mechanism to come to an idle condition pending the reception of the next character. static memory. RAM using flip-flops as the memory elements. Data is retained as long as power is applied to the flip-flops. Contrast with dynamic memory. stop bit. (1) A signal to a receiving mechanism to wait for the next signal. (2) In a start-stop system, a signal following a character or block that prepares the receiving device for the reception of a subsequent character or block. storage. (1) A storage device. (2) A device, or part of a device, that can retain data. (3) The retention of data in a storage device. (4) The placement of data into a storage device. strobe. An instrument that emits adjustable-rate flashes of light. Used to measure the speed of rotating or vibrating objects. STX. Start-of-text. symbol. (1) A conventional representation of a concept. (2) A representation of something by reason of relationship, association, or convention. synchronization. The process of adjusting the corresponding significant instants of two signals to obtain the desired phase relationship between these instants. Synchronous Data Link Control (SDLC). A protocol for management of data transfer over a data link. synchronous transmission. (1) Data transmission in which the time of occurrence of each signal representing a bit is related to a fixed time frame. (2) Data transmission in which the sending and receiving devices are operating continuously at substantially the same frequency and are maintained, by means of correction, in a desired phase relationship. syntax. (1) The relationship among characters or groups of characters, independent of their meanings or the manner of their interpretation and use. (2) The structure of expressions in a language. (3) The rules governing the structure of a language. (4) The relationships among symbols. text. In ASCII and data communication, a sequence of characters treated as an entity if preceded and terminated by one STX and one ETX transmission control character, respectively. time-out. (1) A parameter related to an enforced event designed to occur at the conclusion of a predetermined elapsed time. A time-out condition can be cancelled by the receipt of an appropriate time-out cancellation signal. (2) A time interval allotted for certain operations to occur; for example, response to polling or addressing before system operation is interrupted and must be restarted. track. (1) The path or one of the set of paths, parallel to the reference edge on a data medium, associated with a single reading or writing component as the data medium moves past the component. (2) The portion of a moving data medium such as a drum, or disk, that is accessible to a given reading head position. transistor-transistor logic (TTL). A popular logic circuit family that uses multiple-emitter transistors. translate. To transform data from one language to another. transmission. (1) The sending of data from one place for reception elsewhere. (2) In ASCII and data communication, a series of characters including headings and text. (3) The dispatching of a signal, message, or other form of intelligence by wire, radio, telephone, or other means. (4) One or more blocks or messages. For BSC and start-stop devices, a transmission is terminated by an EOT character. (5) Synonymous with data transmission. TTL. Transistor-transistor logic. typematic key. A keyboard key that repeats its function when held pressed. V. Volt. vector. In computer graphics, a directed line segment. video. Computer data or graphics displayed on a cathode ray tube, monitor, or display. view point. In computer graphics, the origin from which angles and scales are used to map virtual space into display space. viewing reference point. In computer graphics, a point in the modeling coordinate space that is a defined distance from the view point. viewing transformation. Operations on the coordinates of an object (usually matrix multiplications) that cause the view of the object to be rotated about any axis, translated (moved without rotating), and/or scaled (changed in size along any or all dimensions). Viewing transformation differs from modeling transformation in that perspective is considered. See also modeling transformation. viewplane. The visible plane of a CRT display screen that completely contains a defined window. viewport. In computer graphics, a predefined part of the CRT display space. volt. The basic practical unit of electric pressure. The potential that causes electrons to flow through a circuit. X-34 Glossary #### W. Watt. watt. The practical unit of electric power. window. (1) A predefined part of the virtual space. (2) The visible area of a viewplane. word. (1) A character string or a bit string considered as an entity. (2) See computer word. write. To make a permanent or transient recording of data in a storage device or on a data medium. write precompensation. The varying of the timing of the head current from the outer tracks to the inner tracks of the diskette to keep a constant 'write' signal. yon plane. In computer graphics, a plane that is perpendicular to the line joining the viewing reference point and the view point, and that lies beyond the viewing reference point. Any part of an object beyond the yon plane is not seen. See also hither plane. ## **Bibliography** - Microprocessor and Peripheral Handbook - INTEL Corporation.210844.001 - Introduction to the iAPX 286 - INTEL Corporation.210308.001 - iAPX 286 Operating Systems Writer's Guide - INTEL Corporation.121960.001 - iAPX 286 Programmer's Reference Manual - INTEL Corporation.210498.001 - iAPX 286 Hardware Reference Manual - INTEL Corporation.210760.001 - Numeric Processor Extension Data Sheet - INTEL Corporation.210920 - 80287 Support Library Reference Manual - INTEL Corporation. 122129 - National Semiconductor Corporation. NS16450 - Motorola Microprocessor's Data Manual - Motorola Inc. Series B ## **Notes:** ### **Index** A | | AAA 6-8 | |---|-------------------------------| | | AAD 6-9 | | | AAD 6-9<br>AAM 6-9 | | | AAS 6-8 | | | access time, | | | track-to-track 8-6 | | | ACK command 4-13 | | | Acknowledge (ACK) | | | command 4-13 | | | ADC 6-6 | | | ADD 6-6 | | | address generation, | | | DMA 1-9 | | | address latch enable 1-35 | | / | address latch enable, | | | buffered 1-32 | | | address mode | | | real 1-4 | | | virtual 1-4 | | | address space, I/O 1-24 | | | address, segment 1-4 | | | addresses, CMOS RAM 1-59 | | | addresses, page register 1-11 | | | AEN 1-35 | | | ALE 8-4 | | | alternate key 4-37 | | | AND 6-10 | | | APL 8-7 | | | application guidelines 8-7 | | | arithmetic instructions 6-6, | | | 6-25 | | _ | ARPL 6-19 | | | ASCII characters 7-3 | ASCII, extended 4-30 В **BALE 1-32** bandwidth 1-7 BASIC 8-7 basic assurance test 4-5 BASIC interrupts 5-6 BAT (basic assurance test) 4-5 **BAT Completion Code** command 4-13 **BAT Failure Code** command 4-13 battery connector 1-75 BHE 1-9 BIOS fixed disk parameters 1-65 BIOS memory map 5-10 BIOS programming hints 5-10 BIOS quick reference 5-14 block diagram keyboard interface 1-54 system xiv system board 1-6 system timer 1-22 board, system 1-3 **BOUND** 6-16 break code 4-4 break key 4-38 buffer, keyboard 4-4 buffered address latch enable 1-32 buffers, video display 8-14 | bus cycle 1-7 | CMP 6-7 | | |------------------------------------------|------------------------------------------------------|---------------| | busy loop 8-17 | CMPS 6-11 | | | bypassing BIOS 8-6 | COBOL 8-7 | | | byte high enable 1-9 | code | | | | device driver 8-15 | | | | machine | | | C | identification 8-19 | | | | machine-sensitive 8-19 | | | | codes | _ | | cabling 4-3 | character 4-30 | | | CALL 6-13 | extended 4-34 | | | caps lock key 4-37 | multitasking | | | CBW 6-9 | function 8-17 | | | channel, I/O 1-24 | command codes, DMA | | | connectors 1-25 | controller 1 1-10 | | | pin assignments 1-28 | command codes, DMA | | | signals 1-31 | controller 2 1-11 | | | channels, DMA 1-9 | commands | | | character codes 4-30 | I/O 8-11 | | | characters 7-3 | keyboard controller 1-56 | | | characters keystrokes, and | commands from the | | | colors 7-14 | system 4-6 | | | classes, wait loop 8-17 | Default Disable 4-7 | | | CLC 6-17 | Echo 4-7 | Α, | | CLD 6-17 | Enable 4-7 | $\overline{}$ | | CLEX 6-27 | Read ID 4-7 | | | CLI 6-17 | Resend 4-8 | | | CLK 1-31 | Reset 4-8 | | | clock and data signals 4-27 | Select Alternate Scan | | | data input 4-29 | Codes 4-8 | | | data output 4-28 | Set All Keys 4-9 | | | data stream 4-27 | Set Default 4-9 | | | clock cycle 1-7 | Set Key Type 4-9 | | | clock line, keyboard 1-58 | Set Typematic | | | clock, real-time 1-59 | Rate/Delay 4-11 | | | clock, system 1-7<br>CMC 6-17 | Set/Reset Status | | | CMC 6-17<br>CMOS RAM 1-59 | Indicators 4-10 | | | CMOS RAM 1-39<br>CMOS RAM addresses 1-59 | commands to the system | | | CMOS RAM addresses 1-39<br>CMOS RAM | ACK (acknowledge) 4-13<br>BAT (basic assurance test) | | | configuration 1-63 | Completion Code 4-13 | <u> </u> | | CMOS RAM I/O | BAT Failure 4-13 | $\overline{}$ | | operations 1-70 | commands to the | | | operations 1-70 | system 4-13 | | | | ayatem 4-13 | | | Echo 4-13 Key Detection Error 4-14 Keyboard ID 4-14 Overrun 4-14 Resend 4-14 comparison instructions 6-23 compatibility, hardware 8-3 condition, wait 8-16 configuration record 1-60 configuration, CMOS RAM 1-63 connectors battery 1-75 I/O channel 1-25 J-1 through J-8 1-27 J-1, J-7 and J-8 1-26 keyboard 1-75 power supply 0utput 3-6 speaker 1-75 system board 1-74 constants instructions 6-24 control key 4-36 control transfer instructions 6-13 controllers DMA 1-7, 1-9, 1-10 interrupt 1-12 refresh 1-7 Coprocessor controls 1-42 coprocessor | DACK 0-3 and 5-7 1-35 DAS 6-8 data area, ROM BIOS 8-14 data input 4-29 data line, keyboard 1-58 data output 4-28 data stream 4-27 data transfer instructions 6-3, 6-22 data transfer rate, diskette 8-6 DEC 6-7, 6-8 decodes, memory 1-12 DECSTP 6-28 Default Disable command 4-7 default segment workspace 5-10 delay, typematic 4-4 description 4-3 buffer 4-4 cabling 4-3 key-code scanning 4-4 keys 4-4 sequencing key-code scanning 4-4 descriptors 1-5 device driver code 8-15 diagnostic checkpoint port 1-42 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | controller, keyboard 1-44 controllers DMA 1-7, 1-9, 1-10 interrupt 1-12 refresh 1-7 Coprocessor controls 1-42 | keys 4-4 sequencing key-code scanning 4-4 descriptors 1-5 device driver code 8-15 diagnostic checkpoint | diskette write current 8-6 DIV 6-9 divide error exception 8-9 DMA address generation 1-9 DMA channels 1-9 DMA controller 1-7 DMA controller 1 1-9 DMA controller 1 command codes 1-10 DMA controller 2 1-10 DMA controller 2 command codes 1-11 DMA controllers 1-9 **DOS** 8-7 DOS function calls 8-10 DOS interrupts 5-6 DRQ0-DRQ3 1-34 DRQ5-DRQ7 1-34 #### E Echo command 4-7, 4-13 Enable command 4-7 enable NMI 1-39 encoding, keyboard 4-30 ENTER 6-16 ESC 6-18 exception, divide error 8-9 extended ASCII 4-30 extended codes 4-34 ### F FABS 6-26 FADD 6-25 FCHS 6-26 FCOM 6-23 FCOMP 6-23 FCOMPP 6-23 FDIV 6-25 FIFO 4-4 FLD 6-22 **FLDLG2** 6-24 FLDLN2 6-24 FLDL2T 6-24 FLDP1 6-24 FLDZ 6-24 FLD1 6-24 FMUL 6-25 FORTRAN 8-7 FPATAN 6-26 **FPREM** 6-26 FREE 6-28 French keyboard 4-41 FRNDINT 6-26 FSCALE 6-26 **FSQRT** 6-25 FST 6-22 **FSTP 6-22** FSUB 6-25 FTST 6-24 function calls, DOS 8-10 function codes, 8-17 multitasking FXAM 6-24 **FXCH 6-23** FXTRACT 6-26 ### G gap length parameter 8-12 generator, refresh request 1-22 German keyboard 4-42 graphics modes 5-8 guidelines, application 8-7 | / | hard code 5-10 hardware compatibility 8-3 hardware interrupts 5-6 HLT 6-17 hooks 8-15 | input port, keyboard controller 1-58 input requirements 3-3 input, keyboard 4-29 inputs, power supply 3-3 INS 6-12 instructions arithmetic 6-6, 6-25 comparison 6-23 constants 6-24 | |---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | I | control transfer 6-13<br>data transfer 6-3, 6-22<br>logic 6-9 | | / | I/O address map 1-38 I/O address space 1-24 I/O addresses 1-38 I/O CH CK 1-32, 1-39 I/O CH RDY 1-33 I/O channel 1-24 connectors 1-25 pin assignments 1-28 signals 1-31 I/O channel check 1-32 I/O channel connectors 1-28 I/O channel ready 1-33 I/O chip select 1-36 I/O commands 8-11 | processor control 6-17 protection control 6-18 rotate 6-9 shift 6-9 string manipulation 6-11 INT 6-16, 6-27 interfaces, multitasking 8-15 interrupt controller 1-12 interrupt mask register 8-13 interrupt service routine 1-33 interrupt sharing 1-14 interrupt, single step 8-8 interrupts BASIC 5-6 | | | I/O CS16 1-36 I/O port (read/write) 1-40 I/O ports, keyboard controller 1-58 I/O read 1-33 I/O write 1-33 IDIV 6-9 IIMUL 6-9 IMR 8-13 IMUL 6-8 IN 6-5 INC 6-6 INCSTP 6-28 input buffer, keyboard controller 1-56 | DOS 5-6 hardware 5-6 program 5-3 program interrupt listing (real mode) 5-5 sharing 1-14 system 1-12 interrupts, program (real mode) 5-5 INTO 6-16 IOR 1-33 IOW 1-33 IRET 6-16 IRQ 2 8-11 IRQ 9 8-4 8-11 | | IRQ3-IRQ15 1-33 | controller input port 1-58 | | |------------------------------|----------------------------------------------------|---------------| | Italian keyboard 4-43 | controller output | | | | buffer 1-56 | | | | controller output | | | J | port 1-58 | | | J | controller status | | | | register 1-54 | | | JB/JNAE 6-14 | controller test inputs 1-58 | | | JBE/JNA 6-14 | data line 1-58 | | | JCXZ 6-16 | encoding 4-30 | | | JE/JZ 6-14 | interface block | | | JL/JNGE 6-14 | diagram 1-54 | | | JLE/JNG 6-14 | layout 1-47, 4-31 | | | JMP 6-13 | routine 4-39 | | | JNB/JAE 6-15 | keyboard buffer 4-4 | | | | keyboard data input 4-29 | | | JNBE/JA 6-15<br>JNE/JNZ 6-15 | keyboard data input 4-29 keyboard data output 4-28 | | | JNL/JGE 6-15 | Keyboard ID command 4-14 | | | JNLE/JG 6-15 | keyboard layouts | | | JNO 6-15 | French 4-41 | | | JNP/JPO 6-15 | German 4-42 | | | JNS 6-15 | Italian 4-43 | | | JO 6-14 | keyboard layouts 4-40 | | | joystick support 5-6 | Spanish 4-44 | | | JP/JPE 6-14 | U.K. English 4-45 | | | JS 6-14 | U.S. English 4-46 | $\overline{}$ | | jumper, RAM 1-43 | keyboard logic diagrams 4-48 | | | Jumpor, Re Livi 1-45 | keyboard scan codes 4-15 | | | | keyboard scan-code outputs | | | <del></del> | scan code set 1 4-16 | | | <b>K</b> | scan code set 2 4-20 | | | | scan code set 2 4-20 scan code set 3 4-24 | | | Key Detection Error | keyboard, French 4-41 | | | command 4-14 | keyboard, German 4-42 | | | key-code scanning 4-4 | keyboard, Italian 4-43 | | | keyboard 4-48 | keyboard, Italian 4-43<br>keyboard, Spanish 4-44 | | | clock line 1-58 | keyboard, U.K. English 4-45 | | | connector 1-75 | keyboard, U.S. English 4-46 | | | controller 1-44 | keys 4-4 | | | controller | alternate 4-37 | | | commands 1-56 | break 4-38 | | | controller I/O ports 1-58 | caps lock 4-37 | $\overline{}$ | | controller input | combinations 4-37 | | | buffer 1-56 | Combinations 4-3/ | | | Dullel 1-30 | | | | | control 4-36 number lock 4-37 pause 4-38 print screen 4-38 scroll lock 4-37 shift 4-36 system request 4-38, 5-6 keys, typematic 4-4 | LOOP 6-15<br>loop, busy 8-17<br>LOOPNZ/LOOPNE 6-16<br>loops, program 8-14<br>LOOPZ/LOOPE 6-15<br>LSL 6-19<br>LTR 6-18 | |---|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------| | | L | M | | | | machine identification | | | LAHF 6-5 | code 8-19 | | | LAR 6-19 | machine-sensitive code 8-19 | | | layout system board 1-76 | make code 4-4 | | | layout, keyboard 1-47, 4-31 | make/break 4-4<br>mask on and off 1-39 | | | layouts French 4-41 | MASTER (I) 1-36 | | | German 4-42 | math coprocessor 2-3, 8-11 | | | Italian 4-43 | math coprocessor | | | layouts 4-40 | controls 1-42 | | | Spanish 4-44 | MEM chip select 1-36 | | , | U.K. English 4-45 | MEM CS16 1-36 | | | U.S. English 4-46 | memory 1-4 | | | LA17-LA23 1-31 | memory decodes 1-12 | | | LDCW 6-27 | memory locations, | | | LDENV 6-27 | reserved 5-9 | | | LDS 6-5 | memory map, BIOS 5-10 | | | LEA 6-5<br>LEAVE 6-16 | memory module packages 1-24 | | | LEAVE 6-16<br>LES 6-5 | MEMR 1-34 | | | LES 0-3<br>LGDT 6-18 | MEMW 1-34<br>MEMW 1-34 | | | LIDT 6-18 | microprocessor 1-4 1-7 | LIDT 6-18 LLDT 6-18 LMSW 6-19 logic diagrams load current 3-3 LOCK 6-17 LODS 6-11 system board 1-77 logic instructions 6-9 line contention 4-28 line protocol 4-6 microprocessor 1-4, 1-7 microprocessor cycle 1-7 modes, graphic 5-8 modules, RAM 1-24 ROM/EPROM 1-23 4-27 modules, MOV 6-3 MOVS 6-11 mode, data stream 1-45, 4-6, | MUL 6-8 multi-tasking function codes 8-17 | Overrun command 4-14 | | |--------------------------------------------------------------------|-----------------------------------------------|---------------| | interfaces 8-17 interfaces 8-15 provisions 8-15 serialization 8-16 | P | | | startup 8-16 | packages, memory<br>module 1-24 | | | | page register addresses 1-11 | $\overline{}$ | | N | parameter | | | <u></u> | gap length 8-12 passing 5-4 | | | NEG 6-8<br>NMI 1-12, 1-39 | tables 8-12 | | | NMI controls 1-39 | parameters, BIOS fixed disk 1-65 | | | no load protection 3-4 | Pascal 8-7 | | | non-maskable interrupt 1-39 | pause key 4-38 | | | NOP 6-26, 6-28<br>NOT 6-11 | performance, system 1-7<br>POP 6-4 | | | Num Lock state 4-34 | POPA 6-4 | | | number lock key 4-37 | POPF 6-6, 8-8 | | | | POR 4-5 | | | | port, diagnostic | | | 0 | checkpoint 1-42<br>post 8-17 | $\overline{}$ | | | power good signal 3-4 | | | operations, CMOS RAM | power requirements 4-47 | | | I/O 1-70 | power supply | | | OR 6-10<br>OSC 1-36 | connectors 1-74 inputs 3-3 | | | oscillator 1-36 | output connectors 3-6 | | | OUT 6-5 | outputs 3-3 | | | output buffer, keyboard | power-on reset 4-5 | | | controller 1-56 | power-on routine 4-5 | | | output port, keyboard controller 1-58 | basic assurance test 4-5 BAT (basic assurance | | | output voltage sense | test) 4-5 | | | levels 3-5 | POR (power-on | | | output voltage | reset) 4-5 | | | sequencing 3-4<br>output, keyboard 4-28 | power-on reset 4-5<br>print screen key 4-38 | | | outputs, power supply 3-3 | priorities, shift key 4-37 | | | OUTS 6-12 | processor control | | | | instructions 6-17 | | | | | | program interrupts 5-3 refresh controller 1-7 program loops 8-14 refresh request programming hints, generator 1-22 **BIOS 5-10** regulation tolerance 3-3 programming, REP/REPNE, coprocessor 2-3 REPZ/REPNZ 6-12 protected mode 1-5, 5-6 requirements, input 3-3 protection control Resend command 4-8, 4-14 instructions 6-18 reserved memory protection, no load 3-4 locations 5-9 protocol 4-6 reserved scan codes 1-52 provisions, multitasking 8-15 Reset command 4-8 PTAN 6-26 RESET DRV 1-32 **PUSH 6-3** reset, power-on 4-5 PUSH SP 8-8 reset, system 4-38 PUSHA 6-4 **RET 6-13 ROM BIOS** PUSHF 6-6 8-10 ROM BIOS data area 8-14 ROM scan codes 4-30 ROM subsystem 1-23 Q ROM/EPROM modules 1-23 quick reference charts rotate instructions 6-9 BIOS 5-14 rotational, speed 8-6 characters keystrokes, and routine, interrupt service 1-33 colors 7-14 routine, keyboard 4-39 **RSTOR** 6-28 ## R R/W memory 1-24 RAM jumper 1-43 RAM modules 1-24 RAM subsystem 1-24 RAM, CMOS 1-59 rate, typematic 4-4, 4-11 Read ID command 4-7 real address mode 1-4, 2-5 real mode 5-3 real-time clock 1-59, 1-60 record, configuration 1-60 REFRESH 1-35 S SAHF 6-5 SAVE 6-28 SA0-SA19 1-31 SBB 6-7 SBHE 1-35 scan code set 1 4-16 scan code set 2 4-20 scan code set 3 4-24 scan code tables (set 1) 4-16 scan code tables (set 2) 4-20 scan code tables (set 3) 4-24 | scan code translation 1-46 | SMEMR 1-34 | |------------------------------|--------------------------------------------| | scan codes, keyboard 4-15 | SMEMW 1-34 | | scan codes, ROM 4-30 | SMSW 6-19 | | scanning, key-code | sound control 8-13 | | sequencing 4-4 | Spanish keyboard 4-44 | | SCAS 6-11 | speaker 1-43 | | scroll lock key 4-37 | speaker connector 1-75 | | SD0-SD15 1-32 | speaker tone generation 1-22 | | segment address 1-4 | special vectors 5-6 | | segments 1-4 | specifications 4-47 | | Select Alternate Scan Codes | power requirements 4-47 | | command 4-8 | size 4-47 | | sense levels, output | system unit 1-72 | | voltage 3-5 | weight 4-47 | | sequencing key-code | startup, multitasking 8-16 | | scanning 4-4 | states | | sequencing, output | Ctrl 4-34 | | voltage 3-4 | Num Lock 4-34 | | serialization, | Shift 4-34, 4-36 | | multitasking 8-16 | status register, keyboard | | Set All Keys commands 4-9 | controller 1-54 | | Set Default command 4-9 | STC 6-17 | | Set Key Type commands 4-9 | STCW 6-27 | | Set Typematic Rate/Delay | STD 6-17 | | command 4-11 | STENV 6-27 | | Set/Reset Status Indicators | STI 6-17 | | command 4-10 | STOS 6-12 | | <b>SETPM 6-27</b> | STR 6-19 | | SGDT 6-18 | stream, data 4-27 | | shift counts 8-9 | string manipulation | | shift instructions 6-9 | instructions 6-11 | | shift key 4-36 | STSW 6-27 | | shift key priorities 4-37 | STSWAX 6-27 | | Shift state 4-34 | SUB 6-7 | | shift states 4-36 | subsystem, RAM 1-24 | | SIDT 6-18 | subsystem, RAM 1-24<br>subsystem, ROM 1-23 | | signals | support joystick 5-6 | | diskette change 8-6 | switch, display 1-44 | | I/O channels 1-31 | system BIOS usage 5-3 | | power good 3-4 | system block diagram xiv | | system clock 8-4 | system board 1-3 | | signals, clock and data 4-27 | system board block | | single step interrupt 8-8 | diagram 1-6 | | SLDT 6-18 | | | | | system board connectors 1-74 system board layout 1-76 system board logic diagrams 1-77 system bus high enable 1-35 system clock 1-7 system clock signal 8-4 system interrupts 1-12 system performance 1-7 system request key 4-38, 5-6 system reset 4-38 system timer block diagram 1-22 system timers 1-22 ### T T/C 1-35 table, translation 1-49 tables, parameter 8-12 terminal count 1-35 **TEST 6-10** test inputs, keyboard controller 1-58 time-outs 8-18 timer/counter 1-22 timer/counters 1-22 timers, system 1-22 tone generation, speaker 1-22 track density, diskette 8-6 track-to-track access time 8-6 translation table 1-49 translation, scan code 1-46 tri-state 1-36 type of display switch 1-44 typematic delay 4-4 typematic keys 4-4 typematic rate 4-4, 4-11 U.K. English keyboard 4-45 U.S. English keyboard 4-46 ### V vectors, special 5-6 VERR 6-19 video display buffers 8-14 virtual address mode 1-4, 2-5 #### W WAIT 6-17 wait condition 8-16 wait loop classes 8-17 workspace, default segment 5-10 write current, diskette 8-6 ### X XCHG 6-4 XLAT 6-5 XOR 6-11 ### Y YL2XP1 6-27 Z ### Numerics zero wait state 1-37 0WS 1-37 2XM1 6-26 80286 1-4 8042 1-44 8237A-5 1-9 8254-2 1-22 8259A Interrupt 1-12 # Notes: # **Notes:**