IBM Personal Computer Hardware Reference Library # Technical Reference Options and Adapters Volume 2 # Technical Reference Options and Adapters Volume 2 #### **Revised Edition (April 1984)** 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 manual "as is," without warranty of any kind, either expressed or implied, including, but not limited to the particular purpose. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this manual at any time. This product could include technical inaccuracies or typographical errors. Changes are made periodically to the information herein; these changes will be incorporated in new editions of the publication. It is possible that this material may contain reference to, or information about, IBM products (machines or 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. Products are not stocked at the address below. Requests for copies of this product and for technical information about the system should be made to your authorized IBM Personal Computer dealer. The following paragraph applies only to the United States and Puerto Rico: A Reader's Comment Form is provided at the back of this publication. If the form has been removed, address comments to: IBM Corp., Personal Computer, P.O. Box 1328-C, Boca Raton, Florida 33432. IBM may use or distribute any of the information you supply in any way it believes appropriate without incurring any obligations whatever. © Copyright International Business Machines Corporation 1981, 1982, 1983, 1984 # **Federal Communications Commission Radio Frequency Interference Statement** Warning: The equipment described herein has been certified to comply with the limits for a Class B computing device, pursuant to Subpart J of Part 15 of the FCC rules. Only peripherals (computer input/output devices, terminals, printers, etc.) certified to comply with the Class B limits may be attached to the computer. Operation with non-certified peripherals is likely to result in interference to radio and TV reception. If peripherals not offered by IBM are used with the equipment, it is suggested to use shielded grounded cables with in-line filters if necessary. #### CAUTION The product described herein is equipped with a grounded plug for the user's safety. It is to be used in conjunction with a properly grounded receptacle to avoid electrical shock. # IBM Monochrome Display and Printer Adapter # **Contents** | Introduction | |-------------------------------------| | Monochrome Display Adapter Function | | Description | | Programming Considerations 5 | | Specifications 9 | | Printer Adapter Function | | Description | | Programming Considerations | | Specifications | | Logic Diagrams | #### Introduction The IBM Monochrome Display and Printer Adapter has two functions. The first is to provide an interface to the IBM Monochrome Display. The second is to provide a parallel interface for the IBM Printers. We will discuss this adapter by function. ## **Monochrome Display Adapter Function** ### **Description** The IBM Monochrome Display and Printer Adapter is designed around the Motorola 6845 CRT Controller module. There are 4K bytes of RAM on the adapter that are used for the display buffer. This buffer has two ports to which the system unit's microprocessor has direct access. No parity is provided on the display buffer. Two bytes are fetched from the display buffer in 553 ns, providing a data rate of 1.8M bytes/second. The adapter supports 256 different character codes. An 8K-byte character generator contains the fonts for the character codes. The characters, values, and screen characteristics are given in "Of Characters, Keystrokes, and Colors" in your *Technical Reference* system manual. This adapter, when used with a display containing P39 phosphor, does not support a light pen. Where possible, only one low-power Schottky (LS) load is present on any I/O slot. Some of the address bus lines have two LS loads. No signal has more than two LS loads. #### Characteristics of the adapter are: - Supports 80-character by 25-line screen - Has direct-drive output - Supports 9-PEL by 14-PEL character box - Supports 7-PEL by 9-PEL character - Has 18-kHz monitor - Has character attributes The following is a block diagram of the monochrome display adapter portion of the IBM Monochrome Display and Printer Adapter. **IBM Monochrome Display Adapter Block Diagram** ## **Programming Considerations** The following table summarizes the 6845 controller module's internal data registers, their functions, and their parameters. For the IBM Monochrome Display, the values must be programmed into the 6845 to ensure proper initialization of the display. | Register<br>Number | Register<br>File | 1 1 | | |--------------------|------------------------------|----------------|----| | RO | Horizontal Total | Characters | 61 | | R1 | Horizontal Displayed | Characters | 50 | | R2 | Horizontal Sync Position | Characters | 52 | | R3 | Horizontal Sync Width | Characters | F | | R4 | Vertical Total | Character Rows | 19 | | R5 | Vertical Total Adjust | Scan Line | 6 | | R6 | Vertical Displayed | Character Row | 19 | | R7 | Vertical Sync Position | Character Row | 19 | | R8 | Interlace Mode | | 02 | | R9 | Maximum Scan Line<br>Address | Scan Line | D | | R10 | Cursor Start | Scan Line | В | | R11 | Cursor End | Scan Line | С | | R12 | Start Address (H) | | 00 | | R13 | Start Address (L) | | 00 | | R14 | Cursor (H) | | 00 | | R15 | Cursor (L) | | 00 | | R16 | Reserved | | | | R17 | Reserved | | | To ensure proper initialization, the first command issued to the IBM Monochrome Display and Printer Adapter must be sent to the CRT control port 1 (hex 3B8), and must be a hex 01, to set the high-resolution mode. If this bit is not set, the system unit's microprocessor's access to the adapter must never occur. If the high-resolution bit is not set, the system unit's microprocessor will stop running. System configurations that have both an IBM Monochrome Display and Printer Adapter, and an IBM Color/Graphics Monitor Adapter, must ensure that both adapters are properly initialized after a power-on reset. Damage to either display may occur if not properly initialized. The IBM Monochrome Display and Printer Adapter supports 256 different character codes. In the character set are alphanumerics and block graphics. Each character in the display buffer has a corresponding character attribute. The character code must be an even address, and the attribute code must be an odd address in the display buffer. The adapter decodes the character attribute byte as defined above. The blink and intensity bits may be combined with the foreground and background bits to further enhance the character attribute functions listed below: | Background<br>R G B | Foreground<br>R G B | Function | | |---------------------|---------------------|------------------------------------------------|--| | 0 0 0 | 0 0 0 | Non-Display<br>Underline | | | 0 0 0 1 1 1 | 1 1 1 | White Character/Black Background Reverse Video | | The 4K display buffer supports one screen of the 25 rows of 80 characters, plus a character attribute for each display character. The starting address of the buffer is hex B0000. The display buffer can be read using direct memory access (DMA); however, at least one wait state will be inserted by the system unit's microprocessor. The duration of the wait state will vary, because the microprocessor/monitor access is synchronized with the character clock on this adapter. #### 6 Monochrome Adapter Interrupt level 7 is used on the parallel interface. Interrupts can be enabled or disabled through the printer control port. The interrupt is a high-level active signal. The following table breaks down the functions of the I/O address decode for the adapter. The I/O address decode is from hex 3B0 through hex 3BF. The bit assignment for each I/O address follows: | I/O Register<br>Address | Function | | | |-------------------------|----------------------|--|--| | 3B0 | Not Used | | | | 3B1 | Not Used | | | | 3B2 | Not Used | | | | 3B3 | Not Used | | | | 3B4 | 6845 Index Register | | | | 3B5 | 6845 Data Register | | | | 3B6 | Not Used | | | | 3B7 | Not Used | | | | 3B8 | CRT Control Port 1 | | | | 3B9 | Reserved | | | | ЗВА | CRT Status Port | | | | 3BB | Reserved | | | | 3BC | Parallel Data Port | | | | 3BD | Printer Status Port | | | | 3BE | Printer Control Port | | | | 3BF | Not Used | | | I/O Address and Bit Map | Bit<br>Number | Function | |---------------|------------------------| | 0 | + High Resolution Mode | | 1 | Not Used | | 2 | Not Used | | 3 | + Video Enable | | 4 | Not Used | | 5 | + Enable Blink | | 6,7 | Not Used | #### 6845 CRT Control Port 1 (Hex 3B8) | Bit<br>Number | Function | |---------------|---------------------| | 0 | + Horizontal Drive | | 1 | Reserved | | 2 | Reserved | | 3 | + Black/White Video | #### 6845 CRT Status Port (Hex 3BA) # **Specifications** At Standard TTL Levels | | Ground | | 1 | | |------------|--------------|----------|---|-----------------------------| | | Ground | | 2 | 1 | | | | Not Used | 3 | 7 | | <b>ІВМ</b> | | Not Used | 4 | IBM<br>Monochrome | | Monochrome | | Not Used | | | | Display | + Intensity | | 6 | Display and Printer Adapter | | | + Video | | 7 | | | | + Horizontal | | 8 | | | | – Vertical | | 9 | | | | | | | | Signal voltages are 0.0 to 0.6 Vdc at down level and +2.4 to 3.5Note: Vdc at high level. #### **Connector Specifications** # **Printer Adapter Function** ### **Description** The printer adapter portion of the IBM Monochrome Display and Printer Adapter is specifically designed to attach printers with a parallel-port interface, but it can be used as a general input/output port for any device or application that matches its input/output capabilities. It has 12 TTL-buffer output points, which are latched and can be written and read under program control using the microprocessor In or Out instruction. The adapter also has five steady-state input points that may be read using the microprocessor's In instructions. In addition, one input can also be used to create a microprocessor interrupt. This interrupt can be enabled and disabled under program control. A reset from the power-on circuit is also ORed with a program output point, allowing a device to receive a 'power-on reset' when the system unit's microprocessor is reset. The input/output signals are made available at the back of the adapter through a right-angle, printed-circuit-board-mounted, 25-pin, D-shell connector. This connector protrudes through the rear panel of the system unit or expansion unit, where a cable may be attached. When this adapter is used to attach a printer, data or printer commands are loaded into an 8-bit, latched, output port, and the strobe line is activated, writing data to the printer. The program then may read the input ports for printer status indicating when the next character can be written, or it may use the interrupt line to indicate "not busy" to the software. The output ports may also be read at the card's interface for diagnostic loop functions. This allows faults to be isolated to the adapter or the attaching device. The following is a block diagram of the printer adapter portion of the Monochrome Display and Printer Adapter. **Printer Adapter Block Diagram** ### **Programming Considerations** The printer adapter portion of the IBM Monochrome Display and Printer Adapter responds to five I/O instructions: two output and three input. The output instructions transfer data into 2 latches whose outputs are presented on pins of a 25-pin D-shell connector. Two of the three input instructions allow the system unit's microprocessor to read back the contents of the two latches. The third allows the system unit's microprocessor to read the real-time status from a group of pins on the connector. A description of each instruction follows. | IBM Monochrome Display & Printer Adapter | | | | | | | | |------------------------------------------|---------------------------|--|--|--|--|--|--| | 0 | Output to address hex 3BC | | | | | | | | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 | | | | | | | | Pin 9 Pin 8 Pin 7 Pin 6 | | | | | | | | The instruction captures data from the data bus and is present on the respective pins. Each of these pins is capable of sourcing 2.6 mA and sinking 24 mA. It is essential that the external device does not try to pull these lines to ground. | IBM Monochrome Display & Printer Adpater | | | | | |------------------------------------------|---------------|--|--|--| | Output to address hex 3BE | | | | | | | Bit 4 | | | | | | IRQ<br>Enable | | | | This instruction causes the latch to capture the five least significant bits of the data bus. The four least significant bits present their outputs, or inverted versions of their outputs, to the respective pins as shown in the previous figure. If bit 4 is written as a 1, the card will interrupt the system unit's microprocessor on the condition that pin 10 changes from high to low. These pins are driven by open-collector drivers pulled to +5 Vdc through $4.7 \text{ k}\Omega$ resistors. They can each sink approximately 7 mA and maintain 0.8 volts down-level. IBM Monochrome Display & Printer Adapter Input from address hex 3BC This instruction presents the system unit's microprocessor with data present on the pins associated with the output to hex 3BC. This should normally reflect the exact value that was last written to hex 3BC. If an external device should be driving data on these pins at the time of an input (in violation of usage ground rules), this data will be ORed with the latch contents. IBM Monochrome Display & Printer Adapter Input from address hex 3BD This instruction presents the real-time status to the system unit's microprocessor from the pins as follows. | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | |--------|--------|--------|--------|--------|-------|-------|-------| | Pin 11 | Pin 10 | Pin 12 | Pin 13 | Pin 15 | | _ | _ | IBM Monochrome Display & Printer Adapter Input from address hex 3BE This instruction causes the data present on pins 1, 14, 16, 17, and the IRO bit to be read by the system unit's microprocessor. In the absence of external drive applied to these pins, data read by the system unit's microprocessor will match data last written to hex 3BE in the same bit positions. Notice that data bits 0-2 are not included. If external drivers are dotted to these pins, that data will be ORed with data applied to the pins by the hex 3BE latch. | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | |-------|-------|-------|---------------|---------|---------|---------|---------| | | | | IRQ<br>Enable | Pin 17 | Pin 16 | Pin 14 | Pin 1 | | | | | Por = 0 | Por = 1 | Por = 0 | Por = 1 | Por = 1 | These pins assume the states shown after a reset from the system unit's microprocessor. ## **Specifications** **Connector Specifications** Monochrome Display Adapter (Sheet 1 of 10) Monochrome Display Adapter (Sheet 2 of 10) Monochrome Display Adapter (Sheet 3 of 10) Monochrome Display Adapter (Sheet 4 of 10) Monochrome Display Adapter (Sheet 5 of 10) Monochrome Display Adapter (Sheet 6 of 10) Monochrome Display Adapter (Sheet 7 of 10) Monochrome Display Adapter (Sheet 8 of 10) Monochrome Display Adapter (Sheet 9 of 10) Monochrome Display Adapter (Sheet 10 of 10) # IBM Color/Graphics Monitor Adapter # **Contents** | Description | 1 | |----------------------------------------------------|-----| | Controller | 5 | | Mode Set Register | 5 | | Display Buffer | | | Character Generator | | | Timing Generator | | | Composite Color Generator | | | Alphanumeric Mode | | | Graphics Modes | | | Basic Operations | | | Programming Considerations | | | Programming the Mode Control and Status Register 1 | 4 | | Programming the 6845 CRT Controller 1 | 5 | | Color-Select Register 1 | 8 | | Mode-Control Register 1 | Ç | | Mode-Control Register Summary 2 | )( | | Status Register 2 | ( | | Sequence of Events for Changing Modes | 2 ] | | Memory Requirements 2 | 2 | | Specifications 2 | 3 | | Logic Diagrams 2 | | | Tudov. | 1 | ## **Description** The IBM Color/Graphics Monitor Adapter is designed to attach to the IBM Color Display, to a variety of television-frequency monitors, or to home television sets (user-supplied RF modulator is required for home television sets). The adapter is capable of operating in black-and-white or color. It provides three video interfaces: a composite-video port, a direct-drive port, and a connection interface for driving a user-supplied RF modulator. A light pen interface is also provided. The adapter has two basic modes of operation: alphanumeric (A/N) and all-points-addressable (APA) graphics. Additional modes are available within the A/N or APA graphics modes. In the A/N mode, the display can be operated in either a 40-column by 25-row mode for a low-resolution monitor or home television, or in an 80-column by 25-row mode for high-resolution monitors. In both modes, characters are defined in an 8-wide by 8-high character box and are 7-wide by 7-high, double dotted characters with one descender. Both uppercase and lowercase characters are supported in all modes. The character attributes of reverse video, blinking, and highlighting are available in the black-and-white mode. In the color mode, 16 foreground and 8 background colors are available for each character. In addition, blinking on a per-character basis is available. The monitor adapter contains 16K bytes of storage. As an example, a 40-column by 25-row display screen uses 1000 bytes to store character information and 1000 bytes to store attribute/color information. This means that up to eight screens can be stored in the adapter memory. Similarly, in an 80-wide by 25-row mode, four display screens can be stored in the adapter memory. The entire 16K bytes of storage in the display adapter are directly accessible by the processor, which allows maximum program flexibility in managing the screen. In A/N color modes, it is also possible to select the color of the screen's border. One of 16 colors can be selected. In the APA graphics mode, there are two resolutions available: a medium-resolution color graphics mode (320 PELs by 200 rows) and a high-resolution black-and-white graphics mode (640 PELs by 200 rows). In the medium-resolution mode, each picture element (PEL) may have one of four colors. The background color (Color 0) may be any of the 16 possible colors. The remaining three colors come from one of the two program-selectable palettes. One palette contains green/red/brown; the other contains cyan/magenta/white. The high-resolution mode is available only in black-and-white because the entire 16K bytes of storage in the adapter is used to define the on or off state of the PELs. The adapter operates in noninterlace mode at either 7 or 14 MHz, depending on the mode of the operation selected. In the A/N mode, characters are formed from a ROS character generator. The character generator contains dot patterns for 256 different characters. The character set contains the following major groupings of characters. - 16 special characters for game support - 15 characters for word-processing editing support - 96 characters for the standard ASCII graphics set - 48 characters for foreign-language support - 48 characters for business block-graphics support (for the drawing of charts, boxes, and tables using single and double lines) - 16 selected Greek characters - 15 selected scientific-notation characters The color/graphics monitor function is on a single adapter. The direct-drive and composite-video ports are right-angle mounted connectors on the adapter, and extend through the rear panel of the system unit. The direct-drive video port is a 9-pin, D-shell, female connector. The composite-video port is a standard female phono jack. The display adapter uses a Motorola 6845 CRT Controller device. This adapter is highly programmable with respect to raster and character parameters. Therefore, many additional modes are possible with programming of the adapter. On the following page is a block diagram of the Color/Graphics Monitor Adapter. Color/Graphics Monitor Adapter Block Diagram #### Controller The controller is a Motorola 6845 Cathode Ray Tube (CRT) Controller. It provides the necessary interface to drive the raster-scan CRT. ### **Mode Set Register** The mode set register is a general-purpose, programmable, I/O register. It has I/O ports that may be individually programmed. Its function in this adapter is to provide mode selection and color selection in the medium-resolution color-graphics mode. ### **Display Buffer** The display buffer resides in the processor-address space, starting at address hex B8000. It provides 16 bytes of dynamic read/write memory. A dual-ported implementation allows the processor and the graphics control unit access to this buffer. The processor and the control unit have equal access to this buffer during all modes of operation, except in the high-resolution alphanumeric mode. In this mode, only the processor should have access to this buffer during the horizontal-retrace intervals. While the processor may write to the required buffer at any time, a small amount of display interference will result if this does not occur during the horizontal-retrace intervals. #### **Character Generator** A ROS character generator is used with 8K bytes of storage that cannot be read from or written to under program control. This is a general-purpose ROS character generator with three character fonts. Two character fonts are used on the Color/Graphics Monitor Adapter: a 7-high by 7-wide double-dot font and a 7-high by 5-wide single-dot font. The font is selected by a jumper (P3). The single-dot font is selected by inserting the iumper: the double-dot font is selected by removing the jumper. ### **Timing Generator** This generator produces the timing signals used by the 6845 CRT Controller and by the dynamic memory. It also solves the processor/graphic controller contentions for access to the display buffer. ### **Composite Color Generator** This generator produces base-band-video color information. ### Alphanumeric Mode Every display character position in the alphanumeric mode is defined by two bytes in the regen buffer (a part of the monitor adapter), not the system memory. Both the Color/Graphics Monitor Adapter and the Monochrome Display and Printer Adapter use the following 2-byte character-attribute format. | Display-Character Code Byte | | | | | | | | | | At | tribu | te By | /te | | | | |-----------------------------|---|---|---|---|---|---|---|---|---|----|-------|-------|-----|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | The following table shows the functions of the attribute byte. | Attribute Function | Attribute Byte | | | | | | | | | | |--------------------|----------------|-----|------|-----|-----|-------|-----|---|--|--| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | В | R | G | В | ı | R | G | В | | | | | FG | Bac | kgro | und | F | oregr | oun | d | | | | Normal | В | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | | | Reverse Video | В | 1 | 1 | 1 | - 1 | 0 | 0 | 0 | | | | Nondisplay (Black) | В | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | | | Nondisplay (White) | В | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | I = Highlighted Foreground (Character) B = Blinking Foreground (Character) The definitions of the attribute byte are in the following table. In the alphanumeric mode, the display can be operated in either a low-resolution mode or a high-resolution mode. The low-resolution alphanumeric mode has the following features: - Supports home color televisions or low-resolution monitors. - Displays up to 25 rows of 40 characters each. - Has a ROS character generator that contains dot patterns for a maximum of 256 different characters. - Requires 2,000 bytes of read/write memory (on the adapter). - Has an 8-high by 8-wide character box. - Has two jumper-controlled character fonts available: a 7-high by 5-wide single-dot character font with one descender, and a 7-high by 7-wide double-dotted character font with one descender. - Has one character attribute for each character. The high-resolution alphanumeric mode has the following features: - Supports the IBM Color Display or other color monitor with direct-drive capability. - Supports a black-and-white composite-video monitor. - Displays up to 25 rows of 80 characters each. - Has a ROS display generator that contains dot patterns for a maximum of 256 characters. - Requires 4,000 bytes of read/write memory (on the adapter). - Has an 8-high by 8-wide character box. - Has two jumper-controlled character fonts available: a 7-high by 5-wide single-dot character font with one descender, and a 7-high by 7-wide double-dot character font with one descender. - Has one character attribute for each character. The Color/Graphics Monitor Adapter will change foreground and background colors according to the color value selected in the attribute byte. The following figure shows the color values for the various red, green, blue, and intensity bit settings. | R | G | В | ı | Color | |---|---|---|---|------------------------| | 0 | 0 | 0 | 0 | Black | | 0 | 0 | 1 | 0 | Blue | | 0 | 1 | 0 | 0 | Green | | 0 | 1 | 1 | 0 | Cyan | | 1 | 0 | 0 | 0 | Red | | 1 | 0 | 1 | 0 | Magenta | | 1 | 1 | 0 | 0 | Brown | | 1 | 1 | 1 | 0 | White | | 0 | 0 | 0 | 1 | Gray | | 0 | 0 | 1 | 1 | Light Blue | | 0 | 1 | 0 | 1 | Light Green | | 0 | 1 | 1 | 1 | Light Cyan | | 1 | 0 | 0 | 1 | Light Red | | 1 | 0 | 1 | 1 | Light Magenta | | 1 | 1 | 0 | 1 | Yellow | | 1 | 1 | 1 | 1 | White (High Intensity) | Note: Not all Monitors recognize the intensity (I) bit. ### **Graphics Modes** The Color/Graphics Monitor Adapter has three graphics modes: low-resolution, medium-resolution, and high-resolution color graphics. However, only medium- and high-resolution graphics are supported in ROM. The following figure shows these modes. | Mode | Horizontal<br>(PELs) | Vertical<br>(Rows) | Number of Colors Available (Includes Background Color) | |----------------------|----------------------|--------------------|-----------------------------------------------------------------------------------------------------| | Low Resolution | 160 | 100 | 16 (Includes black-and-white) | | Medium<br>Resolution | 320 | 200 | 4 Colors Total 1 of 16 for Background and 1 of Green, Red, or Brown or 1 of Cyan, Magenta, or White | | High Resolution | 640 | 200 | Black-and-white only | ### Low-Resolution Color/Graphics Mode The low-resolution mode supports home televisions or color monitors. This mode, not supported in ROM, has the following features: - Contains a maximum of 160 PELs by 100 rows, with each PEL being 2-high by 2-wide. - Specifies 1 of 16 colors for each PEL by the I. R. G. and B bits. - Requires 16,000 bytes of read/write memory on the adapter. - Uses memory-mapped graphics. #### **Medium-Resolution Color/Graphics Mode** The medium-resolution mode supports home televisions or color monitors. It has the following features: Contains a maximum of 320 PELs by 200 rows, with each PEL being 1-high by 1-wide. - Preselects 1 of 4 colors for each PEL. - Requires 16,000 bytes of read/write memory on the adapter. - Uses memory-mapped graphics. - Formats 4 PELs per byte in the following manner: | 7 | 6 | 5 4 | | 3 | 3 2 | | 0 | |---------------------|------|-----|------------------|-------------------|------|-------------------|------| | C1 | C0 | C1 | CO | C1 | CO | C1 | CO | | Firs<br>Disp<br>PEL | play | l . | ond<br>play<br>- | Thi<br>Dis<br>PEL | play | Fou<br>Dis<br>PEL | play | • Organizes graphics storage into two banks of 8,000 bytes, using the following format: | Memory<br>Address | | |-------------------|-------------| | (in hex) | Function | | B8000 | | | | Even Scans | | | (0,2,4,198) | | | 8,000 bytes | | B9F3F | | | 20. 0. | Not Used | | BA000 | | | | Odd Scans | | | (1,3,5199) | | | 8,000 Bytes | | BBF3F | | | | Not Used | | BBFFF | | Address hex B8000 contains the PEL instruction for the upper-left corner of the display area. Color selection is determined by the following logic: | C1 | CO | Function | |----|----|-----------------------------------------------------------------| | 0 | 0 | Dot takes on the color of 1 of 16 preselected background colors | | 0 | 1 | Selects first color of preselected Color Set 1 or Color Set 2 | | 1 | 0 | Selects second color of preselected Color Set 1 or Color Set 2 | | 1 | 1 | Selects third color of preselected Color Set 1 or Color Set 2 | C1 and C0 select 4 of 16 preselected colors. This color selection (palette) is preloaded in an I/O port. The two color sets are: | Color Set 1 | Color Set 2 | |------------------|--------------------| | Color 1 is Green | Color 1 is Cyan | | Color 2 is Red | Color 2 is Magenta | | Color 3 is Brown | Color 3 is White | The background colors are the same basic 8 colors defined for low-resolution graphics, plus 8 alternate intensities defined by the intensity bit, for a total of 16 colors, including black and white. ### High-Resolution Black-and-White Graphics Mode The high-resolution mode supports color monitors. This mode has the following features: - Contains a maximum of 640 PELs by 200 rows, with each PEL being 1-high by 1-wide. - Supports black-and-white only. - Requires 16,000 bytes of read/write memory on the adapter. - Addressing and mapping procedures are the same as medium-resolution color/graphics, but the data format is different. In this mode, each bit in memory is mapped to a PEL on the screen. • Formats 8 PELs per byte in the following manner: ### **Basic Operations** In the alphanumeric mode, the adapter fetches character and attribute information from its display buffer. The starting address of the display buffer is programmable through the CRT controller, but it must be an even address. The character codes and attributes are then displayed according to their relative positions in the buffer. The following addresses will produce an "AB" in the upper-left corner of a 40 by 25 screen and an "X" in the lower-right corner. The processor and the display control unit have equal access to the display buffer during all of the operating modes, except the high-resolution alphanumeric mode. During this mode, the processor gains access to the display buffer during the vertical retrace time. If it does not, the display will be affected with random patterns as the microprocessor is using the display buffer. In the alphanumeric mode, the characters are displayed from a pre-stored ROM character generator that contains the dot patterns for all of the displayable characters. In the graphics mode, the displayed dots and colors, up to 16K bytes, are fetched from the display buffer. # **Programming Considerations** ### **Programming the Mode Control and Status** Register The following I/O devices are defined on the Color/Graphics Monitor Adapter. | Hex<br>Address | А9 | A8 | Α7 | Α6 | Α5 | Α4 | А3 | A2 | Α1 | Α0 | Function of Register | |----------------|--------------------------|----|----|----|----|----|----|----|----|----|----------------------------| | 3D8 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Mode Control Register (D0) | | 3D9 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | Color Select Register (D0) | | 3DA | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | Status Register (D1) | | 3DB | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | Clear Light Pen Latch | | 3DC | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | Preset Light Pen Latch | | 3D4 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | Z | Z | 0 | 6845 Index Register | | 3D5 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | Z | Z | 1 | 6845 Data Register | | Z = don' | Z = don't care condition | | | | | | | | | | | ### **Programming the 6845 CRT Controller** The controller has 19 internal accessible registers, which are used to define and control a raster-scan CRT display. One of these registers, the index register, is used as a pointer to the the other 18 registers. It is a write-only register, which is loaded from the processor by executing an 'out' instruction to I/O address hex 3D4. The five least-significant bits of the I/O bus are loaded into the index register. In order to load any of the other 18 registers, the index register is first loaded with the necessary pointer, then the data register is loaded with the information to be placed in the selected register. The data register is loaded from the processor by executing an 'out' instruction to I/O address hex 3D5. The table on the next page defines the values that must be loaded into the 6845 CRT Controller registers to control the different modes of operation supported by the attachment. | Address<br>Register | Register<br>Number | Register<br>Type | Units | I/O | 40 by 25<br>Alpha-<br>numeric | 80 by 25<br>Alpha-<br>numeric | Graphic<br>Modes | |---------------------|--------------------|---------------------------------|------------------|----------------|-------------------------------|-------------------------------|------------------| | 0 | RO | Horizontal<br>Total | Character | Write<br>Only | 38 | 71 | 38 | | 1 | R1 | Horizontal<br>Displayed | Character | Write<br>Only | 28 | 50 | 28 | | 2 | R2 | Horizontal<br>Sync Position | Character | Write<br>Only | 2D | 5A | 2D | | 3 | R3 | Horizontal<br>Sync Width | Character | Write<br>Only | OA | OA | OA | | 4 | R4 | Vertical Total | Character<br>Row | Write<br>Only | 1F | 1F | 7F | | 5 | R5 | Vertical Total<br>Adjust | Scan<br>Line | Write<br>Only | 06 | 06 | 06 | | 6 | R6 | Vertical<br>Displayed | Character<br>Row | Write<br>Only | 19 | 19 | 64 | | 7 | R7 | Vertical<br>Sync Position | Character<br>Row | Write<br>Only | 1C | 1C | 70 | | 8 | R8 | Interlace<br>Mode | | Write<br>Only | 02 | 02 | 02 | | 9 | R9 | Maximum<br>Scan Line<br>Address | Scan<br>Line | Write<br>Only | 07 | 07 | 01 | | Α | R10 | Cursor Start | Scan<br>Line | Write<br>Only | 06 | 06 | 06 | | В | R11 | Cursor End | Scan<br>Line | Write<br>Only | 07 | 07 | 07 | | С | R12 | Start<br>Address (H) | - | Write<br>Only | 00 | 00 | 00 | | D | R13 | Start<br>Address (L) | - | Write<br>Only | 00 | 00 | 00 | | E | R14 | Cursor<br>Address (H) | - | Read/<br>Write | XX | XX | XX | | F | R15 | Cursor<br>Address (L) | - | Read/<br>Write | XX | xx | XX | | 10 | R16 | Light Pen (H) | - | Read<br>Only | XX | XX | XX | | 11 | R17 | Light Pen (L) | - | Read<br>Only | XX | XX | XX | **6845** Register Description ### **Color-Select Register** The color-select register is a 6-bit output-only register. Its I/O address is hex 3D9, and it can be written to using a processor 'out' command. The following are the bit definitions for this register. Bit 0 Selects blue border color in 40 by 25 alphanumeric mode. Selects blue background color (C0-C1) in 320 by 200 graphics mode. Selects blue foreground color in 640 by 200 graphics mode. Bit 1 Selects green border color in 40 by 25 alphanumeric mode. Selects green background color (C0-C1) in 320 by 200 graphics mode. Selects green foreground color in 640 by 200 graphics mode. Bit 2 Selects red border color in 40 by 25 alphanumeric mode. Selects red background color (C0-C1) in 320 by 200 graphics mode. Selects red foreground color in 640 by 200 graphics mode. Bit 3 Selects intensified border color in 40 by 25 alphanumeric mode. Selects intensified background color (C0-C1) in 320 by 200 graphics mode. Selects intensified foreground color in 640 by 200 graphics mode. Bit 4 Selects alternate, intensified set of colors in the graphics mode. Selects background colors in the alphanumeric mode. Bit 5 Selects active color set in 320 by 200 graphics mode. When bit 5 is set to 1, colors are determined as follows: | C1 | CO | Set Selected | |----|----|--------------------------------------------------| | 0 | 0 | Background (Defined by bits 0-3 of port hex 3D9) | | 0 | 1 | Cyan | | 1 | 0 | Magenta | | 1 | 1 | White | When bit 5 is set to 0, colors are determined as follows: | C1 | CO | Set Selected | |----|----|--------------------------------------------------| | 0 | 0 | Background (Defined by bits 0-3 of port hex 3D9) | | 0 | 1 | Green | | 1 | 0 | Red | | 1 | 1 | Brown | Bit 6 Not used Bit 7 Not used ### **Mode-Control Register** The mode-control register is a 6-bit output-only register. Its I/O address is hex 3D8, and it can be written to using a processor 'out' command. The following are bit definitions for this register. Bit 0 A 1 selects 80 by 25 alphanumeric mode. A 0 selects 40 by 25 alphanumeric mode. Bit 1 A 1 selects 320 by 200 graphics mode. A 0 selects alphanumeric mode. A 1 selects black-and-white mode. Bit 2 A 0 selects color mode. A 1 enables the video signal. The video signal is Bit 3 disabled when changing modes. - Bit 4 A 1 selects the high-resolution (640 by 200) black-and-white graphics mode. One of eight colors can be selected on direct-drive monitors in this mode by using register hex 3D9. - Bit 5 A 1 will change the character background intensity to the blinking attribute function for alphanumeric modes. When the high-order attribute is not selected, 16 background colors or intensified colors are available. This bit is set to 1 to allow the blinking function. ### **Mode-Control Register Summary** z = don't care condition **Note:** The low-resolution (160 by 100) mode requires special programming and is set up as the 40 by 25 alphanumeric mode. ### **Status Register** The status register is a 4-bit read-only register. Its I/O address is hex 3DA, and it can be read using the processor 'in' instruction. The following are bit definitions for this register. - Bit 0 A 1 indicates that a regen-buffer memory access can be made without interfering with the display. - A 1 indicates that a positive-going edge from the light Bit 1 pen has set the light pen's trigger. This trigger is reset when power is turned on and may also be cleared by a processor 'out' command to hex address 3DB. No specific data setting is required; the action is address-activated. - The light pen switch is reflected in this bit. The switch Bit 2 is not latched or debounced. A 0 indicates that the switch is on. - A 1 indicates that the raster is in a vertical retrace mode. Bit 3 Screen-buffer updating can be performed at this time. ### **Sequence of Events for Changing Modes** - 1 Determine the mode of operation. - 2 Reset the video-enable bit in the mode-control register. - 3 Program the 6845 CRT Controller to select the mode. - 4 Program the mode-control and color-select registers including re-enabling the video. ### **Memory Requirements** The memory used by this adapter is self-contained. It consists of 16K bytes of memory without parity. This memory is used as both a display buffer for alphanumeric data and as a bit map for graphics data. The regen buffer's address starts at hex B8000. # **Specifications** The following pages contain card and connector specifications for the IBM Color/Graphics Monitor Adapter. **Connector Specifications (Part 1 of 2)** #### 24 Color/Graphics Monitor Adapter #### **RF Modulator Interface** **Light Pen Interface** **Connector Specifications (Part 2 of 2)** # **Logic Diagrams** The following pages contain the logic diagrams for the IBM Color/Graphics Monitor Adapter. Color/Graphics Monitor Adapter (Sheet 1 of 6) Color/Graphics Monitor Adapter (Sheet 2 of 6) Color/Graphics Monitor Adapter (Sheet 3 of 6) Color/Graphics Monitor Adapter (Sheet 4 of 6) Color/Graphics Monitor Adapter (Sheet 5 of 6) Color/Graphics Monitor Adapter (Sheet 6 of 6) # **Index** # A alphanumeric mode 6 # B basic operations 12 ## C change modes 21 character generator 5 color-select register 18 composite color generator 6 controller 5 ## D description 1 display buffer 5 ``` graphics modes 9 high-resolution black-and-white 11 low-resolution color 9 medium-resolution color 9 ``` # H high-resolution black-and-white graphics mode 11 # L logic diagrams 27 low-resolution color/graphics mode 9 # M ``` medium-resolution color/graphics mode 9 memory requirements 22 mode set register 5 mode types alphanumeric 6 graphics 9 mode-control register 19 mode-control register summary 20 modes of operation 1 ``` #### P programming considerations 15 programming the mode control and status register 15 programming the 6845 crt controller 15 # R ``` registers color-select 18 mode control and status 15 mode set 5 mode-control 19 status 21 ``` # S sequence of events for changing modes 21 specifications 23 status register 21 ## T timing generator 6 # IBM Enhanced Graphics Adapter # **Contents** | Description | <br> | <br> | | . 1 | |--------------------------------------|------|------|------|-----| | Major Components | | <br> | <br> | . 3 | | Modes of Operation | | | | | | Basic Operations | | | | | | Registers | | | | | | Programming Considerations | | | | | | Programming the Registers | | | | | | RAM Loadable Character Generator | | | | | | Creating a 512 Character Set | | | | | | Creating an 80 by 43 Alphanumeric Mo | | | | | | Vertical Interrupt Feature | | | | | | Creating a Split Screen | | | | | | Compatibility Issues | | | | | | nterface | | | | | | Feature Connector | | <br> | <br> | 76 | | pecifications | | | | | | System Board Switches | | | | | | Configuration Switches | | | | | | Direct Drive Connector | | | | | | Light Pen Interface | | | | | | Jumper Descriptions | | | | | | Logic Diagrams | | | | | | BIOS Listing | | | | | | Vectors with Special Meanings | | | | | # **Description** The IBM Enhanced Graphics Adapter (EGA) is a graphics controller that supports both color and monochrome direct drive displays in a variety of modes. In addition to the direct drive port, a light pen interface is provided. Advanced features on the adapter include bit-mapped graphics in four planes and a RAM (Random Access Memory) loadable character generator. Design features in the hardware substantially reduce the software overhead for many graphics functions. The Enhanced Graphics Adapter provides Basic Input Output System (BIOS) support for both alphanumeric (A/N) modes and all-points-addressable (APA) graphics modes, including all modes supported by the Monochrome Display Adapter and the Color/Graphics Monitor Adapter. Other modes provide APA 640x350 pel graphics support for the IBM Monochrome Display, full 16 color support in both 320x200 pel and 640x200 pel resolutions for the IBM Color Display, and both A/N and APA support with resolution of 640x350 for the IBM Enhanced Color Display. In alphanumeric modes, characters are formed from one of two ROM (Read Only Memory) character generators on the adapter. One character generator defines 7x9 characters in a 9x14 character box. For Enhanced Color Display support, the 9x14 character set is modified to provide an 8x14 character set. The second character generator defines 7x7 characters in an 8x8 character box. These generators contain dot patterns for 256 different characters. The character sets are identical to those provided by the IBM Monochrome Display Adapter and the IBM Color/Graphics Monitor Adapter. The adapter contains 64K bytes of storage configured as four 16K byte bit planes. Memory expansion options are available to expand the adapter memory to 128K bytes or 256K bytes. The adapter is packaged on a single 13-1/8 inch (333.50 mm) card. The direct drive port is a right-angle mounted connector at the rear of the adapter and extends through the rear panel of the system unit. Also on the card are five large scale integration (LSI) modules custom designed for this controller. Located on the adapter is a feature connector that provides access to internal functions through a 32-pin berg connector. A separate 64-pin connector provides an interface for graphics memory expansion. The following is a block diagram of the Enhanced Graphics Adapter: **Enhanced Graphics Adapter Block Diagram** # **Major Components** #### **CRT Controller** The CRT (Cathode Ray Tube) Controller (CRTC) generates horizontal and vertical synchronous timings, addressing for the regenerative buffer, cursor and underline timings, and refresh addressing for the dynamic RAMs. ## Sequencer The Sequencer generates basic memory timings for the dynamic RAMs and the character clock for controlling regenerative memory fetches. It allows the processor to access memory during active display intervals by inserting dedicated processor memory cycles periodically between the display memory cycles. Map mask registers are available to protect entire memory maps from being changed. ## **Graphics Controller** The Graphics Controller directs the data from the memory to the attribute controller and the processor. In graphics modes, memory data is sent in serialized form to the attribute chip. In alpha modes the memory data is sent in parallel form, bypassing the graphics controller. The graphics controller formats the data for compatible modes and provides color comparators for use in color painting modes. Other hardware facilities allow the processor to write 32 bits in a single memory cycle, (8 bits per plane) for quick color presetting of the display areas, and additional logic allows the processor to write data to the display on non-byte boundaries. #### **Attribute Controller** The Attribute Controller provides a color palette of 16 colors, each of which may be specified separately. Six color outputs are available for driving a display. Blinking and underlining are controlled by this chip. This chip takes data from the display memory and formats it for display on the CRT screen. ## **Display Buffer** The display buffer on the adapter consists of 64K bytes of dynamic read/write memory configured as four 16K byte video bit planes. Two options are available for expanding the graphics memory. The Graphics Memory Expansion Card plugs into the memory expansion connector on the adapter, and adds one bank of 16K to each of the four bit planes, increasing the graphics memory to 128K bytes. The expansion card also provides DIP sockets for further memory expansion. Populating the DIP sockets with the Graphics Memory Module Kit adds two additional 16K banks to each bit plane, bringing the graphics memory to its maximum of 256K bytes. The address of the display buffer can be changed to remain compatible with other video cards and application software. Four locations are provided. The buffer can be configured at segment address hex A0000 for a length of 128K bytes, at hex A0000 for a length of 64K bytes, at hex B0000 for a length of 32K bytes, or at hex B8000 for a length of 32K bytes. #### **BIOS** A read-only memory (ROM) Basic Input Output System (BIOS) module on the adapter is linked to the system BIOS. This ROM BIOS contains character generators and control code and is mapped into the processor address at hex C0000 for a length of 16K bytes. #### **Support Logic** The logic on the card surrounding the LSI modules supports the modules and creates latch buses for the CRT controller, the processor, and character generator. Two clock sources (14 MHz and 16 MHz) provide the dot rate. The clock is multiplexed under processor I/O control. The four I/O registers on the card are not part of the LSI devices. # **Modes of Operation** ## **IBM Color Display** The following table describes the modes supported by BIOS on the IBM Color Display: | Mode # | Туре | Colors | Alpha<br>Format | Buffer<br>Start | Box<br>Size | Max.<br>Pages | Resolution | |--------|------|--------|-----------------|-----------------|-------------|---------------|------------| | 0 | A/N | 16 | 40x25 | B8000 | 8x8 | 8 | 320x200 | | 1 | A/N | 16 | 40x25 | B8000 | 8x8 | 8 | 320x200 | | 2 | A/N | 16 | 80x25 | B8000 | 8x8 | 4/8/8 | 640x200 | | 3 | A/N | 16 | 80x25 | B8000 | 8x8 | 4/8/8 | 640x200 | | 4 | APA | 4 | 40x25 | B8000 | 8x8 | 1 | 320x200 | | 5 | APA | 4 | 40x25 | B8000 | 8x8 | 1 | 320x200 | | 6 | APA | 2 | 80x25 | B8000 | 8x8 | 1 | 640x200 | | D | APA | 16 | 40x25 | A0000 | 8x8 | 2/4/8 | 320x200 | | E | APA | 16 | 80x25 | A0000 | 8x8 | 1/2/4 | 640x200 | Modes 0 through 6 emulate the support provided by the IBM Color/Graphics monitor Adapter. Modes 0, 2, and 5 are identical to modes 1, 3, and 4, respectively, at the adapter's direct drive interface. The "MAX. PAGES" fields for modes 2, 3, D, and E indicate the number of pages supported when 64K, 128K, or 256K bytes of graphics memory is installed, respectively. ## **IBM Monochrome Display** The following table describes the modes supported by BIOS on the IBM Monochrome Display. | Mode # | Туре | Colors | Alpha<br>Format | Buffer<br>Start | Box<br>Size | Max.<br>Pages | Resolution | |--------|------|--------|-----------------|-----------------|-------------|---------------|------------| | 7 | A/N | 4 | 80x25 | B0000 | 9x14 | 4/8 | 720x350 | | F | APA | 4 | 80x25 | A0000 | 8x14 | 1/2 | 640x350 | The "MAX. PAGES" fields for modes 7 and F indicate the number of pages supported when either 64K or greater than 64K of graphics memory is installed, respectively. Mode 7 emulates the support provided by the IBM Monochrome Display Adapter. ## **IBM Enhanced Color Display** The Enhanced Graphics Adapter supports attachment of the IBM Enhanced Color Display. The IBM Enhanced Color Display is capable of running at the standard television frequency of 15.75 KHz as well as running 21.85 KHz. The table below summarizes the characteristics of the IBM Enhanced Color Display: | Parameter | TV Frequency | High Resolution | |-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | Horiz Scan Rate Vertical Scan Rate Video Bandwidth Displayable Colors Character Size Character Box Size Maximum Resolution Alphanumeric Modes | 15.75 KHz.<br>60 Hz.<br>14.318 MHz.<br>16 Maximum<br>7 by 7 Pels<br>8 by 8 Pels<br>640x200 Pels | 21.85 KHz.<br>60 Hz.<br>16.257 MHz.<br>16 or 64<br>7 by 9 Pels<br>8 by 14 Pels<br>640 by 350 Pels | | Graphics Modes | 0,1,2,3<br>4,5,6,D,E | 0,1,2,3<br>10 | In the television frequency mode, the IBM Enhanced Color Display displays information identical in color and resolution to the IBM Color Display. In the high resolution mode, the adapter provides enhanced alphanumeric character support. This enhanced alphanumeric support consists of transforming the 8 by 8 character box into an 8 by 14 character box, and providing 16 colors out of a palette of 64 possible display colors. Display colors are changed by altering the programming of the color palette registers in the Attribute Controller. In alphanumeric modes, any 16 of 64 colors are displayable. The screen resolution is 320x350 for modes 0 and 1, and 640x350 for modes 2 and 3. The resolution displayed on the IBM Enhanced Color Display is selected by the switch settings on the Enhanced Graphics Adapter. The Enhanced Color Display is compatible with all modes listed for the IBM Color Display. The following table describes additional modes supported by BIOS for the IBM Enhanced Color Display: | Mode # | Туре | Colors | Alpha<br>Format | Buffer<br>Start | Box<br>Size | Max.<br>Pages | Resolution | |--------|------|---------------|-----------------|-----------------|-------------|---------------|------------| | 0* | A/N | 16/64 | 40x25 | B8000 | 8x14 | 8 | 320x350 | | 1* | A/N | 16/64 | 40x25 | B8000 | 8x14 | 8 | 320x350 | | 2* | A/N | 16/64 | 80x25 | B8000 | 8x14 | 4/8 | 640x350 | | 3* | A/N | 16/64 | 80x25 | B8000 | 8x14 | 4/8 | 640x350 | | 10 | APA | 4/16<br>16/64 | 80x25 | A0000 | 8x14 | 1/2 | 640x350 | <sup>\*</sup> Note that modes 0, 1, 2, and 3 are also listed for IBM Color Display support. BIOS provides enhanced support for these modes when an Enhanced Color Display is attached. The values in the "COLORS" field indicate 16 colors of a 64 color palette or 4 colors of a sixteen color palette. In modes 2, 3, and 10, the dual values for the "COLORS" field and the "MAX. PAGES" field indicate the support provided when either 64K or greater than 64K of graphics memory is installed, respectively. # **Basic Operations** ## **Alphanumeric Modes** The data format for alphanumeric modes on the Enhanced Graphics Adapter is the same as the data format on the IBM Color/Graphics Monitor Adapter and the IBM Monochrome Display Adapter. As an added function, bit three of the attribute byte may be redefined by the Character Map Select register to act as a switch between character sets. This gives the programmer access to 512 characters at one time. This function is valid only when memory has been expanded to 128K bytes or more. When an alphanumeric mode is selected, the BIOS transfers character patterns from the ROM to bit plane 2. The processor stores the character data in bit plane 0, and the attribute data in bit plane 1. The programmer can view bit planes 0 and 1 as a single buffer in alphanumeric modes. The CRTC generates sequential addresses, and fetches one character code byte and one attribute byte at a time. The character code and row scan count address bit plane 2, which contains the character generators. The appropriate dot patterns are then sent to the palette in the attribute chip, where color is assigned according to the attribute data. ## **Graphics Modes** #### 320x200 Two and Four Color Graphics (Modes 4 and 5) Addressing, mapping and data format are the same as the 320x200 pel mode of the Color/Graphics Monitor Adapter. The display buffer is configured at hex B8000. Bit image data is stored in bit planes 0 and 1. #### 640x200 Two Color Graphics (Mode 6) Addressing, mapping and data format are the same as the 640x200 pel black and white mode of the Color/Graphics Monitor Adapter. The display buffer is configured at hex B8000. Bit image data is stored in bit plane 0. #### 640x350 Monochrome Graphics (Mode F) This mode supports graphics on the IBM Monochrome Display with the following attributes: black, video, blinking video, and intensified video. Resolution of 640x350 requires 56K bytes to support four attributes. By chaining maps 0 and 1, then maps 2 and 3 together, two 32K bit planes can be formed. This chaining is done only when necessary (less than 128K of graphics memory). The first map is the video bit plane, and the second map is the intensity bit plane. Both planes reside at hex address A0000. Two bits, one from each bit plane, define one picture element (pel) on the screen. The bit definitions for the pels are given in the following table. The video bit plane is denoted by C0 and the Intensity Bit Plane is denoted by C2. | C2 | СО | Pixel Color | Valid Attributes | |----|----|-------------------|------------------| | 0 | 0 | Black | 0 | | 0 | 1 | Video | 3 | | 1 | 0 | Blinking Video | С | | 1 | 1 | Intensified Video | F | The byte organization in memory is sequential. The first eight pels on the screen are defined by the contents of memory in location A000:0H, the second eight pels by location A000:1H, and so on. The first pel within any one byte is defined by bit 7 in the byte. The last pel within the byte is defined by bit 0 in the byte. Monochrome graphics works in odd/even mode, which means that even CPU addresses go into even bit planes and odd CPU addresses go into odd bit planes. Since both bit planes reside at address A0000, the user must select which plane or planes he desires to update. This is accomplished by the map mask register of the sequencer. (See the table above for valid attributes). #### 16/64 Color Graphics Modes (Mode 10) These modes support graphics in 16 colors on either a medium or high resolution monitor. The memory in these modes consists of using all four bit planes. Each bit plane represents a color as shown below. The bit planes are denoted as C0,C1,C2 and C3 respectively. C0 = Blue Pels C1 = Green Pels C2 = Red Pels C3 = Intensified Pels Four bits (one from each plane) define one pel on the screen. The color combinations are illustrated in the following table: | I | R | G | В | Color | |---|----|---|---|-------------------| | 0 | 0 | 0 | 0 | Black | | 0 | 0 | 0 | 1 | Blue | | 0 | 0 | 1 | 0 | Green | | 0 | 0 | 1 | 1 | Cyan | | 0 | 1 | 0 | 0 | Red | | 0 | .1 | 0 | 1 | Magenta | | 0 | 1 | 1 | 0 | Brown | | 0 | 1 | 1 | 1 | White | | 1 | 0 | 0 | 0 | Dark Gray | | 1 | 0 | 0 | 1 | Light Blue | | 1 | 0 | 1 | 0 | Light Green | | 1 | 0 | 1 | 1 | Light Cyan | | 1 | 1 | 0 | 0 | Light Red | | 1 | 1 | 0 | 1 | Light Magenta | | 1 | 1 | 1 | 0 | Yellow | | 1 | 1 | 1 | 1 | Intensified White | The display buffer resides at address A0000. The map mask register of the sequencer is used to select any or all of the bit planes to be updated when a memory write to the display buffer is executed by the CPU. #### **Color Mapping** The Enhanced Graphics Adapter supports 640x350 Graphics for both the IBM Monochrome and the IBM Enhanced Color Displays. Four color capability is supported on the EGA without the Graphics Memory Expansion Card (base 64 KB), and sixteen colors are supported when the Graphics Memory Expansion Card is installed on the adapter (128 KB or above). This section describes the differences in the colors displayed depending upon the graphics memory available. Note that colors 0H, 1H, 4H, and 7H map directly regardless of the graphics memory available. | Character<br>Attribute | Monochrome | Mode 10H<br>64KB | Mode 10H<br>>64KB | |------------------------|-------------|------------------|-------------------| | 00H* | Black | Black | Black | | 01H* | Video | Blue | Blue | | 02H | Black | Black | Green | | 03H | Video | Blue | Cyan | | 04H* | Blinking | Red | Red | | 05H | Intensified | White | Magenta | | 06H | Blinking | Red | Brown | | 07H* | Intensified | White | White | | 08H | Black | Black | Dark Gray | | 09H | Video | Blue | Light Blue | | 0AH | Black | Black | Light Green | | 0BH | Video | Blue | Light Cyan | | осн | Blinking | Red | Light Red | | ODH | Intensified | White | Light Magenta | | 0EH | Blinking | Red | Yellow | | 0FH | Intensified | White | Intensified White | <sup>\*</sup> Graphics character attributes which map directly regardless of the graphics memory available. # **Registers** ## **External Registers** This section contains descriptions of the registers of the Enhanced Graphics Adapter that are not contained in an LSI device. | Name | Port | Index | |------------------------------------------------|------|-------| | Miscellaneous Output Register | 3C2 | - | | Feature Control Register | 3?A | - | | Input Status Register 0 | 3C2 | - | | Input Status Register 1 | 3?2 | - | | ? = B in Monochrome Modes ? = D in Color Modes | | | #### Miscellaneous Output Register This is a write-only register. The processor output port address is hex 3C2. A hardware reset causes all bits to reset to zero. Bit 0 3BX/3DX CRTC I/O Address—This bit maps the CRTC I/O addresses for IBM Monochrome or Color/Graphics Monitor Adapter emulation. A logical 0 sets CRTC addresses to 3BX and Input Status Register 1 's address to 3BA for Monochrome emulation. A logical 1 sets CRTC addresses to 3DX and Input Status Register 1's address to 3DA for Color/Graphics Monitor Adapter emulation. Bit 1 Enable RAM—A logical 0 disables RAM from the processor; a logical 1 enables RAM to respond at addresses designated by the Control Data Select value programmed into the Graphics Controllers. Bit 2-Bit 3 Clock Select—These two bits select the clock source according to the following table: # Bits - 3 2 - **0 0-** Selects 14 MHz clock from the processor I/O channel - 0 1- Selects 16 MHz clock on-board oscillator - 1 0- Selects external clock source from the feature connector. - **1 1-** Not used Bit 4 Disable Internal Video Drivers—A logical 0 activates internal video drivers; a logical 1 disables internal video drivers. When the internal video drivers are disabled, the source of the direct drive color output becomes the feature connector direct drive outputs. Bit 5 Page Bit For Odd/Even—Selects between two 64K pages of memory when in the Odd/Even modes (0,1,2,3,7). A logical 0 selects the low page of memory; a logical 1 selects the high page of memory. Bit 6 Horizontal Retrace Polarity—A logical 0 selects positive horizontal retrace; a logical 1 selects negative horizontal retrace. **Bit 7** Vertical Retrace Polarity—A logical 0 selects positive vertical retrace; a logical 1 selects negative vertical retrace. The IBM Monochrome display requires a negative vertical retrace polarity. #### **Feature Control Register** This is a write-only register. The processor output register is hex 3BA or 3DA. Bits 0 and 1 Feature Control Bits—These bits are used to convey information to the feature connector. The output of these bits goes to the FEAT 0 (pin 19) and FEAT 1 (pin 17) of the feature connector. #### **Input Status Register Zero** This is a read-only register. The processor input port address is hex 3C2. Bit 4 Switch Sense—When set to 1, this bit allows the processor to read the four configuration switches on the board. The setting of the CLKSEL field determines which switch is being read. The switch configuration can be determined by reading byte 40:88H in RAM. Bit 3: Switch 4; Logical 0 = switch closed Bit 2: Switch 3; Logical 0 = switch closed Bit 1: Switch 2; Logical 0 = switch closed Bit 0: Switch 1; Logical 0 = switch closed - Feature Code—These bits are input from the Feat (0) and Feat (1) pins on the feature connector. - Bit 7 CRT Interrupt—A logical 1 indicates video is being displayed on the CRT screen; a logical 0 indicates that vertical retrace is occurring. ## Input Status Register One This is a read-only register. The processor port address is hex 3BA or hex 3DA. - Bit 0 Display Enable—Logical 0 indicates the CRT raster is in a horizontal or vertical retrace interval. This bit is the real time status of the display enable signal. Some programs use this status bit to restrict screen updates to inactive display intervals. The Enhanced Graphics Adapter does not require the CPU to update the screen buffer during inactive display intervals to avoid glitches in the display image. - Bit 1 Light Pen Strobe—A logical 0 indicates that the light pen trigger has not been set; a logical 1 indicates that the light pen trigger has been set. - Bit 2 Light Pen Switch—A logical 0 indicates that the light pen switch is closed; a logical 1 indicates that the light pen switch is open. - Bit 3 Vertical Retrace—A logical 0 indicates that video information is being displayed on the CRT screen; a logical 1 indicates the CRT is in a vertical retrace interval. This bit can be programmed to interrupt the processor on interrupt level 2 at the start of the vertical retrace. This is done through bits 4 and 5 of the Vertical Retrace End Register of the CRTC. - Bits 4 and 5 Diagnostic Usage—These bits are selectively connected to two of the six color outputs of the Attribute Controller. The Color Plane Enable register controls the multiplexer for the video wiring. The following table illustrates the combinations available and the color output wiring. | Color Plane | Input Status | | | |-------------|----------------|-----------------|--| | Register | Register One | | | | Bit 5 Bit 4 | Bit 5 | Bit 4 | | | 0 0 | Red | Blue | | | 0 1 | Secondary Blue | Green | | | 1 0 | Secondary Red | Secondary Green | | | 1 1 | Not Used | Not Used | | ### **Sequencer Registers** | Name | Port | Index | |----------------------|------|-------| | Address | 3C4 | _ | | Reset | 3C5 | 00 | | Clocking Mode | 3C5 | 01 | | Map Mask | 3C5 | 02 | | Character Map Select | 3C5 | 03 | | Memory Mode | 3C5 | 04 | #### **Sequencer Address Register** The Address Register is a pointer register located at address hex 3C4. This register is loaded with a binary value that points to the sequencer data register where data is to be written. This value is referred to as "Index" in the table above. Bit 0-Bit 3 Sequencer Address Bits—A binary value pointing to the register where data is to be written. #### **Reset Register** This is a write-only register pointed to when the value in the address register is hex 00. The output port address for this register is hex 3C5. Asynchronous Reset—A logical 0 commands the sequencer to asynchronous clear and halt. All outputs are placed in the high impedance state when this bit is a 0. A logical 1 commands the sequencer to run unless bit 1 is set to zero. Resetting the sequencer with this bit can cause data loss in the dynamic RAMs. Bit 1 Synchronous Reset—A logical 0 commands the sequencer to synchronous clear and halt. Bits 1 and 0 must both be ones to allow the sequencer to operate. Reset the sequencer with this bit before changing the Clocking Mode Register, if memory contents are to be preserved. #### **Clocking Mode Register** This is a write-only register pointed to when the value in the address register is hex 01. The output port address for this register is hex 3C5. Bit 0 8/9 Dot Clocks—A logical 0 directs the sequencer to generate character clocks 9 dots wide; a logical 1 directs the sequencer to generate character clocks 8 dots wide. Monochrome alphanumeric mode (07H) is the only mode that uses character clocks 9 dots wide. All other modes must use 8 dots per character clock. Bit 1 Bandwidth—A logical 0 makes CRT memory cycles occur on 4 out of 5 available memory cycles; a logical 1 makes CRT memory cycles occur on 2 out of 5 available memory cycles. Medium resolution modes require less data to be fetched from the display buffer during the horizontal scan time. This allows the CPU greater access time to the display buffer. All high resolution modes must provide the CRTC with 4 out of 5 memory cycles in order to refresh the display image. Bit 2 Shift Load—When set to 0, the video serializers are reloaded every character clock; when set to 1, the video serializers are loaded every other character clock. This mode is useful when 16 bits are fetched per cycle and chained together in the shift registers. Bit 3 Dot Clock—A logical 0 selects normal dot clocks derived from the sequencer master clock input. When this bit is set to 1, the master clock will be divided by 2 to generate the dot clock. All the other timings will be stretched since they are derived from the dot clock. Dot clock divided by two is used for 320x200 modes (0, 1, 4, 5) to provide a pixel rate of 7 MHz, (9 MHz for mode D). ## Map Mask Register This is a write-only register pointed to when the value in the address register is hex 02. The output port address for this register is hex 3C5. Bit 0-Bit 3 Map Mask—A logical 1 in bits 3 through 0 enables the processor to write to the corresponding maps 3 through 0. If this register is programmed with a value of 0FH, the CPU can perform a 32-bit write operation with only one memory cycle. This substantially reduces the overhead on the CPU during display update cycles in graphics modes. Data scrolling operations are also enhanced by setting this register to a value of 0FH and writing the display buffer address with the data stored in the CPU data latches. This is a read-modify-write operation. When odd/even modes are selected, maps 0 and 1 and maps 2 and 3 should have the same map mask value. #### **Character Map Select Register** This is a write-only register pointed to when the value in the address register is hex 03. The output port address for this register is 3C5. Bit 0-Bit 1 Character Map Select B—Selects the map used to generate alpha characters when attribute bit 3 is a 0, according to the following table: | 1 B | its<br>O | Map<br>Selected | Table Location | |-----|----------|-----------------|--------------------------| | Va | lue | | | | 0 | 0 | 0 | 1st 8K of Plane 2 Bank 0 | | 0 | 1 | 1 | 2nd 8K of Plane 2 Bank 1 | | 1 | 0 | 2 | 3rd 8K of Plane 2 Bank 2 | | 1 | 1 | 3 | 4th 8K of Plane 2 Bank 3 | Bit 2-Bit 3 Character Map Select A—Selects the map used to generate alpha characters when attribute bit 3 is a 1, according to the following table: | 3<br>3 | its<br>2 | Map<br>Selected | Table Location | | |--------|----------|-----------------|--------------------------|--| | Value | | | | | | 0 | 0 | 0 | 1st 8K of Plane 2 Bank 0 | | | 0 | 1 | 1 | 2nd 8K of Plane 2 Bank 1 | | | 1 | 0 | 2 | 3rd 8K of Plane 2 Bank 2 | | | 1 | 1 | 3 | 4th 8K of Plane 2 Bank 3 | | In alphanumeric modes, bit 3 of the attribute byte normally has the function of turning the foreground intensity on or off. This bit however may be redefined as a switch between character sets. This function is enabled when there is a difference between the value in Character Map Select A and the value in Character Map Select B. Whenever these two values are the same, the character select function is disabled. The memory mode register bit 1 must be a 1 (indicates the memory extension card is installed in the unit) to enable this function; otherwise, bank 0 is always selected. 128K of graphics memory is required to support two character sets. 256K supports four character sets. Asynchronous reset clears this register to 0. This should be done only when the sequencer is reset. #### **Memory Mode Register** This is a write-only register pointed to when the value in the address register is hex 04. The processor output port address for this register is 3C5. - Bit 0 Alpha—A logical 0 indicates that a non-alpha mode is active. A logical 1 indicates that alpha mode is active and enables the character generator map select function. - Bit 1 Extended Memory—A logical 0 indicates that the memory expansion card is not installed. A logical 1 indicates that the memory expansion card is installed and enables access to the extended memory through address bits 14 and 15. - Bit 2 Odd/Even—A logical 0 directs even processor addresses to access maps 0 and 2, while odd processor addresses access maps 1 and 3. A logical 1 causes processor addresses to sequentially access data within a bit map. The maps are accessed according to the value in the map mask register. #### **CRT Controller Registers** | Name | Port | Index | | | |------------------------------------------------|------|-------|--|--| | Address Register | 3?4 | _ | | | | Horizontal Total | 3?5 | 00 | | | | Horizontal Display End | 3?5 | 01 | | | | Start Horizontal Blank | 3?5 | 02 | | | | End Horizontal Blank | 3?5 | 03 | | | | Start Horizontal Retrace | 3?5 | 04 | | | | End Horizontal Retrace | 3?5 | 05 | | | | Vertical Total | 3?5 | 06 | | | | Overflow | 3?5 | 07 | | | | Preset Row Scan | 3?5 | 08 | | | | Max Scan Line | 3?5 | 09 | | | | Cursor Start | 3?5 | OA | | | | Cursor End | 3?5 | 0B | | | | Start Address High | 3?5 | 0C | | | | Start Address Low | 3?5 | 0D | | | | Cursor Location High | 3?5 | 0E | | | | Cursor Location Low | 3?5 | 0F | | | | Vertical Retrace Start | 3?5 | 10 | | | | Light Pen High | 3?5 | 10 | | | | Vertical Retrace End | 3?5 | 11 | | | | Light Pen Low | 3?5 | 11 | | | | Vertical Display End | 3?5 | 12 | | | | Offset | 3?5 | 13 | | | | Underline Location | 3?5 | 14 | | | | Start Vertical Blank | 3?5 | 15 | | | | End Vertical Blank | 3?5 | 16 | | | | Mode Control | 3?5 | 17 | | | | Line Compare | 3?5 | 18 | | | | ? = B in Monochrome Modes and D in Color Modes | | | | | #### **CRT Controller Address Register** The Address register is a pointer register located at hex 3B4 or hex 3D4. If an IBM Monochrome Display is attached to the adapter, address 3B4 is used. If a color display is attached to the adapter, address 3D4 is used. This register is loaded with a binary value that points to the CRT Controller data register where data is to be written. This value is referred to as "Index" in the table above. Bit 0-Bit 4 CRT Controller Address Bits—A binary value pointing to the CRT Controller register where data is to be written. #### **Horizontal Total Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 00. The processor output port address for this register is hex 3B5 or hex 3D5. This register defines the total number of characters in the horizontal scan interval including the retrace time. The value directly controls the period of the horizontal retrace output signal. An internal horizontal character counter counts character clock inputs to the CRT Controller, and all horizontal and vertical timings are based upon the horizontal register. Comparators are used to compare register values with horizontal character values to provide horizontal timings. Bit 0-Bit 7 Horizontal Total—The total number of characters less 2. #### Horizontal Display Enable End Register This is a write-only register pointed to when the value in the CRT Controller address register is hex 01. The processor output port address for this register is hex 3B5 or hex 3D5. This register defines the length of the horizontal display enable signal. It determines the number of displayed character positions per horizontal line. Bit 0-Bit 7 Horizontal display enable end —A value one less than the total number of displayed characters. #### **Start Horizontal Blanking Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 02. The processor output port address for this register is hex 3B5 or hex 3D5. This register determines when the horizontal blanking output signal becomes active. The row scan address and underline scan line decode outputs are multiplexed on the memory address outputs and cursor outputs respectively during the blanking interval. These outputs are latched external to the CRT Controller with the falling edge of the BLANK output signal. The row scan address and underline signals remain on the output signals for one character count beyond the end of the blanking signal. Bit 0-Bit 7 Start Horizontal Blanking—The horizontal blanking signal becomes active when the horizontal character counter reaches this value. #### **End Horizontal Blanking Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 03. The processor output port address for this register is hex 3B5 or hex 3D5. This register determines when the horizontal blanking output signal becomes inactive. The row scan address and underline scan line decode outputs are multiplexed on the memory address outputs and the cursor outputs respectively during the blanking interval. These outputs are latched external to the CRT Controller with the falling edge of the BLANK output signal. The row scan address and underline signals remain on the output signals for one character count beyond the end of the blanking signal. # Bit 0-Bit 4 End Horizontal Blanking—A value equal to the five least significant bits of the horizontal character counter value at which time the horizontal blanking signal becomes inactive (logical 0). To obtain a blanking signal of width W, the following algorithm is used: Value of Start Blanking Register + Width of Blanking signal in character clock units = 5-bit result to be programmed into the End Horizontal Blanking Register. #### Bit 5-Bit 6 Display Enable Skew Control—These two bits determine the amount of display enable skew. Display enable skew control is required to provide sufficient time for the CRT Controller to access the display buffer to obtain a character and attribute code, access the character generator font, and then go through the Horizontal Pel Panning Register in the Attribute Controller. Each access requires the display enable signal to be skewed one character clock unit so that the video output is in synchronization with the horizontal and vertical retrace signals. The bit values and amount of skew are shown in the following table: | Bit<br>6 | | | |----------|---|----------------------------| | 0 | 0 | Zero character clock skew | | 0 | 1 | One character clock skew | | 1 | 0 | Two character clock skew | | 1 | 1 | Three character clock skew | # Start Horizontal Retrace Pulse Register This is a write-only register pointed to when the value in the CRT Controller address register is hex 04. The processor output port address for this register is hex 3B5 or hex 3D5. This register is used to center the screen horizontally, and to specify the character position at which the Horizontal Retrace Pulse becomes active. Bit 0-Bit 7 Start Horizontal Retrace Pulse—The value programmed is a binary count of the character position number at which the signal becomes active. #### **End Horizontal Retrace Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 05. The processor output port address for this register is hex 3B5 or hex 3D5. This register specifies the character position at which the Horizontal Retrace Pulse becomes inactive (logical 0). Bit 0-Bit 4 End Horizontal Retrace—A value equal to the five least significant bits of the horizontal character counter value at which time the horizontal retrace signal becomes inactive (logical 0). To obtain a retrace signal of width W, the following algorithm is used: Value of Start Retrace Register + width of horizontal retrace signal in character clock units = 5-bit result to be programmed into the End Horizontal Retrace Register. Bit 5-Bit 6 Horizontal Retrace Delay—These bits control the skew of the horizontal retrace signal. Binary 00 equals no Horizontal Retrace Delay. For some modes, it is necessary to provide a horizontal retrace signal that takes up the entire blanking interval. Some internal timings are generated by the falling edge of the horizontal retrace signal. To guarantee the signals are latched properly, the retrace signal is started before the end of the display enable signal, and then skewed several character clock times to provide the proper screen centering. Bit 7 Start Odd/Even Memory Address—This bit controls whether the first CRT memory address output after a horizontal retrace begins with an even or an odd address. A logical 0 selects even addresses; a logical 1 selects odd addresses. This bit is used for horizontal pel panning applications. Generally, this bit should be set to a logical 0. #### **Vertical Total Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 06. The processor output port address for this register is hex 3B5 or 3D5. #### Bit 0-Bit 7 Vertical Total—This is the low-order eight bits of a nine-bit register. The binary value represents the number of horizontal raster scans on the CRT screen, including vertical retrace. The value in this register determines the period of the vertical retrace signal. Bit 8 of this register is contained in the CRT Controller Overflow Register hex 07 bit 0. # **CRT Controller Overflow Register** This is a write-only register pointed to when the value in the CRT Controller Address Register is hex 07. The processor output port address for this register is hex 3B5 or hex 3D5. | Bit 0 | Vertical Total—Bit 8 of the Vertical Total register (index hex 06). | |-------|-----------------------------------------------------------------------------------------------| | Bit 1 | Vertical Display Enable End—Bit 8 of the Vertical Display Enable End register (index hex 12). | | Bit 2 | Vertical Retrace Start—Bit 8 of the Vertical Retrace Start register (index hex 10). | | Bit 3 | Start Vertical Blank—Bit 8 of the Start Vertical Blank register (index hex 15). | | Bit 4 | Line Compare—Bit 8 of the Line Compare register (index hex 18). | | Bit 5 | Cursor Location—Bit 8 of the Cursor Location register (index hex 0A). | #### **Preset Row Scan Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 08. The processor output port address for this register is hex 3B5 or hex 3D5. This register is used for pel scrolling. Bit 0-Bit 4 Preset Row Scan (Pel Scrolling)—This register specifies the starting row scan count after a vertical retrace. The row scan counter increments each horizontal retrace time until a maximum row scan occurs. At maximum row scan compare time the row scan is cleared (not preset). #### **Maximum Scan Line Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 09. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 4 Maximum Scan Line—This register specifies the number of scan lines per character row. The number to be programmed is the maximum row scan number minus one. # **Cursor Start Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 0A. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 4 Cursor Start—This register specifies the row scan of a character line where the cursor is to begin. The number programmed should be one less than the starting cursor row scan. #### **Cursor End Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 0B. The processor output port address for this register is hex 3B5 or hex 3D5. - Bit 0-Bit 4 Cursor End—These bits specify the row scan where the cursor is to end. - Bit 5-Bit 6 Cursor Skew—These bits control the skew of the cursor signal. | Bits | | | |------|---|----------------------------| | 6 | 5 | | | 0 | 0 | Zero character clock skew | | 0 | 1 | One character clock skew | | 1 | 0 | Two character clock skew | | 1 | 1 | Three character clock skew | #### **Start Address High Register** This is a read/write register pointed to when the value in the CRT Controller address register is hex 0C. The processor input/output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Start Address High—These are the high-order eight bits of the start address. The 16-bit value, from the high-order and low-order start address registers, is the first address after the vertical retrace on each screen refresh. #### **Start Address Low Register** This is a read/write register pointed to when the value in the CRT Controller address register is hex 0D. The processor input/output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Start Address Low—These are the low-order 8 bits of the start address. #### **Cursor Location High Register** This is a read/write register pointed to when the value in the CRT Controller address register is hex 0E. The processor input/output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Cursor Location High—These are the high-order 8 bits of the cursor location. # **Cursor Location Low Register** This is a read/write register pointed to when the value in the CRT Controller address register is hex 0F. The processor input/output port address for this register is hex 3B5 or Hex 3D5. Bit 0-Bit 7 Cursor Location Low— These are the low-order 8 bits of the cursor location. #### **Vertical Retrace Start Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 10. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Vertical Retrace Start—This is the low-order 8 bits of the vertical retrace pulse start position programmed in horizontal scan lines. Bit 8 is in the overflow register location hex 07. #### Light Pen High Register This is a read-only register pointed to when the value in the CRT Controller address register is hex 10. The processor input port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Light Pen High—This is the high order 8 bits of the memory address counter at the time the light pen was triggered. #### **Vertical Retrace End Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 11. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 3 Vertical Retrace End—These bits determine the horizontal scan count value when the vertical retrace output signal becomes inactive. The register is programmed in units of horizontal scan lines. To obtain a vertical retrace signal of width W, the following algorithm is used: Value of Start Vertical Retrace Register + width of vertical retrace signal in horizontal scan units = 4-bit result to be programmed into the End Horizontal Retrace Register. Bit 4 Clear Vertical Interrupt—A logical 0 will clear a vertical interrupt. Bit 5 Enable Vertical Interrupt—A logical 0 will enable vertical interrupt. # **Light Pen Low Register** This is a read-only register pointed to when the value in the CRT Controller address register is hex 11. The processor input port address for this register is hex 3B5 or 3D5. Bit 0-Bit 7 Light Pen Low—This is is the low-order 8 bits of the memory address counter at the time the light pen was triggered. #### Vertical Display Enable End Register This is a write-only register pointed to when the value in the CRT Controller address register is hex 12. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Vertical Display Enable End—These are the low-order 8 bits of the vertical display enable end position. This address specifies which scan line ends the active video area of the screen. Bit 8 is in the overflow register location hex 07. #### Offset Register This is a write-only register pointed to when the value in the CRT Controller address register is hex 13. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Offset—This register specifies the logical line width of the screen. The starting memory address for the next character row is larger than the current character row by this amount. The Offset Register is programmed with a word address. Depending upon the method of clocking the CRT Controller, this word address is either a word or double word address. #### **Underline Location Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 14. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 4 Underline Location—This register specifies the horizontal row scan on which underline will occur. The value programmed is one less than the scan line number desired. ## **Start Vertical Blanking Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 15. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Start Vertical Blank—These are the low 8 bits of the horizontal scan line count, at which the vertical blanking signal becomes active. Bit 8 bit is in the overflow register hex 07. #### **End Vertical Blanking Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 16. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 4 End Vertical Blank—This register specifies the horizontal scan count value when the vertical blank output signal becomes inactive. The register is programmed in units of horizontal scan lines. To obtain a vertical blank signal of width W, the following algorithm is used: Value of Start Vertical Blank Register + width of vertical blank signal in horizontal scan units = 5-bit result to be programmed into the End Vertical Blank Register. #### **Mode Control Register** This is a write-only register pointed to when the value in the CRT Controller address register is hex 17. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0 Compatibility Mode Support— When this bit is a logical 0, the row scan address bit 0 is substituted for memory address bit 13 during active display time. A logical 1 enables memory address bit 13 to appear on the memory address output bit 13 signal of the CRT Controller. The CRT Controller used on the IBM Color/Graphics Monitor Adapter is the 6845. The 6845 has 128 horizontal scan line address capability. To obtain 640 by 200 graphics resolution, the CRTC was programmed for 100 horizontal scan lines with 2 row scan addresses per character row. Row scan address bit 0 became the most significant address bit to the display buffer. Successive scan lines of the display image were displaced in memory by 8K bytes. This bit allows compatibility with the 6845 and Color Graphics APA modes of operation. Bit 1 Select Row Scan Counter—A logical 0 selects row scan counter bit 1 on MA 14 output pin. A logical 1 selects MA 14 counter bit on MA 14 output pin. Horizontal Retrace Select—This bit selects Horizontal Retrace or Horizontal Retrace divided by 2 as the clock that controls the vertical timing counter. This bit can be used to effectively double the vertical resolution capability of the CRT Controller. The vertical counter has a maximum resolution of 512 scan lines due to the 9-bit wide Vertical Total Register. If the vertical counter is clocked with the horizontal retrace divided by 2 clock, then the vertical resolution is doubled to 1024 horizontal scan lines. A logical 0 selects HRTC and a logical 1 selects HRTC divided by 2. Bit 3 Count By Two— When this bit is set to 0, the memory address counter is clocked with the character clock input. A logical 1 clocks the memory address counter with the character clock input divided by 2. This bit is used to create either a byte or word refresh address for the display buffer. Bit 4 Output Control—A logical 0 enables the module output drivers. A logical 1 forces all outputs into high impedance state. Address Wrap—This bit selects Memory Address counter bit MA 13 or bit MA 15, and it appears on the MA 0 output pin in the word address mode. If you are not in the word address mode, MA 0 counter output appears on the MA 0 output pin. A logical 1 selects MA 15. In odd/even mode, bit MA 13 should be selected when the 64K memory is installed on the board. Bit MA 15 should be selected when greater then 64K memory is installed. This function is used to implement Color Graphics Monitor Adapter compatibility. Bit 6 Word Mode or Byte Mode—When this bit is a logical 0, the Word Mode shifts all memory address counter bits down one bit, and the most significant bit of the counter appears on the least significant bit of the memory address outputs. See table below for address output details. A logical 1 selects the Byte Address mode. | | Internal Memory Address Counter<br>Wiring to the Output Multiplexer | | |--------------|---------------------------------------------------------------------|----------------------| | CRTC Out Pin | Byte Address<br>Mode | Word Address<br>Mode | | MA 0/RFA 0 | MA 0 | MA 15 or MA 13 | | MA 1/RFA 1 | MA 1 | MAO | | MA 2/RFA 2 | MA 2 | MA 1 | | MA 3/RFA 3 | MA3 | MA 2 | | * | * | * | | * | * | * | | * | * | * | | MA 14/RS 3 | MA 14 | MA 13 | | MA 15/RS 4 | MA 15 | MA 14 | Bit 7 Hardware Reset—A logical 0 forces horizontal and vertical retrace to clear. A logical 1 forces horizontal and vertical retrace to be enabled. #### Line Compare Register This is a write-only register pointed to when the value in the CRT Controller address register is hex 18. The processor output port address for this register is hex 3B5 or hex 3D5. Bit 0-Bit 7 Line Compare—This register is the low-order 8 bits of the compare target. When the vertical counter reaches this value, the internal start of the line counter is cleared. This allows an area of the screen to be immune to scrolling. Bit 8 of this register is in the overflow register hex 07. # **Graphics Controller Registers** | Name | Port | Index | |------------------------|------|-------| | Graphics 1 Position | 3CC | - | | Graphics 2 Position | 3CA | - | | Graphics 1 & 2 Address | 3CE | - | | Set/Reset | 3CF | 00 | | Enable Set/Reset | 3CF | 01 | | Color Compare | 3CF | 02 | | Data Rotate | 3CF | 03 | | Read Map Select | 3CF | 04 | | Mode Register | 3CF | 05 | | Miscellaneous | 3CF | 06 | | Color Don't Care | 3CF | 07 | | Bit Mask | 3CF | 08 | #### **Graphics 1 Position Register** This is a write-only register. The processor output port address for this register is hex 3CC. Bit 0-Bit 1 Position—These 2 bits are binary encoded hierarchy bits for the graphics chips. The position register controls which 2 bits of the processor data bus each chip responds to. Graphics 1 must be programmed with a position register value of 0 for this card. #### **Graphics 2 Position Register** This is a write-only register. The processor output port address for this register is hex 3CA. Bit 0-Bit 1 Position—These 2 bits are binary encoded hierarchy bits for the graphics chips. The position register controls which 2 bits of the processor data bus to which each chip responds. Graphics 2 must be programmed with a position register value of 1 for this card. # **Graphics 1 and 2 Address Register** This is a write-only register and the processor output port address for this register is hex 3CE. Bit 0-Bit 3 Graphics 1 and 2 Address Bits—This output loads the address register in both graphics chips simultaneously. This register points to the data register of the graphics chips. #### Set/Reset Register This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 00 before writing can take place. The processor output port address for this register is hex 3CF. Bit 0-Bit 3 Set/Reset—These bits represent the value written to the respective memory planes when the processor does a memory write with write mode 0 selected and set/reset mode is enabled. Set/Reset can be enabled on a plane by plane basis with separate OUT commands to the Set/Reset register. ### **Enable Set/Reset Register** This is a write-only register and is pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 01 before writing can take place. The processor output port for this register is hex 3CF. Bit 0-Bit 3 Enable Set/Reset—These bits enable the set/reset function. The respective memory plane is written with the value of the Set/Reset register provided the write mode is 0. When write mode is 0 and Set/Reset is not enabled on a plane, that plane is written with the value of the processor data. ### **Color Compare Register** This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 02 before writing can take place. The processor output port address for this register is hex 3CF. Bit 0-Bit 3 Color Compare—These bits represent a 4 bit color value to be compared. If the processor sets read mode 1 on the graphics chips, and does a memory read, the data returned from the memory cycle will be a 1 in each bit position where the 4 bit planes equal the color compare register. #### **Data Rotate Register** This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 03 before writing can take place. The processor output port address for this register is hex 3CF. - Bit 0-Bit 2 Rotate Count—These bits represent a binary encoded value of the number of positions to rotate the processor data bus during processor memory writes. This operation is done when the write mode is 0. To write unrotated data the processor must select a count of 0. - Bit 3-Bit 4 Function Select—Data written to memory can operate logically with data already in the processor latches. The bit functions are defined in the following table. | Bi | its | |----|-----| | 4 | 3 | | _ | _ | - **0 0** Data unmodified. - 0 1 Data AND'ed with latched data. - 1 0 Data OR'ed with latched data. - 1 1 Data XOR'ed with latched data. Data may be any of the choices selected by the Write Mode Register except processor latches. If rotated data is selected, the rotate applies before the logical function. #### **Read Map Select Register** This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 04 before writing can take place. The processor output port address for this register is hex 3CF. Bit 0-Bit 2 Map Select—These bits represent a binary encoded value of the memory plane number from which the processor reads data. This register has no effect on the color compare read mode described elsewhere in this section. #### **Mode Register** This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 05 before writing can take place. The processor output port address for this register is 3CF. Bit 0-Bit 1 Write Mode #### Bits 1 0 - O O Each memory plane is written with the processor data rotated by the number of counts in the rotate register, unless Set/Reset is enabled for the plane. Planes for which Set/Reset is enabled are written with 8 bits of the value contained in the Set/Reset register for that plane. - **0 1** Each memory plane is written with the contents of the processor latches. These latches are loaded by a processor read operation. - Memory plane n (0 through 3) is filled with 8 bits of the value of data bit n. - 1 1 Not Valid The logic function specified by the function select register also applies. Bit 2 Test Condition—A logical 1 directs graphics controller outputs to be placed in high impedance state for testing. - Bit 3 Read Mode—When this bit is a logical 0, the processor reads data from the memory plane selected by the read map select register. When this bit is a logical 1, the processor reads the results of the comparison of the 4 memory planes and the color compare register. - Bit 4 Odd/Even—A logical 1 selects the odd/even addressing mode, which is useful for emulation of the Color Graphics Monitor Adapter compatible modes. Normally the value here follows the value of the Memory Mode Register bit 3 of the Sequencer. - Bit 5 Shift Register—A logical 1 directs the shift registers on each graphics chip to format the serial data stream with even numbered bits on the even numbered maps and odd numbered bits on the odd maps. #### **Miscellaneous Register** This is a write-only register pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 06 before writing can take place. The processor output port for this register is hex 3CF. Graphics Mode—This bit controls alpha-mode Bit 0 addressing. A logical 1 selects graphics mode. When set to graphics mode, the character generator address latches are disabled. Chain Odd Maps To Even Maps—When set to 1, Bit 1 this bit directs the processor address bit 0 to be replaced by a higher order bit and odd/even maps to be selected with odd/even values of the processor A0 bit, respectively. Bit 2-Bit 3 Memory Map—These bits control the mapping of the regenerative buffer into the processor address space. | | its<br>2 | | |--------|----------|--------------------------| | _<br>0 | 0 | Hex A000 for 128K bytes. | | 0 | 1 | Hex A000 for 64K bytes. | | 1 | 0 | Hex B000 for 32K bytes | | 1 | 1 | Hex B800 for 32K bytes. | If the display adapter is mapped at address hex A000 for 128K bytes, no other adapter can be installed in the system. #### Color Don't Care Register This is a write-only register and is pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 07 before writing can take place. The processor output port for this register is hex 3CF. - Bit 0 Color Don't Care—Color plane 0=don't care when reading color compare when this bit is set to 1. - Bit 1 Color Don't Care—Color plane 1=don't care when reading color compare when this bit is set to 1. - Bit 2 Color Don't Care—Color plane 2=don't care when reading color compare when this bit is set to 1. - Bit 3 Color Don't Care—Color plane 3=don't care when reading color compare when this bit is set to 1. # Bit Mask Register This is a write-only register and is pointed to by the value in the Graphics 1 and 2 address register. This value must be hex 08 before writing can take place. The processor output port for this register is hex 3CF. # Bit 0-Bit 7 Bit Mask—Any bit programmed to *n* causes the corresponding bit *n* in each bit plane to be immune to change provided that the location being written was the last location read by the processor. Bits programmed to a 1 allow unimpeded writes to the corresponding bits in the The bit mask applies to any data written by the processor (rotate, AND'ed, OR'ed, XOR'ed, DX and S/R). To preserve bits using the bit mask, data must be latched internally by reading the location. When data is written to preserve the bits, the most current data in latches is written in those positions. The bit mask applies to all bit planes simultaneously. bit planes. # **Attribute Controller Registers** | Name | Port | Index | |---------------------------------|------|-------| | Address Register | 3C0 | - | | Palette Registers | 3C0 | 00-0F | | Mode Control Register | 3C0 | 10 | | Overscan Color Register | 3C0 | 11 | | Color Plane Enable Register | 3C0 | 12 | | Horizontal Pel Panning Register | 3C0 | 13 | ### **Attribute Address Register** This is a write-only register. The processor output port is hex 3C0. #### Bit 0-Bit 4 Attribute Address Bits—The Address Register is a pointer register located at hex 3C0. This register is loaded with a binary value that points to the attribute data register where data is to be written. The Attribute Controller does not have an address bit input to control selection of the address and data registers. An internal address flip-flop controls selection of either the address or data registers. To initialize the flip-flop, an IOR instruction is issued to the Attribute Controller at address 3BA or 3DA. This clears the flip-flop, and selects the Address Register. After the Address Register has been loaded, the next OUT instruction loads the data register. The flip-flop toggles each time an OUT is issued to the Attribute Controller. Bit 5 Palette Address Source—When loading the color palette registers, bit 5 must be cleared to 0. To enable the memory data to access the color palette, bit 5 must be set to 1. #### Palette Register Hex 00 through Hex 0F This is a write-only register. The processor output port is hex 3C0. Bit 0-Bit 5 Palette—These 6-bit registers allow a dynamic mapping between the text attribute or graphic color input value and the display color in the CRT screen. A logical 1 selects the appropriate color. A logical 0 de-selects. The color palette register should be modified only during the vertical retrace interval to avoid glitches in the displayed image. Note that some color monitors do not have an intensity input and only a maximum of eight colors are available. Monitors with four color inputs display sixteen colors, and monitors with six color inputs display 64 colors. #### **Mode Control Register** This is a write-only register pointed to by the value in the Attribute address register. This value must be hex 10 before writing can take place. The processor output port address for this register is hex 3C0. - Bit 0 Graphics/Alphanumeric Mode—A logical 0 selects alphanumeric mode. A logical 1 selects graphics mode. - Bit 1 Monochrome Display/Color Display—A logical 0 selects IBM monochrome display attributes. A logical 1 selects color Display attributes. - Bit 2 Enable Line Graphics Character Codes—When this bit is set to 0, the ninth dot will be the same as the background. A logical 1 enables the special line graphics character codes for the IBM Monochrome Display adapter. When enabled, this bit forces the ninth dot of a line graphic character to be identical to the eighth dot of the character. The line graphics character codes for the Monochrome Display Adapter are Hex C0 through Hex DF. For character fonts that do not utilize the line graphics character codes in the range of Hex C0 through Hex DF, bit 2 of this register should be a logical 0. Otherwise unwanted video information will be displayed on the CRT screen. Bit 3 Enable Blink/Select Background Intensity—A logical 0 selects the background intensity of the attribute input. This mode was available on the Monochrome and Color Graphics adapters. A logical 1 enables the blink attribute in alphanumeric modes. This bit must also be set to 1 for blinking graphics modes. #### **Overscan Color Register** This is a write-only register pointed to by the value in the Attribute address register. This value must be hex 11 before writing can take place. The processor output port address for this register is hex 3C0. Overscan Color—This 6-bit register determines Bit 0-Bit 5 the overscan (border) color displayed on the CRT screen. For monochrome display this register should be set to a value of 0. A logical 1 selects the appropriate color. #### **Color Plane Enable Register** This is a write-only register pointed to by the value in the Attribute address register. This value must be hex 12 before writing can take place. The processor output port address for this register is 3C0. - Bit 0-Bit 3 Enable Color Plane—Writing a logical 1 in any of bits 0 through 3 enables the respective display memory color plane. - Bit 4-Bit 5 Video Status MUX—Selects two of the six color outputs to be available on the status port. The following table illustrates the combinations available and the color output wiring. | COLOR PLANE<br>ENABLE REGISTER | | INPUT STATUS<br>REGISTER ONE | | |--------------------------------|-------|------------------------------|-----------------| | Bit 5 | Bit 4 | Bit 5 | Bit 4 | | 0 | 0 | Red | Blue | | 0 | 1 | Secondary Blue | Green | | 1 | 0 | Secondary Red | Secondary Green | | 1 | 1 | Not Used | Not Used | #### **Horizontal Pel Panning Register** This is a write-only register pointed to by the value in the Attribute address register. This value must be hex 12 before writing can take place. The processor output port address for this register is hex 3C0. Bit 0-Bit 3 Horizontal Pel Panning—This 4 bit register selects the number of picture elements (pels) to shift the video data horizontally to the left. Pel panning is available in both A/N and APA modes. In Monochrome A/N mode, the image can be shifted a maximum of 9 pels. In all other A/N and APA modes, the image can be shifted a maximum of 8 pels. The sequence for shifting the image is given below: 9 pels/character: 8, 0, 1, 2, 3, 4, 5, 6, 7 (Monochrome A/N mode only) 8 pels/character: 0, 1, 2, 3, 4, 5, 6, 7 (All other Modes) # **Programming Considerations** # **Programming the Registers** Each of the LSI devices has an address register and a number of data registers. The address register serves as a pointer to the other registers on the LSI device. It is a write-only register that is loaded by the processor by executing an 'OUT' instruction to its I/O address with the index of the selected data register. The data registers on each LSI device are accessed through a common I/O address. They are distinguished by the pointer (index) in the address register. To write to a data register, the address register is loaded with the index of the appropriate data register, then the selected data register is loaded by executing an 'OUT' instruction to the common I/O address. The external registers that are not part of an LSI device and the Graphics I and II registers are not accessed through an address register; they are written to directly. The following tables define the values that are loaded into the registers by BIOS to support the different modes of operation supported by this adapter. | Regis | ter | | | | | | | | | M | ode of | Ope | ation | | | | | | | | |---------------|------|-------|----|----|----|----|----|----|----|------------|--------|-----|-------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F‡ | 10* | 0* | 1* | 2* | 3* | | Miscellaneous | 3C2 | - | 23 | 23 | 23 | 23 | 23 | 23 | 23 | <b>A</b> 6 | 23 | 23 | A2 | Α7 | A2 | Α7 | Α7 | Α7 | A7 | Α7 | | Feature Cntrl | 3?A | _ | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Input Stat 0 | 3C2 | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Input Stat 1 | 3?2 | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | <sup>? =</sup> B in monochrome modes ? = D in color modes ### **External Registers** | Re | egister | | | | | | | | | M | ode o | f Ope | ration | 1 | | | | | | | |------------------|------------------------------------------------------------------------|-------|----|----|----|----|----|----|----|----|-------|-------|--------|----|----|-----|-----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F* | 10* | 0* | 1* | 2* | 3* | | Seq Address | 3C4 | - | - | - | - | - | 1 | - | - | 1 | - | - | - | - | - | - | - : | - | - | - | | Reset | 3C5 | 00 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | 03 | | Clock Mode | 3C5 | 01 | 0В | 0В | 01 | 01 | 0В | 0B | 01 | 00 | 0B | 01 | 05 | 05 | 01 | 01 | 0B | 0B | 01 | 01 | | Map Mask | | | | | | | | | | | | | | | | | | | | | | Char Gen Sel | 3C5 | 03 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Memory Mode | 3C5 | 04 | 03 | 03 | 03 | 03 | 02 | 02 | 06 | 03 | 06 | 06 | 00 | 00 | 06 | 06 | 03 | 03 | 03 | 03 | | *Values for thes | /alues for these modes when the IBM Enhanced Color Display is attached | | | | | | | | | | | | | | | | | | | | <sup>\*</sup>Values for these modes when greater than 64K Graphics Memory is installed ### **Sequencer Registers** <sup>\*</sup>Values for these modes when the IBM Enhanced Color Display is attached <sup>\*</sup>Values for these modes when greater than 64K Graphics Memory is installed | Re | gister | | | | | | | | | M | ode ( | of Ope | eratio | n | | | | | | | |------------------|---------------------------------------------|--------|-------|--------|------|------|------|-------|------|-------|-------|--------|--------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F‡ | 10* | 0* | 1* | 2* | 3* | | Address Reg | 3?4 | _ | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Horiz Total | 3?5 | 00 | 37 | 37 | 70 | 70 | 37 | 37 | 70 | 60 | 37 | 70 | 60 | 5B | 60 | 5B | 2D | 2D | 5B | 5B | | Hrz Disp End | 3?5 | 01 | 27 | 27 | 4F | 4F | 27 | 27 | 4F | 4F | 27 | 4F | 4F | 4F | 4F | 4F | 27 | 27 | 4F | 4F | | Strt Hrz Blk | 3?5 | 02 | 2D | 2D | 5C | 5C | 2D | 2D | 59 | 56 | 2D | 56 | 56 | 53 | 56 | 53 | 2B | 2B | 53 | 53 | | End Hrz Blk | 3?5 | 03 | 37 | 37 | 2F | 2F | 37 | 37 | 2D | 3A | 37 | 2D | 1A | 17 | ЗА | 37 | 2D | 2D | 37 | 37 | | Strt Hrz Retr | 3?5 | 04 | 31 | 31 | 5F | 5F | 30 | 30 | 5E | 51 | 30 | 5E | 50 | 50 | 50 | 52 | 28 | 28 | 51 | 51 | | End Hrz Retr | 3?5 | 05 | 15 | 15 | 07 | 07 | 14 | 14 | 06 | 60 | 14 | 06 | E0 | ВА | 60 | 00 | 6D | 6D | 5B | 5B | | Vert Total | 3?5 | 06 | 04 | 04 | 04 | 04 | 04 | 04 | 04 | 70 | 04 | 04 | 70 | 6C | 70 | 6C | 6C | 6C | 6C | 6C | | Overflow | 3?5 | 07 | 11 | 11 | 11 | 11 | 11 | 11 | 11 | 1F | 11 | 11 | 1F | Preset Row SC | 3?5 | 08 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Max Scan Line | 3?5 | 09 | 07 | 07 | 07 | 07 | 01 | 01 | 01 | 0D | 00 | 00 | 00 | 00 | 00 | 00 | 0D | 0D | 0D | 0D | | Cursor Start | 3?5 | 0A | 06 | 06 | 06 | 06 | 00 | 00 | 00 | 0B | 00 | 00 | 00 | 00 | 00 | 00 | 0B | 0B | 0В | 0В | | Cursor End | 3?5 | 0B | 07 | 07 | 07 | 07 | 00 | 00 | 00 | 0C | 00 | 00 | 00 | 00 | 00 | 00 | 0C | 0C | 0C | 0C | | Strt Addr Hi | 3?5 | 0C | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Strt Addr Lo | 3?5 | 0D | - | - | - | - | - | - | - | _ | - | - | - | - | - | - | - | - | - | - | | ? = B in monocl | = B in monochrome modes ?= D in color modes | | | | | | | | | | | | | | | | | | | | | *Values for thes | e mode | s when | the I | вм в | nhai | nced | Colo | r Dis | play | is at | ache | d | | | | | | | | | | *Values for thes | e mode | s when | great | ter th | an 6 | 4K G | raph | ics N | lemo | ry is | insta | alled | | | | | | | | | ### CRT Controller Registers (1 of 2) | Re | gister | | | | | | | | | M | ode o | f Ope | ration | 1 | | | | | | | |---------------|--------|-------|----|----|----|----|----|----|----|----|-------|-------|--------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F* | 10* | 0* | 1* | 2* | 3* | | Cursor LC Hi | 3?5 | 0E | - | - | - | - | - | _ | - | - | - | 1 | - | - | - | - | - | - | - | - | | Cursor LC Low | 3?5 | 0F | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | _ | - | - | | Vrt Retr Strt | 3?5 | 10 | E1 | E1 | E1 | E1 | E1 | E1 | E0 | 5E | E1 | E0 | 5E | Light Pen Hi | 3?5 | 10 | - | - | - | - | - | - | - | - | - | 1 | - | - | - | - | - | - | - | - | | Vert Retr End | 3?5 | 11 | 24 | 24 | 24 | 24 | 24 | 24 | 23 | 2E | 24 | 23 | 2E | 2B | 2E | 2B | 2B | 2B | 2B | 2B | | Light Pen Low | 3?5 | 11 | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Vrt Disp End | 3?5 | 12 | C7 5D | C7 | C7 | 5D | 5D | 5D | 5D | 5D | 5D | 50 | 5D | | Offset | 3?5 | 13 | 14 | 14 | 28 | 28 | 14 | 14 | 28 | 28 | 14 | 28 | 14 | 14 | 28 | 28 | 14 | 14 | 28 | 28 | | Underline Loc | 3?5 | 14 | 08 | 08 | 08 | 08 | 00 | 00 | 00 | 0D | 00 | 00 | OD | 0F | OD | 0F | 0F | 0F | 0F | 0F | | Strt Vert Blk | 3?5 | 15 | E0 | E0 | E0 | E0 | E0 | E0 | DF | 5E | E0 | DF | 5E | 5F | 5E | 5F | 5E | 5E | 5E | 5E | | End Vert Blk | 3?5 | 16 | F0 | F0 | F0 | F0 | F0 | F0 | EF | 6E | F0 | EF | 6E | 0A | 6E | 0A | 0A | 0A | 0A | 0А | | Mode Control | 3?5 | 17 | А3 | А3 | А3 | А3 | A2 | A2 | C2 | А3 | E3 | E3 | 8B | 8B | E3 | E3 | А3 | А3 | А3 | А3 | | Line Compare | 3?5 | 18 | FF <sup>? =</sup> B in monochrome modes ### **CRT Controller Registers (2 of 2)** <sup>? =</sup> D in color modes <sup>\*</sup>Values for these modes when the IBM Enhanced Color Display is attached <sup>#</sup>Values for these modes when greater than 64K Graphics Memory is installed | Ro | egister | | | | | | | | | M | lode c | f Ope | ratio | 1 | | | -, | | | | |------------------|---------|--------|----------------------------------------|--------|-------|-------|-------|-------|------|-------|--------|-------|-------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F‡ | 10‡ | 0* | 1* | 2* | 3* | | Grphx I Pos | 3CC | - | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Grphx II Pos | 3CA | - | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | 01 | | Grphx I II AD | 3CE | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Set Reset | 3CF | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Enable S/R | 3CF | 01 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Color Compare | 3CF | 02 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Data Rotate | 3CF | 03 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | | | | | | | | | | | | | | | | | | | Read Map Sel | 3CF | 04 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Mode Register | 3CF | 05 | 10 | 10 | 10 | 10 | 30 | 30 | 00 | 10 | 00 | 00 | 10 | 10 | 00 | 00 | 10 | 10 | 10 | 10 | | Miscellaneous | 3CF | 06 | 0E | 0E | 0E | 0E | 0F | 0F | 0D | 0A | 05 | 05 | 07 | 07 | 05 | 05 | 0E | 0E | 0E | 0E | | Color No Care | 3CF | 07 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 0F | 0F | 0F | 0F | 0F | 0F | 00 | 00 | 00 | 00 | | Bit Mask | 3CF | 08 | FF | *Values for thes | e mode | s when | the | ВМ | Enha | nced | Colo | r Dis | play | is at | tache | ed | | | | | | | | | | *Values for thes | e mode | s when | orea | ter ti | han 6 | 34K ( | Grant | ics I | Memo | rv is | inst | alled | | | | | | | | | # Graphics SI Registers | Reg | ister | | | | | | | | | M | ode ( | f Ope | ratio | 1 | | | | | | | |-----------------|----------|--------|-------|--------|-------|--------|-------|-------|------|--------|-------|-------|-------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F‡ | 10‡ | 0* | 1* | 2* | 3* | | Address | 3?A | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | | Palette | 3C0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Palette | 3C0 | 01 | 01 | 01 | 01 | 01 | 13 | 13 | 17 | 08 | 01 | 01 | 08 | 01 | 08 | 01 | 01 | 01 | 01 | 01 | | Palette | 3C0 | 02 | 02 | 02 | 02 | 02 | 15 | 15 | 17 | 08 | 02 | 02 | 00 | 00 | 00 | 02 | 02 | 02 | 02 | 02 | | Palette | 3C0 | 03 | 03 | 03 | 03 | 03 | 17 | 17 | 17 | 08 | 03 | 03 | 00 | 00 | 00 | 03 | 03 | 03 | 03 | 03 | | Palette | 3C0 | 04 | 04 | 04 | 04 | 04 | 02 | 02 | 17 | 08 | 04 | 04 | 18 | 04 | 18 | 04 | 04 | 04 | 04 | 04 | | Palette | 3C0 | 05 | 05 | 05 | 05 | 05 | 04 | 04 | 17 | 08 | 05 | 05 | 18 | 07 | 18 | 05 | 05 | 05 | 05 | 05 | | Palette | 3C0 | 06 | 06 | 06 | 06 | 06 | 06 | 06 | 17 | 08 | 06 | 06 | 00 | 00 | 00 | 06 | 14 | 14 | 14 | 14 | | Palette | 3C0 | 07 | 07 | 07 | 07 | 07 | 07 | 07 | 17 | 08 | 07 | 07 | 00 | 00 | 00 | 07 | 07 | 07 | 07 | 07 | | Palette | 3C0 | 08 | 10 | 10 | 10 | 10 | 10 | 10 | 17 | 10 | 10 | 10 | 00 | 00 | 00 | 38 | 38 | 38 | 38 | 38 | | Palette | 3C0 | 09 | 11 | 11 | 11 | 11 | 11 | 11 | 17 | 18 | 11 | 11 | 08 | 01 | 08 | 39 | 39 | 39 | 39 | 39 | | Palette | 3C0 | 0A | 12 | 12 | 12 | 12 | 12 | 12 | 17 | 18 | 12 | 12 | 00 | 00 | 00 | 3A | 3A | 3A | 3A | 3A | | Palette | 3C0 | 0В | 13 | 13 | 13 | 13 | 13 | 13 | 17 | 18 | 13 | 13 | 00 | 00 | 00 | 3В | 3В | 3В | 3В | 3В | | ? = B in mono | chrome r | nodes | ? | = D | in co | olor n | node | S | | | | | | | | | | | | | | *Values for the | se mode | s when | the I | BM E | nhai | nced | Colo | r Dis | play | is att | ache | d | | | | | | | | | | *Values for the | ese mode | s when | grea | ter th | an 6 | 4K G | iraph | ics N | 1emo | ry is | insta | alled | | | | | | | | | # Attribute Registers (1 of 2) | Ro | egister | | | | | | | | | M | ode ( | f Ope | ratio | 1 | | | | | | | |-----------------|------------------------------------------------------------------------|--------|-------|-------|------|------|------|-------|------|-------|-------|-------|-------|----|----|-----|----|----|----|----| | Name | Port | Index | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | D | E | F | 10 | F* | 10‡ | 0* | 1* | 2* | 3* | | Palette | 300 | 0C | 14 | 14 | 14 | 14 | 14 | 14 | 17 | 18 | 14 | 14 | 00 | 04 | 00 | 3C | 3C | 3C | 3C | 3C | | Palette | 300 | 0D | 15 | 15 | 15 | 15 | 15 | 15 | 17 | 18 | 15 | 15 | 18 | 07 | 18 | 3D | 3D | 3D | 3D | 3D | | Palette | 300 | 0E | 16 | 16 | 16 | 16 | 16 | 16 | 17 | 18 | 16 | 16 | 00 | 00 | 00 | 3E | 3E | 3E | 3E | 3E | | Palette | alette 3C0 0F 17 17 17 17 17 17 18 17 17 00 00 31 3F 3F 3F 3F 3F 3F | | | | | | | | | | | | | | | | | | | | | Mode Control | | | | | | | | | | | | | | | | | | | | | | Overscan | 3C0 | 11 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Color Plane | 300 | 12 | 0F | 0F | 0F | 0F | 03 | 03 | 01 | 0F | 0F | 0F | 05 | 05 | 05 | 0F | 0F | 0F | 0F | 0F | | Hrz Panning | 300 | 13 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | *Values for the | Values for these modes when the IBM Enhanced Color Display is attached | | | | | | | | | | | | | | | | | | | | | *Values for the | se mode | s when | great | er th | an 6 | 4K G | raph | ics N | lemo | ry is | insta | illed | | | | | | | | | Attribute Registers (2 of 2) ### **RAM Loadable Character Generator** The character generator on the adapter is RAM loadable and can support characters up to 32 scan lines high. Two character generators are stored within the BIOS and one is automatically loaded into the RAM by the BIOS when an alphanumeric mode is selected. The Character Map Select Register can be programmed to define the function of bit 3 of the attribute byte to be a character generator switch. This allows the user to select between any two character sets residing in bit plane 2. This effectively gives the user access to 512 characters instead of 256. character tables may be loaded off line. The adapter must have 128K bytes of storage to support this function. Up to four tables can be loaded can be loaded with 256K of graphics memory installed. The structure of the character tables is described in the following figure. The character generator is in bit plane 2 and must be protected using the map mask function. The following figure illustrates the structure of each character pattern. If the CRT controller is programmed to generate n row scans, then n bytes must be filled in for each character in the character generator. The example assumes eight row scans per character. CC = Value of the character code. For example, 41H in the case of an ASCII "A". # Creating a 512 Character Set This section describes how to create a 512 character set on the IBM Color Display. Note that only 256 characters can be printed on the printer. This is a special application which the Enhanced Graphics Adapter will support. The 9 by 14 characters will be displayed when attribute bit 3 is a logical 0, and the IBM Color/Graphics Monitor Adapter 8 by 8 characters will be displayed when the attribute bit 3 is a logical 1. This example is for demonstrative purposes only. The assembly language routine for creating 512 characters is given below. Debug 2.0 was used for this example. The starting assembly address is 100 and the character string is stored in location 200. This function requires 128K or more of graphics memory. | a100<br>mov ax,1102<br>mov bl,02<br>int 10 | ;load 8x8 character font in character<br>;generator number 2 | |------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | mov ax,1103<br>mov bl,08<br>int 10 | ;select 512 character operation<br>;if attribute bit 3=1 use 8x8 font<br>;if attribute bit 3=0 use 9x14 font | | mov ax,1000<br>mov bx,0712<br>int 10 | ;set color plane enable to 7H to disable ;attribute bit 3 in the color palette ;lookup table | | mov ax,1301<br>mov bx,000F<br>mov cx,003A<br>mov dx,1600<br>mov bp,0200<br>push cs<br>pop es<br>int 10 | ;write char. string with attribute bit 3=1;cx = character string length; write character on line 22 of display; pointer to character string location | | mov ax ,1301<br>mov bx,0007<br>mov cx,003A<br>mov dx,1700<br>mov bp,0200<br>push cs<br>pop es<br>int 10<br>int 3 | ;write char. string with attribute bit 3=0<br>;cx = character string length<br>;write character on line 23 of display<br>;pointer to character string location | | ••• | Hem a second sec | a200 db "This character string is used to show 512 characters" # Creating an 80 by 43 Alphanumeric Mode The following examples show how to create 80 column by 43 row, both alphanumeric and graphics, images on the IBM Monochrome Display. The BIOS Interface supports an 80 column by n row display by using the character generator load routine call. The print screen routine must be revectored to handle the additional character rows on the screen. The assembly language required for both an alphanumeric and a graphics screen is shown below. mov al,7 ;Monochrome alphanumeric mode int 10 ;video interrupt call mov ax,1112 ;character generator BIOS routine mov bl,0 ;load 8 by 8 double dot character font int 10 ;video interrupt call mov ax,1200 ;alternate screen routine move bl,20 ;select alternate print screen routine int 10 ;video interrupt call int 3 mov ax,f ;Monochrome graphic mode int 10 ;video interrupt call mov ax,1123 ;character generator BIOS routine gload 8 by 8 double dot character font mov dl,2B ;43 character rows int 10 ;video interrupt call mov ax,1200 ;alternate screen routine mov bl,20 ;alternate print screen routine int 10 ;video interrupt call int 3 # **Vertical Interrupt Feature** The Enhanced Graphics Adapter can be programmed to create an interrupt each time the vertical display refresh time has ended. An interrupt handler routine must be written by the application to take advantage of this feature. The CRT Vertical interrupt is on IRQ2. The CPU can poll the Enhanced Graphics Adapter Input Status Register 0 (bit 7) to determine whether the CRTC caused the interrupt to occur. The Vertical Retrace End Register (11H) in the CRT controller contains two bits which are used to control the interrupt circuitry. The remaining bits must be output as per the value in the mode table. - Bit 5 Enable Vertical Interrupt—A logical 0 will enable vertical interrupt. - Bit 4 Clear Vertical Interrupt—A logical 0 will clear a vertical interrupt. The sequence of events which occur in an interrupt handler are outlined below. - 1. Clear IRO latch and enable driver - 2. Enable IRO latch - 3. Wait for vertical interrupt - 4. Poll Interrupt Status Register 0 to determine if CRTC has caused the interrupt - 5. If CRTC interrupt, then clear IRQ latch; if not, then branch to next interrupt handler. - 6. Enable IRQ latch - 7. Update Enhanced Graphics Adapter during vertical blanking interval - 8. Wait for next vertical interrupt # **Creating a Split Screen** The Enhanced Graphics Adapter hardware supports an alphanumeric mode dual screen display. The top portion of the screen is designated as screen A, and the bottom portion of the screen is designated as screen B as per the following figure. ### **Dual Screen Definition** The following figure shows the screen mapping for a system containing a 32K byte alphanumeric storage buffer. Note that the Enhanced Graphics Adapter has a 32K byte storage buffer in alphanumeric mode. Information displayed on screen A is defined by the start address high and low registers (0CH and 0DH) of the CRTC. Information displayed on screen B always begins at address 0000H. ### Screen Mapping Within the Display Buffer Address Space The Line Compare Register (18H) of the CRT Controller is utilized to perform the split screen function. The CRTC has an internal horizontal scan counter, and logic which compares the horizontal scan counter value to the Line Compare Register value and clears the memory address generator when a compare occurs. The linear address generator then sequentially addresses the display buffer starting at location zero, and each subsequent row address is determined by the 16 bit addition of the start of line latch and the offset register. Screen B can be smoothly scrolled onto the CRT screen by updating the Line compare in synchronization with the vertical retrace signal. The information on screen B is immune from scrolling operations which utilize the Start Address High and Low registers to scroll through the Screen A address map. # **Compatibility Issues** The CRT Controller on the IBM Enhanced Graphics Adapter is a custom design, and is different than the 6845 controller used on the IBM Monochrome Monitor Adapter and the IBM Color/Graphics Monitor Adapter. It should be noted that several CRTC register addresses differ between the adapters. The following figure illustrates the registers which do not map directly across the two controllers. | Register | 6485 Function | EGA CRTC Function | |----------|-------------------------|-----------------------| | 02H | Start Horiz. Retrace | Start Horiz. Blanking | | 03H | End Horiz. Retrace | End Horiz. Blanking | | 04H | Vertical Total | Start Horiz. Retrace | | 05H | Vertical Total Adjust | End Horiz. Retrace | | 06H | Vertical Displayed | Vertical Total | | 07H | Vertical Sync Position | Overflow | | 08H | Interlace Mode and Skew | Preset Row Scan | Existing applications which utilize the BIOS interface will generally be compatible with the Enhanced Graphics Adapter. Horizontal screen centering was required on the IBM Color/Graphics Monitor Adapter in order to center the screen when generating composite video. This was done through the Horizontal Sync Position Register. Since the Enhanced Graphics Adapter does not support a composite video monitor, programs which do screen centering may cause loss of the screen image if centering is attempted. The Enhanced Graphics Adapter offers a wider variety of displayable monochrome character attributes than the IBM Monochrome Display Adapter. Some attribute values may display differently between the two Adapters. The values listed in the table below, in any combinations with the blink and intensity attributes, will display identically. | Background<br>R G B | Foreground<br>R G B | Function | |---------------------|---------------------|----------------------------------| | 0 0 0 | 0 0 0 | Non-Display | | 000 | 0 0 1 | Underline | | 0 0 0 | 1 1 1 | White Character/Black Background | | 1 1 1 | 0 0 0 | Reverse Video | Software which explicitly addresses 3D8 (Mode Select Register) or 3D9 (Color Select Register) on the Color Graphics Monitor Adapter may produce different results on the Enhanced Graphics Adapter. For example, blinking which is disabled by writing to 3D8 on the Color Graphics Adapter will not be disabled on the Enhanced Graphics Adapter. # Interface ### **Feature Connector** The following is a description of the Enhanced Graphics Adapter feature connector. Note that signals coming from the Enhanced Graphics Adapter are labeled "inputs" and the signals coming to the Enhanced Graphics Adapter through the feature connector are labeled "outputs". | Signal | Description | |--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J2 | This pin is connected to auxiliary jack 2 on the rear panel of the adapter. | | R'OUT | Secondary red output | | ATRS/L | Attribute shift load. This signal controls the serialization of the video information. The shift register parallel loads at the dot clock leading edge when this signal is low. | | G OUT | Primary green output | | R' | Secondary red input | | R | Primary red input | | FC1 | This signal is input from bit 1 (Feature Control Bit 1) of the Feature Control Register. | | FC0 | This signal is input from bit 0 (Feature Control Bit 0) of the Feature control Register. | | FEAT 0 | This signal is output to bit 5 (Feature Code 0) of Input Status Register 0. | | B'/V | Secondary blue input/Monochrome video | | VIN | Vertical retrace input | Internal This signal is output to bit 4 (Disable Internal Video Drivers) of the Miscellaneous Output Register. V OUT Vertical retrace output J1 This pin is connected to auxiliary jack 1 on the rear panel of the adapter. **G'OUT** Secondary green output **B'OUT** Secondary blue output **B OUT** Blue output G Green input B Blue input **R OUT** Red output **BLANK** This is a composite horizontal and vertical blanking signal from the CRTC. **FEAT 1** This signal is output to bit 6 (Feature Code 1) of Input Status Register 0. G'/I Secondary green/Intensity input HIN Horizontal retrace input from the CRTC **14MHZ** 14 MHz signal from the system board **EXT OSC** External dot clock output **HOUT** Horizontal retrace output The following figure shows the layout and pin numbering of the feature connector. **Feature Connector Diagram** # **Specifications** # **System Board Switches** The following figure shows the proper system board DIP switch settings for the IBM Enhanced Graphics Adapter when used with the Personal Computer and the Personal Computer XT. The switch block locations are illustrated in the Technical Reference Manual "System Board Component Diagram". The Personal Computer has two DIP switch blocks; the switch settings shown pertain to DIP Switch Block 1. The Personal Computer XT has one DIP switch block. Switch Block (1) **Note:** The DIP switches must be set as shown whenever the IBM Enhanced Graphics Adapter is installed, regardless of display type. This is true even when a second display adapter is installed in the system. # **Configuration Switches** The following diagram shows the location and orientation of the configuration switches on the Enhanced Graphics Adapter. # **Configuration Switch Settings** The configuration switches on the Enhanced Graphics Adapter determine the type of display support the adapter provides, as follows: | | | | Swite | ch Settings for Enhanced<br>as Primary Display | | | |-----|-----|-----|-------|------------------------------------------------|-----------------------|---------------------------| | | | | | | Configuration | | | SW1 | SW2 | SW3 | SW4 | Enhanced<br>Adapter | Monochrome<br>Adapter | Color/Graphics<br>Adapter | | On | Off | Off | On | Color Display<br>40x25 | Secondary | _ | | Off | Off | Off | On | Color Display<br>80x25 | Secondary | _ | | On | On | On | Off | Enhanced Display<br>Emulation Mode | Secondary | - | | Off | On | On | Off | Enhanced Display<br>Hi Res Mode | Secondary | _ | | On | Off | On | Off | Monochrome | _ | Secondary<br>40x25 | | Off | Off | On | Off | Monochrome | _ | Secondary<br>80x25 | | Switch Settings for Enhanced Graphics Adapter<br>as Secondary Display Adapter | | | | | | | | | |-------------------------------------------------------------------------------|-----|-----|-----|------------------------------------|-----------------------|---------------------------|--|--| | | | | | Configuration | | | | | | SW1 | SW2 | SW3 | SW4 | Enhanced<br>Adapter | Monochrome<br>Adapter | Color/Graphics<br>Adapter | | | | On | On | On | On | Color Display<br>40x25 | Primary | _ | | | | Off | On | On | On | Color Display<br>80x25 | Primary | _ | | | | On | Off | On | On | Enhanced Display<br>Emulation Mode | Primary | _ | | | | Off | Off | On | On | Enhanced Display<br>Hi Res Mode | Primary | 1 | | | | On | On | Off | On | Monochrome | - | Primary<br>40x25 | | | | Off | On | Off | On | Monochrome | - | Primary<br>80x25 | | | # **Direct Drive Connector** | | Signal Name - Description | Pin | | |---------|---------------------------|-----|------------------------------| | | Ground | 1 | | | Direct | Secondary Red | 2 | | | Drive | Primary Red | 3 | Enhanced<br>Graphics Adapter | | Display | Primary Green | 4 | | | | Primary Blue | 5 | | | | Secondary Green/Intensity | 6 | | | | Secondary Blue/Mono Video | 7 | | | | Horizontal Retrace | 8 | | | | Vertical Retrace | 9 | | # **Light Pen Interface** | | P-2 Connector | Pin | | | |-------------------------|-------------------|-----|------------------------------|--| | | +Light Pen Input | 1 | | | | Light Pen<br>Attachment | Not used | 2 | Enhanced<br>Graphics Adapter | | | Audomion | +Light Pen Switch | 3 | Giapines Adapter | | | | Ground | 4 | ] | | | | +5 Volts | 5 | | | | | 12 Volts | 6 | | | # **Jumper Descriptions** Located on the adapter are two jumpers designated P1 and P3. Jumper P1 changes the function of pin 2 on the direct drive interface. When placed on pins 2 and 3, jumper P1 selects ground as the function of direct drive interface, pin 2. This selection is for displays that support five color outputs, such as the IBM Color Display. When P1 is placed on pins 1 and 2, red prime output is placed on pin 2 of the direct drive interface connector. This supports the IBM Enhanced Color Display, which utilizes six color outputs on the direct drive interface. Jumper P3 changes the I/O address port of the Enhanced Graphics Adapter within the system. In its normal position, (pins 1 and 2), all Enhanced Graphics Adapter addresses are in the range 3XX. Moving jumper P3 to pins 2 and 3 changes the addresses to 2XX. Operation of the adapter in the 2XX mode is not supported in BIOS. The following figure shows the location of the jumpers and numbering of the connectors. # **Logic Diagrams** # **ENHANCED GRAPHICS ADAPTER** **Enhanced Graphics Adapter Sheet 1 of 11** August 2, 1984 **Enhanced Graphics Adapter Sheet 2 of 11** **Enhanced Graphics Adapter Sheet 3 of 11** **Enhanced Graphics Adapter Sheet 4 of 11** **ENHANCED GRAPHICS ADAPTER** **Enhanced Graphics Adapter Sheet 6 of 11** 92 **IBM Enhanced Graphics Adapter** **ENHANCED GRAPHICS ADAPTER** **Enhanced Graphics Adapter Sheet 7 of 11** August 2, 1984 **Enhanced Graphics Adapter Sheet 9 of 11** NOTE: I GROUNDS - ONE AT EACH END OF CONNECTOR. August 2, 1984 **Enhanced Graphics Adapter Sheet 11 of 11** **Graphics Memory Expansion Card Sheet 1 of 5** **Graphics Memory Expansion Card Sheet 2 of 5** Graphics Memory Expansion Card Sheet 3 of 5 **Graphics Memory Expansion Card Sheet 4 of 5** **Graphics Memory Expansion Card Sheet 5 of 5** ## **BIOS Listing** ### **Vectors with Special Meanings** #### **Interrupt Hex 42 - Reserved** When an IBM Enhanced Graphics Adapter is installed, the BIOS routines use interrupt 42 to revector the video pointer. # **Interrupt Hex 43 - IBM Enhanced Graphics Video Parameters** When an IBM Enhanced Graphics Adapter is installed, the BIOS routines use this vector to point to a data region containing the parameters required for the initializing of the IBM Enhanced Graphics Adapter. Note that the format of the table must adhere to the BIOS conventions established in the listing. The power-on routines initialize this vector to point to the parameters contained in the IBM Enhanced Graphics Adapter ROM. #### **Interrupt Hex 44 - Graphics Character Table** When an IBM Enhanced Graphics Adapter is installed the BIOS routines use this vector to point to a table of dot patterns that will be used when graphics characters are to be displayed. This table will be used for the first 128 code points in video modes 4, 5, and 6. This table will be used for 256 characters in all additional graphics modes. See the appropriate BIOS interface for additional information on setting and using the graphics character table pointer. FOR WRITE CHARACTER INTERFACE IN GRAPHICS MODE, THE REPLICATION FACTOR CONTAINED IN (CX) ON ENTRY WILL PRODUCE VALID RESULTS ONLY FOR CHARACTERS CONTAINED ON THE SAME ROW. CONTINUATION TO SUCCEEDING LINES WILL NOT PRODUCE CORRECTLY. ``` GRAPHICS INTERFACE (AH) = B SET COLOR PALETTE (TO USE IN COMPATIBILITY MODES (FOR USE IN COMPATIBILITY MODES (FOR USE IN COMPATIBILITY MODES (FOR THE COLOR VALUE TO BE USED WITH THAT COLOR ID (BL) = COLOR VALUE TO BE USED WITH THAT TOLOR ID (BL) = COLOR VALUE TO BE USED WITH THAT TOLOR ID (COLOR (AH) = C WRITE DOT (BH) = PAGE (DX) = ROW NUMBER (CX) = COLUMN NUMBER (AL) = COLUMN NUMBER (AL) = CF BIT 7 OF AL = 1, THEN THE COLOR VALUE IS EXCLUSIVE OR'D WITH THE CURRENT CONTENTS OF THE DOT , ASCII TELETYPE ROUTINE FOR OUTPUT E 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) = F CURRENT VIDEO STATE RETURNS THE CURRENT VIDEO STATE (AL) = MODE CURRENTLY SET (SEE AH=0 FOR EXPLANATION) (AH) = NUMBER OF CHARACTER COLUMNS ON SCREEN (BH) = CURRENT ACTIVE OISPLAY PAGE (AH) = 10 SET PALETTE REGISTERS (AL) = 0 SET INDIVIDUAL PALETTE REGISTER BL = PALETTE REGISTER TO BE SET BH = VALUE TO SET AL = 1 SET OVERSCAN REGISTER BH = VALUE TO SET AL = 2 SET ALL PALETTE REGISTERS AND OVERSCAN ES:DX POINTS TO A 17 BYTE TABLE BYTES 0 - 15 ARE THE PALETTE VALUES, RESPECTIVELY BYTE 16 IS THE OVERSCAN VALUE TOGGLE INTENSIFY/BLINKING BIT BL - 0 ENABLE INTENSIFY BL - 1 ENABLE BLINKING 11 CHARACTER GENERATOR ROUTINE NOTE: THIS CALL WILL INITIATE A MODE SET, COMPLETELY RESETTING THE VIDEO ENVIRONMENT BUT MAINTAINING THE REGEN BUFFER. CONSISTENT COLORS. NOTE: THE FOLLOWING INTERFACE (AL=1X) IS SIMILAR IN FUNCTION TO (AL=0X) EXCEPT THAT: - PAGE ZERO MUST BE ACTIVE - POINTS (EYTES/CHAR) WILL BE RECALCULATED ROWS MILL BE CALCULATED FROM THE FOLLOMING: INTI(200 OR 350) / POINTS| - I - CAT_LEN MILL BE REPROGRAMMED AS FOLLOMS: - THE CRIC WILL BE REPROGRAMMED AS FOLLOMS: ROWS - SOLUTION - MAX SCAN LINE ROSH POINTS - 1 ROWS - SOLUTION - CURSOR START COMBON - POINTS - 1 ROWS - SOLUTION - CURSOR START COMBON - POINTS - 1 ROWS POINTS - 1 ROWS - POINTS - POINTS - 1 ROWS - POINTS P NOTE: THE FOLLOWING INTERFACE IS DESIGNED TO BE CALLED ONLY IMMEDIATELY AFTER A MODE SET HAS BEEN ISSUED. FAILURE TO ADHERE TO THIS PRACTICE MAY CAUSE UNDETERMINED RESULTS. AL = 10 USER ALPHA LOAD ES:BP - POINTER TO USER TABLE CX - COUNT TO STRE BL - BLOCK TO LOAD AL = 11 ROM MONOCHROME SET AL = 11 ROM MONOCHROME SET AL = 12 ROM 8X8 OCUBLE DOT BL - BLOCK TO LOAD AL = 12 ROM 8X8 OCUBLE DOT BL - BLOCK TO LOAD ``` ``` NOTE: THE FOLLOWING INTERFACE IS DESIGNED TO BE CALLED ONLY IMMEDIATELY AFTER A MODE SET HAS BEEN ISSUED. FAILURE TO ADHERE TO THIS PRACTICE MAY CAUSE UNDETERMINED RESULTS. AL = 20 USER GRAPHICS CHARS INT 01FH (8X8) ES:BP - POINTER TO USER TABLE AL = 21 USER GRAPHICS CHARS ES:BP - POINTER TO USER TABLE CX - POINTS (BYTES PER CHARACTER) BL - ROW SPECIFIER BL = 0 USER DL - ROWS BL = 1 14 (OEH) BL = 2 25 (19H) BL = 3 43 (2BH) AL = 22 ROM 8 X 14 SET BL - ROW SPECIFIER AL = 23 ROM 8 X 8 DOUBLE DOT BL - ROW SPECIFIER AL = 30 (AH) = 12 ALTERNATE SELECT RETURN EGA INFORMATION BH = 0 - COLION MODE IN EFFECT <3><0><0><0><0><0><0><0><0><0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 = 0<0 BL = 20 SELECT ALTERNATE PRINT SCREEN ROUTINE WRITE STRING ES:BP - POINTER TO STRING TO BE WRITTEN CX - CHARACTER ONLY COUNT DX - POSITION TO BEGIN STRING, IN CURSOR TERMS BH - PAGE NUMBER BL - ATTRIBUTE STRING - (CHAR, CHAR, CHAR, ...) CURSOR NOT MOVED BL - ATTRIBUTE STRING - (CHAR, CHAR, CHAR, ...) CURSOR IS MOVED STRING - (CHAR, ATTR, CHAR, ATTR, ...) CURSOR NOT MOVED AL = 3 STRING - (CHAR, ATTR, CHAR, ATTR, ...) CURSOR IS MOVED NOTE: CHAR RET, LINE FEED, BACKSPACE, AND BELL ARE TREATED AS COMMANDS RATHER THAN PRINTABLE CHARACTERS. MACRO SEGREG, VALUE IFNB <VALUE> IFIDN <VALUE>, <0> SUB DX, DX SUB ELSE MOV ENDIF DX, VALUE SEGREG, DX ;---- LOW MEMORY SEGMENT SEGMENT AT ORG 005H*4 R LABEL ORG 01FH*4 LABEL ORG 01FH*4 LABEL 0000 0014 0014 0040 0040 007C 007C ABSO INT5_PTR ORG : PRINT SCREEN VECTOR DWORD ; VIDEO I/O VECTOR DWORD ORG EXT_PTR VIDEO : GRAPHIC CHARS 128-255 DWORD 042H*4 LABEL ; REVECTORED 10H*4 ORG PLANAR_VIDEO DWORD : GRAPHIC CHARS 0-255 010C 010C DWORD 0410 0410 0410 EQUIP_LOW EQUIP_FLAG ;---- REUSE RAM FROM PLANAR BIOS 449H DB DW DW DW DW 0449 0449 044A 044C 044E ORG ORG CRT_MODE CRT_COLS CRT_LEN CRT_START CURSOR_POSN 1? 08 [ 7??? 8 DUP(?) 0460 ???? CURSOR_MODE ``` ``` 0472H DW 0484H ? ORG ORG _AG ORG DB DW ; ROWS ON THE SCREEN : BYTES PER CHARACTER 0487 ?? INFO DB 2 ; INFO D7 - HIGH BIT OF MODE SET, CLEAR/NOT CLEAR REGEN D6 - MEMORY D6 D5 = 0 0 - 064K 0 1 - 128K D1 - 128K 1 1 - 128K D1 - 128K 1 1 - 128K D2 - HALT FOR DISPLAY ENABLE (1) D2 - MALT FOR DISPLAY ENABLE (1) D1 - ECA HAS A MONOCHROME ATTACKED (1) D - SET C_TYPE EMULATE ACTIVE (1) 0488 ?? INFO_3 DB FEATURE BITS SWITCHES SAVE_PTR ORG 04A8 DWORD :---- SAVE PTR SAVE_PTR IS A POINTER TO A TABLE AS DESCRIBED AS FOLLOWS : DWORD_1 DWORD_2 DWORD_3 DWORD_4 DWORD_5 DWORD_6 DWORD_7 VIDEO PARAMETER TABLE POINTER DYNAMIC SAVE AREA POINTER ALPHA MODE AUXILIARY CHAR GEN POINTER GRAPHICS MODE AUXILIARY CHAR GEN POINTER RESERVED RESERVED RESERVED DWORD_1 PARAMETER TABLE POINTER INITIALIZED TO BIOS EGA PARAMETER TABLE. THIS VALUE MUST EXIST. PARAMETER SAVE AREA POINTER INITIALIZED TO 0000:0000, THIS VALUE IS OPTIONAL. INITIALIZED TO 0000:0000, THIS VALUE IS OPTIONAL. INITIALIZED TO 0000:0000, THIS VALUE SED. AS POINTER TO A RAMA RAFE WHERE CERTAIN DYNAMIC VALUES ARE TO BE SAVED. WHEN IN EGA OPERATION THIS RAM AREA WILL HOLD THE 16 EGA PALETTE REGISTER VALUES PLUS THE OVERSCAN VALUE IN BYTES 0-16D RESPECTIVELY, AT LEAST 256 BYTES MUST BE ALLOCATED FOR THIS AREA. DWORD_2 ALPHA MODE AUXILIARY POINTER INITIALIZED TO 0000:0000, THIS VALUE IS OPTIONAL WHEN NON-ZERO, THIS POINTER IS USED AS A POINTER TO A TABLES DESCRIBED AS FOLLOWS: DWORD_3 BLES DESCRIBED AS FOLLOWS: BYTES/CHARACTER BLOCK TO LOAD, SHOULD BE ZERO FOR NORMAL OPERATION COUNT TO STORE, SHOULD BE 256D FOR NORMAL OCHARACTER OFFSET, SHOULD BE ZERO FOR NORMAL OPERATION POINTER TO A FORD DISPLAYABLE MAYMUM CALCULATED VALUE WILL BE USED, ELSE HIS VALUE WILL BE USED CONSECUTIVE BYTES OF MODE VALUES FOR WHICH HIS FORD IDSCRIPTION IS TO BE USED. BYTE MODE OF FETTREAM IS INDICATED BY A BYTE MODE OF FETTREAM IS INDICATED BY A WORD WORD BYTF NOTE: USE OF THIS POINTER MAY CAUSE UNEXPECTED CURSOR TYPE OPERATION. FOR AN EXPLANATION OF CURSOR TYPE SEE AH = 01 IN THE INTERFACE SECTION. GRAPHICS MODE AUXILIARY POINTER INITIALIZED TO 0000:0000, THIS VALUE IS OPTIONAL, WHEN NON-ZERO, THIS POINTER IS USED AS A POINTER TO A TABLES DESCRIBED AS FOLLOWS: DWORD_4 DISPLAYABLE ROWS BYTES PER CHARACTER POINTER TO A FONT TABLE CONSECUTIVE BYTES OF MODE VALUES FOR WHICH THIS FONT DESCRIPTION IS TO BE USED. THE END OF THIS STREAM IS INDICATED BY A BYTE CODE OF IFF! DWORD_5 THRU DWORD_7 RESERVED AND SET TO 0000:0000. STATUS_BYTE ABSO ENDS ; 8255 PORT B ADDR ;---- EQUATES FOR CARD PORT ADDRESSES SEQ_ADDR SEQ_DATA CRIC_ADDR CRIC_ADDR CRIC_ADDR CRIC_ADDR B CRIC_DATA CRIC_ADDR GRAPH_1-POS GRAPH_ADDR GRAPH_DATA MISC_OUTPUT IN_STATO INPUT_STATUS ATTR_WRITE 00C4 00C5 00D4 00B4 00D5 00CC 00CA 00CE 00C2 00C2 00BA 00DA 00DA 0C4H 0C5H 0D4H 0B4H 0D5H 0CCH 0CEH 0C2H 0C2H 0C2H 0DAH 0DAH 0DAH ; OR OB5H ;---- EQUATES FOR ADDRESS REGISTER VALUES ``` ``` S_RESET S_CLOCK S_MAP S_CGEN S_MEM 0000 0001 0002 0003 0004 S. MEH C. HRZ_TOT C. HRZ_DSP C. STRI HRZ_ELK C. STRI HRZ_EK WO I TOT C. OVER LOW C. WO I TOT C. OVER LOW C. STRI SW C. STRI C. LOW C. STRI SW C. STRI C. CH C. STRI SW C. STRI C. CH C. STRI 0000 0001 0002 0003 0004 0005 0006 0007 0008 0009 0000 0000 0010 0011 0011 0012 0013 0014 0015 0016 0017 ; WRITE ONLY ; READ ONLY ; WRITE ONLY ; READ ONLY G_SET_RESET G_ENBL_SET G_CLR_GOMP G_DATA_ROT G_READ_MAP G_MODE G_MISC G_COLOR 0000 0001 0002 0003 0004 0005 0006 0007 0008 00H 01H 02H 03H 04H 05H 06H 07H P_MODE P_OVERSC P_CPLANE P_HPEL 10H 11H 12H 13H SUBTTI :---- CODE SEGMENT 0000 SEGMENT PUBLIC CODE INCLUDE VPOST.INC SUBTTL VPOST.INC PAGE ;---- POST ASSUME CS:CODE,DS:ABSO ORG OH DB 055H DB 0AAH DB 020H 0000 0000 0001 0002 ; SIGNATURE ; BYTES ; LENGTH INDICATOR ;---- NOTE : DO NOT USE THE SIGNATURE BYTES AS A PRESENCE TEST PLANAR VIDEO SWITCH SETTINGS ; 0 0 - UNUSED ; 0 1 - 40 X 25 COLOR ; 1 0 - 80 X 25 COLOR ; 1 1 - 80 X 25 MONOCHROME ; NOTE : 0 0 MUST BE SET WHEN THIS ADAPTER IS INSTALLED. VIDEO ADAPTER SWITCH SETTINGS 0 0 0 0 - MONCE PRIMARY, ECA COLOR, 40X29 0 0 1 0 - MONCE PRIMARY, ECA CILOR, 40X29 0 0 1 0 - MONCE PRIMARY, ECA IL 1085 SMILTE 0 0 1 1 0 - MONCE PRIMARY, ECA IL 1085 SMILTE 0 1 1 0 - COLOR 40 PRIMARY, ECA MONCHROME 1 0 1 0 - COLOR 40 PRIMARY, ECA MONCHROME 0 1 1 0 - MONDO SECONDARY, EGA COLOR, 40X25 1 1 1 0 - MONDO SECONDARY, EGA COLOR SECURITION OF THE COLOR T 1 1 0 0 - RESERVED 1 1 0 1 - RESERVED 1 1 1 0 - RESERVED 1 1 1 1 - RESERVED ;---- SETUP ROUTINE FOR THIS MODULE VIDEO_SETUP EB 32 36 36 4F 48 20 39 34 28 34 32 20 50 54 31 2F 30 37 33 43 29 52 49 49 42 38 34 33 2F 30 37 28 59 20 39 31 '2400' '6277356 (C)COPYRIGHT IBM 1984' 35 43 47 4D 0026 DB '9/13/84' :---- SET UP VIDEO VECTORS L1: 002D 002F 0031 0032 0034 0035 0037 B6 03 B2 DA EC B2 BA EC B2 C0 B0 00 EE DH, 3 DL, INPUT_STATUS AL, DX DL, INPUT_STATUS_B AL, DX DL, ATTR_WRITE AL, O DX, AL, O DX, AL MOV IN MOV IN MOV MOV OUT SRLOAD SUB MOV 003A 2B D2 003C 8E DA ``` ``` CLI MOV MOV MOV MOV MOV MOV MOV STI WORD PTR VIDEO,OFFSET COMBO_VIDEO WORD PTR VIDEO+2, US WORD PTR VIDEO+2, US WORD PTR FLAMAR VIDEO+2,DFDOOH WORD PTR SAVE_PTR,OFFSET SAVE_TBL WORD PTR SAVE_PTR+2, CS WORD PTR SAVE_PTR+2, CS WORD PTR SET_FTR+2, CS WORD PTR SET_FTR+2, CS WORD PTR CREATER SAVE_TBL ;---- POST FOR COMBO VIDEO CARD C6 06 0487 R 04 E8 009B R 88 1E 0488 R E8 00CE R 08 06 0488 R 8A 1E 0488 R E8 00F3 R E9 0244 R MOV CALL MOV CALL OR MOV CALL JMP INFO,00000100B RD_SWS INFO_3, BL F_BTS INFO_3, AL BL, INFO_3 MK_ENV POST 0074 0079 007C 0080 0083 0087 008B 008E 0091 0091 RET VIDEO_SETUP ENDP NEAR DX,AL AX AX AL,DX AL,O10H AL,1 0092 0093 0094 0095 0096 0098 0098 EE 50 58 EC 24 10 DO E8 C3 PROC OUT PUSH POP IN AND SHR RET POR_1 ;---- READ THE SWITCH SETTINGS ON THE CARD NEAR DS: ABSO DH, 3 DL, MISC_OUTPUT AL, 1 PROC ASSUME MOV MOV MOV OUT 009B 009B 009D 009F 00A1 ;---- COULD BE 0,4,8,C AL,ODH POR_1 AL,1 AL,1 AL,1 BL,AL BO OD E8 0092 R DO E8 DO E8 DO E8 8A D8 MOV CALL SHR SHR SHR MOV 00A2 00A4 00A7 00A9 00AB 00AD BO 09 E8 0092 R DO E8 DO E8 OA D8 MOV CALL SHR SHR OR AL,9 POR_1 AL,1 AL,1 BL,AL 00AF 00B1 00B4 00B6 00B8 00BA 00BC 00BF 00C1 BO 05 E8 0092 R DO E8 OA D8 MOV CALL SHR OR AL,1 POR_1 BL,AL RD_SWS OBTAIN THE FEATURE BITS FROM DAUGHTER CARD HE FEATURE BIT NHA3 NHA3 LL,0BAH AL,1 DX,AL DL,0DAH DX,AL DL,1BL,STAT_O AL,DX AL,DX BL,AL DL,0BAH AL,2 DX,AL DL,0BAH AL,2 DX,AL DX,BL DX,B PROC MOV MOV OUT MOV OUT MOV IND ASHR MOV OUT MOV IND SHL OUT MOV IND SHL ORT ; READ FEATURE BITS ; READ FEATURE BITS F_BTS ;---- ESTABLISH THE VIDEO ENVIRONMENT, KEYED OFF OF THE SWITCHES PROC ASSUME SUB AND SAL PUSH MOV MOV POP AND INC NOT JMP NEAR DS: ABSO BH, BH BL, OFH BX, 1 DX DH, 3 AH, DH DX AH, 1 AH 00F3 2A FF 80 E3 0F D1 E3 52 B6 03 8A E6 5A 80 E4 01 FE C4 F6 D4 2E: FF A7 0128 R 00F3 00F5 00F8 00FA 00FB 00FD 00FF 0100 0103 0105 0107 WORD PTR CS:[BX + OFFSET T5] 010C 010C 010E 0110 0112 0114 0116 DWORD VIDEO_PARMS 0717 R C000 0000 0000 0000 0000 0000 PARMS PARMS PAL SAVE AREA PAL SAVE AREA ALPHA TABLES ALPHA TABLES GRAPHICS TABLES ``` | 011A<br>011C<br>011E | 0000<br>0000<br>0000 | 757 C<br>758 C<br>759 C<br>760 C | | DW<br>DW | 0 | ; GRAPHICS TABLES | |------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------| | 0120<br>0122<br>0124<br>0126 | 0000<br>0000<br>0000<br>0000 | 760 C<br>761 C<br>762 C<br>763 C<br>764 C<br>765 C | | DW<br>DW<br>DW | 0<br>0<br>0 | | | 0128<br>0128<br>012A<br>012C<br>012E<br>0130<br>0132<br>0134<br>0136 | 0173 R<br>017E R<br>017E R<br>0189 R<br>0194 R<br>0186 R<br>01BC R<br>01C R | 766 C<br>767 C<br>768 C<br>769 C<br>770 C<br>771 C<br>772 C<br>773 C<br>774 C | T5 | LABEL<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW | WORD OFFSET PST_0 OFFSET PST_1 OFFSET PST_2 OFFSET PST_3 OFFSET PST_3 OFFSET PST_5 OFFSET PST_5 OFFSET PST_6 OFFSET PST_7 | | | 0138<br>013A<br>013C<br>013E<br>0140<br>0142<br>0144<br>0146 | 01C7 R<br>01D2 R<br>01DD R<br>01F1 R<br>0204 R<br>0204 R<br>0204 R | 7775 C<br>7776 C<br>7777 C<br>7778 C<br>7779 C<br>780 C<br>781 C | | DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW | OFFSET PST 8 OFFSET PST 9 OFFSET PST 9 OFFSET PST B OFFSET PST OUT OFFSET PST OUT OFFSET PST OUT OFFSET PST OUT | | | 0148<br>0148<br>0140<br>0152<br>0155<br>0157<br>0158 | 80 26 0410 R CF<br>80 0E 0410 R 10<br>88 0001<br>CD 10<br>C3 | 783 C<br>784 C<br>785 C<br>786 C<br>787 C<br>788 C<br>789 C<br>790 C<br>791 C | ENV_X | PROC<br>AND<br>OR<br>MOV<br>INT<br>RET<br>ENDP | NEAR<br>EQUIP_LOW, OCFH<br>EQUIP_LOW, 010H<br>AX, 1H<br>10H | ; SET 40X25 COLOR ALPHA | | 0158<br>0158<br>015D<br>0162<br>0165<br>0167<br>0168 | 80 26 0410 R CF<br>80 0E 0410 R 20<br>88 0003<br>CD 10<br>C3 | 792 C<br>793 C<br>794 C<br>795 C<br>796 C<br>797 C<br>798 C<br>799 C | ENV_O | PROC<br>AND<br>OR<br>MOV<br>INT<br>RET<br>ENDP | NEAR<br>EQUIP_LOW, OCFH<br>EQUIP_LOW, 020H<br>AX, 03H<br>10H | ; SET 80X25 COLOR ALPHA | | 0168<br>0168<br>016D<br>0170<br>0172<br>0173 | 80 OE 0410 R 30<br>B8 0007<br>CD 10<br>C3 | 800 C<br>801 C<br>802 C<br>803 C<br>804 C<br>805 C<br>806 C | ENV_3 ENV_3 | PROC<br>OR<br>MOV<br>INT<br>RET<br>ENDP | NEAR<br>EQUIP_LOW, 030H<br>AX, 07H<br>10H | ; SET MONOCHROME ALPHA | | 0173<br>0173<br>0177<br>017A<br>017D<br>017E<br>017E | 20 26 0487 R<br>E8 0148 R<br>E8 0168 R<br>C3 | 807 C<br>808 C<br>809 C<br>810 C<br>811 C<br>812 C<br>813 C<br>814 C | PST_0: PST_1: PST_2: | AND<br>CALL<br>CALL<br>RET | INFO, AH<br>ENV_X<br>ENV_3 | | | 017E<br>0182<br>0185<br>0188 | 20 26 0487 R<br>E8 0158 R<br>E8 0168 R<br>C3 | 814 C<br>815 C<br>816 C<br>817 C<br>818 C<br>819 C | | AND<br>CALL<br>CALL<br>RET | INFO, AH<br>ENV_O<br>ENV_3 | | | 0189<br>0189<br>018D<br>0190<br>0193 | 20 26 0487 R<br>E8 0158 R<br>E8 0168 R | 820 C<br>821 C<br>822 C<br>823 C<br>824 C | PST_3: | AND<br>CALL<br>CALL<br>RET | INFO, AH<br>ENV_O<br>ENV_3 | | | 0193<br>0194<br>0194<br>0196<br>0198<br>019A<br>019B<br>019D<br>01A1<br>01A4 | B6 03<br>B2 C2<br>B0 00<br>EE<br>F6 D4<br>08 26 0487 R<br>E8 0168 R<br>E8 0148 R | 825 C<br>826 C<br>827 C<br>828 C<br>829 C<br>830 C<br>831 C<br>831 C | PST_4: | MOV<br>MOV<br>OUT<br>NOT<br>OR<br>CALL<br>CALL | DH, 3 DL, MISC_OUTPUT AL, 0 DX, AL AH INFO, AH ENV_3 ENV_X | | | 01A7<br>01A8<br>01A8<br>01AA<br>01AC<br>01AE<br>01AF<br>01B1<br>01B5 | C3 B6 03 B2 C2 B0 00 EE F6 D4 08 26 0487 R E8 0158 R | 834 C<br>835 C<br>836 C<br>837 C<br>838 C<br>839 C<br>840 C<br>841 C | PST_5: | MOV<br>MOV<br>MOV<br>OUT<br>NOT<br>OR<br>CALL | DH, 3<br>DL, MISC_OUTPUT<br>AL, 0<br>DX, AL<br>AH<br>INFO, AH<br>FNV 3 | | | 01B8<br>01BB<br>01BC<br>01BC<br>01C0<br>01C3<br>01C6 | E8 0158 R<br>C3<br>20 26 0487 R<br>E8 0168 R<br>E8 0148 R<br>C3 | 842 C<br>843 C<br>844 C<br>845 C<br>846 C<br>847 C<br>848 C<br>849 C | PST_6: | CALL<br>CALL<br>RET<br>AND<br>CALL<br>CALL<br>RET | ENV_3<br>ENV_0<br>INFO,AH<br>ENV_3<br>ENV_X | | | 01C7<br>01C7<br>01C7<br>01CB<br>01CE<br>01D1 | 20 26 0487 R<br>E8 0168 R<br>E8 0158 R<br>C3 | 850 C<br>851 C<br>852 C<br>853 C<br>854 C<br>855 C | PST_7:<br>PST_8: | AND<br>CALL<br>CALL<br>RET | INFO, AH<br>ENV_3<br>ENV_O | | | 01D2<br>01D2<br>01D6<br>01D9<br>01DC | 20 26 0487 R<br>E8 0168 R<br>E8 0158 R<br>C3 | 856 C<br>857 C<br>858 C<br>859 C<br>860 C | PST_9: | AND<br>CALL<br>CALL<br>RET | INFO, AH<br>ENV_3<br>ENV_0 | | | 01DD<br>01DD<br>01DF<br>01E1<br>01E3<br>01E4<br>01E6<br>01EA | 86 03<br>82 02<br>80 00<br>EE<br>F6 D4<br>08 26 0487 R<br>E8 0148 R<br>E8 0168 R | 861 C 862 C 863 C 864 C 865 C 866 C 867 C 868 C 869 C 869 | PST_A: | MOV<br>MOV<br>OUT<br>NOT<br>OR<br>CALL<br>CALL | DH, 3 DL, MISC_OUTPUT AL, 0 DX, AL AH INFO, AH ENV_X ENV_3 | | | 01F0<br>01F1<br>01F1<br>01F3<br>01F5<br>01F7<br>01F8<br>01FA<br>01FE | C3 B6 03 B2 C2 B0 00 EE F6 D4 08 26 0487 R E8 0158 R E8 0158 R | 870 C<br>871 C<br>872 C<br>873 C<br>874 C<br>875 C<br>876 C<br>877 C | PST_B: | MOV<br>MOV<br>MOV<br>OUT<br>NOT<br>OR<br>CALL | DH, 3<br>DL, MISC_OUTPUT<br>AL, 0<br>DX, AL<br>AH<br>INFO, AH<br>FNV 0 | | | 0201<br>0204<br>0204<br>0205 | E8 0168 R | 878 C<br>879 C<br>880 C<br>881 C<br>882 C | PST_OUT | | ENV_0<br>ENV_3 | | ``` THIS ROUTINE TESTS THE CRT CARD INTERNAL DATA BUS AND IN A LIMITED WAY TESTS THE CRTC VIDEO CHIP BY WRITING/READING FROM CURSOR REGISTER CARRY IS SET IF AN ERROR IS FOUND ; CARRY IS SET IF AN ERROR IS FOUND ; REGISTERS BX, SI, ES, DS ARE PRESERVED.; REGISTERS AX, CX, DX ARE MODIFYED. CD_PRESENCE_TST PROC NEAR PUSH AX CALL RD, CURSOR MOV DI, BX PUSH AX CALL RD, CURSOR POP SX, AX PUSH AX CALL WR, CURSOR POP AX CALL RD, CURSOR POP AX CALL RD, CURSOR POP AX CALL RD, CURSOR POP AX CALL RD, CURSOR POP AX CALL RD, CURSOR POP AX, DI JNZ MOT PRESENT NOT_PRESENT: 53 BB 007F 88 FB 50 E8 022C R 88 F0 50 E8 0236 R 58 50 E8 0236 R 58 50 22C R 38 C7 75 03 EB 05 90 0205 0205 0206 0209 020B 020C 0211 0212 0213 0218 0218 021B 021D 021E 0223 0223 0223 0223 0223 ; SAVE BX ; INITIAL WORD PATTERN BYTE ; SAVE PORT ADDRESS SAVE ORIGINAL VALUE RECOVER PORT ADDRESS SAVE PORT ADDRESS WRITE CURSOR RECOVER PORT ADDRESS SAVE PORT ADDRESS READ IT BACK SAME? ; EXIT IF NOT EQUAL AX, AX BX NOT_PRESENT: 33 C0 5B C3 ; SET NOT PRESENT ; SET PRESENT ON EXIT ; RESTORE BX B8 0001 5B C3 MOV POP RET MODULE NAME RD_CURSOR ; READ CURSOR POSITION [ADDRESS] (FROM CRTC) TO AX REGISTER AX IS MODIFIED. RO_CURSOR PD NEAR ; SA MOV DX, AX MOV AL, C_CRSR_LOC_HGH OUT DX, AL INC DX AI DX 022C 022C 022D 022F 0231 0232 ÃĹ,DX DХ RD_CURSOR MODULE NAME WE CURSOR (TO CRTC) WITH CONTENTS OF AX ; ALL REGISTERS PRESERVED WR_CURSOR PROC NEAR 0236 AX DX, DX, AX AH, C_CRSR_LOC_HGH AL, 07FH OUT_DX ; CURSOR LOCATION HIGH INDEX ; TEST VALUE ; RETURN WITH CURSOR POS IN AX ; RESTORE REGS USED WR_CURSOR 0244 POST: INITIALIZE AND START CRT CONTROLLER (6845) ON COLOR GRAPHICS AND MONOCHROME CARDS DESCRIPTION DESCRIPTION RESET THE VIDEO ENABLE SIGNAL. SELECT ALPHANUMERIC MODE, 40 * 25, B & M. READ/MRITE DATA PATTERNS TO STG. CHECK STG ADDRESSABILITY. ADDRESSA ASSUME CALL TEST JNZ MOV CALL CMP DS:ABSO,ES:ABSO DDS INFO,2 COLOR_PRESENCE_TST AX,03B4H CD_PRESENCE_TST AX_1 E8 OCFE R F6 06 0487 R 02 75 12 B8 03B4 E8 0205 R 3D 0001 74 03 E9 0317 R 0244 0247 0246 0246 0251 0254 0257 0256 0256 0260 0263 0263 CONT1: ; MONOCHROME CARD INSTALLED MOV AX,03D4H CD_PRESENCE_TST AX,1 CONT2 POD14 COLOR_PRESENCE_TST: B8 03D4 E8 0205 R 3D 0001 74 03 E9 0317 R MOV CALL CMP 0269 026B 026E 026E 0270 0270 0271 0274 0277 027A 027C 027F CONT2: MOV AH, 20H ; COLOR GRAPHICS CARD INSTALLED 50 BB B000 BA 03B8 B9 1000 B0 01 80 FC 30 74 08 B7 B8 B7 B8 B2 D8 B5 40 FE C8 OVER: ; RESAVE VALUE ; BEO VIDEO RAM ADDR B/W CD BEO VIDEO RAM ADDR B/W CD BET MODE FOR BW CARD SET MODE FOR BW CARD SET MODE FOR BW CARD YES OGD TRAM ADDEC STG WHOSE CONTRAM ADDEC STG HODE CONTRAM ADDEC STG RAM BYTE CNT FOR COLOR CD TEST MODE TO 0 FOR COLOR CD TEST VIDEO STG: DISABLE VIDEO FOR COLOR CD AX BX,0B000H DX,3B8H CX,4096 AL,1 AH,30H E9 BH,0B8H DL,008H PUSH MOV MOV MOV CMP JE MOV MOV MOV DEC CH, 40H E9: OUT ; POD INITIALIZED BY KBD RESET BP, DS: RESET_FLAG 028A 8B 2E 0472 R MOV 028E 81 FD 1234 0292 8E C3 ; POD INITIATED BY KBD RESET? ; POINT ES TO VIDEO RAM STG CMP MOV ``` ``` JE E10 MOV DS,BX ASSUME DS:NOTHING,ES:NOTHING CALL STGTST_CNT JNE E17 ; YES - SKIP VIDEO RAM TEST 0294 74 07 0296 8E DB 1019 1010 1011 1012 1013 1014 ; GO TEST VIDEO R/W STG ; R/W STG FAILURE - BEEP SPI 0298 E8 02DF R 029B 75 2E SETUP VIDEO DATA ON SCREEN FOR VIDEO LINE TEST. DESCRIPTION BABLE VIDEO SIGNAL AND SET MODE. DISPLAY A HORIZONTAL BAR ON SCREEN. 029D 029D 029E 029F 02A2 02A4 02A7 AX AX,7020H DI,DI CX,40 STOSW ; GET VIDEO SENSE SWS (AH) ; SAVE IT ; WRT BLANKS IN REVERSE VIDEO ; SETUP STARTING LOC ; NO. OF BLANKS TO DISPLAY ; WRITE VIDEO STORAGE 58 50 88 7020 28 FF 89 0028 F3/ AB 1021 1022 PUSH MOV SUB MOV REP 1023 1024 1025 1026 1027 CRT INTERFACE LINES TEST DESCRIPTION SENSE ON/OFF TRANSITION OF THE VIDEO ENABLE AND HORIZONTAL SYNC LINES. POP PUSH CMP MOV JE MOV ; GET YIDEO SENSE SW INFO ; SAVE IT ; BAW CARD ATTACHED? ; SETUP ADDR OF EW STATUS PORT ; YES - GO TEST LINES ; COLOR CARD IS ATTACHED ; LINE_TST; AX AX AH, 30H DX, 03BAH E11 58 50 80 FC 30 BA 03BA 74 02 B2 DA 02A9 02AA 02AB 02AE 02B1 02B3 02B5 02B5 02B7 02B7 02B9 02BA 02BC DL.ODAH E11: RA OR MOV AH.8 ; OFLOOP_CNT: E12: 2B C9 SUB CX,CX E13: AL, DX AL, AH E14 E13 SHORT E17 EC 22 C4 75 04 E2 F9 EB 09 IN AND JNZ LOOP ; READ CRT STATUS PORT ; CHECK VIDEO/HORZ LINE ; ITS ON - CHECK IF IT GOES OFF ; LOOP TILL ON OR TIMEOUT ; GO PRINT ERROR MSG 02BE 02BE 02C0 02C2 02C2 02C4 02C4 02C5 02C7 02C9 F14: SUB 2B C9 CX.CX E15: AL,DX AL,AH E16 E15 ; READ CRT STATUS PORT ; CHECK VIDEO/HORZ LINE ; ITS ON - CHECK NEXT LINE ; LOOP IF OFF TILL IT GOES ON ; CRT_ERR EC 22 C4 74 OA E2 F9 IN AND JZ LOOP E17: 02CB 02CB 02CE 02D1 02D3 02D3 02D5 02D7 BA 0102 E8 06C8 R EB 06 MOV CALL JMP DX,102H ERR_BEEP SHORT E18 ; GO BEEP SPEAKER ; NXT_LINE ; GET NEXT BIT TO CHECK E16: CL,3 AH,CL E12 MOV SHR JNZ B1 03 D2 EC 75 DE ; GO CHECK HORIZONTAL LINE ; DISPLAY CURSOR: ; GET VIDEO SENSE SWS (AH) 1063 02D9 02D9 58 02DA EB 3B E18: AX SHORT POD14 THIS SUBROUTINE PERFORMS A READ/MRITE STORAGE TEST ON A 16K BLOCK OF STORAGE. ENTER REQUIREMENTS: ES = ADDRESS OF STORAGE SECHENT BEING TESTED STORAGE SECHENT BEING TESTED WHEN ENTERING AT STOTST, CAT, CX MUST BE LOADED WITH THE BYTE COUNT. EXIT PRAMETERS: ZERO FLAG = 0 IF STORAGE FERON (DATA COMPARE OR PARITY CHECK. AL = 0 DENOTES APENT (DATA COMPARE OR PARITY CHECK. AL STORAGE PROBLEM OF THE CHECK CLISE AL-XON ED BIT AL CITAL DATA READ. AX, BX, CX, DX, DI, AND SI ARE ALL DESTROYED. STOTST PROC NEAR STGTST PROC NEAR CX.4000H B9 4000 ; SETUP CNT TO TEST A 16K BLK MOV STGTST_CNT: CLD ; SET DIR FLAG TO INOREMENT ; SAVE CNT (4K FOR VIDEO OR 16K); GET DATA PATTERN TO MRITE ; SETUP OTHER DATA PATTERNS TO USE ; DI = OFFSET O RELATIVE TO ES REG ; MRITE STORAGE LOCATIONS ; STGOI ; POINT TO LAST BYTE JUST WRITTEN ; SET DIR FLAG TO GO BACKWARDS FC 8B D9 B8 AAAA BA FF55 2B FF F3/ AA 02DF BX,CX AX,OAAAAH DX,OFF55H DI,DI STOSB 02DF 02E0 02E2 02E5 02E8 02EA 02EC 02EC MOV MOV SUB REP C3: 4F FD 02EE 02EE 02F0 02F2 02F2 02F2 02F3 02F5 1095 1096 1097 1098 1099 1100 C4: MOV MOV 8B F7 8B CB , SETUP BYTE ONT INNER TIST LOOP INNER TIST LOOP IN THE STATE OF THE STATE OF THE STATE IN THE STATE OF S LODSB 02F2 AC 02F3 32 C4 02F5 75 1E 02F7 8A C2 02F9 AA 02FA E2 F6 XOR JNE MOV STOSB LOOP AL, AH C7 AL, DL C5 ; ENDING O PATTERN WRITTEN TO STG? YES - RETURN TO CALLER WITH AL-O YES - RETURN TO CALLER WITH AL-O HOVE NET DATE POTENTIAL HOVE NET DATE POTENT THE CONTINUE TEST SEQUENCE TILL ELSE SET O FOR END READ PATTERN AND MAKE FINAL BACKWARDS PASS 22 E4 74 13 8A E0 86 F2 22 E4 75 04 8A D4 EB E0 AH, AH C6X AH, AL DH, DL AH, AH C6 DL, AH C3 AND JZ MOV XCHG AND JNZ MOV JMP 1108 1109 1110 1111 0300 0302 0304 0306 0308 030A 030C 030C 030D 030E C6: CLD INC JZ DEC JMP ; SET DIR FLAG TO GO FORWARD ; SET POINTER TO BEG LOCATION ; READ/WRITE FORWARD IN STG ; ADJUST POINTER ; READ/WRITE BACKWARD IN STG FC 47 74 DE 4F EB D9 D1 C4 D1 C3 C6X: BO 00 MOV AL,000H ; AL=O DATA COMPARE OK C7: ; SET DIRECTION FLAG BACK TO INC 1123 1124 STGTST ENDP 1125 1126 1127 1128 1129 1130 1131 EGA CRT ATTACHMENT TEST 1. INIT CRT TO 40X25 - BW ****SET TO MODE**** 2. CHECK FOR VERTICAL AND VIDEO ENABLES, AND CHECK THING OF SAME 3. CHECK VERTICAL INTERRUPT 4. CHECK RED, BLUE, GREEN, AND INTENSIFY DOTS ``` | | 1135<br>1136<br>1137 | ; 5. INIT TO 40 | 0X25 - COLOR/MONO ****SET TO MODE | **** | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | NOMINAL | TIME IS B286H FOR 60 HZ.<br>TIME IS A2FEH FOR 50 HZ. | | | = AOAC | 1139<br>1140<br>1141 | ; | EQU OAOACH | ; MAX TIME FOR VERT/VERT | | = C460 | 1141<br>1142<br>1143<br>1144 | MIN_VERT_COLOR | EQU 0C460H | ; MAX TIME FOR VERT/VERT<br>(NOMINAL + 10%)<br>MIN TIME + FOR VERT/VERT<br>(NOMINAL - 10%)<br>NUM OF ENBALES PER FRAME<br>MAX TIME FOR VERT/VERT<br>(NOMINAL - 10%)<br>ENBANCE CHABLES PER FRAME<br>NUM OF ENBALES PER FRAME<br>NUM OF ENBALES PER FRAME | | = 00C8<br>= 8D99 | 1145 | CENAB_PER_FRAME<br>MAX_VERT_MONO | E EQU 200<br>EQU 08D99H | NUM OF ENABLES PER FRAME<br>MAX TIME FOR VERT/VERT | | = B862 | 1145<br>1146<br>1147<br>1148<br>1149 | MIN_VERT_MONO | EQU OB862H | ; (NOMINAL + 10%)<br>; MIN TIME FOR VERT/VERT | | = 015E<br>= 015E | 1149<br>1150<br>1151 | EENAB_PER_FRAME MENAB_PER_FRAME | E EQU 350<br>E EQU 350 | ; (NOMINAL = 10%)<br>; ENHANCED ENABLES PER FRAME<br>: NUM OF FNARIFS PER FRAME | | = 0043<br>= 0040 | 1152<br>1153<br>1154 | TIM_CTL<br>TIMERO | EQU 043H | ; 8253 TIMER CONTROL PORT<br>; 8253 TIMER/CNTER 0 PORT | | | 1154<br>1155<br>1156<br>1157 | POD14 PROC | | | | 0317<br>0317 83 EC 0A<br>031A 8B EC | 1157<br>1158<br>1159<br>1160 | SUB<br>MOV<br>ASSUMF | NEAR<br>SP, OAH<br>BP, SP | ; RESERVE 5 WORDS ON STACK<br>; INIT SCRATCH PAD POINTER | | 031C E8 OCFE R<br>031F B0 30 | 1161 (<br>1162 (<br>1163 ( | CALL<br>MOV | DS:ABSO,ES:ABSO<br>DDS<br>AL,00110000B | ; SET TIMER 0 TO MODE 0 | | 0321 E6 43<br>0323 B0 00<br>0325 E6 40 | 1164<br>1165<br>1166 | OUT<br>MOV<br>OUT | TIM_CTL,AL<br>AL,OOH<br>TIMERO,AL | ; SEND FIRST BYTE TO TIMER | | 0323 80 00 0325 E6 40 0327 F6 06 0487 R 02 0327 F6 06 0487 R 02 0328 R 0168 R 0331 C7 46 02 015E 0336 C7 46 04 0199 0338 C7 46 04 0199 0338 C7 46 06 8862 0334 28 41 11 0344 80 27 0346 E8 0015 R 0346 88 0015 R 0346 82 04 | 1167<br>1168<br>1169 | TEST<br>JZ<br>CALL | INFO, 2<br>COLOR_EGA_V<br>ENV_3 | ; SET UP IN MONOCHROME | | 0331 C7 46 02 015E<br>0336 C7 46 04 8D99<br>033B C7 46 06 B862 | 1170<br>1171<br>1172 | MOV<br>MOV<br>MOV | COLOR_EGA_V WIND 3 TER BP 12 , MENAB PER FRAME WORD PTR BP 14 , MAX VERT MONO DUL, CRTC ADDR B AH, C. HRZ_DSP AL, 27H OUT_DX DL, INPUT_STATUS_B SHORT COMMON | SET UP IN MONOCHROME NUM. OF FRAMES FOR MONO MAX TIME FOR VERT/VERT MIN TIME FOR VERT/VERT MONO CRIC REG HORIZ. TOTAL DIPLAY TO 40 COL | | 0340 B2 B4<br>0342 B4 01 | 1173<br>1174 | MOV<br>MOV | DL, CRTC_ADDR_B AH. C HRZ DSP | ; MONO CRTC REG<br>: HORIZ. TOTAL DIPLAY | | 0344 B0 27<br>0346 E8 0D15 R<br>0349 B2 BA | 1175<br>1176<br>1177<br>1178 | MOV<br>CALL<br>MOV | AL, 27H<br>OUT_DX | TO 40 COL | | 0349 B2 BA<br>034B EB 2A<br>034D | 1177<br>1178<br>1179 | MOV<br>JMP<br>COLOR EGA V: | SHORT COMMON | ; 3BA | | 0340<br>0340 E8 0148 R<br>0350 E8 0E9A R<br>0353 73 11<br>0355 B2 D4 | 1179<br>1180<br>1181 | COLOR_EGA_V:<br>CALL<br>CALL | ENV_X<br>BRST_DET | ; SET UP IN 40X25 COLOR<br>; ENHANCED MODE | | 0353 73 11<br>0355 B2 D4<br>0357 Rb 01 | 1182<br>1183<br>1184 | JNC<br>MOV<br>MOV | COLOR_V<br>DL,CRTC_ADDR | ; NO,40X25<br>; BRST MODE ONLY! | | 0357 B4 01<br>0359 B0 14<br>0358 E8 0015 R<br>035E C7 46 02 015E<br>0363 EB 06 90 | 1185<br>1186 | MOV<br>CALL<br>MOV | AL,20<br>OUT_DX | , MODIFY FOR TEST ONLY | | 035E C7 46 02 015E<br>0363 EB 06 90<br>0366 | 1187<br>1188<br>1189 | MOV<br>JMP<br>COLOR_V: | ENV.X OET COLOR.V DL, CRTC, ADDR AH, 17 ADDR AH, 17 ADDR AH, 18 AD | ; NUM.OF FRAMES FOR COLOR | | | 1190<br>1191<br>1192 | MOV. | | ; NUM.OF FRAMES FOR COLOR | | 0366 C7 46 02 00C8<br>036B<br>036B C7 46 04 A0AC<br>0370 C7 46 06 C460<br>0375 B2 DA | 1192<br>1193<br>1194 | BRST_COLOR_V: MOV MOV | WORD PTR[BP][4], MAX_VERT_COLOR WORD PTR[BP][6], MIN_VERT_COLOR DL, INPUT_STATUS | | | | 1195<br>1196<br>1197 | MOV | DL, INPUT_STATUS | ; MAX TIME FOR VERT/VERT<br>; MIN TIME FOR VERT/VERT<br>; SET ADDRESSING TO VIDEO<br>; ATTR STATUS | | 0377<br>0377 B8 0500 | 1197<br>1198 | COMMON: | АХ, 0500Н | ; SET TO VIDEO PAGE 0 | | 0377 B8 0500<br>037A CD 10<br>037C 2B C9 | 1198<br>1199<br>1200<br>1201 | INT<br>SUB | AX,0500H<br>10H<br>CX,CX | | | | 1202<br>1203 | ; LOOK FOR | R VERTICAL | | | 037E<br>037E<br>037F EC<br>038F A8 08<br>0381 75 07<br>0383 E2 F9<br>0385 B3 00 | 1204<br>1205<br>1206 | POD14_1:<br>IN<br>TEST | AL, DX | ; GET STATUS | | 03/E<br>03/F EC<br>03/F A8 08<br>0381 75 07<br>0383 E2 F9<br>0385 B3 00 | 1207<br>1208 | JNE<br>LOOP<br>MOV | AL, DX<br>AL, 00001000B<br>P0D14_2<br>P0D14_1 | ; GET STATUS ; VERTICAL THERE YET? ; CONTINUE IF IT IS ; KEEP LOOKING TILL COUNT ; EXHAUSTED | | 0385 B3 00<br>0387 E9 0448 R | 1209<br>1210<br>1211<br>1212 | MOV<br>JMP | POD14_ERR | ; EXHAUSTED<br>; NO VERTICAL | | | 1212 | ; GOT VER1 | FICAL - START TIMER | | | 038A<br>038A B0 00<br>038C E6 40 | 1214<br>1215 | POD14_2:<br>MOV<br>OUT | AL,0<br>TIMERO,AL | . CEND OND DVIE TO TIMED TO | | 038E 2B DB | 1216<br>1217<br>1218<br>1219 | SUB | | ; SEND 2ND BYTE TO TIMER TO<br>; START IT<br>; INIT. ENABLE COUNTER | | 0200 22 00 | 1219<br>1220 | ; WAIT FOR | BX,BX<br>R VERTICAL TO GO AWAY<br>CX,CX | , | | 0392<br>0392 EC<br>0393 AR 08 | 1220<br>1221<br>1222<br>1223<br>1224 | XOR POD14_25: IN TEST | AL, DX | ; GET STATUS | | 0390 0392 EC 0392 EC 0393 A8 08 0395 74 07 0397 E2 F9 0399 B3 01 0398 E9 0448 R | 1224 (<br>1225 ( | JZ<br>LOOP<br>MOV<br>JMP | POD14_3<br>POD14_25 | ; GET STATUS ; VERTICAL STILL THERE ; CONTINUE IF IT'S GONE ; KEEP LOOKING TIEL COUNT ; EXHAUSTED | | 0399 B3 01<br>039B E9 0448 R | 1225<br>1226<br>1227 | JMP | AL, DX<br>AL, 00001000B<br>POD14_3<br>POD14_25<br>BL, 01H<br>POD14_ERR | ; EXHAUSTED<br>; VERTICAL STUCK ON | | | 1228<br>1229<br>1230 | ; NOW STAF | RT LOOKING FOR ENABLE TRANSITIONS | | | 039E<br>039E 2B C9<br>03A0 | 1231<br>1232<br>1233 | POD14_3:<br>SUB<br>POD14_4: | cx,cx | | | 03A0<br>03A0 EC<br>03A1 A8 01<br>03A3 74 15<br>03A5 A8 08<br>03A7 75 23<br>03A9 E2 F5 | 1234<br>1235<br>1236 | IN<br>TEST | AL, DX<br>AL, 00000001B | ; GET STATUS ; ENABLE ON YET? ; GO ON IF IT IS ; VERTICAL ON AGAIN? ; CONTINUE IF IT IS ; KEEP LOOKING IF NOT | | 03A3 74 15<br>03A5 A8 08<br>03A7 75 23<br>03A9 E2 F5 | 1236<br>1237<br>1238<br>1239 | JE<br>TEST | POD14_5<br>AL,00001000B | GO ON IF IT IS<br>VERTICAL ON AGAIN? | | 03A9 E2 F5<br>03AB B3 02 | 1238<br>1239<br>1240 | JNE<br>LOOP<br>MOV | AL, DX<br>AL, 000000001B<br>P0014_5<br>AL, 00001000B<br>P0014_75<br>P0014_18<br>BL. 02H | | | 03AB B3 02<br>03AD E9 0448 R<br>03B0 | 1240<br>1241<br>1242 | MOV<br>JMP<br>POD14_4A: | POD14_ERR | ; ENABLE STUCK OFF | | 03B0 B3 03<br>03B2 E9 0448 R<br>03B5 | 1243<br>1244<br>1245 | MOV<br>JMP<br>POD14_4B: | BL,03H<br>POD14_ERR | ; VERTICAL STUCK ON | | 03B5 B3 04<br>03B7 E9 0448 R | 1212 1213 1214 1215 1216 1216 1216 1217 1218 1218 1220 1221 1222 1222 1222 1222 1222 1222 1223 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1230 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1240 1250 1250 1250 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 1255 12 | MOV<br>MOV<br>JMP | BL,04H<br>POD14_ERR | ; ENABLE STUCK ON | | | 1248<br>1249 | ; MAKE SUF | RE VERTICAL WENT OFF WITH ENABLE | | | 03BA<br>03BA A8 08<br>03BC 75 F2 | 1248<br>1249<br>1250<br>1251<br>1252<br>1253<br>1254 | POD14_5:<br>TEST<br>JNZ | AL,00001000B | ; VERTICAL OFF? | | | 1253<br>1254 | JNZ<br>; NOW WAIT<br>POD14_6: | AL,00001000B<br>POD14_4A<br>F FOR ENABLE TO GO OFF | ; VERTICAL OFF?<br>; GO ON IF IT IS<br>; (ERROR IF NOT) | | 03BE<br>03BE EC<br>03BF A8 01<br>03C1 E1 FB<br>03C3 E3 F0 | 1254<br>1255<br>1256<br>1257<br>1258<br>1259 | IN<br>TEST | AL,DX<br>AL,00000001B | ; GET STATUS<br>; ENABLE OFF YET? | | 03BF A8 01<br>03C1 E1 FB<br>03C3 E3 F0 | 1257<br>1258<br>1259<br>1260 | LOOPE<br>JCXZ | AL,DX<br>AL,00000001B<br>P0014_6<br>P0014_4B<br>HAS TOGGLED, BUMP COUNTER AND TES | KEEP LOOKING IF NOT | | | 1200 | , , ENABLE I | ING TOUGLED, BUMP COUNTER AND TES | I FOR MEAT VERTICAL | | 0305 | | 1261 | С | POD14_7:<br>INC<br>JZ | | | | |------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------|--------------------------|---------------------------------------------------------------------------------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 03C5<br>03C5<br>03C6 | 43<br>74 04 | 1261<br>1262<br>1263<br>1264 | 0000000000 | INC<br>JZ | BX<br>POD14_75<br>AL,00001000B<br>POD14_3<br>D COMPLETE VERTICAL-VERTICAL CYCLE | ; | BUMP ENABLE COUNTER<br>IF COUNTER WRAPS, | | 03C8 | A8 08 | 1264<br>1265 | c | TEST | AL,00001000B | ; | SOMETHING IS WRONG<br>DID ENABLE GO LOW | | 03CA | 74 D2 | 1266<br>1267 | c | JZ | POD14_3 | ; | IF NOT, LOOK FOR ANOTHER | | | | 1264<br>1265<br>1266<br>1267<br>1268<br>1269<br>1270<br>1271 | ç | ; HAVE HA | D COMPLETE VERTICAL-VERTICAL CYCLE | ; | NOW TEST RESULTS | | 03CC<br>03CC<br>03CE | B0 00 | 1270<br>1271 | ç | MOV | | | LATCH TIMERO | | 03CE | E6 43<br>3B 5E 02 | 1272<br>1273 | C | OUT<br>CMP | AL,00<br>TIM_CTL,AL<br>BX,WORD PTR[BP][2] | ; | NUMBER OF ENABLES BETWEEN VERTICALS O.K.? | | 03D3 | 74 04<br>B3 05<br>EB 6F | 1273<br>1274<br>1275 | 000000000 | JE<br>MOV | POD14_8 | ; | VERTIGALS U.K.? | | 03D5<br>03D7<br>03D9 | EB 6F | 1276<br>1277<br>1278<br>1279 | č | JMP<br>POD14_8: | POD14_8<br>BL,05H<br>SHORT POD14_ERR | | | | | E4 40<br>8A E0 | 1279 | č | I N | AL,TIMERO<br>AH,AL | į | GET TIMER VALUE LOW<br>SAVE IT | | 03DB<br>03DD | 90<br>F4 40 | 1280<br>1281 | č | MOV<br>NOP | | | GET TIMER HIGH | | 03DE<br>03E0<br>03E2 | 86 E0<br>90 | 1282<br>1283<br>1284 | č | IN<br>XCHG<br>NOP | AL, TIMERO<br>AH, AL | , | OCT TIMEN IIION | | 03E3<br>03E4<br>03E7<br>03E9<br>03EB<br>03ED | 00 | 1285<br>1286<br>1287 | 000000 | NOP<br>CMP<br>JGE | AY WORD STRIRSIAN | | MAXIMUM VERTICAL TIMING | | 03E7 | 3B 46 04<br>7D 04<br>B3 06 | 1287 | č | MOV | AX,WORD PTR[BP][4]<br>POD14 9<br>BL,O6H<br>SHORT POD14_ERR | • | The state of s | | 03EB<br>03ED | EB 5B | 1288<br>1289<br>1290<br>1291<br>1292<br>1293<br>1294<br>1295<br>1296 | CCC | JMP<br>POD14 9: | SHORT POD14_ERR | | | | 03ED<br>03F0<br>03F2 | 3B 46 06<br>7E 04<br>B3 07 | 1291 | CCC | CMP | AX,WORD PTR[BP][6]<br>POD14_10<br>BL,O7H<br>SHORT POD14_ERR | ; | MINIMUM VERTICAL TIMING | | 03F2<br>03F4 | 7E 04<br>B3 07<br>EB 52 | 1293<br>1294 | Ċ | JLE<br>MOV<br>JMP | BL,07H<br>SHORT POD14 ERR | | | | | | 1295<br>1296 | CCC | | RED, GREEN, BLUE AND INTENSIFY DOT | rs | WORK | | | | 1297<br>1298<br>1299 | C | FIRST | SET A LINE OF REVERSE VIDEO, INTEN | | | | 03F6<br>03F6<br>03F9 | B8 09DB | 1299<br>1300 | 00000 | POD14_10: | | | | | | B8 09DB<br>BB 000F | 1300<br>1301<br>1302 | С | MOV | AX,09DBH<br>BX,000FH | í | WRITE CHARS, BLANKS<br>PAGE O, REVERSE VIDEO,<br>HIGH INTENSITY<br>80 CHARACTERS | | 03FC<br>03FF<br>0401 | B9 0050<br>CD 10 | 1303<br>1304<br>1305 | C | MOV<br>I N T | CX,80<br>10H | ; | 80 CHARACTERS | | | | | C | INT<br>IN<br>PUSH | AL, DX | : | SAVE INPUT STATUS | | 0403<br>0405 | B2 C0<br>B4 OF | 1307<br>1308 | C | MOV<br>MOV | DL,ATTR_WRITE<br>AH,OFH | į | SAVE INPUT STATUS<br>ATTRIBUTE ADDRESSS<br>PALETTE REG 'F'<br>TEST VALUE | | 0407<br>0409<br>040C | 52<br>B2 C0<br>B4 OF<br>B0 3F<br>E8 OD15 R<br>B8 000F | 1309<br>1310<br>1311 | 00000000000 | MOV<br>CALL<br>MOV | DL, ATTR_WRITE AH, OFH AL, 03FH OUT DX AX, OFH DX | ;;;;;;; | TEST VALUE<br>VIDEO STATUS MUX<br>START WITH BLUE DOTS | | 040C<br>040F | B8 000F<br>5A | 1311<br>1312 | C | POP | AX,ŌFH<br>DX | ; | START WITH BLUE DOTS | | 040F<br>0410<br>0410 | 50 | 1312<br>1313<br>1314 | C | POD14_13:<br>PUSH | | : | SAVE | | 0411<br>0412<br>0414<br>0416<br>0419<br>041A<br>041B | 52<br>B2 C0 | 1315<br>1316<br>1317<br>1318 | 000000 | PUSH<br>MOV | DX<br>DL,ATTR_WRITE | ;;;;;;; | SAVE<br>SAVE INPUT STATUS<br>ATTRIBUTE ADDRESSS<br>COLOR PLANE ENABLE<br>VIDEO STATUS MUX<br>RECOVER INPUT STATUS | | 0414<br>0416 | B4 32<br>E8 0D15 R | 1317<br>1318 | c | MOV<br>MOV<br>CALL | DL, ATTR_WRITE<br>AH, 32H<br>OUT_DX | ; | COLOR PLANE ENABLE<br>VIDEO STATUS MUX | | 0419<br>041A | 5A<br>58 | 1319 | c | POP<br>POP | DX<br>AX | ; | RECOVER INPUT STATUS | | | 2B C9 | 1321<br>1322<br>1323 | CCC | ; SEE IF | OUT_DX DX AX CX,CX DOT COMES ON | | | | 041D<br>041D<br>041E | EC | 1324 | C | PUD14_14: | | ; | GET STATUS | | | A8 30<br>75 09 | 1325<br>1326 | c | TEST<br>JNZ | AL,00110000B<br>POD14_15 | ; | GET STATUS<br>DOT THERE?<br>LOOK FOR DOT TO TURN OFF<br>CONTINUE TEST FOR DOT ON | | 0422<br>0424 | EC<br>A8 30<br>75 09<br>E2 F9<br>B3 10 | 1326<br>1327<br>1328 | c | LOOP<br>MOV | POD14-14<br>BL,10H | | | | 0426<br>0428 | OA DC<br>EB 1E 90 | 1329<br>1330<br>1331 | c | OR<br>JMP | AL, DX<br>AL, 00110000B<br>POD14_15<br>POD14_14<br>BL, 10H<br>BL, AH<br>POD14_ERR<br>DOT GOES OFF | ; | OR IN DOT BEING TESTED DOT NOT COMING ON | | 042B | | 1331<br>1332 | ç | | | | | | 042B<br>042D | 2B C9 | 1332<br>1333<br>1334 | Ċ | POD14_16: | cx,cx | | | | 042D<br>042E<br>0430 | EC<br>A8 30<br>74 08<br>E2 F9 | 1335<br>1336<br>1337 | 00000000000 | TEST | AL,DX<br>AL,00110000B<br>POD14_17<br>POD14_16 | ; | GET STATUS IS DOT STILL ON? GO ON IF DOT OFF ELSE, KEEP WAITING FOR DOT TO GO OFF | | 0430 | 74 08<br>E2 F9 | 1337 | ç | JE<br>LOOP | POD14_17<br>POD14_16 | ; | ELSE, KEEP WAITING FOR | | 0434 | B3 20<br>0A DC | 1338<br>1339<br>1340 | 000000 | MOV | BL,20H | | | | 0438 | OA DC<br>EB OE | 1340<br>1341<br>1342<br>1343<br>1344<br>1345 | C | JMP | BL,20H<br>BL,AH<br>SHORT POD14_ERR | ; | OR IN DOT BEING TESTED | | | | 1344 | č | ; ADJUST | TO POINT TO NEXT DOT | | | | 043A | EE Ch | 1346 | č | POD14_17: | АН | | | | 043A<br>043A<br>043C<br>043F | FE C4<br>80 FC 30<br>74 25<br>80 CC OF<br>8A C4<br>EB C8 | 1347<br>1348<br>1349 | 000000 | CMP<br>JE | AH, 030H<br>P0D14_18<br>AH, 0FH<br>AL, AH<br>P0D14_13 | ; | ALL 3 DOTS DONE?<br>GO END<br>MAKE 0F,1F,2F | | | 80 CC OF<br>8A C4 | 1350<br>1351<br>1352 | č | OR<br>MOV | AH, OFH<br>AL, AH | | | | 0444<br>0446<br>0448 | | 1352<br>1353 | 0000 | IMP | POD14_13 | ; | GO LOOK FOR ANOTHER DOT | | 0448<br>0448<br>044B | B9 0006<br>BA 0103 | 1353<br>1354<br>1355<br>1356<br>1357<br>1358<br>1359<br>1360 | č | POD14_ERR:<br>MOV<br>MOV | CX, 6<br>DX, 0103H<br>ERR_BEEP<br>SP, OAH<br>AL, 00110110B<br>TIM_CTL, AL<br>AL, AL<br>TIMEOT, AL | | ONE LONG AND THREE SHORT | | 044E<br>0451<br>0454 | B9 0006<br>BA 0103<br>E8 06C8 R<br>83 C4 0A<br>B0 36<br>E6 43<br>2A C0<br>E6 40 | 1356<br>1357 | 000000000000 | CALL<br>ADD | ERR_BEEP<br>SP.OAH | | BALANCE STACK<br>RE-INIT TIMER O | | 0454<br>0456 | BO 36<br>E6 43 | 1358<br>1359 | Č | MOV<br>OUT<br>SUB | AL,00110110B<br>TIM_CTL,AL | ; | RE-INIT TIMER O | | 0456<br>0458<br>045A | 2A CO<br>E6 40 | 1360<br>1361 | C | SUB<br>OUT | AL,ĀL<br>TIMERO,AL | | | | 045C<br>045D<br>045E | 90 | 1361<br>1362<br>1363<br>1364 | C | OUT<br>NOP<br>NOP | | | | | 0460 | É6 40<br>BD 0001<br>E9 0091 R | 1364<br>1365<br>1366 | C | OUT<br>MOV<br>JMP | TIMERO, AL<br>BP, 1 | | | | 0463 | | 1366<br>1367 | C | | BP,1<br>SKIP<br>DS:ABSO | | | | 0466<br>0466 | E8 OCFE R | 1367<br>1368<br>1369<br>1370<br>1371<br>1372<br>1373<br>1374<br>1375<br>1376 | CC | POD14_18:<br>CALL<br>MOV | | | | | 0466<br>0469<br>046C<br>046E | E8 OCFE R<br>B8 0500<br>CD 10<br>B0 36<br>E6 43<br>2A CO<br>E6 40 | 1370<br>1371 | Ç | MOV<br>INT | AX,0500H<br>10H | | SET TO VIDEO PAGE 0 | | 046E<br>0470 | B0 36<br>E6 43 | 1372<br>1373 | C | INT<br>MOV<br>OUT | AL,00110110B<br>TIM_CTL,AL | ; | RE-INIT TIMER 0 | | 0472<br>0474 | 2A CO<br>E6 40 | 1374<br>1375 | 000000 | SUB | AL,AL<br>TIMERO,AL | | | | 0476<br>0477 | 90<br>90 | 1376<br>1377 | C | NOP<br>NOP<br>OUT | | | | | 0470<br>0472<br>0474<br>0476<br>0477<br>0478 | 90<br>E6 40<br>83 C4 0A<br>BD 0000 | 1377<br>1378<br>1379 | CCC | ADD | TIMERO, AL<br>SP, OAH | ; | REMOVE SCRATCH PAD<br>MAKE BP NON ZERO | | 047D<br>0480 | BD 0000 | 1380<br>1381 | C | POD14 | SP, OAH<br>BP, O<br>ENDP | ; | MAKE BP NON ZERO | | | | 1382<br>1383<br>1384 | 0000000 | ; TEST ST | | | | | 0480 | | 1385 | C | MEM_TEST: | DS | | | | 0480 | 1E | 1386 | C | PUSH | υə | | | | 0481 | E8 OCFE R | 1387 C | | CALL | DDS | | |----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|---------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | 0484<br>0489 | F6 06 0487 R 02 | 1387 C<br>1388 C<br>1389 C<br>1390 C | | ASSUME<br>TEST | DDS DS:ABSO INFO,2 D_COLOR_M EQUIP_LOW,030H AX,0FH INFO,060H | | | 0489<br>048B<br>0490<br>0493 | F6 06 0487 R 02<br>74 12<br>80 0E 0410 R 30<br>B8 000F<br>80 0E 0487 R 60<br>B8 000F | 1390 C<br>1391 C<br>1392 C | | OR<br>MON | D.COLOR_M<br>EQUIP_LOW,030H<br>AX,0FH<br>INFO,060H<br>AX,0FH<br>SHORT D_OUT_M | | | 0490 | 80 OE 0487 R 60 | 1393 C<br>1394 C | | OR<br>MOV | INFO,060H | | | 0498<br>049B<br>049D | EB OD | 1395 | D COLOR | JMP | SHORT D_OUT_M | | | 049D | 80 26 0410 R CF<br>80 0E 0410 R 20<br>B8 000E | 1396 C<br>1397 C<br>1398 C | D_COLOR | AND<br>OR | EQUIP_LOW,OCFH<br>EQUIP_LOW,O20H<br>AX,OEH | | | 04A7 | | 1399 C | D_OUT_M | MOV | | ; INTERNAL COLOR MODE<br>; TEST IN COLOR | | 04A7<br>04AA<br>04AA<br>04AC | CD 10<br>83 EC 06<br>8B EC<br>B8 A000 | 1401 C | | INT | 10H<br>SP.6 | · PESERVE 3 WORDS ON STACK | | 04AF<br>04B1 | 8B EC<br>B8 A000 | 1403 C | | MOV | SP,6<br>BP,SP<br>AX,OA000H<br>DS:NOTHING,ES:NOTHING | ; RESERVE 3 WORDS ON STACK<br>; SET BP<br>; PUT BUFFER ADDRESS IN AX | | Oheli | | 1405 C | | ASSUME<br>MOV<br>MOV | DS: NOTHING DS: NOTHING DS; AX ES; EX; AX ES; EX; AX ES; EX; | ; SET UP SEG REGS TO POINT | | 0486<br>0488 | 8E C0<br>C7 46 02 0000<br>C7 46 04 0000<br>B6 03<br>B2 C4 | 1407 C | | | ES,AX<br>WORD PTR[BP][2],0 | ; SET UP SEG REGS TO POINT<br>; TO BUFFER AREA<br>; INITIALIZE<br>; INITIALIZE | | 04BD<br>04C2<br>04C4 | C7 46 04 0000<br>B6 03 | 1409 C | | MOV<br>MOV<br>MOV | WORD PTR[BP][4],0<br>DH,3 | ; INITIALIZE | | 04C4<br>04C6 | B2 C4<br>B8 0201 | 1411 C<br>1412 C<br>1413 C | | MOV | DL,SEQ_ADDR<br>AX,0201H | | | 04C6<br>04C9<br>04CC | B2 CE | 1413 C | | MOV<br>CALL<br>MOV | DL,GRAPH_ADDR | ; ADDRESS READ MAP SELECT | | 04CE<br>04D1<br>04D4 | B2 04<br>B8 0201<br>E8 0D15 R<br>B2 CE<br>B8 0400<br>E8 0D15 R<br>52 | 1415 C | | MOV<br>CALL<br>PUSH | OUT_DX<br>DX | | | 04D5<br>04D7<br>04D8 | | 1418 C | | MOV<br>IN<br>MOV | DX _ | ; SET UP ATTRIBUTE | | 04D8 | EC<br>B2 C0<br>B8 3200 | 1420 0 | | MOV<br>MOV | DL,ATTR_WRITE | ; ATTRIBUTE WRITE ADDRESS | | 04DA<br>04DD<br>04E0 | B8 3200<br>E8 0D15 R<br>E8 068F R<br>80 FC 00<br>74 03<br>E9 05CD R | 1422 C | | MOV<br>CALL<br>CALL<br>CMP | OUT_DX<br>HOW_BIG | ; GO FIND AMOUNT OF MEMORY | | | 80 FC 00<br>74 03 | 1424 C<br>1425 C<br>1426 C | | CMP<br>JZ | AH, O<br>AA1 | , | | 04E8<br>04EB | | 1426 C | AA1: | JZ<br>JMP | EGA_MEM_ERROR | | | 04E8<br>04E8<br>04EB<br>04EB<br>04EE<br>04F1 | E8 05D9 R<br>80 FC 00<br>74 03 | 1428 C | | CALL<br>· CMP<br>JZ | MEMORY_OK<br>AH,O<br>AA2 | ; GO TEST IT | | | E9 05CD R | 1430 C<br>1431 C<br>1432 C | | JZ<br>JMP | AA2<br>EGA_MEM_ERROR | | | 04F6<br>04F6 | 5A | 1432 C | AA2: | POP | DX | | | 04F3<br>04F6<br>04F6<br>04F7<br>04F9<br>04FC | 5A<br>B2 C4<br>B8 0202<br>E8 0015 R<br>B2 CE<br>B8 0401<br>E8 0015 R<br>52 | 1434 C | | MOV<br>MOV | DL, SEQ_ADDR AX, 0202H OUT_DX DL, GRAPH_ADDR AX, 0401H OUT_DX | | | 04FF<br>0501<br>0504 | B2 CE | 1436 C | | CALL<br>MOV<br>MOV | DL, GRAPH_ADDR | ; ADDRESS OF READ MAP | | 0504 | E8 0D15 R | 1438 C | | | OUT_DX | | | 0508 | BZ DA | 1440 C<br>1441 C<br>1442 C | | PUSH<br>MOV | DL,ATTR_READ | ; SET UP ATTRIBUTE | | 050B<br>050D<br>0510<br>0513<br>0518 | EC B2 C0 B8 3200 B8 0015 R C7 46 04 0000 E8 068F R 80 FC 00 74 03 | 1443 C | | MOV<br>MOV<br>CALL | OUT_DX DX | ; ATTRIBUTE WRITE ADDRESS | | 0510<br>0513 | E8 0D15 R<br>C7 46 04 0000 | 1445 C | | CALL | OUT_DX<br>WORD PTR [BP][4].0 | : INITIALIZE | | 0518<br>051B | E8 068F R<br>80 FC 00 | 1446 C<br>1447 C<br>1448 C | | MOV<br>CALL<br>CMP | HOW_BIG<br>AH,O | ; INITIALIZE<br>; GO FIND AMOUNT OF MEMORY | | 0520 | 74 03<br>E9 05CD R | | | JZ<br>JMP | AA3<br>EGA_MEM_ERROR | | | 0523<br>0523<br>0526 | | 1451 C | AA3: | CALL<br>CMP | MEMORY_OK | ; GO TEST IT | | 0526<br>0529 | E8 05D9 R<br>80 FC 00<br>74 03 | 1453 C | | JZ | AH, U<br>AA4 | | | 0529<br>052B<br>052E | É9 05CD R | 1455 C<br>1456 C<br>1457 C | AA4: | JMP<br>POP | EGA_MEM_ERROR | | | 052E<br>052F<br>0531 | 5A<br>B2 C4<br>B8 0204 | 1457 C<br>1458 C<br>1459 C | | MOV<br>MOV | DX<br>DL, SEQ_ADDR | | | | | 1460 C | | CALL | DL, SEQ_ADDR<br>AX,0204H<br>OUT_DX | | | 0537<br>0538 | 52<br>B2 CE<br>B8 0402 | 1461 C<br>1462 C | | CALL<br>PUSH<br>MOV<br>MOV | DL, GRAPH_ADDR | ; ADDRESS OF READ MAP | | 053A<br>053D<br>0540 | B8 0402<br>E8 0D15 R<br>B2 DA | 1464 C | | CALL | OUT DX. DX. GRAPH_ADDR AX, DID. GRAPH_ADDR AX, DID. GRAPH_ADDR AX, DID. GRAPH_ADDR DL, ATTR _ READ AL, DX DL, ATTR _ WRITE AX, SCOOL WORD _ PTR[BP][4], O HOW_BIG AH, O | ; SET UP ATTRIBUTE | | | EC | 1466 C | | MOV | AL, DX<br>DL, ATTR WRITE | ; ATTRIBUTE WRITE ADDRESS | | 0543<br>0545<br>0548 | B2 C0<br>B8 3200<br>E8 0D15 R<br>C7 46 04 0000<br>E8 068F R<br>80 FC 00 | 1468 C | | MOV<br>CALL | AX,3200H<br>OUT DX | | | 054B<br>0550 | C7 46 04 0000<br>E8 068F R | 1470 C<br>1471 C<br>1472 C | | MOV<br>CALL<br>CMP | WORD PTR[BP][4],0<br>HOW_BIG | ; INITIALIZE<br>; GO FIND AMOUNT OF MEMORY | | 0553<br>0556 | | 1472 C<br>1473 C | | .17 | AH,0<br>AA5 | | | 0558<br>055B | | 1474 C | AA5: | JMP | | 00 7507 17 | | 0548<br>0548<br>0550<br>0553<br>0556<br>0558<br>0558<br>0558<br>0561 | E8 05D9 R<br>80 FC 00<br>74 03 | 14501 C C C C C C C C C C C C C C C C C C C | | CALL<br>CMP<br>JZ | MEMORY_OK<br>AH,O<br>AA6 | ; GO TEST IT | | 0563<br>0566 | EB 68 90 | 1479 C | AA6: | JMP | EGA_MEM_ERROR | | | | 5A<br>B2 C4<br>B8 0208<br>E8 0D15 R<br>B2 CE | 1481 C | | POP<br>MOV | DX<br>DL.SEQ ADDR | | | 0567<br>0569<br>056C | B8 0208<br>F8 0D15 R | 1483 C | | MOV<br>MOV<br>GALL | AX,0208H | | | 056F | B2 CE<br>B8 0403 | 1485 C | | MOV | DL, SEQ_ADDR AX, 0208H OUT_DX DL, GRAPH_ADDR AX, 04033H OUT_DX | ; ADDRESS OF READ MAP | | 0574<br>0577 | B8 0403<br>E8 0D15 R<br>52 | 1487 C | | CALL | OUT_DX<br>DX | | | 0578<br>057A | B2 DA<br>EC | 1489 C | | MOV | DL,ATTR_READ<br>AL,DX | ; SET UP ATTRIBUTE | | 057B<br>057D | B2 C0<br>B8 3200 | 1491 C | | MOV<br>MOV<br>CALL | AX,3200H | ; ATTRIBUTE WRITE ADDRESS | | 0580<br>0583<br>0588<br>058B | B8 0403<br>B8 0403<br>B2 DA<br>B2 DA<br>B3 200<br>B8 020<br>B8 0205<br>B8 0207<br>B8 0207<br>B8 0208<br>B8 0208<br>B9 0208 | 1493 C<br>1494 C<br>1495 C | | | DX _ DV | ; INITIALIZE<br>; GO FIND AMOUNT OF MEMORY | | 058B | 80 FC 00<br>75 3D | 1496 C | | CALL<br>CMP | AH, O<br>FGA MEM FRROR | , GO FIND ANOUNT OF MEMORY | | 058E<br>0590<br>0593 | E8 05D9 R<br>80 FC 00 | 1498 C<br>1499 C | | JNZ<br>CALL<br>CMP<br>JNZ | MEMORY_OK<br>AH, 0 | ; GO TEST IT | | 0596<br>0598<br>0599 | 75 35<br>55 | 1500 C<br>1501 C<br>1502 C | | JNZ<br>PUSH | EGA_MEM_ERROR<br>BP | ; SAVE SCRATCH PAD POINTER<br>; RESET BP FOR XT | | 0599<br>0590 | BD 0000 | 1502 C | EGA_MEM | MOV<br>EXIT: | BP,0 | | | 059D | 5E<br>5A<br>E8 OCFE R | 1504 C | | POP<br>POP<br>CALL | SI<br>DX<br>DDS | ; RESTORE | | 059E | E8 OCFE R<br>36: 8B 5C 02 | 1506 C | | ASSUME | DS: ABSO | ; SET DATA SEGMENT | | 05A1<br>05A5 | 30: 88 30 02<br>B1 06 | 1507 C<br>1508 C<br>1509 C | | ASSUME<br>MOV<br>MOV | DS:ABSO<br>BX,WORD PTR SS:[SI][2]<br>CL,06H<br>BX,CL<br>BX | ; GET EGA MEMORY SIZE<br>; DIVIDE BY 64 TO GET<br>; NUMBER OF 64KB BLOCKS | | 05A5<br>05A7<br>05A9<br>05AA | B1 06<br>D3 EB<br>4B<br>B1 05 | 1510 C<br>1511 C<br>1512 C | | SHR<br>DEC<br>MOV | BX<br>CL,05H | , HUMBER OF OARD BEOURS | | U ) AA | | | | | ,*** | | ``` 05AC D3 E3 05AE 80 E3 60 $14567680012334567890012944567899017944455555555666666666667723455777777780011234556789999990078345678900178345678900789999990783456789017834567890178345678901783456789017834567890178345678900178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345678901783456789017834567890178345 BX,CL BL,01100000B : ISOLATE BITS 5 AND 6 05B1 80 26 0487 R 9F AND INFO. 10011111B OR 0586 08 1E 0487 R 80 OE 0487 R 04 8A 1E 0488 R E8 00F3 R 83 C4 06 1F INFO,00000100B BL,INFO_3 MK_ENV SP,6 DS 05BA 05BF 05C3 05C6 05C9 05CA 05CD 05CD 05D0 05D3 05D4 05D7 : 04H SET 3XX ACTIVE ΛP OR MOV CALL ADD POP : RESTORE STACK E9 0091 R SKIP : GO TO END EGA_MEM_ERROR: DX,0103H ERR_BEEP BP BP,1 EGA_MEM_EXIT BA 0103 E8 06C8 R 55 BD 0001 EB C3 MOV CALL PUSH MOV JMP ; ONE LONG AND THREE SHORT ; SAVE SCRATCH PAD POINTER : INDICATE ERROR FOR XT ;---- THIS ROUTINE FINDS AMOUNT OF MEMORY GOOD MEMORY_OK MOV MOV MOV MOV MOV SUB SHL CALL CMP JNZ MEMORY_OK_EX: MOV MOV MOV MOV MOV MOV MOV MEMORY_OK_EX: PROC 05D9 05DC 05DC 05DE 05E0 05E3 05E7 05E7 05E1 05F1 05F1 05FA 05FB BB A000 8E DB 8E C3 8B 46 04 8A E8 2A C9 D1 E1 E8 05FB R 80 FC 00 75 09 PROC NEAR BX,0A000H DS,BX ES,BX AX,WORD PTR[BP][4] CH,AL CL,CL CX,1 PODSTG ; SET PTR. TO BUFFER SEG ; SET SEG.REG. ; SET COUNT FOR 32K WORDS ; SET AMOUNT OF BUFFER ; TO BE TESTED ; MULTIPLY BY TWO AH, 0 MEMORY_OK_ERR ; TEST FOR ERROR ; IF ERROR GO PRINT IT AX, WORD PTR[BP][4] WORD PTR[BP][2], AX AX,0 ; AMOUNT OF MEMORY FOUND : AMOUNT OF MEMORY GOOD 8B 46 04 01 46 02 B8 0000 MEMORY_OK_ERR: MEMORY_OK THIS ROUTINE PERFORMS A READ/WRITE TEST ON A BLOCK OF STORAGE (MAX. SIZE = 32KM). IF "WARM START", FILL BLOCK WITH 0000 AND RETURN. OR START ST 05FB 05FB 05FC 05FD 55 FC 2B FF PUSH CLD SUB ; SET DIR TO INCREMENT ; SET DI=0000 REL TO START ; OF SEGMENT ; INITIAL DATA PATTERN FOR ; 00-FF TEST DI, DI 05FF 2B CO SUB AX, AX DDS DS:ABSO BX,DS:RESET_FLAG BX,1234H DX,ES DS,DX 0601 E8 OCFE R CALL CALL ASSUME MOV CMP MOV MOV JE 0604 0608 060C 060E 0610 ; WARM START? ; RESTORE DS ; GO DO FILL WITH 0000 ; IF WARM START ; DCP WARM START? ; DO FILL IF SO PODSTG_5 CMP 0612 0616 0618 0618 061A 061C 061E 0620 0622 0624 81 FB 4321 74 50 JE PODSTG_1: MOV MOV XOR [DI],AL AL,[DI] AL,AH PODSTG_ERRO ; WRITE TEST DATA ; GET IT BACK ; COMPARE TO EXPECTED ; ERROR EXIT IF MISCOMPARE ; FORM NEW DATA PATTERN AH AL,AH PODSTG_1 ; LOOP TILL ALL 256 DATA ; PATTERNS DONE ; SAVE WORD COUNT ; LOAD DATA PATTERN 8B E9 B8 AA55 8B D8 BA 55AA F3/ AB MOV MOV MOV MOV REP BP,CX AX,0AA55H BX,AX DX,055AAH STOSW 0626 0628 062B 062D LOAD DATA PATTERN LOAD DATA PATTERN FILL MONDOS FROM LOW TO POINT TO LAST WORD MRITTEN SET DIR FLAG TO GO DOWN SET INDEX REOS. EQUAL RECOVER WORD COUNT GET WORD FROM MEMORY EQUAL WHAT S/B THERE? GO ERROR EXIT IF NOT GET SO DATA PATTERN AND STORE IN LOC JUST READ RECOVER WORD COUNT GET SO DATA PATTERN AND STORE IN LOC JUST READ RECOVER WORD COUNT BACK TO INCREMENT ADJUST PTRS DEC DEC STD PODSTG 2 2: LODSW XOR JNZ MOV STOSW AD 33 C3 75 22 88 C2 AB E2 F6 8B CD FC 46 46 8B FE AX,BX PODSTG_ERRO AX,DX LOOP MOV CLD INC PODSTG_2 CX,BP S١ INC Di.sı ; LOW TO HIGH DOING WORDS ; GET A WORD ; SHOULD COMPARE TO DX ; GO ERROR IF NOT ; WRITE 0000 BACK TO LOC ; JUST READ ; LOOP TILL DONE PODSTG_3: AD 33 C2 75 11 AB ionsw PODSTG_ERRO LOOP PODSTG_3 0650 E2 F8 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 BACK TO DECREMENT ADJUST POINTER DOWN TO LAST WORD WRITTEN 0652 FD 0653 4E 0654 0655 0657 0658 065A 065C 065E 4E 8B CD DEC ; GET WORD COUNT PODSTG_4: LODSW ; GET WORD ; = TO 0000 ; ERROR IF NOT ; LOOP TILL DONE AX,AX PODSTG_ERRO PODSTG_4 SHORT PODSTG_ERR2 OR JNZ LOOP PODSTG_ERRO: 8B C8 32 E4 0A ED : SAVE BITS IN ERROR : HIGH BYTE ERROR? ``` ``` JZ MOV PODSTG_ERR1: OR JZ ADD PODSTG_ERR2: POP CLD RET 16349 16467 11648 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 16524 PODSTG_ERR1 AH, 1 : SET HIGH BYTE ERROR CL,CL PODSTG_ERR2 AH,2 : LOW BYTE ERROR? ; SET DIR FLAG BACK TO INC RETURN TO CALLER SIMPLE FILL WITH 0000 ON WARM-START ; SAVE ; SAVE VALUE AX DX DX DL, SC _ADDR AX, 020FH OUT_DX DX AX STOSM DDS: ABSO DS: RESET_FLAG, BX PODSTG_ERR2 0674 0675 0676 0678 067A 067D 0680 0681 0682 0684 ; SEQ_ADDR REGISTER 89 1E 0472 R 8E DA EB E2 ;---- DETERMINE SIZE OF BUFFER PROC NEAR DX,DS BX,BX ; SET PNTR TO BUFFER LOC ; BASIC COUNT OF OOK 28 DB 8E C2 2B FF 88 A355 8B C8 26: 89 05 80: 0F 26: 8B 05 33 C1 75 14 89 2000 F3/ AB 81 C2 0400 80 FE B0 75 DA EB 01 90 ES, DX D1, D1 AX, OAA55H CX, AX ES: [D1], AX AL, OFH AX, ES: [D1] AX, CX HOW BIG_END CX, 2000H ; SET SEG. REG ; SEND TO MEMORY ; PUT SOMETHING IN AL GET PATTERN FROM MEMORY ; COMPARE PATTERNS GO END IF NO COMPARE ; SET COUNT FOR 8K WORDS ; FILL 8K WORDS ; POINT TO NEXT 16K BLOCK ; BUMP COUNT BY 16KB DX,0400H BX,16 DH,0B0H FILL_LOOP HOW_BIG_END ; AREA YET ?(B0000H) DH,OAOH HB_ERROR_EXIT ; 1ST 16KB OK RESUME: ADD MOV HB_ERROR_EX RET WORD PTR[BP][4],BX ; SAVE BUFFER FOUND C3 SUBROUTINES FOR POWER ON DIAGNOSTICS : THIS PROCEDURE WILL ISSUE ONE LONG TONE (3 SEC) AND ONE OR MORE SHORT TONES (1 SEC) TO INDICATE A FAILURE ON THE PLANAR BOARD, A BAD RAM MODULE, OR A PROBLEM WITH THE CRT. ENTRY REQUIREMENTS: DH=NUMBER OF LONG TONES TO BEEP DL=NUMBER OF SHORT TONES TO BEEP. ; DL=NUMBER C ERR_BEEP PROC PUSHF CLI PUSH DS CALL DDS ASSUME DS: OR DH JZ G3 9C FA 1E E8 OCFE R ; SAVE FLAGS ; DISABLE SYSTEM INTS ; ANY LONG TONES TO BEEP ; NO, DO THE SHORT ONES ; LONG BEEP ; COUNTER FOR BEEPS ; DO THE BEEP 06CE 06D0 06D2 06D2 06D4 06D7 06D9 06DB 06DD 06DD 06E2 06E2 06E8 06E8 06E8 06E8 06EA G1: BL,6 BEEP G2: ; DELAY BETWEEN BEEPS ; ANY MORE TO DO ; DO IT G3: ; COUNTER FOR A SHORT BEEP G4: G5: E2 FE LOOP G5 ; DELAY BEFORE RETURN G6: LOOP G6 POP POPF RET E2 FE ; RESTORE CONTENTS OF DS : RESTORE FLAGS ERR_BEEP ENDP SUBTTL ; MODE SET ; SET CURSOR TYPE ; SET CURSOR POSITION ; READ LIGHT PEN POSITION ; READ LIGHT PEN POSITION ; READ LIGHT PEN POSITION ; READ LIGHT PEN POSITION ; READ CURLY PAGE ; SCROLL UP ; SEAD COLMA/ATTRIBUTE ; WRITE CHAR/ATTRIBUTE ; WRITE CHAR/ATTRIBUTE ; WRITE CHARACTER ONLY ; SET COLM PALETTE ; SET POLITY FOR THE PALETTE ; SET PALETTE ; SET PALETTE ; SET PALETTE ; SET PALETTE ; SET PALETTE ; ARE SET FALETTE WRITE STRING T21 ``` ``` 1765/ 17769/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17770/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 17780/ 177 INCLUDE VPARMS.INC SUBTIL VPARMS.INC PAGE VIDEO_PARMS LABEL BYTE COLUMNS, ROWS, PELS PER CHARACTER PAGE LENGTH SEQUENCER PARAMETERS MISCELLANEOUS REGISTER CRITC PARAMETERS ATTRIBUTE PARAMETERS GRAPHICS PARAMETERS $ - VIDEO_PARMS 40D,24D,08D 00800H TFS_LEN EQU $ - BASE_1_L 071C 071C 0B 03 00 03 = 0004 LABEL BYTE 00BH,003H,000H,003H $ - SEQ_PARMS 0721 0721 37 27 2D 37 31 15 0727 04 11 00 07 06 07 072D 00 00 00 00 06 12 0733 C7 14 08 E0 F0 A3 0739 FF = 0019 LABEL BYTE 037H,027H,02DH,037H,031H,015H 004H,011H,000H,007H,006H,007H 000H,000H,000H,000H,02HH,024H 0C7H,014H,008H,0E0H,0F0H,0A3H LABEL BYTE 000H,001H,002H,003H,004H,005H 006H,007H,010H,011H,012H,013H 014H,015H,016H,017H,008H,000H 00FH,000H S - BASE 1 L LABEL BYTE 000H,000H,000H,000H,000H,010H 00EH,000H,0FFH S-GRAPH_PARMS M_TBL_LEN 0757 28 18 08 075A 0800 40D,24D,08D 00800H DB 00BH,003H,000H,003H DB 0761 37 27 20 37 31 15 0767 04 11 00 07 06 07 076D 00 00 00 00 E1 24 0773 C7 14 08 E0 F0 A3 0779 FF 037H,027H,02DH,037H,031H,015H 004H,011H,000H,007H,006H,007H 000H,000H,000H,00H,0E1H,024H 0C7H,014H,008H,0E0H,0F0H,0A3H 077A 00 01 02 03 04 05 0780 06 07 10 11 12 13 0786 14 15 16 17 08 00 078C 0F 00 000H,001H,002H,003H,004H,005H 006H,007H,010H,011H,012H,013H 014H,015H,016H,017H,008H,000H 00FH,000H 078E 00 00 00 00 00 10 0794 0E 00 FF 000H,000H,000H,000H,000H,010H 00EH,000H,0FFH 80D,24D,08D 01000H 079C 01 03 00 03 001н,003н,000н,003н DB 07A1 70 4F 5C 2F 5F 07 07A7 04 11 00 07 06 07 07AD 00 00 00 00 E1 24 07B3 C7 28 08 E0 F0 A3 07B9 FF 07BA 00 01 02 03 04 05 07C0 06 07 10 11 12 13 07C6 14 15 16 17 08 00 07CC 0F 00 000H,001H,002H,003H,004H,005H 006H,007H,010H,011H,012H,013H 014H,015H,016H,017H,008H,000H 00FH,000H 000H,000H,000H,000H,000H,010H 00EH,000H,0FFH 07CE 00 00 00 00 00 10 07D4 0E 00 FF 80D,24D,08D 01000H 07DC 01 03 00 03 DB 001Н,003Н,000Н,003Н DB 07E1 70 4F 5C 2F 5F 07 07E7 04 11 00 07 06 07 07ED 00 00 00 00 E1 24 07F3 C7 28 08 E0 F0 A3 07F9 FF 070H,04FH,05CH,02FH,05FH,007H 004H,011H,000H,007H,006H,007H 000H,000H,000H,00F1H,024H 0C7H,028H,008H,0E0H,0F0H,0A3H 0FFH 07FA 00 01 02 03 04 05 0800 06 07 10 11 12 13 0806 14 15 16 17 08 00 080C 0F 00 000H,000H,000H,000H,000H,010H 00EH,000H,0FFH 080E 00 00 00 00 00 10 0814 0E 00 FF 0817 28 18 08 40D,24D,08D ``` | | | | - 1 | | | | |------------------------------|----------------------------------------------------------------------------------|----------------------|----------|-----|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 081A | 4000 | 1891<br>1892<br>1893 | ç | | DW | 04000Н | | 081C | OB 03 00 02 | 1893<br>1894 | C | | DB | 008н,003н,000н,002н | | 0820 | 23 | 1894<br>1895<br>1896 | č | | DB | 023H | | 0821<br>0827 | 37 27 2D 37 30 14 | 1897<br>1898 | č | | DB | 037H,027H,02DH,037H,030H,014H<br>004H,011H,000H,001H,000H,000H<br>000H,000H,000 | | 0827<br>082D | 37 27 2D 37 30 14<br>04 11 00 01 00 00<br>00 00 00 00 E1 24<br>C7 14 00 E0 F0 A2 | 1800 | C | | DB<br>DB | 004H,011H,000H,001H,000H,000H<br>000H,000H,000 | | 082D<br>0833<br>0839 | C7 14 00 E0 F0 A2 | 1900<br>1901 | C | | DB<br>DB | 0C7H, 014H, 000H, 0E0H, 0F0H, 0A2H | | | | 1902 | č | | | 0 | | 083A<br>0840 | 00 13 15 17 02 04<br>06 07 10 11 12 13<br>14 15 16 17 01 00 | 1903<br>1904 | C | | DB<br>DB | 000H,013H,015H,017H,002H,004H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,001H,000H<br>003H,000H | | 0846<br>084C | 14 15 16 17 01 00 | 1905<br>1906 | ç | | DB<br>DB | 014H, 015H, 016H, 017H, 001H, 000H | | 084E | 00 00 00 00 00 00 | 1907 | č | | | | | 084E<br>0854 | 00 00 00 00 00 30<br>0F 00 FF | 1909 | C | | DB<br>DB | 000H,000H,000H,000H,000H,030H<br>00FH,000H,0FFH | | | | 1910<br>1911 | C | ;5 | | | | 0857<br>085A | 28 18 08<br>4000 | 1912<br>1913 | Ċ | , - | DB<br>DW | 40D,24D,08D<br>04000H | | | | 1914 | č | | | | | 085C | OB 03 00 02 | 1915<br>1916 | C | | DB | оовн, оозн, ооон, оогн | | 0860 | 23 | 1917<br>1918 | C | | DB | 023H | | 0861 | 37 27 2D 37 30 14 | 1919 | č | | DB | 037H, 027H, 02DH, 037H, 030H, 014H<br>004H, 011H, 000H, 001H, 000H, 000H<br>000H, 000H, 000H, 00H, 0E1H, 024H<br>0C7H, 014H, 000H, 0E0H, 0F0H, 0A2H | | 0867<br>086D<br>0873 | 37 27 2D 37 30 14<br>04 11 00 01 00 00<br>00 00 00 00 E1 24<br>C7 14 00 E0 F0 A2 | 1921 | č | | DB<br>DB | 000H,000H,000H,000H,0E1H,024H | | 0873<br>0879 | C7 14 00 E0 F0 A2<br>FF | 1922<br>1923 | C | | DB<br>DB | 0C7H,014H,000H,0E0H,0F0H,0A2H | | 0974 | 00 13 15 17 02 04 | 1923<br>1924<br>1925 | ç | | DB | 0004 0134 0154 0174 0024 0054 | | 0880 | 00 13 15 17 02 04<br>06 07 10 11 12 13<br>14 15 16 17 01 00 | 1926<br>1927 | č | | DB<br>DB | 006H,007H,010H,011H,012H,013H | | 087A<br>0880<br>0886<br>088C | 00 13 15 17 02 04<br>06 07 10 11 12 13<br>14 15 16 17 01 00<br>03 00 | | C | | DB<br>DB | 000H,013H,015H,017H,002H,004H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,001H,000H<br>003H,000H | | | | 1929<br>1930 | C | | DB | | | 088E<br>0894 | 00 00 00 00 00 30<br>0F 00 FF | | č | | DB<br>DB | 000H,000H,000H,000H,000H,030H<br>00FH,000H,0FFH | | | | 1932<br>1933 | č | ;6 | | | | 0897<br>089A | 50 18 08<br>4000 | 1934<br>1935 | C | | DB<br>DW | 80D,24D,08D<br>04000H | | 0890 | 01 01 00 06 | 1936<br>1937 | Č | | DB | 001Н,001Н,000Н,006Н | | | | 1938 | č | | | | | 08A0 | 23 | 1939 | Ċ | | DB | 023H | | 08A1<br>08A7<br>08AD | 70 4F 59 2D 5E 06<br>04 11 00 01 00 00<br>00 00 00 00 E0 23<br>C7 28 00 QF EF C2 | 1941 | C | | DB<br>DB<br>DB | 070H,04FH,059H,02DH,05EH,006H<br>004H,011H,000H,001H,000H,000H<br>000H,000H,000 | | 08AD<br>08B3 | 04 11 00 01 00 00<br>00 00 00 00 E0 23<br>C7 28 00 QF EF C2<br>FF | 1943 | č | | DB<br>DB | 000H,000H,000H,000H,0E0H,023H | | 08B3 | FF 00 QF EF G2 | 1944<br>1945 | Č | | DB | OFFH | | | | 1946 | C | | D.B. | | | 08BA<br>08C0<br>08C6 | 00 17 17 17 17 17<br>17 17 17 17 17 17<br>17 17 17 17 01 00 | 1948<br>1949 | č | | DB<br>DB | 017H,017H,017H,017H,017H,017H | | 0800 | 01 00 | 1050 | č | | DB | 000H,017H,017H,017H,017H,017H<br>017H,017H,017H,017H,017H,017H<br>017H,017H,017H,017H,001H,000H<br>001H,000H | | 08CE | 00 00 00 00 00 00<br>0D 00 FF | 1951<br>1952 | c | | DB | 000H,000H,000H,000H,000H,000H<br>00DH,000H,0FFH | | 08D4 | 0D 00 FF | 1953<br>1954 | C | | DB | OODH, OOOH, OFFH | | | | 1955 | č | ;7 | | | | 08D7<br>08DA | 50 18 0E<br>1000 | 1956<br>1957 | C | | DB<br>DW | 80D,24D,14D<br>01000H | | 08DC | 00 03 00 03 | 1958<br>1959 | C | | DB | 000Н,003Н,000Н,003Н | | 08E0 | A6 | 1960<br>1961 | č | | DB | 0A6H | | | · · · · | 1962 | č | | | | | 08E1<br>08E7 | 60 4F 56 3A 51 60<br>70 1F 00 0D 0B 0C<br>00 00 00 00 5E 2E<br>5D 28 0D 5E 6E A3 | 1963<br>1964 | c | | DB<br>DB | 060H,04FH,056H,03AH,051H,060H<br>070H,01FH,000H,00DH,00BH,00CH<br>000H,000H,000H,00GH,05EH,02EH<br>05DH,028H,00DH,05EH,06EH,0A3H | | 08ED | 70 1F 00 0D 0B 0C<br>00 00 00 00 5E 2E<br>5D 28 0D 5E 6E A3 | 1965<br>1966 | ç | | DB<br>DB | 000H, 000H, 000H, 000H, 05EH, 02EH | | 08F3<br>08F9 | FF CO OD JE OE AS | 1967 | č | | DB | OFFH | | 08FA | 00 08 08 08 08 08 | 1968<br>1969<br>1970 | C | | DB | 000H,008H,008H,008H,008H,008H | | 08FA<br>0900<br>0906<br>090C | 08 08 10 18 18 18<br>18 18 18 18 0E 00<br>0F 08 | 1970<br>1971 | C | | DB<br>DB<br>DB<br>DB | 000H,008H,008H,008H,008H,008H<br>008H,008H, | | 090C | OF 08 | 1972<br>1973 | Č | | DB | 00FH,008H | | 090E<br>0914 | 00 00 00 00 00 10<br>0A 00 FF | 1974 | č | | DB<br>DB | 000H,000H,000H,000H,000H,010H<br>00AH,000H,0FFH | | 0914 | 0A 00 FF | 1975<br>1976 | C | | DB | 00AH,000H,0FFH | | 0917 | 28 18 08 | 1977<br>1978 | C | ;8 | DB | 40D. 24D. 08D | | 0917<br>091A | 28 18 08<br>4000 | 1979<br>1980 | č | | DW | 40D,24D,08D<br>04000H | | 091C | 00 00 00 03 | 1981 | č | | DB | 000Н,000Н,000Н,003Н | | 0920 | 23 | 1982<br>1983 | C | | DB | 023H | | 0921 | 37 27 20 37 31 15 | 1984<br>1985 | C | | DB | 037H. 027H. 02DH. 037H. 031H. 015H | | 0921<br>0927<br>0920 | 37 27 2D 37 31 15<br>04 11 00 07 06 07<br>00 00 00 00 E1 24<br>C7 14 08 E0 F0 A3 | 1986<br>1987 | č | | DB<br>DB | 037H,027H,02DH,037H,031H,015H<br>004H,011H,000H,007H,006H,007H<br>000H,000H,000H,00H,0E1H,024H<br>007H,014H,008H,0E0H,0F0H,0A3H | | 0933<br>0939 | C7 14 08 E0 F0 A3 | 1988 | č | | DB | 0C7H,014H,008H,0E0H,0F0H,0A3H | | | FF | 1989<br>1990 | c | | DB | Urrn | | 093A<br>0940<br>0946<br>094C | 00 01 02 03 04 05<br>06 07 10 11 12 13<br>14 15 16 17 08 00 | 1991 | č | | DB<br>DB | 000H,001H,002H,003H,004H,005H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,008H,000H | | 0946 | 06 07 10 11 12 13<br>14 15 16 17 08 00<br>0F 00 | 1993 | č | | DB | 014H,015H,016H,017H,008H,000H<br>00FH,000H | | | | 1994<br>1995<br>1996 | Ċ | | DB | | | 094E<br>0954 | 00 00 00 00 00 10<br>0E 00 FF | | C | | DB<br>DB | 000H,000H,000H,000H,000H,010H<br>00EH,000H,0FFH | | 0,,,4 | 02 00 11 | 1998<br>1999 | č | | | 00211,00011,01111 | | 0957<br>095A | 28 18 08<br>4000 | 2000 | č | ;9 | DB<br>DW | 400,240,080<br>04000H | | | | 2001<br>2002 | C | | | | | 095C | 00 00 00 03 | 2003<br>2004 | Ċ | | DB | ооон, ооон, ооон, оозн | | 0960 | 23 | 2005<br>2006 | č | | DB | 023H | | 0961 | 37 27 2D 37 31 15 | 2007 | Ċ | | DB . | 037H,027H,02DH,037H,031H,015H | | 0967<br>096D<br>0973 | 37 27 2D 37 31 15<br>04 11 00 07 06 07<br>00 00 00 00 E1 24<br>C7 14 08 E0 F0 A3 | 2008<br>2009 | C | | DB<br>DB | 037H,027H,02DH,037H,031H,015H<br>004H,011H,000H,007H,006H,007H<br>000H,000H,000H,00H,0E1H,024H<br>0C7H,014H,008H,0E0H,0F0H,0A3H | | 0973 | 00 00 00 00 E1 24<br>C7 14 08 E0 F0 A3<br>FF | 2010<br>2011 | ć | | DB<br>DB | OC7H, 014H, 008H, 0E0H, 0F0H, 0A3H | | 0,,, | | 2012 | č | | | Vrrn | | 097A<br>0980 | 00 01 02 03 04 05<br>06 07 10 11 12 13<br>14 15 16 17 08 00<br>0F 00 | 2013<br>2014 | <u> </u> | | DB<br>DB | 000H,001H,002H,003H,004H,005H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,008H,000H<br>00FH,000H | | 0986<br>0980 | 14 15 16 17 08 00<br>0F 00 | 2015<br>2016 | c | | DB<br>DB | 014H,015H,016H,017H,008H,000H<br>00FH,000H | | | | | | | | | | 098E<br>0994 | 00 00<br>0E 00 | 00<br>FF | 00 | 00 | 10 | 2017<br>2018<br>2019<br>2020 | <u> </u> | | DB<br>DB | 000H,000H,000H,000H,000H,010H<br>00EH,000H,0FFH | |--------------------------------------|----------------------------------|----------------------|----------------------|----------------------|----------------------|------------------------------|-----------------------------------------|----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 0997<br>099A | 28 18<br>4000 | 80 | | | | 2021<br>2022<br>2023 | CCC | ;A | DB<br>DW | 40D,24D,08D<br>04000H | | 099C | 00 00 | 00 | 03 | | | 2024<br>2025 | C | | DB | 000Н,000Н,000Н,003Н | | 09A0 | 23 | | | | | 2026<br>2027<br>2028 | C | | DB | 023H | | 09A1<br>09A7<br>09AD<br>09B3 | 37 27<br>04 11<br>00 00<br>C7 14 | 2D<br>00<br>00 | 37<br>07<br>00 | 31<br>06<br>E1 | 15<br>07<br>24 | 2029<br>2030<br>2031 | C | | DB<br>DB<br>DB | 037H, 027H, 02DH, 037H, 031H, 015H<br>004H, 011H, 000H, 007H, 006H, 007H<br>000H, 000H, 000H, 000H, 0E1H, 024H<br>007H, 014H, 008H, 0E0H, 0F0H, 0A3H | | 09B3<br>09B9 | C7 14 | 08 | EO | FO | A3 | 2032<br>2033 | C | | DB<br>DB | OC7H, 014H, 008H, 0E0H, 0F0H, 0A3H<br>OFFH | | | 00 01<br>06 07<br>14 15 | 02 | 03 | 04<br>12<br>08 | 05<br>13<br>00 | 2034<br>2035 | C | | DB | 000H,001H,002H,003H,004H,005H | | 09BA<br>09C0<br>09C6<br>09CC | 06 07<br>14 15<br>0F 00 | 02<br>10<br>16 | 03<br>11<br>17 | 08 | 00 | 2036<br>2037<br>2038 | C | | DB<br>DB<br>DB | 000H,001H,002H,003H,004H,005H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,008H,000H<br>00FH,000H | | 09CE<br>09D4 | 00 00<br>0E 00 | 00 | 00 | 00 | 10 | 2039 | C | | DB<br>DB | 000H,000H,000H,000H,000H,010H<br>00EH,000H,0FFH | | | | | | | | 2041<br>2042<br>2043 | č | ;B | | | | 09D7<br>09DA | 1000 | 08 | | | | 2044<br>2045<br>2046 | CCC | | DB<br>DW | 80D,24D,08D<br>01000H | | 09DC | 01 04 | 00 | 07 | | | 2047<br>2048 | Ċ | | DB | 001H,004H,000H,007H | | 09E0<br>09E1 | 23<br>70 4F | 5C | 2 F | 5F | 07 | 2049<br>2050<br>2051 | C | | DB<br>DB | 023H<br>070H. 04FH. 05CH. 02FH. 05FH. 007H | | 09E7<br>09ED<br>09F3 | 70 4F<br>04 11<br>00 00<br>C7 28 | 00<br>00<br>08 | 2F<br>07<br>00<br>E0 | 06<br>E1<br>F0 | 07<br>24<br>A3 | 2052<br>2053<br>2054 | C | | DB<br>DB | 070H,04FH,05CH,02FH,05FH,007H<br>004H,011H,000H,007H,006H,007H<br>000H,000H,000H,000H,0E1H,024H<br>0C7H,028H,008H,0E0H,0F0H,0A3H | | 09F3<br>09F9 | C7 28<br>FF | 08 | EO | FO | A3 | 2054<br>2055<br>2056 | 000 | | DB<br>DB | OFFR | | 09FA<br>0A00 | 00 00<br>00 00<br>00 00 | 00<br>00<br>00 | 00<br>00<br>00 | 00<br>00 | 00<br>00 | 2057<br>2058<br>2059 | Č | | DB<br>DB<br>DB | 000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,000H | | 0A00<br>0A06<br>0A0C | OF 00 | | 00 | 00 | 00 | 2059<br>2060<br>2061 | 000 | | DB<br>DB | | | 0A0E<br>0A14 | 00 00<br>04 00 | 00<br>FF | 00 | 00 | 00 | 2062 | č | | DB<br>DB | 000H,000H,000H,000H,000H,000H<br>004H,000H,0FFH | | 0A17<br>0A1A | 50 18<br>1000 | 0E | | | | 2064<br>2065<br>2066 | C | ;C | DB<br>DW | 80D,24D,14D<br>01000H | | 0A1C | 00 04 | 00 | 07 | | | 2067<br>2068<br>2069 | C | | DB | 000Н,004Н,000Н,007Н | | 0A20 | A6 | | | | | 2070<br>2071 | C | | DB | 0A6H | | 0A21<br>0A27<br>0A2D<br>0A33 | 60 4F<br>70 1F<br>00 00<br>5D 28 | 56<br>00 | 3A<br>0D<br>00<br>5E | 51<br>0B<br>5E<br>6E | 60<br>0C<br>2E<br>A3 | 2072<br>2073<br>2074 | C | | DB<br>DB<br>DB | 060H, 04FH, 056H, 03AH, 051H, 060H<br>070H, 01FH, 000H, 00DH, 00BH, 00CH<br>000H, 000H, 000H, 005CH, 02EH<br>05DH, 028H, 00DH, 05EH, 06EH, 0A3H | | 0A33<br>0A39 | 5D 28 | 0D | 5E | 6E | A3 | 2074<br>2075<br>2076<br>2077 | CCC | | DB<br>DB | 05DH, 028H, 00DH, 05EH, 06EH, 0A3H<br>0FFH | | 0A3A<br>0A40 | 00 00<br>00 00 | 00 | 00<br>00 | 00<br>00 | 00 | 2077<br>2078<br>2079 | C | | DB<br>DB | 000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,000H | | 0A46<br>0A4C | 00 00<br>0F 08 | 00 | 00 | 0E | 00 | 2080<br>2081 | C | | DB<br>DB | 000H,000H,000H,000H,00EH,000H<br>00FH,008H | | 0A4E<br>0A54 | | 00<br>FF | 00 | 00 | 00 | 2082<br>2083<br>2084 | C | | DB<br>DB | 000H,000H,000H,000H,000H,000H<br>004H,000H,0FFH | | 0A57<br>0A5A | | 08 | | | | 2085<br>2086<br>2087 | C | ;D | DB<br>DW | 40D,24D,08D<br>02000H | | 0A5C | 0B 0F | 00 | 06 | | | 2087<br>2088<br>2089<br>2090 | C | | DB | 02000H<br>00BH,00FH,000H,006H | | 0A60 | 23 | | | | | | C | | DB | 023H | | 0A61<br>0A67 | 37 27<br>04 11 | 2D<br>00<br>00<br>00 | 37<br>00<br>00<br>E0 | 30<br>00 | 14<br>00 | 2092<br>2093<br>2094 | Č | | DB<br>DB | 037H,027H,02DH,037H,030H,014H<br>004H,011H,000H,000H,000H,000H | | 0A61<br>0A67<br>0A6D<br>0A73<br>0A79 | 00 00<br>C7 14<br>FF | 00 | 00<br>E0 | 30<br>00<br>E1<br>F0 | 00<br>24<br>E3 | 2095<br>2096<br>2097 | CCC | | DB<br>DB<br>DB | 037H,027H,02DH,037H,030H,014H<br>004H,011H,000H,000H,000H,000H<br>000H,000H,000 | | 0A7A<br>0A80 | | 02 | 03 | 04 | 05 | 2098<br>2099<br>2100 | Ċ | | DB<br>DB | | | 0A80<br>0A86<br>0A8C | 00 01<br>06 07<br>14 15<br>0F 00 | 02<br>10<br>16 | 03<br>11<br>17 | 12<br>01 | 05<br>13<br>00 | 2100<br>2101<br>2102<br>2103 | CC | | DB<br>DB<br>DB | 000H,001H,002H,003H,004H,005H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,001H,000H<br>00FH,000H | | 0A8E<br>0A94 | | 00<br>FF | 00 | 00 | 00 | 2104 | ç | | DB | 000H,000H,000H,000H,000H,000H<br>005H,00FH,0FFH | | 0A94<br>0A97<br>0A9A | | 08 | | | | 2105<br>2106<br>2107<br>2108 | C | ;E | DB<br>DB | 005H, 00FH, 0FFH<br>80D, 24D, 08D<br>04000H | | 0A9A<br>0A9C | 4000<br>01 OF | | | | | 2108<br>2109<br>2110<br>2111 | C | | DW<br>DB | | | OAAO | 23 | 00 | 06 | | | 2111<br>2111<br>2112 | CCC | | DB | 001H,00FH,000H,006H<br>023H | | 0441 | 70 4F | 59 | 2D | 5E | 06 | 2112<br>2113<br>2114 | C | | DB | | | OAA7<br>OAAD<br>OAB3 | 04 11<br>00 00<br>C7 28 | 59<br>00<br>00<br>00 | 2D<br>00<br>00<br>DF | 5E<br>00<br>E0<br>EF | 00<br>23<br>E3 | 2115<br>2116<br>2117 | C | | DB<br>DB<br>DB | 070H, 04FH, 059H, 02DH, 05EH, 006H<br>004H, 011H, 000H, 000H, 000H, 000H<br>000H, 000H, 000H, 000H, 0E0H, 023H<br>0C7H, 028H, 000H, 0DFH, 0EFH, 0E3H | | OAB9 | FF | | | | | 2118<br>2119<br>2120 | C | | DB<br>DB | UFFH | | OABA<br>OACO<br>OAC6<br>OACC | 00 01<br>06 07<br>14 15 | 02<br>10<br>16 | 03<br>11<br>17 | 04<br>12<br>01 | 05<br>13<br>00 | 2120<br>2121<br>2122<br>2123 | C | | DB<br>DB | 000H,001H,002H,003H,004H,005H<br>006H,007H,010H,011H,012H,013H<br>014H,015H,016H,017H,001H,000H<br>00FH,000H | | | 01 00 | | | | | 2123<br>2124<br>2125 | CC | | DB<br>DB | | | OACE<br>OAD4 | | | 00 | 00 | 00 | | c | ;F | DB | 000H,000H,000H,000H,000H,000H<br>005H,00FH,0FFH | | 0AD7<br>0ADA | 8000 | 0E | | | | 2127<br>2128<br>2129<br>2130 | 000000000000000000000000000000000000000 | | DB<br>DW | 80D,24D,14D<br>08000H | | OADC | 05 OF | 00 | 00 | | | 2131 | Ċ | | DB | 005H,00FH,000H,000H | | 0AE0<br>0AE1 | A2<br>60 4F | 56 | 1A | 50 | ΕO | 2132<br>2133<br>2134<br>2135 | C | | DB<br>DB | 060H.04FH.056H.01AH.050H.0E0H | | OAE7<br>OAED<br>OAF3 | 60 4F<br>70 1F<br>00 00 | 56<br>00<br>00<br>0D | 00<br>00<br>5E | 00<br>5E<br>6E | 00<br>2E<br>8B | 2136 | Č | | DB<br>DB<br>DB | 060H,04FH,056H,01AH,050H,0E0H<br>070H,01FH,000H,000H,000H,000H<br>000H,000H,000H,00 | | OAF9 | FF | | | | | 2138<br>2139<br>2140 | C | | DB | | | OAFA<br>OBOO | $^{00\ 08}_{00\ 00}$ | 00<br>00 | 00<br>80 | 18<br>00 | 18<br>00 | 2141<br>2142 | Č | | DB<br>DB | 000H,008H,000H,000H,018H,018H<br>000H,000H,000H,008H,000H,000H | | 0B06<br>0B0C | 00 18<br>05 00 | 00 | 00 | ОВ | 00 | 2143 C<br>2144 C<br>2145 C<br>2146 C | | DB<br>DB | 000H, 018H, 000H, 000H, 008H, 000<br>005H, 000H | |------------------------------|----------------------------------|----------------|----------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 0B0E<br>0B14 | 00 00<br>07 0F | 00<br>FF | 00 | 00 | 10 | 2145 C<br>2146 C<br>2147 C | | DB<br>DB | 000H,000H,000H,000H,000H,010<br>007H,00FH,0FFH | | 0B17 | 50 18 | 0E | | | | 2147 C<br>2148 C<br>2149 C | ;-10 | DB | 80D,24D,14D | | OB1A<br>OB1C | 8000<br>05 OF | 00 | 00 | | | 2149 C<br>2150 C<br>2151 C<br>2152 C | | DW<br>DB | 08000H<br>005H,00FH,000H,000H | | 0B20 | A7 | ••• | •• | | | 2153 C<br>2154 C | | DB | 0А7Н | | 0821 | 5B 4F | 53 | 17 | 50 | ВА | 2155 C<br>2156 C<br>2157 C | | DB | 05BH, 04FH, 053H, 017H, 050H, 0BA | | 0B27<br>0B2D<br>0B33<br>0B39 | 6C 1F<br>00 00<br>5D 14<br>FF | 00 | 00<br>00<br>5F | 00<br>5E<br>0A | 00<br>2B<br>8B | 2157 C<br>2158 C<br>2159 C<br>2160 C | | DB<br>DB<br>DB<br>DB | 05BH, 04FH, 053H, 017H, 050H, 08A<br>06CH, 01FH, 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H, 05EH, 02I<br>05DH, 014H, 00FH, 05FH, 00AH, 08I<br>0FFH | | 0B3A<br>0B40<br>0B46<br>0B4C | 00 01<br>00 00<br>04 07<br>05 00 | 00 | 00<br>01<br>00 | 04<br>00<br>01 | 07<br>00<br>00 | 2153 C C 2154 C C 2155 C C 2156 C C 2157 C C 2158 C C 2159 C C 2161 C C 2161 C C 2162 C C 2163 C C 2166 C C 2166 C C 2166 C C 2166 C C 2166 C C 2167 C C 2167 C C 2168 C C 2167 C C 2168 C C 2170 C C 2171 C C 2171 C C | | DB<br>DB<br>DB<br>DB | 000H,001H,000H,000H,004H,000<br>000H,000H,000H,001H,000H,000<br>004H,007H,000H,000H,001H,000<br>005H,000H | | 0B4E<br>0B54 | 00 00<br>07 0F | 00<br>FF | 00 | 00 | 10 | 2166 C<br>2167 C<br>2168 C | | DB<br>DB | 000H,000H,000H,000H,000H,010 | | = 044 | | | | | | 2169 C<br>2170 C | BASE 2 | EQU | \$ - VIDEO_PARMS | | | | | | | | 2172 C | ; | | MODE VALUES | | 0B57 | 50 18 | 0E | | | | 2173 C<br>2174 C | ;F | DB | 80D 24D 14D | | 0 <b>B</b> 5A | 8000 | | | | | 2175 C<br>2176 C<br>2177 C | | DW | 80D,24D,14D<br>08000Н | | 0B5C | | 00 | 06 | | | 2178 C<br>2179 C | | DB | 001H,00FH,000H,006H | | 0B60<br>0B61 | A2<br>60 4F | 5.6 | 3.6 | 50 | 60 | 2180 C<br>2181 C<br>2182 C | | DB<br>DB | 0A2H<br>060H.04FH.056H.03AH.050H.060 | | 0B67<br>0B6D | 70 1F | 00 | 3A<br>00<br>00 | 5E | 00<br>2E | 2181 C<br>2182 C<br>2183 C<br>2184 C | | DB<br>DB | 060H, 04FH, 056H, 03AH, 050H, 060<br>070H, 01FH, 000H, 000H, 000H, 000<br>000H, 000H, 000H, 000H, 05EH, 028<br>05DH, 028H, 00DH, 05EH, 06EH, 0ES | | 0B73<br>0B79 | 5D 28 | őĎ | 5Ĕ | 6E | E3 | 2185 C | | DB<br>DB | 05DH,028H,00DH,05EH,06EH,0E | | 0B7A<br>0B80 | 00 00 | 00 | 00 | 18 | 18<br>00 | 2187 C<br>2188 C<br>2189 C | | DB<br>DB | 000H,008H,000H,000H,018H,018<br>000H,000H,000H,008H,000H,000<br>000H,018H,000H,000H,008H,000 | | 0886<br>088C | 00 00<br>00 18<br>05 00 | 00 | 00 | 00<br>0B | 00 | 2189 C<br>2190 C<br>2191 C | | DB<br>DB | 000H,000H,000H,008H,000H,000<br>000H,018H,000H,000H,00BH,000 | | 0B8E | 00 00 | 00 | 00 | 00 | 00 | 2192 C<br>2193 C | | DB | 000H,000H,000H,000H,000H,000<br>005H,00FH,0FFH | | 0B94 | 05 OF | FF | | | | | 10 | DB | 005H,00FH,0FFH | | 0B97<br>0B9A | 50 18<br>8000 | 0E | | | | 2195 C<br>2196 C<br>2197 C<br>2198 C<br>2199 C<br>2200 C<br>2201 C<br>2202 C<br>2203 C<br>2204 C<br>2205 C | ;-10 | DB<br>DW | 80D,24D,14D<br>08000H | | OB9C | 01 OF | . 00 | 06 | | | 2199 C<br>2199 C<br>2200 C | | DB | 001H,00FH,000H,006H | | 0BA0 | A7 | | | | | 2201 C<br>2202 C | | DB | 0А7Н | | OBA1 | 58 4F<br>60 1F | 53 | 37 | 52 | 00 | 2203 C<br>2204 C | | DB | 05BH,04FH,053H,037H,052H,000<br>06CH,01FH,000H,000H,000H,000 | | OBA7<br>OBAD<br>OBB3 | 00 00 | 00 | 00<br>00<br>5F | 00<br>5E<br>0A | 00<br>2B<br>E3 | 2205 C<br>2206 C | | DB<br>DB | 06CH,01FH,000H,000H,000H,000<br>000H,000H,000H,000 | | 0BB3 | 5D 28<br>FF | UF | 16 | UA | E.3 | 2207 C<br>2208 C<br>2209 C | | DB<br>DB | 05DH,028H,00FH,05FH,00AH,0E | | OBBA<br>OBCO<br>OBC6<br>OBCC | 00 01<br>14 07<br>3C 3D<br>0F 00 | 02<br>38<br>3E | 03<br>39<br>3F | 04<br>3A<br>01 | 05<br>3B<br>00 | 2210 C<br>2211 C<br>2212 C<br>2213 C | | DB<br>DB<br>DB<br>DB | 000H,001H,002H,003H,004H,00<br>014H,007H,038H,039H,03AH,03<br>03CH,03DH,03EH,03FH,001H,00<br>00FH,000H | | OBCE<br>OBD4 | 00 00<br>05 0F | 00<br>FF | 00 | 00 | 00 | 2214 C<br>2215 C<br>2216 C<br>2217 C | | DB<br>DB | 000H,000H,000H,000H,000H,000<br>005H,00FH,0FFH | | = 040 | 0 | | | | | 2218 C<br>2219 C | BASE_3 | EQU | \$ - VIDEO_PARMS | | | | | | | | 2220 C<br>2221 C | ; | | LTERNATE VALUES | | OBD7 | 28 18 | 0E | | | | 2222 C<br>2223 C<br>2224 C | ;0 | DB | 100 210 110 | | OBDA | 0800 | UŁ | | | | 2224 C<br>2225 C<br>2226 C | | DM | 40D,24D,14D<br>00800H | | OBDC | OB 03 | 00 | 03 | | | 2227 C<br>2228 C | | DB | 00ВН,003Н,000Н,003Н | | OBEO | A7 | | 0.0 | | ۲۵ | 2229 C<br>2230 C | | DB | 0A7H | | OBE1<br>OBE7<br>OBED | 2D 27<br>6C 1F<br>00 00 | 2B<br>00 | 2D<br>0D<br>00 | 28<br>06<br>5E | 6D<br>07<br>2B | 2231 C<br>2232 C<br>2233 C | | DB<br>DB<br>DB | 02DH, 027H, 02BH, 02DH, 028H, 06D<br>06CH, 01FH, 000H, 00DH, 006H, 007 | | OBED<br>OBF3<br>OBF9 | 50 00<br>FF | 0F | 5E | 0A | A3 | 2233 C<br>2234 C<br>2235 C | | DB<br>DB<br>DB | 06CH, 01FH, 000H, 00DH, 006H, 00<br>000H, 000H, 000H, 000H, 05EH, 02E<br>05DH, 014H, 00FH, 05EH, 00AH, 0AS<br>0FFH | | OBFA | 00 01 | 02 | 03 | 04 | 05 | 2236 C<br>2237 C | | DB | | | 0C00 | 00 01<br>14 07<br>3C 3D | 38<br>3E | 39<br>3F | 04<br>3A<br>08 | 3B<br>00 | 2238 C<br>2239 C | | DB<br>DB | 000H,001H,002H,003H,004H,005<br>014H,007H,038H,039H,03AH,03B<br>03CH,03DH,03EH,03FH,008H,000 | | OCOE | 0F 00 | | 00 | 00 | 10 | 2224 C 2225 C 2226 C 2226 C 2227 C 2228 C 2230 C 2231 C 2231 C 2233 2234 2244 C 2244 C | | DB<br>DB | 00гн,000н | | 0014 | 0E 00 | FF | 50 | 00 | .0 | 2242 C<br>2243 C<br>2244 C | | DB | 000H,000H,000H,000H,000H,010<br>00EH,000H,0FFH | | 0C17<br>0C1A | 28 18 | 0E | | | | 2245 C<br>2246 C<br>2247 C<br>2248 C | ;1 | DB | 40D,24D,14D<br>00800H | | | 0800 | | ٠- | | | 2247 C<br>2248 C | | DW | | | 0010 | OB 03 | 00 | 03 | | | 2249 C<br>2250 C | | DB<br>DB | 00BH,003H,000H,003H | | 0020 | A/<br>2D 27 | 20 | 20 | 28 | 6D | 2251 C<br>2252 C<br>2253 C | | DB<br>DB | 020H 027H 028H 020H 028H 060 | | 0C21<br>0C27<br>0C2D | 2D 27<br>6C 1F<br>00 00 | 00 | 2D<br>0D<br>00 | 06<br>5F | 07<br>2B | 2254 C | | DB<br>DB | 02DH, 027H, 02BH, 02DH, 028H, 06<br>06CH, 01FH, 000H, 00DH, 006H, 00<br>000H, 000H, 000H, 000H, 05EH, 02<br>05DH, 014H, 00FH, 05EH, 00AH, 0A | | 0C33<br>0C39 | 5D 14 | ÖF | 5E | ÓĀ | A3 | 2254 C<br>2255 C<br>2256 C<br>2257 C<br>2258 C | | DB<br>DB | 05DH, 014H, 00FH, 05EH, 00AH, 0A | | OC3A | 00 01 | 02 | 03 | 04 | 05 | 2258 C<br>2259 C | | DB | ***** | | 0C40<br>0C46 | 14 07<br>3C 3D | 38<br>3E | 03<br>39<br>3F | 3A<br>08 | 3B<br>00 | 2260 C<br>2261 C | | DB<br>DB | 000H,001H,002H,003H,004H,003<br>014H,007H,038H,039H,03AH,031<br>03CH,03DH,03EH,03FH,008H,000 | | OC4C<br>OC4E | | | | DO. | 10 | 2259 C<br>2260 C<br>2261 C<br>2262 C<br>2263 C<br>2264 C<br>2265 C | | DB<br>DB | 00FH,000H | | 0C54 | 00 00<br>0E 00 | FF | 50 | 00 | 10 | 2265 C<br>2266 C | | DB | 000H,000H,000H,000H,000H,010<br>00EH,000H,0FFH | | 0057 | 50 18 | 0E | | | | 2267 C<br>2268 C | ;2 | DB | 80D, 24D, 14D | | | | | | | | | | | | ``` 0C5A 1000 DW 01000H 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2283 2284 2285 2286 2287 2288 2288 2288 0C5C 01 03 00 03 DB 001Н,003Н,000Н,003Н DB 0C61 0C67 0C6D 0C73 0C79 5B 4F 53 37 51 5B 6C 1F 00 0D 06 07 00 00 00 00 5E 2B 5D 28 0F 5E 0A A3 FF 05BH, 04FH, 053H, 037H, 051H, 05BH 06CH, 01FH, 000H, 000H, 006H, 007H 000H, 000H, 000H, 006H, 05EH, 02BH 05DH, 028H, 00FH, 05EH, 00AH, 0A3H 0FFH DB DB DB DB DB 000H,001H,002H,003H,004H,005H 014H,007H,038H,039H,03AH,03BH 03CH,03DH,03EH,03FH,008H,000H 00FH,000H 00 01 02 03 04 05 14 07 38 39 3A 3B 3C 3D 3E 3F 08 00 0F 00 00 00 00 00 00 10 0E 00 FF 000H,000H,000H,000H,000H,010H ;--3-- 0C97 50 18 0E 0C9A 1000 80D,24D,14D 01000H 0C9C 01 03 00 03 DB 001H,003H,000H,003H OCAO DB 5B 4F 53 37 51 5B 6C 1F 00 0D 06 07 00 00 00 00 5E 2B 5D 28 0F 5E 0A A3 FF OCBA OCCO OCC6 OCCC 00 01 02 03 04 05 14 07 38 39 3A 3B 3C 3D 3E 3F 08 00 0F 00 000H,001H,002H,003H,004H,005H 014H,007H,038H,039H,03AH,03BH 03CH,03DH,03EH,03FH,008H,000H 00FH,000H 00 00 00 00 00 10 0E 00 FF 000H,000H,000H,000H,000H,010H SUBTTL ;---- VECTOR INTO <AH> SPECIFIED FUNCTION OCD7 OCD8 OCD9 OCDA OCDB OCDC OCDD OCDE OCDF OCDF STI CLD PUSH PUSH PUSH PUSH PUSH PUSH PUSH 50 8A C4 32 E4 D1 E0 8B F0 3D 0028 72 06 58 CD 42 E9 219E R PUSH MOV XOR SAL MOV CMP JB POP AX AL, AH AH, AH AX, 1 SI, AX AX, T2L M2 AX 42H V_RET SAVE AX VALUE GET INTO LOW BYTE ZERO TO HIGH BYTE * 2 FOR TABLE LOOKUP PUT INTO SI FOR BRANCH TEST FOR WITHIN RANGE BRANCH AROUND BRANCH RECOVER REGISTER PASS UNRECOGNIZED CALL RETURN TO CALLER OCE1 OCE2 OCE4 OCE6 OCE8 OCEA OCED OCEF OCF0 OCF2 OCF5 2333345 2233378 2233378 2233378 2233378 2233344 2233444 2233444 223344 223344 223344 223344 22334 22334 22334 22334 22335 22335 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 2236 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 22336 INT ASSUME CALL POP JMP DS: ABSO E8 OCFE R DDS ; RECOVER ; JMP TO AH=0 THRU AH=XX 58 2E: FF A4 06EF R WORD PTR CS:[SI + OFFSET T2] ;---- UTILITY ROUTINES ;---- SET DS TO THE DATA SEGMENT PROC PUSH SUB MOV POP RET ENDP NEAR AX AX,AX DS,AX AX OCFE OCFE OCFF ODO1 ODO3 ODO4 ODO5 DDS 50 2B C0 8E D8 58 C3 ; SAVE REGISTER : RESTORE REGISTER DDS PROC NEAR DS:ABSO DS DDS DX,ADDR_6845 DL,OFOH DL,OAH DS 0D05 WHAT_BASE ASSUME PUSH CALL MOV AND OR POP RET 0D05 0D06 0D09 0D0D 0D10 0D13 0D14 0D15 ; SAVE DATA SEGMENT ; GET LOW MEMORY SEGMENT ; GET CRTC ADDRESS ; STRIP OFF LOW NIBBLE ; SET TO STATUS REGISTER 1E E8 OCFE R 8B 16 0463 R 80 E2 F0 80 CA OA 1F C3 ENDP WHAT_BASE NEAR AL, AH DX, AL DX AL, AH DX, AL AH=INDEX, AL=DATA, DX=PORT GET INDEX VALUE SET INDEX REG SET DX TO DATA REG GET DATA VALUE SET DATA REG SET DX BACK TO INDEX XCHG OUT 42 86 C4 EE 4A C3 INC XCHG OUT DEC OUT_DX ENDP ;---- ROUTINE TO SOUND BEEPER PROC OUT RET BP_1 BP_1 ENDP NEAR DX DX, TIMER+3 AL, 10110110B BP_1 AX,533H DX BP_1 AL,AH BP_1 DX, PORT_B 0D20 BEEP PROC PUSH MOV MOV CALL MOV DEC CALL MOV CALL MOV 52 BA 0043 BO B6 E8 0D1E R B8 0533 4A E8 0D1E R BA C4 E8 0D1E R BA 0061 0D20 0D21 0D24 0D26 0D29 0D2C 0D2D ; SEL TIM 2, LSB, MSB, BINARY ; WRITE THE TIMER MODE REG ; DIVISOR FOR 1000 HZ ; WRITE TIMER 2 CNT - LSB ; WRITE TIMER 2 CNT - MSB ``` ``` IN MOV OR CALL SUB AL,DX AH,AL AL,03 BP_1 CX,CX ; GET SETTING OF PORT ; SAVE THAT SETTING ; TURN SPEAKER ON 0D38 0D39 0D3B 0D3D 0D40 0D42 0D42 0D44 0D46 0D48 0D4A 0D4D : SET CNT TO WAIT 500 MS E2 FE FE CB 75 FA 8A C4 E8 OD1E R 5A C3 G7 · G7 BL G7 AL, AH BP_1 DX ; DELAY BEFORE TURNING OFF ; DELAY CNT EXPIRED? ; NO-CONTINUE BEEPING SPK ; RECOVER VALUE OF PORT LOOF DEC JNZ MOV CALL POP RET ENDP 2403 2403 2404 2405 2406 2407 2408 2410 2411 ; RETURN TO CALLER ;---- FIND THE PARAMETER TABLE VECTOR IN THE SAVE TABLE PROC NEAR DS:ABSO DDS BX,SAVE_PTR BX,DWORD PTR ES:[BX] ODAE ASSUME CALL LES LES RET E8 OCFE R C4 1E O4A8 R 26: C4 1F C3 0D4F 0D52 0D56 0D59 0D5A ;---- ESTABLISH ADDRESSING TO THE CORRECT MODE TABLE ENTRY PROC OD5A SE ASSUME PUSH PUSH CALL DS: ABSO CX DX 51 52 E8 0D4F R 8A 26 0449 R F6 06 0487 R 60 74 18 0D5A 0D5B 0D5C 0D5F 0D63 DX SET_BASE AH,CRT_MODE INFO,OGOH B_M_1 ; GET PARM TBL PTR MOV TEST ; TEST FOR BASE CARD ;---- WE HAVE A MEMORY EXPANSION OPTION HERE AH,0FH B_M_2 BX,BASE_2 - BASE_1 B_M_OUT 80 FC OF 75 07 81 C3 0440 EB 33 90 CMP 0D6A 0D6F 0D73 0D76 0D76 0D79 0D7B 0D7F 0D82 0D82 JNE ADD JMP 80 FC 10 75 07 81 C3 0480 EB 27 90 AH,010H B_M_1 BX,BASE_2 + M_TBL_LEN - BASE_1 B_M_OUT СМР JNE ADD JMP 2441 2442 2444 2444 2446 2446 2447 2448 2449 2450 2451 80 FC 03 CMP AH,03H B_M_3 ; SKIP ENHANCED PORTION ; ---- CHECK THE SWITCH SETTING FOR ENHANCEMENT A0 0488 R 24 0F 3C 03 74 07 3C 09 74 03 EB 05 90 MOV AND CMP JE CMP AL, INFO_3 AL, OFH AL, O3H BRS 0D87 0D8A 0D8C 0D8E 0D90 0D92 ; SECONDARY EMULATE SETTING BRS AL,09H BRS B_M_3 2452 2452 2453 2454 2455 2456 2457 JE JMP ;---- WE WILL PERFORM ENHANCEMENT 24459 224612 224612 224612 224612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 2246612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 224612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 244612 24 81 C3 04C0 BX,BASE_3 - BASE_1 ; VECTOR TO ENHANCEMENT TBL 8A 0E 0449 R 2A ED F3 05 MOV CL,CRT_MODE CH,CH B_M_4 JCXZ ;---- THIS LOOP WILL MOVE THE PTR TO THE INDIVIDUAL MODE ENTRY ODA3 ODA6 ODA8 ODA8 ODA8 ODA9 ODAA ODAB BX,M_TBL_LEN B M 5 ; LENGTH OF ONE MODE ENTRY ;---- PROGRAM THE EGA REGISTERS FROM THE PARAMETER TABLE PROC NEAR DS: ABSO, ES: NOTHING ODAR SET_REGS ASSUME ;---- PROGRAM THE SEQUENCER E8 0D5A R 83 C3 05 B6 03 B2 C4 B8 0001 FA E8 0D15 R 26: 8A 07 FE C4 E8 0D15 R ODAB ODAE ODB1 ODB3 CALL ADD MOV MOV CLI CALL MOV INC CALL MAKE_BASE BX,TFS_LEN DH,3 DL,SEQ_ADDR AX,0001H ; GET TABLE PTR : MODE TO SEQUENCER PARMS ODB5 ODB8 ODB9 OUT_DX AL,ES:[BX] ; GET SEQUENCER VALUE ; NEXT INDEX : SET IT ODBC AH OUT_DX 0DBF 0DC1 0DC4 0DC4 0DC6 0DC7 0DCA 0DCD D1: FE C4 43 26: 8A 07 E8 0D15 R 80 FC 05 72 F2 INC INC MOV CALL CMP ; NEXT INDEX REGISTER ; NEXT TABLE ENTRY BX AL,ES:[BX] OUT_DX AH,M1+1 D1 JΒ 0DD2 0DD5 0DD6 0DD8 0DD9 0DDB 26: 8A 07 43 B2 C2 EE B2 C4 B8 0003 E8 0D15 R MOV INC MOV OUT MOV MOV CALL STI AL,ES:[BX] BX DL,MISC_OUTPUT DX,AL DL,SEQ_ADDR AX,0003H OUT_DX ;---- PROGRAM THE CRT CONTROLLER ODE2 ODE6 ODE8 ODE8 ODEB ODEE 8B 16 0463 R 2A E4 DX,ADDR_6845 AH,AH ; CRTC INDEX REGISTER : COUNTER MOV CALL INC INC CMP ; GET VALUE FROM TABLE ; SET CRTC REGISTER ; NEXT TABLE ENTRY ; NEXT INDEX VALUE ; TEST REGISTER COUNT 26: 8A 07 E8 0D15 R 43 FE C4 80 FC 19 AL,ES:[BX] OUT_DX ``` ``` 72 F2 26: 8B 47 F1 86 E0 A3 0460 R JB MOV XCHG MOV X1 AX,ES:[BX][-OFH] AH,AL CURSOR_MODE,AX ; DO THE REST ; GET CURSOR MODE 122445628901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345678901121345 ; SET LOW RAM VALUE ;---- PROGRAM THE ATTRIBUTE CHIP 8B F3 E8 0D05 R EC B2 C0 2A E4 MOV SI,BX WHAT_BASE AL,DX DL,ATTR_WRITE AH,AH 0DFF 0E01 0E04 0E05 0E07 0E09 0E0C 0E0E 0E0F 0E11 0E12 0E13 0E15 IN MOV SUB : INDEX COUNTER ñã. AL, ES: [BX] AH, AL DX, AE AH, AL DX, AE BX AH AH, M5 D3 26: 8A 07 86 E0 EE 86 E0 EE 43 FE C4 80 FC 14 72 EF MOV XCHG OUT : GET DATA VALUE OUT XCHG OUT INC INC CMP JB ; NEXT DATA VALUE ; NEXT INDEX VALUE ; TEST REGISTER COUNT ; DO THE REST 0E1A B0 00 :---- CHECK IF PALETTE REGISTER VALUES ARE TO BE SAVED 1E 06 04 3E 04A8 R 26: C4 7D 04 8C C0 0B C7 74 09 PUSH PUSH LES LES MOV OR JZ DS ES DI, SAVE_PTR DI, DWORD PTR ES:[DI][4] AX, ES AX, DI SAVE_OUT 0E1D 0E1E 0E1F 0E23 0E27 0E29 ; IF ZERO, NO SAVE OCCURS :---- STORE AWAY THE PALETTE VALUES IN RAM SAVE AREA 1F 1E B9 0010 F3/ A4 46 A4 POP PUSH MOV MOVSB INC MOVSB DS CX, 16D ; SAVE THE PALETTE REGS SAVE_OUT: SI . SAVE THE OVERSCAN REG :---- PROGRAM THE GRAPHICS CHIPS DL, GRAPH_1_POS AL, O DX, AL DL, GRAPH_2_POS AL, 1 DX, AL DL, GRAPH_ADDR AH, AH B2 CA B0 01 B2 CA B0 01 EE B2 CE B2 CE MOV OUT MOV OUT MOV SUB 26: 8A 07 E8 0D15 R 43 FE C4 80 FC 09 72 F2 C3 MOV CALL INC INC CMP JB RET AL,ES:[BX] ; PARAMETER BYTE ; SET IT ; NEXT BYTE ; NEXT REGISTER BX AH AH, M6 D4 ; CONTINUE SET_REGS ENDP ;---- MODE SET REGEN CLEAR ROUTINE PROC... ASSUME MOV... TEST JNZ MOV CMP JBE MOV CMP JE MOV MOV NEAR DS: ABSO, ES: NOTHING AL, INFO AL, OBOH OUT 1 DX, OBBOH AL, CRT_MODE AL, CB, OBOOH OCCORD OF CB, OBOOH OCCORD 0F55 ; FILL REGEN WITH BLANKS A0 0487 R A8 80 75 39 BA B800 A0 0449 R 3C 06 76 0A BA B000 3C 07 74 03 BA A000 ; SEE IF BLANK IS TO OCCUR ; MODE SET HIGH BIT ; SKIP BLANK FOR REGEN ; COLOR MODE REGEN ADDRESS ; CURRENT MODE SET ; 0-6 ARE COLOR MODES 0E55 0E58 0E5C 0E5F 0E64 0E66 0E69 0E70 0E73 0E75 0E77 0E77 0E78 CGO: BB 0720 3C 04 72 06 3C 07 74 02 2B DB MOV CMP JB CMP JE SUB BX,0720H AL,4 WW1. AL,7 WW1 BX,BX ; GRAPHICS BLANK VALUE SRLOAD MOV MOV JCXZ MOV CMP JE. MOV ES ES, DX CX, CRT_LEN OUT_1 CX, D8000H DH, OAOH N_BA CH, O40H ; SET THE REGEN SEGMENT 8E C2 8B 0E 044C R E3 10 B9 8000 80 FE A0 74 02 B5 40 0E7D 0E7F 0E83 0E85 0E88 0E8B 0E8F 0E8F 0E8F 0E95 0E95 N_BA: MOV SUB REP ôUT_1: ; RETURN TO CALLER BLANK PROC CALL RET NEAR PAL_ON E8 1DB7 R ;---- SEE IF WE ARE TO SUPPORT 640 X 350 ON A 640 X 200 MODE PROC NEÁR DS:ABSO AX DS DDS AL,INFO_3 DS AL,OFH AL,O3H B_YES AL,O9H B_YES DEGA ASSUME PUSH PUSH CALL MOV POP AND CMP JE CMP JE ; EMULATE MODE ``` ``` OEAD OEAE OEAF OEBO OEBO OEB1 OEB2 OEB3 OEB3 ASSUME DS: ÁBSO CLI MOY WORD PTR MOY WORD PTR STI AND INFO,111 FA 06 010C R 0000 E 8C 0E 010E R FB 80 26 0487 R F3 WORD PTR GRX_SET, OFFSET CGDDOT WORD PTR GRX_SET+2, CS ; TURN OFF RETRACE BIT ; EGA ACTIVE BIT ; SAVE PUSH TEST JZ MOV AND CMP JE 0EC4 0EC5 0ECA 0ECC 0ECF 0ED1 50 F6 06 0487 R 02 74 2C A1 0410 R 24 30 3C 30 74 48 AX INFO,2 ST_1 AX,EQUIP_FLAG AL,030H ST_2 THERE IS NO MONOCHROME THERE IS A MONOCHROME CHECK THE EQUIPMENT FLAG FOR MONOCHROME CALL IT IS A MONOCHROME CALL ;---- FALL THROUGH => REGULAR COLOR CARD SETUP OED5 C6 06 0484 OEDA C7 06 0485 OEE0 58 OEE1 80 C0 0487 OEE6 3C 01 OEEA 76 09 OEEA 3C 04 OEEC 73 05 OEEE 80 0E 0487 OEEF3 CD 42 OEF5 E9 219E R ROWS, 024D POINTS, 8 AX INFO, 00001000B AL, 1 ST_7 AL, 4 ST_7 INFO, 00000100B C6 06 0484 R 18 C7 06 0485 R 0008 58 0 0E 0487 R 08 3C 01 76 09 3C 04 73 05 80 0E 0487 R 04 MOV MOV POP OR CMP JBE CMP JAE OR ; RECOVER ; EGA NOT ACTIVE ; OTHER ADAPTER MODE CALL BACK TO CALLER POINT THERE IS NO MONOCHROME ATTACHED TO THE ADAPTER ;---- FALL THROUGH => REGULAR MONOCHROME CARD SETUP 0F01 C6 06 0484 R 18 0F06 C7 06 0485 R 000E 0F00 CD 42 0F0F C7 06 0460 R 0B0C 0F15 80 0E 0487 R 08 0F1A E9 219E R ROWS,024D POINTS,014D AX 42H CURSOR_MODE,0BOCH INFO,8 V_RET MOV POP INT MOV OR JMP ; RECOVER ; OTHER ADAPTER MODE CALL ; FIX PLANAR VALUE ; THE EGA IS NOT ACTIVE ; BACK TO CALLER ;---- MONOCHROME SETUP TO THE ADAPTER 58 50 86 03 24 80 80 26 0487 R 7F 08 06 0487 R 58 7F 30 0F 74 02 80 07 AX AX DH, 3 AL, 080H INFO, 07FH INFO, AL AX AL, 07FH AL, 0FH ST_2A AL, 7 0F1D 0F1E 0F1F 0F21 0F23 0F28 0F2C 0F2D 0F31 0F33 0F35 0F35 0F38 0F38 POP PUSH MOV AND AND OR POP AND CMP JE MOV 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 PICK OFF THE CLEAR BIT MASK OFF THE OTHER BITS SAVE REGEN CLEAR BIT RECOVER TRUE CALL VALUE ALREADY DEALT WITH D7 A MONOCHROME MODE DO THIS MODE REGULAR MONOCHROME 2719 2720 2721 2722 2723 2724 A2 0449 R B2 B4 89 16 0463 R EB 1C 90 CRT_MODE,AL DL,CRTC_ADDR_B ADDR_6845,DX QQ1 ; SAVE MODE VALUE ; IT IS 3-B-X ; SAVE CRTC ADDRESS ; CONTINUE THE MODE SET 27256 272672 272672 27272 27272 27273 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 27373 2737 ;---- COLOR SETUP TO THE ADAPTER 58 50 86 03 24 80 80 26 0487 R 7F 08 06 9487 R 58 7F A2 0449 R B2 D4 89 16 0463 R AX AX DH, 3 AL, 080H INFO, 07FH INFO, AL AX AL, 07FH GRT_MODE, AL DL, CRTC_ADDR ADDR_68#5, DX ; RECOVER PARAMETER VALUE : SAVE IT POP PUSH MOV AND AND OR POP AND MOV MOV MOV ) ISOLATE REGEN CLEAR BIT PREPARE INFO BYTE SET IT, OR NOT RECOVER TRUE MODE CALL DONE WITH D'T SAVE THIS MODE 3-D-X SAVE CRIC ADDRESS CRT_START,0 ACTIVE_PAGE,0 ES:NOTHING CX,8 DI,OFFSET CURSOR_POSN MOV MOV ASSUME MOV MOV C7 06 044E R 0000 C6 06 0462 R 00 ; 8 PAGES OF CURSOR VALUES ; OFFSET : ESTABLISH : ADDRESSING : O THOSE CURSOR LOCATIONS ; CLEAR OUT SAVED VALUES 0F67 B9 0008 0F6A BF 0450 R 0F6D 1E 0F6E 07 0F6F 2B C0 0F71 F3/ AB PUSH POP SUB 0F73 E8 0D5A R CALL 0F76 26: 8A 07 0F79 2A E4 0F7B A3 044A R AL,ES:[BX] AH,AH CRT_COLS,AX ; GET COLUMN COUNT ; ZERO HIGH BYTE ; STORE COLUMN VALUE MOV MOV 0F85 26: 8A 47 02 0F89 2A E4 0F8B A3 0485 R AL,ES:[BX][2] AH,AH POINTS,AX ; GET THE BYTES/CHAR ; ZERO HIGH BYTE ; STORE BYTES/CHAR MOV SUB MOV BX, BX AL, 1 AH, CRT_MODE AH, 7 2B DB BO 01 8A 26 0449 R 80 FC 07 74 OC ``` ``` 0FA2 80 FC 03 0FA5 77 35 AH,03H ENTRY 1 OFA7 E8 OE9A R OFAA 72 O2 CALL B0 02 MOV AL.2 ; COLOR ALPHA CHAR GEN ENTRY 2: E8 1EAE R E8 0CFE R 8A 26 0449 R 80 FC 07 74 03 EB 1D 90 CALL ; LOAD ALPHA CHAR GEN CH_GEN DDS AH, CRT_MODE AH, 7 FDG_IT ENTRY_1 ; GET CURRENT MODE ; IS IT MONOCHROME ; 9X14 FONT MOV CMP JE JMP FDG IT: BD 0000 E BB 0E00 MOV MOV BP,OFFSET CGMN_FDG BX,0E00H ; TABLE POINTER : 14 BYTES PER CHAR FDG: GET THE ROM SEGMENT PUSH CS ES DX, ES: [BP] DX, DX ENTRY_1 CX, 1 BP DO_MAP2 BP, 014D FDG GET THE ROM SEGMENT INTO ES GET THE CHAR HEX CODE ZERO = NO MORE CHARS NO MORE DO ONE CHAR AT A TIME MOVE TO FIRST CODE POINT STORE THE CODE POINT ADJUST BP TO NEXT CODE DO ANOTHER 07 26: 8B 56 00 0B D2 74 0C B9 0001 45 E8 1EF6 R 83 C5 0E EB EA POP MOV OR JZ MOV INC CALL ADD JMP ENTRY_1: E8 ODAB R E8 OE55 R E8 OE96 R CALL : CLEAR OUT THE BUFFER ASSUME CALL CMP DS:ABSO E8 OCFE R 80 3E 0449 R OF 72 06 C7 06 010C R 0000 E 0FE5 0FE8 0FE8 0FF5 0FF5 0FF5 0FF6 1003 1005 1009 1001 1015 1018 1018 1018 1018 1018 1019 1023 1023 1024 1028 1028 1029 DDS CRT_MODE,OFH JB MOV MS_T WORD PTR GRX_SET , OFFSET CGMN MS 1: 80 3E 0449 R 07 77 09 74 4B 80 3E 0449 R 03 76 44 CRT_MODE,7 SAVE_GRPH SAVE_ALPH CRT_MODE,3 SAVE_ALPH CMP SAVE_GRPH: LES LES MOV OR JZ MOV JBE C4 1E 04A8 R 83 C3 0C 26: C4 1F 8C C0 0B C3 74 32 BE 0007 BX, SAVE_PTR BX, OCH BX, DWORD PTR ES:[BX] AX, ES AX, BX J4J S1,07H : JMP AHO DONE SG_1; 26: 8A 00 3C FF 74 7A 3A 06 0449 R 74 03 AL,ES:[BX][SI] AL,OFFH AHO_DONE AL,CRT_MODE SG_2 MOV CMP JE CMP JE INC JMP 46 EB FO SI SG 1 SG 2: FA 26: 8A 07 AL, BYTE PTR ES:[BX] 26: 8A 07 FE C8 A2 0484 R 26: 8B 47 01 A3 0485 R 26: 8B 47 03 A3 010C R 26: 8B 47 05 A3 010E R FB AL, BYTE PTR ES: [BX] AL ROWS, AL AX, WORD PTR ES: [BX][1] POINTS AX AX, WORD PTR ES: [BX][3] WORD PTR GRX SET, AX AX, WORD PTR ES: [BX][5] WORD PTR GRX_SET + 2, AX DEC MOV MOV MOV MOV MOV STI .14.1: EB 50 JMP SHORT AHO DONE SAVE_ALPH: LES ADD LES C4 1E 04A8 R 83 C3 08 26: C4 1F 8C C0 0B C3 74 40 BE 000B BX, SAVE_PTR BX, SAVE_PIR BX, O8H BX, DWORD PTR ES: [BX] AX, ES AX, BX AHO_DONE SI, OBH MOV OR JZ MOV 26: 8A 00 3C FF 74 36 3A 06 0449 R 74 03 AL,ES:[BX][SI] AL,OFFH AHO_DONE AL,CRT_MODE SA_2 INC 46 EB F0 SI SA_1 26: 8A 47 01 26: 8B 4F 02 26: 8B 4F 02 26: 8B 57 04 26: 8B 57 04 26: 8B 6F 08 26: 8B 6F 08 26: 8B 6F 08 27 08 28 08 28 1110 29 10 29 10 29 26: 8A 47 0A 3C FF 74 05 FE C8 A2 0484 R AH, ES: [BX] [1] AL, ES: [BX] [2] CX, ES: [BX] [2] CX, ES: [BX] [4] EX: [2] EX MOV MOV MOV MOV MOV PUSH MOV INT POP 1083 1084 1086 1089 108B 108C 1090 1092 1094 1096 2877 2878 2879 2880 ROWS. AL ;---- AHO_DONE: CALL CMP 2881 2882 2883 2884 2885 ;---- SET THE LOW RAM VALUES FOR COMPATIBILITY (3D8 AND 3D9 SAVE BYTES) 1099 1099 109C 10A1 10A3 10A6 10A9 10AB 10AD 10B3 10B3 10BA 10BC E8 OCFE R 80 3E 0449 R 07 77 1E B8 10C8 R A0 0449 R 2A E4 03 D8 2E: 8A 07 A2 0465 R 80 30 80 3E 0449 R 06 75 02 80 3F DDS CRT MODE, 7 DNDGS BX, OFFSET COMPAT_MODE AH, AH BX, AX AL, CST; (BX) CRT MODE SET, AL AL OS3, (BX) CRT MODE, SET, AL AL OS3, (BX) CRT MODE, SET, AL AL OS3, (BX) CRT MODE, AL AL, OSH, AL 2886 2887 2888 2889 2890 2891 2892 JA MOV SUB ADD MOV MOV CMP DO_PAL: A2 0466 R MOV CRT_PALETTE, AL ``` ``` DNDCS: 10C1 10C1 8B 0E 0460 R 10C5 EB 28 90 CX,CURSOR_MODE 289001234567678899121234567679991212345676791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912145679121456791214567912 LABEL BYTE 02CH,028H,02DH,029H,02AH,02EH 01EH,029H COMPAT_MODE 2C 28 2D 29 2A 2E 1E 29 CALC_CURSOR ASSUME CMP JNE INC JMP PROC NEAR DS:ABSO CH,0 CC_1 10D0 80 FD 00 75 04 FE C1 EB 0A ; CHECK FOR FULL HEIGHT ; NORMAL CHECK ; ADJUST END VALUE 10D0 10D3 10D5 10D7 10D9 10D9 10DB 10DF 10E1 CL SHORT CALC_OUT CC_1: FE C1 3A OE 0485 R 72 02 2A C9 CL CL,BYTE PTR POINTS CALC_OUT CL,CL ; ADJUST FOR EGA REGISTERS ; WILL IT WRAP ; NO, ITS OK ; EGA METHOD FOR CURSOR END JB SUB CALC_OUT: 51 2A CD 80 F9 10 59 75 02 FE C1 ; SAVE CURSOR TYPE VALUE ; END - START ; LOW NIBBLE EQUAL ; RESTORE CX CL,CH CL,010H CX COMP_4 CL SUB CMP POP JNE INC ; ADD 1 FOR CORRECT CURSOR COMP_4: ; BACK TO CALLER SET_CTYPE SET CURSOR TYPE THIS ROUTINE SETS THE CURSOR VALUE INPUT (CX) HAS CURSOR VALUE CH-START LINE, CL-STOP LINE OUTPUT NONE CUT_OFF ASSUME DS:ABSO MOV AH,C_CRSR_START MOV CURSOR_MODE,CX TEST INFO,8 JNZ DO_SET ; CRTC REG FOR CURSOR SET ; SAVE IN DATA AREA ; EGA ACTIVE BIT ; 0=EGA, 1=OLD CARDS ;---- THIS SECTION WILL EMULATE CURSOR OFF ON THE EGA AL,CH AL,060H AL,020H AH1_A CX,01E00H SHORT DO_SET C5 60 20 05 1E00 26 ;---- THIS SECTION : ADJUST THE CURSOR AND TEST FOR ENHANCED OPERATION 1109 1109 110E 1110 1115 1117 INFO, 1 DO_SET CRT_MODE, 3 AH1_S BRST_DET AH1_S CH, CUT_OFF AH1_B CH, 5 ; CURSOR EMULATE BIT , 0=EMULATE, 1=VALUE AS-IS , POSSIBLE EMULATION , NO, SET THE CURSOR TYPE , SEE IF EMULATE MODE , NOT EMULATING , TEST START , SKIP ADJUST , ADJUST F6 06 0487 R 01 75 1F 80 3E 0449 R 03 77 15 E8 0E9A R 73 10 80 FD 04 76 03 80 C5 05 JNZ CMP JA CALL JNC CMP JBE ADD 80 F9 04 76 03 80 C1 05 CL,CUT_OFF AH1_S CL,5 ; TEST END : SKIP ADJUST JBE ADD AH1_S: E8 10D0 R CALL CALC_CURSOR ; ADJUST END REGISTER DO_SET: ;---- THIS ROUTINE OUTPUTS THE CX REGISTER TO THE CRTC REGS NAMED IN AH M16: 8B 16 0463 R 8A C5 E8 0D15 R FE C4 8A C1 E8 0D15 R ; ADDRESS REGISTER ; DATA ; OUTPUT THE VALUE ; NEXT REGISTER ; SECOND DATA VALUE ; OUTPUT THE VALUE ; ALL DONE DX, ADDR_6845 AL, CH OUT_DX AH AL, CL OUT_DX MOV CALL INC MOV CALL RET POSITION THIS SERVICE ROUTINE CALCULATES THE REGEN BUFFER ADDRESS OF A CHARACTER IN THE ALPHA MODE INPUT 1146 1147 1149 1148 114F 1151 1153 1155 1156 53 8B D8 8A C4 F6 26 32 FF 03 C3 D1 E0 5B C3 ; SAVE REGISTER ; ROWS TO AL ; DETERMINE BYTES TO ROW ; ZERO OUT ; ADD IN COLUMN VALUE ; * 2 FOR ATTRIBUTE BYTES ; RESTORE REGISTER POSITION SET_COPS SET CURSOR POSITION THIS ROUTINE SETS THE CURRENT CURSOR POSITION TO THE NEW X-Y VALUES PASSED INPUT DX - ROW, COLUMN OF NEW CURSOR BUT DI SIFLLY PAGE OF CURSOR OUTPUT DUBSOR IS SET AT CRTC IF DISPLAY PAGE IS CURRENT DISPLAY PAGE HZ: 1157 1157 E8 115D R ``` ``` 115A E9 219E R JMP 0.22(2.890) 0.33435(7.890) 1.2343(7.890) 0.22(2.890) 0.22(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0.23(2.890) 0 SET_CPOS: MOV XOR SAL MOV CMP JNZ MOV CALL 115D 115F 1161 1163 1165 1169 1160 116F 1171 CL, BH CH, CH CX, 1 S1, CX [S1+OFFSET CURSOR_POSN], DX ACTIVE_PAGE, BH M17 AX, DX M18 ; SET_CPOS_RETURN ; GET_ROW/COLUMN TO AX ; CURSOR_SET ; SET_CPOS_RETURN M17: SET CURSOR POSITION, AX HAS ROW/COLUMN FOR CURSOR EB 1146 R 8B C8 03 OE 044E R CX, AX CX, CRT_START D1 F9 B4 0E E8 1135 R C3 SAR MOV CALL RET ENDP INPUT BH - PAGE OF CURSOR OUTPUT CX - ROW, COLUMN OF THE CURRENT CURSOR POSITION CX - CURRENT CURSOR MODE 8A DF 32 FF D1 E3 0450 R 8B 97 0450 R 5F 5E 5B 58 58 1F 07 5D CF INFO,2 EGA_IS_COLOR AL,07H READ_LPEN OLD_LP -- EGA IS COLOR HERE (MONOC BIT 0) EGA_IS_COLOR: CMP JBE 42H DI SI SP,6 DS ES BP ; CALL EXISTING CODE LIGHT PEN ROUTINE TESTS THE LIGHT PEN SHITCH AND THE LIGHT PEN INTIGORE, IF BOTH ARE SET, THE LOCATION OF THE LIGHT PEN IS DETERMINED. OTHERWISE, A RETURN WITH NO INFORMATION IS MEDICAL ON EXIT (AH) = 0 IF NO LIGHT PEN INFORMATION IS AVAILABLE (AH) = 1 IF LIGHT PEN SHAULABLE (OH, DL) = POSITION (CH) = RASTER POSITION (OLD MODES) (CX) = RASTER POSITION (NEW MODES) (BX) = BEST GUESS AT PIXEL HORIZONTAL POSITION ASSUME GS:CODE.DS:ABSO ASSUME CS: CODE, DS: ABSO SUBTRACT TABLE LABEL BY COME, DS: ABSO 0044, 0054, 0074, 0074, 0074, 0054, 0054 DB 0044, 0054, 0044, 0044, 0044, 0044 DB 0044, 0054, 0064, 0044, 0044, 0044 DB 0044, 0054, 0064, 0044, 0044, 0044 DB 0074, 0044 06 06 07 07 05 05 04 05 00 00 00 00 00 05 06 04 04 04 04 06 06 04 07 04 07 04 ;---- WAIT FOR LIGHT PEN TO BE DEPRESSED 8B 16 0463 R 83 C2 06 EC A8 04 B4 00 74 03 E9 1291 R ;--- 11EC 11EC A8 02 ; TEST LIGHT PEN TRIGGER ``` | 11EE<br>11F0 | 75 03<br>E9 129B R | 3151 C<br>3152 C<br>3153 C<br>3154 C | JNZ<br>JMP | V7A<br>V7 | ; RETURN WITHOUT RESETTING<br>; TRIGGER<br>; EXIT LIGHT PEN ROUTINE | |------------------------------|--------------------------------------------|--------------------------------------------------------------------|--------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | 11F3 | | 3155 C<br>3156 C<br>3157 C | | ER HAS BEEN SET, READ THE VALUE IN | | | 11F3 | B4 10 | 3158 C | V7A: | AH,16 | ; LIGHT PEN REGISTERS | | | | 3159 C<br>3160 C<br>3161 C | ; INPUT | REGS POINTED TO BY AH, AND CONVERT | TO ROW COLUMN IN DX | | 11F5<br>11F9<br>11FB<br>11FC | 8B 16 0463 R<br>8A C4<br>EE<br>42 | 3162 C<br>3163 C<br>3164 C<br>3165 C | MOV<br>MOV<br>OUT<br>INC | DX, ADDR_6845<br>AL, AH<br>DX, AL<br>DX | ; ADDRESS REGISTER<br>; REGISTER TO READ<br>; SET IT UP<br>; DATA REGISTER | | 11FD<br>11FE | 50<br>EC | 3166 C<br>3167 C | PUSH | AX<br>AL. DX | ; GET THE VALUE<br>; SAVE IN CX | | 11FF<br>1201 | 8A E8<br>58 | | MOV<br>POP | CH, AL<br>AX | | | 1202<br>1203 | 4A<br>FE C4 | 3170 C | DEC | DX<br>AH | ; ADDRESS REGISTER | | 1205<br>1207 | 8A C4<br>EE | 3173 C | MOV<br>OUT | AL,AH<br>DX,AL | ; SECOND DATA REGISTER | | 1208<br>1209 | 42<br>EC | 3173 C<br>3174 C<br>3175 C | INC | DX<br>AL,DX | ; POINT TO DATA REGISTÉR<br>; GET THE 2ND DATA VALUE<br>; AX HAS INPUT VALUE | | 120A | 8A E5 | 3176 C<br>3177 C | MOV | AH, CH | AX HAS INPUT VALUE | | | | 3178 C<br>3179 C | ; AX HA | S THE VALUE READ IN FROM THE 6845 | | | 120C<br>1210<br>1212 | 8A 1E 0449 R<br>2A FF | 3178 C<br>3179 C<br>3180 C<br>3181 C<br>3182 C | MOV<br>SUB | BL, CRT_MODE | . MODE VALUE TO BY | | 1212 | 2F: BA QF 11C1 R | | MOV | 8H,8H<br>BL,CS:V1[BX]<br>AX,BX<br>BX,CRT_START<br>BX,1<br>AX,BX | ; MODË VALUË TO BX ; AMOUNT TO SUBTRACT ; TAKE IT AMAY ; SCREEN ADDRESS : DIVIDE BY 2 ; ADJUST TO ZERO START | | 1217<br>1219<br>121D | 2B C3<br>8B 1E 044E R | 3183 C<br>3184 C<br>3185 C | SUB<br>MOV<br>SHR | BX, CRT_START | SCREEN ADDRESS | | 121F | D1 EB<br>2B C3 | 3185 C<br>3186 C | SHR<br>SUB | BX, 1<br>AX, BX | ; DIVIDE BY 2<br>; ADJUST TO ZERO START | | 1221<br>1223 | 79 02<br>2B CO | 3187 C<br>3188 C | JNS<br>SUB | V2<br>AX, AX | ; IF POSITIVE, GET MODE<br>; <0 PLAYS AS 0 | | | | 3189 C<br>3190 C | | MINE MODE OF OPERATION | , | | 1225 | | 3190 C<br>3191 C<br>3192 C | V2: | | + DETERMINE MODE | | 1225<br>1225<br>1227<br>1220 | 81 03<br>80 %F 0///0 P 0// | 3192 C | MOV | CL,3 | ; DETERMINE_MODE<br>; SET *8 SHIFT COUNT<br>; GRAPHICS OR ALPHA | | 1220 | 80 3E 0449 R 04<br>72 4D | 3194 C<br>3195 C | CMP<br>JB | CRT_MODE,4 | ; GRAPHICS OR ALPHA<br>; ALPHA_PEN | | 122E<br>1233 | 80 3E 0449 R 07<br>74 46 | 3193 C<br>3194 C<br>3195 C<br>3196 C<br>3197 C<br>3198 C<br>3199 C | CMP<br>JE | CRT_MODE,7<br>V4 | ; ALPHA_PEN | | 1235 | 80 3E 0449 R 06 | 3198 C<br>3199 C | СМР | CRT_MODE, 06H | | | 123A<br>123C<br>123E | 80 3E 0449 R 06<br>77 28<br>75 02<br>D1 E8 | 3200 C | JA<br>JNE | V8<br>V8X | | | 123E | D1 E8 | 3200 C<br>3201 C<br>3202 C<br>3203 C | SHR | AX, 1 | | | | | 3204 C<br>3205 C<br>3206 C | ; DLD G | RAPHICS MODES | | | 1240<br>1240 | 82 28 | | V8X: | DI 14 | , plicinos con ocasillos | | 1242 | F6 F2 | 3207 C<br>3208 C<br>3209 C | DIV | DL, 40<br>DL | ; DIVISOR FOR GRAPHICS<br>; ROW(AL) AND COLUMN(AH) | | | | 3209 C<br>3210 C | | | ; ROW(AL) AND COLUMN(AH)<br>; AL RANGE 0-99;<br>; AH RANGE 0-39 | | | | 3210 C<br>3211 C<br>3212 C<br>3213 G | | MINE GRAPHIC ROW POSITION | | | 1244<br>1246 | 8A E8<br>02 ED | 3214 C | MOV<br>ADD | CH, AL<br>CH, CH | ; SAVE ROW VALUE IN CH<br>; *2 FOR EVEN/ODD FIELD<br>; COLUMN VALUE TO BX<br>; *8 FOR MEDIUM RES | | 1248 | 8A DC<br>2A FF | 3215 C | MOV<br>SUB | CH, CH<br>BL, AH<br>BH, BH | COLUMN VALUE TO BX | | 124A<br>124C | 80 3E 0449 R 06 | 3215 C<br>3216 C<br>3217 C<br>3218 C<br>3219 C | CMP<br>JNE | CRT_MODE,6 | MEDIUM OR HIGH RES | | 1251<br>1253<br>1255<br>1257 | 75 04<br>B1 04<br>D0 E4 | 3219 C | MOV | CL,4 | ; MEDIUM OR HIGH RES<br>; NOT_HIGH_RES<br>; SHIFT VALUE FOR HIGH RES | | 1257<br>1257 | | 3220 C<br>3221 C | V3: | AH, 1 | ; COLUMN VALUE *2 FOR HIGH RES<br>; NOT_HIGH_RES<br>; *16 FOR HIGH RES | | 1251 | D3 E3 | 3222 C<br>3223 C<br>3224 C | SHL | BX,CL | ; #16 FOR HIGH RES | | 1000 | A4 51: | 3225 C | | MINE ALPHA CHAR POSITION | | | 1259<br>125B<br>125D | 8A D4<br>8A F0 | 3227 C | MOV<br>MOV | DL,AH<br>DH,AL | ; COLUMN VALUE FOR RETURN<br>; ROW VALUE | | 125D<br>125F | DO EE<br>DO EE | 3229 C | SHR<br>SHR | DH, 1<br>DH, 1 | ; ROW VALUE<br>; DIVIDE BY 4<br>; FOR VALUE IN 0-24 RANGE<br>; LIGHT_PEN_RETURN_SET | | 125F<br>1261<br>1264 | EB 2C 90 | 3230 C<br>3231 C | JMP<br>V8: | V5 | ; LIGHT_PEN_RETURN_SET | | | | 3232 C<br>3233 C | : NEW G | RAPHICS MODES | | | 1264 | 99 | 3234 C<br>3235 C | CWD | | ; PREPARE TO DIVIDE | | 1265<br>1269<br>1268 | F7 36 044A R<br>8B DA<br>D3 E3 | 3236 C | DIV | CRT_COLS<br>BX, DX<br>BX, CL<br>CX, AX | ; PREPARE TO DIVIDE<br>; AX = ROW, DX = COLUMN<br>; SAVE REMAINDER<br>; PEL COLUMN<br>; PEL ROW | | 126B<br>126D | D3 E3<br>8B C8 | 3237 C<br>3238 C<br>3239 C | MOV<br>SAL<br>MOV | BX, CL | PEL COLUMN | | 126F<br>1270<br>1271 | 52<br>99 | 3240 C<br>3241 C | PUSH | DX, AA | SAVE FROM DIVIDE | | 1271 | F7 36 0485 R | 3242 C | DIV | POINTS | ; SAVE FROM DIVIDE<br>; PREPARE TO DIVIDE<br>; DIVIDE BY BYTES/CHAR | | 1275 | 5A<br>8A FO | 3244 C | POP<br>MOV | DX<br>DH, AL | RECOVER<br>CHARACTER ROW | | 1278 | EB 15 90 | 3246 C | JMP | V5 | | | | | 3247 C | | MODE ON LIGHT PEN | | | 127B<br>127B<br>127F | F5 36 044A R<br>8A F0 | 3248 C<br>3249 C<br>3250 C | V4: | BYTE PTR CRT_COLS | ; ALPHA_PEN<br>; ROW,COLUMN VALUE | | 127F<br>1281 | 8A Du | 3250 C<br>3251 C<br>3252 C | MOV<br>MOV | DH, AL<br>DL, AH | ; ROW, COLUMN VALUE<br>; ROWS TO DH<br>; COLS TO DL | | 1283<br>1285 | 8A DC<br>32 FF | 3253 C | MOV<br>XOR | DH, AL DL, AH BL, AH BH, BH | COLUMN VALUE | | 1287<br>1289 | D3 E3<br>F6 26 0485 R | 3254 C<br>3255 C<br>3256 C | SAL<br>MUL | BX,CL<br>BYTE PTR POINTS | , | | 128D | 8B C8 | 3257 C | MOV | CX,AX | . Figure and which can | | 128F<br>128F | B4 01 | 3258 C<br>3259 C | V5: | AH, 1 | ; LIGHT PEN_RETURN_SET<br>; INDICATE EVERTHING SET | | 1291<br>1291 | 52 | 3260 C<br>3261 C<br>3262 C | V6:<br>PUSH | Х | LIGHT PEN RETURN SAVE RETURN VALUE (IN CASE) GET BASE ADDRESS POINT TO RESET PARM | | 1292 | 8B 16 0463 R | 3262 C<br>3263 C | MOV | DX, ADDR_6845 | ; (IN CASE)<br>: GET BASE ADDRESS | | 1296<br>1299 | 8B 16 0463 R<br>83 C2 07<br>EE | 3264 C | ADD<br>OUT | DX, 7<br>DX, AL | POINT TO RESET PARM | | | 5A | 3263 C<br>3264 C<br>3265 C<br>3266 C<br>3267 C | POP | DX | ; ADDRESS, NOT DATA,<br>; IS IMPORTANT<br>; RECOVER VALUE | | 129A<br>129B<br>129B | 5F | 3268 C | V7: | | ; REGOVER VALUE<br>; RETURN_NO_RESET | | 1290 | S.C. | 3270 G | POP<br>POP | DI<br>SI | | | 129D<br>12A0<br>12A1 | 83 C4 06<br>1F | 3270 G<br>3271 G<br>3272 G<br>3273 G | ADD<br>POP | ŠP, Š<br>DS<br>ES | ; DISCARD SAVED BX,CX,DX | | 12A1<br>12A2 | 07<br>50<br>CF | 3274 C | POP<br>POP | ES<br>BP | | | 12A2<br>12A3<br>12A4 | CF | 3274 C<br>3275 C<br>3276 C | READ_LPEN | ENDP | | | | | | | | | ``` ACT_DISP_PAGE SELECT ACTIVE DISPLAY PAGE THIS ROUTINE SETS THE ACTIVE DISPLAY PAGE, ALLOHING FOR MULTIPLE PAGES OF DISPLAYED VIDEO. INPUT AL HAS THE NEW ACTIVE DISPLAY PAGE OUTPUT THE CRTC IS RESET TO DISPLAY THAT PAGE ; SAVE ACTIVE PAGE VALUE GET SAVED LENGTH OF REGN BUFFER CONVERT AL TO WORD SAVE PAGE VALUE DISPLAY PAGE TIMES REGN LENGTH SAVE START ADDRESS FOR LATER REQUIREMENT; SATAT ADDRESS TO CX ACTIVE_PAGE,AL CX,CRT_LEN A2 0462 R 8B 0E 044C R CBW PUSH 12AF A3 044F R MOV CRT_START,AX 12B2 12B4 12B8 8B C8 8A 1E 0449 R 80 FB 07 77 02 MOV MOV CMP ADP_1 12BB 12BD 12BD 12BF 12BF 12C1 12C4 12C5 12C7 12CB ADP_2: D1 F9 SAR CX,1 ; / 2 FOR CRTC HANDLING B4 OC E8 1135 R 5B D1 E3 8B 87 0450 R E8 1175 R E9 219E R MOV CALL POP SAL MOV CALL JMP AH, C_STRT_HGH M16 BX BX, 1 AX, [BX + OFFSET CURSOR_POSN] M18 V_RET ; RECOVER PAGE VALUE ; *2 FOR WORD OFFSET ; GET CURSOR FOR THIS PAGE ; SET THE CURSOR POSITION SUBTTL INCLUDE VSCROLL.INC SUBTTL VSCROLL.INC PAGE FLTA PROC PUSH MOV SUB INC CMP POP JNE SUB ; CHECK FOR SCROLL COUNT 12D1 12D1 12D2 12D4 12D6 12D8 12DA 12DB 12DD 12DF 12DF 12DF 12DF 50 8A E6 2A E5 FE C4 3A E0 58 75 02 2A C0 NEAR AX AH, DH AH, CH AH AH, AL AX LTA AL, AL : YES, SET TO 0 FOR BLANK LTA: C3 FLTA PROC PUSH ASSUME PUSH CALL ; MOVE ROWS OF PELS UP CRANK NEAR BX DS: ABSO DS DDS BX, CRT_COLS DS ; SAVE DATA SEGMENT : SET DATA SEGMENT 12E1 12E2 12E5 12E9 12EA 12EB 12ED 12F1 12F3 12F4 12F7 12F7 12F7 12FB POP CRANK_A: USH MOV SUB PUSH PUSH REP POP ADD ADD POP LOOP POP CRANK ENDP CX CL,DL CH,CH SI DI MOVSB DI SI SI,BX DI,BX ; SAVE MOVE COUNT ; COLUMN COUNT ; CLEAR HIGH BYTE ; SAVE POINTERS 51 8A CA 2A ED 567 F3/ A4 5F 5E 03 F3 03 FB 59 E2 EE C3 ; NEXT ROW ; NEXT ROW ; RECOVER ROW COUNT ; DO MORE CX CRANK_A ; RETURN TO CALLER CRANK_4 PROC PUSH ASSUME PUSH CALL ; MOVE ROWS OF PELS DOWN NFAR BX DS: ABSO DS DDS 53 1E E8 OCFE R 8B 1E 044A R 1F 12FF 1300 1303 1307 1308 1308 1309 130B 130D 130E 130F 1311 1312 1313 1315 1317 BX, CRT_COLS MOV CRANK_B: CX CL, DL CH, CH SI DI MOVSB DI SI PUSH MOV SUB PUSH PUSH REP POP SUB SUB POP LOOP POP ; SAVE MOVE COUNT ; COLUMN COUNT ; CLEAR HIGH BYTE ; SAVE POINTERS 51 8A CA 2A ED 56 57 F3/ A4 5F 5E 2B F3 2B FB 59 E2 EE 5B C3 RECOVER ROW COUNT CRANK_B : RETURN TO CALLER CRANK_4 ENDP CRANK_4, ENDP PART_1 PROC PIUSH MOV MOV COLLE SUB MOV SUB PUSH POP MOV PUSH POP MOV CALL POP MOV PUSH REP : FILL ROW AFTER SCROLL 131C 131D 131F 1321 1324 1327 1328 132A 132C 132E 132F 1331 1332 NEAR NEAR DX DH, 3 DL, SEQ_ADDR AX,020FH OUT_DX DX AX, AX CL, DL CH, CH DI STOSB DI AL, DH 52 86 03 82 02 88 020F 88 020F 88 020F 88 020F 88 020F 89 020F 80 ; SEQUENCER ; MAP MASK : ALL MAPS ON ; SAVE POINTER ; CLEAR ONE ROW OF PELS ; RECOVER POINTER ; GET COLOR VALUE DI AL, DH DX DH, 3 DL, SEQ_ADDR AH, 02H OUT_DX DX 1334 1335 1337 ; SEQUENCER ; MAP MASK ; SET THE COLOR 1337 1339 133B 133E 133F 1341 ; ALL BITS ON ; COLUMN COUNT ; SAVE POINTER ; TURN ON THOSE BITS IN AL,OFFH CL,DL DI STOSB ``` ``` 3404 3404 3405 3406 3407 3408 PART 1 1348 1348 134A 134C 134F 1352 1353 PROC MOV MOV MOV CALL NEAR DH,3 DL,SEQ_ADDR AX,020FH OUT_DX PART_2 B6 03 B2 C4 B8 020F E8 0D15 R 011-131-1577-1990-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-7890-1-234567-789 ; SEQUENCER ; MAP MASK, ALL MAPS ; ENABLE THE MAPS ; RETURN TO CALLER PART_2 FNDP PROC 1353 1353 BLNK_3 NEAR ; BLANK FOR SCROLL UP : SAVE DATA SEGMENT PROC PUSH ASSUME CALL MOV SUB PUSH PUSH NEAR DS: ABSO DDS: DH, BH BH, BH AX DX AX, BX POINTS BX, AX DX AX 1F E8 OCFE R 8A F7 2A FF 50 52 8B C3 F7 26 0485 R 8B D8 5A GET LOW MEMORY SEGMENT ATTRIBUTE FOR BLANK LINE CLEAR HIGH BYTE SAVE SAVE BECAUSE OF MULTIPLY ROW COUNT CHARACTER HEIGHT NET VALUE TO BX RECOVER 1354 1357 1359 135B 135C 135D 135F 1363 1365 1366 MOV MUL MOV POP POP POP ASSUME 1367 1F DS: NOTHING S13: 1368 1368 E8 131C R CALL ASSUME PUSH CALL ADD POP DEC JNZ CALL RET PART_1 DS:ABS0 DS DDS DI,CRT_COLS DS BX S13 PART_2 ; BLANK OUT ROW WITH COLOR 136B 136C 136F 1373 1374 1375 1377 137A 137B 1E E8 OCFE R 03 3E 044A R ; SAVE SEGMENT ; LOW MEMORY SEGMENT ; NEXT ROW ; RECOVER 4B 75 F1 E8 1348 R C3 ; RETURN TO CALLER BLNK_3 ENDP BLNK_4 · PROC ; BLANK FOR SCROLL DOWN ; SAVE DATA SEGMENT 137B 137B NEAR DS: ABSO DDS: DH, BH BH, BH AX DX AX, BX POINTS BX, AX DX AX PROC PUSH ASSUME CALL MOV SUB 1 E ; GET LOW MEMORY SEGMENT ATTRIBUTE FOR BLANK LINE CLEAR HIGH BYTE ; SAVE SAVE BECAUSE OF MULTIPLY ROW COUNT CHARACTER HEIGHT NET VALUE TO BX RECOVER E8 OCFE R 8A F7 2A FF 50 52 8B C3 F7 26 0485 R 8B D8 5A 137C 137F 1381 1383 1384 1385 1387 138B 138D 138E PUSH PUSH MOV MUL MOV POP POP POP DS ASSUME DS: NOTHING 138F 1F S13_4: 1390 1390 E8 131C R PART_1 DS:ABS0 DS DI,CRT_COLS DS BX S13_4 PART_2 CALL ASSUME ; BLANK OUT ROW WITH COLOR ; SAVE SEGMENT ; LOW MEMORY SEGMENT ; NEXT ROW ; RECOVER 1393 1394 1397 139B 139C 139D 139F 13A2 13A3 1E E8 OCFE R 2B 3E 044A R 1F 4B 75 F1 E8 1348 R C3 PUSH SUB POP DEC JNZ CALL RET ; NEXT ; DO MORE : RETURN TO CALLER SCROLL UP THIS ROUTINE MOVES A BLOCK OF CHARACTERS UP ON THE SCREEN BLNK_4 ENDP (AH) = CURRENT CRT MODE (AL) = NUMBER OF ROWS TO SCROLL (CX) = ROW/COLUMN OF UPPER LEFT CORNER (DX) = ROW/COLUMN OF LOWER RIGHT CORNER (BH) = ATTRIBUTE TO BE USED ON BLANKED LINE (BS) = ROĞEN BUFFER SEGMENT (ES) = REĞEN BUFFER SEGMENT (ES) = REGEN BUFFER SEGMENT THE REGEN BUFFER IS MODIFIED ASSUME CS:CODE, DS:ABSO, ES:NOTHING UP PROC NEAR CALL MK, ES CMP AH, 4 JB N1 SCROLL_UP MOV CALL CMP JB CMP JE JMP 8A D8 E8 16EB R 80 FC 04 72 08 80 FC 07 74 03 E9 1474 R : SAVE LINE COUNT IN BL ; TEST FOR GRAPHICS MODE ; HANDLE SEPERATELY ; TEST FOR BW CARD ; UP_CONTINUE ; SAVE FILL ATTR IN BH UPPER LEFT POSITION ; DO SETUP FOR SCROLL BLANK_FIELD ; FROM ADDRESS ; # ROWS IN BLOCK ; # ROWS IN BLOCK ; ROW LOOP ; MOVE ONE ROW ; MOVE ONE ROW PUSH MOV CALL JZ ADD MOV SUB BX AX,CX SCROLL_POSITION N7 SI,AX AH,DH AH,BL 53 8B C1 E8 13F2 R 74 31 03 F0 8A E6 2A E3 N2: E8 1432 R 03 F5 03 FD FE CC 75 F5 CALL ADD ADD DEC JNZ N10 SI,BP DI,BP AH N2 , NOVE ONE NOW , NEXT LINE IN BLOCK , COUNT OF LINES TO MOVE , ROW LEOP , CLEAR ENTRY , RETOUR IN BLANKS , CLEAR LOOP , CLEAR LOP , CLEAR LOOP , LINES TO SCROLL , LINES TO SCROLL , SCROLL, END N3: POP E8 143B R 03 FD FE CB 75 F7 CALL ADD DEC JNZ E8 OCFE R 80 3E 0449 R 07 74 07 A0 0465 R BA 03D8 EE N5: CALL CMP JE MOV MOV OUT DDS CRT_MODE,7 ; IS THIS THE B/W CARD ; SKIP THE MODE RESET ; GET THE MODE SET ; ALWAYS SET COLOR CARD N6 AL,CRT_MODE_SET DX,03D8H DX,AL ; VIDEO_RET_HERE N6: E9 219E R ``` ``` 901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-234-367-8901-2 SCROLL_POSITION PROC TEST INFO,4 JZ N9 F6 06 0487 R 04 ;---- 80X25 COLOR CARD SCROLL 13F9 13FA 113FE 113FE 11402 11404 11408 11408 11408 11408 11418 11418 11418 11418 11418 11418 11418 11418 11418 11418 11418 11418 11418 11428 11428 11428 11428 11428 11428 11438 ; COLOR CARD HERE ; WAIT_DISP_ENABLE EC A8 74 B0 B2 EE 58 IN TEST JZ MOV MOV OUT POP POP ; DX=3D8 ; TURN OFF VIDEO ; DURING VERTICAL RETRACE N9: CALL ADD AX, CF MOV SI, AX SUB DX, CC INC DH INC DH INC DH INC DL XOR CL HOV BP, CF HOV BP, CF HOV AX, AX HOV AX, AX HOV AX, BP, CF HOV AX, AX HOV BP, CF HOV AX, AX HOV BP, CF HOV BP, CF HOV AX, AX HOV BP, CF BP ;---- MOVE_ROW PROC MOV PUSH PUSH REP POP POP RET ENDP ; SAVE START ADDRESS ; MOVE THAT LINE ON SCREEN PROC MOV PUSH REP POP RET ENDP SCROLL DOWN THIS ROUTINE MOVES THE CHARACTERS WITHIN A DEFINED BLOCK DOWN ON THE SCREEN, FILLING THE TOP LINES WITH A DEFINED CHARACTER (AH) = CURRENT CRT MODE (AL) = NUMBER OF LINES TO SCROLL (CX) = UPPER LEFT CORNER OF REGION (DX) = LOWER RIGHT CORNER OF REGION (BH) = FILL CHARACTER (DS) = DATA SEGMENT (ES) = REGEN SEGMENT OUTPUT NONE -- SCREEN IS SCROLLED PDOC NEAR SCROLLED SCROLL_DOWN STD MOV CALL PUSH MOV CALL JZ SUB MOV SUB N13: FD 8A D8 E8 16EB R 53 8B C2 E8 13F2 R 74 20 2B FO 8A E6 2A E3 BL,AL MK_ES BX_ AX,DX SCROLL_POSITION N16 SI,AX AH,DH AH,BL ; SAVE ATTRIBUTE IN BH ; LOWER RIGHT CORNER ; GET REGEN LOCATION ; SI IS FROM ADDRESS ; GET TOTAL # ROWS ; COUNT TO MOVE IN SCROLL N13: E8 1432 R 2B F5 2B FD FE CC 75 F5 N10 SI,BP DI,BP AH N13 N14: 58 B0 20 ; RECOVER ATTRIBUTE IN AH E8 143B R 2B FD FE CB 75 F7 E9 13DA R CALL SUB DEC JNZ JMP BL N15 N5 ; SCROLL_END BL, DH N14 ENDP SCROLL UP THIS ROUTINE SCROLLS UP THE INFORMATION ON THE CRT CH, CL = UPPER LEFT CORNER OF REGION TO SCROLL DH, DL = LOWER RIGHT CORNER OF REGION TO SCROLL BOTH OF THE ABOVE ARE IN CHARACTER POSITIONS BH = FILL VALUE FOR BLANKED LINES AL = # LINES TO SCROLL (AL=O MEANS BLANK THE ENTIRE FIELD) DS = DATA SEGMENT ``` | | | 3655 C | EXIT | | EGEN SEGMENT | | : | |------------------------------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------|---------------------------------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 3657 C<br>3658 C | ; | NOTHING | , THE SCREEN IS SCROLLED | | i | | 1474<br>1474<br>1476 | 8A D8<br>8B C1 | 3655 C C 3655 C C 3655 C C 3655 C C 3655 C C C 3655 C C C 3655 C C C 3655 C C C C 3655 C C C C S 3665 C C C C S 3665 C C C C S 3665 C S 3665 C C C C S 3665 C C C C C S 3665 C C C C C S 3665 C C C C C S 3665 C C C | GRAPHIC | S_UP<br>MOV<br>MOV | PROC NEAR<br>BL,AL<br>AX,CX | | SAVE LINE COUNT IN BL<br>GET UPPER LEFT POSITION<br>INTO AX REG | | | | 3663 C<br>3664 C<br>3665 C | ; | USE CHAR | RACTER SUBROUTINE FOR POSITIONIN<br>RETURNED IS MULTIPLIED BY 2 FRO | G<br>M C | ORRECT VALUE | | 1478<br>1478 | E8 16A7 R<br>8B F8 | 3664 C<br>3665 C<br>3666 C<br>3667 C<br>3668 C | | CALL<br>MOV | GRAPH_POSN<br>DI,AX | ; | SAVE RESULT AS<br>DESTINATION ADDRESS | | | | 3669 C<br>3670 C<br>3671 C | ; | DETERMIN | IE SIZE OF WINDOW | , | DESTINATION ADDRESS | | 147D<br>147F | 2B D1 | 3672 C<br>3673 C | | SUB | | | | | 147F<br>1483 | 2B D1<br>81 C2 0101<br>D0 E6 | 3673 C<br>3674 C<br>3675 C<br>3676 C<br>3677 C | | ADD<br>SAL | DX,CX<br>DX,101H<br>DH,1 | ; | ADJUST VALUES MULTIPLY # ROWS BY 4 SINCE 8 VERT DOTS/CHAR AND EVEN/ODD ROWS | | 1485 | DO E6 | 3677 C<br>3678 C<br>3679 C<br>3680 C | | SAL | DH,1<br>HE CRT MODE | ; | AND EVEN/ODD ROWS | | 41.07 | 00 25 0kk0 D 00 | 3680 C | ; | CMP | CRT_MODE,6 | | TEST FOR MEDIUM DES | | 1487<br>148C | 80 3E 0449 R 06<br>73 04 | 3681 C<br>3682 C<br>3683 C | | JNC | R7 | ; | TEST FOR MEDIUM RES<br>FIND_SOURCE | | 41.05 | 20 50 | 3684 C<br>3685 C<br>3686 C<br>3687 C | ; | MEDIUM F | | | * 2 | | 148E<br>1490 | D0 E2<br>D1 E7 | 3686 C<br>3687 C<br>3688 C | | SAL | DL,1<br>Di,1 | ; | * 2,<br>SINCE 2 BYTES/CHAR | | | | 3689 C<br>3690 C | | DETERMIN | NE THE SOURCE ADDRESS IN THE BUF | FER | | | 1492 | 06 | 3691 C<br>3692 C | R7: | PUSH | ES<br>DS | 1 | FIND SOURCE<br>GET SEGMENTS BOTH<br>POINTING TO REGEN<br>O TO HIGH OF COUNT REG<br>NUMBER OF LINES *4 | | 1492<br>1493<br>1494<br>1496<br>1498<br>1490<br>1490<br>1440<br>1440<br>1444 | 06<br>1F<br>2A ED<br>DO E3 | 3693 C<br>3694 C | | POP<br>SUB | DS<br>CH. CH | į | POINTING TO REGEN<br>O TO HIGH OF COUNT REG | | 1496 | DO E3 | 3695 C | | SAI | BL,1<br>BL 1 | ; | NUMBER OF LINES #4 | | 149A | 74 2D | 3696 C<br>3697 C<br>3698 C | | SAL<br>JZ<br>MOV | R11 | | IF O, BLANK ENTIRE FIELD | | 149E | B4 50 | 3699 C | | | AH, 80 | : | 80 BYTES/ROW | | 14A0<br>14A2 | 8B F7 | 3700 C<br>3701 C | | MUL<br>MOV<br>ADD | SI,DI | 1 | SET UP SOURCE | | 14A4 | 2A EU DO E3 TO E3 TO E4 8A C3 84 50 F6 E4 85 F7 03 F0 8A E6 2A E3 | 3702 C<br>3703 C<br>3704 C | | MOV<br>SUB | CH, CH BL,1 BL,1 BL,1 AL,BL AH,80 AH,80 ASI,DI SI,AX AH,DH AH,BL | : | IF 0, BLANK ENTIRE FIELD<br>NUMBER OF LINES IN AL<br>80 BYTES/ROW<br>OFFSET TO SOURCE<br>SET UP SOURCE<br>ADD IN OFFSET TO IT<br>NUMBER OF ROWS IN FIELD<br>DETERMINE NUMBER TO MOVE | | 14A8 | ZA E3 | 3705 C<br>3706 C<br>3707 C | | | ROUGH, MOVING ONE ROW AT A TIME, | BO. | | | 12:44 | | 3706 C | R8: | | | | | | 14AA<br>14AA<br>14AD<br>14B1<br>14B5 | E8 14CD R<br>81 EE 1FBO<br>81 EF 1FBO<br>FE CC<br>75 F1 | 3707<br>3708<br>3709<br>C<br>3710<br>C<br>3711<br>C<br>3712<br>C | | CALL<br>SUB | R17<br>SI,2000H-80<br>DI,2000H-80<br>AH<br>R8 | ; | ROW_LOOP<br>MOVE ONE ROW<br>MOVE TO NEXT ROW | | 14B1<br>14B5<br>14B7 | 81 EF 1FB0<br>FE CC<br>75 F1 | 3711 C<br>3712 C | | SUB<br>DEC<br>JNZ | D1,2000H-80<br>AH<br>R8 | ; | NUMBER OF ROWS TO MOVE<br>CONTINUE TILL ALL MOVED | | 1401 | ,, ,, | 3714 C<br>3715 C<br>3716 C<br>3717 C | ; | | THE VACATED LINE(S) | , | | | 14B9 | | 3716 C<br>3717 C | R9: | | | ; | CLEAR_ENTRY | | 1489<br>1488<br>1488 | 8A C7 | 3718 C<br>3719 C | R10: | MOV | AL,BH | ; | ATTRIBUTE TO FILL WITH | | 14BB<br>14BE | E8 14E6 R<br>81 EF 1FB0<br>FE CB<br>75 F5<br>E9 219E R | 3720 C<br>3721 C | | CALL<br>SUB | R18<br>DI,2000H-80<br>BL<br>R10<br>V_RET | ; | CLEAR THAT ROW<br>POINT TO NEXT LINE<br>NUMBER OF LINES TO FILL<br>CLEAR_LOOP | | 14BE<br>14C2<br>14C4<br>14C6<br>14C9 | 75 F5<br>F9 219F R | 3722 C<br>3723 C<br>3724 C | | DEC<br>JNZ<br>JMP | R10<br>V RET | | | | 14C9<br>14C9 | 8A DE | 3725 C<br>3726 C | R11: | MOV | BL, DH | ; | BLANK_FIELD<br>SET BLANK COUNT TO<br>EVERYTHING IN FIELD<br>CLEAR THE FIELD | | 14CB<br>14CD | EB EC | 3727 C<br>3728 C<br>3729 C | GRAPHIC | JMP | R9<br>ENDP | ; | CLEAR THE FIELD | | 1400 | | | | | TO MOVE ONE ROW OF INFORMATION | | | | 14CD | | 3731 C<br>3732 C<br>3733 C | R17 | PROC | NEAR | | | | 14CD<br>14CF | 8A CA<br>56<br>57 | 3734 C<br>3735 C | | MOV<br>PUSH<br>PUSH | CL,DL<br>SI<br>DI | ; | NUM OF BYTES IN THE ROW | | 14CD<br>14CD<br>14CF<br>14D0<br>14D1<br>14D3 | F3/ A4<br>5F | 3736 C<br>3737 C<br>3738 C<br>3739 C | | REP<br>POP<br>POP | MOVSB<br>DI<br>SI | ; | SAVE POINTERS<br>MOVE THE EVEN FIELD | | 14D3 | 5E | 3739 C | | POP | SI . | | | | 1404<br>1405<br>1409 | 81 C7 2000 | 3740 C<br>3741 C<br>3742 C | | ADD<br>ADD<br>PUSH | SI,2000H<br>DI,2000H<br>SI | ; | POINT TO THE ODD FIELD | | 1400<br>140E<br>140F | 57 | 3743 C<br>3744 C | | PUSH<br>MOV<br>REP | ĎΪ | ; | SAVE THE POINTERS | | 14DF | F3/ A4 | 3745 C | | REP | CL, DL<br>MOVSB | ; | SAVE THE POINTERS<br>COUNT BACK<br>MOVE THE ODD FIELD | | 14E1<br>14E3<br>14E4<br>14E5 | 5E<br>81 C6 2000<br>81 C7 2000<br>56<br>57<br>8A CA<br>F3/ A4<br>5E | 3746 C | | POP<br>POP<br>RET | DI<br>SI | ; | POINTERS BACK<br>RETURN TO CALLER | | 14E5 | C3 | 3745 C<br>3746 C<br>3747 C<br>3748 C<br>3749 C | R17 | ENDP | | , | RETURN TO CALLER | | | | 3750 C | ; | CLEAR A | SINGLE ROW | | | | 14E6 | | 3751 C<br>3752 C<br>3753 C<br>3754 C<br>3755 C<br>3756 C<br>3757 C<br>3758 C<br>3759 C | R18 | PROC | NEAR | | NUMBER OF BYTES IN FIELD | | 14E6<br>14E8<br>14E9 | 8A CA<br>57<br>F3/ AA<br>5F | 3755 C | | PUSH | CL,DL<br>DI<br>STOSB | ; | SAVE POINTER STORE THE NEW VALUE POINTER BACK POINT TO ODD FIELD | | 14EB | 5F AA | 3756 C | | REP<br>POP | DI | ; | POINTER BACK | | 14EB<br>14EC<br>14F0 | 81 C7 2000<br>57 | 3759 C | | POP<br>ADD<br>PUSH | DI,2000H<br>DI | ; | POINT TO ODD FIELD | | 14F1<br>14F3<br>14F5 | 8A CA<br>F3/ AA<br>5F | 3760 C<br>3761 C<br>3762 C | | MOV<br>REP<br>POP | CL, DL<br>STOSB<br>DI | ; | FILL THE ODD FIELD | | 14F5<br>14F6<br>14F7 | 5F<br>C3 | 3762 C<br>3763 C<br>3764 C | | RFT | וט | ; | RETURN TO CALLER | | | | 3764 C<br>3765 C | R18 | ENDP | | | | | 14F7 | | 3765 C<br>3766 C<br>3767 C<br>3768 C<br>3769 C<br>3770 C<br>3771 C | WEW_DE. | F PROC<br>ASSUME<br>PUSH | NEAR<br>DS:ABSO<br>AX | | | | 14F7<br>14F8 | 50<br>1E | 3768 C<br>3769 C | | PUSH<br>PUSH | DS | | | | 14F9<br>14FC | 50<br>1E<br>E8 OCFE R<br>8A 26 O487 R<br>80 E4 60<br>1F | 3770 C<br>3771 C | | PUSH<br>CALL<br>MOV | DDS<br>AH, INFO | | | | 1500 | 80 E4 60 | 3772 C<br>3773 C<br>3774 C | | AND | AH,060H<br>DS | | | | 14F7<br>14F8<br>14F9<br>14FC<br>1500<br>1503<br>1504<br>1505 | 58<br>74 02<br>F9 | 3774 C | | | AH, INFO<br>AH, 060H<br>DS<br>AX<br>MIN | | | | 1507 | 74 02<br>F9<br>C3 | 3775 C<br>3776 C<br>3777 C | | JZ<br>STC<br>RET | | | | | 1508<br>1509<br>1509 | | 3778 C<br>3779 C | MIN: | | | | | | 1509<br>150A | F8<br>C3 | 3780 C | | CLC<br>RET | | | | | 150B | | 3781 C<br>3782 C<br>3783 C<br>3784 C | MEM_DET | | CTIVE PAGE UP | | |----------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------| | 150B<br>150B | E9 13A3 R | 37883 C C 37893 C C 37893 C C C C 37893 C C C C C C C C C C C C C C C C C C C | sc_2: | JMP | SCROLL_UP | | | 150E | | 3788 C | AH6: | ACCUME | De. Apen | | | 150E<br>1511 | E8 12D1 R<br>8A 26 0449 R<br>80 FC 07<br>76 F1<br>80 FC 0D<br>73 17<br>E9 219E R | 3789 C<br>3790 C<br>3791 C | | ASSUME<br>CALL<br>MOV<br>CMP<br>JBE<br>CMP | DS:ABSO<br>FLTA<br>AH,CRT_MODE<br>AH,O7H | ; GET CURRENT MODE | | 1511<br>1515<br>1518<br>151A<br>151D<br>151F | 80 FC 07 | 3792 C<br>3793 C | | CMP | AH, 07H | ; ANY OF THE OLD MODES | | 151A<br>151D | 80 FC 0D<br>73 17 | 3794 C<br>3795 C<br>3796 C | | CMP | SC_2<br>AH,ODH<br>GRAPHICS_UP_2<br>V_RET | | | 151F | É9 219E R | 3796 C<br>3797 C | | JAE<br>JMP | | ; NEW GRAPHICS MODES<br>; NOT A RECOGNIZED MODE | | 1522<br>1522<br>1525<br>1528<br>1528 | BA A000 | 3798 C<br>3799 C | GR_ST_ | PROC<br>MOV<br>MOV | NEAR<br>DX.DAOOOH | ; REGEN BUFFER<br>; GRAPHICS WRITE MODE | | 1525<br>1528 | BD 0511<br>80 FC 0F | 3800 C<br>3801 C<br>3802 C | | MOV<br>CMP<br>JB | NEAR<br>DX, 0A000H<br>BP, 0511H<br>AH, 0FH<br>VV1 | ; GRAPHICS WRITE MODE | | 152B<br>152D | 72 08<br>E8 14F7 R | 3802 C<br>3803 C | | JB<br>CALL | | | | 1530<br>1532 | BA A000<br>BD 0511<br>80 FC 0F<br>72 08<br>E8 14F7 R<br>73 03<br>BD 0501 | 3804 C<br>3805 C | | CALL<br>JNC<br>MOV | VV1<br>BP,0501H | ; GRAPHICS WRITE MODE | | 152b<br>152D<br>1530<br>1532<br>1535<br>1535 | C3 | 3806 C<br>3807 C<br>3808 C | VV1:<br>GR_ST_ | RET | | | | 1536 | | 3808 C<br>3809 C<br>3810 C | GR_SI_ | | PROC NEAR | | | | 52 | 3811 C | GRAFHI | ASSUME<br>PUSH | DS: ABSO | | | 1536<br>1537 | É8 1522 R | 3813 C<br>3814 C | | CALL<br>SRLOAD | DX<br>GR_ST_1<br>ES | ; SET SEGMENT, WRITE MODE<br>; SET REGEN | | 153A<br>153C | 8E C2 | 3815 C+ | | | ES, DX | | | 153A<br>153C<br>153D<br>153F<br>1541<br>1542 | 5A<br>8A D8<br>8B C1 | 3816 C<br>3817 C<br>3818 C | | POP<br>MOV<br>MOV | UX BL, AL AX, CX BX BH, ACTIVE_PAGE GRX_PSN BX | ; NUMBER OF LINES<br>; UPPER LEFT CORNER | | 1541<br>1542 | 53<br>84 3F 0462 R | 3819 C<br>3820 C | | MOV<br>PUSH<br>MOV<br>CALL<br>POP<br>MOV<br>SUB | BX<br>BH.ACTIVE PAGE | ; ACTIVE PAGE FOR SCROLL<br>; ADDRESS IN REGEN | | 1546<br>1549<br>154A<br>154C | | 3821 C<br>3822 C | | CALL<br>POP | GRX_PSN<br>BX | | | 154A<br>154C | 5B<br>8B F8<br>2B D1 | 3823 C<br>3824 C | | MOV<br>SUB | DI,AX<br>DX,CX | ; SET POINTER<br>; DETERMINE WINDOW | | 154E<br>1552 | 2B D1<br>81 C2 0101<br>2A E4<br>8A G3 | 3825 C<br>3826 C | | SUB | DX,0101H<br>AH,AH | ; SET POINTER<br>; DETERMINE WINDOW<br>; ADJUST<br>; ZERO HIGH BYTE<br>; LINE COUNT | | 154C<br>154E<br>1552<br>1554<br>1556<br>1557<br>155B<br>155F<br>1561 | 8A C3<br>52<br>F7 26 0485 R<br>F7 26 044A R | 3827 C<br>3828 C<br>3829 C | | MOV<br>PUSH<br>MUL | GRX_PSN - ST DI_AX DI_AX DI_AX DX_CX | | | 155B | 52<br>F7 26 0485 R<br>F7 26 044A R<br>8B F7<br>03 F0 | 3830 C<br>3831 C | | | CRT_COLS | ; BYTES PER CHARACTER<br>; COLUMNS<br>; SET UP SOURCE INDEX | | 1561 | 03 F0 | 3832 C | | MOV<br>ADD<br>ASSUMF | SI,AX | ; ADJUST | | 1563<br>1564 | 06<br>1F | 3834 C<br>3835 C | | PUSH | ES<br>DS | | | 1563<br>1564<br>1565<br>1566<br>1568<br>156A<br>156C | 06<br>1F<br>5A<br>0A DB<br>74 3F<br>8A CE<br>2A CB<br>2A ED | 3836 C<br>3837 C<br>3838 C | | | | ; LINE COUNT | | 1568<br>156A | 74 3F<br>8A CE | 3838 C<br>3839 C | | OR<br>JZ<br>MOV | BL, BL<br>AR9<br>CL, DH | , | | 156C<br>156E | 2A CB<br>2A ED | 3840 C<br>3841 C | | SUB<br>SUB | CL, DH<br>CL, BL<br>CH, CH | | | | | 3842 C<br>3843 C | | ASSUME | DS: ABSO | | | 1570<br>1571 | 1E<br>E8 OCFE R | 3844 C<br>3845 C | | ASSUME<br>PUSH<br>CALL<br>PUSH<br>PUSH | DS<br>DDS | ; LOW MEMORY SEGMENT | | 1575 | 50<br>52 | 3846 C<br>3847 C<br>3848 C | | PUSH<br>PUSH<br>MOV | AX<br>DX | | | 1570<br>1571<br>1574<br>1575<br>1576<br>1578<br>157C<br>157E<br>157F | 8B C1<br>F7 26 0485 R<br>8B C8 | 3849 C<br>3850 C | | MUL<br>MOV<br>POP | AX,CX<br>POINTS<br>CX,AX<br>DX | ; BYTES PER CHAR<br>; SET THE COUNT | | 157E | 5A<br>58 | 3851 C | | POP | DX | ; SET THE COUNT | | 1580 | 1F | 3852 C<br>3853 C<br>3854 C | | POP<br>ASSUME<br>POP | AX<br>DS: NOTHING<br>DS | | | 1601 | 52 | 3855 C<br>3856 C | | DIIGH | | | | 1582<br>1584<br>1586<br>1588 | | 3857 C<br>3858 C | | MOV<br>MOV<br>CALL | DX AX, BB' DH, 3 DL, GRAPH_ADDR OUT_DX DL, SEQ_ADDR AX, 020FH OUT_DX DX | | | 1586<br>1588 | B2 GE<br>E8 0D15 R | 3859 C<br>3860 C | | MOV<br>CALL | DL,GRAPH_ADDR<br>OUT_DX | ; GRAPHICS | | 158B<br>158D<br>1590<br>1593<br>1594 | 8B C5<br>B6 03<br>B2 CE<br>E8 0D15 R<br>B2 C4<br>B8 020F<br>E8 0D15 R | 3861 C<br>3862 C | | MOV | DL,SEQ_ADDR<br>AX,020FH | ; SEQUENCER<br>; ENABLE ALL MAPS | | 1590<br>1593 | E8 0D15 R<br>5A<br>E8 12E0 R | 3863 C<br>3864 C<br>3865 C | | CALL<br>POP | OUT_DX<br>DX<br>CRANK | | | 1594 | | 3865 C | | PUSH | | ; SCROLL THE SCREEN | | 1597<br>1598<br>1599<br>159B<br>159D<br>159F | 52<br>40<br>8B C5 | 3867 C<br>3868 C<br>3869 C | | DEC | DX<br>BP<br>AX. BP | | | 159B<br>159D | B6 03<br>B2 CE | 3870 C<br>3871 C | | MOV | AX,BP<br>DH,3<br>DL,GRAPH_ADDR<br>OUT_DX | | | 159F<br>15A2 | E8 0D15 R<br>5A | 3872 C<br>3873 C | | CALL | OUT_DX<br>DX | | | 15A3<br>15A3 | E8 1353 R<br>E9 219E R | 3874 C<br>3875 C | AR10: | CALL<br>JMP | BLNK_3<br>V_RET | | | 159F<br>15A2<br>15A3<br>15A3<br>15A6<br>15A9 | | 3876 C<br>3877 C | AR9: | | | | | 15A9<br>15AB<br>15AD | 8A DE<br>EB F6 | 3878 C<br>3879 C | | MOV<br>JMP<br>CS_UP_2 | BL, DH<br>AR10<br>ENDP | ; BLANK ENTIRE WINDOW | | 15AU | | 3880 C<br>3881 C<br>3882 C | GKAPHI | | ACTIVE DISPLAY PAGE DOWN | | | 15AD | | 3883 C<br>3884 C | SC_3: | SCHOLL A | ACTIVE DISPERT PAGE DOWN | | | 15AD<br>15AD | E9 1442 R | 3885 C<br>3886 C | 00_0. | JMP | SCROLL_DOWN | | | 15B0 | | 3887 C<br>3888 C | AH7: | ASSUME | DS: ABSO | | | 15B0<br>15B3 | E8 12D1 R<br>8A 26 0449 R<br>80 FC 03<br>76 F1<br>80 FC 07<br>74 EC | 3889 C<br>3890 C | | ASSUME<br>CALL<br>MOV | US: MSSU<br>FLTA<br>AH, CRT_MODE<br>AH, O3H<br>SC 3<br>AH, O7H<br>SC_3 | | | 15B3<br>15B7<br>15BA<br>15BC | 80 FC 03<br>76 F1 | 3891 C<br>3892 C | | CMP<br>JBE | AH, 03H<br>SC_3 | ; OLD COLOR ALPHA | | 15BF | 80 FC 07<br>74 EC | 3893 C<br>3894 C | | CMP<br>JE | SC_3 | ; MONOCHROME ALPHA | | 1501 | 80 FC 0D | 3895 C<br>3896 C | | CMP | AH, ODH | ; NEW GRAPHICS MODES | | 1506 | 80 FC 06 | 3897 C<br>3898 C<br>3899 C | | JAE<br>CMP | AH,06H | ; OLD GRAPHICS MODES | | 15C1<br>15C4<br>15C6<br>15C9<br>15CB<br>15CD | 80 FC 0D<br>73 0C<br>80 FC 06<br>77 04<br>B4 07<br>CD 42 | 3900 C<br>3901 C | | JA<br>MOV<br>INT | AH, ODH<br>GRAPHICS_DN_2<br>AH, O6H<br>M O<br>AH, O7H<br>42H | | | 15CF<br>15CF | E9 219E R | 3902 C<br>3903 C<br>3904 C | M_0: | JMP | V_RET | | | 15D2<br>15D2 | | 3904 C<br>3905 C | GRAPHI | CS_DN_2<br>STD | PROC NEAR | | | 1502 | FD | 3906 C | | STD | | ; DIRECTION TO DECREMENT | ``` BL, AL DX GR_ST_1 ES ES, DX DX AX, DX AH 8A D8 52 E8 1522 R MOV PUSH CALL SRLOAD MOV POP MOV INC CALL SUB MOV SUB SUB MOV SUB SUB MOV SUB SUB MOV SUB PUSH MOV SUB PUSH POP POP OR JZ MOV 9399911111151677890121331345678901131456789019555555555578901173145677890121345678901955578901173145678901955789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019578901957890195789019 ; LINE COUNT ; SAVE LOWER RIGHT E8 1522 R 8E C2 8F C4 8B C C2 FF C4 BA SE C6 BA SE C6 BA SE C6 BA SE C6 BA SE C6 BA SE C6 BA SE C7 : SET REGEN SEGMENT ; MOV CHAR ROW UP BY ONE AH BX BH, ACTIVE_PAGE GRX_PSN ; ADDRESS IN REGEN ; ONE SCAN OVERSHOOT 1606 1607 1608 1609 160B 160D 160F 1611 ; SET DS TO ; THE REGEN SEGMENT 06 1 F 1F 5A 0A DB 74 40 8A CE 2A CB 2A ED ; SCROLL COUNT : BLANK ENTIRE WINDOW SUB SUB ASSUME PUSH CALL PUSH MOV MOV POP POP ASSUME POP DS: ABSO DS DDS AX DX AX, CX POINTS CX, AX DX AX DS: NOTHING DS 1E E8 OCFE R 50 52 8B C1 F7 26 0485 R 8B C8 5A 1613 1614 1617 1618 1619 161B 161F 1621 1622 ; BYTES PER CHAR 1623 1F 52 8B C5 B6 03 B2 CE E8 0D15 R B2 C4 B8 020F E8 0D15 R 5A E8 12FE R DX AX, BP DH, 3 DL, GRAPH_ADDR OUT DX DL, SEQ_ADDR AX, 020FH OUT_DX DX CRANK_4 PUSH MOV MOV CALL MOV MOV CALL POP CALL 1624 1625 1627 1629 162B 162E 1630 1633 1636 1637 ; GRAPHICS ; SEQUENCER ; ENABLE ALL MAPS : SCROLL THE SCREEN 52 4D 8B C5 86 03 B2 CE E8 OD15 R PUSH DEC MOV MOV MOV CALL POP DX BP AX,BP DH,3 DL,GRAPH_ADDR OUT_DX DX 163A 163B 163C 163E 1640 1642 1645 1646 1646 1649 164A 164D 164F 1651 DXR10: E8 137B R FC E9 219E R BLNK_4 V_RET MOV ; BLANK ENTIRE WINDOW JMP GRAPHICS_DN_2 SURTTI INCLUDE VGRW.INC SUBTTL VGRW.INC PAGE ASSUME FIND_POSITION MOV XOR MOV 8A CF 32 ED 8B F1 D1 E6 8B 84 0450 R 33 DB E3 06 ; DISPLAY PAGE TO CX ; MOVE TO SI FOR INDEX * 2 FOR WORD OFFSET ; ROW/COLUMN OF THAT PAGE ; SET START ADDRESS TO 0 ; NO_PAGE ; PAGE_LOOP ; LENGTH OF BUFFER MOV SAL MOV XOR JCXZ P4: ADD LOOP BX,CRT_LEN ; NO_PAGE ; DETERMINE LOC IN REGEN : ADD TO START OF REGEN CALL ADD RET FIND_POSITION E8 1146 R 03 D8 C3 POSITION BX,AX EXPAND MED_COLOR THIS ROUTINE EXPANDS THE LOW 2 BITS IN BL TO FILL THE ENTIRE BX REGISTER ENTRY BL = COLOR TO BE USED ( LOW 2 BITS ) EXIT BX = COLOR TO BE USED ( 8 REPLICATIONS OF THE 2 COLOR BITS ) OBDO: NEAR : ISOLAT PROC AND MOV PUSH MOV NEAR BL,3 AL,BL CX CX,3 80 E3 03 8A C3 51 B9 0003 ; ISOLATE THE COLOR BITS ; COPY TO AL ; SAVE REGISTER ; NUMBER OF TIMES S20: DO EO DO EO OA D8 SAL SAL OR ; LEFT SHIFT BY 2 ; ANOTHER COLOR VERSION ; INTO BL ; FILL ALL OF BL ; FILL UPPER PORTION ; REGISTER BACK ; ALL DONE LOOP MOV POP RET S20 BH,BL CX EXPAND BYTE THIS ROUTINE TAKES THE BYTE IN AL AND DOUBLES : ALL OF THE BITS, TURNING THE 8 BITS INTO ``` ``` PROC PUSH PUSH PUSH SUB MOV 1682 1683 1684 1685 1687 168A 168C 1690 1694 1696 1698 1698 52 51 53 28 D2 89 0001 88 D8 23 D9 0B D3 D1 E0 D1 E1 8B D8 23 D9 0B D3 D1 E1 ; BASE INTO TEMP ; USE MASK TO EXTRACT BIT ; PUT INTO RESULT REGISTER MOV AND OR SHL SHL MOV AND OR SHL S22 169C 73 EC JNC MOV POP POP POP RET ENDP AX,DX BX CX DX ; RECOVER REGISTERS $21 ENDP $26 PROC GRAPH_POSN PUSH MOV MOV MOV SHL SHL SUB ADD POP POP $26 ENDP NEAR AX, CURSOR POSN LABEL NEAR BX BX, AX AL, AH BYTE PTR CRT_COLS AX, 1 BH, BH AX, 3 BX, BX BX 16A4 16A7 16A7 16A8 16AA 16AC 16B2 16B4 16B8 16B8 16B9 A1 0450 R ; GET CURRENT CURSOR 53 8B D8 8A C4 F6 26 044A R D1 E0 D1 E0 2A FF 03 C3 5B C3 4077 4078 4079 4080 4081 4082 4083 R_CUR: ASSUME PUSH MOV SUB SAL MOV POP GRX_PSN ENTRY AX = CU 16BA SAVE REGISTER GET TO LOW BYTE ZERO HIGH BYTE #2 FOR WORD COUNT CURSOR, REQUESTED PAGE RECOVER REGISTER 53 8A DF 2A FF D1 E3 8B 87 0450 R 5B 4085 4086 4087 4088 4089 4090 4091 4093 4094 4095 4096 4097 AX = BYTE OFFSET INTO REGEN GRX_PSN PROC PUSH PUSH PUSH PUSH SUB MOV MOV MUL MUL SUB ADD MOV JCXZ GP_3: 16C6 16C6 16C8 16C9 16CB 16CB 16CD 16CF 16DD 16DD 16E3 16E3 16E5 16E7 16E8 16E8 53 51 52 2A ED 8A CF 8B D8 8A C4 F6 26 F7 26 2A FF 03 C3 8B 1E E3 04 ROW * COLUMNS/ROW BYTES PER ROW ZERO TO LEAVE COL VALUE ADD IN COLUMN PAGE LENGTH NO PAGE OFFSET GP_3: ADD LOOP ; ADD IN THE PAGE LENGTH ; DO FOR NUMBER OF PAGES AX,BX GP_3 POP POP GRX_PSN ENDP 16EB 16EB 16EE 16F2 16F6 16FB 16FE 16FE 1700 BE B800 8B 3E 0410 R 81 E7 0030 83 FF 30 75 03 BE B000 MOV MOV AND CMP JNE MOV SI,0B800H DI,EQUIP_FLAG DI,030H DI,030H P6_A SI,0B000H 8E C6 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 OUTPUT (AL) = CHAR READ (AH) = ATTRIBUTE READ ASSUME C.S.CODE, DS. ABSO, ES. NOTHING CURRENT PROC NEAR CALL FIND POSITION MOV SI, BX ASSUME READ_AC_CURRENT CALL CALL MOV ; ADDRESSING IN SI DX, ADDR_6845 GET BASE ADDRESS F6 06 0487 R 04 ŤEST INFO,4 ``` ``` 1715 06 1716 1F ; SEGMENT FOR QUICK ACCESS JZ 1717 7h 00 ;---- WAIT FOR HORIZONTAL RETRACE ; WAIT FOR RETRACE LOW ; GET STATUS ; IS HORZ RETRACE LOW ; WAIT UNTIL IT IS ; NO MORE INTERRUPTS ; WAIT FOR RETRACE HIGH ; GET STATUS ; IS IT HIGH ; WAIT UNTIL IT IS P2: P3: IN TEST JZ ; GET THE CHAR/ATTR AD E9 219E R LODSW JMP V_RET MED_READ_BYTE THIS ROUTINE WILL TAKE 2 BYTES FROM THE REGEN BUFFER, COMPARE AGAINST THE CURRENT FOREGROUND COLOR, AND PLACE THE CORRESPONDING ON/OFF BIT PATTERN INTO THE CURRENT POSITION IN THE SAVE SI,DS = POINTER TO REGEN AREA OF INTEREST BX = EXPANDED FOREGROUND COLOR BP = POINTER TO SAVE AREA BP IS INCREMENT AFTER SAVE PROC MOV MOV MOV NEAR AH,[SI] AL,[SI+1] CX,0C000H ; GET FIRST BYTE ; GET SECOND BYTE ; 2 BIT MASK TO TEST ; THE ENTRIES ; RESULT REGISTER B2 00 MOV DL,0 S24: ; IS THIS BACKGROUND? ; CLEAR CARRY IN HOPES ; THAT IT IS ; IF 0 IT IS BACKGROUND ; WASN'T, SO SET CARRY 74 01 F9 JZ STC S25: ; MOVE THAT BIT INTO THE RESULT MOVE THE MASK TO THE RIGHT BY 2 BITS DO IT AGAIN IF MASK DIDN'T FALL OUT STORE RESULT IN SAVE ADJUST POINTER RCL SHR SHR JNC S24 173E 73 F2 MOV INC RET ENDP [BP],DL BP S23 GRAPHICS_READ CALL CALL PROC MK_ES S26 4220 4221 : CONVERTED TO OFFSET ;---- DETERMINE GRAPHICS MODES 80 3E 0449 R 06 06 1E 72 1A CRT_MODE,6 ES DS S13P ;---- HIGH RESOLUTION READ ;---- GET VALUES FROM REGEN BUFFER AND CONVERT TO CODE POINT B6 04 ; GET FIRST BYTE ; SAVE IN STORAGE AREA ; NEXT LOCATION ; GET LOWER REGION BYTE ; ADJUST AND STORE MOV MOV INC MOV INC ADD DEC JNZ JMP AL,[SI] [BP],AL BP AL,[SI+2000H] [BP],AL BP SI,80 DH 45 8A 84 2000 88 46 00 45 83 C6 50 FE CE 75 EB EB 17 90 ; POINTER INTO REGEN ; LOOP CONTROL ; DO IT SOME MORE ; GO MATCH THE SAVED CODE ; POINTS ;---- MEDIUM RESOLUTION READ ; MED_RES_READ ; OFFSET*2, 2 BYTES/CHAR ; NUMBER OF PASSES GET PAIR BYTES INTO SINGLE SAVE GO TO LOWER REGION GET THIS PAIR INTO SAVE ADJUST POINTER BACK INTO UPPER CALL S23 81 C6 2000 E8 1728 R 81 EE 1FB0 FE CE 75 EE ADD CALL SUB DEC JNZ $1,2000H $23 $1,2000H-80 DH $14P ; REEP GOING UNTIL 8 DONE ;---- SAVE AREA HAS CHARACTER IN IT, MATCH IT DS DDS DI,GRX_SET DS BP,8 1E E8 OCFE R C4 3E 010C R PUSH CALL LES POP SUB ; ESTABLISH ADDRESSING ; ADJUST POINTER TO ; BEGINNING OF SAVE AREA 8B F5 FC BO OO 1797 1799 179A 179C 179C 179D 179E 17A1 17A1 17A2 ; ENSURE DIRECTION ; CURRENT CODE POINT BEING ; MATCHED ; ADDRESSING TO STACK ; FOR THE STRING COMPARE ; NUMBER TO TEST AGAINST AL, 0 $16P: PUSH POP MOV 16 1F BA 0080 SS DS DX, 128 PUSH ``` ``` 17A3 17A6 17A8 17A9 17AA B9 0008 F3/ A6 5F 5E 74 1D 4285 4286 4287 4288 MOV REPE POP POP JZ NUMBER OF BYTES TO MATCH COMPARE THE 8 BYTES RECOVER THE POINTERS CX,8 CMPSB ; IF ZERO FLAG SET, ; THEN MATCH OCCURRED ; NO MATCH, MOVE TO NEXT ; NEXT CODE POINT ; LOOP CONTROL ; DO ALL OF THEM SIRP FE CO 83 C7 O8 4A 75 ED 17AC 17AE 17B1 INC AL DI,8 4291 4293 4294 4295 4296 4297 4298 4299 ;---- CHAR NOT MATCHED, MIGHT BE IN USER SUPPLIED SECOND HALF AL <> 0 IF ONLY 1ST HALF SCANNED IF = 0, THEN ALL HAS BEEN SCANNED CMP 17B4 3C 00 JE S18P 1786 74 11 4300 4301 4302 4303 4304 4305 4306 4307 4310 43112 43114 43116 4317 4318 4317 4318 4318 4312 4312 4312 4312 4312 4312 4312 ASSUME CALL DS: ABSO E8 OCFE R C4 3E 007C R 8C C0 0B C7 74 04 B0 80 EB D3 DS:ABSO DDS DI,EXT_PTR AX,ES AX,DI S18P AL,128 S16P 17B8 17BB 17BF 17C1 17C3 17C5 17C7 GET POINTER SEE IF THE PNTR EXISTS IF ALL O, DOESN'T EXIST NO SENSE LOOKING ORIGIN FOR SECOND HALF GO BACK AND TRY FOR IT LES MOV OR JZ MOV ;---- CHARACTER IS FOUND ( AL=O IF NOT FOUND ) 17C9 17C9 83 C4 08 ; READJUST THE STACK, ; THROW AWAY SAVE : ALL DONE ADD SP.8 JMP GRAPHICS_READ 17CC 17CF E9 219E R ;---- READ CHARACTER/ATTRIBUTE AT CURRENT CURSOR POSITION F9 1701 R READ AC CURRENT 4324 4325 4326 4327 4328 AH8: 1702 DS: ABSO AH, CRT_MODE AH, 07H AH8S AH, 03H AH8S AH, 06H Z_1 GRAPHICS_READ ASSUME 8A 26 0449 R 80 FC 07 74 F4 80 FC 03 76 EF 80 FC 06 MOV CMP JE CMP JBE CMP : GET THE CURRENT MODE 17D9 17DB 4329 4330 4331 4332 4333 17DE 17E0 17E3 17E5 17E8 80 FC 06 77 03 E9 1745 R JA JMP 4334 4335 4336 4337 4338 4349 4341 4342 4343 4344 4345 4347 Z_1: 80 FC OF 72 52 E8 14F7 R 72 4D EB OA 80 FC OD 73 46 BO OO E9 219E R CMP JB CALL JC JMP CMP JAE AH, OFH GRX_RD2 MEM_DET GRX_RD2 SHORT_GRX_RD1 17E8 17EB 17ED 17F0 17F2 17F4 17F7 17F9 AH, ODH GRX_RD2 AL, O V_RET GRX_RD1 PROC ASSUME 17FF NEAR DS: ABSO ASSUME SRLOAD MOV MOV CALL MOV MOV SUB DS: ABSO ES, OAOOOH DX, OAOOOH ES, DX GR_CUR SI, AX BX, POINTS SP, BX 143494 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 143591 ; REGEN SEGEMNT 17FE 1801 1803 1806 1808 180C BA A000 8E C2 E8 16BA R 8B F0 8B 1E 0485 R 2B E3 ; BYTE OFFSET INTO REGEN ; SAVE IN SI ; BYTES PER CHARACTER ; ALLOCATE SPACE TO SAVE ; THE READ CODE POINT ; POINTER TO SAVE AREA 180E 8B EC MOV BP.SP ;---- GET VALUES FROM REGEN BUFFER AND CONVERT TO CODE POINT 53 24 01 8A C8 80 05 D2 E0 B4 07 B6 03 B2 CE E8 0D15 R B8 0518 E8 0D15 R PUSH AND MOV MOV SHL MOV MOV CALL BX AL, 1 CL, AL AL, 5 AL, CL AH, G_COLOR DH, 3 DL, GRAPH_ADDR OUT_DX AX, 518H OUT_DX ; SAVE BYTES PER CHARACTER DOD OR EVEN BYTE ; USE FOR SHIFT ; COLOR COMP VALUE (CO-C2) ; (C1-C3) IF ODD BYTE ; COLOR COMPARE REGISTER 1810 1811 1813 1815 1817 1819 181B 181F 1825 1828 1828 1828 1830 1831 1835 1838 1838 1838 1838 1838 ; SET GRAPHICS CHIP ; READ MODE ; SET GRAPHICS CHIP MOV 26: 8A 04 F6 D0 88 46 00 45 03 36 044A R 4B 75 F0 5B 88 0510 EB 32 90 S12_1: AL,ES:[SI] AL SS:[BP],AL BP MOV NOT MOV INC ADD DEC JNZ POP MOV JMP GRX_RD1 ENDP ; GET FIRST BYTE MOV ; SAVE IN STORAGE AREA NEXT LOCATION POINTER INTO REGEN LOOP CONTROL DO IT SOME MORE RECOVER BYTES PER CHAR UNDO READ MODE CHAR RECONTION ROUTINE SI, CRT_COLS BX S12_1 BX AX,510H GRX_RECG NEAR DS:ABSO ES, 0A000H DX, 0A000H ES, DX GR_CUR SI, AX BX, POINTS SP, BX GRX_RD2 PROC ASSUME SRLOAD MOV MOV CALL 183F : REGEN SEGMENT BA A000 8E C2 E8 16BA R 8B F0 8B 1E 0485 R 2B E3 183F 1842 1844 1847 1849 184D ; BYTE OFFSET INTO REGEN ; SAVE IN SI ; BYTES PER CHARACTER ; ALLOCATE SPACE TO SAVE ; THE READ CODE POINT ; POINTER TO SAVE AREA 184F 8B EC MOV BP, SP ;---- GET VALUES FROM REGEN BUFFER AND CONVERT TO CODE POINT B6 03 B2 CE B8 0508 E8 0D15 R DH,3 DL,GRAPH_ADDR AX,508H OUT_DX ; GRAPHICS CHIP ; COLOR COMPARE ; SET THE REGISTER ; SAVE BYTES PER CHARACTER S12: 26: 8A 04 F6 D0 88 46 00 45 03 36 044A R 4B 75 F0 GET COLOR COMPARED BYTE ADJUST SAVE IN STORAGE AREA NEXT LOCATION POINTER INTO REGEN LOOP CONTROL DO IT SOME MORE MOV NOT MOV INC ADD AL,ES:[SI] AL SS:[BP],AL BP SI, CRT_COLS BX S12 ``` ``` POP MOV GRX_RD2 ENDP ВХ АХ,500Н ; RECOVER BYTES PER CHAR : UNDO READ MODE 5B B8 0500 1870 GRX_RECG: ;---- SAVE AREA HAS CHARACTER IN IT, MATCH IT ; SET READ MODE BACK ; GET FONT DEFINITIONS ; ADJUST POINTER TO ; BEGINNING OF SAVE AREA OUT_DX DI,GRX_SET BP,BX LES 8B F5 FC BO 00 16 1F BA 0100 MOV CLD MOV PUSH POP MOV SI,BP ; ENSURE DIRECTION ; CODE POINT BEING MATCHED ; ADDRESSING TO STACK ; FOR THE STRING COMPARE ; NUMBER TO TEST AGAINST AL,O SS DS DX,256D S17_5: PUSH PUSH MOV REPE POP POP JZ 56 57 8B CB F3/ A6 5F 5E 74 07 SAVE SAVE AREA POINTER SAVE CODE POINTER NUMBER OF BYTES TO MATCH COMPARE THE 8 BYTES RECOVER THE POINTERS SI S18_5 ; IF ZFL SET, THEN MATCH OCCURRED NO MATCH ON TO NEXT NEXT CODE POINT LOOP CONTROL DO ALL OF THEM AL=CHAR, O IF NOT FOUND READJUST THE STACK FE C0 03 FB 4A 75 EF AL DI,BX ADD DEC JNZ DX S17_5 03 E3 E9 219E R ;---- WRITE CHARACTER/ATTRIBUTE AT CURRENT CURSOR POSITION INPUT. (AH) = CURRENT CRT MODE (BH) = DISPLAY PAGE (CX) = COUNT OF CHARACTERS TO WRITE (AL) = CHART TO WRITE (DS) = DATA SEGMENT (ES) = REGEN SEGMENT NONE 1899 ASSUME DS:ABSO CALL DDS MOV AH,CRT_MODE 80 FC 04 72 08 80 FC 07 74 03 EB 74 90 AH,4 P6 AH,7 P6 CMP JC CMP JE JMP 18A0 18A3 18A5 18A8 18AA 18AD 18B0 18B2 18B3 18B4 18B7 18B9 18BA ; IS THIS GRAPHICS ; IS THIS BW CARD P6 GRAPHICS_WRITE P6: E8 16EB R 8A E3 50 51 E8 1651 R 8B FB 59 58 8B 16 0463 R 83 C2 06 MK_ES AH, BL AX CX FIND_POSITION DI, BX CX BX DX, ADDR_6845 DX, 6 ; WRITE_AC_CONTINUE CALL ; GET ATTRIBUTE TO AH ; SAVE ON STACK ; SAVE WRITE COUNT MOV PUSH PUSH CALL ; ADDRESS TO DI REGISTER ; WRITE COUNT ; CHARACTER IN BX REG ; GET BASE ADDRESS ; POINT AT STATUS PORT MOV POP POP MOV ADD WAIT FOR HORIZONTAL RETRACE P7: 18C2 18C7 18C9 18C9 18C9 18CA 18CC 18CE 18CF 18CF F6 06 0487 R 04 74 0B TEST JZ INFO,4 P9A ; GET STATUS ; IS IT LOW ; WAIT UNTIL IT IS ; NO MORE INTERRUPTS ; GET STATUS ; IS IT HIGH ; WAIT UNTIL IT IS IN TEST JZ 18D2 18D4 8B C3 AB FB E2 E8 E9 219E R ; RECOVER THE CHAR/ATTR ; PUT THE CHAR/ATTR ; INTERRUPTS BACK ON ; AS MANY TIMES MOV STOSW STI 18D4 AX, BX 18D6 18D7 P7 V_RET ;---- WRITE CHARACTER ONLY AT CURRENT CURSOR POSITION WRITE C CURRENT THIS ROUTINE WRITES THE CHARACTER AT THE CURRENT CURSOR POSITION, ATTRIBUTE UNCHANGED INPUT (AH) = CURRENT CRT MODE (BH) = DISPLAY PAGE (CX) = COUNT OF CHARACTERS TO WRITE (AL) = CHAR TO WRITE (AL) = CHAR TO WRITE (DS) = DATA SEGMENT OUTPU (ES) = REGEN SEGMENT , NONE 18DD ASSUME DS:ABSO CALL DDS MOV AH,CRT_MODE 80 FC 04 72 08 80 FC 07 74 03 CMP AH,4 P10 : IS THIS GRAPHICS JC CMP JE P10 AH,7 P10 ; IS THIS BW CARD EB 30 90 JMP GRAPHICS_WRITE P10: E8 16EB R CALL MK ES ``` ``` ; SAVE ON STACK ; SAVE WRITE COUNT CX FIND_POSITION DI,BX PUSH CALL MOV ; ADDRESS TO DI ; WRITE COUNT ; BL HAS CHAR TO WRITE WAIT FOR HORIZONTAL RETRACE DX,ADDR_6845 DX,6 MOV ADD 8B 16 0463 R 83 C2 06 ; GET BASE ADDRESS ; POINT AT STATUS PORT F6 06 0487 R 04 TEST JZ ; GET STATUS ; IS IT LOW ; WAIT UNTIL IT IS ; NO MORE INTERRUPTS JNZ P13: EC A8 01 74 FB AL,DX AL,1 P13 TEST JZ P13A: 8A C3 AA FB 47 E2 E7 E9 219E R RECOVER CHAR PUT THE CHAR/ATTR INTERRUPTS BACK ON BUMP POINTER PAST ATTR AS REQUESTED AL.BL GRAPHICS WRITE THIS ROUTINE WRITES THE ASCII CHARACTER TO THE CURRENT POSITION ON THE SCREEN. 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 (0 IS USED FOR THE BACKGROUND COLOR) CX = NUMBER OF CHARAS TO WRITE DS = DATA SEOMEN! NOTHING IS RETURNED GRAPHICS 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 THE SCREEN TO THE CHARACTER GENERATOR CODE PO NONE (0 IS ASSUMED AS THE BACKGROUND COLOR) AL = CHARACTER READ AT THAT POSITION (O RETURNED IF NONE FOUND) FOR COMPATIBILITY 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 INITIALIZE THE WESTOR AT INTERRUPT 1FH (LOCATION DODOTCH) TO POINT TO THE USER INTERRUPT 1FH (LOCATION DODOTCH) TO POINT TO THE USER INTERRUPT 1FH (LOCATION DODOTCH) TO POINT TO THE USER INTERRUPT 1FOR THE USER INTERRUPT 15 1 80 FC 07 72 03 E9 19D7 R E8 16EB R B4 00 50 CALL ;---- DETERMINE POSITION IN REGEN BUFFER TO PUT CODE POINTS 192E E8 16A4 R 1931 8B F8 ; LOC IN REGEN BUFFER : REGEN POINTER IN DI ;---- DETERMINE REGION TO GET CODE POINTS FROM ; RECOVER CODE POINT ; IS IT IN SECOND HALF ; YES CMP JAE ;---- IMAGE IS IN FIRST HALF, CONTAINED IN ROM 1938 C5 36 010C R 193C EB 06 : DETERMINE MODE ;---- IMAGE IS IN SECOND HALF, IN USER RAM ; EXTEND_CHAR ; 0 ORIGIN FOR SECOND HALF 2C 80 C5 36 007C R SUB AL,80H SI,EXT_PTR :---- DETERMINE GRAPHICS MODE IN OPERATION DETERMINE_MODE MULTIPLY CODE POINT VALUE BY 8 1944 1946 1948 1948 1940 1950 1955 1956 D1 E0 D1 E0 D1 E0 O3 F0 1E E8 OCFE R 80 3E 0449 R 06 SAL SAL ADD PUSH CALL CMP POP AX,1 AX,1 AX,1 Si,AX DS DS DDS CRT_MODE,6 DS S7 ; TEST FOR MEDIUM RES MODE jč HIGH RESOLUTION MODE ; HIGH_CHAR ; SAVE REGEN POINTER ; SAVE CODE POINTER ; NUMBER OF TIMES THROUGH LOOP ; GETOTE FROM CODE POINT ; GUILD WE USE THE ; FUNCTION TO PUT CHAR IN ; STORE IN REGEN BUFFER 57 56 B6 04 PUSH PUSH MOV LODSB TEST JNZ STOSB LODSB BL,80H S6 S5: 26: 88 85 1FFF 83 C7 4F FE CE 75 EC 5E ES:[DI+2000H-1],AL DI,79 DH S4 SI ; STORE IN SECOND HALF ; MOVE TO NEXT ROW IN REGEN ; DONE WITH LOOP ``` | 1971<br>1972<br>1973<br>1975<br>1978 | 5F<br>47<br>E2 E3<br>E9 219E R<br>26: 32 05 | 4663 C<br>4664 C<br>4665 C<br>4666 C<br>4667 C | S6: | POP<br>INC<br>LOOP<br>JMP | DI<br>DI<br>S3<br>V_RET | ; RECOVER REGEN POINTER<br>; POINT TO NEXT CHAR POS<br>; MORE CHARS TO WRITE | |--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1978<br>1978<br>1970<br>1970 | AA<br>AC<br>26: 32 85 1FFF | 4668 C<br>4669 C<br>4670 C<br>4671 C | | XOR<br>STOSB<br>LODSB<br>XOR | AL, ES: [DI] AL, ES: [DI+2000H-1] | ; XOR WITH CURRENT<br>; STORE THE CODE POINT<br>; AGAIN FOR ODD FIELD | | 1982 | EB EO | 4672 C<br>4673 C<br>4674 C | : 1 | JMP | S5<br>ESOLUTION WRITE | ; BACK TO MAINSTREAM | | 1984<br>1984<br>1986<br>1988<br>1988<br>1988<br>1980<br>1980 | 8A D3<br>D1 E7<br>E8 166D R<br>57<br>56<br>B6 04 | 4675 C<br>4676 C<br>4677 C<br>4678 C<br>4679 C<br>4680 C<br>4681 C<br>4682 C | \$7:<br>\$8: | MOV<br>SAL<br>CALL<br>PUSH<br>PUSH<br>MOV | DL, BL<br>D1, 1<br>S19<br>D1<br>S1<br>D1, 4 | ; MED RES_WRITE<br>; SAVE HIGH COLOR BIT<br>; OFFSET*2, 2 BYTES/CHAR<br>; EXPAND BL TO FULL WORD<br>; OF COLOR<br>; SAVE REGEN POINTER<br>; SAVE THE CODE POINTER<br>; NUMBER OF LOOPS | | 198F<br>198F<br>1990<br>1993<br>1995<br>1998<br>199A<br>199D | AC<br>E8 1682 R<br>23 C3<br>F6 C2 80<br>74 07<br>26: 32 25<br>26: 32 45 01 | 4683 C<br>4685 C<br>4686 C<br>4687 C<br>4688 C<br>4689 C<br>4691 C<br>4692 C | 89: | LODSB<br>CALL<br>AND<br>TEST<br>JZ<br>XOR<br>XOR | \$21<br>AX, BX<br>DL, 80H<br>\$10<br>AH, ES:[DI]<br>AL, ES:[DI+1] | ; GET CODE POINT ; DOUBLE UP ALL THE BITS ; CONVERT THEM TO FORE- ; GROUND COLOR (0 BACK) ; IS THIS XOR FUNCTION ; NO, STORE IT IN AS IT IS ; DO FUNCTION WITH HALF ; AND WITH OTHER HALF | | 19A1<br>19A1<br>19A4<br>19A8 | 26: 88 25<br>26: 88 45 01<br>AC | 4693 C<br>4694 C<br>4695 C<br>4696 C | \$10: | MOV<br>MOV<br>LODSB | | ; STORE FIRST BYTE<br>; STORE SECOND BYTE<br>; GET CODE POINT | | 19A9<br>19AC<br>19AE<br>19B1<br>19B3<br>19B8<br>19BD | E8 1682 R<br>23 C3<br>F6 C2 80<br>74 0A<br>26: 32 A5 2000<br>26: 32 85 2001 | 4697 C<br>4698 C<br>4699 C<br>4700 C<br>4701 C<br>4702 C<br>4703 C | \$11: | CALL<br>AND<br>TEST<br>JZ<br>XOR<br>XOR | S21<br>AX, BX<br>DL, 80H<br>S11<br>AH, ES: [DI+2000H]<br>AL, ES: [DI+2001H] | ; CONVERT TO COLOR<br>; IS THIS XOR FUNCTION<br>; NO, JUST STORE THE VALUE<br>; FUNCTION WITH FIRST HALF<br>; AND WITH SECOND HALF | | 19BD<br>19C2<br>19C7<br>19CA<br>19CC | 26: 88 A5 2000<br>26: 88 B5 2001<br>83 C7 50<br>FE CE<br>75 C1 | 4704 C<br>4705 C<br>4706 C<br>4707 C<br>4708 C | | MOV<br>MOV<br>ADD<br>DEC<br>JNZ | ES:[DI+2000H],AH<br>ES:[DI+2000H+1],AL<br>DI,80<br>DH<br>S9 | ; STORE IN SECOND PORTION<br>; POINT TO NEXT LOCATION<br>; KEEP GOING | | 19CE<br>19CF<br>19D0<br>19D1 | 47<br>47 | 4709 C<br>4710 C<br>4711 C<br>4712 C | | POP<br>POP<br>INC<br>INC | SI<br>DI<br>DI | ; RECOVER CODE PONTER<br>; RECOVER REGEN POINTER<br>; POINT TO NEXT CHAR<br>; MORE TO WRITE | | 1902<br>1904<br>1907 | E2 B7<br>E9 219E R | 4713 C<br>4714 C<br>4715 C<br>4716 C | GRAPHIC | LOOP<br>JMP<br>S_WRITE | S8<br>V_RET<br>ENDP | ; MORE TO WRITE | | | | 4717 C<br>4718 C<br>4719 C<br>4720 G<br>4721 C<br>4722 C | ENTRY | | AR TO WRITE<br>SPLAY PAGE<br>TRIBUTE/COLOR<br>UNT OF CHARS TO WRITE | | | 19D7<br>19D7<br>19DA<br>19DC<br>19DF<br>19E1<br>19E4<br>19E6<br>19E8 | 80 FC OF<br>72 OE<br>88 14F7 R<br>72 09<br>80 E3 85<br>8A E3<br>D0 E4<br>0A DC | 4724 C<br>4725 C<br>4726 C<br>4727 C<br>4728 C<br>4729 C<br>4730 C<br>4731 C<br>4732 C | GRX_WRT | | NEAR<br>DS:ABSO, ES:NOTHING<br>AH,OFH<br>NO_ADJ1<br>MEM_DET<br>NO_ADL1 | ; 640X350 GRAPHICS<br>; BASE CARD<br>; 85H, XOR C2 CO MASK<br>; EXPAND C0 TO C1, C2 TO C3<br>; BUILD 7(80H) + (0,3,C,F) | | 19EA<br>19EA<br>19EC<br>19F0<br>19F1<br>19F4<br>19F6 | 2A E4<br>F7 26 0485 R<br>50<br>E8 16BA R<br>8B F8<br>8B 2E 0485 R | 4734 C<br>4735 C<br>4736 C<br>4737 C<br>4738 C<br>4739 C<br>4740 C<br>4741 C<br>4742 C+ | NO_ADJ1 | | AH, AH POINTS ACCUR GI_AX BP, POINTS ES, (ADOODH DX, (ADOODH | ; ZERO ; OFFSET FONT TABLE BASE ; FONT TABLE DISPLACEMENT GET OFFSET INTO REGEN INTO DESTINATION BYTES PER CHAR ; REGEN SEGEMNT | | 19FF<br>1A03<br>1A04<br>1A06<br>1A08 | 8E C2<br>C5 36 010C R<br>58<br>03 F0<br>B6 03 | 4743 C+<br>4744 C<br>4745 C<br>4746 C<br>4747 C<br>4748 C | \$20A: | LDS<br>POP<br>ADD<br>MOV | ES,DX<br>SI,GRX_SET<br>AX<br>SI,AX<br>DH,3 | ; ADDRESSING TO FONTS<br>; RECOVER OFFSET<br>; CHARACTER IN TABLE | | 1A08<br>1A0B<br>1A0D<br>1A0F<br>1A12<br>1A15<br>1A18<br>1A18<br>1A18<br>1A1B<br>1A1E<br>1A21<br>1A23<br>1A24 | F6 C3 80<br>74 08 B2 CE<br>B8 0318<br>E8 0015 R<br>EB 1E 90<br>57 4<br>B8 020F<br>E8 0015 R<br>28 C0<br>51 88 020F<br>E8 0015 R | 4719 C<br>4750 C<br>4751 C<br>4752 C<br>4752 C<br>4754 C<br>4755 C<br>4756 C<br>4757 C<br>4758 C<br>4758 C<br>4756 C<br>4760 C<br>4760 C | NO_XOR: | TEST JZ MOV MOV CALL JMP PUSH MOV CALL SUB PUSH MOV CALL SUB MOV | BL_080H NO_XOR DL_GRAPH_ADDR AX, 0318H OUI_DX F_2 DI DL_SEQ_ADDR AX, 020FH OUI_DX AX AX AX AX CX, AX CX, AX CX, BY CX, BP | ; TEST FOR XOR ; ORAPHICS CHIP XOR ; SET REGISTER ; SET | | 1A26<br>1A27<br>1A2A<br>1A2A<br>1A2B<br>1A2F<br>1A30<br>1A32<br>1A33 | 1E 8 0CFE R AA 03 3E 044A R 4F 62 F8 1F 59 | 4763 C<br>4765 C<br>4766 C<br>4767 C<br>4767 C<br>4768 C<br>4769 C<br>4770 C<br>4771 C | S13A: | PUSH<br>CALL<br>STOSB<br>ADD<br>DEC<br>LOOP<br>POP<br>POP<br>POP | DS DDS DI, CRT_COLS DI S13A DS CX DI | ; ZERO REGEN BYTE<br>; NEXT BYTE OF BOX<br>; ADJUST<br>; NEXT BYTE<br>; RECOVER CHARACTER COUNT<br>; RECOVER REGEN POINTER | | 1A35<br>1A35<br>1A37<br>1A39<br>1A3B<br>1A3E<br>1A3F<br>1A40<br>1A41<br>1A43 | B2 C4<br>B4 02<br>8A C3<br>E8 0D15 R<br>57<br>53<br>51<br>8B DD<br>1E<br>E8 0CFE R | 4773 C<br>4774 C<br>4775 C<br>4776 C<br>4777 C<br>47778 C<br>47778 C<br>4778 C<br>4780 C<br>4781 C<br>4782 C<br>4783 C | F_2: | MOV<br>MOV<br>CALL<br>PUSH<br>PUSH<br>MOV<br>PUSH<br>CALL | DL_SEQ_ADDR AH, 02H AL, 8L OUT_DX BX CX BX BX BX DS DS DOS | SET MAP MASK FOR COLOR SET THE CHIP SAVE OFFSET IN REGEN SAVE COLOR VALUE SAVE CHACTER COUNT LOOP CONTROL, BYTES/CHAR SAVE FONT SEGMENT SET LOW RAM SEGMENT | | 1A47<br>1A4B<br>1A4C | 8B 0E 044A R<br>1F | 4784 C<br>4785 C<br>4786 C<br>4787 C<br>4788 C | S1K: | ASSUME<br>MOV<br>POP<br>ASSUME | DS: ABSO<br>CX, CRT_COLS<br>DS<br>DS: NOTHING | ; GET COLUMN COUNT<br>; RESTORE FONT SEGMENT<br>; WRITE OUT THE CHARACTER | ``` 8A 04 26: 8A 25 26: 88 05 46 03 F9 4B 75 F2 AL,DS:[SI] AH,ES:[DI] ES:[DI],AL SI DI,CX BX S1K ; CODE POINT LATCH DATA WRITE ONE BYTE OF FONT ; NEXT FONT POINT ; ONE ROW BELOW LAST POINT BYTES PER CHAR COUNTER ; DO NEXT ROW OF CHARACTER 4789 4790 4791 4792 4793 4794 4796 4797 MOV MOV INC ADD DEC JNZ 59 58 28 F5 5F 47 E2 A6 POP POP SUB POP INC LOOP CX BX SI,BP DI ; CHARACTER COUNT ; COLOR VALUE ; ADJUST PTR TO FONT TABLE ; RECEN POINTER ; NEXT CHAR POSN IN REGEN ; WRITE ANOTHER CHARACTER 1A5A 1A5B 1A5C 1A5E 1A5F 1A60 4801 520A B2 CE B8 0300 E8 0D15 R B2 C4 B8 020F E8 0D15 R E9 219E R DL, GRAPH_ADDR AX, 0300H OUT_DX DL, SEQ_ADDR AX, 020FH OUT_DX V_RET 1A62 1A64 1A67 1A6A 1A6C 1A6F 1A72 1A75 MOV MOV CALL MOV MOV CALL ; NORMAL WRITE, NO ROTATE : SET THE CHIP 4806 ; ENABLE ALL MAPS : SET THE CHIP 4808 JMP GRX_WRT ENDP SURTTI ;---- SET COLOR PALETTE 1A75 DS:ABS0 BYTE PTR ADDR_6845,0B4H M21 B INFO,2 M21_A 42H ASSUME CMP JE TEST 80 3E 0463 R B4 74 09 F6 06 0487 R 02 74 05 CD 42 1A75 1A7A 1A7C 1A81 1A83 1A85 1A88 1A88 1A88 1A90 1A93 1A96 1A9D 1A9D 1AA2 ; CALL VALID ONLY FOR COLOR ; SEE IF ITS THE OLD COLOR CARD ; IF NOT, HANDLE IT HERE ; OLD CODE CALL 4819 4820 4821 4822 4823 4824 JZ INT M21_B: F9 219F R .IMP V RET ; BACK TO CALLER 4825 4826 4827 4828 4829 4830 4831 4832 2B C0 8B E8 C4 3E 04A8 R 83 C7 04 26: C4 3D 8C C0 0B C7 74 01 45 AX,AX BP,AX DI,SAVE_PTR DI,44 DI,WORD PTR ES:[DI] AX,ES AX,DI NOT4AHB BP SUB MOV LES ADD LES MOV OR JZ INC NOT4AHB: E8 1DC0 R 0A FF 75 65 CALL OR JNZ PAL_INIT BH,BH M20 ;---- HANDLE BH = 0 HERE ; ALPHA MODES => BL = OVERSCAN COLOR ; GRAPHICS => BL = OVERSCAN AND BACKGROUND COLOR ;---- MOVE INTENSITY BIT FROM D3 TO D4 FOR COMPATIBILITY EMSITY BIT FROM BH, BL AL, CRT PALETTE AL, OEOH BL, OIFH AL, BL CRT PALETTE, AL BL, BH BH, O8H BH, O8H BH, OFH BH, OFH BL, O 8A FB AO 0466 R 24 EO 80 E3 1F OA C3 4850 4851 00 C3 A2 0466 R 8A DF F 80 E7 08 BA E8 B0 E5 EF 0A ED B8 E3 B0 TO F 0A DF 1AB0 1AB3 1AB5 1AB8 1ABA 1ABC 1AC1 1AC4 1AC6 1AC8 1ACB AL, CRT_MODE AL, 3 M21 1ADO AO 0449 R 1AD3 3C 03 1AD5 76 0E MOV CMP JBE ;---- GRAPHICS MODE DONE HERE (SET PALETTE O AND OVERSCAN) AH,0 AL,BL PAL_SET 1AD7 B4 00 1AD9 8A C3 1ADB E8 1D9F R MOV MOV BP,BP M21 ES:[DI],BL 1ADE OB ED 1AEO 74 03 1AE2 26: 88 1D OR 4878 4878 4880 4881 4882 4883 4884 4885 4886 4887 4888 4888 ;---- ALPHA MODE DONE HERE (SET OVERSCAN REGISTER) 1AE5 80 3E 044 1AE6 77 05 1AEC 80 0E9A F. 1AEF 72 07 1AEF 1 20 7 1AF1 1AF3 8A C3 1AF5 E8 1D9F F. 1AF8 0B ED 1A 421: CMP JA CALL JC SET_OVRSC: MOV MOV CALI 80 3E 0449 R 03 77 05 E8 0E9A R 72 07 CRT_MODE, 3 SET_OVRSC BRST_DET SKIP_OVRSC ; CHECK FOR AN ENHANCED MODE ; NO CHANCE ; SEE IF WE ARE ENHANCED ; THERE IS NO BORDER AH,011H AL,BL PAL_SET B4 11 8A C3 E8 1D9F R : OVERSCAN REGISTER : SET THE BORDER 4890 4891 4892 4893 4894 4895 4896 4897 4898 4899 4901 4902 4903 4904 4907 4908 4909 4911 4912 4913 4914 SKIP OVRSC: 0B ED 74 04 26: 88 5D 10 BP, BP M21Y ES:[DI][16D], BL OR JZ MOV BL,CH BL,O2OH CL,5 BL,CL MOV ``` ``` M20: 1809 80 3E 0449 R 03 180E 76 4A CRT_MODE, 3 1B10 1B13 1B15 1B18 1B1A 1B1C A0 0466 R 24 DF 80 E3 01 74 02 0C 20 MOV AND AND JZ OR AL,CRT_PALETTE AL,ODFH BL,1 M22 AL. 020H M22: A2 0466 R 24 10 0C 02 0A D8 B4 01 8A C3 E8 1D9F R CRT_PALETTE,AL AL,010H AL,2 BL,AL AH,1 AL,BL PAL_SET MOV AND OR OR 181F 1821 1823 1825 1827 1827 MOV MOV CALL 1B2C 1B2E 1B30 1B34 0B ED 74 04 26: 88 5D 01 OR JZ MOV BP, BP M22Y ES:[DI][1], BL M22Y 1B34 1B36 1B38 1B3A 1B3C FE C3 FE C3 B4 02 8A C3 E8 1D9F R INC MOV MOV CALL BL AH, 2 AL,BL PAL_SET 183F 1841 1843 1847 08 ED 74 04 26: 88 5D 02 OR JZ MOV BP, BP M27Y ES:[DI1[2].BL M27V+ 1847 1849 1848 1840 184F FE C3 FE C3 B4 03 8A C3 E8 1D9F R INC INC MOV MOV CALL BL BL AH, 3 AL, BL PAL_SET OR JZ MOV BP,BP M80 ES:[DI][3],BL 1B52 OB ED 1B54 74 04 1B56 26: 88 5D 03 185A 185A E8 1D87 R 185D E9 219E R M80: INCLUDE VDOT. INC ENTRY DX = ROW CX = COLUMN BH = PAGE : EXIT BX = OFFSET INTO REGEN AL = BIT MASK FOR COLUMN BYTE DOT_SUP_1 PROC NEAR 1B60 ;---- OFFSET = PAGE OFFSET + ROW * BYTES/ROW + COLUMN/8 ; ROM * BYTES/ROW ; SAVE COLUMN VALUE ; DIVIDE BY EIGHT TO ; DETERMINE THE BYTE THAT ; (8 BITS/ROYE) ; BYTE OFFSET INTO PAGE ; GET PAGE INTO BL ; ZERO ; CET PAGE INTO BL ; ZERO ; CET PAGE INTO BL ; ZERO ; CET PAGE INTO BL ; ZERO ; PAGE ZERO WORD PTR CRT_COLS CX CX,1 CX,1 CX,1 1B60 F7 26 044A R 1B64 51 1B65 D1 E9 1B67 D1 E9 1B69 D1 E9 MILL PUSH ADD MOV SUB MOV MOV JCXZ AX,CX BL,BH BH,BH CX,BX BX,CRT_LEN DS_2 03 C1 8A DF 2A FF 8B CB 8B 1E 044C R E3 04 DS_3: ADD LOOP ; BUMP TO NEXT PAGE ; DO FOR THE REST 59 8B D8 80 E1 07 B0 80 D2 E8 C3 CX BX,AX CL,07H AL,080H AL,CL ; RECOVER COLUMN VALUE ; REGEN OFFSET ; SHIFT COUNT FOR BIT MASK ; MASK BIT ; POSITION MASK BIT POP MOV AND MOV SHR 187E 1880 1883 1885 1887 1888 DOT_SUP_1 ENDP THIS SUBROUTINE DETERMINES THE REGEN BYTE LOCATION OF THE INDICATED ROW COLUMN VALUE IN GRAPHICS MODE. ENTITY OF THE INDICATED ROW COLUMN VALUE IN GRAPHICS MODE. OX = COLUMN VALUE (0-639) CX = COLUMN VALUE (0-639) EXIT - FIRST INTO REGEN BUFFER FOR BYTE OF INTEREST AL = MASK TO DITRIP OFF THE BITS OF INTEREST AL = MASK TO BITS TO RIGHT JUSTIFY THE MASK IN AH OH = # BITS IN RESULT R3 PROC NEAR PUSH BX PROC PUSH PUSH NEAR BX AX 1B88 1B88 53 1B89 50 ; SAVE BX DURING OPERATION ; WILL SAVE AL DURING OPERATION ;---- DETERMINE 1ST BYTE IN IDICATED ROW BY MULTIPLYING ROW VALUE BY 40 ;---- ( LOW BIT OF ROW DETERMINES EVEN/ODD, 80 BYTES/ROW MOV PUSH AND MUL 188A B0 28 188C 52 188D 80 E2 FE 1890 F6 E2 AL,40 DX ; SAVE ROW VALUE ; STRIP OFF DODDEVEN BIT ; AX HAS ADDRESS OF 1ST BYTE ; AX HAS ADDRESS OF 1ST BYTE ; RECOVER. ; RECOVER. ; RECOVER. ; EXEL FOR EVEN/ODD ; JUMP IF EVEN ROW ; EVEN ROW ; EVEN ROW TO LOCATION OF ODD ROWS ; EVEN ROW WITER TO SI ; ROVECER ALL VALUE ; COLUMN VALUE TO DX DL, OFEH DL 1892 1893 1896 1898 1898 189B 189B 189D DX DL,1 R4 AX,2000H 5A F6 C2 01 74 03 05 2000 POP TEST ADD SI,AX AX DX,CX 8B FO 58 8B D1 MOV ;---- DETERMINE GRAPHICS MODE CURRENTLY IN EFFECT SET UP THE REGISTERS ACCORDING TO THE MODE : CH = MASK FOR LOW OF COLUMN ADDRESS ( 7/3 FOR HIGH/MED RES) : ``` ``` C ; CL = # OF ADDRESS BITS IN COLUMN VALUE ( 3/2 FOR M/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 808/CDB FOR H/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 17/2 FOR H/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 17/2 FOR H/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 17/2 FOR H/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 17/2 FOR H/M) C ; BL = MASK TO SELECT BITS FROM POINTED BYTE ( 17/2 FOR H/M) C ; CL = # OF ADDRESS BYTE OF ALL O BB 02C0 B9 0302 80 3E 0449 R 06 72 06 BB 0180 B9 0703 1BA0 1BA3 1BA6 1BAB 1BAD 1BB3 22 FA ; ADDRESS OF PEL WITHIN BYTE TO CH ; SHIFT BY CORRECT AMOUNT ; INCREMENT THE POINTER ; GET THE # OF BITS IN RESULT TO DH 2A C9 ; LEFT JUSTIFY THE VALUE ; IN AL (FOR WRITE) ; ADD IN THE BIT OFFSET VALUE ; ON EXIT, CL HAS SHIFT COUNT ; TO RESTORE BITS ; GET MASK TO AH ; MOVE THE MASK TO CORRECT LOCATION ; RECOVER REG ; RETURN WITH EVERYTHING SET UP 1BCB BA B800 8E C2 5A 50 50 E8 1B88 R D2 E8 22 C4 26: 8A OC 5B 75 0D 76 0D 76 0D 76 0D 76 0D 76 0D 77 0D 78 0 1BD3 1BD6 1BD8 1BD9 1BDA ; SAVE DOT VALUE ; THICE ; THICE ; DETERMINE BYTE POSITION OF THE DOT ; SHIFT TO SET UP THE BITS FOR OUTPUT ; STIP OF THE OTHER BITS GET THE CURRENT BYTE GET THE CORNER FLAG IS IT ON FLAG ; SITON THE DOT ; YES, XOR THE DOT ; SET THE MASK TO REMOVE THE ; INDICATED BITS ; OR IN THE REW VALUE OF THOSE BITS ; FRITTE THE NEW VALUE OF THOSE BITS ; FRITTE THE BYTE IN MEMORY 26: 88 04 58 E9 219E R 1BFC 1BFC 1C01 1C03 1C06 1C08 1C0A 1C0C 1C10 1C10 1C11 1C13 1C16 1C18 1C18 1C1A 1C1C 80 3E 0449 R 0F 72 0D E8 14F7 R 72 08 24 85 8A E0 D0 E4 OA C4 ; EXPAND CO TO C1, C2 TO C3 ; BUILD ?(80H) + (0,3,C,F) 50 8B C2 E8 1B60 R B6 03 B2 CE B4 08 E8 0D15 R ; ROW VALUE ; BX=OFFSET, AL=BIT MASK ; GRAPHICS CHIP ; BIT MASK REGISTER ; SET BIT MASK 1C20 1C23 1C25 1C26 1C27 1C29 1C2C 1C30 1C32 1C35 1C38 1C38 1C3A 1C3C B2 C4 B4 02 B0 FF E8 0D15 R ``` ``` ; LATCH DATA ; ZERO ; BLANK THE DOT ; BLANK THE DOT ; SET THE COLOR MAP MASK ; SET THE COLOR VALUE ; VALUES 0-15 ; SET IT ; LATCH DATA ; WRITE VALUE ; SET THE DOT 26: 8A 07 2A C0 26: 88 07 AL,ES:[BX] AL,AL ES:[BX],AL 1C44 1C46 SUB WD B: 1C49 1C49 1C4B 1C4D 1C4F 1C51 1C57 1C57 B2 C4 B4 02 8A C5 24 0F E8 0D15 R 26: 8A 07 B0 FF 26: 88 07 DL, SEQ_ADDR AH, S_MAP AL, CH AL, OFH OUT_DX AL, ES: [BX] AL, OFFH ES: [BX], AL MOV MOV MOV AND CALL MOV MOV MOV NORMALIZE THE ENVIRONMENT E8 OD15 R B2 CE B4 O3 2A CO E8 OD15 R B4 O8 B0 FF E8 OD15 R E9 219E R OUT_DX DL,GRAPH_ADDR AH,G_DATA_ROT AL,AL OUT_DX AH,G_BIT_MASK AL,OFFH OUT_DX V_RET ENDP ; ALL MAPS ON ; GRAPHICS CHIPS ; XOR REGISTER ; NORMAL WRITES ; SET IT ; BIT MASK ; ALL BITS ON ; SET IT ; WRITE DOT DONE 1050 105F 1061 1063 1065 1068 MOV MOV SUB CALL MOV MOV CALL JMP WRITE_DOT_2 1072 RD S PROC NEAR PROC ASSUME PUSH PUSH SRLOAD DS: ABSO 1072 50 1073 52 ES, OAOOOH DX, OAOOOH ES, DX DX AX AX, DX DOT_SUP_1 CH, 7 CH, CL DX, DX AL, 0 BA A000 8E C2 5A 58 C2 E8 1B60 R B5 07 2A E9 2B D2 B0 00 C3 1C74 1C77 1C79 1C7A 1C7B 1C7D 1C80 1C82 1C84 1C86 1C88 1C89 MOV MOV POP POP MOV CALL MOV SUB SUB MOV RET ENDP RD_S PROC 1C89 1C89 1C8B 1C8D 1C8E 1C90 1C92 1C95 1C96 1C98 1C9E 1C9F 8A CD 84 04 52 86 03 82 CE E8 0D15 R 5A 26: 8A 27 D2 EC 80 E4 01 C3 RD 1S NEAR CL,CH AH,4 MOV MOV PUSH AH, 4 DX, 3 DH, 3 DL, GRAPH_ADDR OUT_DX DX AH, ES: [BX] AH, CL AH, 1 MOV MOV CALL POP MOV SHR AND RD_1S :---- READ DOT 1C9 F ASSUME CMP DS:ABSO CRT_MODE,7 R_1 80 3E 0449 R 07 1C9 F R_1 PROC NEAR DS: ABSO, ES: NOTHING XX, SS, OBBOOH DX, OBBOOH ES, DX R3 AL, ES: [SI] AL, AH AL, CH AL, CL V, RET ENDP READ_DOT 1046 ASSUME PUSH SRLOAD MOV MOV POP CALL MOV AND SHL MOV ROI 1CA6 52 BA B800 8E C2 5A E8 1B88 R 26: 8A 04 22 C4 D2 E0 8A CE D2 C0 E9 219E R 1CA7 1CAA 1CAC 1CAD ; DETERMINE BYTE POSITION OF DOT ; GET THE BYTE ; MASK OFF THE OTHER BITS IN THE BYTE ; LEFT JUSTIFY THE VALUE ; GET NUMBER OF BITS IN RESULT ; RIGHT JUSTIFY THE RESULT 1CAD 1CB0 1CB3 1CB5 1CB7 1CB9 1CBB 1CBE ROL JMP READ DOT 1CBE 1CBE 1CC3 1CC5 1CC8 80 3E 0449 R 0F 72 25 E8 14F7 R 72 20 CRT_MODE,OFH READ_DOT_2 MEM_DET READ_DOT_2 CMP JB CALL READ_DOT_1 ASSUME CALL CALL PROC NEAR DS: ABSO, ES: NOTHING RD. S RD. TS ; 2 MAPS 1CCA E8 1C72 R E8 1C89 R OA D4 D0 E4 D0 D4 B0 02 E8 1C89 R D0 E4 E9 219E R 1CCA 1CCD 1CD0 1CD2 1CD4 1CD6 OR SHL OR OR MOV CALL SHL SHL OR SHL OR MOV 1CDB 1CDD 1CDF 1CE1 1CE3 1CE5 1CE7 READ_DOT_1 READ_DOT_2 ASSUME CALL PROC NEAR DS:ABSO, ES:NOTHING RD_S 1CFA : 4 MAPS 1CEA 1CED 1CED 1CF0 1CF2 1CF4 1CF6 1CF8 1CFA 1CFC 1CFE E8 1C72 R E8 1C89 R 8A C8 D2 E4 OA D4 FE C0 3C 03 76 F1 8A C2 E9 219E R RD_1S CL,AL AH,CL DL,AH MOV SHL OR INC CMP JBE MOV JMP AL,3 RD_2A AL,DL V_RET ENDP READ_DOT_2 WRITE_TTY WRITE TELETYPE TO ACTIVE PAGE THIS INTERFACE PROVIDES A TELETYPE LIKE INTERFACE TO THE VIDEO CARD. THE INPUT CHARACTER IS WRITEN TO THE CURRENT CURSOR POSITION, AND THE CURSOR IS MOVED TO THE MEXT POSITION. IF THE CURSOR LEAVES THE LAST COLUMN OF THE FIELD, THE COLUMN IS SET ``` ``` TO ZERO, AND THE ROW VALUE IS INCREMENTED. IF THE ROW VALUE LEAVES THE FIELD, THE CURSOR IS PLACED ON THE LAST ROW, FIRST COLUMN, AND THE ENTITE SCREEN IS SCROLLED UP ONE LINE. WHEN THE SCREEN IS SCROLLED UP, THE ATTRIBUTE FOR FILLING THE NEWLOW BLANKED LINE IS READ FROM THE CURSOR POSITION ON THE PREVIOUS LINE BEFORE THE SCROLL, IN CHARACTER MODE. IN GRAPHICS MODE, THE O COLOR IS USED. (AH) = CURRENT CRT MODE (AL) = CHARACTER TO BE WRITTEN (AL) = CHARACTER TO BE WRITTEN (AL) = CHARACTER TO BE WRITTEN (AR) = CHARACTER TO BE WRITTEN (AR) = CHARACTER TO BE WRITTEN (BL) = FOREGROUND COLOR FOR CHAR WRITE IF CURRENTLY IN A GRAPHICS MODE EXIT ALL REGISTERS SAVED CS:CODE,DS:ABSO AX BH,ACTIVE_PAGE BX BL,BH BH,BH BX,1 DX,[BX + OFFSET CURSOR_POSN] BX 1D01 1D02 1D06 1D07 1D09 1D0B 1D0D 1D11 50 8A 3E 0462 R 53 8A DF 32 FF D1 E3 8B 97 0450 R 5B ; SAVE REGISTERS ; GET THE ACTIVE PAGE ; SAVE ; GET PAGE TO BL ; CLEAR HIGH BYTE ; *2 FOR WORD OFFSET ; CURSOR, ACTIVE PAGE ; RECOVER PUSH MOV PUSH MOV XOR SAL MOV POP -- DX NOW HAS THE CURRENT CURSOR POSITION ; IS IT CARRIAGE RETURN CAR RET IS TT A LINE FEED IS IT A BACKSPACE BACK_SPACE IS IT A BELL BELL BELL AL,0DH U9 AL,0AH U10 AL,08H U8 AL,07H U11 CMP JE CMP JE CMP JE CMP JE WRITE THE CHAR TO THE SCREEN AH, 10 CX, 1 10H ;---- POSITION THE CURSOR FOR NEXT CHAR DL DL,BYTE PTR CRT_COLS U7 DL,DL DH,ROWS U6 ; TEST FOR COLUMN OVERFLOW ; SET_CURSOR ; COLUMN FOR CURSOR ; SET_CURSOR_INC ;---- SCROLL REQUIRED SET_CPOS ;---- DETERMINE VALUE TO FILL WITH DURING SCROLL A0 0449 R 3C 04 72 06 2A FF 3C 07 75 06 JB SUB CMP JNE U2 BH, BH AL, 7 U3 U2: MOV INT MOV AH,8 10H BH,AH ; READ CHAR/ATTR ; STORE IN BH ; SCROLL-UP ; SCROLL-UP ; UPPER LEFT CORNER ; LOWER RIGHT ROW ; LOWER RIGHT COLUMN AX,601H CX,CX DH,ROWS DL,BYTE PTR CRT_COLS DL B8 0601 2B C9 8A 36 0484 R 8A 16 044A R FE CA MOV SUB MOV MOV DEC VIDEO-CALL-RETURN SCROLL UP THE SCREEN TTY-RETURN RESTORE THE CHARACTER RETURN TO CALLER SET-CURSOR-INC U4: INT 10H U5: U6: FE C6 INC ; NEXT ROW ; SET-CURSOR ; ESTABLISH THE NEW CURSOR ;---- BACK SPACE FOUND U8: ; ALREADY AT END OF LINE ; SET CURSOR ; NO -- JUST MOVE IT BACK ; SET_CURSOR ;---- CARRIAGE RETURN FOUND U9: ; MOVE TO FIRST COLUMN ; SET_CURSOR DL, DL U7 ;---- LINE FEED FOUND U10: 3A 36 0484 R 75 E8 EB BB ; BOTTOM OF SCREEN ; YES, SCROLL THE SCREEN ; NO, JUST SET THE CURSOR :---- BELL FOUND B3 02 E8 0D20 R EB DB ; SET UP COUNT FOR BEEP ; SOUND THE POD BELL ; TTY_RETURN ;---- CURRENT VIDEO STATE 1085 ASSUME MOV MOV MOV AND OR DS:ABSO AH,BYTE PTR CRT_COLS BH,ACTIVE_PAGE AL,INFO AL,080H AL,CRT_MODE 8A 26 044A R 8A 3E 0462 R AO 0487 R 24 80 OA 06 0449 R 1D85 1D89 1D8D 1D90 ; GET NUMBER OF COLUMNS ``` ``` DI SI CX CX DX DS ES BP 1D96 1D97 1D98 1D99 1D9A 1D9B 1D9C 1D9D 1D9E ; DISCARD BX SUBTTL 1D9F 1D9F 1DA0 1DA3 1DA4 1DA5 1DA7 1DA7 1DA6 1DAF 1DAF 1DB1 1DB2 1DB4 1DB5 1DB6 50 E8 OD05 R AX WHAT BASE AL,DX AL,D8H VR AX DL,ATTR_WRITE AL,AH DX,AL AL,AH DX,AL AL,O2OH DX,AL EC A8 08 74 FB 58 C0 86 C4 EE 86 C4 EE B0 20 EF B C3 IN TEST JZ POP MOV XCHG OUT XCHG OUT MOV OUT STI ; VERTICAL RETRACE NEAR PAL_INIT DL,ATTR_WRITE AL,020H DX,AL 1DB7 1DB7 1DBA 1DBC 1DBE 1DBF E8 1DC0 R B2 C0 B0 20 EE C3 E8 0D05 R EC C3 1DC5 F6 06 0487 R 02 1DCA 75 07 : IN MONOCHROME MODE ;---- HERE THE EGA IS IN A COLOR MODE 1DCC 1DD1 1DD3 1DD3 1DD5 1DD7 CMP JE 80 3E 0463 R B4 74 33 SET INDIVIDUAL REGISTER 2B ED C4 3E 04A8 R 83 C7 04 26: C4 3D 8C C0 0B C7 74 01 45 BP,BP DI,SAVE_PTR DI,4 DI,DWORD PTR ES:[DI] AX,ES AX,DI TLO_1 BP SUB LES ADD LES MOV OR JZ INC CALL MOV CALL CALL OR JZ MOV SUB ADD MOV 2B ED C4 3E 04A8 R 83 C7 04 26: C4 3D 8C C0 0B C7 74 01 45 BP,BP DI,SAVE_PTR DI,4 DI,DWORD PTR ES:[DI] AX,ES AX,DI TLO_2 BP 1E0D 1E0F 1E13 1E16 1E19 1E1B 1E1D 1E1F 1E20 PAL_INIT AH,011H AL,BH PAL_SET PAL_ON 1E2D 1E2F 1E31 1E34 BP,BP BM_OUT DI,O11H ES:[DI],BH OB ED 74 D5 83 C7 11 26: 88 3D SET 16 PALETTE REGISTERS AND OVERSCAN REGISTER 1E3E 1E 1E3F 06 ``` ``` 55554467889567899612355555556666667690712334556789801233456899912344567899590001335555555666606007 DI, SAVE_PTR DI, 4 DI, 5 DI, DWORD PTR ES:[DI] AX, ES C4 3E 04A8 R 83 C7 04 26: C4 3D 8C C0 0B C7 74 09 LES ADD LES MOV OR JZ ; ES:DI PTR TO PAL SAVE AREA POP PUSH MOV MOV DS DS SI,DX CX,17D ; PARAMETER ES ; PARAMETER OFFSET REP 1E59 1E59 07 1E5A 1F TLO_3: 1E5B 1E60 1E62 1E62 1E65 1E68 1E6A 1E6B 1E6E 1E70 1E75 1E78 1E78 BX,DX PAL_INIT AH,AH 26: 8A 07 E8 1D9F R FE C4 43 80 FC 10 72 F2 FE C4 26: 8A 07 E8 1D9F R E8 1D9F R E9 219E R BM 2A: PAL_SET AH BX AH,010H BM_2A AH AL,ES:[BX] PAL_SET PAL_ON V_RET INC INC CMP JB INC MOV CALL 1E7E 1E7E FE CC 1E80 75 29 DEC JNZ ; ---- TOGGLE INTENSIFY/BLINKING BIT 1E82 53 1E83 E8 0D5A R 1E86 83 C3 33 1E89 26: 8A 07 1E8C 5B PUSH CALL ADD MOV POP BX MAKE_BASE BX,010H + LN_4 AL,ES:[BX] BX ;---- ENABLE INTENSIFY CRT_MODE_SET,11011111B AL,0F7H BM_7 80 26 0465 R DF 24 F7 EB 0C 90 ;---- ENABLE BLINK 1E9F 1EA4 1EA6 80 0E 0465 R 20 0C 08 CRT_MODE_SET,020H AL,08H 1EA6 1EA8 B4 10 E8 1D9F R JMP V_RET 1EAB E9 219E R INCLUDE VCHGEN.INC SUBTIL VCHGEN.INC PAGE : ENTRY ENTRY AL = 0 USER SPECIFIED FONT 1 8 X 14 FONT 2 8 X 8 DOUBLE DOT BL = BLOCK TO LOAD 1EAE 1EAF 1EAF 1EB0 1EB1 1EB2 1EB3 PUSH ; SAVE THE INVOLVED REGS PUSH PUSH PUSH ASSUME CALL MOV PUSH CMP JE MOV JMP DS: ABSO DDS AL, CRT_MODE AX AL, 7 H14 CRT_MODE, 0BH SHORT H15 ; SET DATA SEGMENT ; GET THE CURRENT MODE ; SAVE IT ; IS THIS MONOCHROME ; MONOCHROME VALUES ; COLOR VALUES ; SKIP E8 OCFE R A0 0449 R 50 3C 07 74 07 C6 06 0449 R OB EB 05 1EB4 1EB7 1EBA 1EBB 1EBD 1EBF 1EC4 1EC6 1EC6 1ECB 1ECB 1ECB 1ECE H14: C6 06 0449 R OC MOV CRT_MODE,OCH ; MONOCHROME VALUES H15: E8 ODAB R E8 OCFE R 58 A2 O449 R CALL CALL POP MOV SET_REGS DDS ; RESET THE DATA SEGMENT ; RECOVER OLD MODE VALUE ; RETURN TO LOW MEMORY DDS AX CRT_MODE,AL 1ED2 1ED5 1ED6 1ED7 1ED8 1ED9 1EDA POP POP POP POP POP ; RESTORE REGS THAT WERE ; USED BY THE MODE SET : ROUTINES OA CO 74 17 OE 07 28 D2 B9 0100 FE C8 75 07 B7 0E BD 0000 E ; SET FLAGS ; USER SPECIFIED FONT ; SET SEGMENT TO ; THIS MODULE ; ZERO OUT START OFFSET ; CHAR COUNT (FULL SET) ; HIGH SEARMETER ; BYTES PER CHARACTER ; B X 14 TABLE OFFSET ; STORE IT 1EDB 1EDD OR JZ PUSH POP SUB MOV DEC JNZ MOV MOV JMP 1EDF 1EE0 1EE1 1EE3 1EE6 1EE8 1EEA 1EEC 1EEF ; 8 X 8 FONT ; ROM 8 X 8 DOUBLE DOT 1EF1 B7 08 1EF3 BD 0000 E BH,8 BP,OFFSET CGDDOT ; ALPHA CHARACTER GENERATOR LOAD : ``` ``` ENTRY ES:BP - POINTER TO TABLE CX - COUNT OF CHARS CY - COUNT OF CHARS BH - BYTES PER CHARACTER BL - MAP 2 BLOCK TO LOAD ES DS DX ES, OAOOOH ES, DX DX CX CL, 5 DX, CL CX BL, BL H3 ; RECOVER REGISTER ; MULTIPLY BY OZOH SINCE ; MAXIMUM BYTES PER ; CHARACTER IS 32D=020H ; RECOVER ; WHICH 16K BLOCK TO LOAD ; BLOCK ZERO ; INCREMENT TO NEXT BLOCK ; ANY MORE ; DO ANOTHER ADD DEC JNZ DX,04000H BL H4 BYTES PER CHARACTER ZERO OFFSET INTO MAP OFFSET INTO TABLE CHARACTER COUNT ; SAVE CHARACTER COUNT ONE ENTIRE CHARACTER AT A TIME ADJUST OFFSET NEXT CHARACTER POSITION RECOVER CHARACTER COUNT DO THE REST 51 8B C8 F3/ A4 2B F8 83 C7 20 59 E2 F3 PUSH MOV REP SUB ADD POP LOOP CX CX,AX MOVSB DI,AX DI,020H CX LD RFT DS:ABSO DDS POINTS,AX DX,ADDR_6845 CRT_MODE,7 H11A AH,C_UNDERLN_LOC OUT_DX ASSUME CALL MOV MOV CMP JNE MOV CALL E8 OCFE R A3 0485 R 8B 16 0463 R 80 3E 0449 R 07 75 05 B4 14 E8 0D15 R ; SET LOW MEMORY SEGMENT ; GET BYTES/CHARACTER : CRTC REGISTER ; R14H ; SET THE UNDERLINE LOC DEC MOV CALL DEC AL AH,C_MAX_SCAN_LN OUT_DX AL ; POINTS - 1 ; RO9H ; SET THE CHARACTER HEIGHT ; POINTS - 2 FE C8 B4 09 E8 0D15 R FE C8 ; CURSOR START ; CURSOR END ; ADJUST END ; SET C_TYPE BIOS CALL ; SET THE CURSOR 8A E8 8A C8 FE C1 B4 O1 CD 10 MOV MOV INC MOV INT CH, AL CL, AL CL AH, 1 10H 1F48 1F4A 1F4C 1F4E 1F50 8A 1E 0449 R B8 015E 80 FB 03 77 08 E8 0E9A R 72 03 B8 00C8 MOV MOV CMP JA CALL ; GET THE CURRENT MODE ; MAX SCANS ON SCREEN ; 640X200 ALPHA MODES ; MUST BE 350 BL,CRT_MODE AX,350D BL,3 H11 BRST_DET H11 JC MOV ; SET FOR 200 ; SET FOR 200 PREPARE TO DIVIDE MAX ROWS ON SCREEN ADJUST SAVE ROWS READJUST CLEAR ADJUST CREAR ROWS-COLUMNS SET CHARACTER ROWS ADJUST ROWS-COLUMNS SET CREAR ROWS-CREAR ADJUST ROWS-COLUMNS SET CREAR ROWS-CREAR ADJUS 99 177 36 0485 R 184 R 185 C 1 CWD DIV DEC MOV INC SUB MUL DEC MOV CALL MOV INC SHL ADD MOV LADD MOV LADD ;---- LOADABLE CHARACTER GENERATOR ROUTINES AL,010H AH11_ALPHA1 ; CHECK PARAMETER ; NEXT STAGE ;---- ALPHA MODE ACTIVITY HERE AL, 03H H1 CH GEN SET_REGS PH_5 DS: ABSO DDS: CASC CX, CURSOR_MODE AH, 1 10H V_RET CMP JAE CALL CALL CALL ASSUME CALL 3C 03 73 17 E8 1EAE R E8 0DAB R E8 0E96 R ; RANGE CHECK ; NEXT STAGE ; SET THE CHAR GEN : VIDEO ON ; SET THE DATA SEGMENT ; GET THE MODE ; SET C_TYPE ; EMULATE CORRECT CURSOR ; RETURN TO CALLER E8 OCFE R 8B OE 0460 R B4 01 CD 10 E9 219E R ;---- SET THE CHARACTER GENERATOR BLOCK SELECT REGISTER H2 DH, 3 DL, SEQ_ADDR : NOT IN RANGE : SEQUENCER ; AH=S_RESET, AL=1 AX,1 OUT DX ; CHAR BLOCK REGISTER ; GET THE VALUE ; SET IT AH,S_CGEN AL,BL OUT_DX MOV ``` ``` ; AH=S_RESET, AL=3 AX,3 OUT_DX H2: E9 219E R ; RETURN TO CALLER 1FD3 SUB CMP JA PUSH PUSH CALL POP MOV OR MOV JZ MOV CMP JNE MOV ; LOAD THE CHAR GEN RESTORE CALLING PARAMETER USER MODE DO NOT SET BYTES/CHAR 8 X 8 FONT IS THE CALL FOR MONOC NO, LEAVE IT AT 8 MONOC SET ; CLEAR UPPER BYTE : CONTINUE 2A E4 E9 1F29 R ;---- GRAPHICS MODE ACTIVITY HERE 1FFD DS:ABSO AL,030H AH11_INFORM AL,020H F10 ;---- COMPATIBILITY, UPPER HALF GRAPHICS CHARACTER SET ASSUME SRLOAD SUB MOV CLI MOV MOV STI DS:ABSO DS,O DX,DX DS,DX 2B D2 8E DA FA 2005 2007 2009 200A 200E 2012 2013 2013 2016 WORD PTR EXT_PTR , BP WORD PTR EXT_PTR + 2 . ES F11: E9 219E R JMP V_RET ASSUME PUSH SRLOAD SUB MOV POP JA DEC JZ PUSH POP DEC JNZ MOV MOV JMP 2016 52 22 2B D2 8E DA 5A 3C 03 777 F3 FE C8 74 14 0E 07 FE C8 75 08 B9 0000 EB 06 EB 06 AL,03H F11 ; RANGE CHECK F11 AL F19 CS ES AL F13 CX,140 BP,OFFSET CGMN SHORT F19 MOV MOV B9 0008 BD 0000 E CX,8 BP,OFFSET CGDDOT ; ROM 8 X 8 DOUBLE DOT CLI MOV MOV STI ASSUME CALL MOV MOV MOV OR JNZ MOV JMP WORD PTR GRX_SET , BP WORD PTR GRX_SET + 2 , ES DS:ABSO DDS POINTS,CX AL,BL BX,OFFSET RT AL,AL DR_3 AL,DL DR_1 E8 OCFE R 89 OE 0485 R 8A C3 BB 2067 R 0A C0 75 05 8A C2 EB 09 90 2042 2045 2049 2048 2052 2052 2057 2057 2058 205D 205D 205F 205F 205F 205F 205F 205F DR_3: DR_2: 2E: D7 XLAT CS:RT FE C8 A2 0484 R E9 219E R DEC MOV JMP LABEL DB BYTE 00D, 14D, 25D, 43D 00 OE 19 2B ;---- INFORMATION RETURN DONE HERE AH11_INFORM: 206B DS:ABSO AL,030H F6 206B 206D 206F 206F 2072 2072 2076 207A 207D 207F F5: E9 219E R JMP V_RET 8B 0E 0485 R 8A 16 0484 R 80 FF 07 77 F0 80 FF 01 77 18 MOV MOV CMP JA CMP JA CX, POINTS DL, ROWS BH, 7 F5 BH, 1 F7 ASSUME PUSH SRLOAD SUB MOV POP 2084 52 DX DS,0 DX,DX DS,DX DX 2085 2087 2089 ``` ``` 0A FF 75 07 C4 2E 007C R EB 1A 90 BH, BH F9 BP, EXT_PTR INFORM_OUT 208A 208C 208E JNZ LES JMP 208E 2092 2095 2095 2099 F9: C4 2E 010C R BP,GRX_SET HANDLE BH = 2 THRU BH = 5 HERE RETURN ROM TABLE POINTERS 2000 ASSUME DS: ABSO SUB BH, 2 MOV BL, BH SUB BH, BH SAL BX, 1 ADD BX, OFFSET TBL_5 MOV BP, CS: [BX] PUSH CS 80 EF 02 8A DF 2A FF D1 E3 81 C3 20B7 R 2E: 8B 2F 0E 07 209C 209F 20A1 20A3 20A5 20A9 20AC 20AE 20AE 20AF 20B0 20B1 INFORM OUT: DI SI BX AX AX DS AX ; DISCARD SAVED CX : DISCARD SAVED DX 20B1 20B2 20B3 20B4 20B5 20B6 ; DISCARD SAVED ES ;---- TABLE OF CHARACTER GENERATOR OFFSETS 20B7 20B7 20B9 20BB 20BD WORD OFFSET CGMN OFFSET CGDDOT OFFSET INT_1F_1 OFFSET CGMN_FDG LARFI 0000 E 0000 E 0000 E DW DW DW SUBTTL ;---- ALTERNATE SELECT 20BF ASSUME CMP JB JE CMP JE JMP DS:ABS0 BL,010H ACT_1 ACT_3 BL,020H ACT_2 V_RET 80 FB 10 72 51 74 1B 80 FB 20 74 03 E9 219E R 20BF : RETURN ACTIVE CALL 2002 2004 2006 2009 2008 2008 ; ALTERNATE PRINT SCREEN ACT_2: SRLOAD DS,0 DX,DX DS,DX 28 D2 8E DA FA C7 06 0014 R 21A7 R 8C 0E 0016 R FB E9 219E R 20CE 20D0 20D2 20D3 20D9 20DD 20DE 20E1 20E1 20E5 20E8 SUB MOV CL I MOV MOV STI JMP WORD PTR INT5_PTR, OFFSET PRINT_SCREEN WORD PTR INT5 PTR+2. CS V_RET ACT_3: 8A 3E 0487 R 80 E7 02 D0 EF MOV BH, INFO . LOOKING FOR MONOC BIT ; ISOLATE ; ADJUST A0 0487 R 24 60 B1 05 D2 E8 8A D8 20EA 20ED 20EF 20F1 20F3 AL, INFO AL, 01100000B CL, 5 AL, CL BL, AL ; LOOKING FOR MEMORY ; MEMORY BITS ; SHIFT COUNT ; ADJUST MEM VALUE ; RETURN REGISTER MOV AND CL, INFO_3 CH, CL CL, OFH CH, 1 CH, 1 CH, 1 CH, 1 CH, 1 CH, 1 8A OE 0488 R 8A E9 80 E1 OF DO ED DO ED DO ED DO ED BO ED 80 E5 OF 20F5 20F9 20FB 20FE 2100 2102 2104 2106 MOV MOV AND SHR SHR ; FEATURE/SWITCH ; DUPLICATE IN CH ; MASK OFF SWITCH VALUE ; MOVE FEATURE VALUE : MASK IT 2109 210A 210B 210C 210D 5F 5A 5A 5A 1F 07 5D CF POP POP POP POP POP POP POP IRET DI SI DX DX DX DX DS ES 60056 60077 60088 60110 60123 60111 60123 60144 60156 60200 60210 60200 60200 60200 60200 60200 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 60310 2100 210E 210F 2110 2111 2112 2112 2115 2115 2115 AH12_X: E9 219E R JMP : RETURN TO CALLER ACT_1: STR_OUTZ: JMP F9 219F R ; RETURN TO CALLER V_RET ;---- WRITE STRING 3C 04 73 F9 E3 F7 53 BA DF 2A FF D1 E3 8B B7 0450 R 5B 2118 2118 211A 211C 211E 211F 2121 2123 2125 2129 212A AL,04 STR_OUTZ STR_OUTZ BX BL,BH BH,BH ; RANGE CHECK : INVALID PARAMETER JAE JCXZ PUSH MOV SUB SAL MOV POP PUSH ; SAVE REGISTER ; GET PAGE TO LOW BYTE BX,1 SI,[BX + OFFSET CURSOR_POSN] BX SI ; *2 FOR WORD OFFSET ; GET CURSOR POSITION ; RESTORE ; CURRENT VALUE ON STACK 50 B8 0200 CD 10 58 AX AX,0200H 10H AX 212B 212C 212F 2131 2132 2132 2133 2135 2136 2136 2136 2140 2144 PUSH MOV INT POP ; SET THE CURSOR POSITION 51 53 50 86 E0 26: 8A 46 00 45 3C 0D 74 3D 3C 0A 74 39 3C 08 STR_1: CX BX AX AH, AL AL, ES:[BP] BP PUSH PUSH ; GET THE CHAR TO WRITE BP' AL,ODH STR_CR_LF AL,OAH STR_CR_LF AL,O8H ``` ``` 74 35 3C 07 74 31 B9 0001 80 FC 02 72 05 26: 8A 5E 00 45 STR_CR_LF AL,07H STR_CR_LF CX,1 AH,2 DO_STR BL_ES:[BP] BP 2148A 2148A 2145A 2145A 2155B 2155B 2155B 2155B 2155B 2155B 2155B 2155B 2157B 2177A 2177B B4 09 CD 10 FE C2 3A 16 044A R 72 11 3A 36 0484 R 75 07 B8 0EOA CD 10 FE CE AH,09H 10H 10L 10L,BYTE PTR CRT_COLS STR 2 DH,ROWS STR 3 AX,0EOAH 10H DH MOV INT INC CMP JB CMP JNE MOV INT DEC B4 0E CD 10 8A DF 2A FF D1 E3 8B 97 0450 R AH, OEH 10H BL, BH BH, BH BX, 1 DX,[BX + OFFSET CURSOR_POSN] POP CMP JE CMP JE MOV INT AL,1 STR_OUT AL,3 STR_OUT AX,0200H 10H ; SET CURSOR POSITION INCLUDE VPRSC.INC SUBTTL VPRSC.INC PAGE EITHER PRINT SCREEN HAS NOT BEEN CALLED OR UPON RETURN FROM A CALL THIS INDICATES A SUCCESSFUL OPERATION PRINT SCREEN IS IN PROGRESS ERROR ENCOUNTERED DURING PRINTING CS: CODE, DS: ABSO PROC FAR 21A7 21A7 21A8 21A9 21AA 21AC 21AC 21AD 21BO 21B5 21B7 21BC 21BE ; MUST RUN WITH INTS ENABLED ; MUST USE 50:0 FOR DATA ; AREA STORAGE ; SEE IF PRINT ALREADY IN PROGRESS JUMP IF PRINT IN PROGRESS INDICATE PRINT NOW IN PROGRESS WILL REQUEST THE CURRENT MODE INDICATE OF THE COLUMNS/LINE INDICATE OCCUMNS/LINE INDICATE OCCUMNS/LINE INDICATE OCCUMNS/LINE THIS POINT WE KNOW THE COLUMNS/LIRE ARE IN AX AND THE MCK KNOW THE COLUMNS/LIRE ARE IN AX AND THE MCK CAP APPL CARBON S AX BX X, CX, DX PUSHED [AL] HAS VIDEO MODE MOV CL, AN MOV CL, AN MOV CH, ROWS ; WILL MAKE USE OF [CX] REG TO MOV CH, ROWS ; CONTROL ROW & COLUMNS COLL CRL CRL ; CAR RETURN LINE FEED ROUTINE PUSH CX ; SAVE SCREEN BOUNDS MOV AH, 3 ; WILL NOW READ THE CURSOR, INT 10H ; AND PRESERVE THE MOSTION INT 10H ; AND PRESERVE THE MOSTION XOR DX, DX : RECALL [BH] EVI SUAL PAGE XOR DX, DX : SET CURSOR POSITION TO [0,0] THE LOOP FOO READ EACH CURSOR POSITION TO RIZO : SCREEN AND PRINT. 8A CC 8A 2E 0484 R FE C5 E8 2220 R 51 84 03 CD 10 59 52 33 D2 21C0 21C2 21C6 21C8 21CB 21CC 21CE 21D0 21D1 21D2 21D4 21D4 21D6 21D8 21DA 21DC ; TO INDICATE CURSOR SET REQUEST ; NEW CURSOR POS ESTABLISHED ; TO INDICATE READ CHARACTER ; CHARACTER NOW IN [AL] ; SEE IF VALID CHAR B4 02 CD 10 B4 08 CD 10 OA CO ``` ``` ; JUMP IF VALID CHAR : MAKE A BLANK ; MAKE A BLANK SAVE CURSOR POSITION INDICATE PRINTER 1 TO INDICATE PRINTER 1 TO INDICATE PRINT CHAR IN [AL] PRINT THE CHARACTER RECALL CURSOR POSITION TEST FOR PRINTER ERROR JUMP IF ERROR DETECTED ADVANCE AT ON EACH COLUMN IF NOT PROCEED LINE IF NOT PROCEED BACK TO COLUMN 0 [AN] -0 SAVE NEED CARRIAGE RETURN RECALL CURSOR POSITION ADVANCE TO NEXT LINE FINISHED IF NOT CONTINUE 52 20 52 33 D2 32 E4 CD 17 5A CA 29 FE C2 3A CA 75 D2 8A E2 52 2220 R FE C6 3A EE 75 D0 PR115: PUSH XOR XOR INT POP TEST JNZ CMP JNZ XOR PUSH CALL POP INC CMP JNZ DX DX, DX AH, AH 17H DX AH, 029H ERR10 DL CL, DL PRI10 DL, DL AH, DL DX CRLF DX DX AH,2 10H STATUS_BYTE,0 SHORT EXIT RECALL CURSOR POSITION TO INDICATE CURSOR SET REQUEST CURSOR POSITION RESTORED INDICATE FINISHED EXIT THE ROUTINE 5A B4 02 CD 10 C6 06 0500 R 00 EB 0A POP MOV INT MOV ; GET CURSOR POSITION ; TO REQUEST CURSOR SET ; CURSOR POSITION RESTORED ; INDICATE ERROR 5A B4 02 CD 10 C6 06 0500 R FF DX AH,2 10H STATUS_BYTE,0FFH POP POP POP POP POP POP POP RET PRINT_SCREEN ; RESTORE ALL THE REGISTERS USED CARRIAGE RETURN, LINE FEED SUBROUTINE CRLF PRINTER O WILL NOW SEND INITIAL CR, LF TO PRINTER AL,ODH 17H AH,AH AL,OAH 17H TO PRINTER CR SEND THE LINE FEED NOW FOR THE CR LF SEND THE CARRIAGE RETURN 2224 2226 2228 222A 222C 222E 222F MOV INT XOR MOV INT RET CRLF SUBTTL 222F CODE ENDS PAGE, 120 SUBTIL MONOCHROME CHARACTER GENERATOR SEGMENT PUBLIC PUBLIC GOMN LABEL BYTE nnnn CODE იიიი COMN ; BW 8*14 PATTTERN 000H,000H,000H,000H,000H; TOP_HALF_00 0000 DB 8 9 10 11 12 13 14 15 16 17 000H,000H,000H,000H,000H,000H ; BOTTOM_HALF 00 000H,000H,07EH,081H,0A5H,081H,0BDH ; TH_01 DB DB 099H,081H,07EH,000H,000H,000H ; BT_01 000H,000H,07EH,0FFH,0DBH,0FFH,0FFH,0C3H ; TH_02 DB DB 00 00 7E FF DB FF FF FF FF G3 7E FF G4 0E7H,0FFH,07EH,000H,000H,000H ; BT_02 000H,000H,000H,06CH,0FEH,0FEH,0FEH,0FEH; TH_03 07CH,038H,010H,000H,000H,000H ; BT_03 DB DB 038H,010H,000H,000H,000H,000H ; BT_04 000H,000H,018H,03CH,03CH,0E7H,0E7H,0E7H; TH_05 018H,018H,03CH,000H,000H,000H ; BT_05 000H,000H,018H,03CH,07EH,0FFH,0FFH,07EH ; TH_06 DB DB 018H,018H,03CH,000H,000H,000H ; BT_06 000H,000H,000H,000H,018H,03CH,03CH ; TH_07 018H,000H,000H,000H,000H,000H ; BT_07 0FFH,0FFH,0FFH,0FFH,0FFH,0E7H,0C3H,0C3H ; TH_08 DB DB 0E7H,0FFH,0FFH,0FFH,0FFH ; BT_08 000H,000H,000H,000H,03CH,066H,042H,042H ; TH_09 066H,03CH,000H,000H,000H,000H ; BT_09 0FFH,0FFH,0FFH,0C3H,099H,0BDH,0BDH ; TH_0A 0086 008C FF FF FF FF FF C3 99 B0 B0 99 C3 FF FF FF FF 00 00 1E 0E 1A 32 78 CC CC CC 78 00 00 00 00 00 3C 66 66 66 3C 18 7E 18 18 00 00 00 00 00 3F 33 3F 30 099H,0C3H,0FFH,0FFH,0FFH,0FFH ; BT_0A 000H,000H,01EH,00EH,01AH,032H,078H,0CCH ; TH_0B 0094 009A DB DB ОССН,ОССН,078H,000H,000H,000H ; ВТ_ОВ 000H,000H,03CH,066H,066H,03CH,018H ; ТН_ОС DB DB 07EH,018H,018H,000H,000H,000H ; BT_OC 000H,000H,03FH,033H,03FH,030H,03OH,03OH; TH_OD 00 00 3F 33 3F 30 30 30 70 F0 E0 00 00 00 00 00 7F 63 7F 63 63 63 67 E7 E6 C0 00 00 00 00 18 18 DB 3C E7 3C DB 18 18 00 00 00 070H, 0F0H, 0E0H, 000H, 000H, 000H ; BT_0D 000H, 000H, 07FH, 063H, 07FH, 063H, 063H, 063H ; ТН_0E 00BE 00C4 067H,0E7H,0E6H,0C0H,000H,000H ; BT_0E 000H,000H,018H,018H,0DBH,03CH,0E7H,03CH ; TH_0F OODA DB ODBH, 018H, 018H, 000H, 000H, 000H 00 00 80 C0 E0 F8 FE F8 E0 C0 80 00 00 00 00 00 02 06 0E 3E FE 3E 0E 06 02 00 00 00 00 00 18 3C 7E 18 7E 3C 18 00 00 00 00 00 66 66 66 66 00F0 DB 000H,000H,080H,0C0H,0E0H,0F8H,0FEH,0F8H ; TH_10 0E0H,0C0H,080H,000H,000H,000H ; BT_10 000H,000H,002H,006H,00EH,03EH,0FEH,03EH ; TH_11 DB DB 00EH,006H,002H,000H,000H,000H ; BT_11 000H,000H,018H,03CH,07EH,018H,018H,018H; TH_12 07EH, 03CH, 018H, 000H, 000H, 000H ; BT_12 ``` | 0112<br>0118 | 66 66<br>00 66 66 00 00 00<br>00 00 7F DB DB DB | 66<br>67<br>68 | DB<br>DB | 000H,066H,066H,000H,000H,000H ; ВТ_13<br>000H,000H,07FH,0DBH,0DBH,0DBH,07BH,01BH ; ТН_14 | | |----------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0120<br>0126 | 7B 1B<br>1B 1B 1B 00 00 00<br>00 7C C6 60 38 6C<br>C6 C6 | 69<br>70<br>71<br>72<br>73<br>74<br>75<br>76<br>77<br>78<br>79<br>80 | DB<br>DB | 01BH,01BH,01BH,000H,000H,000H ; BT_14<br>000H,07CH,0C6H,060H,038H,06CH,0C6H,0C6H ; TH_15 | | | 012E<br>0134 | C6 C6<br>6C 38 0C C6 7C 00<br>00 00 00 00 00 00 | 72<br>73<br>74 | DB<br>DB | 06CH,038H,00CH,0C6H,07CH,000H ; BT_15<br>000H,000H,000H,000H,000H,000H,000H ; TH_16 | | | 013C<br>0142 | 00 00<br>FE FE FE 00 00 00<br>00 00 18 3C 7E 18 | 75<br>76<br>77 | DB<br>DB | OFEH, OFEH, OFEH, 000H, 000H, 000H ; BT_16<br>000H, 000H, 018H, 03CH, 07EH, 018H, 018H, 018H ; TH_17 | | | 014A<br>0150 | 18 18<br>7E 3C 18 7E 00 00<br>00 00 18 3C 7E 18 | 78<br>79<br>80 | DB<br>DB | 07EH,03CH,018H,07EH,000H,000H ; BT_17<br>000H,000H,018H,03CH,07EH,018H,018H,018H ; TH_18 | | | 0158<br>015E | 18 18<br>18 18 18 00 00 00<br>00 00 18 18 18 18 | 81<br>82<br>83 | DB<br>DB | 018H, 018H, 018H, 000H, 000H, 000H ; BT_18<br>000H, 000H, 018H, 018H, 018H, 018H, 018H ; TH_19 | | | 0166<br>016C | 18 18<br>7E 3C 18 00 00 00<br>00 00 00 00 18 0C | 84<br>85<br>86 | DB<br>DB | 07EH, 03CH, 018H, 000H, 000H, 000H<br>000H, 000H, 000H, 000H, 00CH, 0FEH, 00CH; TH_1A | | | 0174<br>017A | FE OC<br>18 00 00 00 00 00 | 87<br>88 | DB<br>DB | 018H,000H,000H,000H,000H,000H ; BT_1A<br>000H,000H,000H,000H,030H,060H,0FEH,060H ; TH_1B | | | 0182<br>0188 | 00 00 00 00 30 60<br>FE 60<br>30 00 00 00 00 00<br>00 00 00 00 00 C0 | 89<br>90<br>91<br>92 | DB<br>DB | 030H,000H,000H,000H,000H,000H ; BT_1B<br>000H,000H,000H,000H,000H,0COH,0COH,0COH ; TH_1C | | | 0190<br>0196 | CO CO<br>FE 00 00 00 00 00 | 93<br>94 | DB<br>DB | 0FEH,000H,000H,000H,000H,000H ; BT_1C<br>000H,000H,000H,000H,000H,00CH,0FEH,06CH ; TH_1D | | | 0196<br>019E<br>01A4 | FE 6C<br>28 00 00 00 00 00 | 93<br>94<br>95<br>96<br>97 | DB<br>DB<br>DB | 000H,000H,000H,000H,000H,000H<br>028H,000H,000H,000H,000H,000H<br>000H,000H,00 | | | 01AC<br>01B2 | 7C 7C | 98<br>99<br>100 | DB | 000H,000H,000H,010H,038H,038H,07CH,07CH; TH_1E<br>0FEH,0FEH,000H,000H,000H,000H ; BT_1E<br>000H,000H,000H,0FEH,0FEH,07CH,07CH,038H; TH_1F | | | 01B2<br>01BA | 00 00 00 FE FE 7C<br>7C 38<br>38 10 00 00 00 00 | 101<br>102<br>103 | DB<br>DB | 000H,000H,000H,0FEH,0FEH,07CH,07CH,038H; TH_1F<br>038H,010H,000H,000H,000H,000H; BT_1F | | | 0100 | 00 00 00 00 00 00 | 104<br>105<br>106 | DB | 000H,000H,000H,000H,000H,000H,000H; ТН_20 SP | | | 01C8<br>01CE | 00 00 00 00 00 00<br>00 00 18 3C 3C 3C | 107<br>108 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_20 SP<br>000H,000H,018H,03CH,03CH,03CH,018H,018H ; TH_21 ! | | | 01D6<br>01DC | 00 18 18 00 00 00<br>00 66 66 66 24 00 | 109<br>110<br>111 | DB<br>DB | 000H,018H,018H,000H,000H,000H ; BT_21 ! 000H,066H,066H,066H,024H,000H,000H,000H ; TH_22 " | | | 01E4<br>01EA | 00 00<br>00 00 00 00 00 00<br>00 00 6C 6C FE 6C | 112<br>113<br>114 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_22 "<br>000H,000H,06CH,06CH,0FEH,06CH,06CH,06CH; TH_23 # | | | 01F2<br>01F8 | 6C 6C<br>FE 6C 6C 00 00 00<br>18 18 7C C6 C2 C0<br>7C 06 | 115<br>116<br>117 | DB<br>DB | OFEH,06CH,06CH,000H,000H,000H ; BT_23 # 018H,018H,07CH,0C6H,0C2H,0C0H,07CH,006H ; TH_24 \$ | | | 0200<br>0206 | 86 C6 7C 18 18 00<br>00 00 00 00 C2 C6 | 118<br>119<br>120 | DB<br>DB | 086H,0C6H,07CH,018H,018H,000H ; BT_24 \$ 000H,000H,000H,000H,0C2H,0C6H,00CH,018H ; TH_25 '% | | | 020E<br>0214 | 0C 18<br>30 66 C6 00 00 00<br>00 00 38 6C 6C 38 | 121<br>122<br>123 | DB<br>DB | 030H,066H,0C6H,000H,000H,000H<br>000H,000H,038H,06CH,06CH,038H,076H,0DCH; TH_26 & | | | 021C<br>0222 | 76 DC<br>CC CC 76 00 00 00 | 124<br>125<br>126 | DB<br>DB | OCCH, OCCH, 076H, 000H, 000H, 000H ; BT_26 & 000H, 030H, 030H, 030H, 060H, 000H, 000H, 000H; TH_27 | | | 022A<br>0230 | 00 00<br>00 00 00 00 00 00<br>00 00 00 18 30 30 | 127<br>128<br>129 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT 27 '000H,000H,000H,018H,030H,030H,030H,030H; TH_28 ( | | | 0238<br>023E | 30 30<br>30 18 0C 00 00 00 | 130<br>131<br>132 | DB<br>DB | 030H, 018H, 00CH, 000H, 000H, 000H ; BT_28 (<br>000H, 000H, 030H, 018H, 00CH, 00CH, 00CH, 00CH ; TH_29 ) | | | 0246<br>024C | 00 00 | 133<br>134<br>135 | DB<br>DB | 00CH, 018H, 030H, 000H, 000H, 000H<br>000H, 000H, 000H, 000H, 05CH, 05FH, 03CH; TH_2A * | | | 0254<br>025A | 66 00 00 00 00 00 | 136<br>137<br>138 | DB<br>DB | 066H, 000H, 000H, 000H, 000H, 000H<br>000H, 000H, 000H, 000H, 018H, 018H, 07EH, 018H ; TH_2B + | | | 0262<br>0268 | 7E 18<br>18 00 00 00 00 00 00<br>00 00 00 00 00 00 | 139<br>140<br>141 | DB<br>DB | 018H,000H,000H,000H,000H,000H,000H, 91 BT_2B + 000H,000H,000H,000H,000H,000H,000H,00 | | | 0270<br>0276 | 00 00<br>18 18 18 30 00 00 | 142<br>143<br>144 | DB<br>DB | 018H, 018H, 018H, 030H, 000H, 000H, 000H; BT_2C, 000H, 000H | | | 027E | FE 00 | 145 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; HT_2D -<br>000H,000H,000H,000H,000H,000H,000H,000 | | | 0284<br>028C<br>0292 | 00 00 | 147<br>148<br>149 | DB | 000H,000H,000H,000H,000H,000H,000H; TH_2E . 000H,018H,018H,000H,000H,000H ; BT_2E . 000H,000H,002H,006H,00CH,018H,030H,060H ; TH_2F / | | | 0292<br>029A | 00 00 02 06 0C 18<br>30 60<br>C0 80 00 00 00 00 | 150<br>151<br>152 | DB<br>DB | 000H,000H,002H,006H,00CH,018H,030H,060H; TH_2F /<br>0C0H,080H,000H,000H,000H,000H ; BT_2F / | | | 02A0 | 00 00 7C C6 CF DF | 153<br>154<br>155 | DB | 000H,000H,07CH,0C6H,0CEH,0F6H,0E6H; TH_30 0 | | | 02A8<br>02AE | C6 C6 7C 00 00 00<br>00 00 18 38 78 18 | 156<br>157<br>158<br>159 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_30 0<br>000H,000H,018H,038H,078H,018H,018H,018H ; TH_31 1 | | | 02B6<br>02BC | 18 18<br>18 18 7E 00 00 00<br>00 00 7C C6 06 0C | | DB<br>DB | 018H,018H,07EH,000H,000H,000H ; BT_31 1<br>000H,000H,07CH,0C6H,006H,00CH,018H,030H ; TH_32 2 | | | 02C4<br>02CA | 18 30<br>60 C6 FE 00 00 00<br>00 00 7C C6 06 06 | 161<br>162<br>163 | DB<br>DB | 060H,0C6H,0FEH,000H,000H,000H ; BT_32 2<br>000H,000H,07CH,0C6H,006H,006H,03CH,006H ; TH_33 3 | | | 02D2<br>02D8 | 3C 06<br>06 C6 7C 00 00 00<br>00 00 0C 1C 3C 6C | 164<br>165<br>166 | DB<br>DB | 006H,0C6H,07CH,000H,000H,000H ; BT_33 3<br>000H,000H,00CH,01CH,03CH,06CH,0CCH,0FEH ; TH_34 4 | | | 02E0<br>02E6 | 0C 0C 1E 00 00 00 | 167<br>168<br>169 | DB<br>DB | 00CH,00CH,01EH,000H,000H,000H ; BT_34 4 000H,000H,0FEH,0COH,0COH,0COH,0FCH,006H ; TH_35 5 | | | 02EE<br>02F4 | FC 06<br>06 C6 7C 00 00 00 | 170<br>171<br>172 | DB<br>DB | 006H,0C6H,07CH,000H,000H,000H ; BT_35 5 000H,000H,038H,060H,0C0H,0C0H,0FCH,0C6H ; TH_36 6 | | | 02FC<br>0302 | FC C6 | 173<br>174<br>175 | DB<br>DB | 0C6H, 0C6H, 07CH, 000H, 000H, 000H, 000H, 000H, 0TH, 36 6 000H, 000H, 0TH, 0C6H, 00GH, 00CH, 018H, 030H ; TH_37 7 | | | 0302<br>030A<br>0310 | 00 00 FE C6 06 0C<br>18 30<br>30 30 30 00 00 00<br>00 00 7C C6 C6 C6 | 176<br>177<br>178 | DB<br>DB | 030H,030H,030H,000H,000H,000H<br>000H,000H, | | | 0310<br>0318<br>031E | 7C C6<br>C6 C6 7C 00 00 00 | 178<br>179<br>180 | DB<br>DB | 000H,000H,07CH,00CH,00CH,00CH,07CH,00CH; TH_38 8<br>00CH,07CH,00CH,00OH,00OH ; BT_38 8<br>000H,00OH,07CH,0CCH,0CCH,0CCH,0TEH,00CH; TH_39 9 | | | 031E<br>0326<br>032C | 7F 06 | 181<br>182<br>183<br>184 | DB | 000H,000H,07CH,0C6H,0C6H,0C6H,07EH,006H; TH_39 9<br>006H,00CH,078H,000H,000H,000H ; BT_39 9<br>000H,000H,000H,018H,018H,000H,000H,000H; TH_3A : | | | 032C<br>0334<br>033A | 06 0C 78 00 00 00<br>00 00 00 18 18 00<br>00 00<br>18 18 00 00 00 00<br>00 00 00 18 18 00 | 184<br>185<br>186<br>187 | DB<br>DB | 000H,000H,000H,018H,018H,000H,000H,000H; TH_3A:<br>018H,018H,000H,000H,000H,000H; BT_3A:<br>000H,000H,000H,018H,018H,000H,000H; TH_3B; | | | 033A<br>0342<br>0348 | 00.00 | | DB<br>DB<br>DB | | | | 0348 | 18 18 30 00 00 00<br>00 00 06 0C 18 30<br>60 30 | 189<br>190<br>191 | ĎΒ | 018H,018H,030H,000H,000H,000H ; BT_3B; 000H,000H,000H,00CH,018H,030H,060H,030H ; TH_3C < | | | | | | | | | | 0350<br>0356 | 18 OC 06 OO 00 00<br>00 00 00 00 00 7E<br>00 00 | 192 | DB<br>DB | 018H,00CH,006H,000H,000H,000H ; BT_3C < 000H,000H,000H,000H,00CH; TH_3D = | |----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 035E<br>0364 | 18 OC 06 OO 00 00<br>00 00 00 00 00 7E<br>00 00<br>7E 00 00 00 00 00<br>00 00 60 30 18 OC | 192<br>193<br>194<br>195<br>196<br>197<br>198<br>199 | DB<br>DB | 07EH,000H,000H,000H,000H,000H ; BT_3D = 000H,000H,060H,018H,00EH,00CH; TH_3E > | | 036C<br>0372 | 06 0C<br>18 30 60 00 00 00<br>00 00 7C C6 C6 0C | 196<br>197<br>198 | DB<br>DB | 018H,0300H,060H,000H,000H,000H<br>000H,0300H,07CH,066H,06CH,000H,018H,018H; TH_3F? | | 0372<br>037A | 06 0C<br>18 30 60 00 00 00<br>00 00 7C C6 C6 0C<br>18 18<br>00 18 18 00 00 00 | 199<br>200<br>201 | DB<br>DB | 000H,000H,07CH,0C6H,0C6H,00CH,018H,018H; TH_3F?<br>000H,018H,018H,000H,000H,000H ; BT_3F? | | 0380 | 00 00 7C C6 C6 DE | 202<br>203<br>204 | DB | 000H,000H,07CH,0C6H,0C6H,0DEH,0DEH; TH_40 € | | 0388<br>038E | DC CO 7C 00 00 00<br>00 00 10 38 6C C6 | 204<br>205<br>206<br>207 | DB<br>DB | ODCH,OCOH,O7CH,OOOH,OOOH,OOOH ; BT_40 @<br>OOOH,OOOH,O1OH,O38H,O6CH,OC6H,OC6H,OFEH ; TH_41 A | | 0396<br>0390 | 00 00 7C C6 C6 DE<br>DE DE<br>DC C0 7C 00 00 00<br>00 00 10 38 6C C6<br>C6 FE<br>C6 C5 C6 00 00 00<br>00 00 FC 66 66 66<br>7C 66<br>66 66 FC 00 00 00 | | DB<br>DB | 0C6H,0C6H,0C6H,000H,000H,000H ; BT_41 A 000H,000H,0FCH,066H,066H,066H,07CH,066H; TH_42 B | | 03A4<br>03AA | 00 00 7C C6 C6 DE DE DE DE DE C0 7C 00 00 00 00 00 00 10 38 6C C6 FE 66 C6 C6 FC 66 | 209<br>210<br>211 | DB<br>DB | 066H,066H,0FCH,000H,000H,000H ; BT_42 B 000H,000H,03CH,066H,0CCH,0COH,0COH; TH_43 C | | 03B2<br>03B8 | C0 C0<br>C2 66 3C 00 00 00 | 212<br>213<br>214 | DB<br>DB | 002H,066H,03CH,000H,000H,000H ; BT_43 C 000H,000H,066H,066H,066H ; TT_44 D | | 03C0<br>03C6 | 66 66<br>66 6C F8 00 00 00 | 215<br>216<br>217<br>218<br>219 | DB | 006H,000H,018H,000H,000H,000H<br>006H,006H,018H,000H,000H,000H<br>000H,000H,018H,066H,062H,068H,078H,068H; TH_45 E | | 03C6<br>03CE<br>03D4 | 00 00 3C 66 C2 C0<br>00 00 00 00 00 00<br>00 00 88 6C 66 66<br>66 6C F8 00 00 00<br>00 00 F6 66 22<br>78 68 FE 00 00 00<br>00 00 F6 66 22<br>00 00 F6 66 22<br>00 00 00 00 00<br>00 00 00 00 00<br>00 00 00 00 00<br>00 00 00 00 00<br>00 00 00 00 00 00<br>00 | 218<br>219<br>220 | DB<br>DB<br>DB | | | | 00 00 FE 66 62 68<br>78 68 | 220<br>221<br>222<br>223 | DB<br>DB | 062H, 066H, 0FEH, 000H, 000H, 000H ; BT. 45 E 000H, 000H, 0FEH, 066H, 062H, 068H, 078H, 068H ; TH_46 F 060H, 060H, 060H, 000H, | | 03DC<br>03E2 | 00 00 3C 66 C2 C0<br>C0 DE | 224<br>225 | DB | 060H,060H,0F0H,000H,000H,000H<br>000H,03CH,066H,0C2H,0C0H,0C0H,0DEH; TH_47 G | | 03EA<br>03F0 | C6 66 3A 00 00 00<br>00 00 C6 C6 C6 C6<br>FE C6<br>C6 C6 C6 00 00<br>00 00 3C 18 18 18<br>18 18<br>18 18 3C 00 00 00<br>00 00 1E 0C 0C | 226<br>227<br>228<br>229 | DB<br>DB | ОС6H,066H,03AH,000H,000H,000H ; ВТ_47 G<br>000H,000H,0C6H,0C6H,0C6H,0C6H,0FEH,0C6H ; ТН_48 H | | 03F8<br>03FE | C6 C6 C6 00 00 00<br>00 00 3C 18 18 18<br>18 18 | 230 | DB<br>DB | 0С6H,0С6H,0С6H,000H,000H,000H ; ВТ_48 Н<br>000H,000H,03CH,018H,018H,018H,018H,018H; ТН_49 Н | | 0406<br>040C | 18 18 3C 00 00 00<br>00 00 1E 0C 0C 0C | 232<br>233<br>234 | DB<br>DB | 018H,018H,03CH,000H,000H,000H ; BT_49 ! 000H,000H,01EH,00CH,00CH,00CH,00CH; TH_4A J | | 0414<br>041A | 0C 0C<br>CC CC 78 00 00 00<br>00 00 E6 66 6C 6C | 235<br>236 | DB<br>DB | ОССН,ОССН,078H,000H,000H,000H ; ВТ_4А J<br>000H,000H,0E6H,066H,06CH,06CH,078H,06CH ; ТН_4В К | | 0422<br>0428 | 78 6C<br>6C 66 E6 00 00 00<br>00 00 F0 60 60 60<br>60 60 | 237<br>238<br>239 | DB<br>DB | 06CH,066H,0E6H,000H,000H,000H ; ВТ_4В К<br>000H,000H,0F0H,060H,060H,060H,060H ; ТН_4С L | | 0430<br>0436 | | 240<br>241<br>242 | DB<br>DB | 062H, 066H, 0FEH, 000H, 000H, 000H ; ВТ_4С L<br>000H, 000H, 006H, 0EEH, 0FEH, 0FEH, 0D6H, 0C6H ; ТН_4D М | | 043E<br>0444 | 62 66 FE 00 00 00<br>00 00 C6 EE FE FE<br>D6 C6<br>C6 C6 C6 00 00 00<br>00 00 C6 E6 F6 FE | 242<br>243<br>244<br>245 | DB<br>DB | 0C6H, 0C6H, 0C0H, 000H, 000H, 000H<br>000H, 000H, 0C6H, 0E6H, 0F6H, 0FEH, 0CEH; TH_4E N | | 044C<br>0452 | DE CE<br>C6 C6 C6 00 00 00<br>00 00 38 6C C6 C6<br>C6 C6 | 246<br>247<br>248<br>249 | DB<br>DB | 0C6H, 0C6H, 0C6H, 00OH, 00OH, 00OH ; BT_4E N<br>00OH, 00OH, 03BH, 06CH, 0C6H, 0C6H, 0C6H ; TH_4F O | | 045A | C6 C6<br>C6 C6 C | 248<br>249<br>250 | DB | 0C6H,06CH,038H,000H,000H,000H ; BT_4F 0 | | 0460 | 00 00 FC 66 66 66<br>7C 60<br>60 60 F0 00 00 00<br>00 00 7C C6 C6 C6 | 250<br>251<br>252<br>253 | DB | 000H,000H,0FCH,066H,066H,07CH,060H ; TH_50 Р | | 0468<br>046E | 7C 60<br>60 60 F0 00 00 00<br>00 00 7C C6 C6 C6 | 253<br>254<br>255<br>256 | DB<br>DB | 060H,060H,0F0H,000H,000H,000H ; BT_50 P<br>000H,000H,07CH,0C6H,0C6H,0C6H,0C6H,0D6H ; TH_51 Q | | 0476<br>0470 | C6 D6 DE 7C OC OE OO OO OO OO FC 66 66 66 7C 6C | 256<br>257<br>258<br>259<br>260 | DB<br>DB | ODEH,07CH,00CH,00EH,000H,000H ; BT_51 Q<br>000H,000H,0FCH,066H,066H,07CH,06CH ; TH_52 R | | 0484<br>048A | 66 66 E6 00 00 00<br>00 00 70 06 06 60 | | DB<br>DB | 066H,066H,0E6H,000H,000H,000H ; BT_52 R<br>000H,000H,07CH,0C6H,0C6H,060H,038H,00CH ; TH_53 S | | 0492<br>0498 | 38 0C<br>C6 C6 7C 00 00 00<br>00 00 7E 7E 5A 18 | 262<br>263<br>264 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_53 S<br>000H,000H,07EH,07EH,05AH,018H,018H,018H; TH_54 T | | 04A0<br>04A6 | 18 18<br>18 18 3C 00 00 00 | 265<br>266<br>267 | DB<br>DB | 018H,018H,03CH,000H,000H,000H ; BT_54 T<br>000H,000H,00C6H,0C6H,0C6H,0C6H,0C6H; TH_55 U | | 04AE<br>04B4 | C6 C6 7C 00 00 00 | 268<br>269<br>270 | DB<br>DB | 0C6H, 0C6H, 07CH, 000H, 000H, 000H<br>000H, 000H, 0C6H, 0C6H, 0C6H, 0C6H, 0C6H; BT_55 V | | 04BC<br>04C2 | C6 C6<br>6C 38 10 00 00 00<br>00 00 C6 C6 C6 C6 | 270<br>271<br>272<br>273 | DB<br>DB | 06CH,038H,010H,000H,000H,000H ; BT_56 V 000H,000H,006H,006H,006H,006H,006H,006H | | 04CA<br>04D0 | D6 D6<br>FE 7C 6C 00 00 00 | 274<br>275 | DB<br>DB | 00FH,07CH,06CH,00CH,00CH,00CH,00CH<br>000H,00CH,0CGH,0CGH,0CH,03BH,03BH,03BH; TH_58 X | | 04D8<br>04DE | 38 38<br>6C C6 C6 00 00 00 | 276<br>277<br>278<br>279 | DB<br>DB | 006H, 006H, 006H, 006H, 006H, 008H, 038H, 038H ; 1H_38 X<br>006H, 006H, 006H, 006H, 006H, 006H, 036H, 018H ; TH_59 Y | | 04E6<br>04EC | 00 00 66 66 66 66<br>3C 18<br>18 18 3C 00 00 00 | 280<br>281 | DB<br>DB | 000H,000H,066H,066H,066H,066H,03CH,018H; TH_59 Y<br>018H,018H,03CH,000H,000H,000H<br>000H,000H,0FEH,0C6H,08CH,018H,030H,060H; TH_5A Z | | | 00 00 FE C6 8C 18<br>30 60<br>C2 C6 FE 00 00 00 | 282<br>283<br>284 | DB<br>DB | | | 04F4<br>04FA | 00 00 3C 30 30 30<br>30 30 | 285<br>286<br>287 | DB<br>DB | 000H,006H,0FEH,000H,000H,000H<br>000H,000H,03CH,030H,030H,030H,030H,030H; TH_5B [ | | 0502<br>0508 | 00 00 80 C0 E0 70<br>38 1C | 288<br>289 | DB | 030H,030H,03CH,000H,000H,000H ; BT_58 [ 000H,000H,080H,0COH,0EOH,070H,038H,01CH ; TH_5C | | 0510<br>0516 | 80 30 10 00 00 00 00 00 00 00 00 00 00 00 00 | 288<br>289<br>290<br>291<br>292 | DB<br>DB | 00EH,006H,002H,000H,000H,000H; BT_5C<br>000H,000H,03CH,00CH,00CH,00CH,00CH; TH_5D ] | | 051E<br>0524 | 0C 0C 0C 3C 00 00 00 10 38 6C C6 00 00 00 00 00 00 00 00 00 00 00 00 00 | 293<br>294<br>295 | DB<br>DB | 00CH,00CH,03CH,000H,000H,000H ; ВТ_5D ]<br>010H,038H,06CH,0C6H,000H,000H,000H,000H ; ТН_5E | | 052C<br>0532 | 00 00 00 00 00 00<br>00 00 00 00 00 00<br>00 00<br>00 00 | 296<br>297<br>298 | DB<br>DB | 000H,000H,000H,000H,000H<br>000H,000H,000H | | 053A | | 299<br>300 | DB | 000Н,000Н,000Н,000Н,0FFH,000Н ; ВТ_5F _ | | 0540<br>0548<br>054E | 30 30 18 00 00 00<br>00 00<br>00 00 00 00 00 00<br>00 00 | 301<br>302<br>303<br>304<br>305 | DB<br>DB<br>DB | 030H,030H,018H,000H,000H,000H,000H,000H; TH_60 ' | | | 00 00 00 00 00 00<br>00 00 00 00 00 78<br>0C 7C<br>CC CC 76 00 00 00 | 306 | | 000H,000H,000H,000H,000H,000H ; BT_60 ' 000H,000H,000H,000H,000H,000H,00CH,07CH ; TT_61 LOWER_CASE A | | 0556<br>0550 | 00 76 00 00 00<br>00 00 E0 60 60 78<br>60 66<br>66 66 7C 00 00 00<br>00 00 00 00 7C | 307 | DB<br>DB<br>DB | OCCH, OCCH, 076H, 000H, 000H, 000H<br>000H, 000H, 0EOH, 0EOH, 060H, 078H, 06CH, 06GH ; BT_61 LOWER CASE A<br>006H, 06GH, 077H, 000H, 000H, 000H | | 0564<br>056A | | 309<br>310<br>311 | DB | 066H,066H,070H,000H,000H,000H,000H,000H, | | 0572<br>0578 | CO C6 7C 00 00 00<br>00 00 1C 0C 0C 3C<br>6C CC | 311<br>312<br>313<br>314<br>315<br>316<br>317 | DB<br>DB | OCOH, OCGH, O7CH, O0OH, O0OH, O0OH<br>000H, 00OH, O1CH, O0CH, O3CH, O3CH, O6CH, OCCH; TH_64 L.C. D | | 0580<br>0586 | 6C CC<br>CC CC 76 00 00 00<br>00 00 00 00 00 7C<br>C6 FE | 316<br>317 | DB<br>DB | OCCH, OCCH, 076H, 000H, 000H, 000H ; BT 64 L.C. D 000H, 000H, 000H, 000H, 07CH, OC6H, 0FEH ; TH_65 L.C. E | | | | | | | | 058E<br>0594 | C0 C6 7C 00 00 00<br>00 00 38 6C 64 60 | 318 DB<br>319 DB | 0COH, 0C6H, 07CH, 000H, 000H, 000H ; BT_65 L.C. E 000H, 000H, 038H, 06CH, 064H, 060H, 0F0H, 060H ; TH_66 L.C. F | |----------------------|----------------------------------------------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 059C<br>05A2 | 60 60 F0 00 00 00<br>00 00 00 00 00 76 | 320<br>321 DB<br>322 DB | 060H,060H,0F0H,000H,000H,000H ; BT_66 L.C. F 000H,000H,000H,000H,000H,000H,00CH,0CH; TH_67 L.C. G | | 05AA<br>05B0 | CC CC<br>CC 7C OC CC 78 OO<br>OO OO EO 60 60 6C | 323<br>324 DB<br>325 DB | ОССН, ОТСН, ООСН, ОССН, ОТВН, ОООН ; ВТ_67 L.C. G<br>ОООН, ОЕОН, ОЕОН, ОБОН, ОБОН, ОТБН, ОБОН ; ТН_БВ L.C. H | | 05B8<br>05BE | 76 66<br>66 66 E6 00 00 00<br>00 00 18 18 00 38 | 326<br>327 DB<br>328 DB | 066H,066H,0E6H,000H,000H,000H ; BT_68 L.C. H<br>000H,000H,018H,018H,000H,038H,018H,018H ; TH_69 L.C. I | | 05C6<br>05CC | 18 18<br>18 18 3C 00 00 00<br>00 00 06 06 00 0E | 329<br>330 DB | 018H, 018H, 03CH, 000H, 000H, 000H ; BT_69 L.C. 1<br>000H, 000H, 006H, 000H, 000H, 006H, 006H; TM_6A L.C. J | | 05D4 | 06 06<br>06 06 66 66 3C 00 | 331 DB<br>332<br>333 DB | 000H,000H,006H,006H,00CH,000H,00CH,000H; 1H_6A L.C. J<br>000H,000H,0E0H,06CH,03CH,000H<br>000H,000H,0E0H,06OH,06CH,06CH,078H; TH_6B L.C. K | | 05DA<br>05E2 | 6C 78<br>6C 66 E6 00 00 00 | 334 DB<br>335<br>336 DB | 000H,000H,0E0H,060H,060H,060H,06CH,078H; TH_6B L.C. K<br>06CH,066H,0E6H,000H,000H,000H<br>000H,000H,038H,018H,018H,018H,018H; TH_6C L.C. L | | 05E8<br>05F0 | 18 18<br>18 18 3C 00 00 00 | 337 DB<br>338<br>339 DB | 000H,000H,038H,018H,018H,018H,018H; TH_6C L.C. L 018H,018H,03CH,000H,000H,000H 000H,000H,000H,000H,00 | | 05F6<br>05FE | 00 00 00 00 00 EC | 340 DB<br>341<br>342 DB | | | 0604<br>060C | 00 00 00 00 00 DC | 343 DB<br>344<br>345 DB | 006H,006H,006H,000H,000H,000H ; BT_6D L.C. M<br>000H,000H,000H,000H,000H,00CH,066H,066H, | | 0612<br>061A | 66 66 66 00 00 00<br>00 00 00 00 00 7C<br>C6 C6<br>C6 C6 7C 00 00 00 | 346 DB<br>347<br>348 DB | 066H,066H,066H,000H,000H,000H ; BT_6E L.C. N<br>000H,000H,000H,000H,000H,07CH,0C6H,0C6H ; TH_6F L.C. O<br>0C6H,0C6H,07CH,000H,000H,000H ; BT_6F L.C. O | | 0620 | 00 00 00 00 00 DC | 349<br>350 DB | 000H,000H,000H,000H,000H,006H,066H; TH_70 L.C. P | | 0628<br>062E | 66 66<br>66 7C 60 60 F0 00<br>00 00 00 00 76 | 351<br>352 DB<br>353 DB | 066H,07CH,060H,060H,0F0H,000H ; BT_70 L.C. P<br>000H,000H,000H,000H,000H,076H,0CCH,0CCH ; TH_71 L.C. Q | | 0636<br>063C | CC CC<br>CC 7C OC OC 1E OO<br>00 00 00 00 DC | 354<br>355 DB<br>356 DB | OCCH,07CH,00CH,00CH,01EH,000H ; BT_71 L.C. Q 000H,000H,000H,000H,000H,00CH,076H,066H ; TH_72 L.C. R | | 0644<br>064A | 76 66<br>60 60 F0 00 00 00<br>00 00 00 00 7C | 357<br>358 DB<br>359 DB | 060H,060H,0F0H,000H,000H,000H ; BT_72 L.C. R 000H,000H,000H,000H,000H,07CH,0C6H,070H ; TH_73 L.C. S | | 0652<br>0658 | C6 70<br>1C C6 7C 00 00 00<br>00 00 10 30 30 FC | 360<br>361 DB<br>362 DB | 01CH, 0C6H, 07CH, 000H, 000H, 000H ; BT_73 L.C. S<br>000H, 000H, 010H, 030H, 030H, 0FCH, 030H, 030H ; TH_74 L.C. T | | 0660<br>0666 | 30 30<br>30 36 1C 00 00 00<br>00 00 00 00 00 CC | 363<br>364 DB | 030H, 036H, 01CH, 000H, 000H, 000H, 00CH, 0CCH, 0CCH; 1H-75 L.C. U | | 066E | CC CC<br>CC CC 76 00 00 00 | 366<br>367 DB | 00CH, 00CH, 076H, 000H, 000H, 000H ; BT_75 L.C. U<br>000H, 000H, 000H, 000H, 066H, 066H, 066H ; TH_76 L.C. V | | 0674<br>0670 | 00 00 00 00 00 66<br>66 66<br>66 3C 18 00 00 00 | 369<br>370 DB | 000H, 000H, 000H, 000H, 000H, 000H; 1H_76 L.C. V<br>000H, 000H, 018H, 000H, 000H, 000H; BT_76 L.C. V<br>000H, 000H, 000H, 000H, 000H, 006H, 006H; TH_77 L.C. W | | 0682<br>068A | 00 00 00 00 00 C6<br>C6 D6<br>D6 FE 6C 00 00 00 | 371 DB<br>372<br>373 DB | 000H,000H,000H,000H,000H,0C6H,0C6H,0D6H; TH_77 L.C. W<br>0D6H,0FEH,06CH,000H,000H,000H<br>000H,000H,000H,000H,00 | | 0690<br>0698 | 00 00 00 00 00 C6<br>6C 38<br>38 6C C6 00 00 00 | 374 DB<br>375<br>376 DB | | | 069E | 00 00 00 00 00 C6<br>C6 C6<br>C6 7E 06 0C F8 00 | 377 DB<br>378<br>379 DB | | | 06AC<br>06B4 | 00 00 00 00 00 FE<br>CC 18 | 380 DB<br>381<br>382 DB | 06H,07EH,006H,00CH,0FBH,000H ; BT_79 L.C. Y 000H,000H,000H,000H,000H,00CH,018H ; TH_7A L.C. Z | | 06BA<br>06C2 | 00 00 0E 18 18 18<br>70 18 | 383 DB<br>384<br>385 DB | 030H,066H,0FEH,000H,000H,000H ; BT_7A L.C. Z<br>000H,000H,00EH,018H,018H,070H,018H ; TH_7B L BRAK<br>018H,018H,00EH,000H,000H ; BT_7B L BRAK | | 06C8 | 00 00 18 18 18 18 | 386 DB<br>387 | 000H,000H,018H,018H,018H,018H,000H,018H ; TH_7C | | 06D0<br>06D6 | 18 18 18 00 00 00<br>00 00 70 18 18 18<br>0E 18 | 388 DB<br>389 DB<br>390 | 018H,018H,018H,000H,000H,000H<br>000H,000H,070H,018H,018H,018H,00EH,018H; TH_7D R BRAK | | 06DE<br>06E4 | 18 18 70 00 00 00<br>00 00 76 DC 00 00<br>00 00 | 391 DB<br>392 DB<br>393 | 018H,018H,070H,000H,000H,000H ; BT_7D R BRAK<br>000H,000H,076H,0DCH,000H,000H,000H; TH_7E TILDE | | 06EC<br>06F2 | 00 00 00 00 00 00<br>00 00 00 00 10 38<br>6C C6 | 394 DB<br>395 DB<br>396 | 000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,010H,038H,06CH,0C6H; ТН_7F DELTA | | 06FA<br>0700 | C6 FE 00 00 00 00<br>00 00 3C 66 C2 C0 | 397 DB<br>398<br>399 DB | 0C6H,0FEH,000H,000H,000H,000H ; BT_7F DELTA<br>000H,000H,03CH,066H,0C2H,0C0H,0C0H,0C2H ; TH_80 | | 0708<br>070E | CO C2<br>66 3C OC 06 7C 00<br>00 00 CC CC 00 CC | 400<br>401 DB<br>402 DB | 066H, 03CH, 00CH, 006H, 07CH, 000H ; BT_80<br>000H, 000H, 0CCH, 0CCH, 000H, 0CCH, 0CCH ; TH_81 | | 0716 | CC CC 76 00 00 00 | 403<br>404 DB | 000H, 00CH, 076H, 000H, 000H, 000H ; BT_81<br>000H, 00CH, 076H, 030H, 000H, 07CH, 06H, 0FH; TH_82 | | 071C<br>0724 | 00 0C 18 30 00 7C<br>C6 FE<br>C0 C6 7C 00 00 00<br>00 10 38 6C 00 78 | 405 DB<br>406<br>407 DB | 000H, 000H, 076H, 030H, 000H, 076H, 005H, 07FH; 1H_82<br>000H, 076H, 076H, 000H, 000H, 000H; BT_82<br>000H, 010H, 038H, 066H, 000H, 078H, 00CH, 076H; TH_83 | | 072A<br>0732 | 00 10 38 6C 00 78<br>0C 7C<br>CC CC 76 00 00 00<br>00 00 CC CC 00 78 | 408 DB<br>409<br>410 DB | 000H,010H,038H,06CH,000H,078H,00CH,07CH; TH_83<br>0CCH,0CCH,076H,000H,000H,000H<br>000H,000H,0CCH,0CCH,000H,078H,00CH,07CH; TH_84 | | 0738<br>0740<br>0746 | OC 7C<br>CC CC 76 00 00 00 | 411 DB<br>412<br>413 DB | 000H,000H,0CCH,0CCH,000H,078H,00CH,07CH; TH_84<br>0CCH,0CCH,076H,000H,000H,000H<br>000H,060H,030H,018H,000H,078H,00CH,07CH; TH_85 | | 0746<br>074E | 0C 7C<br>CC CC 76 00 00 00 | 414 DB<br>415<br>416 DB | | | 0754<br>075C | CC CC 76 00 00 00<br>00 38 6C 38 00 78<br>0C 7C<br>CC CC 76 00 00 00 | 417 DB<br>418<br>419 DB | 000Н,038Н,06СН,038Н,000Н,078Н,00СН,07СН ; ТН_86 | | 0762<br>076A | 00 00 00 00 3C 66 | 420 DB<br>421<br>422 DB | OCCH, OCCH, 076H, 000H, 000H, 000H ; BT_86<br>000H, 000H, 000H, 000H, 03CH, 066H, 066H, 066H ; TH_87<br>03CH, 00CH, 006H, 03CH, 000H, 000H ; BT_87 | | 0770 | 00 10 38 6C 00 7C | 423 DB<br>424 | 000H,010H,038H,06CH,000H,07CH,0C6H,0FEH; TH_88 | | 0778<br>077E | CO C6 7C 00 00 00<br>00 00 CC CC 00 7C<br>C6 FE | 426 DB<br>427 | ОСОН, ОССН, ОТСН, ОООН, ОООН, ОООН<br>ОООН, ОООН, ОССН, ОССН, ОООН, ОТСН, ОССН, ОГЕН ; ТН_89 | | 0786<br>078C | CO C6 7C 00 00 00<br>00 60 30 18 00 7C<br>C6 FE | 428 DB<br>429 DB<br>430 | 0COH, 0C6H, 07CH, 000H, 000H, 000H ; BT_89<br>000H, 060H, 030H, 018H, 000H, 07CH, 0C6H, 0FEH ; TH_8A | | 0794<br>079A | CO C6 7C 00 00 00<br>00 00 66 66 00 38<br>18 18 | 431 DB<br>432 DB<br>433 | 0C0H,0C6H,07CH,000H,000H,000H ; BT_8A<br>000H,000H,066H,066H,000H,038H,018H,018H ; TH_8B | | 07A2<br>07A8 | 18 18 3C 00 00 00<br>00 18 3C 66 00 38<br>18 18 | 434 DB<br>435 DB<br>436 | 018H,018H,03CH,000H,000H,000H ; BT_8B<br>000H,018H,03CH,066H,000H,038H,018H,018H ; TH_8C | | 07B0<br>07B6 | 18 18 3C 00 00 00<br>00 60 30 18 00 38<br>18 18 | 437 DB<br>438 DB<br>439 | 018H,018H,03CH,000H,000H,000H ; BT_8C<br>000H,060H,030H,018H,000H,038H,018H,018H ; TH_8D | | 07BE<br>07C4 | 18 18 3C 00 00 00<br>00 C6 C6 10 38 6C | 440 DB<br>441 DB | 018H,018H,03CH,000H,000H,000H<br>000H,0C6H,0C6H,010H,038H,06CH,0C6H,0C6H; TH_8E | | 07CC | C6 C6<br>FE C6 C6 00 00 00 | 442<br>443 DB | OFEH, OC6H, OC6H, O00H, O00H, O00H ; BT_8E | | | | | | | 0702 | 38 6C 38 00 38 | <b>60</b> 1111 | DB | 038H,06CH,038H,000H,038H,06CH,0C6H,0C6H; TH_8F | |--------------|-------------------------------------------------------------|-------------------------|----------|------------------------------------------------------------------------------------------------------| | 07D2 | C6 C6<br>FE C6 C6 00 00 | 445 | DB<br>DB | OFEH, OC6H, OC6H, OCOH, OCOH, OCOH ; BT_8F | | 07E0 | 18 30 60 00 FE | 66 448 | DB | 018H,030H,060H,000H,0FEH,066H,060H,07CH ; TH_90 | | 07E8<br>07EE | 60 7C<br>60 66 FE 00 00<br>00 00 00 00 CC | 00 450<br>76 451 | DB<br>DB | 060H,066H,0FEH,000H,000H,000H ; BT_90<br>000H,000H,000H,000H,00CH,076H,036H,07EH ; TH_91 | | 07F6 | 36 7E<br>D8 D8 6E 00 00 | 00 452<br>453 | DB | 000H 000H 06FH 000H 000H 000H | | 07FC | 00 00 3E 6C CC<br>FE CC | CC 454<br>455 | DB<br>DB | 000H,000H,03EH,06CH,0CCH,0CCH,0FEH,0CCH ; TH_92 | | 0804<br>080A | CC CC CE 00 00<br>00 10 38 6C 00<br>C6 C6 | 7C 457<br>458 | DB | 000H,010H,038H,06CH,000H,07CH,0C6H,0C6H; TH_93 | | 0812<br>0818 | C6 C6 7C 00 00<br>00 00 C6 C6 00 | 7C 460 | DB<br>DB | ОС6H,ОС6H,О7CH,ОООH,ОООH,ОООH ; ВТ_93<br>ОООH,ОООH,ОС6H,ОС6H,ОООH,О7CH,ОС6H,ОС6H ; ТН_94 | | 0820<br>0826 | C6 C6<br>C6 C6 7C 00 00<br>00 60 30 18 00 | 00 462<br>7C 463 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_94<br>000H,060H,030H,018H,000H,07CH,0C6H,0C6H ; TH_95 | | 082E<br>0834 | C6 C6<br>C6 C6 7C 00 00<br>00 30 78 CC 00 | 00 464<br>00 465 | DB<br>DB | 0C6H, OC6H, O7CH, O00H, O00H, O00H ; BT 95<br>000H, O30H, O78H, OCCH, O00H, OCCH, OCCH ; TH 96 | | 083C | CC CC 76 00 00 | 467<br>00 468 | DB | OCCH. OCCH. 076H. 000H. 000H. 000H : BT 96 | | 0842<br>084A | 00 60 30 18 00<br>CC CC<br>CC CC 76 00 00 | 470 | DB<br>DB | | | 0850 | 00 00 C6 C6 00<br>C6 C6 | C6 472<br>473 | DB | ОССН,ОССН,076H,000H,000H,000H ; ВТ 97<br>000H,000H,006H,006H,006H,006H,006H; ТН_98 | | 0858<br>085E | C6 7E 06 0C 78<br>00 C6 C6 38 6C<br>C6 C6 | 00 474<br>C6 475<br>476 | DB<br>DB | 0C6H,07EH,006H,00CH,078H,000H ; ВТ_98<br>000H,0C6H,0C6H,038H,06CH,0C6H,0C6H,0C6H; ТН_99 | | 0866<br>0860 | C6 6C 38 00 00<br>00 C6 C6 00 C6 | 00 477<br>C6 478 | DB<br>DB | 0C6H,06CH,038H,000H,000H,000H ; BT_99<br>000H,0C6H,0C6H,00CH,0C6H,0C6H,0C6H,0C6H ; TH_9A | | 0874<br>087A | C6 C6<br>C6 C6 7C 00 00<br>00 18 18 3C 66 | 479<br>00 480<br>60 481 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_9A<br>000H,018H,018H,03CH,066H,060H,060H,066H ; TH_9B | | 0882 | 60 66<br>3C 18 18 00 00 | 00 482<br>483 | DB | 03CH.018H.018H.000H.000H.000H : BT 9B | | 0888 | 00 38 6C 64 60<br>60 60<br>60 E6 FC 00 00 | 485 | DB<br>DB | | | 0896 | 00 00 66 66 3C | 18 487<br>488 | DB<br>DB | 060H,0E6H,0FCH,000H,000H,000H ; BT_9C<br>000H,000H,066H,066H,03CH,018H,07EH,018H ; TH_9D | | 089E<br>08A4 | 7E 18 18 00 00<br>00 F8 CC CC F8<br>CC DE | C4 490<br>491 | DB | 07EH,018H,018H,000H,000H,000H ; ВТ_9D<br>000H,0F8H,0CCH,0CCH,0F8H,0C4H,0CCH,0DEH ; ТН_9E | | 08AC<br>08B2 | CC CC C6 00 00<br>00 0E 1B 18 18 | 00 492<br>18 493 | DB<br>DB | ОССН,ОССН,ОС6Н,ОООН,ОООН,ОООН; ВТ_9E<br>ОООН,ООЕН,О18Н,О18Н,О18Н,О7ЕН,О18Н; ТН_9F | | 08BA | 7E 18<br>18 18 18 D8 70 | 00 495<br>496 | DB | 018H,018H,018H,0D8H,070H,000H ; BT_9F | | 0800 | 00 18 30 60 00<br>0C 7C | 498 | DB | 000H,018H,030H,060H,000H,078H,00CH,07CH ; TH_A0 | | 08C8<br>08CE | CC CC 76 00 00<br>00 0C 18 30 00<br>18 18 | | DB<br>DB | OCCH,OCCH,076H,000H,000H,000H; BT_A0<br>000H,00CH,018H,030H,000H,038H,018H,018H; TH_A1 | | 08D6<br>08DC | 18 18 3C 00 00<br>00 18 30 60 00<br>C6 C6 | 00 502<br>7C 503<br>504 | DB<br>DB | 018H,018H,03CH,000H,000H,000H ; BT_A1<br>000H,018H,030H,060H,000H,07CH,0C6H,0C6H ; TH_A2 | | 08E4<br>08EA | C6 C6 7C 00 00<br>00 18 30 60 00 | 00 505<br>CC 506 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_A2 000H,018H,030H,060H,000H,0CCH,0CCH,0CCH ; TH_A3 | | 08F2<br>08F8 | CC CC<br>CC CC 76 00 00<br>00 00 76 DC 00 | 507<br>00 508<br>DC 509 | DB<br>DB | OCCH,OCCH,076H,000H,000H,000H; BT_A3 | | 0900 | 66 66 66 00 00 | 510<br>511 | DB | 066H,066H,066H,000H,000H,000H ; BT_A4 | | 0906<br>090E | 76 DC 00 C6 E6<br>FE DE<br>CE C6 C6 00 00 | 513 | DB<br>DB | | | 0914<br>0910 | 00 3C 6C 6C 3E<br>7E 00 | 00 515<br>516 | DB<br>DB | OCEH, OC6H, OC6H, OOCH, OOOH, OOOH ; BT_A5 | | 0922 | 00 38 6C 6C 38<br>7C 00 | 00 518<br>519 | DB | 000H,000H,000H,000H,000H,000H; BT_A6<br>000H,038H,06CH,06CH,038H,000H,07CH,000H; TH_A7 | | 092A<br>0930 | 00 00 00 00 00<br>00 00 30 30 00<br>30 60 | 00 520<br>30 521<br>522 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_A7<br>000H,000H,030H,030H,000H,030H,030H,060H ; TH_A8 | | 0938<br>093E | C6 C6 7C 00 00<br>00 00 00 00 00 | 00 523<br>00 524 | DB<br>DB | 0C6H,0C6H,07CH,000H,000H,000H ; BT_A8<br>000H,000H,000H,000H,000H,0FEH,0C0H ; TH_A9 | | 0946<br>0940 | FE C0<br>C0 C0 00 00 00<br>00 00 00 00 00 | 525<br>00 526<br>00 527 | DB<br>DB | 0C0H,0C0H,000H,000H,000H,000H ; BT_A9<br>000H,000H,000H,000H,000H,0FEH,006H ; TH_AA | | 0954 | FE 06<br>06 06 00 00 00 | 528<br>529 | DB | 006H.006H.000H.000H.000H.000H : BT AA | | 095A<br>0962 | 00 C0 C0 C6 CC<br>30 60<br>DC 86 OC 18 3E | 531 | DB<br>DB | 000H,000H,000H,006H,000H,000H,030H,060H; TH_AB 0DCH,086H,00CH,018H,03EH,000H ; BT_AB | | 0968 | 00 CO CO C6 CC<br>30 66 | D8 533<br>534 | DB | 000H,0C0H,0C0H,0C6H,0CCH,0D8H,030H,066H ; TH_AC | | 0970<br>0976 | CE 9E 3E 06 06<br>00 00 18 18 00<br>18 3C | 00 535<br>18 536<br>537 | DB<br>DB | OCEH, 09EH, 03EH, 006H, 006H, 000H ; BT_AC<br>000H, 000H, 018H, 018H, 000H, 018H, 018H, 03CH ; TH_AD | | 097E<br>0984 | 3C 3C 18 00 00<br>00 00 00 00 36 | 00 538 | DB<br>DB | 03CH,03CH,018H,000H,000H,000H ; BT_AD<br>000H,000H,000H,000H,036H,06CH,0D8H,06CH ; TH_AE | | 098C<br>0992 | D8 6C<br>36 00 00 00 00<br>00 00 00 D8 | 00 541 | DB<br>DB | 036H,000H,000H,000H,000H,000H ; BT_AE<br>000H,000H,000H,000H,00BH,06CH,036H,06CH ; TH_AF | | 099A | 36 6C<br>D8 00 00 00 00 | 543 | DB | OD8H,000H,000H,000H,000H ; BT_AF | | 09A0 | 11 44 11 44 11<br>11 44 | 44 546<br>547 | DB | 011H,044H,011H,044H,011H,044H,011H,044H ; TH_B0 | | 09A8<br>09AE | 11 44 11 44 11 | AA 549 | DB<br>DB | 011H,044H,011H,044H,011H,044H ; BT_B0<br>055H,0AAH,055H,0AAH,055H,0AAH,055H,0AAH ; TH_B1 | | 09B6<br>09BC | 55 AA 55 AA 55<br>55 AA<br>55 AA 55 AA 55<br>DD 77 DD 77 DD | 550<br>AA 551<br>77 552 | DB<br>DB | 055H,0AAH,055H,0AAH,055H,0AAH ; BT_B1<br>0DDH,077H,0DDH,077H,0DDH,077H,0DDH,077H ; TH_B2 | | 09C4<br>09CA | DD 77<br>DD 77 DD 77 DD<br>18 18 18 18 18 | 553<br>77 554 | DB<br>DB | ODDH, 077H, ODDH, 077H, ODDH, 077H<br>018H, 018H, 018H, 018H, 018H, 018H, 018H, 17H_B3 | | 0902 | 18 18<br>18 18 18 18 18 | 556 | DB | 018H.018H.018H.018H.018H.018H : BT B3 | | 09D8<br>09E0 | 18 F8 | 18 558<br>559<br>18 560 | DB<br>DB | 0100 0100 0100 0100 0100 0100 | | 09E6 | 18 18 18 18 18<br>18 F8 | F8 561<br>562 | DB | 018H,018H,018H,018H,018H,0F8H,018H,0F8H ; TH_B5 | | 09EE<br>09F4 | 18 18 18 18 18<br>36 36 36 36 36<br>36 F6 | 18 563 | DB<br>DB | 018H,018H,018H,018H,018H,018H ; BT_B5<br>036H,036H,036H,036H,036H,036H,056H ; TH_B6 | | 09FC<br>0A02 | 36 36 36 36 36<br>00 00 00 00 00 | 36 566<br>00 567 | DB<br>DB | 036H,036H,036H,036H,036H,036H ; BT_B6<br>000H,000H,000H,000H,000H,000H,0FEH ; TH_B7 | | 0A0A | 00 FE<br>36 36 36 36 36 | 36 569 | DB | 036H,036H,036H,036H,036H,036H ; BT_B7 | | | | | | | | 0A10 | 00 00 00 00 00 F8 | 570<br>571 | DB | 000Н,000Н,000Н,000Н,000Н,018Н,018Н,0F8Н ; ТН_В8 | |----------------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0A18<br>0A1E | 18 F8<br>18 18 18 18 18 18 18<br>36 36 36 36 36 F6 | 571<br>572<br>573<br>574 | DB<br>DB | 018H,018H,018H,018H,018H,018H ; BT_B8 036H,036H,036H,036H,036H,036H,056H,006H,0F6H ; TH_B9 | | 0A26<br>0A2C | 36 36 36 36 36 F6<br>06 F6<br>36 36 36 36 36 36<br>36 36 36 36 36 36<br>36 36 36 36 36 36<br>36 36 36 36 36 36 | 575<br>576 | DB<br>DB | 036H,036H,036H,036H,036H,036H,036H,036H, | | 0A34<br>0A3A | 36 36 36 36 36 36<br>00 00 00 00 00 FE | 578<br>579<br>580 | DB<br>DB | 036H,036H,036H,036H,036H,036H ; BT_BA 000H,000H,000H,000H,000H,000H,00FEH,006H,0F6H ; TH_BB | | 0A42<br>0A48 | 06 F6<br>36 36 36 36 36 36<br>36 36 36 36 F6<br>06 FE | 581<br>582 | DB<br>DB | 036H,036H,036H,036H,036H,036H,06H,0FEH; TH_BC | | 0A50<br>0A56 | 06 F6<br>36 36 36 36 36 36<br>36 36 36 36 36 F6<br>06 FE<br>00 00 00 00 00 00<br>36 36 36 36 36 36<br>36 FE<br>00 00 00 00 00 00 | 583<br>584<br>585 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_BC 036H,036H,036H,036H,036H,036H,036H,036H, | | 0A5E<br>0A64 | 18 18 18 18 18 FR | 586<br>587<br>588 | DB<br>DB | 000H,000H,000H,000H,000H,000H<br>018H,018H,018H,018H,018H,018H,018H,018H; TH_BE | | 0A6C<br>0A72 | | 589<br>590<br>591 | DB<br>DB | 000H,000H,000H,000H,000H,000H,000H,0F8H; TH_BF | | 0A7A | 00 F8<br>18 18 18 18 18 18 | 592<br>593<br>594 | DB | 018H,018H,018H,018H,018H | | 0880 | 18 18 18 18 18 18<br>18 1F<br>00 00 00 00 00 00 | 595<br>596<br>597 | DB<br>DB | 018H,018H,018H,018H,018H,018H,018H,01FH; TH_CO | | 0A88<br>0A8E | 18 18 18 18 18 18<br>18 FF | 598<br>599<br>600 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_C0<br>018H,018H,018H,018H,018H,018H,018H,0FFH ; TH_C1 | | 0A96<br>0A9C<br>0AA4 | 00 00 00 00 00 00<br>00 FF | 601<br>602<br>603 | DB<br>DB | 000H,000H,000H,000H,000H,000H,000H,0FFH; TH_C2 | | OAAA | 18 18 18 18 18 18<br>18 1F | 604<br>605 | DB | 018H,018H,018H,018H,018H,018H,018H,01FH; TH_C3 | | OAB2<br>OAB8 | 18 18 18 18 18 18<br>00 00 00 00 00 00<br>00 FF | 606<br>607<br>608 | DB<br>DB | 018H,018H,018H,018H,018H,018H<br>000H,000H,000H,000H,000H,000H,0FFH; TH_C4 | | 0AC0<br>0AC6 | 00 00 00 00 00 00<br>18 18 18 18 18 18<br>18 FF | 609<br>610<br>611 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_C4<br>018H,018H,018H,018H,018H,018H,018H,0FFH ; TH_C5 | | OACE<br>OAD4 | 18 18 18 18 18 18<br>18 18 18 18 18 1F<br>18 1F | 612<br>613<br>614 | DB<br>DB | 018H,018H,018H,018H,018H,018H,018H,018H, | | 0ADC<br>0AE2 | 18 18 18 18 18 18<br>18 18 18 18 18 17<br>18 17<br>18 18 18 18 18 18<br>36 36 36 36 36 36<br>36 37<br>36 36 36 36 36 36 | 615<br>616 | DB<br>DB | 018H,018H,018H,018H,018H,018H ; BT_C6<br>036H,036H,036H,036H,036H,036H,037H ; TH_C7 | | OAEA<br>OAFO | 36 36 36 36 36 36<br>36 36 36 36 36 37<br>30 3F | 617<br>618<br>619 | DB<br>DB | 036H,036H,036H,036H,036H,036H,030H,030H, | | OAF8<br>OAFE | 00 00 00 00 00 00 | 620<br>621<br>622 | DB<br>DB | 000H,000H,000H,000H,000H,03FH,030H,037H; TH_C9 | | 0B06<br>0B0C | 00 00 00 00 00 3F<br>30 37<br>36 36 36 36 36 36 36<br>36 36 36 36 36 F7<br>00 FF<br>00 00 00 00 00 00 | 624<br>625 | DB<br>DB | 036H,036H,036H,036H,036H,036H,05H; BT_C9<br>036H,036H,036H,036H,036H,0F7H,000H,0FFH; TH_CA | | 0B14<br>0B1A | 00 FF<br>00 00 00 00 00 00 00<br>00 00 00 00 00 FF<br>00 F7 | 626<br>627<br>628 | DB<br>DB | 000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,00FH,000H,0FTH; TH_CB | | 0B22<br>0B28 | 36 36 36 36 36 36 | 629<br>630<br>631 | DB<br>DB | 036H,036H,036H,036H,036H,036H,030H,037H; BT_CB | | 0B30<br>0B36 | | 632<br>633<br>634 | DB<br>DB | 036H,036H,036H,036H,036H,036H; ; BT_CC 000H,000H,000H,000H,000H,000H,000H,0FFH; TH_CD | | 0B3E<br>0B44 | 00 FF | 635<br>636<br>637 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_CD 036H,036H,036H,036H,036H,036H,036H,036H, | | 0B4C<br>0B52 | 00 F7<br>36 36 36 36 36 36<br>18 18 18 18 18 FF | 638<br>639<br>640 | DB<br>DB | 036H,036H,036H,036H,036H,036H ; BT_CE 018H,018H,018H,018H,018H,018H,018H,018H, | | OB5A | 00 FF<br>00 00 00 00 00 00 | 641<br>642<br>643 | DB | 000H,000H,000H,000H,000H ; BT_CF | | 0B60<br>0B68 | 36 36 36 36 36 36<br>36 FF<br>00 00 00 00 00 00 | 644<br>645<br>646 | DB<br>DB | 036H,036H,036H,036H,036H,036H,0FFH ; TH_D0 | | 086E | 00 00 00 00 00 FF | 647<br>648<br>649 | DB | 000H,000H,000H,000H,000H,000H<br>000H,000H,000H,000H,00FH,000H,0FFH; TH_D1 | | 0B76<br>0B7C | 00 00 00 00 00 00 | 650<br>651 | DB<br>DB | 018H,018H,018H,018H,018H,018H<br>000H,000H,000H,000H,000H,000H,00H,0FFH; TH_D2 | | 0B84<br>0B8A | 36 36 36 36 36 36<br>36 36 36 36 36 36<br>36 3F<br>00 00 00 00 00 00 | 652<br>653<br>654 | DB<br>DB | 036H,036H,036H,036H,036H,036H,036H,036H, | | 0B92<br>0B98 | 18 18 18 18 18 1F<br>18 1F | 655<br>656<br>657 | DB<br>DB | 000H,000H,000H,000H,000H ; BT_D3 018H,018H,018H,018H,018H,018H,018H,018H, | | OBAO<br>OBA6 | 00 00 00 00 00 00<br>00 00 00 00 00 1F<br>18 1F | 658<br>659<br>660 | DB<br>DB | 000H,000H,000H,000H,000H,000H ; BT_D4 000H,000H,000H,000H,000H,01FH,018H,01FH ; TH_D5 | | OBAE<br>OBB4 | 18 18 18 18 18 18<br>00 00 00 00 00 00<br>00 3F | 661<br>662<br>663 | DB<br>DB | 018H,018H,018H,018H,018H,018H ; BT_D5<br>000H,000H,000H,000H,000H,000H,03FH ; TH_D6 | | OBC2 | 36 36 36 36 36 36<br>36 36 36 36 36 36<br>36 FF | 664<br>665<br>666 | DB<br>DB | 036H,036H,036H,036H,036H,036H,036H,05FH; TH_D7 | | OBCA<br>OBDO | 36 36 36 36 36 36<br>18 18 18 18 18 FF<br>18 FF | 667<br>668<br>669 | DB<br>DB | 036H,036H,036H,036H,036H,036H ; BT_D7<br>018H,018H,018H,018H,018H,0FFH,018H,0FFH ; TH_D8 | | OBD8<br>OBDE | 18 18 18 18 18 18<br>18 18 18 18 18 18 | 670<br>671 | DB<br>DB | 018H,018H,018H,018H,018H,018H,018H,018H, | | OBE6<br>OBEC | 00 00 00 00 00 00 00 | 672<br>673<br>674 | DB<br>DB | 000H,000H,000H,000H,000H,000H,01FH; TH_DA | | OBF4<br>OBFA | 18 18 18 18 18 18<br>FF FF FF FF FF | 675<br>676<br>677 | DB<br>DB | 018H,018H,018H,018H,018H,018H ; BT_DA | | 0C02<br>0C08 | 00 00 00 00 00 00 | 678<br>679<br>680 | DB<br>DB | OFFH, OFFH, OFFH, OFFH, OFFH ; BT_DB OOOH, OOOH, OOOH, OOOH, OOOH, OOOH, OOOH, OOOH, OFFH ; TH_DC | | 0C10<br>0C16 | 00 FF<br>FF FF FF FF FF<br>F0 F0 F0 F0 F0 | 681<br>682<br>683 | DB<br>DB | OFFH, OFFH, OFFH, OFFH, OFFH ; BT_DC OFOH, | | 0C1E<br>0C24 | FO FO<br>FO FO FO FO FO<br>OF OF OF OF OF<br>OF OF | 684<br>685<br>686 | DB<br>DB | OFOH, OFOH, OFOH, OFOH, OFOH, OFOH, OFH, OOFH, OFH, | | 0C2C<br>0C32 | OF OF OF OF OF OF FF FF FF FF FF FF FF F | 687<br>688<br>689 | DB<br>DB | OOFH,OOFH,OOFH,OOFH,OOFH,OOFH OFFH,OFFH, | | 0C3A | FF 00<br>00 00 00 00 00 00 | 690<br>691<br>692 | DB | 000H,000H,000H,000H,000H ; BT_DF | | 0040 | 00 00 00 00 00 76<br>DC D8<br>D8 DC 76 00 00 00 | 692<br>693<br>694<br>695 | DB | 000H,000H,000H,000H,000H,076H,0DCH,0D8H ; TH_E0 | | 0C48 | D8 DC 76 00 00 00 | 695 | DB | OD8H,ODCH,O76H,OOOH,OOOH,OOOH ; BT_EO | ``` DB. 000H,000H,000H,000H,07CH,0C6H,0FCH,0C6H; TH E1 OC6H, OFCH, OC0H, OC0H, O40H, O00H ; BT_E1 O00H, O00H, OFEH, OC6H, OC6H, OC0H, OC0H, OC0H ; TH_E2 0C0H,0C0H,0C0H,000H,000H,000H ; BT_E2 000H,000H,000H,000H,0FEH,06CH,06CH,06CH; TH_E3 DB DB 06CH,06CH,06CH,000H,000H,000H ; BT_E3 000H,000H,0FEH,0C6H,060H,030H,018H,030H ; TH_E4 DB DB 060H,0C6H,0FEH,000H,000H,000H ; BT_E4 000H,000H,000H,000H,07EH,0D8H,0D8H ; TH_E5 DB DB ОВН, ОВН, О7ОН, ОООН, ОООН, ОООН ; ВТ_Е5 ОООН, ОООН, ОООН, ОООН, О66Н, О66Н, О66Н, О66Н ; ТН_Е6 07CH,060H,060H,0COH,000H,000H ; BT_E6 DB DB 018H,018H,018H,000H,000H,000H ; BT_E7 000H,000H,07EH,018H,03CH,066H,066H,066H ; TH_E8 DB DB 03CH,018H,07EH,000H,000H,000H ; BT_E8 000H,000H,038H,06CH,0C6H,0C6H,0FEH,0C6H ; TH_E9 DB DB 0C6H,06CH,038H,000H,000H,000H ; BT_E9 000H,000H,038H,06CH,0C6H,0C6H,0C6H,06CH ; TH_EA DB DB 06CH,06CH,0EEH,000H,000H,000H ; BT_EA DB DB 066H,066H,03CH,000H,000H,000H ; BT_EB 000H,000H,000H,000H,07EH,0DBH,0DBH ; TH_EC 07EH,000H,000H,000H,000H,000H ; BT_EC 000H,000H,003H,006H,07EH,0DBH,0DBH,0F3H ; TH_ED DB DB 07EH,060H,0C0H,000H,000H,000H ; BT_ED 000H,000H,01CH,030H,060H,07CH,060H ; TH_EE DB DB 060H,030H,01CH,000H,000H,000H ; ВТ_ЕЕ 000H,000H,000H,07CH,0C6H,0C6H,0C6H,0C6H,0C6H; ТН_ЕF nn ОС6Н,ОС6Н,ОС6Н,ОООН,ОООН,ОООН C6 C6 C6 00 00 00 FE FE 00 00 FE 00 FE 00 FE 00 FE 00 FE 00 00 FE 0020 nn 000H,000H,000H,0FEH,000H,000H,0FEH,000H ; TH_F0 000H, 0FEH, 000H, 000H, 000H, 000H ; ВТ_F0 000H, 000H, 000H, 018H, 018H, 07EH, 018H, 018H ; ТН_F1 000H,000H,0FFH,000H,000H,000H ; BT_F1 000H,000H,030H,018H,00CH,006H,00CH,018H ; TH_F2 030H,000H,07EH,000H,000H,000H ; BT_F2 000H,000H,00CH,018H,030H,060H,030H,018H ; TH_F3 00CH,000H,07EH,000H,000H,000H ; BT_F3 000H,000H,00EH,01BH,01BH,018H,018H,018H ; TH_F4 DB DB 018H,018H,018H,018H,018H,018H ; BT_F4 018H,018H,018H,018H,018H,018H,018H ; TH_F5 0D60 0D66 DB DB 0D8H,0D8H,070H,000H,000H,000H ; ВТ_F5 000H,000H,000H,018H,018H,000H,07EH,000H ; ТН_F6 0D6E 0D74 018H,018H,000H,000H,000H,000H ; BT_F6 000H,000H,000H,000H,076H,0DCH,000H,076H ; TH_F7 0D7C 0D82 ODCH,000H,000H,000H,000H,000H ; BT_F7 DB DB 000H,000H,000H,000H,000H,000H,018H,018H; TH_F9 0D98 0D9E ODA6 000H,000H,000H,000H,000H,000H,000H,018H; TH_FA DB DB 000H,000H,000H,000H,000H,000H ; BT_FA 000H,00FH,00CH,00CH,00CH,00CH,00CH,0ECH ; TH_FB DB DB 06CH,03CH,01CH,000H,000H,000H ; BT_FB 000H,0D8H,06CH,06CH,06CH,06CH,06CH,000H ; TH_FC 000H,000H,000H,000H,000H,000H ; BT_FC 000H,070H,008H,030H,060H,0C8H,0F8H,000H ; TH_FD 07CH,07CH,000H,000H,000H,000H,000H; BT_FE DB DB ODFA OEOO DB ENDS END 000Н, 000Н, 000Н, 000Н, 000Н, 000Н CODE PAGE 120 SUBBITI MONOCHROME CHARACTER GENERATOR - ALPHA SUPPLEMENT SEGMENT PUBLIC PUBLIC COMM. FOG LABEL BYTE 0000 CODE 0000 CGMN_FDG ; STRUCTURE OF THIS FILE ; DB XXH WHERE XX IS THE HEX CODE FOR THE FOLLOWING CHAR ; DB [BYTES 0 - 13 OF THAT CHARACTER] ĎВ INDICATES NO MORE REPLACEMENTS TO BE DONE 01DH 000H,000H,000H,000H,024H,066H,0FFH,066H ; TH_1D 0009 000F 0010 DB DB DB 024H,000H,000H,000H,000H ; BT_1D 000H,063H,063H,063H,022H,000H,000H,000H; TH_22 " DB DB DB 000H,000H,000H,000H,000H,000H ; BT_22 " 000H,000H,000H,018H,018H,018H,0FFH,018H; TH_2B + 018H,018H,000H,000H,000H,000H ; BT_2B + 000H,000H,000H,000H,000H,0FFH,000H; TH_2D - ``` | 0036<br>003C<br>003D | 00 00 00 00 00 00<br>4D | 29<br>30<br>31<br>32 | DB<br>DB<br>DB | 000H,000H,000H,000H,000H ; BT_2D - | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | 003D<br>0045 | 00 00 C3 E7 FF DB<br>C3 C3<br>C3 C3 C3 00 00 00 | 31<br>32 | DB<br>DB | 000H,000H,0C3H,0E7H,0FFH,0DBH,0C3H,0C3H; TH_4D M | | | 0045<br>004B<br>004C | 00 00 FF DB 99 18 | 33<br>34<br>35 | DB<br>DB<br>DB | OC3H,OC3H,OC3H,OOOH,OOOH ; BT_4D M<br>054H<br>000H,OOOH,OFFH,ODBH,O99H,O18H,O18H,O18H, TH_54 T | | | 0054<br>005A | 18 18<br>18 18 3C 00 00 00<br>56 | 36<br>37<br>38 | DB<br>DB | 018H,018H,03CH,000H,000H,000H ; BT_54 T | | | 005B | 00 00 C3 C3 C3 C3<br>C3 C3 | 39<br>40 | DB | 000н, ооон, осзн, осзн, осзн, осзн, осзн, осзн ; тн_56 v | | | 0063<br>0069 | 66 3C 18 00 00 00<br>57 | 41<br>42 | DB<br>DB | 066H,03CH,018H,000H,000H,000H ; BT_56 V 057H ; | | | 006A | 00 00 C3 C3 C3 C3<br>DB DB<br>FF 66 66 00 00 00 | 43<br>44 | DB<br>DB | 000Н,000Н,0СЗН,ОСЗН,ОСЗН,ОСЗН,ОВН,ОВН ; ТН_57 W | | | 0072<br>0078<br>0079 | 58'<br>00 00 C3 C3 66 3C | 45<br>46 | DB<br>DB<br>DB | OFFH,066H,066H,000H,000H,000H ; BT_57 W<br>058H<br>000H,000H,003H,003H,066H,03CH,018H,03CH ; TH_58 X | | | 0081 | 18 3C<br>66 C3 C3 00 00 00 | 48<br>49 | DB | 066H,0C3H,0C3H,000H,000H,000H ; BT_58 X | | | 0087<br>0088 | 59<br>00 00 C3 C3 C3 66 | 50<br>51 | DB<br>DB | 059H<br>000H,000H,0C3H,0C3H,0C3H,066H,03CH,018H ; TH_59 Y | | | 0090 | 3C 18<br>18 18 3C 00 00 00 | 52<br>53<br>54 | DB | 018H,018H,03CH,000H,000H,000H ; BT_59 Y | | | 0096<br>0097 | 5A<br>00 00 FF C3 86 0C | 54<br>55 | DB<br>DB | 05AH<br>000H,000H,0FFH,0C3H,086H,00CH,018H,030H; TH_5A Z | | | 009F<br>00A5 | 61 C3 FF 00 00 00<br>6D | 56<br>57<br>58 | DB<br>DB | 061H,0C3H,0FFH,000H,000H,000H ; BT_5A Z | | | 00A5 | 00 00 00 00 00 E6 | 59<br>60 | DB | 000H,000H,000H,000H,000H,0E6H,0FFH,0DBH; TH_6D L. | .c. M | | 00AE<br>00B4 | DB DB DB 00 00 00<br>76 | 61<br>62 | DB<br>DB | ODBH, ODBH, ODBH, OOOH, OOOH, OOOH ; BT_6D L. | .C. M | | 00B5 | 00 00 00 00 00 C3<br>C3 C3 | 63<br>64 | DB | 000н,000н,000н,000н,000н,0сзн,осзн,осзн; тн_76 L. | | | 00BD<br>00C3 | 66 3C 18 00 00 00<br>77 | 65<br>66 | DB<br>DB | 066H,03CH,018H,000H,000H,000H ; BT_76 L. | | | 00C4 | 00 00 00 00 00 C3<br>C3 DB<br>DB FF 66 00 00 00 | 67<br>68 | DB | 000Н,000Н,000Н,000Н,000Н,0СЗН,ОСЗН,ОВВН ; ТН_77 L. | | | 00CC<br>00D2<br>00D3 | DB FF 66 00 00 00<br>91<br>00 00 00 00 6E 3B | 69<br>70<br>71<br>72 | DB<br>DB<br>DB | ODBH, OFFH, O66H, O00H, O00H, O00H ; BT_77 L. | .c. w | | OODB | 1B 7E<br>D8 DC 77 00 00 00 | 71<br>72<br>73 | DB | ооон, ооон, ооон, ооон, ооен, озвн, отвн, отен ; тн_91<br>орвн, орсн, оттн, ооон, ооон ; вт_91 | | | 00E1<br>00E2 | 9B<br>00 18 18 7E C3 C0 | 74<br>75 | DB<br>DB | 098H ; 61_91<br>000H,018H,018H,07EH,0C3H,0C0H,0C0H,0C3H ; TH_9B | | | OOEA | CO C3<br>7E 18 18 00 00 00 | 76<br>77<br>78 | DB | 07EH, 018H, 018H, 000H, 000H ; BT_9B | | | 00F0<br>00F1 | 9D<br>00 00 C3 66 3C 18 | 79 | DB<br>DB | 09DH ; 000H,000H,0C3H,066H,03CH,018H,0FFH,018H ; TH_9D | | | 00F9 | FF 18 18 00 00 00 | 80<br>81 | DB | OFFH,018H,018H,000H,000H,000H ; BT_9D | | | 00FF<br>0100 | 9E<br>00 FC 66 66 7C 62 | 82<br>83 | DB<br>DB | 09EH<br>000H,0FCH,066H,066H,07CH,062H,066H,06FH; TH_9E | | | 0108<br>010F | 66 6F<br>66 66 F3 00 00 00 | 84<br>85<br>86 | DB<br>DB | 066H,066H,0F3H,000H,000H,000H ; BT_9E | | | 010F | 00 00 18 18 18 FF<br>18 18 | 87<br>88 | DB | 000H,000H,018H,018H,018H,0FFH,018H,018H; TH_F1 | | | 0117<br>011D | 18 00 FF 00 00 00<br>F6 | 89<br>90 | DB<br>DB | 018H,000H,0FFH,000H,000H,000H ; BT_F1 | | | 011E | 00 00 18 18 00 00<br>FF 00 | 89<br>90<br>91<br>92<br>93<br>94 | DB | 000Н,000Н,018Н,018Н,000Н,000Н,0FFH,000Н ; ТН_F6 | | | 0126<br>0120 | 00 18 18 00 00 00 | 93 | DB | 000H,018H,018H,000H,000H,000H ; BT_F6 | | | 012C<br>012D | 00 | 95 CODE | DB<br>ENDS | 000H,018H,018H,000H,000H,000H ; BT_F6<br>000H ; NO MORE | | | 012C<br>012D | 00 | 95 CODE<br>96 | DB<br>ENDS<br>END | OUOH ; NO MORE | | | 012D<br>0000 | 00 | 95 CODE<br>96 | DB<br>ENDS<br>END<br>PAGE, 12<br>SUBTTL<br>SEGMENT<br>PUBLIC | OUDH ; NO MORE O DUBLE DOT CHARACTER GENERATOR PUBLIC | | | 012D<br>0000<br>0000 | • | 95 CODE<br>96 | PAGE, 12<br>SUBTTL<br>SEGMENT<br>PUBLIC<br>LABEL | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 BYTE | оот | | 012D<br>0000<br>0000<br>0000 | 00 00 00 00 00 00 | 95 CODE<br>96 | PAGE, 12<br>SUBTIL<br>SEGMENT<br>PUBLIC<br>LABEL<br>DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 BYTE OOOH, 000H, 0 | рот | | 0000<br>0000<br>0000<br>0000 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>81 7E | 95 CODE 1 2 3 CODE 4 5 CGDDOT 7 8 9 | PAGE, 12<br>SUBTIL<br>SEGMENT<br>PUBLIC<br>LABEL<br>DB | 0000H ; NO MORE 0001BLE DOT CHARACTER GENERATOR PUBLIC CORDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0_00 07EH, 081H, 085H, 081H, 080H, 099H, 081H, 07EH; 0_01 | оот | | 0000<br>0000<br>0000<br>0000<br>0008<br>0010 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>87 FF DB FF C3 E7 | 95 CODE<br>96<br>1<br>2<br>3 CODE<br>4 5 CGDDOT<br>7<br>7<br>9<br>9 | DB ENDS END PAGE, 12 SUBTIL SEGMENT PUBLIC LABEL DB DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CODDOT, INT_1F_1 BYTE OOOH, 000H, 0 | оот | | 0000<br>0000<br>0000<br>0000 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>81 7E<br>7E FF DB FF C3 E7<br>FF 7E FE FE TC 38 | 95 CODE<br>96 CODE<br>1<br>2 CODE<br>3 CODE<br>5 CGDDOT<br>6 7<br>8 9<br>9 10<br>111<br>12 13<br>13 | PAGE, 12<br>SUBTTL<br>SEGMENT<br>PUBLIC<br>LABEL<br>DB<br>DB<br>DB | ODUBLE DOT CHARACTER GENERATOR PUBLIC CEDDOT, INT_1F_1 BYTE OOOH, 000H, 000H, 000H, 000H, 000H, 000H, 000H OTEH, 081H, 0A5H, 081H, 0BH, 099H, 081H, 07EH; D_01 OTEH, 0FFH, 0DBH, 0FFH, 0C3H, 0E7H, 0FFH, 0TEH; D_02 06CH, 0FEH, 0FEH, 0FEH, 07CH, 038H, 010H, 000H; D_03 | 00Т | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018 | 00 00 00 00 00 00<br>00 00 80 81 8D 99<br>11 72 72 75 75 75 75 75 75 75 75 75 75 75 75 75 | 95 CODE<br>96 CODE<br>1<br>2<br>3 CODE<br>5 CGDDOT<br>6 CGDDOT<br>10 11 12 13 14 14 15 15 16 17 | DB ENDS END PAGE, 12 SUBTIL SEGMENT PUBLIC LABEL DB DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H 07EH, 081H, 085H, 081H, 08BH, 099H, 081H, 07EH; 0_01 07EH, 0FFH, 07EH, 07EH, 07EH, 07EH, 07EH, 0_02 06CH, 0FEH, 0FEH, 07CH, 038H, 010H, 000H; 0_03 010H, 038H, 07CH, 0FEH, 07CH, 038H, 010H, 000H; 0_04 | оот | | 0000<br>0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020 | 00 00 00 00 00 00<br>00 00 80 81 8D 99<br>11 72 72 75 75 75 75 75 75 75 75 75 75 75 75 75 | 95 CODE<br>1<br>2<br>3 CODE<br>4<br>4<br>5 GGDDOT<br>7<br>8<br>9<br>10<br>11<br>11<br>12<br>13<br>14<br>14<br>15<br>16<br>17<br>18<br>18<br>19 | DB ENDS END PAGE, 12 SUBTIL SEGMENT PUBLIC LABEL DB DB DB DB DB DB DB | ODUBLE DOT CHARACTER GENERATOR PUBLIC CEDDOT, INT_1F_1 BYTE OOOH, 000H, 000H, 000H, 000H, 000H, 000H, 000H OTEH, 081H, 0A5H, 081H, 0BH, 099H, 081H, 07EH; D_01 OTEH, 0FFH, 0DBH, 0FFH, 0C3H, 0E7H, 0FFH, 0TEH; D_02 06CH, 0FEH, 0FEH, 0FEH, 07CH, 038H, 010H, 000H; D_03 | оот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028 | 00 00 00 00 00 00<br>00 00 7E 81 A5 81 BD 99<br>12 FF DB FF C3 E7<br>FF 7E FE FE FC 7C 38<br>10 00 7C FE 7C 38<br>10 30 7C FE 7C 38<br>10 38 7C 38 FE FE 7C<br>38 7C 38 FE FE 7C<br>10 10 13 36 7C FC 7C<br>10 10 38 7C FC 7C | 95 CODE 1 2 3 CODE 3 CODE 4 CGDDOT 7 8 9 10 11 12 12 11 12 11 15 16 17 18 19 190 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; D_00 07EH, 081H, 0A9H, 081H, 08DH, 099H, 081H, 07EH; D_02 07EH, 09FH, 07EH, 07EH, 07EH, 07EH, 07EH; D_02 010H, 038H, 07CH, 07EH, 07CH, 038H, 010H, 000H; D_04 038H, 07CH, 038H, 07EH, 07CH, 038H, 010H, 000H; D_05 | оот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>81 7E<br>7E FF DB FF C3 E7<br>FF FE FF FC 38<br>10 00<br>10 38 7C FE 7C 38<br>10 00<br>38 7C 38 FE FE 7C<br>38 7C 38 7C FE 7C | 95 CODE<br>96 CODE<br>1 2 3 CODE<br>4 CODDOT<br>7 8 9<br>9 1111<br>112 13 14 14 15 116 116 117 118 119 20 21 12 22 22 22 22 2 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | OUBLE DOT CHARACTER GENERATOR PUBLIC CORDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0_00 07EH, 081H, 0A5H, 081H, 0BDH, 099H, 081H, 07EH; 0_02 07EH, 06FH, 0FEH, 07EH, 07EH, 07EH, 07EH; 0_02 06CH, 07EH, 0FEH, 07EH, 07CH, 03BH, 010H, 000H; 0_03 010H, 03BH, 07CH, 07EH, 07CH, 03BH, 010H, 000H; 0_05 010H, 010H, 03BH, 07EH, 07EH, 07CH, 03BH, 07CH; 0_05 | оот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028<br>0030 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>81 7E<br>7E FF DB FF C3 E7<br>FC C5 FE FE FC 7C 38<br>10 00 7C 8F FC 7C 38<br>10 00 38 7C FE 7C 38<br>10 00 38 7C FE 7C 38<br>10 00 00 18 3C 3C 18<br>00 00 18 3C 3C 3C 7C<br>FF FF FE FC 7C 3C 3C 3C 7C 7C 3C 3C 7C 7C 3C 3C 3C 7C 7C 3C 3C 3C 7C 3C | 95 CODE 96 CODE 1 2 3 CODE 4 CODDOT 7 8 9 9 11 11 11 11 11 11 11 11 11 11 11 11 | DB ENDS END PAGE, 12 SUBTIL SEGMENT PUBLIC LABEL DB DB DB DB DB DB DB DB DB D | OUBLE DOT CHARACTER GENERATOR DUBLIC DOT CHARACTER GENERATOR DUBLIC CORDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0_00 07EH, 081H, 0A5H, 081H, 0BDH, 099H, 081H, 07EH; 0_01 07EH, 06FH, 00EH, 07FH, 03SH, 010H, 000H; 0_03 010H, 038H, 07CH, 07EH, 07CH, 038H, 010H, 000H; 0_04 038H, 07CH, 038H, 07EH, 07CH, 038H, 07CH; 0_05 010H, 010H, 038H, 07CH, 07EH, 07CH, 038H, 07CH; 0_05 010H, 010H, 038H, 07CH, 07EH, 07CH, 038H, 07CH; 0_06 000H, 000H, 018H, 03CH, 018H, 000H, 000H; 0_07 | оот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028<br>0030<br>0048<br>0040 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>17F FD B FF C3 E7<br>6C FE FE FE TC 38<br>10 00<br>10 38 7C FE 7C<br>10 10 38 7C FE 7C<br>10 10 38 7C FE 7C<br>10 10 38 7C FE 7C<br>10 10 38 7C FE 7C<br>10 10 38 7C FE 7C<br>10 10 38 7C SE 8C<br>10 10 38 7C SE 8C<br>10 10 38 7C SE 7C<br>10 10 38 7C SE 8C<br>10 | 95 CODE 96 CODE 1 2 3 CODE 4 CODDOT 7 8 9 9 11 11 11 11 11 11 11 11 11 11 11 11 | DB ENDS END PAGE, 12 SUBTIL SEGMENT PUBLIC LABEL DB | OUBLE DOT CHARACTER GENERATOR PUBLIC COMPANY (1974) OOUBLE DOT CHARACTER GENERATOR PUBLIC (1974) OOOH, 000H, 000H, 000H, 000H, 000H, 000H, 000H; OOOH, 000H, 000H, 000H, 000H, 000H, 000H, 000H; OTEH, 081H, 0A5H, 081H, 0BDH, 099H, 081H, 07EH; OTEH, 0FFH, 0DBH, 0FFH, 0C3H, 0FFH, 0FFH, 0FFH; OOOH, 0FFH, 0FFH, 0FFH, 0FCH, 05H, 010H, 000H; OOOH, 038H, 07CH, 0FFH, 07CH, 038H, 07CH; OOOH, 000H, 038H, 07CH, 0FFH, 07CH, 038H, 07CH; OOOH, 000H, 018H, 03CH, 03CH, 018H, 000H, 000H; DOOOH, 000H, 018H, 03CH, 03CH, 018H, 00OH, 00OH; DOOOH, 00FFH, 0FFH, 0C7H, 0C3H, 0C7H, 0FFH, 0FFH; DOOOH | оот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028<br>0030<br>0040<br>0048<br>0050<br>0058 | 00 00 00 00 00 00<br>00 00<br>7E 81 A5 81 BD 99<br>81 7E FE DB FF C3 E7<br>FC FF EF FE TC 38<br>10 00 76 FE FE FE TC 38<br>10 00 76 FE FE FE TC 38<br>10 00 38 7C FE TC 38<br>10 00 00 18 3C 3C 18<br>00 00 18 3C 3C 3C 18<br>00 00 18 3C | 95 CODE 96 CODE 1 2 CODE 4 CODE 4 CODE 5 CODDOT 7 8 9 10 11 12 13 14 114 115 16 17 18 19 20 21 22 21 22 24 25 26 27 28 28 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0_00 07EH, 081H, 0A5H, 081H, 0B0H, 099H, 081H, 07EH; 0_02 07EH, 06FH, 0FEH, 0FEH, 07CH, 03BH, 010H, 000H; 0_03 010H, 038H, 07CH, 0FEH, 07CH, 03BH, 010H, 000H; 0_04 03BH, 07CH, 03BH, 0FEH, 07CH, 03BH, 010H, 000H; 0_05 010H, 010H, 03BH, 07CH, 0FEH, 07CH, 03BH, 07CH; 0_05 010H, 010H, 03BH, 07CH, 0FEH, 07CH, 03BH, 07CH; 0_06 000H, 03CH, 06GH, 04CH, 06CH, 05CH, 05CH, 07CH; 0_08 0FFH, 0CFH, 0CFH, 0CH, 04CH, 06CH, 03CH, 06H; 0_09 0FFH, 0CSH, 099H, 0B0H, 0B0H, 099H, 0CSH, 0FFH; 0_0A 00FH, 007H, 00FH, 07DH, 0CCH, 0CCH, 0CCH, 07CH, 07BH; 0_0B | рот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0018<br>0020<br>0028<br>0030<br>0048<br>0050<br>0058<br>0060 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 CODE 1 2 CODE 1 4 CODE 4 CODE 6 CODDOT 7 CODE 11 11 11 11 11 11 11 11 11 11 11 11 11 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | OUBLE DOT CHARACTER GENERATOR PUBLIC CORDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0_00 07EH, 081H, 0A5H, 081H, 0BDH, 099H, 081H, 07EH; 0_01 07EH, 06FH, 05FH, 05EH, 07EH, 07EH, 07EH; 0_02 06CH, 07EH, 07EH, 07EH, 07CH, 038H, 010H, 000H; 0_03 010H, 038H, 07CH, 07EH, 07CH, 038H, 010H, 000H; 0_04 038H, 07CH, 038H, 07EH, 07CH, 038H, 07CH; 0_05 010H, 010H, 038H, 07EH, 07EH, 07CH, 038H, 07CH; 0_06 000H, 000H, 018H, 03CH, 03CH, 01CH, 05CH, 07CH 07FH, 05TH, 05TH, 05TH, 05TH, 05TH, 07CH 07FH, 05TH, 05TH, 05TH, 05TH, 05TH, 05TH; 0_08 000H, 30CH, 066H, 04CH, 04CH, 06CH, 03CH, 000H; 0_09 00FH, 007H, 007H, 05TH, 05CH, 05CH, 05TH, 07TH; 0_08 03CH, 06GH, 06GH, 06GH, 03CH, 018H, 07EH, 018H; 0_0B | ООТ | | 0000<br>0000<br>0000<br>0008<br>0010<br>0020<br>0028<br>0030<br>0040<br>0048<br>0050<br>0058<br>0060 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 CODE 1 2 CODE 1 3 CODE 4 GODOT 7 8 9 10 11 12 13 14 15 16 17 16 17 18 19 20 21 22 24 25 26 28 29 30 30 31 31 33 34 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | 0 DUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H 07EH, 061H, 065H, 061H, 068H, 099H, 081H, 07EH; 0_01 07EH, 0FFH, 0FEH, 07CH, 038H, 010H, 000H; 0_02 06CH, 07EH, 0FEH, 07CH, 038H, 010H, 000H; 0_03 010H, 038H, 07CH, 0FEH, 07CH, 038H, 010H, 000H; 0_04 038H, 07CH, 038H, 07CH, 07CH, 038H, 07CH; 0_05 010H, 010H, 038H, 07CH, 05CH, 07CH, 038H, 07CH; 0_06 000H, 000H, 010H, 03CH, 03CH, 018H, 000H, 00H; 0_07 0FFH, 0FFH, 0E7H, 0C3H, 0C3H, 0E7H, 0FFH, 0FFH; 0_08 000H, 03CH, 066H, 042H, 04CH, 06CH, 03CH, 000H; 0_09 01FH, 05TH, 09TH, 07CH, 03CH, 018H, 07CH, 018H; 0_08 03CH, 06GH, 06CH, 05CH, 03CH, 07CH, 018H; 0_0B 03CH, 06GH, 06GH, 06CH, 03CH, 018H, 07CH, 018H; 0_0C 03FH, 033H, 03GH, 03GH, 03CH, 07CH, 016H; 0_0C | т | | 0000<br>0000<br>0000<br>0000<br>0008<br>0010<br>0020<br>0028<br>0030<br>0040<br>0048<br>0050<br>0058<br>0060<br>0068 | 00 00 00 00 00 00<br>00 00 7E 81 A5 81 BD 99<br>81 7E FF DB FF C3 E7<br>FF FD BF FC 38 81<br>10 00 7E FE FE FC 7C 38<br>10 00 7E FE FE FC 7C 38<br>10 00 38 7C FE 7C 38<br>10 00 18 3C 3C 18<br>00 | 95 CODE 96 CODE 1 2 CODE 3 CODE 5 CGDDOT 7 CGDDOT 11 11 11 11 11 11 11 11 11 11 11 11 11 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | тоот | | 0000<br>0000<br>0000<br>0008<br>0010<br>0028<br>0030<br>0038<br>0040<br>0058<br>0060<br>0068<br>0070 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 CODE 1 2 CODE 4 CODE 5 CODDOT 7 8 9 9 1111 112 113 114 115 116 117 118 119 121 221 222 23 244 245 247 28 29 29 30 31 31 31 31 31 31 31 31 31 31 31 31 31 | DB CAME CAM | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 000H, | торот | | 0000<br>0000<br>0000<br>0000<br>0010<br>0018<br>0020<br>0028<br>0030<br>0040<br>0048<br>0050<br>0058<br>0060<br>0068<br>0070 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 CODE 1 2 CODE 4 CODE 5 CODDOT 7 8 9 9 10 11 11 12 13 134 114 119 122 13 19 15 16 17 18 19 19 20 21 22 23 24 25 26 27 28 29 29 29 30 31 32 33 34 35 36 37 38 39 40 40 40 | DB ENDS ENDS ENDS ENDS ENDS ENDS ENDS ENDS | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 000H, | О | | 0000<br>0000<br>0000<br>0008<br>0010<br>0028<br>0030<br>0038<br>0040<br>0058<br>0060<br>0068<br>0070<br>0078 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 4 5 GGDDOT 7 8 9 9 1111 112 113 114 115 117 118 119 122 122 123 124 125 126 127 128 129 129 120 121 121 121 121 122 123 124 125 126 127 128 129 129 120 120 120 120 120 120 120 120 120 120 | DB COMMENT OF THE PROPERTY | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 900H, 000H, 07CH, 07CH, 03CH, 010H, 000H, 000H, 000H, 07CH, 07CH, 07CH, 07CH, 03SH, 010H, 000H, 00H, 00H, 000H, 00CH, 07CH, 07CH, 07CH, 07CH, 03SH, 07CH, 0DCH, 00CH, 0 | т | | 0000<br>0000<br>0000<br>0008<br>0010<br>0028<br>0030<br>0038<br>0040<br>0058<br>0060<br>0068<br>0070<br>0078 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 4 5 CGDDOT 7 8 9 91 111 113 114 115 116 117 118 119 20 21 22 22 23 24 24 25 26 26 27 28 29 29 30 31 31 31 31 31 31 31 31 31 31 31 31 31 | PAGE, 12: PAGE, 12: SEGMENT FROM PAGE DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CORDOT, INT_1F_1 SYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; DOTEH, 061H, 065H, 065H, 067H, 067H, 076H; DOTEH, 061H, 067H, 067H, 076H, 038H, 010H, 000H; DOTEH, 061H, 076H, 076H, 076H, 038H, 010H, 000H; DOTEH, 076H, 076H, 076H, 076H, 038H, 010H, 000H; DOTEH, 076H, 076H, 076H, 076H, 038H, 070H; DOTEH, 076H, 076H, 076H, 076H, 038H, 070H; DOTEH, 076H, 076H, 076H, 076H, 038H, 070H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 077H, 063H, 076H, 076H, 076H; DOTEH, 077H, 063H, 076H, 076H, 076H; DOTEH, 077H, 063H, 076H, 076H, 076H; DOTEH, 077H, 063H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 076H, 076H, 076H, 076H, 076H, 076H, 076H; DOTEH, 0 | DOT | | 0000<br>0000<br>0000<br>0000<br>0018<br>0020<br>0028<br>0030<br>0048<br>0050<br>0060<br>0068<br>0060<br>0078 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 4 4 5 CODE 4 5 CODE 6 7 8 9 9 10 11 11 12 13 14 15 16 17 17 18 19 20 21 22 23 24 25 26 27 28 29 30 30 31 32 33 34 35 36 37 38 39 40 40 44 44 44 44 44 44 44 44 44 44 44 | PAGE, 12 SEGMENT PAGE, 12 SEGMENT PAGE SEGMENT PAGE DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CORDOT, INT_1F_1 BYTE 000H, 000H, 000H, 000H, 000H, 000H, 000H, 000H; 0 0.00 07EH, 081H, 0A5H, 081H, 0BDH, 099H, 081H, 07EH; 0 0.01 07EH, 06FH, 0FEH, 0FEH, 07EH, 03HH, 010H, 07EH; 0 0.02 06CH, 07EH, 0FEH, 07EH, 07EH, 03HH, 010H, 000H; 0 0.03 010H, 038H, 07CH, 0FEH, 07CH, 03HH, 010H, 000H; 0 0.05 010H, 010H, 038H, 07CH, 0FEH, 07CH, 038H, 07CH; 0 0.05 010H, 010H, 038H, 07CH, 05HH, 07CH, 03HH, 07CH; 0 0.05 010H, 010H, 038H, 07CH, 05HH, 07CH, 03HH, 07CH; 0 0.05 010H, 010H, 03HH, 07CH, 05HH, 07CH, 03HH, 07CH; 0 0.06 000H, 03CH, 06CH, 04CH, 04CH, 06CH, 03CH, 000H; 0 0.09 0FFH, 0C3H, 099H, 0BDH, 099H, 0C3H, 0FFH; 0 0.08 03CH, 06CH, 06CH, 06CH, 03CH, 01CH, 07CH; 0 0.01 03SH, 03SH, 03SH, 03SH, 03OH, 07OH, 0FOH, 0FOH; 0 0.00 03FH, 03SH, 03FH, 03SH, 06SH, 06TH, 06CH; 0 0.00 07FH, 06SH, 06CH, 06CH, 06CH, 06CH, 06CH; 0 0.00 08OH, 08OH, 05CH, 05CH, 05CH, 06CH, 00CH; 0 0.00 08OH, 06OH, 07CH, 06SH, 06CH, 06CH, 00CH; 0 0.00 00CH, 03CH, 07CH, 06SH, 07CH, 06CH, 00CH; 0 0.00 00CH, 03CH, 07CH, 06SH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 07CH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 01CH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 01CH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 01CH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 01CH, 07CH, 06CH, 00CH; 0 0.01 00CH, 03CH, 07CH, 01CH, 01CH, 07CH, 00CH, 00CH; 0 0.01 | оот | | 0000<br>0000<br>0000<br>0000<br>0008<br>0018<br>0020<br>0028<br>0030<br>0048<br>0050<br>0058<br>0060<br>0068<br>0070<br>0078<br>0088<br>0090<br>0098 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 4 4 CODE 5 CGDDOT 7 8 9 10 11 11 12 13 14 15 16 17 17 18 19 20 21 22 24 25 26 22 24 25 26 22 28 30 31 33 32 33 33 33 34 35 36 37 38 39 40 41 44 44 45 46 44 44 45 | DB COMMENT OF THE COM | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 000H, | ООТ | | 0000<br>0000<br>0000<br>0000<br>0018<br>0020<br>0028<br>0030<br>0048<br>0050<br>0060<br>0068<br>0060<br>0078 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 1 4 4 5 CODDOT 7 6 7 7 8 9 10 11 11 12 13 14 15 16 17 11 18 19 20 1 22 23 24 25 6 26 27 28 29 30 31 31 32 33 34 35 36 37 38 39 40 41 42 43 44 44 44 44 44 44 44 44 44 44 44 44 | PAGE, 12 SEGMENT PAGE, 12 SEGMENT PAGE SEGMENT PAGE DB | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 900H, 000H, | О | | 0000<br>0000<br>0000<br>0000<br>0010<br>0018<br>0020<br>0028<br>0038<br>0040<br>0048<br>0050<br>0068<br>0070<br>0078<br>0080<br>0080<br>0088<br>0090<br>0098 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 1 4 4 5 CODDOT 7 6 7 7 8 9 10 11 11 12 13 14 15 16 17 11 18 19 20 1 22 23 24 25 6 26 27 28 29 30 31 31 32 33 34 35 36 37 38 39 40 41 42 43 44 44 44 44 44 44 44 44 44 44 44 44 | DB COMMENT OF THE COM | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 900H, 000H, | О | | 0000<br>0000<br>0000<br>0000<br>0010<br>0018<br>0020<br>0028<br>0030<br>0040<br>0040<br>0050<br>0068<br>0070<br>0078<br>0080<br>0090<br>0098<br>0090<br>0090 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 95 CODE 96 1 2 3 CODE 4 4 CODE 5 CGDDOT 7 8 9 10 11 11 12 13 14 15 16 17 17 18 19 20 21 22 24 25 26 22 24 25 26 22 28 30 31 33 32 33 33 33 34 35 36 37 38 39 40 41 44 44 45 46 44 44 45 | DB COMMENT OF THE PROPERTY | OUBLE DOT CHARACTER GENERATOR PUBLIC CGDDOT, INT_1F_1 900H, 000H, | DOT | | 0008 | 18 00<br>18 18 18 18 7E 3C | 57<br>58 | DB | 018H,018H,018H,018H,07EH,03CH,018H,000H ; D_19 | |--------------|-------------------------------------------------|-------------------|----------|----------------------------------------------------------------------------------------------------| | 00D0 | 18 00<br>00 18 0C FE 0C 18 | 59<br>60 | DB | 000H,018H,00CH,0FEH,00CH,018H,000H,000H ; D_1A | | 00D8 | 00 00<br>00 30 60 FE 60 30<br>00 00 | 61<br>62 | DB | 000H,030H,060H,0FEH,060H,030H,000H,000H ; D_1В | | 00E0 | 00 00 CO CO CO FE<br>00 00 | 63<br>64<br>65 | DB | 000H,000H,0C0H,0C0H,0FEH,000H,000H ; D_1C | | 00E8 | 00 24 66 FF 66 24<br>00 00 | 66<br>67 | DB | 000H,024H,066H,0FFH,066H,024H,000H,000H ; D_1D | | 00F0 | 00 18 3C 7E FF FF.<br>00 00 | 68<br>69 | DB | 000H,018H,03CH,07EH,0FFH,0FFH,000H,000H ; D_1E | | 00F8 | 00 FF FF 7E 3C 18<br>00 00 | 70<br>71 | DB | 000H,0FFH,0FFH,07EH,03CH,018H,000H,000H ; D_1F | | 0100 | 00 00 00 00 00 00 | 72<br>73<br>74 | DB | 000H,000H,000H,000H,000H,000H,000H; SP D_20 | | 0108 | 30 78 78 30 30 00<br>30 00 | 75<br>76 | DB | 030H,078H,078H,030H,030H,000H,030H,000H ; ! D_21 | | 0110 | 6C 6C 6C 00 00 00<br>00 00 | 77<br>78 | DB | 06CH,06CH,06CH,000H,000H,000H,000H; " D_22 | | 0118 | 6C 6C FE 6C FE 6C<br>6C 00 | 79<br>80 | DB | 06CH,06CH,0FEH,06CH,0FEH,06CH,06CH,000H ; # D_23 | | 0120 | 30 7C CO 78 OC F8<br>30 00 | 81<br>82 | DB | 030H,07CH,0C0H,078H,00CH,0F8H,030H,000H ; \$ 0_24 | | 0128 | 00 C6 CC 18 30 66<br>C6 00 | 83<br>84 | DB | 000H,0C6H,0CCH,018H,030H,066H,0C6H,000H; PER CENT D_25 | | 0130 | 38 6C 38 76 DC CC<br>76 00 | 85<br>86 | DB | 038H,06CH,038H,076H,0DCH,0CCH,076H,000H ; & D_26 | | 0138 | 60 60 CO 00 00 00<br>00 00 | 87<br>88 | DB | 060H,060H,0СОH,000H,000H,000H,000H; ' D_27 | | 0140 | 18 30 60 60 60 30<br>18 00 | 89<br>90 | DB | 018H,030H,060H,060H,060H,030H,018H,000H ; ( D_28 | | 0148 | 60 30 18 18 18 30<br>60 00 | 91<br>92 | DB | 060H,030H,018H,018H,018H,030H,060H,000H ; ) D_29 | | 0150 | 00 66 3C FF 3C 66<br>00 00 | 93<br>94 | DB | 000H,066H,03CH,0FFH,03CH,066H,000H,000H; * D_2A | | 0158 | 00 30 30 FC 30 30<br>00 00 | 95<br>96 | DB | 000H,030H,030H,0FCH,030H,030H,000H,000H; + D_2B | | 0160 | 00 00 00 00 00 30<br>30 60<br>00 00 00 FC 00 00 | 97<br>98<br>99 | DB<br>DB | 000H,000H,000H,000H,000H,030H,030H,060H; , D_2C<br>000H,000H,000H,0FCH,000H,000H,000H,000H; - D_2D | | 0168 | 00 00 00 FC 00 00<br>00 00 00 00 00 30 | 100<br>101 | DB | 000H,000H,000H,000H,000H,030H,030H,000H ; . D_2E | | 0178 | 30 00<br>06 0C 18 30 60 C0 | 102 | DB | 006H,00CH,018H,030H,060H,0COH,080H,000H; / D_2F | | 0.70 | 80 00 | 104<br>105 | 00 | 0001,0001,0101,0001,0001,0001,0001,0001 | | 0180 | 7C C6 CE DE F6 E6<br>7C 00 | 106<br>107 | DB | 07CH,0C6H,0CEH,0DEH,0F6H,0E6H,07CH,000H ; 0 D_30 | | 0188 | 30 70 30 30 30 30<br>FC 00 | 108<br>109 | DB | 030H,070H,030H,030H,030H,0FCH,000H ; 1 D_31 | | 0190 | 78 CC OC 38 60 CC<br>FC 00 | 110<br>111 | DB | 078H,0CCH,00CH,038H,060H,0CCH,0FCH,000H ; 2 D_32 | | 0198 | 78 CC OC 38 OC CC<br>78 OO | 112<br>113 | DB | 078H,0ССH,00СH,038H,00СH,0ССH,078H,000H ; 3 D_33 | | 01A0 | 1C 3C 6C CC FE 0C<br>1E 00 | 114<br>115 | DB | 01CH,03CH,06CH,0CCH,0FEH,00CH,01EH,000H ; 4 D_34 | | 01A8 | FC CO F8 OC OC CC<br>78 00 | 116<br>117 | DB | 0FCH, OCOH, OF8H, OOCH, OOCH, O78H, OOOH ; 5 D_35 | | 01B0 | 38 60 C0 F8 CC CC<br>78 00 | 118<br>119 | DB | 038H,060H,0COH,0F8H,0CCH,0CCH,078H,000H ; 6 D_36 | | 01B8<br>01C0 | FC CC OC 18 30 30<br>30 00<br>78 CC CC 78 CC CC | 120<br>121 | DB | 0FCH,0CCH,00CH,018H,030H,030H,030H,000H ; 7 D_37 | | 0108 | 78 00<br>78 CC CC 7C OC 18 | 123 | DB<br>DB | 078H,0CCH,0CCH,078H,0CCH,0CH,078H,000H; 8 D_38<br>078H,0CCH,0CCH,07CH,00CH,018H,070H,000H; 9 D_39 | | 0100 | 70 00<br>00 30 30 00 00 30 | 125<br>126 | DB | 000H,030H,030H,000H,000H,030H,030H,000H; : D_3A | | 0108 | 30 00<br>00 30 30 00 00 30 | 127<br>128 | DB | 000H,030H,030H,000H,030H,030H,060H ; ; D_3B | | 01E0 | 30 60<br>18 30 60 CO 60 30 | 129<br>130 | DB | 018H,030H,060H,0C0H,060H,030H,018H,000H; < D_3C | | 01E8 | 18 00<br>00 00 FC 00 00 FC | 131<br>132 | DB | 000H,000H,0FCH,000H,00OH,0FCH,000H,000H; = D_3D | | 01F0 | 00 00<br>60 30 18 0C 18 30 | 133<br>134 | DB | 060H,030H,018H,00CH,018H,030H,060H,000H; > D_3E | | 01F8 | 60 00<br>78 CC 0C 18 30 00<br>30 00 | 135<br>136<br>137 | DB | 078H,0CCH,00CH,018H,030H,000H,030H,000H ; ? D_3F | | 0200 | 7C C6 DE DE DE CO | 138 | DB | 07CH, OC6H, ODEH, ODEH, OCOH, O78H, OOOH ; @ D_40 | | 0208 | 78 00<br>30 78 CC CC FC CC | 140<br>141 | DB | 030H,078H,0CCH,0CCH,0FCH,0CCH,0CCH,000H; A D_41 | | 0210 | CC 00<br>FC 66 66 7C 66 66 | 142<br>143 | DB | 0FCH,066H,07CH,066H,066H,0FCH,000H; B D_42 | | 0218 | FC 00<br>3C 66 CO CO CO 66 | 144<br>145 | DB | 03CH,066H,0C0H,0C0H,0C0H,066H,03CH,000H ; C D_43 | | 0220 | 3C 00<br>F8 6C 66 66 66 6C | 146<br>147 | DB | OF8H,06CH,066H,066H,06CH,0F8H,000H ; D D_44 | | 0228 | F8 00<br>FE 62 68 78 68 62 | 148<br>149 | DB | OFEH,062H,068H,078H,068H,062H,0FEH,000H ; E D_45 | | 0230 | FE 00<br>FE 62 68 78 68 60 | 150<br>151 | DB | OFEH,062H,068H,078H,068H,060H,0F0H,000H ; F D_46 | | 0238 | FO 00<br>3C 66 CO CO CE 66 | 152 | DB | 03CH,066H,0C0H,0COH,0CEH,066H,03EH,000H ; G D_47 | | 0240 | SE 00<br>CC CC CC FC CC CC<br>CC 00 | 154<br>155 | DB | OCCH,OCCH,OCCH,OCCH,OCCH,OCCH,OOOH; H D_48 | | 0248 | 78 30 30 30 30 30<br>78 00 | 157 | DB | 078H,030H,030H,030H,030H,078H,000H ; I D_49 | | 0250 | 1E 0C 0C 0C CC CC | 159 | DB | 01EH,00CH,00CH,00CH,0CCH,0CCH,078H,000H ; J D_4A | | 0258 | E6 66 6C 78 6C 66<br>E6 00 | 161<br>162 | DB | 0E6H,066H,06CH,078H,06CH,066H,0E6H,000H ; K D_4B | | 0260 | F0 60 60 60 62 66<br>FE 00 | 163<br>164 | DB | ОFОH,О6ОH,О6ОH,О6ОH,О62H,О66H,ОFEH,ОООН ; L D_4C | | 0268 | C6 EE FE FE D6 C6<br>C6 00 | 165<br>166 | DB | OC6H,OEEH,OFEH,OFEH,OD6H,OC6H,OC6H,OOOH ; M D_4D | | 0270 | C6 E6 F6 DE CE C6 | 167<br>168 | DB | OC6H, OE6H, OF6H, ODEH, OC6H, OC6H, OOOH ; N D_4E | | 0278 | C6 00<br>38 6C C6 C6 C6 6C<br>38 00 | 169<br>170<br>171 | DB | 038H,06CH,0C6H,0C6H,0C6H,06CH,038H,000H ; 0 D_4F | | 0280 | FC 66 66 7C 60 60<br>FO 00 | 171<br>172<br>173 | DB | OFCH,066H,066H,07CH,060H,060H,0FOH,000H ; P D_50 | | 0288 | 78 CC CC CC DC 78 | 173<br>174<br>175 | DB | 078H,0CCH,0CCH,0CCH,0DCH,078H,01CH,000H ; Q D_51 | | 0290 | FC 66 66 7C 6C 66<br>E6 00 | 176<br>177 | DB | OFCH,066H,066H,07CH,06CH,066H,0E6H,000H ; R D_52 | | 0298 | 78 CC EO 70 1C CC | 178<br>179 | DB | 078H,0CCH,0EOH,070H,01CH,0CCH,078H,000Н ; S D_53 | | 02A0 | 78 00<br>FC B4 30 30 30 30<br>78 00 | 180<br>181 | DB | OFCH, OB4H, O3OH, O3OH, O3OH, O78H, OOOH ; T D_54 | | 02A8 | cc cc cc cc cc | 182 | DB | OCCH,OCCH,OCCH,OCCH,OCCH,OFCH,OOOH; U D_55 | | | | | | | ``` กรหก CC CC CC 78 DB OCCH, OCCH, OCCH, OCCH, OCCH, O78H, O30H, O00H + V D 56 0288 C6 D6 FE EE DB OC6H, OC6H, OC6H, OD6H, OFFH, OFFH, OC6H, OOOH : W D 57 0200 6C 38 38 6C DB OC6H, OC6H, O6CH, O38H, O38H, O6CH, OC6H, O0OH : X D 58 CC 78 30 30 0208 DB OCCH.OCCH.OCCH.078H.030H.030H.078H.000H : Y D 59 0200 8C 18 32 66 DB OFEH. OC6H. O8CH. 018H. 032H. 066H. OFEH. 000H : Z D 5A 0208 60 60 60 60 DΒ 078H.060H.060H.060H.060H.060H.078H.000H : [ D 5B 30 18 0C 06 02E0 DR DOOR DOOR DOOR DIEN DOOR DOOR DOOR . BACKSLASH D. SC 0258 18 18 18 18 ÐΒ 078H . 018H . 018H . 018H . 018H . 018H . 078H . 000H · 1 D 5D 02F0 6C C6 00 00 DB 010H, 038H, 06CH, 0C6H, 000H, 000H, 000H, 000H : CIRCUMFLEX D 5E 00 00 00 00 02F8 000H.000H.000H,000H,000H,000H,0FFH; _ D_5F DB 30 18 00 00 00 00 0300 DB 030H, 030H, 018H, 000H, 000H, 000H, 000H, 000H + 1 D, 60 0308 78 OC 7C CC DB 000H, 000H, 078H, 00CH, 07CH, 0CCH, 076H, 000H : LOWER CASE A D 61 60 7C 66 66 0310 DB OEOH, 060H, 060H, 07CH, 066H, 066H, 0DCH, 000H + L.C. B D 62 78 CC CO CC 0318 DB 000H,000H,078H,0CCH,0C0H,0CCH,078H,000H : L.C. C D 63 oc 7c cc cc 0320 DB 01CH.00CH.00CH.07CH.0CCH.0CCH.076H.000H : L.C. D D 64 0328 78 CC FC CO DB 000H, 000H, 078H, 000H, 050H, 000H, 078H, 000H + 1, C, F, D, 65 60 F0 60 60 0330 DB D38H D6CH D60H DF0H D60H D60H DF0H D00H + 1 C F D 66 0338 76 CC CC 7C DB 000H, 000H, 076H, 0CCH, 0CCH, 07CH, 00CH, 0F8H + 1 , C , G D 67 0340 6C 76 66 66 DB OFOH, 060H, 06CH, 076H, 066H, 066H, 0F6H, 000H + 1, C, H D 68 0348 70 30 30 30 DB 030H, 000H, 070H, 030H, 030H, 030H, 078H, 000H + 1, C, 1, D, 69 0350 OC OC OC CC DB OOCH, OOCH, OOCH, OOCH, OCCH, OCCH, O78H : L.C. J D 6A 66 6C 78 6C 0358 DB OEOH. 060H. 066H. 06CH. 078H. 06CH. 0E6H. 000H : L.C. K D 6E 0360 30 30 30 30 DB 070H.030H.030H.030H.030H.030H.078H.000H : L.C. L D 6C 0368 CC FE FE D6 DB 000H,000H,0CCH,0FEH,0FEH,0D6H,0C6H,000H ; L.C. M D_6D 0370 00 F8 CC CC CC DB 000H,000H,0F8H,0CCH,0CCH,0CCH,0CCH,000H : L.C. N D 6E 78 CC CC CC 0378 DB 000H, 000H, 078H, 0CCH, 0CCH, 0CCH, 078H, 000H + 1, C, 0, D, 6E 0380 00 00 DC 66 66 7C 60 F0 DB 000H-000H-0DCH-066H-066H-07CH-060H-0F0H + L C P D 70 0388 76 CC CC 7C DB 000H-000H-076H-0CCH-0CCH-07CH-00CH-01FH : 1.C. 0 D 71 0390 00 DC 76 66 60 DB 000H, 000H, 0DCH, 076H, 066H, 060H, 0F0H, 000H + 1, C, R D 72 7C CO 78 OC 0398 DB 000H,000H,07CH,0C0H,078H,00CH,0F8H,000H : L.C. S D 73 30 7C 30 30 34 03A0 DB 010H, 030H, 07CH, 030H, 030H, 034H, 018H, 000H; L.C. T D 74 00 CC CC CC CC 03A8 DB 000H, 000H, 0CCH, 0CCH, 0CCH, 0CCH, 076H, 000H + 1, C, U D 75 03B0 00 CC CC CC 78 DB 000H,000H,0CCH,0CCH,0CCH,078H,030H,000H : L.C. V D 76 0388 00 C6 D6 FE FE DB 000H,000H,0C6H,0D6H,0FEH,0FEH,06CH,000H; L.C. W D_77 00 00 C6 6C 38 6C 03C0 DB 000H,000H,0C6H,06CH,038H,06CH,0C6H,000H : L.C. X D 78 00 CC CC CC 7C 03C8 DB 000H,000H,0CCH,0CCH,0CCH,07CH,00CH,0F8H : L.C. Y D 79 03D0 00 FC 98 30 64 DB 000H,000H,0FCH,098H,030H,064H,0FCH,000H : L.C. Z D 7A 30 30 EO 30 30 03D8 DB 01CH, 030H, 030H, 0EOH, 030H, 030H, 01CH, 000H : L BRAK D 7E 03E0 18 00 18 18 DB 018H,018H,018H,000H,018H,018H,018H,000H ; | D 7C 03E8 30 1C 30 30 DB OEOH, 030H, 030H, 01CH, 030H, 030H, 0EOH, 000H; R BRAK D 7D 03F0 00 00 00 00 DB 076H, 0DCH, 000H, 000H, 000H, 000H, 000H; TILDE D 7E 38 6C C6 C6 03F8 ns 000H, 010H, 038H, 06CH, 0C6H, 0C6H, 0FEH, 000H ; DELTA D_7F 0400 INT 1F 1 LABEL BYTE 78 CC CO CC 78 18 0C 78 0400 DB 078H, 0CCH, 0C0H, 0CCH, 078H, 018H, 00CH, 078H : 0408 00 CC CC CC DB 000H, OCCH, 000H, OCCH, OCCH, OCCH, 07EH, 000H; 78 CC FC CO 0410 DR 01CH,000H,078H,0CCH,0FCH,0COH,078H,000H; 3C 06 3E 66 0418 DB 07EH, 0C3H, 03CH, 006H, 03EH, 066H, 03FH, 000H; 78 OC 7C CC 0420 DB OCCH,000H,078H,00CH,07CH,0CCH,07EH,000H : 78 OC 7C CC 0428 DB OEOH, 000H, 078H, 00CH, 07CH, OCCH, 07EH, 000H; 0430 78 OC 7C CC DB 030H, 030H, 078H, 00CH, 07CH, 0CCH, 07EH, 000H; 0438 78 CO CO 78 DB 000H,000H,078H,0C0H,0C0H,078H,00CH,038H : 0440 3C 66 7E 60 DB 07EH.0C3H.03CH.066H.07EH.060H.03CH.000H : 78 CC FC CO 0448 DR OCCH, 000H, 078H, OCCH, OFCH, OCOH, 078H, 000H; 0450 78 CC FC C0 DR OEOH, 000H, 078H, OCCH, OFCH, OCOH, 078H, 000H; 0458 70 30 30 30 DB OCCH,000H,070H,030H,030H,030H,078H,000H; 0460 38 18 18 18 DB 07CH, 0C6H, 038H, 018H, 018H, 018H, 03CH, 000H; 70 30 30 30 0468 DB OEOH,000H,070H,030H,030H,030H,078H,000H ; 6C C6 FE C6 0470 DB OC6H, 038H, O6CH, OC6H, OFEH, OC6H, OC6H, OO0H; 00 78 CC FC 0478 DB 030H, 030H, 000H, 078H, OCCH, OFCH, OCCH, 000H; 1C 00 FC 60 78 60 FC 00 00 00 7F 0C 7F CC 0480 DB 01CH,000H,0FCH,060H,078H,060H,0FCH,000H ; D_90 0488 000H,000H,07FH,00CH,07FH,0CCH,07FH,000H; ``` | | 7F 00 | 309 | | | |------|-------------------------------------|------------|----------|--------------------------------------------------------| | 0490 | 3E 6C CC FE CC CC<br>CE 00 | 310<br>311 | DB | O3EH,O6CH,OCCH,OFEH,OCCH,OCCH,OCEH,OOOH; D_92 | | 0498 | 78 CC 00 78 CC CC<br>78 00 | 312<br>313 | DB | 078H, OCCH, 000H, 078H, OCCH, OCCH, 078H, 000H ; D_93 | | 04A0 | 00 CC 00 78 CC CC | 314 | DB | 000H,0CCH,000H,078H,0CCH,0CCH,078H,000H ; D_94 | | 04A8 | 00 E0 00 78 CC CC | 316 | DB | 000H,0E0H,000H,078H,0CCH,0CCH,078H,000H ; D_95 | | 04B0 | 78 00<br>78 CC 00 CC CC CC | 317<br>318 | DB | 078H, OCCH, OOOH, OCCH, OCCH, OCCH, O7EH, OOOH ; D_96 | | 04B8 | 7E 00<br>00 E0 00 CC CC CC | 319<br>320 | DB | 000H.0E0H.000H.0CCH.0CCH.0CCH.07EH.000H : D 97 | | 0400 | 7E 00<br>00 CC 00 CC CC 7C | 321 | DB | 000H,0CCH,000H,0CCH,0CCH,07CH,00CH,0F8H; D_98 | | 0408 | 0C F8<br>C3 18 3C 66 66 3C | 323 | DB | | | | 18 00 | 325 | | | | 04D0 | CC 00 CC CC CC CC<br>78 00 | 326<br>327 | DB | оссн, ооон, оссн, оссн, оссн, отян, ооон ; D_9A | | 04D8 | 18 18 7E CO CO 7E<br>18 18 | 328<br>329 | DB | 018H,018H,07EH,0COH,0COH,07EH,018H,018H; D_9B | | 04E0 | 38 6C 64 FO 60 E6<br>FC 00 | 330 | DB | 038H,06CH,064H,0F0H,060H,0E6H,0FCH,000H ; D_9C | | 04E8 | CC CC 78 FC 30 FC | 332 | DB | OCCH,OCCH,078H,OFCH,030H,OFCH,030H,030H ; D_9D | | 04F0 | F8 CC CC FA C6 CF | 334 | DB | OF8H, OCCH, OCCH, OFAH, OC6H, OCFH, OC6H, OC7H ; D_9E | | 04F8 | C6 C7<br>OE 1B 18 3C 18 18<br>D8 70 | 335<br>336 | DB | OOEH,01BH,018H,03CH,018H,018H,0D8H,07OH ; D_9F | | | | 337<br>338 | | | | 0500 | 1C 00 78 0C 7C CC<br>7E 00 | 339 | DB | 01CH,000H,078H,00CH,07CH,0CCH,07EH,000H ; D_A0 | | 0508 | 38 00 70 30 30 30<br>78 00 | 341 | DB | 038H,000H,070H,030H,030H,078H,000H ; D_A1 | | 0510 | 00 1C 00 78 CC CC | 343 | DB | 000H,01CH,000H,078H,0CCH,0CCH,078H,000H; D_A2 | | 0518 | 78 00<br>00 1C 00 CC CC CC | 344<br>345 | DB | 000H,01CH,000H,0CCH,0CCH,0CCH,07EH,000H ; D_A3 | | 0520 | 7E 00<br>00 F8 00 F8 CC CC | 346<br>347 | DB | 000H,0F8H,000H,0F8H,0CCH,0CCH,0CCH,000H; D_A4 | | 0528 | CC 00<br>FC 00 CC EC FC DC | 348 | DB | OFCH,000H,0CCH,0ECH,OFCH,0DCH,0CCH,000H; D_A5 | | | CC 00 | 350 | DB | | | 0530 | 3C 6C 6C 3E 00 7E<br>00 00 | 352 | | | | 0538 | 38 6C 6C 38 00 7C<br>00 00 | 353<br>354 | DB | 038H,06CH,06CH,038H,000H,07CH,000H,000H; D_A7 | | 0540 | 30 00 30 60 C0 CC<br>78 00 | 355<br>356 | DB | 030H,000H,030H,060H,0C0H,0CCH,078H,000H ; D_A8 | | 0548 | 00 00 00 FC CO CO<br>00 00 | 357<br>358 | DB | 000H,000H,000H,0FCH,0COH,0COH,000H,000H; D_A9 | | 0550 | 00 00 00 FC 0C 0C<br>00 00 | 359<br>360 | DB | 000H,000H,000H,0FCH,00CH,00CH,000H,000H; D_AA | | 0558 | C3 C6 CC DE 33 66 | 361<br>362 | DB | OC3H,OC6H,OCCH,ODEH,O33H,O66H,OCCH,OOFH ; D_AB | | 0560 | C3 C6 CC DB 37 6F | 363 | DB | OC3H, OC6H, OCCH, ODBH, O37H, O6FH, OCFH, O03H ; D_AC | | 0568 | CF 03<br>18 18 00 18 18 18 | 364<br>365 | DB | 018H,018H,000H,018H,018H,018H,018H,000H ; D_AD | | 0570 | 18 00<br>00 33 66 CC 66 33 | 366<br>367 | DB | 000H,033H,066H,0CCH,066H,033H,000H,000H; D_AE | | 0578 | 00 00<br>00 CC 66 33 66 CC | 368<br>360 | DB | 000H,0CCH,066H,033H,066H,0CCH,000H,000H; D_AF | | 0,10 | 00 00 | 370<br>371 | | | | 0580 | 22 88 22 88 22 88<br>22 88 | 372 | DB | 022H,088H,022H,088H,022H,088H,022H,088H ; D_B0 | | 0588 | 22 88<br>55 AA 55 AA 55 AA | 373<br>374 | DB | 055H, 0AAH, 055H, 0AAH, 055H, 0AAH, 055H, 0AAH ; D_B1 | | 0590 | 55 AA<br>DB 77 DB EE DB 77 | 375<br>376 | DB | ODBH,077H,ODBH,OEEH,ODBH,077H,ODBH,OEEH ; D_B2 | | 0598 | DB EE<br>18 18 18 18 18 18 | 377<br>378 | DB | 018H,018H,018H,018H,018H,018H,018H,018H; D_B3 | | 05A0 | 18 18<br>18 18 18 18 F8 18 | 379<br>380 | DB | 018H,018H,018H,018H,018H,018H,018H; D_B4 | | 05A8 | 18 18<br>18 18 F8 18 F8 18 | 381 | DB | 018H,018H,0F8H,018H,0F8H,018H,018H,018H; D_B5 | | 0580 | 18 18 | 383<br>384 | DB | | | | 36 36 | 385 | | | | 0588 | 00 00 00 00 FE 36<br>36 36 | 386<br>387 | DB | 000Н,000Н,000Н,000Н,0FEH,036Н,036Н,036Н; D_B7 | | 05C0 | 00 00 F8 18 F8 18<br>18 18 | 388<br>389 | DB | 000H,000H,0F8H,018H,0F8H,018H,018H,018H; D_В8 | | 05C8 | 36 36 F6 06 F6 36 | 390<br>301 | DB | 036H,036H,0F6H,006H,0F6H,036H,036H,036H; D_B9 | | 05D0 | 36 36 36 36 36 36<br>36 36 | 392 | DB | 036H,036H,036H,036H,036H,036H,036H; D_BA | | 05D8 | 00 00 FE 06 F6 36 | 394 | DB | 000H,000H,0FEH,006H,0F6H,036H,036H,036H; D_BB | | 05E0 | 36 36<br>36 36 F6 06 FE 00 | 395<br>396 | DB | 036H,036H,0F6H,006H,0FEH,000H,000H,000H; D_BC | | 05E8 | 00 00<br>36 36 36 36 FE 00 | 397<br>398 | DB | 036H.036H.036H.036H.0FEH.000H.000H.000H ; D BD | | 05F0 | 00 00<br>18 18 F8 18 F8 00 | 399<br>400 | DB | 018H,018H,0F8H,018H,0F8H,000H,000H,000H; D_BE | | 05F8 | 00 00<br>00 00 00 00 F8 18 | 401 | DB | 000H,000H,000H,000H,0F8H,018H,018H,018H; D_BF | | 0110 | 18 18 | 403 | 50 | 555.,555.,556.,506.,506.,516.,516.,516,516,516,516,516 | | 0600 | 18 18 18 18 1F 00 | 405 | DB | 018H,018H,018H,018H,01FH,000H,000H,000H; D_C0 | | 0608 | 00 00<br>18 18 18 18 FF 00 | 406<br>407 | DB | 018H,018H,018H,018H,0FFH,000H,000H,000H; D_C1 | | 0610 | 00 00<br>00 00 00 00 FF 18 | 408<br>409 | DB | 000H,000H,000H,000H,0FFH,018H,018H,018H; D_C2 | | 0618 | 18 18<br>18 18 18 18 1F 18 | 410<br>411 | DB | 018H,018H,018H,018H,01FH,018H,018H,018H; D_C3 | | 0620 | 18 18<br>00 00 00 00 FF 00 | 412 | DB | 000H,000H,000H,000H,0FFH,000H,000H; D_C4 | | | 00 00 | 414 | DB<br>DB | | | 0628 | 18 18 | 415<br>416 | | | | 0630 | 18 18 1F 18 1F 18<br>18 18 | 417<br>418 | DB | 018H,018H,01FH,018H,01FH,018H,018H,018H; D_C6 | | 0638 | 36 36 36 36 37 36<br>36 36 | 419<br>420 | DB | 036H,036H,036H,036H,036H,036H,036H; D_C7 | | 0640 | 36 36 37 30 3F 00<br>00 00 | 421<br>422 | DB | 036H,036H,037H,030H,03FH,000H,000H,000H ; D_C8 | | 0648 | 00 00 3F 30 37 36 | 423 | DB | 000H,000H,03FH,030H,037H,036H,036H,036H; D_C9 | | 0650 | 36 36 F7 00 FF 00 | 424<br>425 | DB | 036H,036H,0F7H,000H,0FFH,000H,000H,000H; D_CA | | 0658 | 00 00<br>00 00 FF 00 F7 36 | 426<br>427 | DB | 000H,000H,0FFH,000H,0F7H,036H,036H,036H; D_CВ | | 0660 | 36 36<br>36 36 37 30 37 36 | 428<br>429 | DB | 036H,036H,037H,030H,037H,036H,036H,036H; D_CC | | 0668 | 36 36<br>00 00 FF 00 FF 00 | 430<br>431 | DB | 000H,000H,0FFH,000H,0FFH,000H,000H; D_CD | | 0670 | 00 00 | 432<br>433 | DB | 036H,036H,0F7H,000H,0F7H,036H,036H,036H; D_CE | | | 36 36 F7 00 F7 36<br>36 36 | 434 | 00 | 555.,5550i,617i,666i,617i,656i,636i,636ii ; 0_6E | | | | | | | ``` 18 18 FF 00 FF 00 0678 DB 018H,018H,0FFH,000H,0FFH,000H,000H,000H; 36 36 36 FF 00 0680 DB 036H, 036H, 036H, 036H, 0FFH, 000H, 000H, 000H; FF 0688 00 FF 18 DB 000H,000H,0FFH,000H,0FFH,018H,018H,018H; 0690 00 00 FF 36 DB 000H,000H,000H,000H,0FFH,036H,036H,036H; 0698 36 36 3F 00 DB 036H,036H,036H,036H,03FH,000H,000H,000H; 06A0 1F 18 DB 018H,018H,01FH,018H,01FH,000H,000H,000H; 1F 18 0648 DB 000H,000H,01FH,018H,01FH,018H,018H,018H; 06B0 00 00 3F 36 DΒ 000H,000H,000H,000H,03FH,036H,036H,036H; 06B8 36 36 FF DB 036H,036H,036H,036H,05FH,036H,036H,036H; 06C0 FF 18 FF DB 018H,018H,0FFH,018H,0FFH,018H,018H,018H; 0608 18 18 F8 00 DB 018H,018H,018H,018H,0F8H,000H,000H,000H; 06D0 00 00 DB 000H,000H,000H,000H,01FH,018H,018H,018H; FF FF 0608 DB OFFH,OFFH,OFFH,OFFH,OFFH,OFFH,OFFH; 00 00 00 FF FF 06F0 DB FF FO FO FO FO FO FO OF OF OF OF OF OF FF FF FF OO OO 06E8 DB оғон, оғон, оғон, оғон, оғон, оғон, оғон, оғон; 06F0 DB OOFH, OOFH, OOFH, OOFH, OOFH, OOFH, OOFH; 06F8 DB OFFH, OFFH, OFFH, OFFH, OOOH, OOOH, OOOH; 0700 76 DC C8 DC DB 000H,000H,076H,0DCH,0C8H,0DCH,076H,000H ; D_E0 CC F8 CC F8 0708 DB 000H,078H,0CCH,0F8H,0CCH,0F8H,0COH,0COH; cc co co co 0710 DB 000H, 0FCH, 0CCH, 0COH, 0COH, 0COH, 0COH, 00OH; 0718 6C 6C 6C 6C DB 000H, 0FEH, 06CH, 06CH, 06CH, 06CH, 06CH, 00OH ; 60 30 60 CC DB OFCH, OCCH, 060H, 030H, 060H, OCCH, OFCH, 000H; 7E D8 D8 D8 DB OOOH, OOOH, O7EH, OD8H, OD8H, O7OH, OOOH ; 66 66 66 70 DB 000H,066H,066H,066H,07CH,060H,0C0H; DC 18 18 18 DB 000H,076H,0DCH,018H,018H,018H,018H,000H; 78 CC CC 78 0740 DB OFCH, 030H, 078H, 0CCH, 0CCH, 078H, 030H, 0FCH; C6 FE C6 60 DB 038H,06CH,0C6H,0FEH,0C6H,06CH,038H,000H ; 0750 C6 C6 6C 6C DB 038H, 06CH, 0C6H, 0C6H, 06CH, 06CH, 0EEH, 000H ; 18 7C CC CC DB 01CH, 030H, 018H, 07CH, 0CCH, 0CCH, 078H, 000H; 00 7E DB DB 7E 00 7E DB DB 7E 00 7E DB DB 7E 00 60 CO F8 CO 60 00 CC CC CC CC CC 7E DB DB 7E DB OOOH, OOOH, O7EH, ODBH, ODBH, O7EH, OOOH, OOOH ; DB 006H, 00CH, 07EH, 0DBH, 0DBH, 07EH, 060H, 0COH; DB 038H,060H,0C0H,0F8H,0C0H,060H,038H,000H; DB 078H, OCCH, OCCH, OCCH, OCCH, OCCH, OCCH, OOOH ; FC 00 FC 00 FC 00 30 FC 30 30 00 00 0780 DB 000Н,0ГСН,000Н,0ГСН,000Н,0ГСН,000Н,000Н ; DB 030H, 030H, 0FCH, 030H, 030H, 000H, 0FCH, 000H; 18 30 60 00 DB 060H,030H,018H,030H,060H,000H,0FCH,000H; 0798 60 30 18 00 DB 018H,030H,060H,030H,018H,000H,0FCH,000H; 07A0 1B 18 18 18 DB OOEH,01BH,01BH,018H,018H,018H,018H; 07A8 18 18 18 D8 DB 018H,018H,018H,018H,018H,0D8H,070H ; 70 30 00 FC 00 30 00 76 DC 00 76 DC 00 6C 6C 38 00 00 00 00 18 18 00 07B0 DB 030H,030H,000H,0FCH,000H,030H,030H,000H; 07B8 DB 000H,076H,0DCH,000H,076H,0DCH,000H,000H; 07C0 DB 038H,06CH,06CH,038H,000H,000H,000H,000H; 07C8 DB 000Н,000Н,000Н,018Н,018Н,000Н,000Н,000Н ; 07D0 00 00 18 00 DB 000Н,000Н,000Н,000Н,018Н,000Н,000Н,000Н ; 07D8 OC OC EC 6C DB OOFH, OOCH, OOCH, OECH, O6CH, O3CH, O1CH ; 1C 6C 6C 6C 6C 00 07E0 DB 078H,06CH,06CH,06CH,000H,000H,000H; 18 30 60 78 00 00 00 3C 3C 3C 3C 00 00 00 00 00 00 00 00 00 00 00 07E8 DB 070H,018H,030H,060H,078H,000H,000H,000H; 07F0 DB 000H,000H,03CH,03CH,03CH,03CH,000H,000H; 07F8 DВ ; нооо, нооо, нооо, нооо, нооо, нооо, нооо 0800 CODE PAGE,120 SUBTTL END ADDRESS E SEGMENT PUBLIC LIC END_ADDRESS _ADDRESS LABEL BYT 0000 0000 ``` ## Index | $\mathbf{A}$ | compatibility issues 74 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------| | | configuration switches 80 | | A | CRT Controller description 3 | | Attribute Address Register 56 Attribute Controller | registers 24 | | description 3 | CRT Controller Address | | registers 56 | Register 24 | | - | CRT Controller Overflow Register 30 | | | Cursor End Register 33 | | В | Cursor Location High Register 35 | | | Cursor Location Low | | BIOS | Register 35 | | description 4 | Cursor Start Register 32 | | vectors with special | | | meanings 103 | | | BIOS listing 103 | D | | | | | Bit Mask Register 54 | D | | Dit Wask Register 34 | D | | Dit Wask Register 34 | Data Rotate Register 49 | | C | Data Rotate Register 49 direct drive connector 83 | | C | Data Rotate Register 49 | | C | Data Rotate Register 49 direct drive connector 83 | | C character generator ROM 1 | Data Rotate Register 49<br>direct drive connector 83<br>display buffer 4 | | C character generator ROM 1 Character Map Select | Data Rotate Register 49 direct drive connector 83 | | C character generator ROM 1 Character Map Select Register 21 Clocking Mode Register 19 | Data Rotate Register 49 direct drive connector 83 display buffer 4 | | C character generator ROM 1 Character Map Select Register 21 Clocking Mode Register 19 Color Compare Register 48 | Data Rotate Register 49 direct drive connector 83 display buffer 4 Enable Set/Reset Register 47 | | C character generator ROM 1 Character Map Select Register 21 Clocking Mode Register 19 Color Compare Register 48 Color Don't Care Register 53 | Data Rotate Register 49 direct drive connector 83 display buffer 4 Enable Set/Reset Register 47 End Horizontal Blanking | | C character generator ROM 1 Character Map Select Register 21 Clocking Mode Register 19 Color Compare Register 48 Color Don't Care Register 53 color mapping 10 | Data Rotate Register 49 direct drive connector 83 display buffer 4 Enable Set/Reset Register 47 | | C character generator ROM 1 Character Map Select Register 21 Clocking Mode Register 19 Color Compare Register 48 Color Don't Care Register 53 | Data Rotate Register 49 direct drive connector 83 display buffer 4 Enable Set/Reset Register 47 End Horizontal Blanking Register 27 | I End Vertical Blanking Register 40 Input Status Register One 15 Input Status Register Zero 14 Interface 76 F feature connector 76 feature connector 76 Feature Control Register 14 L G Light Pen High Register 36 light pen interface 84 Light Pen Low Register 37 Line Compare Register 43 **Graphics Controller** description 3 registers 45 Graphics 1 and 2 Address M Register 46 **Graphics 1 Position** Register 45 **Graphics 2 Position** Map Mask Register 20 Register 46 Maximum Scan Line Register 32 Memory Mode Register 23 Miscellaneous Output H Register 12 Miscellaneous Register 52 Mode Control Register 41, 58 Mode Register 50 Horizontal Display Enable End modes Register 26 alphanumeric 8 Horizontal Pel Panning graphics 8 Register 60 IBM Color Display 5 Horizontal Total Register 25 **IBM Enhanced Color** Display 6 IBM Monochrome Display 6 Graphics Controller 45 Sequencer 18 Reset Register 18 Offset Register 38 Overscan Color Register 59 S P Sequencer description 3 registers 18 Palette Registers 57 Sequencer Address Register 18 Preset Row Scan Register 31 Set/Reset Register 47 programming specifications 79 considerations 62 configuration switch compatibility issues 74 settings 81 creating a split screen 73 configuration switches 80 creating a 512 character direct drive connector 83 set 70 light pen interface 84 creating an 80 by 43 system board switches 79 alphanumeric mode 71 Start Address High Register 34 programming registers 62 Start Address Low Register 34 RAM loadable character Start Horizontal Blanking generator 69 Register 26 vertical interrupt feature 72 Start Horizontal Retrace Pulse Register 28 Start Vertical Blanking Register 39 R support logic 4 RAM loadable character generator 69 U Read Map Select Register 50 registers Attribute Controller 56 CRT Controller 24 external 12 ## Index-3 Underline Location Register 39 Vertical Display Enable End Register 38 vertical interrupt feature 72 Vertical Retrace End Register 36 Vertical Retrace Start Register 36 Vertical Total Register 30 ## **IBM Printer Adapter** # **Contents** | Description | 1 | |----------------------------|---| | Programming Considerations | 3 | | Specifications | 7 | | Logic Diagrams | ç | # **Description** The IBM Printer Adapter is specifically designed to attach printers with a parallel port-interface, but it can be used as a general input/output port for any device or application that matches its input/output capabilities. It has 12 TTL-buffer output points, which are latched and can be written and read under program control using the microprocessor In or Out instruction. The adapter also has five steady-state input points that may be read using the microprocessor's In instructions. In addition, one input can also be used to create a microprocessor interrupt. This interrupt can be enabled and disabled under program control. A reset from the power-on circuit is also ORed with a program output point, allowing a device to receive a 'power-on reset' when the system unit's microprocessor is reset. The input/output signals are made available at the back of the adapter through a right-angle, printed-circuit-board-mounted, 25-pin, D-shell connector. This connector protrudes through the rear panel of the system unit or expansion unit, where a cable may be attached. When this adapter is used to attach a printer, data or printer commands are loaded into an 8-bit, latched, output port, and the strobe line is activated, writing data to the printer. The program then may read the input ports for printer status indicating when the next character can be written, or it may use the interrupt line to indicate "not busy" to the software. The output ports may also be read at the card's interface for diagnostic loop functions. This allows faults to be isolated to the adapter or the attaching device. This same function is also part of the IBM Monochrome Display and Printer Adapter. The following is a block diagram of the Printer Adapter. **Printer Adapter Block Diagram** # **Programming Considerations** The Printer Adapter responds to five I/O instructions; two output and three input. The output instructions transfer data into two latches whose outputs are presented on pins of a 25-pin D-shell connector. Two of the three input instructions allow the system unit's microprocessor to read back the contents of the two latches. The third allows the system unit's microprocessor to read the real-time status from a group of pins on the connector. A description of each instruction follows. | Printer Adapter | | | | | | | | | |-------------------------|---------------------------|--|--|--|--|--|--|--| | Οι | Output to address hex 378 | | | | | | | | | Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | Pin 5 | Pin 4 Pin 3 Pin 2 | | | | | | | | The instruction captures data from the data bus and is present on the respective pins. Each of these pins is capable of sourcing 2.6 mA and sinking 24 mA. It is essential that the external device does not try to pull these lines to ground. | | Printer Adapter | | | | | | | | | |---|---------------------------|--------|--------|-------|--|--|--|--|--| | | Output to address hex 37A | | | | | | | | | | Ī | Bit 3 | Bit 2 | Bit 1 | Bit O | | | | | | | 1 | Pin 17 | Pin 16 | Pin 14 | Pin 1 | | | | | | | | | | | | | | | | | This instruction causes the latch to capture the five least significant bits of the data bus. The four least significant bits present their outputs, or inverted versions of their outputs, to the respective pins as shown in the previous figure. If bit 4 is written as a 1, the card will interrupt the system unit's microprocessor on the condition that pin 10 changes from high to low. These pins are driven by open-collector drivers pulled to +5 Vdc through $4.7 \text{ k}\Omega$ resistors. They can each sink approximately 7 mA and maintain 0.8 volts down-level. Printer Adapter Input from address hex 378 This instruction presents the system unit's microprocessor with data present on the pins associated with the output to hex 3BC. This should normally reflect the exact value that was last written to hex 3BC. If an external device should be driving data on these pins at the time of an input (in violation of usage ground rules), this data will be ORed with the latch contents. Printer Adapter Input from address hex 379 This instruction presents the real-time status to the system unit's microprocessor from the pins, as follows. | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | |--------|--------|--------|--------|--------|-------|-------|-------| | Pin 11 | Pin 10 | Pin 12 | Pin 13 | Pin 15 | _ | _ | _ | Printer Adapter Input from address hex 37A #### 4 Printer Adapter This instruction causes the data present on pins 1, 14, 16, 17, and the IRQ bit to be read by the system unit's microprocessor. In the absence of external drive applied to these pins, data read by the system unit's microprocessor will match data last written to hex 3BE in the same bit positions. Notice that data bits 0-2 are not included. If external drivers are dotted to these pins, that data will be ORed with data applied to the pins by the hex 3BE latch. | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------|-------|-------|---------------|---------|---------|---------|---------| | )<br> | | | IRQ<br>Enable | Pin 17 | Pin 16 | Pin 14 | Pin 1 | | | | | Por = 0 | Por = 1 | Por = 0 | Por = 1 | Por = 1 | These pins assume the states shown after a reset from the system unit's microprocessor. # **Specifications** | | At Standard 112 Levels | | | | | |---------|----------------------------------------|------------|---------|--|--| | | Signal | Adapter | | | | | | Name | Pin Number | | | | | | - Strobe | 1 | | | | | | + Data Bit 0 | 2 | ] | | | | [ | + Data Bit 1 | 3 | | | | | | + Data Bit 2 | 4 | | | | | { | + Data Bit 3 | 5 | | | | | | + Data Bit 4 | 6 | | | | | | + Data Bit 5 | 7 | | | | | | + Data Bit 6 | 8 | | | | | Printer | + Data Bit 7 | 9 Pr | | | | | | <ul> <li>Acknowledge</li> </ul> | 10 | Adapter | | | | | + Busy | 11 | | | | | | + P.End (out of paper) | 12 | | | | | | + Select | 13 | | | | | | - Auto Feed | 14 | | | | | | – Error | 15 | | | | | | <ul> <li>Initialize Printer</li> </ul> | 16 | | | | | | - Select Input | 17 | | | | | | Ground | 18-25 | | | | | | | | L | | | At Standard TTL Levels **Connector Specifications** # **Logic Diagrams** The following page contains the logic diagram for the IBM Printer Adapter. Printer Adapter (Sheet 1 of 1) # IBM 5-1/4" Diskette Drive Adapter # **Contents** | Description | |------------------------------| | Programming Considerations | | Digital-Output Register 3 | | Floppy Disk Controller 4 | | Command Summary 8 | | Programming Summary 17 | | Interface | | System I/O Channel Interface | | Drive A and B Interface 20 | | Specifications | | Logic Diagrams | ## **Description** The IBM 5-1/4" Diskette Drive Adapter fits into one of the expansion slots in the system unit. It is connected to one or two diskette drives through an internal, daisy-chained flat cable. The adapter has a connector at the other end that extends through the rear panel of the system unit. This connector has signals for two additional external diskette drives; thus, the 5-1/4 inch diskette drive adapter can attach four 5-1/4 inch drives — two internal and two external. The adapter is designed for double-density, MFM-coded, diskette drives and uses write precompensation with an analog phase-lock loop for clock and data recovery. The adapter is a general-purpose device using the NEC µPD765 or equivalent controller. Therefore, the diskette drive parameters are programmable. In addition, the attachment supports the diskette drive's write-protect feature. The adapter is buffered on the I/O bus and uses the system board's direct memory access (DMA) for record data transfers. An interrupt level also is used to indicate when an operation is complete and that a status condition requires microprocessor attention. In general, the 5-1/4 inch diskette drive adapter presents a high-level command interface to software I/O drivers. 5-1/4 Inch Diskette Drive Adapter Block Diagram ## **Programming Considerations** This attachment consists of an 8-bit digital output register in parallel with a NEC $\mu$ PD765 or equivalent floppy disk controller (FDC). In the following description, drive numbers 0, 1, 2, and 3 are equivalent to drives A, B, C, and D. ## **Digital-Output Register** The Digital-Output register (DOR) is an output-only register used to control drive motors, drive selection, and feature enable. All bits are cleared by the I/O interface 'reset' line. The bits have the following functions: Bits 0 and 1 These bits are decoded by the hardware to select one drive if its motor is on: | Bit 1 0 | Drive | |---------|-------| | 0 0 | 0(A) | | 0 1 | 1 (B) | | 10 | 2 (C) | | 1 1 | 3 (D) | Bit 2 The FDC is held reset when this bit is clear. It must be set by the program to enable the FDC. Bit 3 This bit allows the FDC interrupt and DMA requests to be gated onto the I/O interface. If this bit is cleared, the interrupt and DMA request I/O interface drivers are disabled. Bits 4, 5, 6, These bits control, respectively, the motors of drives 0, 1, 2 (A, B, C), and 3 (D). If a bit is drives 0, 1, 2 (A, B, C), and 3 (D). If a bit is clear, the associated motor is off, and the drive cannot be selected. ## Floppy Disk Controller The floppy disk controller (FDC) contains two registers that may be accessed by the system unit's microprocessor: a status register and a data register. The 8-bit main status register contains the status information of the FDC and may be accessed at any time. The 8-bit data register (actually consisting of several registers in a stack with only one register presented to the data bus at a time) stores data, commands, parameters, and provides floppy disk drive (FDD) status information. Data bytes are read from or written to the data register in order to program or obtain results after a particular command. The main status register can only be read and is used to facilitate the transfer of data between the system unit's microprocessor and FDC. The bits in the main status register (hex 34F) are defined as follows: | Bit<br>Number | Name | Symbol | Description | |---------------|-----------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DB0 | FDD A Busy | DAB | FDD number 0 is in the Seek mode. | | DB1 | FDD B Busy | DBB | FDD number 1 is in the Seek mode. | | DB2 | FDD C Busy | DCB | FDD number 2 is in the Seek mode. | | DB3 | FDD D Busy | DDB | FDD number 3 is in the Seek mode. | | DB4 | FDC Busy | СВ | A read or write command is in process. | | DB5 | Non-DMA<br>Mode | NDM | The FDC is in the non-DMA mode. | | DB6 | Data Input/<br>Output | DIO | Indicates direction of data transfer between FDC and processor. If DIO = ''1,'' then transfer is from FDC data register to the processor. If DIO = ''0,'' then transfer is from the processor to FDC data register. | | DB7 | Request for<br>Master | RQM | Indicates data register is ready to send or receive data to or from the processor. Both bits DIO and RQM should be used to perform the handshaking functions of ''ready'' and ''direction'' to the processor. | The FDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer from the system unit's microprocessor, and the result after execution of the command may also be a multi-byte transfer back to the system #### 4 Diskette Adapter unit's microprocessor. Because of this multi-byte interchange of information between the FDC and the system unit's microprocessor, it is convenient to consider each command as consisting of three phases: #### **Command Phase** The FDC receives all information required to perform a particular operation from the system unit's microprocessor. #### **Execution Phase** The FDC performs the operation it was instructed to do. #### **Result Phase** After completion of the operation, status and other housekeeping information are made available to the system unit's microprocessor. The following tables define the symbols used in the command summary. The command summary immediately follows these tables. | Symbol | Name | Description | |--------|------------------|-------------------------------------------------------------------------------------------------------------------------| | A0 | Address Line 0 | A0 controls selection of main status register (A0 = 0) or data register (A0 = 1). | | С | Cylinder Number | C stands for the current/selected cylinder (track) number of the medium. | | D | Data | D stands for the data pattern that is going to be written into a sector. | | D7-D0 | Data Bus | 8-bit data bus, where D7 stands for a most significant bit, and D0 stands for a least significant bit. | | DTL | Data Length | When N is defined as 00, DTL stands for the data length that users are going to read from or write to the sector. | | EOT | End of Track | EOT stands for the final sector number on a cylinder. | | GPL | Gap Length | GPL stands for the length of gap 3 (spacing between sectors excluding VC0 sync field). | | Н | Head Address | H stands for head number 0 or 1, as specified in ID field. | | HD | Head | HD stands for a selected head number 0 or 1. (H = HD in all command words). | | HLT | Head Load Time | HLT stands for the head load time in the FDD (4 to 512 ms in 4-ms increments). | | HUT | Head Unload Time | HUT stands for the head unload time after a read or write operation has occurred (0 to 480 ms in 32-ms increments). | | MF | FM or MFM Mode | If MF is low, FM mode is selected; if it is high, MFM mode is selected only if MFM is implemented. | | MT | Multi-Track | If MT is high, a multi-track operation is to be performed. (A cylinder under both HDO and HD1 will be read or written.) | | N | Number | N stands for the number of data bytes written in a sector. | #### Symbol Descriptions (Part 1 of 2) | Symbol | Name | Description | |------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NCN | New Cylinder<br>Number | NCN stands for a new cylinder number, which is going to be reached as a result of the seek operation. (Desired position of the head.) | | ND | Non-DMA Mode | ND stands for operation in the non-DMA mode. | | PCN | Present Cylinder<br>Number | PCN stands for cylinder number at the completion of sense-interrupt-status command indicating the position of the head at present time. | | R | Record | R stands for the sector number, which will be read or written. | | R/W | Read/Write | R/W stands for either read (R) or write (W) signal. | | SC | Sector | SC indicates the number of sectors per cylinder. | | SK | Skip | SK stands for skip deleted-data address mark. | | SRT | Step Rate Time | SRT stands for the stepping rate for the FDD (2 to 32 ms in 2-ms increments). | | ST 0<br>ST 1<br>ST 2<br>ST 3 | Status 0<br>Status 1<br>Status 2<br>Status 3 | STO-3 stand for one of four registers that store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the main status register (selected by A0 = 0). ST 0-3 may be read only after a command has been executed and contain information relevant to that particular command. | | STP | Scan Test | During a scan operation, if STP = 1, the data in contiguous sectors is compared byte-by-byte with data sent from the processor (or DMA), and if STP = 2, then alternate sectors are read and compared. | | USO,<br>US1 | Unit Select | US stands for a selected drive number encoded the same as bits 0 and 1 of the digital output register (DOR). | #### Symbol Descriptions (Part 2 of 2) ## **Command Summary** In the following table, 0 indicates "logical 0" for that bit, 1 means "logical 1," and X means "don't care." | | | | | | | Bus | | | | | |-----------|-----|----------|----|------|--------|----------|------|-----|-----|-----------------------| | Phase | R/W | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | Remarks | | | | | | | | Data | | | | | | Command | W | | MF | SK | 0 | 0 | 1 | 1 | 0 | Command Codes | | ĺ | W | X | X | X | Х | _ X | HD | US1 | USO | | | | W | | | | | 2 | | | | Sector ID information | | | W | | | | | Η | | | | prior to command | | | W | | | | • | ₹ | | | | execution. | | | W | | | | | V | | | | | | | w | 1 | | | - | OT<br>PL | | | İ | | | | W | | | | | PL<br>TL | | | | | | Execution | ** | l | | | D | IL | | | | Data transfer | | Execution | | | | | | | | | | between the FDD | | | ) | | | | | | | | | and main system. | | Result | R | | | | 51 | ГО | | | | Status information | | ricsurt | l R | | | | | Г1 | | | | after command | | | R | | | | | Г2 | | | 1 | execution. | | | R | | | | _ | 2 | | | į | Sector ID information | | | R | | | | | 4 | | | | after command | | 1 | R | | | | F | 3 | | | | execution. | | | R | | | | ١ | V | | | | | | | | | | Read | d Dele | eted | Data | 1 | | | | Command | w | МТ | MF | SK | 0 | 1 | 1 | 0 | 0 | Command Codes | | | w | Х | Х | Х | Х | Χ | HD | US1 | uso | | | | w | | | | ( | 2 | | | | Sector ID information | | | w | | | | H | + | | | | prior to command | | | W | | | | F | 7 | | | | execution. | | | W | | | | 1 | V | | | | | | | W | | | | | TC | | | | | | | W | } | | | | PL | | | | | | | W | | | | D. | TL | | | | | | Execution | | | | | | | | | | Data transfer | | | | | | | | | | | Į | between the FDD | | | | | | | _ | | | | | and main system. | | Result | R | 1 | | | _ | 0 | | | | Status information | | | R | | | | ST | | | | | after command | | | R | | | | _ | 2 | | | | execution. | | | R | | | | | 2 | | | | Sector ID information | | | R | | | | - | Η | | | | after command | | | R | | | | | 3 | | | | execution. | | | R | <u> </u> | | | Γ | ٧ | | | | | | <u> </u> | | | | | | | | | | | |-----------|-----|----|----|------|------------|------|------|-----|-----|-----------------------| | Phase | R/W | D7 | D6 | D5 | Data<br>D4 | | | D1 | DO | Remarks | | | | | | · | Write | Data | a | | | | | Command | w | МТ | MF | 0 | 0 | 0 | 1 | 0 | 1 | Command Codes | | | w | Х | Х | Х | Х | Х | HD | US1 | uso | | | | w | | | | ( | 3 | | | | Sector ID information | | | w | | | | H | 4 | | | | prior to command | | | w | | | | F | ₹ | | | - 1 | execution. | | | w | | | | ١ | V | | | | | | | w | | | | EC | TC | | | 1 | | | | w | | | | GI | PL | | | Ì | | | | W | | | | D. | ΤL | | | Ì | | | Execution | | 1 | | | | | | | | Data transfer | | | | | | | | | | | | between the main | | | | | | | | | | | | system and FDD. | | Result | R | | | | | 0 | | | | Status information | | | R | | | | ST | 1 | | | | after command | | | R | l | | | | 2 | | | | execution. | | | R | | С | | | | | | | Sector ID information | | | R | 1 | | | | 4 | | | { | after command | | | R | | | | | ₹ | | | - | execution. | | | R | | | | | ١ | | | | | | | | | | Writ | e Del | eted | Data | 3 | | | | Command | w | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 | Command Codes | | | w | X | Χ | Χ | Χ | Χ | HD | US1 | USO | | | | W | | | | ( | 2 | | | | Sector ID information | | | W | | | | H | 4 | | | | prior to command | | | W | | | | F | ₹ | | | | execution. | | | W | | | | ١ | N | | | | | | | W | | | | | TC | | | | | | | W | l | | | | PL | | | | | | | W | ļ | | | D. | TL | | | | | | Execution | | | | | | | | | | Data transfer | | | | | | | | | | | Ì | between the FDD and | | | | | | | | | | | | main system. | | Result | R | | | | | 0 | | | | Status ID information | | | R | | | | ST | | | | | after command | | | R | 1 | | | | 2 | | | ł | execution. | | | R | | С | | | | | | | Sector ID information | | | R | į | | | | 1 | | | l | after command | | | R | ĺ | | | | ₹ | | | | execution. | | | R | | | | | ٧ | | | | | | · · · · · · · · · · · · · · · · · · · | T T | Γ | | | <u> </u> | | | | | | |---------------------------------------|---------------------------------------|--------|------------------------------------------|--------|---------------------------|------------------------------|---------|----------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------| | Phase | R/W | D7 | D6 | D5 | Data<br>D4 | | | D1 | DO | Remarks | | | Read a Track | | | | | | | | | | | Command | w | 0<br>X | MF<br>X | | 0<br>X | 0 | 0 | 1 | 0<br>US0 | Command Codes | | | W W W W W W W W W W | X | X | X | (<br>F | C<br>H<br>R<br>N<br>DT<br>PL | ни | UST | USO | Sector ID information prior to command execution. | | Execution | • | | | | D | | | | | Data transfer between the FDD and main system. FDC reads all of cylinder's contents from index hole to EOT. | | Result | R<br>R<br>R<br>R<br>R<br>R | | | | ST<br>ST<br>ST<br>()<br>H | 1<br>2<br>2<br>1 | | | | Status information after command execution. Sector ID information after command execution. | | | | | | | Rea | d ID | | | | | | Command<br>Execution | W | O<br>X | MF<br>X | 0<br>X | 0<br>X | 1<br>X | O<br>HD | 1<br>US1 | o<br>USO | The first correct ID information on the cylinder is stored in | | Result | R<br>R<br>R<br>R<br>R<br>R | | ST 0<br>ST 1<br>ST 2<br>C<br>H<br>R<br>N | | | | | | data register. Status information after command execution. Sector ID information during execution phase. | | | | Ī | | T | | | | | | | | | |-----------|----------------|----|-----------|----|------|--------------|----|-----|--------------------|-----------------------|--| | Phase | R/W | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Remarks | | | | Format a Track | | | | | | | | | | | | Command | W | 0 | MF | 0 | 0 | 1 | 1 | 0 | 0 | Command Codes | | | | W | X | Х | Χ | Χ | Χ | HD | US1 | USO | | | | | W | | | | | N | | | | Bytes/Sector | | | | W | ĺ | | | _ | С | | | ı | Sector/Track | | | | W | | | | _ | PL | | | | Gap 3 | | | | W | | | | ( | ) | | | 1 | filler byte. | | | Execution | Ì | | | | | | | | | FDC formats an | | | | _ | | | | | | | | - 1 | entire cylinder. | | | Result | R | | | | | 0 | | | 1 | Status information | | | | R | | | | | Γ1 | | | | after command | | | | R | | | | | 2 | | | - 1 | execution. | | | | R | | | | | 2 | | | 1 | In this case, the ID | | | | R | | | | | 4 | | | | information has no | | | | R | | R<br>N | | | | | | - 1 | meaning. | | | | R | | | | | | | | | | | | | | l | | | Scan | | | _ | | | | | Command | W | | MF | | 1 | 0 | 0 | 0 | 1 | Command Codes | | | | W | X | Х | Х | Х | X | HD | US1 | USO | | | | | W | | | | | 2 | | | - 1 | Sector ID information | | | | W | 1 | | | | <del> </del> | | | - 1 | prior to command | | | | W | 1 | | | | ₹ | | | | execution. | | | | W | | | | | V | | | į | | | | | W | | | | | )T | | | | | | | | W | | | | | PL<br>TP | | | | | | | Execution | ) VV | | | | 3 | 17 | | | | Data compared | | | Execution | ! | | | | | | | | | between the FDD | | | | | 1 | | | | | | | | and the main system. | | | Result | R | | ST 0 | | | | | | Status information | | | | Hesuit | R | | ST 1 | | | | | | | after Command | | | | R | | ST 2 | | | | | | | execution. | | | | R | | S1 2<br>C | | | | | | | Sector ID information | | | | R | 1 | | | | <del>-</del> | | | | after command | | | | R | | | | • | 3 | | | | execution. | | | | R | | | | | N | | | | | | | · | | | | | Data | Bus | | | | | |-----------|----------|----------|----|------|--------|---------------|-------|-----|-----|----------------------------------| | Phase | R/W | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Remarks | | | | | | Scar | Lov | or E | qual | | | | | Command | W | | MF | SK | 1 | 1 | 0 | 0 | 1 | Command Codes | | | W | X | Х | X | Х | Х | HD | US1 | USO | | | | W | | | | ( | - | | | | Sector ID information | | | W | | | | ,<br>, | | | | | prior to command | | | W | | | | 1 | ₹ | | | | execution. | | | w | | | | | N<br>DT | | | | | | | w | | | | GI | | | | | j | | | w | | | | | ΓP | | | | | | Execution | ** | | | | 3 | | | | | Data compared | | Execution | | | | | | | | | | between the FDD | | | | | | | | | | | | and main system. | | Result | R | | | | ST | 0 | | | | Status information | | | R | | | | ST | - 1 | | | | after command | | | R | | | | ST | 2 | | | | execution. | | | R | 1 | | | ( | 2 | | | 1 | Sector ID information | | | R | | | | ŀ | <del>-i</del> | | | | after command | | | R | | | | F | ₹ | | | | execution. | | | R | | | | 1 | ٧ | | | | | | | | | | | ı Higl | h or E | Equal | | | | | Command | W | MT | MF | SK | 1 | 1 | 1 | 0 | 1 | Command Codes | | | w | X | Х | Х | Х | Х | HD | US1 | USO | | | | w | | | | | 2 | | | | Sector ID information | | | W | 1 | | | - | 4 | | | | prior to command | | | W | | | | | 3 | | | 1 | execution. | | | W | | | | | N. | | | | | | | W | | | | | TC | | | | | | | W | | | | GI | | | | l | | | F | l vv | | | | S | ΓP | | | | Data | | Execution | | | | | | | | | | Data compared<br>between the FDD | | | | | | | | | | | | and main system. | | Result | R | | | | 27 | 0 | | | | Status information | | Headit | R | | | | S1 | - | | | | after command | | | R | | | | | 2 | | | | execution. | | | R | | | | | 2 | | | | Sector ID information | | | R | | | | | 4 | | | | after command | | | R | | | | | ₹ | | | | execution. | | | R | 1 | | | 1 | V | | | | | | | <u> </u> | <u> </u> | | | | • | | | | | | | <u> </u> | | | | | | | | | | |---------------------------------|-------------|--------|-----------------|--------|-----------------|--------------|---------|----------|----------|-----------------------------------------------------------------------------| | Phase | R/W | D7 | D6 | D5 | Data<br>D4 | | D2 | D1 | DO | Remarks | | | | | | | | | | | | | | Command | W | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | Command Codes | | Execution<br>No Result<br>Phase | W | X | X | Х | Х | Х | 0 | US1 | uso | Head retracted to track 0 | | | | | S | ense | Inter | rupt | Stat | us | | | | Command<br>Result | W<br>R<br>R | 0 | 0 | 0 | O<br>ST<br>PC | 1<br>0<br>CN | 0 | 0 | 0 | Command Codes Status information at the end of seek operation about the FDC | | | Specify | | | | | | | | | | | Command | W | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | Command Codes | | | W | ļ | SRTHUT<br>HLTND | | | | | | | | | No Result<br>Phase | VV | | | HLI | | | | | · NU | | | | | | | Sens | e Dri | ve S | tatus | 3 | | | | Command | W | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | Command Codes | | Result | W<br>R | × | X | X | X<br>ST | | но | 051 | US0 | Status information about FDD. | | | | | | | Se | ek | | | | | | Command | W<br>W<br>W | 0<br>X | 0<br>X | 0<br>X | O<br>X<br>NO | | 1<br>HD | 1<br>US1 | 1<br>USO | Command Codes | | Execution | VV | | | | INC | ZIN | | | | Head is positioned over proper cylinder on diskette. | | No Result<br>Phase | | | | | | | | | | on diskette. | | Command | W | | | ln | <b>Inv</b> alid | | es | | | Invalid command codes (NoOp — FDC goes into standby state). | | Result | R | | | | ST | 0 | | | | ST 0 = 80. | | | Bit | | | |----------|--------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No. | Name | Symbol | Description | | D7 | Interrupt<br>Code | IC | D7 = 0 and D6 = 0 Normal termination of command (NT). Command was completed and properly executed. D7 = 0 and D6 = 1 Abnormal termination of command (AT). Execution of command was started, but was not successfully completed. D7 = 1 and D6 = 0 Invalid command issue (IC). Command that was issued was never started. D7 = 1 and D6 = 1 Abnormal termination because, during command execution, the ready signal from FDD changed state. | | D5 | Seek End | SE | When the FDC completes the seek command, this flag is set to 1 (high). | | D4 | Equipment<br>Check | EC | If a fault signal is received from the FDD, or if the track 0 signal fails to occur after 77 step pulses (recalibrate command), then this flag is set. | | D3 | Not Ready | NR | When the FDD is in the not-ready state and a read or write command is issued, this flag is set. If a read or write command is issued to side 1 of a single-sided drive, then this flag is set. | | D2 | Head Address | HD | This flag is used to indicate the state of the head at interrupt. | | D1<br>D0 | Unit Select 1<br>Unit Select 0 | US 1<br>US 0 | These flags are used to indicate a drive unit number at interrupt. | | | Bit | | | |-----|----------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No. | Name | Symbol | Description | | D7 | End of<br>Cylinder | EN | When the FDC tries to access a sector beyond the final sector of a cylinder, this flag is set. | | D6 | _ | _ | Not used. This bit is always 0 (low). | | D5 | Data Error | DE | When the FDC detects a CRC error in either the ID field or the data field, this flag is set. | | D4 | Over Run | OR | If the FDC is not serviced by the main system during data transfers within a certain time interval, this flag is set. | | D3 | _ | _ | Not used. This bit is always 0 (low). | | D2 | No Data | ND | During execution of a read data, write deleted data, or scan command, if the FDC cannot find the sector specified in the ID register, this flag is set. During execution of the read ID command, if the FDC cannot read the ID field without an error, then this flag is set. During the execution of the read a cylinder command, if the starting sector cannot be found, then this flag is set. | | D1 | Not Writable | NW | During execution of a write data, write<br>deleted data, or format-a-cylinder<br>command, if the FDC detects a<br>write-protect signal from the FDD, then<br>this flag is set. | | DO | Missing<br>Address<br>Mark | MA | If the FDC cannot detect the ID address mark, this flag is set. Also, at the same time, the MD (missing address mark in the data field) of status register 2 is set. | | | Bit | | | |-----|------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No. | Name | Symbol | Description | | D7 | _ | _ | Not used. This bit is always 0 (low). | | D6 | Control Mark | СМ | During execution of the read data or scan command, if the FDC encounters a sector that contains a deleted data address mark, this flag is set. | | D5 | Data Error in<br>Data Field | DD | If the FDC detects a CRC error in the data, then this flag is set. | | D4 | Wrong<br>Cylinder | WC | This bit is related to the ND bit, and when the contents of C on the medium are different from that stored in the ID register, this flag is set. | | D3 | Scan Equal<br>Hit | SH | During execution of the scan command, if the condition of "equal" is satisfied, this flag is set. | | D2 | Scan Not<br>Satisfied | SN | During execution of the scan command, if the FDC cannot find a sector on the cylinder that meets the condition, then this flag is set. | | D1 | Bad Cylinder | ВС | This bit is related to the ND bit, and when the contents of C on the medium are different from that stored in the ID register, and the contents of C is FF, then this flag is set. | | DO | Missing<br>Address Mark<br>in Data Field | MD | When data is read from the medium, if<br>the FDC cannot find a data address mark<br>or deleted data address mark, then this<br>flag is set. | | | Bit | | | |-----|--------------------|--------|--------------------------------------------------------------------| | No. | Name | Symbol | Description | | D7 | Fault | FT | This bit is the status of the fault signal from the FDD. | | D6 | Write<br>Protected | WP | This bit is the status of the write-protected signal from the FDD. | | D5 | Ready | RY | This bit is the status of the ready signal from the FDD. | | D4 | Track 0 | ТО | This bit is the status of the track 0 signal from the FDD. | | D3 | Two Side | TS | This bit is the status of the two-side signal from the FDD. | | D2 | Head Address | HD | This bit is the status of the side-select signal from the FDD. | | D1 | Unit Select 1 | US 1 | This bit is the status of the unit-select-1 signal from the FDD. | | D0 | Unit Select 0 | US 0 | This bit is the status of the unit-select-0 signal from the FDD. | # **Programming Summary** | FDC Data I | Register | I/O Address Hex 3F5 | | | | | |---------------|-----------------|---------------------|--|--|--|--| | FDC Main | Status Register | I/O Address Hex 3F4 | | | | | | Digital Out | put Register | I/O Address Hex 3F2 | | | | | | Bit O | Drive | 00: DR #A 10: DR #C | | | | | | 1 | Select | 01: DR #B 11: DR #D | | | | | | 2 | Not FDC Rese | et | | | | | | 3 | Enable INT & | DMA Requests | | | | | | 4 | Drive A Moto | r Enable | | | | | | 5 | Drive B Motor | r Enable | | | | | | 6 | Drive C Moto | r Enable | | | | | | 7 | Drive D Moto | r Enable | | | | | | All bits clea | ared with chann | nel reset. | | | | | #### **DPC Registers** #### **FDC** Constants (in hex) N: 02 GPL Format: 05 SC: 08 GPL R/W: 2A HUT: F HLT: 01 SRT: C (6 ms track-to-track) #### **Drive Constants** Head Load 35 ms Head Settle 15 ms Motor Start 250 ms #### Comments - Head loads with drive select, wait HD load time before R/W. - Following access, wait HD settle time before R/W. - Drive motors should be off when not in use. Only A or B and C or D may run simultaneously. Wait motor start time before R/W. - Motor must be on for drive to be selected. - Data errors can occur while using a home television as the system display. Placing the TV too close to the diskette area can cause this to occur. To correct the problem, move the TV away from, or to the opposite side of the system unit. ## Interface ## System I/O Channel Interface All signals are TTL-compatible: | Most Positive Up Level | + 5.5 Vdc | |---------------------------|-----------| | Least Positive Up Level | + 2.7 Vdc | | Most Positive Down Level | +0.5 Vdc | | Least Positive Down Level | -0.5 Vdc | The following lines are used by this adapter. - +D0-7 (Bidirectional, Load: 1 74LS, Driver: 74LS 3-state): These eight lines form a bus through which all commands, status, and data are transferred. Bit 0 is the low-order bit. - +A0-9 (Adapter input, Load: 1 74LS): These 10 lines form an address bus by which a register is selected to receive or supply the byte transferred through lines D0-7. Bit 0 is the low-order bit. - +AEN (Adapter input, load: 1 74LS): The content of lines A0–9 is ignored if this line is active. - -IOW (Adapter input, Load: 1 74LS): The content of lines D0-7 is stored in the register addressed by lines A0-9 or DACK2 at the trailing edge of this signal. - -IOR (Adapter input, Load: 1 74LS): The content of the register addressed by lines A0–9 or DACK2 is gated onto lines D0–7 when this line is active. - **-DACK2** (Adapter input, load: 2 74LS): This line being active degates output DRQ2, selects the FDC data register as the source or destination of bus D0–7, and indirectly gates T/C to IRQ6. - +T/C (Adapter input, load: 4 74LS): This line along with DACK2 being active indicates that the byte of data for which the DMA count was initialized is now being transferred. - +RESET (Adapter input, load: 1 74LS): An up level ends any operation in process and clears the digital output register (DOR). - +DRQ2 (Adapter output, driver: 74LS 3-state): This line is made active when the attachment is ready to transfer a byte of data to or from main storage. The line is made inactive by DACK2 becoming active or an I/O read of the FDC data register. - +IRQ6 (Adapter output, driver: 74LS 3-state): This line is made active when the FDC has completed an operation. It results in an interrupt to a routine that should examine the FDC result bytes to reset the line and determine the ending condition. #### **Drive A and B Interface** All signals are TTL-compatible: | Most Positive Up Level | + 5.5 Vdc | |---------------------------|-----------| | Least Positive Up Level | + 2.4 Vdc | | Most Positive Down Level | + 0.4 Vdc | | Least Positive Down Level | - 0.5 Vdc | All adapter outputs are driven by open-collector gates. The drives must provide termination networks to Vcc (except 'motor enable', which has a 2,000-ohm resistor to Vcc). Each adapter input is terminated with a 150-ohm resistor to Vcc. #### **Adapter Outputs** -Drive Select A and B (Driver: 7438): These two lines are used by drives A and B to degate all drivers to the adapter and receivers from the attachment (except 'motor enable') when the line associated with a drive is inactive. -Motor Enable A and B (Driver: 7438): The drive associated with each of these lines must control its spindle motor such that it starts when the line becomes active and stops when the line becomes inactive. -Step (Driver: 7438): The selected drive moves the read/write head one cylinder in or out per the direction line for each pulse present on this line. -Direction (Driver: 7438): For each recognized pulse of the 'step' line, the read/write head moves one cylinder toward the spindle if this line is active, and away from the spindle if inactive. -Head Select (Driver: 7438): Head 1 (upper head) will be selected when this line is active (low). -Write Data (Driver: 7438): For each inactive-to-active transition of this line while 'write enable' is active, the selected drive causes a flux change to be stored on the diskette. -Write Enable (Driver: 7348): The drive disables write current in the head unless this line is active. #### **Adapter Inputs** **-Index** The selected drive must supply one pulse per diskette revolution on this line. **-Write Protect** The selected drive must make this line active if a write-protected diskette is in the drive. **-Track 0** The selected drive must make this line active if the read/write head is over track 0. **-Read Data** The selected drive supplies a pulse on this line for each flux change encountered on the diskette. # **Specifications** Note: Lands 1-33 (odd numbers) are on the back of the board. Lands 2-34 (even numbers) are on the front, or component side. Connector Specifications (Part 1 of 2) Connector Specifications (Part 2 of 2) 5-1/4 Inch Diskette Drive Adapter (Sheet 1 of 4) 5-1/4 Inch Diskette Drive Adapter (Sheet 2 of 4) NOTE: U4[74LS08] PINS 12 AND 13 ARE CONNECTED ONLY ON CARDS BUILT USING RAW CARD P/N 5001293 5-1/4 Inch Diskette Drive Adapter (Sheet 3 of 4) 5-1/4 Inch Diskette Drive Adapter (Sheet 4 of 4) # IBM Fixed Disk Adapter ii # **Contents** | Description | |----------------------------| | Fixed Disk Controller 1 | | Programming Considerations | | Status Register 3 | | Sense Bytes | | Data Register 7 | | Control Byte 8 | | Command Summary 10 | | Programming Summary 14 | | Interface | | Specifications | | Logic Diagrams | | BIOS Listing | # **Description** The Fixed Disk Adapter attaches to one or two fixed disk drive units through an internal, daisy-chained, flat cable (data/control cable). Each system supports a maximum of one Fixed Disk Adapter and two fixed disk drives. The adapter is buffered on the I/O bus and uses the system board's direct memory access (DMA) for record data transfers. An interrupt level also is used to indicate operation completion and status conditions that require microprocessor attention. The Fixed Disk Adapter provides automatic 11-bit burst error detection and correction in the form of 32-bit error checking and correction (ECC). The device level control for the Fixed Disk Adapter is contained on a ROM module on the adapter. A listing of this device level control can be found in "BIOS Listing" of this section. Warning: The last cylinder on the fixed disk drive is reserved for diagnostic use. The diagnostic write test will destroy any data on this cylinder. #### Fixed Disk Controller The disk controller has two registers that may be accessed by the system unit's microprocessor: a status register and a data register. The 8-bit status register contains the status information of the disk controller, and can be accessed at any time. The 8-bit data register (actually consisting of several registers in a stack with only one register presented to the data bus) stores data, commands, and parameters, and provides the disk controller's status information. Data bytes are read from, or written to the data register in order to program or obtain the results after a particular command. The status register is a read-only register that is used to help the transfer of data between the system unit's microprocessor and the disk controller. The controller-select pulse is generated by writing to port address hex 322. Fixed Disk Adapter Block Diagram # **Programming Considerations** ### **Status Register** At the end of all commands from the system board, the disk controller sends a completion status byte to the system board. This byte informs the system unit's microprocessor if an error occurred during the execution of the command. The following shows the format of this byte. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---|---|---|---|---|---|---|---| | | 0 | 0 | d | 0 | 0 | 0 | е | 0 | Bits 0, 1, 2, 3, 4, 6, 7 These bits are set to zero. Rit 1 When set, this bit shows an error has occurred during command execution. Bit 5 This bit shows the logical unit number of the drive. If the interrupts are enabled, the controller sends an interrupt when it is ready to transfer the status byte. Busy from the disk controller is unasserted when the byte is transferred to complete the command. ### **Sense Bytes** If the status register receives an error (bit 1 set), the disk controller requests four bytes of sense data. The format for the four bytes is as follows: | Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------------|---------|------|---------|-------|----------|------|---| | Byte 0 | Address<br>Valid | 0 | Erro | or Type | | Error | Code | | | Byte 1 | 0 | 0 | d | | Hea | ad Numb | er | | | Byte 2 | Cylinde | er High | | | Sec | tor Numb | er | | | Byte 3 | | : | | Cylinde | r Low | | | | Remarks d = drive Byte 0 Bits 0, 1, 2, 3 Error code. Byte 0 Bits 4, 5 Error type. Byte 0 Bit 6 Set to 0 (spare) Byte 0 Bit 7 The address-valid bit. Set only when the previous command required a disk address, in which case it is returned as a 1; otherwise, it is 0. #### **Disk Controller Error Tables** The following disk controller error tables list the error types and error codes found in byte 0: | | Erro | r Type | E | Error Code | | de | | |------|------|--------|---|------------|---|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 0 | 0 | 0 | 0 | 0 | 0 | The controller did not detect any error during the execution of the previous operation. | | | 0 | 0 | 0 | 0 | 0 | 1 | The controller did not detect an index signal from the drive. | | | 0 | 0 | 0 | 0 | 1 | 0 | The controller did not get a seek-complete signal from the drive after a seek operation (for all non-buffered step seeks). | | | 0 | 0 | 0 | 0 | 1 | 1 | The controller detected a write fault from the drive during the last operation. | | | 0 | 0 | 0 | 1 | 0 | 0 | After the controller selected the drive, the drive did not respond with a ready signal. | | | 0 | 0 | 0 | 1 | 0 | 1 | Not used. | | | 0 | 0 | 0 | 1 | 1 | 0 | After stepping the maximum number of cylinders, the controller did not receive the track 00 signal from the drive. | | | 0 | 0 | 0 | 1 | 1 | 1 | Not used. | | | 0 | 0 | 1 | 0 | 0 | 0 | The drive is still seeking. This status is reported by the Test Drive Ready command for an overlap seek condition when the drive has not completed the seek. No time-out is measured by the controller for the seek to complete. | | | Erro | r Type | E | rror | e Error Code | | | |------|------|--------|---|------|--------------|---|--------------------------------------------------------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 0 | 1 | 0 | 0 | 0 | 0 | ID Read Error: The controller detected an ECC error in the target ID field on the disk. | | | 0 | 1 | 0 | 0 | 0 | 1 | Data Error: The controller detected an uncorrectable ECC error in the target sector during a read operation. | | | 0 | 1 | 0 | 0 | 1 | 0 | Address Mark: The controller did not detect the target address mark (AM) on the disk. | | | 0 | 1 | 0 | 0 | 1 | 1 | Not used. | | | 0 | 1 | 0 | 1 | 0 | 0 | Sector Not Found: The controller found the correct cylinder and head, but not the target sector. | | | 0 | 1 | 0 | 1 | 0 | 1 | Seek Error: The cylinder or head address<br>(either or both) did not compare with the<br>expected target address as a result of a<br>seek. | | | 0 | 1 | 0 | 1 | 1 | 0 | Not used. | | | 0 | 1 | 0 | 1 | 1 | 1 | Not used. | | | 0 | 1 | 1 | 0 | 0 | 0 | Correctable Data Error: The controller detected a correctable ECC error in the target field. | | | 0 | 1 | 1 | 0 | 0 | 1 | Bad Track: The controller detected a bad<br>track flag during the last operation. No<br>retries are attempted on this error. | | | Error Type Error Code | | de | | | | | |------|-----------------------|---|----|---|---|---|--------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 1 | 0 | 0 | 0 | 0 | 0 | Invalid Command: The controller has received an invalid command from the system unit. | | | 1 | 0 | 0 | 0 | 0 | 1 | Illegal Disk Address. The controller detected an address that is beyond the maximum range. | | | Erro | r Type | Error Code | | de | | | |------|------|--------|------------|---|----|---|-------------------------------------------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 1 | 1 | 0 | 0 | 0 | 0 | RAM Error: The controller detected a data error during the RAM sector-buffer diagnostic test. | | | 1 | 1 | 0 | 0 | 0 | 1 | Program Memory Checksum Error: During this internal diagnostic test, the controller detected a program-memory checksum error. | | | 1 | 1 | 0 | 0 | 1 | 0 | ECC Polynominal Error: During the controller's internal diagnostic tests, the hardware ECC generator failed its test. | ### **Data Register** The system unit's microprocessor specifies the operation by sending the 6-byte device control block (DCB) to the controller. The figure below shows the composition of the DCB, and defines the bytes that make up the DCB. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |--------|--------|---------------------------|---|---------|--------|--------|---|-----|--|--|--| | Byte 0 | | Command<br>Class | | | | Opcode | | . : | | | | | Byte 1 | 0 | 0 0 d Head Number | | | | | | | | | | | Byte 2 | Cyline | der High | | | Sector | Number | | | | | | | Byte 3 | | | | Cylinde | r Low | | | | | | | | Byte 4 | | Interleave or Block Count | | | | | | | | | | | Byte 5 | | Control Field | | | | | | | | | | - Byte 0 Bits 7, 6, and 5 identify the class of the command. Bits 4 through 0 contain the Opcode command. - Bit 5 identifies the drive number. Bits 4 through 0 Byte 1 contain the disk head number to be selected. Bits 6 and 7 are not used. Byte 2 Bits 6 and 7 contain the two most significant bits of the cylinder number. Bits 0 through 5 contain the sector number. Byte 3 Bits 0 through 7 are the eight least-significant bits of the cylinder number. Byte 4 Bits 0 through 7 specify the interleave or block count. Byte 5 Bits 0 through 7 contain the control field. ## **Control Byte** Byte 5 is the control field of the DCB and allows the user to select options for several types of disk drives. The format of this byte is as follows: | Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|---|---|---|---|---|---| | | r | а | 0 | 0 | 0 | s | s | S | Remarks r = retries s = step option a = retry option on data ECC error Bit 7 Disables the four retries by the controller on all disk-access commands. Set this bit only during the evaluation of the performance of a disk drive. Bit 6 If set to 0 during read commands, a reread is attempted when an ECC error occurs. If no error occurs during reread, the command will finish without an error status. If this bit is set to 1, no reread is attempted. Bits 5, 4, 3 Set to 0. Bits 2, 1, 0 These bits define the type of drive and select the step option. See the following figure. | Bits 2, 1, ( | 0 | | | |--------------|---|---------------------------------------------------------------------|---| | 0 0 0 | ) | This drive is not specified and defaults to 3 milliseconds per step | | | 0 0 | 1 | N/A | | | 0 1 ( | ) | N/A | - | | 0 1 1 | 1 | N/A | | | 1 0 0 | ) | 200 microseconds per step. | | | 1 0 1 | 1 | 70 microseconds per step (specified by BIOS). | | | 1 1 0 | 5 | 3 milliseconds per step. | | | 1 1 1 | 1 | 3 milliseconds per step. | | # **Command Summary** | Command | Data Control Block | Remarks | |-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | Test Drive<br>Ready<br>(Class 0,<br>Opcode 00) | Bit 7 6 5 4 3 2 1 0 Byte 0 0 0 0 0 0 0 0 0 Byte 1 0 0 d x x x x x x | x = don't care | | Recalibrate<br>(Class 0,<br>Opcode 01) | Bit 7 6 5 4 3 2 1 0 Byte 0 0 0 0 0 0 0 0 0 1 Byte 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 < | x = don't care<br>r = retries | | Reserved (Class 0, Opcode 02) Request Sense Status (Class 0, Opcode 03) | Bit 7 6 5 4 3 2 1 0 Byte 0 0 0 0 0 0 0 1 1 Byte 1 0 0 d x x x x x x | x = don't care | | Format Drive<br>(Class 0,<br>Opcode 04) | Bit 7 6 5 4 3 2 1 0 Byte 0 0 0 0 0 1 0 0 Byte 1 0 0 0 0 0 0 0 0 Byte 2 ch 0 0 0 0 0 0 0 Byte 3 Cylinder Low Byte 4 0 0 0 Interleave Byte 5 r 0 0 0 0 s s | r = retries s = step option ch = cylinder high Interleave 1 to 16 | | Ready Verify<br>(Class 0,<br>Opcode 05) | Bit 7 6 5 4 3 2 1 0 Byte 0 0 0 0 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0< | r = retries s = step option a = retry option on data ECC ch = cylinder high | | Command | Data Control Block | | Remarks | | |--------------|--------------------|-------------------|-----------------------------------------|--| | Format Track | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | | (Class 0, | | 0 0 0 0 0 1 1 0 | r = retries | | | Opcode 06) | <del> - / </del> | 0 0 d Head Number | s = step option | | | Opcode 00) | Byte 2 | ch 0 0 0 0 0 0 | ch = cylinder high | | | | Byte 3 | Cylinder Low | on = cymiaci riigii | | | | <del> </del> | 0 0 0 Interleave | Interleave 1 to 16 | | | | <del> </del> | r 0 0 0 0 s s s | for 512-byte sectors. | | | | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | Format Bad | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | | Track | Byte 0 | 0 0 0 0 0 1 1 1 | r = retries | | | (Class 0, | Byte 1 | 0 0 d Head Number | s = step option | | | Opcode 07) | Byte 2 | ch 0 0 0 0 0 0 | ch = cylinder high | | | : | Byte 3 | Cylinder Low | | | | | Byte 4 | 0 0 0 Interleave | Interleave 1 to 16 | | | | Byte 5 | r 0 0 0 0 s s s | for 512-byte sectors. | | | | | | | | | Read | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | | (Class 0, | Byte 0 | 0 0 0 0 1 0 0 0 | r = retries | | | Opcode 08) | Byte 1 | 0 0 d Head Number | a = retry option on | | | | Byte 2 | ch Sector Number | data ECC error | | | | Byte 3 | Cylinder Low | s = step option | | | | Byte 5 | r a 0 0 0 s s s | ch = cylinder high | | | December 1 | | | T1 :- 0 | | | Reserved | | | This Opcode is not | | | (Class 0, | | | used. | | | Opcode 09) | | | | | | Write | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | | (Class 0, | Byte 0 | 0 0 0 0 1 0 1 0 | r = retries | | | Opcode 0A) | Byte 1 | 0 0 d Head Number | s = step option | | | · | Byte 2 | ch Sector Number | ch = cylinder high | | | | Byte 3 | Cylinder Low | | | | | Byte 4 | Block Count | | | | | Byte 5 | r 0 0 0 0 s s s | | | | | | | | | | Seek | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | | (Class 0, | Byte 0 | 0 0 0 0 1 0 1 1 | r = retries | | | Opcode 0B) | Byte 1 | 0 0 d Head Number | s = step option | | | | Byte 2 | ch 0 0 0 0 0 0 | x = don't care | | | | Byte 3 | Cylinder Low | ch = cylinder high | | | | Byte 4 | x x x x x x x x | | | | | Byte 5 | r 0 0 0 0 s s s | | | | L | | <del></del> | l | | | Command | | Data Control Block | Remarks | |-----------------------|----------|--------------------|--------------------------| | Initialize | Bit | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Drive | Byte 0 | 0 0 0 0 1 1 0 0 | don't care | | Characteristics* | | | | | (Class 0, | | | | | Opcode OC) | | | | | Read ECC Burst | Bit | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Error Length | Byte 0 | 0 0 0 0 1 1 0 1 | don't care | | (Class 0, | | | | | Opcode OD) | | | | | Read Data from | Bit | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Sector Buffer | Byte 0 | 0 0 0 0 1 1 1 0 | don't care | | (Class 0, | | | | | Opcode 0E) | | | | | Write Data to | Bit | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Sector Buffer | Byte 0 | 0 0 0 0 1 1 1 1 | don't care | | (Class 0, | <u> </u> | | | | Opcode 0F) | | | | | RAM | Bit | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Diagnostic | Byte 0 | 1 1 1 0 0 0 0 0 | don't care | | (Class 7, | L-/ | | | | Opcode 00) | | | | | Deserved | | | This Oussels is not | | Reserved<br>(Class 7, | | | This Opcode is not used. | | Opcode 01) | | | useu. | | Opcode 017 | | | | | Reserved | | | This Opcode is not | | (Class 7, | | | used. | | Opcode 02) | | | | <sup>\*</sup>Initialize Drive Characteristics: The DBC must be followed by eight additional bytes. | Maximum number of cylinders | (2 bytes) | |--------------------------------------|-----------| | Maximum number of heads | (1 byte) | | Start reduced write current cylinder | (2 bytes) | | Start write precompensation cylinder | (2 bytes | | Maximum ECC data burst length | (1 byte) | ### 12 Fixed Disk Adapter | Command | Data Control | Block | Remarks | |----------------|----------------|-------------|------------------------| | Drive | Bit 7 6 5 4 | 3 2 1 0 | d = drive (0 or 1) | | Diagnostic | Byte 0 1 1 1 0 | 0 0 1 1 | s = step option | | (Class 7, | Byte 1 0 0 d x | x x x x | r = retries | | Opcode 03) | Byte 2 x x x x | x x x x | x = don't care | | | Byte 3 x x x x | x x x x | | | | Byte 4 x x x x | x x x x | | | | Byte 5 r 0 0 0 | 0 s s s | | | | | | | | Controller | Bit 7 6 5 4 | 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = | | Internal | Byte 0 1 1 1 0 | 0 1 0 0 | don't care | | Diagnostics | | | | | (Class 7, | | | · | | Opcode 04) | | | | | Read Long* | Bit 7 6 5 4 | 3 2 1 0 | d = drive (0 or 1) | | (Class 7, | Byte 0 1 1 1 0 | 0 1 0 1 | s = step option | | Opcode 05) | Byte 1 0 0 d F | lead Number | r = retries | | | Byte 2 ch Sec | tor Number | ch = cylinder high | | | Byte 3 Cylind | der Low | | | | Byte 4 Block | Count | | | | Byte 5 r 0 0 0 | 0 s s s | | | | | | | | Write Long * * | Bit 7 6 5 4 | | d = drive (0 or 1) | | (Class 7, | Byte 0 1 1 1 0 | | s = step option | | Opcode 06) | | lead Number | r = retries | | | | tor Number | ch = cylinder high | | | <u> </u> | der Low | | | | | Count | | | | Byte 5 r 0 0 0 | 0 s s s | | <sup>\*</sup>Returns 512 bytes plus 4 bytes of ECC data per sector. <sup>\* \*</sup>Requires 512 bytes plus 4 bytes of ECC data per sector. ### **Programming Summary** The two least-significant bits of the address bus are sent to the system board's I/O port decoder, which has two sections. One section is enabled by the I/O read signal (-IOR) and the other by the I/O write signal (-IOW). The result is a total of four read/write ports assigned to the disk controller board. The address enable signal (AEN) is asserted by the system board when DMA is controlling data transfer. When AEN is asserted, the I/O port decoder is disabled. The following figure is a table of the read/write ports. | R/W | Port Address | Function | |---------------|--------------|------------------------------------------------------------------------------------------| | Read<br>Write | 320<br>320 | Read data (from controller to system unit). Write data (from system unit to controller). | | Read<br>Write | 321<br>321 | Read controller hardware status. Controller reset. | | Read<br>Write | 322<br>322 | Reserved. Generate controller-select pulse. | | Read<br>Write | 323<br>323 | Not used. Write pattern to DMA and interrupt mask register. | ### Interface The following lines are used by the disk controller: - A0-A19 Positive true 20-bit address. The least-significant 10 bits contain the I/O address within the range of hex 320 to hex 323 when an I/O read or write is executed by the system unit. The full 20 bits are decoded to address the read-only memory (ROM) between the addresses of hex C8000 and C9FFF. - DO-D7 Positive 8-bit data bus over which data and status information is passed between the system board and the controller. - -IOR Negative true signal that is asserted when the system board reads status or data from the controller under either programmed I/O or DMA control. - -IOW Negative true signal that is asserted when the system board sends a command or data to the controller under either programmed I/O or DMA control. - AEN Positive true signal that is asserted when the DMA in the system board is generating the I/O Read (-IOR) or I/O Write (-IOW) signals and has control of the address and data buses. - RESET Positive true signal that forces the disk controller to its initial power-up condition. - IRQ 5 Positive true interrupt-request signal that is asserted by the controller when enabled to interrupt the system board on the return ending status byte from the controller. - DRQ 3 Positive true DMA-request signal that is asserted by the controller when data is available for transfer to or from the controller under DMA control. This signal remains active until the system board's DMA channel activates the DMA-acknowledge signal (-DACK 3) in response. **-DACK 3** This signal is true when negative, and is generated by the system board DMA channel in response to a DMA request (DRQ 3). # **Specifications** The Fixed Disk Adapter connector and interface specifications follow. **Fixed Disk Adapter Interface Specifications** #### 18 Fixed Disk Adapter Fixed Disk Adapter (Sheet 1 of 6) Fixed Disk Adapter (Sheet 2 of 6) Fixed Disk Adapter (Sheet 3 of 6) Fixed Disk Adapter (Sheet 4 of 6) Fixed Disk Adapter (Sheet 5 of 6) Fixed Disk Adapter (Sheet 6 of 6) # **BIOS Listing** The BIOS Listing for the IBM Fixed Disk Adapter follows. LOC OBJ LINE SOURCE ``` $TITLE(FIXED DISK BIOS FOR IBM DISK CONTROLLER) ;-- INT 13 ----- ; FIXED DISK I/O INTERFACE THIS INTERFACE PROVIDES ACCESS TO 5 1/4" FIXED DISKS THROUGH THE IBM FIXED DISK CONTROLLER. 10 11 12 13 THE BIOS ROUTINES ARE MEANT TO BE ACCESSED THROUGH SOFTWARE INTERRUPTS ONLY. ANY ADDRESSES PRESENT IN 15 THE LISTINGS ARE INCLUDED ONLY FOR COMPLETENESS. NOT FOR REFERENCE. APPLICATIONS WHICH REFERENCE ABSOLUTE ADDRESSES WITHIN THE CODE SEGMENT 16 17 VIOLATE THE STRUCTURE AND DESIGN OF BIOS. 19 |---- 20 ; INPUT (AH = HEX VALUE) 21 (AH)=00 RESET DISK (DL = 80H,81H) / DISKETTE 23 (AH)=01 READ THE STATUS OF THE LAST DISK OPERATION INTO (AL) 24 25 NOTE: DL < 80H - DISKETTE DL > 80H - DISK (AH)=02 READ THE DESIRED SECTORS INTO MEMORY 28 (AH)=03 WRITE THE DESTRED SECTORS FROM MEMORY 29 (AH)=04 VERIFY THE DESIRED SECTORS (AH)=05 FORMAT THE DESIRED TRACK 31 (AH)=06 FORMAT THE DESIRED TRACK AND SET BAD SECTOR FLAGS (AH)=07 FORMAT THE DRIVE STARTING AT THE DESIRED TRACK 32 33 (AH)=08 RETURN THE CURRENT DRIVE PARAMETERS 34 (AH)=09 INITIALIZE DRIVE PAIR CHARACTERISTICS 36 INTERRUPT 41 POINTS TO DATA BLOCK 37 (AH)=OA READ LONG 38 (AH)=OB WRITE LONG 39 NOTE: READ AND WRITE LONG ENCOMPASS 512 + 4 BYTES ECC (AH)=OC SEEK 40 41 (AH)=0D ALTERNATE DISK RESET (SEE DL) 42 (AH)=0E READ SECTOR BUFFER 43 (AH)=OF WRITE SECTOR BUFFER, (RECOMMENDED PRACTICE BEFORE FORMATTING) 45 (AH)=10 TEST DRIVE READY 46 (AH)=11 RECALIBRATE 47 (AH)=12 CONTROLLER RAM DIAGNOSTIC (AH)=13 DRIVE DIAGNOSTIC 49 (AH)=14 CONTROLLER INTERNAL DIAGNOSTIC 50 51 REGISTERS USED FOR FIXED DISK OPERATIONS 52 53 (DL) - DRIVE NUMBER (80H-87H FOR DISK, VALUE CHECKED) 54 (DH) - HEAD NUMBER (0-7 ALLOWED, NOT VALUE CHECKED) (CH) - CYLINDER NUMBER (0-1023, NOT VALUE CHECKED)(SEE CL) 55 (CL) - SECTOR NUMBER (1-17, NOT VALUE CHECKED) 57 NOTE: HIGH 2 BITS OF CYLINDER NUMBER ARE PLACED 58 IN THE HIGH 2 BITS OF THE CL REGISTER 59 60 (10 BITS TOTAL) (AL) - NUMBER OF SECTORS (MAXIMUM POSSIBLE RANGE 1-80H, 61 FOR READ/WRITE LONG 1-79H) 62 (INTERLEAVE VALUE FOR FORMAT 1-16D) 63 (ES:BX) - ADDRESS OF BUFFER FOR READS AND WRITES, (NOT REQUIRED FOR VERIFY) 65 66 ; OUTPUT 67 AH = STATUS OF CURRENT OPERATION STATUS BITS ARE DEFINED IN THE EQUATES BELOW CY = 0 SUCCESSFUL OPERATION (AH=0 ON RETURN) 70 71 CY = 1 FAILED OPERATION (AH HAS ERROR REASON) NOTE: ERROR 11H INDICATES THAT THE DATA READ HAD A RECOVERABLE 73 ERROR WHICH WAS CORRECTED BY THE ECC ALGORITHM. THE DATA 74 75 IS PROBABLY GOOD. HOWEVER THE BIOS ROUTINE INDICATES AN ERROR TO ALLOW THE CONTROLLING PROGRAM A CHANCE TO DECIDE FOR ITSELF. THE ERROR MAY NOT RECUR IF THE DATA IS ``` ``` LOC OBJ LINE SOURCE 78 REWRITTEN, (AL) CONTAINS THE BURST LENGTH. 79 80 TE DOTVE PADAMETEDS WEDE DEGLIESTED. 81 DI = NIMBER OF CONSECUTIVE ACKNOWLEDGING DRIVES ATTACHED (0-2) 82 83 (CONTROLLER CARD ZERO TALLY ONLY) 84 DH = MAXIMUM USEABLE VALUE FOR HEAD NUMBER CH = MAXIMUM USEABLE VALUE FOR CYLINDER NUMBER 85 86 CL = MAXIMIM LISEABLE VALUE FOR SECTOR NUMBER 87 AND CYLINDER NUMBER HIGH BITS 88 89 REGISTERS WILL BE PRESERVED EXCEPT WHEN THEY ARE USED TO RETURN 90 INFORMATION. 91 92 NOTE: IF AN ERROR IS REPORTED BY THE DISK CODE, THE APPROPRIATE 93 ACTION IS TO RESET THE DISK, THEN RETRY THE OPERATION. 94 95 I----- 96 OOFF 97 3 SENSE OPERATION FAILED SENSE_FAIL EQU OFFH UNDEF_ERR EQU OBBH ; UNDEFINED ERROR OCCURRED 00BB 98 0080 99 ; ATTACHMENT FAILED TO RESPOND ; SEEK OPERATION FAILED 0040 100 0020 101 ; CONTROLLER HAS FAILED ; ECC CORRECTED DATA ERROR ; BAD ECC ON DISK READ 102 DATA CORRECTED EQU 11H 10H 0010 BAD_ECC EQU 103 0008 104 BAD_TRACK EQU 0BH ; BAD TRACK FLAG DETECTED DMA_BOUNDARY EQU INIT_FAIL EQU 0009 105 0 9H ; ATTEMPT TO DMA ACROSS 64K BOUNDARY 07H ; DRIVE PARAMETER ACTIVITY FAILED 106 0005 107 BAD RESET FQU 05H ; RESET FAILED ; REQUESTED SECTOR NOT FOUND RECORD_NOT_FND EQU 0004 108 04H 0002 109 BAD_ADDR_MARK EQU 02H ; ADDRESS MARK NOT FOUND 0001 ; BAD COMMAND PASSED TO DISK I/O 110 BAD_CMD EQU 01H 111 112 113 INTERRUPT AND STATUS AREAS 115 DUMMY SEGMENT AT 0 116 0034 117 ORG ODH*4 ; FIXED DISK INTERRUPT VECTOR 0034 HDISK_INT LABEL DWORD 118 004C 119 ORG 13H*4 ; DISK INTERRUPT VECTOR CTOR LABEL DWORD ORG 19H*4 004C ORG_VECTOR 120 0064 121 * BOOTSTDAD INTERDURT VECTOR 0064 122 BOOT_VEC LABEL DWORD 123 1EH*4 ; DISKETTE PARAMETERS 0078 DISKETTE_PARM LABEL DWORD 124 ORG : NEW DISKETTE INTERPUPT VECTOR 0100 125 040H*4 DISK_VECTOR 0100 126 LABEL DWORD 127 ORG 041H*4 ; FIXED DISK PARAMETER VECTOR LABEL DWORD 0104 128 HF_TBL_VEC 7000 129 ORG 7C00H : BOOTSTRAP LOADER VECTOR LABEL FAR 7C00 130 BOOT_LOCK 131 132 DATA SEGMENT AT 40H 133 0042 134 ORG 42H 135 HD_ERROR ROR DB ORG 06CH 0042 (7 ??) 136 7 DUP(?) ; OVERLAYS DISKETTE STATUS 006C 137 006C ???? 138 TIMER_LOW DM ; TIMER LOW WORD 0072 139 72H 0072 ???? DW ? ; 1234H IF KEYBOARD RESET UNDERWAY 140 RESET_FLAG ORG 74H DISK_STATUS DB 0074 141 0074 ?? 142 ; FIXED DISK STATUS BYTE HF_NUM DB ? CONTROL_BYTE DB ? PORT_OFF DB ? 0075 ?? ; COUNT OF FIXED DISK DRIVES 0076 ?? 144 ; CONTROL BYTE DRIVE OPTIONS 0077 ?? 145 PORT_OFF ; PORT OFFSET DATA ENDS ---- 146 147 149 ``` 150 151 152 153 154 ; HARDWARE SPECIFIC VALUES > WHEN READ FROM: ; - CONTROLLER I/O PORT ``` LOC OBJ LINE SOURCE 155 HF PORT+0 - READ DATA (FROM CONTROLLER TO CPU) : 156 HF_PORT+1 - READ CONTROLLER HARDWARE STATUS 157 (CONTROLLER TO CPU) HF_PORT+2 - READ CONFIGURATION SWITCHES 158 HF_PORT+3 - NOT USED 150 160 > WHEN WRITTEN TO: 161 HF_PORT+0 - WRITE DATA (FROM CPU TO CONTROLLER) : HF PORT+1 - CONTROLLER RESET 162 163 HF_PORT+2 - GENERATE CONTROLLER SELECT PULSE HF_PORT+3 - WRITE PATTERN TO DMA AND INTERRUPT : 165 MASK REGISTER 166 167 168 0320 HF_PORT 169 EQU 0320H : DISK PORT R1_BUSY R1_BUS R1_IOMODE 00001000B ; DISK PORT 1 BUSY BIT 0008 170 EQU 0004 171 EQU 00000100B COMMAND/DATA BIT 0002 172 EQU 00000010B 173 R1_REQ EQU 00000001B REQUEST BIT 174 DMA_READ EQU DMA_WRITE EQU 01000111B 0047 175 ; CHANNEL 3 (047H) 004B 176 ; CHANNEL 3 (04BH) 01001011B DMA 0000 177 DMA_HIGH EQU ; DMA ADDRESS 0082 178 EQU 082H ; PORT FOR HIGH 4 BITS OF DMA 179 0000 TST_RDY_CMD EQU 00000000В ; CNTLR READY (00H) 180 181 RECAL_CMD EQU 00000001B RECAL (01H) 0003 SENSE_CMD 182 FOU 000000118 SENSE (03H) 0004 183 FMTDRV_CMD EQU 00000100B DRIVE (04H) 0005 184 CHK_TRK_CMD FQU 00000101B T CHK (OSH) TRACK (06H) 0006 185 FMTTRK CMD EQU 00000110B . 0007 186 FMTBAD_CMD EQU 00000111B BAD (07H) 0008 187 READ_CMD EQU 00001000B READ (08H) WRITE_CMD AOOO EQU 00001010B WRITE (OAH) 000B 189 SEEK CMD EQU 00001011B SEEK (OBH) INIT_DRV_CMD EQU 0000 190 00001100B TNTT (OCH) 000D 191 RD_ECC_CMD EQU 00001101B BURST (ODH) 192 RD_BUFF_CMD EQU 00001110B BUFFR (OEH) WR_BUFF_CMD 000F 193 BUFFR (OFH) EQU 00001111B ; 00F0 194 RAM_DIAG_CMD EQU 11100000B RAM (EOH) 00E3 195 CHK_DRV_CMD EQU 11100011B DRV (E3H) 00E4 196 CNTLR_DIAG_CMD EQU 11100100B CNTLR (E4H) .__LUNG_CMD EQU WR_LONG_CMD FOR 00E5 197 11100101B RLONG (E5H) 00E6 198 11100110B WLONG (E6H) 199 INT_CTL_PORT 0020 EQU ; 8259 CONTROL PORT 200 20H 0020 201 ; END OF INTERRUPT COMMAND EQU 202 MAX_FILE 8000 203 MAX_FILE S_MAX_FILE EQU 205 206 ASSUME CS:CODE 0000 207 ORG 0000 55 DB 055H ; GENERIC BIOS HEADER 0001 AA DB 209 DAAH 0002 10 210 DB 211 213 ; FIXED DISK I/O SETUP 214 215 ; - ESTABLISH TRANSFER VECTORS FOR THE FIXED DISK ; - PERFORM POWER ON DIAGNOSTICS 216 SHOULD AN ERROR OCCUR A "1701" MESSAGE IS DISPLAYED 217 218 219 220 DISK_SETUP PROC FAR SHORT L3 0003 221 JMP 0003 EB1E 222 0005 35303030303539 DB '5000059 (C)COPYRIGHT IBM 1982' : COPYRIGHT NOTICE 20284329434F50 59524947485420 2049424D203139 ASSUME DS:DUMNY ; ZERO 0023 2BC0 226 SUB AX, AX ``` 227 0025 8ED8 MOV DS,AX | L0C 0 | )BJ | LINE | SOURCE | | | | | |-------|--------------|------------|--------|-----------|------------------------------|------------------|-----------------------------------------| | 0027 | FA | 228 | | CLI | | | | | 0028 | A14C00 | 229 | | MOV | AX, WORD PTR ORG_VECTOR | | ; GET DISKETTE VECTOR | | 002B | A30001 | 230 | | MOV | WORD PTR DISK_VECTOR,AX | | ; INTO INT 40H | | 002E | A14E00 | 231 | | MOV | AX, WORD PTR ORG_VECTOR+2 | | | | 0031 | A30201 | 232 | | MOV | WORD PTR DISK_VECTOR+2,A | X | | | 0034 | C7064C005602 | 233 | | MOV | WORD PTR ORG_VECTOR, OFF | | ; HDISK HANDLER | | 003A | 8C0E4E00 | 234 | | MOV | WORD PTR ORG_VECTOR+2,CS | | | | 003E | B86007 | 235 | | MOV | AX, OFFSET HD_INT | | ; HDISK INTERRUPT | | 0041 | A33400 | 236 | | MOV | WORD PTR HDISK_INT,AX | | | | 0044 | 8C0E3600 | 237 | | MOV | WORD PTR HDISK_INT+2,CS | | | | | C70664008601 | 238 | | MOV | WORD PTR BOOT_VEC,OFFSET | BOOT STRAP | ; BOOTSTRAP | | | 8C0E6600 | 239 | | MOV | WORD PTR BOOT_VEC+2,CS | | , | | | C7060401E703 | 240 | | MOV | WORD PTR HF_TBL_VEC,OFFS | FT FD TBI | ; PARAMETER TBL | | | 8C0E0601 | 241 | | MOV | WORD PTR HF_TBL_VEC+2,CS | | , , , , , , , , , , , , , , , , , , , , | | 005C | | 242 | | STI | NOND 1 11 11 _ 101_110 12,00 | | | | **** | | 243 | | 0.1 | | | | | | | 244 | | ASSIME | DS:DATA | | | | 0050 | B84000 | 245 | | MOV | | ; ESTABLISH SEGN | 4ENT | | 0060 | | 246 | | MOV | DS,AX | , LUINDLIGH SEG | iciii | | | C606740000 | 247 | | MOV | | RESET THE STAT | THE TARTESTON | | | C606750000 | 248 | | MOV | | ; ZERO COUNT OF | | | | C606430000 | 249 | | MOV | | | T VALUE IN BLOCK | | | | | | | | | | | 0071 | C606770000 | 250 | | MOV | PORT_OFF,0 | ; ZERO CARD OFFS | DE 1 | | 007/ | 802500 | 251 | | MOV | רע פנט | . DETRY COLLY | | | 0076 | B92500 | 252 | 14. | 1104 | CX,25H | ; RETRY COUNT | | | | | 253 | L4: | | | | | | | E8F200 | 254 | | CALL | | ; RESET CONTROLI | LER | | 007C | | 255 | | JNC | L7 | | | | 007E | | 256 | | LOOP | | ; TRY RESET AGA | IN | | | E9BF00 | 257 | | JMP | ERROR_EX | | | | 0083 | | 258 | L7: | | | | | | | B90100 | 259 | | MOV | CX,1 | | | | 0086 | BA8000 | 260 | | MOV | DX,80H | | | | | | 261 | | | | | | | | B80012 | 262 | | MOV | | ; CONTROLLER DIA | AGNOSTICS | | 008C | | 263 | | INT | 13H | | | | 008E | 7303 | 264 | | JHC | P7 | | | | | E9AF00 | 265 | | JMP | ERROR_EX | | | | 0093 | | 266 | P7: | | | | | | | B80014 | 267 | | MOV | | ; CONTROLLER DI | AGNOSTICS | | 0096 | | 268 | | INT | 13H | | | | 0098 | | 269 | | JNC | P9 | | | | | E9A500 | 270 | | JMP | ERROR_EX | | | | 009D | | 271 | P9: | | | | | | | C7066C000000 | 272 | | MOV | TIMER_LOW, 0 | ; ZERO TIMER | | | | A17200 | 273 | | MOV | AX,RESET_FLAG | | | | 00A6 | 303412 | 274 | | CMP | AX,1234H | ; KEYBOARD RESE | т | | 00A9 | 7506 | 275 | | JNE | P8 | | | | 00AB | C7066C009A01 | 276 | | MOV | TIMER_LOW,410D | ; SKIP WAIT ON | RESET | | 00B1 | | 277 | P8: | | | | | | 00B1 | E421 | 278 | | IN | AL,021H | ; TIMER | | | 00B3 | 24FE | 279 | | AND | AL, OFEH | ; ENABLE TIMER | | | 0085 | E621 | 280 | | OUT | 021H,AL | ; START TIMER | | | 00B7 | | 281 | P4: | | | | | | 00B7 | E8B400 | 282 | | CALL | HD_RESET_1 | ; RESET CONTROL | LER | | OOBA | 7207 | 283 | | JC | P10 | | | | OOBC | B80010 | 284 | | MOV | AX,1000H | ; READY | | | OOBF | CD13 | 285 | | INT | 13H | | | | 00C1 | 730B | 286 | | JNC | P2 | | | | 00C3 | | 287 | P10: | | | | | | 0003 | A16C00 | 288 | | MOV | AX,TIMER_LOW | | | | 0006 | 30BE01 | 289 | | CMP | AX,446D | ; 25 SECONDS | | | 0009 | | 290 | | JB | P4 | | | | | EB7590 | 291 | | JMP | ERROR_EX | | | | OOCE | | 292 | P2: | | - | | | | | B90100 | 293 | | MOV | CX,1 | | | | | BA8000 | 294 | | MOV | DX,80H | | | | • | -<br>- | 295 | | | ** | | | | pnn4 | B80011 | 296 | | MOV | AX,1100H | ; RECALIBRATE | | | 00D7 | | 297 | | INT | 13H | | | | 0007 | | 298 | | JC IN | ERROR EX | | | | 5009 | | 299 | | | an | | | | 0000 | B80009 | 300 | | MOV | AX,0900H | ; SET DRIVE PAR | AMETEDE | | 00DE | | | | | | , SEI DETAE PAR | ALL LEKS | | | | 301<br>302 | | INT<br>JC | 13H | | | | 00E0 | , 200 | | | Ju | ERROR_EX | | | | 0055 | Donne | 303 | | MOV | AX,0C800H | ; DMA TO BUFFER | | | 0062 | B800C8 | 304 | | .104 | AA, UCOUUN | , DIR TO BUFFER | | | LOC OBJ | LINE | SOURCE | | | |--------------------------------|------------|------------|--------------------|--------------------------------| | 00E5 8EC0 | 705 | MOV | FR 4V | | | 00E7 2BDB | 305 | | ES,AX | ; SET SEGMENT | | 00E9 B8000F | 306<br>307 | SUB | BX,BX<br>AX,0F00H | ; WRITE SECTOR BUFFER | | 00EC CD13 | 308 | INT | 13H | , WRITE SECTOR BUFFER | | 00EE 7252 | 309 | JC | ERROR_EX | | | 0000 7000 | 310 | 30 | EKKOK_EX | | | 00F0 FE067500 | 311 | INC | HF_NUM | ; DRIVE ZERO RESPONDED | | | 312 | 2.10 | | , share sand head and so | | 00F4 BA1302 | 313 | MOV | DX,213H | ; EXPANSION BOX | | 00F7 B000 | 314 | MOV | AL,0 | , | | 00F9 EE | 315 | OUT | DX,AL | ; TURN BOX OFF | | 00FA BA2103 | 316 | MOV | DX,321H | ; TEST IF CONTROLLER | | OOFD EC | 317 | IN | AL,DX | ; IS IN THE SYSTEM UNIT | | 00FE 240F | 318 | AND | AL,0FH | | | 0100 3C0F | 319 | CMP | AL,OFH | | | 0102 7406 | 320 | JE | BOX_ON | | | 0104 C7066C00A401 | 321 | MOV | TIMER_LOW,420D | ; CONTROLLER IS IN SYSTEM UNIT | | 010A | 322 | BOX_ON: | | | | 010A BA1302 | 323 | MOV | DX,213H | ; EXPANSION BOX | | 010D BOFF | 324 | MOV | AL,OFFH | | | 010F EE | 325 | OUT | DX,AL | ; TURN BOX ON | | | 326 | | | | | 0110 B90100 | 327 | MOV | CX,1 | ; ATTEMPT NEXT DRIVES | | 0113 BA8100 | 328 | MOV | DX,081H | | | 0116 | 329 | P3: | | | | 0116 2BC0 | 330 | SUB | AX,AX | ; RESET | | 0118 CD13 | 331 | INT | 13H | | | 011A 7240 | 332 | JC | POD_DONE | | | 011C B80011 | 333 | MOV | AX,01100H | ; RECAL | | 011F CD13 | 334 | INT | 13H | | | 0121 730B | 335 | JNC | P5 | | | 0123 A16C00 | 336 | MOV | AX, TIMER_LOW | | | 0126 3DBE01 | 337 | CMP | AX,446D | ; 25 SECONDS | | 0129 72EB | 338 | JB | P3 | | | 012B EB2F90 | 339 | JMP | POD_DONE | | | 012E | 340 | P5: | | | | 012E B80009 | 341 | MOV | AX,0900H | ; INITIALIZE CHARACTERISTICS | | 0131 CD13 | 342 | INT | 13H | | | 0133 7227 | 343 | JC | POD_DONE | | | 0135 FE067500<br>0139 81FA8100 | 344 | INC | HF_NUM | ; TALLY ANOTHER DRIVE | | | 345 | CMP | DX,(80H + S_MAX_FI | LE - 1) | | 013D 731D | 346<br>347 | JAE<br>INC | POD_DONE<br>DX | | | 013F 42 | | JMP | P3 | | | 0140 EBD4 | 348<br>349 | Jrip | rs | | | | 350 | ; POD ERR | OB | | | | 351 | ) POD ERR | OR . | | | 0142 | 352 | ERROR_EX: | | | | 0142 BD0F00 | 353 | MOV | BP,0FH | 3 POD ERROR FLAG | | 0145 2BC0 | 354 | SUB | AX,AX | , , | | 0147 8BF0 | 355 | MOV | SI,AX | | | 0149 B9060090 | 356 | MOV | CX,F17L | ; MESSAGE CHARACTER COUNT | | 014D B700 | 357 | MOV | BH,0 | ; PAGE ZERO | | 014F | 358 | OUT_CH: | | | | 014F 2E8A846801 | 359 | MOV | AL,CS:F17[SI] | ; GET BYTE | | 0154 B40E | 360 | MOV | AH,14D | ; VIDEO OUT | | 0156 CD10 | 361 | INT | 10H | ; DISPLAY CHARACTER | | 0158 46 | 362 | INC | SI | ; NEXT CHAR | | 0159 E2F4 | 363 | LOOP | OUT_CH | ; DO MORE | | 015B F9 | 364 | STC | - | | | 015C | 365 | POD_DONE: | | | | 015C FA | 366 | CLI | | | | 015D E421 | 367 | IN | AL,021H | ; BE SURE TIMER IS DISABLED | | 015F 0C01 | 368 | OR | AL,01H | | | 0161 E621 | 369 | OUT | 021H,AL | | | 0163 FB | 370 | STI | | | | 0164 E8A500 | 371 | CALL | DSBL | | | 0167 CB | 372 | RET | | | | | 373 | | | | | 0168 31373031 | 374 | F17 DB | '1701',0DH,0AH | | | 016C 0D | | | | | | 016D 0A | | | | | | 0006 | 375 | F17L EQU | \$-F17 | | | | 376 | | | | | 016E | 377 | HD_RESET_1 | PROC NEAR | | | 016E 51 | 378 | PUSH | CX | SAVE REGISTER | | 016F 52 | 379 | PUSH | DX | | ``` LOC OBJ LINE SOURCE 0170 F8 380 CLC ; CLEAR CARRY 0171 B90001 381 MOV : PETRY COUNT 0174 382 L6: 0174 E80706 383 CALL PORT 1 0177 FF 384 OUT DX,AL ; RESET CARD 0178 E80306 385 CALL PORT 1 017B EC 386 IN AL.DX ; CHECK STATUS 017C 2402 387 AND AL.2 ; ERROR BIT 017E 7403 188 JZ R3 0180 E2E2 389 LOOP L6 0182 F9 390 STC 391 0183 54 392 POP ; RESTORE REGISTER 0184 59 393 POP cx 0185 C3 394 PFT HD_RESET_1 395 FNDP 405 397 DISK_SETUP 398 :---- TNT 19 ----- 399 400 401 ; INTERRUPT 19 BOOT STRAP LOADER 402 403 ; - THE FIXED DISK BIOS REPLACES THE INTERRUPT 19 404 BOOT STRAP VECTOR WITH A POINTER TO THIS BOOT ROUTINE ; - RESET THE DEFAULT DISK AND DISKETTE PARAMETER VECTORS 406 : - THE BOOT BLOCK TO BE DEAD IN WILL BE ATTEMPTED FROM 407 CYLINDER 0 SECTOR 1 OF THE DEVICE. 408 ; - THE BOOTSTRAP SEQUENCE IS: > ATTEMPT TO LOAD FROM THE DISKETTE INTO THE BOOT 410 LOCATION (0000:7000) AND TRANSFER CONTROL THERE 411 > IF THE DISKETTE FAILS THE FIXED DISK IS TRIED FOR A 412 VALID BOOTSTRAP BLOCK. A VALID BOOT BLOCK ON THE FIXED DISK CONSISTS OF THE BYTES 055H 0AAH AS THE 413 LAST TWO BYTES OF THE BLOCK 414 415 1 > IF THE ABOVE FAILS CONTROL IS PASSED TO RESIDENT BASIC 416 417 418 0186 BOOT_STRAP: 419 420 ASSUME DS:DUMMY,ES:DUMMY 0186 2BC0 421 0188 8ED8 MOV DS,AX ; ESTABLISH SEGMENT 422 423 424 :---- RESET PARAMETER VECTORS 425 426 018B C7060401E703 427 WORD PTR HF_TBL_VEC, OFFSET FD_TBL 0191 8C0E0601 428 MOV WORD PTR HF_TBL_VEC+2, CS 0195 C70678000102 429 MOV WORD PTR DISKETTE PARM, OFFSET DISKETTE TBL 019B 8C0E7A00 MOV 430 WORD PTR DISKETTE_PARM+2, CS DIGE FR 431 STI 432 ;---- ATTEMPT BOOTSTRAP FROM DISKETTE 433 434 01A0 B90300 435 MOV CX.3 ; SET RETRY COUNT 01A3 ; IPL_SYSTEM 436 01A3 51 437 PUSH ; SAVE RETRY COUNT cx 0144 2802 438 SUB nx.nx : DRIVE ZERO ; RESET THE DISKETTE 01A6 2BC0 439 SUB AX,AX 01A8 CD13 440 INT 13H ; FILE IO CALL 01AA 720F 441 JC ; IF ERROR, TRY AGAIN H2 01AC B80102 MOV AX,0201H ; READ IN THE SINGLE SECTOR 442 443 01AF 2BD2 SUB 444 DX,DX 01B1 8EC2 MOV ; ESTABLISH SEGMENT 445 ES,DX 01B3 BB007C MOV BX, OFFSET BOOT_LOCK 446 447 MOV 01B6 B90100 448 ; SECTOR 1, TRACK 0 01B9 CD13 449 INT ; FILE IO CALL 13H H2: 01BB 59 450 POP CX : RECOVER RETRY COUNT 01BC 730A 451 JNC H4 ; CF SET BY UNSUCCESSFUL READ 01BE 80FC80 452 CMP AH,80H ; IF TIME OUT, NO RETRY 01C1 740A 453 JZ H5 ; TRY FIXED DISK ; DO IT FOR RETRY TIMES 01C3 E2DE LOOP 454 H1 01C5 EB0690 455 JMP H5 : UNABLE TO IPL FROM THE DISKETTE 0108 456 H4: ; IPL WAS SUCCESSFUL ``` | LOC ( | DBJ | LINE | SOURCE | | | | |-------|----------------|------|---------|-----------|---------------------------|---------------------------------------| | | | | | | | | | 0108 | EA007C0000 | 457 | | JMP | BOOT_LOCH | | | | | 458 | | | | | | | | 459 | ; | ATTEMPT | BOOTSTRAP FROM FIXED DISK | | | | | 460 | | | | | | OICD | | 461 | H5: | | | | | | 2BC0 | 462 | | SUB | AX,AX | ; RESET DISKETTE | | | 2802 | 463 | | SUB | DX,DX | , Keder brokerie | | | CD13 | 464 | | INT | 13H | | | | B90300 | 465 | | MOV | CX,3 | . OFT DETRY COUNT | | 0106 | D70300 | | | 1104 | CA,13 | ; SET RETRY COUNT | | | | 466 | H6: | | | ; IPL_SYSTEM | | 0106 | | 467 | | PUSH | cx | ; SAVE RETRY COUNT | | | BA8000 | 468 | | MOV | DX,0080H | ; FIXED DISK ZERO | | | 2BC0 | 469 | | SUB | AX,AX | ; RESET THE FIXED DISK | | OIDC | CD13 | 470 | | INT | 13H | ; FILE IO CALL | | OIDE | 7212 | 471 | | JC | H7 | ; IF ERROR, TRY AGAIN | | 01E0 | B80102 | 472 | | MOV | AX,0201H | ; READ IN THE SINGLE SECTOR | | 01E3 | 2B0B | 473 | | SUB | BX,BX | | | 01E5 | 8EC3 | 474 | | VOM | ES,BX | | | | BB007C | 475 | | MOV | BX,OFFSET BOOT_LOCK | ; TO THE BOOT LOCATION | | | BA8000 | 476 | | MOV | DX,80H | ; DRIVE NUMBER | | | B90100 | 477 | | MOV | | | | | CD13 | | | | CX,1 | ; SECTOR 1, TRACK 0 | | | | 478 | | INT | 13H | ; FILE IO CALL | | 01F2 | | 479 | H7: | POP | cx | ; RECOVER RETRY COUNT | | | 7208<br>A1557D | 480 | | JC | H8 | •• | | | A1FE7D | 481 | | MOV | AX,WORD PTR BOOT_LOCN+51 | | | | 3D55AA | 482 | | CMP | AX,0AA55H | ; TEST FOR GENERIC BOOT BLOCK | | 01FB | 74CB | 483 | | JZ | H4 | | | 01FD | | 484 | н8: | | | | | 01FD | E2D7 | 485 | | LOOP | H6 | ; DO IT FOR RETRY TIMES | | | | 486 | | | | | | | | 487 | ; | UNABLE | TO IPL FROM THE DISKETTE | OR FIXED DISK | | | | 488 | | | | | | 01FF | CD18 | 489 | | INT | 18H | ; RESIDENT BASIC | | | | 490 | | 2111 | 1011 | , Kesiseiii sasie | | 0201 | | 491 | DISKETT | F TD1 . | | | | 0201 | | | DISKELL | C_10L. | | | | | | 492 | | | | | | 0201 | | 493 | | DB | | ; SRT=C, HD UNLOAD=OF - 1ST SPEC BYTE | | 0202 | | 494 | | DB | 2 | ; HD LOAD=1, MODE=DMA - 2ND SPEC BYTE | | 0203 | | 495 | | DB | 25H | ; WAIT AFTER OPN TIL MOTOR OFF | | 0204 | | 496 | | DB | 2 | ; 512 BYTES PER SECTOR | | 0205 | 08 | 497 | | DB | 8 | ; EOT (LAST SECTOR ON TRACK) | | 0206 | 2A | 498 | | DB | HAS0 | ; GAP LENGTH | | 0207 | FF | 499 | | DB | OFFH | ; DTL | | 0208 | 50 | 500 | | DB | 050H | ; GAP LENGTH FOR FORMAT | | 0209 | F6 | 501 | | DB | 0F6H | ; FILL BYTE FOR FORMAT | | 020A | | 502 | | DB | 25 | HEAD SETTLE TIME (MILLISECONDS) | | 020B | | 503 | | DB | 4 | ; MOTOR START TIME (1/8 SECOND) | | 0000 | • • | 504 | | 00 | 7 | , HOTOR START TITLE (TYO SECOND) | | | | 505 | | MAKE CIE | E THAT ALL HOUSEKEEDING T | C DOME DECOME EVIT | | | | | , | TIANE SUR | E THAT ALL HOUSEKEEPING I | S DONE BEFORE EXTI | | | | 506 | | | | | | 050C | | 507 | DSBL | PROC | NEAR | | | | | 508 | | ASSUME | | | | 050C | | 509 | | PUSH | DS | ; SAVE SEGMENT | | | B84000 | 510 | | MOV | AX,DATA | | | 0210 | 8ED8 | 511 | | MOV | DS,AX | | | | | 512 | | | | | | 0212 | 8A267700 | 513 | | MOV | AH, PORT_OFF | | | 0216 | 50 | 514 | | PUSH | AX | ; SAVE OFFSET | | | | 515 | | | | | | 0217 | C606770000 | 516 | | MOV | PORT_OFF,OH | | | | E86905 | 517 | | CALL | PORT_3 | | | 021F | | 518 | | SUB | AL,AL | | | 0221 | | 519 | | OUT | DX,AL | , DECET TAIT /DMA MACV | | | | | | | PORT_OFF,4H | ; RESET INT/DMA MASK | | | C606770004 | 520 | | MOV | _ | | | | E85E05 | 521 | | CALL | PORT_3 | | | ASS0 | | 522 | | SUB | AL,AL | | | 0550 | | 523 | | OUT | DX,AL | ; RESET INT/DMA MASK | | | C606770008 | 524 | | MOV | PORT_OFF,8H | | | 0232 | E85305 | 525 | | CALL | PORT_3 | | | 0235 | 2ACO | 526 | | SUB | AL,AL | | | 0237 | EE | 527 | | OUT | | ; RESET INT/DMA MASK | | | C60677000C | 528 | | MOV | PORT_OFF,OCH | | | | E84805 | 529 | | CALL | PORT_3 | | | 0240 | | 530 | | SUB | AL,AL | | | 0242 | | 531 | | OUT | DX,AL | ; RESET INT/DMA MASK | | | B007 | 532 | | VOM | AL,07H | , and one intell | | | | | | | DMA+10,AL | ; SET DMA MODE TO DISABLE | | 0645 | E60A | 533 | | OUT | MINITARINA | , SE. DIM HODE TO DISABLE | | | | | | | | | ``` LOC OBJ LINE SOURCE 0247 FA 534 CLT ; DISABLE INTERRUPTS 0248 E421 535 A1 . 021H IN 0244 0020 E36 nα AL,020H 024C E621 537 OUT ; DISABLE INTERRUPT 5 021H,AL 538 STI ; ENABLE INTERRUPTS 024F 58 539 POP ; RESTORE OFFSET 0250 88267700 540 MOV PORT_OFF,AH 0254 1F 541 POP DS ; RESTORE SEGMENT 0255 C3 542 RET 543 DSBL FMDD 544 545 546 FIXED DISK BIOS ENTRY POINT 547 .----- 548 0256 549 DISK_IO PROC 550 ASSUME DS:NOTHING.ES:NOTHING 0256 80FA80 551 CMP D1 - 80H ; TEST FOR FIXED DISK DRIVE 0259 7305 552 JAF HARD_DISK ; YES, HANDLE HERE 025B CD40 553 ; DISKETTE HANDLER 0250 554 RET_2: 025D CA0200 555 RET ; BACK TO CALLER 0260 HARD_DISK: 556 557 ASSUME DS:DATA 0260 FB 558 STI : ENABLE INTERRUPTS 0261 0AE4 559 OR AH, AH 0263 7509 560 JNZ A3 : RESET NEC WHEN AH=0 0265 CD40 561 INT 404 0267 24F4 SUB AH,AH 562 0269 80FA81 563 CMP DL,(80H + S_MAX_FILE - 1) 026C 77EF 564 J. RET_2 026F 565 A3: 026E 80FC08 566 CMP AH,08 3 GET PARAMETERS IS A SPECIAL CASE 0271 7503 567 JNZ 0273 E91A01 568 JMP GET_PARM_N 42: 0276 569 0276 53 570 PHSH BY : SAVE DESISTEDS DURING OPERATION 0277 51 571 PUSH 0278 52 572 PUSH DΧ 0279 1E 573 PUSH DS 0274 06 574 PHISH FS 027B 56 575 PUSH SI 027C 57 576 PUSH 577 ; PERFORM THE OPERATION 027D F86400 DISK_IO_CONT 578 CALL 579 580 0281 E888FF DSBI ; BE SURE DISABLES OCCURRED 581 CALL 0284 884000 582 MOV AX.DATA 0287 8ED8 583 MOV DS,AX ; ESTABLISH SEGMENT 0289 58 584 POP MOV ; GET STATUS FROM OPERATION 028A 8A267400 585 AH,DISK_STATUS ; SET THE CARRY FLAG TO INDICATE 028E 80FC01 586 CMP AH 1 0291 F5 587 CMC ; SUCCESS OR FAILURE ; RESTORE REGISTERS 0292 SE 588 POP пT 0293 SF 590 POP ES 0294 07 0295 1F POP 591 ns 0296 5A 592 POP nх 0297 59 593 POP cx 0298 5B 594 POP BX 0299 CA0200 595 RET ; THROW AWAY SAVED FLACS 2 596 DISK_IO ENDP 597 ; FUNCTION TRANSFER TABLE 598 LABEL WORD 029C DISK_RESET ; 000H 0290 3803 599 DW RETURN_STATUS 029E 4D03 600 nω : 001H 02A0 5603 601 DW DISK_READ ; 002H 02A2 6003 602 DW DISK_WRITE ; 003H 02A4 6A03 nω DISK VERF ; 004H 603 02A6 7203 604 DM FMT_TRK : 005H ; 006H DW FMT_BAD 02A8 7903 605 0244 8003 606 DW FMT_DRV 0240 3003 DW BAD COMMAND ; 008H 607 02AE 2704 608 nω INIT DRV : 009H 02B0 CF04 609 DW RD_LONG ; 00AH 02B2 DD04 WR_LONG 610 ``` ``` LOC OBJ LINE SOURCE 02B4 F204 611 DISK_SEEK ; 00CH 0286 3803 DISK RESET 02B8 F904 RD BUFF 613 DW : 00FH 02BA 0705 614 - DW WR BUFF : 00FH 02BC 1505 615 DW TST_RDY 02BE 1005 616 HDISK_RECAL ; 011H 0200 2305 RAM_DIAG 617 пw : 012H 0202 2405 618 DШ CHK DRV ; 013H 02C4 3105 619 DW CNTLR_DIAG M1L EQU 620 621 SETUP_A PROC NEAR 622 623 02C6 C606740000 DISK STATUS,0 ; RESET THE STATUS INDICATOR 625 PUSH SAVE CX CX 626 627 ;---- CALCULATE THE PORT OFFSET 02CC BAEA CH,DL 629 MOV : SAVE DI DOCE ADDADE 630 nρ DL.1 02D1 FECA 631 DEC DL 02D3 D0E2 632 SHL ; GENERATE OFFSET PORT_OFF,DL 02D5 88167700 633 MOV : STORE DEESET MOV DL,CH 02D9 8AD5 634 : PESTORE DI 02DB 80E201 635 AND DL,1 636 02DE B105 ; SHIFT COUNT 637 MOV CL.5 02F0 D2F2 638 3 DRIVE NUMBER (0,1) 02F2 0AD6 639 OR DL,DH ; HEAD NUMBER 02E4 88164300 640 MOV CMD_BLOCK+1,DL 02E8 59 641 POP 02F9 C3 642 RET 643 SETUP_A ENDP 644 645 DISK_IO_CONT PROC NEAD 02FA 50 646 DUGH 02FB B84000 647 MOV AX,DATA 02EE 8ED8 MOV DS,AX ; ESTABLISH SEGMENT 649 POP AX 02F1 80FC01 650 CMP AH.01H ; RETURN STATUS JNZ 02F4 7503 651 02F6 EB5590 652 JMP RETURN_STATUS 02F9 653 02F9 80EA80 654 SUB DL,80H CONVERT DRIVE NUMBER TO 0 BASED PANGE 02FC 80FA08 655 CMP DL,MAX_FILE ; LEGAL DRIVE TEST 02FF 732F 656 BAD_COMMAND 657 0301 E8C2FF SETUP A 658 CALL 659 660 ;---- SET UP COMMAND BLOCK 661 0304 FEC9 662 DEC : SECTORS 0-16 FOR CONTROLLER 0306 C606420000 663 MOV CMD_BLOCK+0,0 030B 880E4400 MOV 664 CMD_BLOCK+2,CL ; SECTOR AND HIGH 2 BITS CYLINDER 030F 882F4500 665 MOV CMD_BLOCK+3,CH CYLINDER 0313 A24600 666 MOV CMD BLOCK+4.AL ; INTERLEAVE / BLOCK COUNT 0316 A07600 667 MOV AL, CONTROL_BYTE ; CONTROL BYTE (STEP OPTION) 0319 A24700 668 MOV CMD_BLOCK+5,AL 031C 50 669 PUSH ÀΧ : SAVE AX 031D 8AC4 670 MOV AL AH ; GET INTO LOW BYTE 031F 32E4 671 XOR AH,AH ; ZERO HIGH BYTE 0321 D1E0 672 ; *2 FOR TABLE LOOKUP 0323 8BF0 673 MOV SI,ÁX ; PUT INTO SI FOR BRANCH 0325 3D2A00 674 CMP AX,MIL : TEST WITHIN PANGE 0328 58 675 POP AX ; RESTORE AX 0329 7305 676 JNB BAD_COMMAND 032B 2EFFA49C02 WORD PTR CS:[SI + OFFSET M1] 0330 678 BAD COMMAND: 0330 C606740001 DISK_STATUS,BAD_CMD ; COMMAND ERROR 679 MOV 0335 B000 680 MOV 0337 C3 681 RET 682 DISK_IO_CONT ENDP 683 684 RESET THE DISK SYSTEM (AH = 000H) 686 687 ``` ``` LOC OBJ LINE SOURCE 0338 688 DISK_RESET PROC NEAR 0338 E84304 CALL PORT_1 689 ; RESET PORT 033B EE 690 OUT DX,AL PORT_1 ; ISSUE RESET 033C E83F04 691 CALL : CONTROLLED HADDWADE STATUS 033F EC AL,DX 692 IN ; GET STATUS 0340 2402 CINA 693 AL,2 ; ERROR BIT 0342 7406 694 JZ DR1 0344 C606740005 695 MOV DISK STATUS BAD RESET RET DR1: 0349 C3 696 INIT_DRV 034A E9DA00 698 ; SET THE DRIVE PARAMETERS JMP DISK_RESET 699 ENDP 700 702 ; DISK STATUS ROUTINE (AH = 001H) : 703 704 0340 RETURN_STATUS PROC NEAR AL,DISK_STATUS ; OBTAIN PREVIOUS STATUS DISK_STATUS,0 ; RESET STATUS 034D A07400 706 MOV 0350 C606740000 707 MOV 0355 C3 708 RFT 709 RETURN_STATUS ENDP 710 711 ; DISK READ ROUTINE (AH = 002H) 712 714 0356 715 DISK_READ PROC NEAR MOV AL,DMA_READ MOV CMD_BLOCK+0,READ_CMD JMP DMA_OPN ; MODE BYTE FOR DMA READ 0356 B047 716 0358 C606420008 717 035D E9E501 718 719 DISK READ ENDP 720 721 : DISK WRITE ROUTINE (AH = 003H) : 722 723 ..... 0360 DISK_WRITE PROC 725 NEAR MOV AL, DMA_WRITE 0360 B04B ; MODE BYTE FOR DMA WRITE 726 MOV CMD_BLOCK+0,WRITE_CMD JMP DMA_OPN RITE ENDP 0362 C60642000A 727 0367 E9DB01 728 DISK WRITE 729 730 731 732 DISK VERIFY (AH = 004H) 733 734 DISK_VERF PROC NEAR MOV CMD_BLOCK+0,CHK_TRK_CMD JMP NDMA_OPN 036A 735 036A C606420005 736 036F E9C401 737 738 DISK_VERF ENDP 730 740 FORMATTING (AH = 005H 006H 007H) 741 742 743 744 FMT_TRK PROC ; FORMAT TRACK (AH = 005H) 0372 C606420006 CMD_BLOCK,FMTTRK_CMD 0377 EB0C SHORT FMT_CONT 746 JMP 747 FMT_TRK ENDP 748 FMT_BAD PROC 749 NEAR ; FORMAT BAD TRACK (AH = 006H) 0379 C606420007 CMD_BLOCK,FMTBAD_CMD 037E EB05 SHORT FMT_CONT 751 JMP 752 FMT_BAD ENDP 753 0380 754 FMT_DRV PROC NEAR ; FORMAT DRIVE (AH = 007H) 0380 C606420004 CMD_BLOCK, FMTDRV_CMD 755 756 FMT_DRV ENDP 757 0385 758 FMT_CONT: 0385 A04400 MOV AL,CMD_BLOCK+2 ; ZERO OUT SECTOR FIELD 0388 2400 760 AND AL,11000000B MOV 0384 424400 761 CMD BLOCK+2.AL 038D E9A601 762 JMP NDMA_OPN ``` ``` LOC OBJ LINE SOURCE 764 765 GET PARAMETERS (AH = 8) 766 767 0290 768 GET_PARM_N 0390 769 PROC FAR GET DRIVE PARAMETERS GET_PARM 0390 1E PUSH 770 ns : SAVE DEGISTEDS 0391 06 771 PUSH ES 0392 53 772 PUSH 773 ASSUME DS: DUMMY 774 0393 2BC0 775 SUB AX+AX : ESTABLISH ADDRESSING 0395 8ED8 776 MOV DS,AX 0397 C41E0401 777 LES BX,HF TBL VEC 778 ASSUME DS:DATA 039B B84000 779 MOV AX, DATA 039E 8ED8 780 MOV DS,AX ; ESTABLISH SEGMENT 781 03A0 80EA80 SUB DL,80H 782 0343 ADEADA 783 CMD DL,MAX_FILE ; TEST WITHIN RANGE 03A6 732F 784 JAE 785 03A8 E81BFF 786 CALL SETUP A 787 034B FADEO3 788 CALL SW2_OFFS 03AE 7227 789 03B0 03D8 790 ADD BX,AX 791 03B2 268B07 792 MOV AX.FS:[BX] ; MAX NUMBER OF CYLINDERS 03B5 2D0200 793 ADJUST FOR 0-N 794 ; AND RESERVE LAST TRACK MOV DIRA BAFA 795 CH.AL . HIGH TWO BITS OF CYL 0384 250003 796 AND AX.0300H 03BD D1E8 797 SHR AX,1 03BF D1E8 798 AX,1 0301 0011 799 OΒ AL,011H ; SECTORS 03C3 8AC8 800 MOV CL,AL 801 ; HEADS MOV DH,ES:[BX][2] 03C5 268A7702 802 03C9 FECE DEC : 0-N RANGE 803 DL,HF_NUM 03CB 8A167500 804 MOV 03CF 2BC0 805 SUB AX.AX 806 65: 0301 0301 58 807 POP вх : RESTORE REGISTERS 0302 07 808 03D3 1F 809 POP ns 03D4 CA0200 810 RET 0307 811 03D7 C606740007 812 MOV DISK_STATUS, INIT_FAIL ; OPERATION FAILED 03DC B407 813 MOV AH, INIT FAIL 03DF 2AC0 SUB 814 AL . A1. 03E0 2BD2 815 SUB DX.DX 03E2 2BC9 816 CX,CX 03E4 F9 817 STC ; SET ERROR FLAG 03E5 EBEA AIA JMP 65 819 GET_PARM ENDP 820 821 ; INITIALIZE DRIVE CHARACTERISTICS 822 823 ; FIXED DISK PARAMETER TABLE 825 ; - THE TABLE IS COMPOSED OF A BLOCK DEFINED AS: 826 827 (1 WORD) - MAXIMUM NUMBER OF CYLINDERS (1 BYTE) - MAXIMUM NUMBER OF HEADS 829 (1 WORD) - STARTING REDUCED WRITE CURRENT CYL 830 (1 WORD) - STARTING WRITE PRECOMPENSATION CYL 831 (1 BYTE) - MAXIMUM ECC DATA BURST LENGTH 833 (1 BYTE) - CONTROL BYTE (DRIVE STEP OPTION) 834 ; BIT 7 DISABLE DISK-ACCESS RETRIES : 835 BIT 6 DISABLE ECC RETRIES BITS 5-3 ZERO 836 BITS 2-0 DRIVE OPTION 837 838 (1 BYTE) - STANDARD TIME OUT VALUE (SEE BELOW) : 839 (1 BYTE) - TIME OUT VALUE FOR FORMAT DRIVE (1 BYTE) - TIME OUT VALUE FOR CHECK DRIVE ``` (4 BYTES) 841 ``` LOC OBJ LINE SOURCE ``` ``` 842 - RESERVED FOR FUTURE USE 843 844 - TO DYNAMICALLY DEFINE A SET OF PARAMETERS 845 BUILD A TABLE OF VALUES AND PLACE THE 846 CORRESPONDING VECTOR INTO INTERRUPT 41. 848 NOTE: 849 THE DEFAULT TABLE IS VECTORED IN FOR 850 AN INTERRUPT 19H (BOOTSTRAP) 851 852 ; ON THE CARD SWITCH SETTINGS 853 854 855 DRIVE 0 DRIVE 1 856 A57 : -1- -2- / -3- -4- : ASA A59 860 861 862 863 TRANSLATION TABLE 864 1/3 : 2/4 : TABLE ENTRY 866 ON : ON : 0 867 868 ON : OFF : 869 OFF : ON : OFF : OFF : 870 871 872 03E7 874 FD TBL: ;---- DRIVE TYPE 00 876 877 03E7 3201 878 0306D 03E9 02 879 DB 03EA 3201 880 DΜ 0306D 03EC 0000 881 DW 00000 OSEE OR 882 DB овн 03EF 00 03F0 OC 884 DB ; STANDARD 0CH 03F1 B4 ; FORMAT DRIVE 885 DB 0B4H 03F2 28 886 DB 028H ; CHECK DRIVE 03F3 00000000 887 DB 888 ;---- DRIVE TYPE 01 889 890 03F7 7701 891 892 DB 03FA 7701 893 03750 nω 03FC 0000 894 DW 00000 O3FE OB 895 DB овн 03FF 05 0400 OC 897 DB ; STANDARD OCH 0401 B4 898 DB 0B4H ; FORMAT DRIVE 0402 28 899 DB 028H ; CHECK DRIVE 0403 00000000 900 DB 0,0,0,0 901 ;---- DRIVE TYPE 02 902 903 0407 3201 904 0409 06 905 DB 060 040A 8000 0128D 906 DW 040C 0001 907 DW 0256D 040E 0B 908 040F 05 05H 909 DB 0410 OC 910 DB OCH ; STANDARD 0411 B4 911 DB 0B4H ; FORMAT DRIVE 0412 28 912 DB 028H ; CHECK DRIVE 0413 00000000 913 DB 0,0,0,0 915 ;---- DRIVE TYPE 03 916 0417 3201 917 DΨ 03060 0419 04 918 DB ``` ``` LOC OBJ LINE SOURCE 041A 3201 919 0306D 041C 0000 920 041F 0B 921 DB овн 041F 05 922 DB 05H 0420 00 923 DB осн 3 STANDARD 0421 B4 924 0B4H ; FORMAT DRIVE 0422 28 925 0288 DB ; CHECK DRIVE 0423 00000000 026 DB 0,0,0,0 927 0427 928 INIT_DRV PROC NEAR 929 ;---- DO DRIVE ZERO 930 931 0427 C60642000C CMD BLOCK+0, INIT DRV CMD 042C C606430000 933 MOV CMD_BLOCK+1,0 0431 F81000 INIT_DRV_R 934 CALL 0434 7200 935 JC INIT_DRV_OUT ;---- DO DRIVE ONE 937 938 0436 C60642000C 939 MOV CMD_BLOCK+0,INIT_DRV_CMD 043B C606430020 MOV CMD_BLOCK+1,00100000B 0440 E80100 941 CALL INIT_DRV_R 0443 INIT_DRV_OUT: 942 0443 C3 943 RET 944 INIT_DRV 945 0444 946 INIT_DRV_R PROC NEAR 947 ASSUME ES:CODE 0444 2AC0 0446 E81901 949 COMMAND CALL : ISSUE THE COMMAND 0449 7301 950 INC R1 044B C3 951 RFT 044C 952 B1: 044C 1E 953 PUSH DS ; SAVE SEGMENT ASSUME DS:DUMMY 954 044D 2BC0 955 SUB AX.AX 044F 8ED8 956 MOV DS,AX ; ESTABLISH SEGMENT 0451 C41E0401 957 BX,HF_TBL_VEC 0455 1F 958 POP ; RESTORE SEGMENT DS 959 ASSUME DS:DATA 0456 E83403 960 CALL SW2_OFFS 0459 7257 961 JC 045B 03D8 962 ADD BX,AX 963 964 ;---- SEND DRIVE PARAMETERS MOST SIGNIFICANT BYTE FIRST 965 045D BF0100 966 MOV 0460 E85F00 967 INIT_DRV_S CALL 0463 724D 968 JC B3 969 0465 BF0000 970 DI,O 0468 E85700 971 CALL INIT_DRV_S 046B 7245 972 JC B3 973 046D BF0200 974 MOV 0470 E84F00 975 CALL INIT_DRV_S 0473 7230 976 JC B3 977 0475 BF0400 978 MOV 0478 E84700 CALL INIT DRV S 047B 7235 980 JC В3 981 047D BF0300 982 MOV 983 CALL INIT_DRV_S 0483 722D 984 JC B3 985 0485 BF0600 986 MOV DI,6 0488 E83700 987 CALL INIT_DRV_S 048B 7225 988 -IC R3 989 048D BF0500 990 MOV DI,5 991 CALL INIT_DRV S 0493 721D 992 JC В3 993 0495 BF0700 994 MOV DI,7 0498 E82700 995 CALL INIT_DRV_S ``` ``` LOC OBJ LINE SOURCE 049B 7215 996 JC 997 998 049D BF0800 MOV DI.8 ; DRIVE STEP OPTION AL,ES:[BX + DI] 0440 268401 999 MOV 04A3 A27600 1000 MOV CONTROL_BYTE,AL 1001 04A6 2BC9 1002 SUB CX,CX 1003 В5: 0448 0448 F8D302 1004 CALL PORT 1 04AB EC 1005 AL,DX 04AC A802 1006 TEST AL,R1_IOMODE ; STATUS INPUT MODE 044F 7509 1007 INZ R6 04B0 E2F6 1008 LOOP bЕ 04B2 1009 B3: 04B2 C606740007 DISK_STATUS, INIT_FAIL ; OPERATION FAILED 1010 04B7 F9 1011 STC 04B8 C3 1012 DET 1013 04B9 1014 04B9 E8B502 1015 CALL PORT_0 04BC EC 1016 IN AL,DX 04BD 2402 1017 AND AL,2 : MASK ERROR BIT 04BF 75F1 1018 JNZ 04C1 C3 1019 RET 1020 ASSUME ES: NOTHING INIT_DRV_R 1021 ENDP 1022 ;---- SEND THE BYTE OUT TO THE CONTROLLER 1023 1024 0402 INIT_DRV_S PROC NEAR 1025 04C2 E8C501 1026 CALL HD_WAIT_REQ 04C5 7207 1027 JC D1 04C7 E8A702 1028 CALL PORT_0 AL,ES:[BX + DI] 0404 268401 1029 MOV 04CD ÉE 1030 OUT DX,AL 04CE 1031 04CE C3 1032 RET INIT_DRV_S 1033 ENDP 1034 1035 1036 READ LONG (AH = OAH) 1037 1038 LONG PROC NEAR CALL CHK_LONG 04CF 1039 04CF E81900 1040 04D2 726B 1041 JC GB 04D4 C6064200F5 MOV 1042 CMD_BLOCK+0,RD_LONG_CMD 04D9 B047 1043 MOV AL,DMA_READ JMP SHORT DMA_OPN 04DB EB68 1044 1045 RD_LONG ENDP 1046 1047 1048 WRITE LONG (AH = OBH) : 1049 {------ 1050 0400 1051 PROC NEAR 04DD E80B00 CALL CHK_LONG 04E0 725D JC 1053 68 CMD_BLOCK+0,WR_LONG_CMD 04E2 C6064200E6 MOV 1054 NAF7 BNAB 1055 MOV AL,DMA_WRITE SHORT DMA_OPN 04E9 EB5A 1056 JMP ENDP 1057 WR_LONG 1058 04FB 1059 CHK_LONG PROC NEAR 04EB A04600 MOV AL,CMD_BLOCK+4 1060 04EE 3C80 CMP 1061 AL,080H 04F0 F5 1062 CMC 04F1 C3 1063 RET 1064 CHK_LONG ENDP 1065 1066 1067 SEEK (AH = OCH) 1068 ;----- 1069 PROC NEAR 04F2 1070 DISK_SEEK MOV CMD_BLOCK, SEEK_CMD JMP SHORT NDMA_OPN 04F2 C60642000B 1071 04F7 FB3D 1072 ``` ``` LOC OBJ LINE SOURCE 1073 DISK_SEEK ENDP 1074 1076 READ SECTOR BUFFER (AH = DEH) 1077 1078 04F9 RD_BUFF PROC NEAR 04F9 C60642000E MOV CMD_BLOCK+0,RD_BUFF_CMD CMD_BLOCK+4,1 1080 04FE C606460001 3 ONLY ONE BLOCK 1081 MOV 0503 B847 1082 MOV AL,DMA_READ JMP SHORT DMA_0 SHORT DMA_OPN 0505 EB3E 1083 RO_BUFF ENDP 1084 1085 1086 WRITE SECTOR BUFFER (AH = 0FH) : 1088 1089 0507 1090 WR_BUFF PROC NEAR 0507 C68642888F CMD_BLOCK+0,WR_BUFF_CMD MOV CMD_BLOCK+4,1 ; ONLY ONE BLOCK 050C C606460001 0511 B04B MOV AL, DMA_WRITE 1093 051% FR30 1094 JMP SHORT DMA_OPN 1095 WR_BUFF ENDP 1097 1098 TEST DISK READY (AH = 010H) 1099 TST_RDY PROC NEAR 1101 0515 C606420000 MOV CMD_BLOCK+0,TST_ JMP SHORT NDMA_OPN 1102 CMD_BLOCK+0,TST_RDY_CMD 051A EB1A 1103 TST_RDY ENDP 1104 1105 1106 ; RECALIBRATE (AH = 011H) 1107 1108 1109 1110 HDISK RECAL PROC NEAR MOV CMD_BLOCK,RECAL_CMD JMP SHORT NDMA_OPN HDISK_RECAL ENDP 051C C606420001 1111 0521 EB13 1112 1114 1115 1116 CONTROLLER RAM DIAGNOSTICS (AH = 012H) 1117 RAM_DIAG PROC NEAR MOV CHD_BLOCK+0.RAM_DIAG_CHD JMP SHORT NDMA_OPN RAM_DIAG ENDP 1118 RAM_DIAG 0523 1119 0523 C6064200E0 1120 0528 EB0C 1122 1123 1124 DRIVE DIAGNOSTICS (AH = 013H) : 1125 1126 CHK_DRV PROC NEAR 1128 0524 C6064200F3 MOV CMD_BLOCK+0,CHK_DRV_CMD JMP SHORT NDMA OPN 1129 052F EB05 1130 SHORT NDMA_OPN CHK_DRV ENDP 1132 1133 ; CONTROLLER INTERNAL DIAGNOSTICS (AH = 014H) : 1134 1135 1136 CNTLR_DIAG PROC NEAR MOV CMD_BLOCK+0,CNTLR_DIAG_CMD CNTLR_DIAG ENDP 0531 1137 0531 C6064200E4 1138 1140 1141 SUPPORT ROUTINES 1142 1144 9536 1145 NDMA_OPN: MOV AL,02H 0536 B002 1146 0538 E82700 CALL COMMAND ; ISSUE THE COMMAND JC G11 JMP SHORT G3 053B 7221 1148 1149 053D EB16 ``` ``` LINE SOURCE LOC OBJ 053F 053F C606740009 DISK STATUS, DMA BOUNDARY 1151 MOV 0544 C3 1152 DET 0545 1153 DMA_OPN: 0545 E85701 ; SET UP FOR DMA OPERATION 1154 CALL DMA_SETUP 0548 72F5 1155 JC 68 1156 0544 B003 MOV AL.O3H 054C F81300 1157 CALL COMMAND ; ISSUE THE COMMAND 054F 720D 1158 JC 0551 B003 1159 MOV AL,03H DMA+10,AL 0553 F60A 1160 : THITTALIZE THE DISK CHANNEL DUIT 1161 0555 0555 E421 1162 AL,021H 0557 24DF 1163 OHA AL, ODFH 0559 E621 1164 1165 OUT 021H.AL CALL WAIT_INT 055B E8AA01 055F 1166 055E E83B00 1167 CALL ERROR_CHK 0561 C3 1168 RFT 1169 1170 1171 ; COMMAND THIS POLITINE OUTPUTS THE COMMAND BLOCK 1172 2 1173 1174 AL = CONTROLLER DMA/INTERRUPT REGISTER MASK 1175 1176 ..... 1177 0562 1178 COMMAND PROC NEAR MOV 0562 BE4200 1179 SI,OFFSET CMD_BLOCK PORT_2 0565 E81B02 1180 CALL 0568 EE OUT 1181 DX AL CONTROLLER SELECT PULSE 0569 E81C02 1182 CALL PORT 3 OSAC FF 1183 DUT DX,AL 056D 2BC9 1184 SUB CX,CX ; WAIT COUNT 056F E80C02 1185 CALL PORT_1 0572 1186 WAIT_BUSY: 1187 IN 0572 FC AL, DX ; GET STATUS 0573 240F 1188 AND AL, OFH 0575 3C0D AL,R1_BUSY OR R1_BUS OR R1 REQ 1189 CMP 0577 7409 1190 JF C1 0579 F2F7 1191 LOOP WAIT_BUSY 057B C606740080 1192 MOV DISK_STATUS,TIME_OUT 1193 STC 0581 C3 1194 RFT 1 FREND PETURN 0582 1195 0582 FC 1196 CLD 0583 B90600 1197 MOV CX<sub>1</sub>6 : BYTE COUNT 1198 0586 E8E801 1199 CALL PORT 0 ; GET THE NEXT COMMAND BYTE 0589 AC 1200 LODSB : OUT IT GOES 058A EE 1201 OUT DY.AL 058B E2F9 1202 LOOP ; DO MORE 1203 PORT 1 1204 CALL STATUS 058D E8EE01 0590 EC 1205 IN AL, DX 0591 A801 1206 TEST AL,R1_REQ 0593 7406 1207 JZ CM7 0595 C606740020 MOV DISK STATUS, BAD CHTLR 1208 0594 F9 1209 STC 059B 1210 059B C3 1211 1212 COMMAND ENDP 1213 1214 1215 1216 ; BYTE 0 1217 ; BIT 7 ADDRESS VALID, WHEN SET ; BIT 6 SPARE, SET TO ZERO ; BITS 5-4 ERROR TYPE 1218 1219 1220 BITS 3-0 ERROR CODE 1221 1222 . 1223 ; BYTE 1 ; BITS 7-6 ZERO ; BIT 5 DRIVE (0-1) 1224 1225 BITS 4-0 HEAD NUMBER 1226 ``` ``` LOC OBJ LINE SOURCE 1227 t 1228 ; BYTE 2 ; BITS 7-5 CYLINDER HIGH 1230 BITS 4-0 SECTOR NUMBER 1231 1232 ; BYTE 3 1233 BITS 7-0 CYLINDER LOW 1235 1236 059C 1237 ERROR_CHK PROC NEAR 1238 ASSUME ES:DATA 059C A07400 ; CHECK IF THERE WAS AN ERROR 1239 MOV AL,DISK STATUS OSSE DACO ΩP 1240 A1 . A1 05A1 7501 1241 JNZ 621 05A3 C3 1242 1243 :---- PERFORM SENSE STATUS 1244 1245 05A4 1246 05A4 B84000 1247 AX, DATA 0547 8FC0 1248 MOV FS.AX : ESTABLISH SEGMENT 05A9 2BC0 1249 SUB AX,AX 05AB 8BF8 1250 MOV 05AD C606420003 MOV CMD_BLOCK+0,SENSE_CMD 1251 05B2 2AC0 1252 SUB A1 . A1 05B4 E8ABFF 1253 CALL COMMAND ; ISSUE SENSE STATUS COMMAND 05B7 7223 1254 JC SENSE_ABORT ; CANNOT RECOVER 05B9 B90400 1255 MOV CX.4 G22: 1256 1257 05BC 05BC E8CB00 CALL HD_WAIT_REQ 05BF 7220 05C1 E8AD01 1259 CALL PORT 0 05C4 EC 1260 IN AL DX ES:HD_ERROR[DI],AL ; STORE AWAY SENSE BYTES 05C5 26884542 1261 MOV 1262 05CA E8B101 1263 CALL PORT_1 1264 OSCD E2ED LOOP 622 05CF E8B800 1265 CALL HD_WAIT_REQ 1266 05D2 720D JC G24 05D4 E89A01 1267 CALL PORT_0 1268 05D7 EC IN AL, DX 1269 05D8 A802 TEST AL,2 05DA 740F 1270 JΖ STAT_ERR 05DC 1271 SENSE ABORT: 05DC C6067400FF 1272 MOV DISK STATUS, SENSE FAIL 05E1 1273 G24: 05E1 F9 1274 05E2 C3 1275 ERROR_CHK 1276 1277 TYPE_0 05E3 1A06 1278 T_0 TYPE_1 T_1 05F7 6A06 1280 T_2 DW TYPE_2 TYPE 3 05E9 7706 1281 T_3 DW 1282 STAT_ERR: 1283 ; GET ERROR BYTE 05EB 268A1E4200 1284 BL,ES:HD_ERROR 05F0 8AC3 1285 MOV AL, BL 05F2 240F 1286 AND AL, OFH ; ISOLATE TYPE BL,00110000B 05F4 80E330 1287 AND 05F7 2AFF 1288 SUB вн,вн 1289 05F9 B103 SHR BX,CL 1290 05FB D3EB WORD PTR CS:[BX + OFFSET T_0] 05FD 2EFFA7E305 1291 JMP ASSUME ES: NOTHING 1293 TYPEO_TABLE LABEL BYTE 1294 O,BAD_CNTLR,BAD_SEEK,BAD_CNTLR,TIME_OUT,O,BAD_CNTLR 0602 00204020800020 1295 DB 0609 0040 1296 DB 0,BAD_SEEK 1297 TYPEO_LEN EQU $-TYPE0_TABLE LABEL BYTE 0009 TYPE1_TABLE 060B 1298 BAD_ECC,BAD_ECC,BAD_ADDR_MARK,0,RECORD_NOT_FND 1299 DB DB BAD_SEEK,0,0,DATA_CORRECTED,BAD_TRACK 0610 400000110B 1301 TYPE1_LEN EQU $-TYPE1_TABLE 000A TYPE2_TABLE LABEL BYTE 1302 0615 DB BAD_CMD,BAD_ADDR_MARK 0615 0102 1303 ``` ``` LOC OBJ LINE SOURCE 0002 1304 TYPE2_LEN FOIL $-TYPE2_TABLE 0617 1305 TYPE3_TABLE LABEL BYTE 0617 202010 1306 DB BAD CHTLR, BAD CHTLR, BAD ECC 0003 1307 TYPE3 LEN FQU $-TYPE3 TABLE 1308 1309 ;---- TYPE 0 ERROR 1310 061A TYPE_0: 1311 0614 BB0206 MOV 1312 BX,OFFSET TYPEO_TABLE 061D 3C09 1313 CMP AL, TYPEO_LEN ; CHECK IF ERROR IS DEFINED 061F 7363 1314 JAE UNDER ERR L 0621 2ED7 1315 YLAT CS:TYPEO TABLE : TABLE LOOKUP 0623 427400 1316 MOV DISK_STATUS,AL ; SET ERROR CODE 0626 C3 1317 RFT 1318 1319 ;---- TYPE 1 ERROR 1320 0627 1321 TYPE_1: 0627 BB0B06 1322 MOV BX,OFFSET TYPE1 TABLE 062A 8BC8 1323 MOV CX.AX 062C 3C0A 1324 CMP AL, TYPE1 LEN : CHECK IF ERROR IS DEFINED 062F 7354 1325 JAE UNDEF_ERR_L 0630 2ED7 1326 CS:TYPE1_TABLE ; TABLE LOOKUP 0632 A27400 1327 MOV DISK STATUS, AL SET ERROR CODE 0635 80E108 1328 AND CL. DSH : CORRECTED FCC 0638 80F908 1329 CMP CL,08H 063B 752A 1330 JNZ G30 1331 :---- OBTAIN ECC ERROR BURST LENGTH 1332 1333 063D C60642000D 1334 MOV CMD_BLOCK+0,RD_ECC_CMD 0642 2AC0 1335 SUB AL, AL 0644 E81BFF COMMAND 1336 CALL 0647 721F 1337 ır G30 0649 E83E00 1338 CALL HD_WAIT_REQ 064C 7219 1339 JC 630 064E E82001 1340 PORT 0 CALL 1341 0652 8AC8 1342 MOV CL,AL 0654 F83300 1343 CALL HD WAIT REQ 0657 720E 1344 JC 630 0659 E81501 1345 CALL PORT_0 065C EC 1346 IN AL,DX 065D A801 1347 TEST AL.OIH 065F 7406 1348 JZ 630 0661 C606740020 1349 MOV DISK_STATUS, BAD_CHTLR 0666 F9 1350 STC 0667 630. 1351 0667 8401 1352 MOV AL,CL 0669 C3 1353 RET 1354 ;---- TYPE 2 ERROR 1355 1356 0664 1357 TYPE 2: 066A BB1506 1358 MOV BX,OFFSET TYPE2_TABLE 066D 3C02 1359 CMP AL, TYPE2_LEN ; CHECK IF ERROR IS DEFINED 066F 7313 UNDEF_ERR_L 1360 JAF 0671 2ED7 1361 XLAT CS:TYPE1_TABLE ; TABLE LOOKUP 0673 A27400 1362 MOV DISK_STATUS,AL ; SET ERROR CODE 0676 C3 1363 RET 1364 :---- TYPE 3 ERROR 1365 1366 1367 TYPE_3: 0677 BB1706 BX,OFFSET TYPE3_TABLE 1368 MOV 0674 3003 1369 CMD AL, TYPE3 LEN 067C 7306 1370 JAE UNDEF_ERR_L 067E 2FD7 1371 XLAT CS: TYPE3_TABLE 0680 A27400 DISK_STATUS,AL MOV 1372 0683 C3 1373 DFT 1374 UNDEF_ERR_L: 1375 0684 C6067400BB DISK STATUS, UNDEF ERR 1376 MOV 0689 C3 1377 RET 1378 1379 HD_WAIT_REQ PROC NEAR 068A 51 1380 PUSH CX ``` ``` LOC OBJ LINE SOURCE 068B 2BC9 SUB 1381 CX,CX 068D E8EE00 1382 CALL PORT_1 1383 L1: 06.90 0690 FC 1384 TN AL,DX 1385 0691 A801 TEST AL,R1_REQ 0693 7508 1386 JNZ 0695 F2F0 1387 LOOP 1.1 0697 C606740080 MOV DISK_STATUS, TIME_OUT 1389 L2: STC 069D 1390 0690 59 1391 POP СX 069E C3 1392 RET 1393 HD_WAIT_REQ ENDP 1394 1395 1396 ; DMA_SETUP 1397 THIS ROUTINE SETS UP FOR DMA OPERATIONS. ; INPLIT 1398 (AL) = MODE BYTE FOR THE DMA 1399 1400 (ES:BX) = ADDRESS TO READ/WRITE THE DATA 1401 : OUTPUT 1402 (AX) DESTROYED DMA SETUP PROC NEAR 069F 50 PUSH 1405 AX 0640 404600 1406 MOV AL,CMD_BLOCK+4 0643 3081 1407 CMP AL,81H ; BLOCK COUNT OUT OF RANGE 1408 POP AX 06A6 7202 1409 JB .11 STC 0648 F9 1410 06A9 C3 1411 RET 1412 J1: 06AA 51 1413 PUSH CX ; SAVE THE REGISTER NAAR FA 1414 CLI ; NO MORE INTERRUPTS 1415 DEAC FEDC DMA+12,AL OUT ; SET THE FIRST/LAST F/F 06AE 50 AX 1416 PUSH 06AF 58 1417 POP AX OUT 06B0 F60B 1418 DMA+11,AL ; OUTPUT THE MODE BYTE 06B2 8CC0 1419 MOV AX,ES ; GET THE ES VALUE 1420 MOV CL,4 ; SHIFT COUNT AX,CL 06B6 D3C0 1421 1422 ROL MOV ; ROTATE LEFT DARR RAFR CH.AL ; GET HIGHEST NYBBLE OF ES TO CH 1422 1423 1424 1425 1426 1427 J33: 1428 1429 1430 AND 06BA 24F0 AL, OF OH ; ZERO THE LOW NYBBLE FROM SEGMENT 06BC 03C3 ADD AX,BX ; TEST FOR CARRY FROM ADDITION 06BE 7302 JNC .133 OACO FECS INC CH ; CARRY MEANS HIGH 4 BITS MUST BE INC 0602 06C2 50 PUSH AX ; SAVE START ADDRESS 06C3 E606 OUT DMA+6,AL ; OUTPUT LOW ADDRESS 06C5 8AC4 MOV AL,AH 1431 06C7 E606 OUT DMA+6.AL ; OUTPUT HIGH ADDRESS 06C9 8AC5 1432 MOV AL,CH : GET HIGH 4 BITS 06CB 240F 1433 AL,OFH AND 06CD E682 1434 OUT DMA_HIGH,AL ; OUTPUT THE HIGH 4 BITS TO PAGE REG 1435 ;---- DETERMINE COUNT 1437 06CF A04600 1438 MOV AL,CMD_BLOCK+4 RECOVER BLOCK COUNT 06D2 D0E0 AL,1 1439 SHL ; MULTIPLY BY 512 BYTES PER SECTOR 06D4 FEC8 1440 DEC AL ; AND DECREMENT VALUE BY ONE 06D6 8AE0 1441 MOV AH,AL 06D8 BOFF AL, OFFH 1442 MOV 1443 ;---- HANDLE READ AND WRITE LONG (516D BYTE BLOCKS) 1445 06DA 50 1446 PUSH ; SAVE REGISTER 06DB A04200 1447 MOV AL,CMD_BLOCK+0 06DE 3CE5 1448 CMP AL.RD_LONG_CMD 06E0 7407 ADD4 1450 1451 CMP AL, WR_LONG_CMD 06E2 3CE6 06E4 7403 JE ADDA POP AX ; RESTORE REGISTER 1452 1453 1454 SHORT J20 06E7 EB11 ADD4; 06E9 1455 06E9 58 POP ΔX ; RESTORE REGISTER AX,516D 06EA B80402 1456 1457 MOV ; ONE BLOCK (512) PLUS 4 BYTES ECC 06ED 53 PUSH ``` ``` LOC OBJ LINE SOURCE OSEE 2AFF 1458 SUB BH.BH 06F0 841F4600 1459 MOV BL,CMD BLOCK+4 06F4 52 PUSH 1460 06F5 F7E3 1461 MUL вх : BLOCK COUNT TIMES 516 06F7 5A POP 1462 nx NAFA ER 1463 POP вх 06F9 48 1464 : ADJUST 1465 J20: 1466 DAFA ED 1467 PUSH ; SAVE COUNT VALUE 06FB E607 1468 DMA+7.AL ; LOW BYTE OF COUNT 06FD 8AC4 1469 MOV AI.AH 06FF F607 1470 OUT DMA+7.AL ; HIGH BYTE OF COUNT 0701 FB 1471 STI ; INTERRUPTS BACK ON 0702 59 1472 ; RECOVER COUNT VALUE 0703 58 1473 POP AX ; RECOVER ADDRESS VALUE 0704 0301 1474 ADD AX.CX ; ADD, TEST FOR 64K OVERFLOW 0706 59 1475 POP cx ; RECOVER REGISTER 0707 63 RET 1476 ; RETURN TO CALLER, CFL SET BY ABOVE IF ERROR 1477 DMA_SETUP ENDP 1478 1479 ------ 1480 ; WAIT_INT 1481 THIS ROUTINE WAITS FOR THE FIXED DISK 1482 CONTROLLED TO STENAL THAT AN INTERDURT . . 1483 HAS OCCURRED. 1484 0708 1485 WAIT_INT PROC NEAR 0708 FB 1486 STI : TURN ON THTERRUPTS 0709 53 1487 PUSH BX ; PRESERVE REGISTERS 070A 51 1488 PUSH CX 070B 06 1489 PUSH ES 070C 56 1490 PUSH SI PUSH 070D 1F 1401 DS 1492 ASSUME DS: DUMMY 070E 2BC0 1493 SUB AX,AX 0710 8ED8 1494 MOV DS.AX : FSTARLISH SEGMENT 0712 C4360401 1495 LES SI,HF_TBL_VEC 1496 ASSUME DS:DATA 0716 1F POP 1497 1498 ;---- SET TIMEOUT VALUES 1499 1500 0717 2AFF 1501 0719 268A5C09 BL, BYTE PTR ES:[SI][9] ; STANDARD TIME OUT 1502 MOV 071D 8A264200 1503 MOV AH, CMD BLOCK 0721 80FC04 1504 СМР AH, FMTDRV CMD 0724 7506 1505 JNZ W5 0726 268A5C0A 1506 MOV BL, BYTE PTR ES:[SI][OAH] ; FORMAT DRIVE 072A EB09 1507 JMP SHORT W4 072C 80FCE3 1508 W5: CMP AH,CHK_DRV_CMD 072F 7504 1509 JNZ 0731 268A5C0B 1510 MOV BL,BYTE PTR ES:[SI][OBH] ; CHECK DRIVE 0735 1511 0735 2BC9 1512 SUB cx.cx 1513 1514 :---- WAIT FOR INTERRUPT 1515 1516 0737 E84400 PORT 1 1517 CALL 0734 FC 1518 TN AL, DX 073B 2420 AND AL,020H 1519 073D 3C20 1520 CMP AL,020H ; DID INTERRUPT OCCUR 073F 740A 1521 JZ W2 0741 E2F4 1522 LOOP Wl : INNER LOOP 0743 4B DEC 1523 0744 75F1 1524 JNZ ; OUTER LOOP DISK_STATUS,TIME_OUT 0746 C606740080 1525 MOV 074B 1526 W2: 074B E82300 1527 CALL PORT_0 AL,DX 074E EC 1528 IN 074F 2402 1529 ΔHD ; ERROR BIT A1 . 2 0751 08067400 1530 OR DISK_STATUS,AL ; SAVE 0755 E83000 1531 CALL PORT_3 ; INTERRUPT MASK REGISTER 0758 3200 1532 XOR AL,AL ; ZERO 075A EE 1533 OUT DX.AL ; RESET MASK 075B 5F 1534 POP ST ; RESTORE REGISTERS ``` ``` LOC OBJ LINE SOURCE 1535 POP ES 075D 59 1536 POP CX 075E 5B 1537 POP 075F C3 1538 RET 1539 WAIT_INT ENDP 1540 1541 0760 HD_INT PROC NEAR 0760 50 1542 PUSH 0761 B020 1543 1544 MOV AL, EOI ; END OF INTERRUPT 0763 E620 OUT INT_CTL_PORT,AL 0765 B007 1545 1546 MOV AL,07H SET DMA MODE TO DISABLE 0767 E60A OUT DMA+10,AL AL,021H 076B 0C20 1548 1549 OR AL . 020H 076D E621 OUT 021H.AL n76F 58 1550 POP 0770 CF 1551 IRET 1552 HD_INT ENDP 1553 1554 1555 GENERATE PROPER PORT VALUE : 1556 1557 BASED ON THE PORT OFFSET 1558 1559 PORT_0 PROC NEAR 0771 1560 0771 BA2003 1561 MOV DX,HF_PORT ; BASE VALUE 0774 50 1562 PUSH 1563 0775 2AE4 SUB AH,AH 0777 A07700 AL, PORT_OFF 1564 1565 MOV : ADD IN THE OFFSET 077A 03D0 ADD DX,AX 077C 58 1566 POP 1567 RET 1568 PORT_0 ENDP 1569 077E 1570 PORT 1 PROC NEAR 1571 077E E8F0FF PORT_0 CALL 0781 42 1572 1573 INC DX ; INCREMENT TO PORT ONE 0782 C3 RET 1574 PORT_1 ENDP 1575 PORT_2 PROC 0783 NEAR 1576 1577 0783 E8F8FF CALL PORT_1 0786 42 1578 INC DX ; INCREMENT TO PORT TWO 1579 RET PORT_2 ENDP 1580 1581 0788 1582 PORT_3 PROC NEAR 0788 E8F8FF 1583 CALL PORT_2 1584 078B 42 INC DX ; INCREMENT TO PORT THREE 078C C3 1585 RET 1586 PORT_3 ENDP 1587 1588 1589 DETERMINE PARAMETER TABLE OFFSET USING CONTROLLER PORT TWO AND 1591 DRIVE NUMBER SPECIFIER (0-1) 1592 1593 1594 078D 1595 SW2_OFFS PROC NEAR CALL PORT_2 1596 1597 0790 EC ; READ PORT 2 IN AL, DX PUSH 1598 1599 0791 50 AX 159. 1600 0792 E8E9FF PORT_1 0795 EC 0796 2402 1601 DHA AL,2 ; CHECK FOR ERROR 1602 POP 0798 58 AX 1603 JNZ MOV SW2_OFFS_ERR 0799 7516 079B 8A264300 1605 1605 AH,CMD_BLOCK+1 079F 80E420 AND AH,00100000B ; DRIVE 0 OR 1 1606 JNZ 1607 SHR 1608 SHR 1609 SW2_AND: 1610 AND 1611 MOV JNZ SW2_AND 07A2 7504 07A4 D0E8 AL,1 ; ADJUST 07A8 AL,011B 07A8 2403 : ISOLATE 07AA B104 CL,4 ``` | LOC OBJ | LINE | SOURCE | | | |---------------------|------|---------------|------------|------------------| | 07AC D2E0 | 1612 | SHL | AL,CL | ; ADJUST | | 07AE 2AE4 | 1613 | SUB | AH, AH | | | 07B0 C3 | 1614 | RET | | | | 07B1 | 1615 | SW2_OFFS_ERR: | | | | 07B1 F9 | 1616 | STC | | | | 07B2 C3 | 1617 | RET | | | | | 1618 | SW2_OFFS | ENDP | | | | 1619 | | | | | 0783 30382F31362F38 | 1620 | DB | '08/16/82' | ; RELEASE MARKER | | 32 | | | | | | | 1621 | | | | | 07BB | 1622 | END_ADDRESS | LABEL BYTE | | | | 1623 | CODE ENDS | | | | | 1624 | END | | | | | | | | | ## **Notes:** Personal Computer Hardware Reference Library # Fixed Disk and Diskette Drive Adapter # **Contents** | Description | |---------------------------------| | Fixed Disk Function | | Task File | | Task File Registers | | Miscellaneous Information | | Diskette Function | | Diskette Controller 14 | | Diskette Controller Commands 16 | | Controller Commands 20 | | Command Status Registers | | Interfaces | | Interface Lines | | Logic Diagrams 41 | # **Notes:** # **Description** The IBM Personal Computer AT Fixed Disk and Diskette Drive Adapter connects to the system board using one of the system expansion slots. The adapter controls the 5-1/4 inch diskette drives and fixed disk drives. Connectors on the adapter supply all the signals necessary to operate up to two fixed drives and one diskette drive or one fixed drive and two diskette drives. The adapter will allow concurrent data operations on one diskette and one fixed disk drive. The adapter operates when connected to a system board expansion slot. This channel is described in the "System Board" section of the IBM Personal Computer AT *Technical Reference* Manual. ## **Fixed Disk Function** The fixed disk function features 512-byte sectors; high-speed, programmed input/output (PIO) data transfers; error correction code (ECC) correction of up to five bits on data fields; multiple sector operations across track and cylinder boundaries; and on-board diagnostic tests. The adapter will support two fixed disks with up to 16 read/write heads and 1024 cylinders. #### Task File A task file, which contains eight registers, controls fixed-disk operations. The following figure shows the addresses and functions of these registers. | I/O A | Address | | | | | | |---------|-----------|-----------------|------------------|--|--|--| | Primary | Secondary | Read | Write | | | | | 1F0 | 170 | Data Register | Data Register | | | | | 1F1 | 171 | Error Register | Write Precomp | | | | | 1F2 | 172 | Sector Count | Sector Count | | | | | 1F3 | 173 | Sector Number | Sector Number | | | | | 1F4 | 174 | Cylinder Low | Cylinder Low | | | | | 1F5 | 175 | Cylinder High | Cylinder High | | | | | 1F6 | 176 | Drive/Head | Drive/Head | | | | | 1F7 | 177 | Status Register | Command Register | | | | Task File ## Task File Registers #### **Data Register** The data register provides access to the sector buffer for read and write operations in the PIO mode. This register must not be accessed unless a Read or Write command is being executed. The register provides a 16-bit path into the sector buffer for normal Read and Write commands. When a R/W Long is issued, the 4 ECC bytes are transferred by byte with at least 2 microseconds between transfers. 'Data Request' (DRQ) must be active before the transferring of the ECC bytes. ### **Error Register** The error register is a read-only register that contains specific information related to the previous command. The data is valid only when the error bit in the status register is set, unless the adapter is in diagnostic mode. Diagnostic mode is the state immediately after power is switched on or after a Diagnose command. In these cases, the register must be checked regardless of the status register indicator. The following are bit values for the diagnostic mode. #### Diagnostic Mode - 01 No errors - 02 Controller error - 03 Sector buffer error - **04** ECC device error - **05** Control processor error The following are bit definitions for the operational mode. #### **Operational Mode** - Bit 0 Data Address Mark (DAM) Not Found—This bit indicates that DAM could not be found within 16 bytes of the ID field. - Bit 1 TR 000 Error—This bit will be set if, during a Restore command, the track 000 line from the fixed disk is not true within 1023 step pulses to the drive. - Bit 2 Aborted Command—A command is aborted based on the drive status (Write Fault, Not Seek Complete, Drive Not Ready, or an invalid command). The status and error registers may be decoded to determine the cause. - Bit 3 Not used. - Bit 4 ID Not Found—The ID field with the specified cylinder, head, and sector number could not be found. If retries are enabled, the controller attempts to read the ID 16 times before indicating the error. If retries are disabled, the track is scanned a maximum of two times before setting this error bit. - Bit 5 Not used - Bit 6 Data ECC Error—This bit indicates that an uncorrectable ECC error occurred in the target's data field during a read command. - Bit 7 Bad Block Detect—This bit indicates that the bad block mark was detected in the target's ID field. No Read or Write commands will be executed in any data fields marked bad. #### Write Precompensation Register The value in this register is the starting cylinder number divided by 4. The 'reduced write current' signal to the drive is activated and the adapter's write precompensation logic is turned on when this number is entered into the register. #### **Sector Count Register** The sector count register defines the number of sectors to be transferred during a Verify, Read, Write, or Format command. During a multi-sector operation, the sector count is decremented and the sector number is incremented. When the disk is being formatted, the number of sectors per track must be loaded into the register prior to each Format command. The adapter supports multi-sector transfers across track and cylinder boundaries. The drive characteristics must be set up by the Set Parameters command before initiating a multi-sector transfer. The sector count register must be loaded with the number of sectors to be transferred for any data-related command. **Note:** A 0 in the sector count register specifies a 256-sector transfer. #### **Sector Number Register** The target's logical sector number for Read, Write, and Verify commands is loaded into this register. The starting sector number is loaded into this register for multi-sector operations. #### **Cylinder Number Registers** The target number for Read, Write, Seek, and Verify commands is loaded into these registers as shown in the following figure. The cylinder-number registers address up to 1024 cylinders. | | Cylinder High | Cylinder Low | |---------------|----------------|--------------| | Register Bits | 76543210 | 76543210 | | Cylinder Bits | <del></del> 98 | 76543210 | #### **Cylinder Number Registers** #### **Drive/Head Register** Bit 7 Set to 1 Bit 6 Set to 0 Bit 5 Set to 1 Bit 4 Drive Select—This bit selects the drive. A 0 indicates the first fixed disk drive, and a 1 indicates the second. Bit 3-Bit 0 Head Select Bits—Bits 3 through 0 specify the desired read/write head. Bit 0 is the least-significant (0101 selects head 5). The adapter supports up to 16 read/write heads. For access to heads 8 through 15, bit 3 of the fixed disk register (address hex 3F6) must be set to 1. **Note:** This register must be loaded with the maximum number of heads for each drive before a Set Parameters command is issued. #### **Status Register** The controller sets up the status register with the command status after execution. The program must look at this register to determine the result of any operation. If the busy bit is set, no other bits are valid. A read of the status register clears interrupt #### August 31, 1984 request 14. If '-write fault' or 'error' is active, or if '-seek complete' or '-ready' is inactive, a multi-sector operation is aborted. The following defines the bits of the status register: | Busy—This bit indicates the controller's status. | |--------------------------------------------------------------| | A 1 indicates the controller is executing a | | command. If this bit is set, no other status | | register bit is valid, and the other registers reflect | | the status register's contents; therefore, the busy | | bit must be examined before any fixed disk register is read. | | | - Bit 6 Drive Ready—A 1 on this bit together with a 1 on seek complete bit (bit 4) indicates that the fixed disk drive is ready to read, write, or seek. A 0 indicates that read, write, and seek are inhibited. - Bit 5 Write Fault—A 1 on this bit indicates improper operation of the drive; read, write, or seek is inhibited. - Bit 4 Seek Complete—A 1 on this bit indicates that the read/write heads have completed a seek operation. - Bit 3 Data Request—This bit indicates that the sector buffer requires servicing during a Read or Write command. If either bit 7 (busy) or this bit is active, a command is being executed. Upon receipt of any command, this bit is reset. - Bit 2 Corrected Data—A 1 on this bit indicates that the data read from the disk was successfully corrected by the ECC algorithm. Soft errors will not end multi-sector operations. - Bit 1 Index—This bit is set to 1 each revolution of the #### Bit 0 Error—A 1 on this bit indicates that the previous command ended in an error, and that one or more bits are set in the error register. The next command from the controller resets the error bit. This bit, when set, halts multi-sector operations. #### **Command Register** The command register accepts eight commands to perform fixed disk operations. Commands are executed by loading the task file and writing in the command register while the controller status is not busy. If '-write fault' is active or if '-drive ready' or '-seek complete' are inactive, the controller will not execute any command. Any code not defined in the following figure causes an Aborted Command error. Interrupt request 14 is reset when any command is written. The following are acceptable commands to the command register. | Command | | Bit | s | | | | | | | | |----------------|---|-----|---|---|---|----|----|----|----|--| | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Restore | | 0 | 0 | 0 | 1 | R3 | R2 | R1 | R0 | | | Seek | | 0 | 1 | 1 | 1 | R3 | R2 | R1 | R0 | | | Read Sector | į | 0 | 0 | 1 | 0 | 0 | 0 | L | Т | | | Write Sector | | 0 | 0 | 1 | 1 | 0 | 0 | L | T | | | Format Track | | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | | | Read Verify | | 0 | 1 | 0 | 0 | 0 | 0 | 0 | T | | | Diagnose | | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | Set Parameters | | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | Valid Command-Register Commands **Note:** Stepping rate values and bit definitions for L and T are shown in the following figures. The following figure shows the stepping rate as defined by R3 through R0. | R3 | R2 | R1 | R0 | Stepping Rate | |----|----|----|-----|---------------| | 0 | 0 | 0 | 0 | 35 us | | 0 | 0 | 0 | 1 | 0.5 ms | | 0 | 0 | 1 | 0 | 1.0 ms | | 0 | 0 | 1 | 1 1 | 1.5 ms | | 0 | 1 | 0 | 0 | 2.0 ms | | 0 | 1 | 0 | 1 | 2.5 ms | | 0 | 1 | 1 | 0 | 3.0 ms | | 0 | 1 | 1 | 1 | 3.5 ms | | 1 | 0 | 0 | 0 | 4.0 ms | | 1 | 0 | 0 | 1 | 4.5 ms | | 1 | 0 | 1 | 0 | 5.0 ms | | 1 | 0 | 1 | 1. | 5.5 ms | | 1 | 1 | 0 | 0 | 6.0 ms | | 1 | 1 | 0 | 1 | 6.5 ms | | 1 | 1 | 1 | 0 | 7.0 ms | | 1 | 1 | 1 | 1 | 7.5 ms | #### **Stepping Rate** **Note:** After a Diagnose or Reset Command, the stepping rate is set to 7.5 milliseconds. The following figure shows the bit definitions for bits L and T. | Bit | Definition | 0 | 1 | |-----|------------|-----------------|----------------------| | L | Data Mode | Data Only | Data Plus 4 Byte ECC | | Т | Retry Mode | Retries Enabled | Retries Disabled | #### L and T Bit Definitions **Note:** When retries are disabled, ECC and ID field retries are limited to less than two complete revolutions. Following are descriptions of the valid command-register commands. **Restore:** The controller issues step pulses to the drive until the Track 000 indicator from the drive is active. If Track 000 is not active within 1023 steps the error bit in the status register is set and a Track 000 error is posted in the error register. The implied seek step rate can be set up using the stepping rate figure on the previous page. The restore step rate is established by the seek complete signal from the drive (each step pulse is issued after seek complete is asserted by the drive from the previous step). **Seek:** The Seek command moves the R/W heads to the cylinder specified in the task files. The adapter supports overlapped seeking on two drives or setup of the buffered seek stepping rate for the implied seek during a Read/Write command. An interrupt is generated at the completion of the command. Read Sector: A number of sectors (1–256) may be read from the fixed disk with or without the ECC field appended in the Programmed I/O (PIO) mode. If the heads are not over the target track, the controller issues step pulses to the drive and checks for the proper ID field before reading any data. The stepping rate used during the implied seek is the value specified during the previous Seek or Restore command. Data errors, up to 5 bits in length, are automatically corrected on Read Short commands. If an uncorrectable error occurs, the data transfer still takes place; however, a multi-sector read ends after the system reads the sector in error. Interrupts occur as each sector is ready to be read by the system. No interrupt is generated at the end of the command, after the last sector is read by the system. Write Sector: A number of sectors (1–256) may be written to the fixed disk with or without the ECC field appended in the PIO mode. The Write Sector command also supports implied seeks. Interrupts for the Write command occur before each sector is transferred to the buffer (except the first) and at the end of the command. The first sector may be written to the buffer immediately after the command has been sent, and '-data request' is active. Format Track: The track specified by the task file is formatted with ID and data fields according to the interleave table transferred to the buffer. The interleave table is composed of two bytes per sector as follows: 00, Physical Sector 1, 00, Physical Sector 2, ... 00, Physical Sector 17. The table for 2-to-1 interleave is: 00, 01, 00, 0A, 00, 02, 00, 0B, 00, 03, 00, 0C, 00, 04, 00, 0D, 00, 05, 00, 0E, 00, 06, 00, 0F, 00, 07, 00, 10, 00, 08, 00, 11, 00, 09. The data transfer must be 512 bytes even though the table may be only 34 bytes. The sector count register must be loaded with the number of sectors per track before each Format Track command. An interrupt is generated at the completion of the command; the Format Track command supports no error reporting. A bad block may be specified by replacing a 00 table entry with an 80. When switching between drives, a restore command must be executed prior to attempting a format. Preform the following when formatting a drive with more than 8 read/write heads: - 1. Restore - 2. Format all cylinders, heads 0 7 only - 3. Restore - 4. Format all cylinders, heads 8 and above. **Read Verify:** This command is similar to to a Read command except that no data is sent to the host. This allows the system to verify the integrity of the fixed disk drive. A single interrupt is generated upon completion of the command or in the event of an error. **Diagnose:** This command causes the adapter to execute its self-test code and return the results to the error register. An interrupt is generated at the completion of this command. **Set Parameters:** This command sets up the drive parameters (maximum number of heads and sectors per track). The drive/head register specifies the drive affected. The sector count and drive/head registers must be set up before this command is issued. The adapter uses the values specified for track and cylinder crossing during multi-sector operations. An interrupt is generated at the completion of this command. This command must be issued before any multi-sector operations are attempted. The adapter supports two fixed disk drives with different characteristics, as defined by this command. ## **Miscellaneous Information** The following is miscellaneous information about the fixed disk drive function. - The adapter performs normal read/write operations on a data field only after a successful match of that sector's ID with the targeted ID. - ID fields are checked for errors when read from the disk. - The adapter supports only ECC on data fields and only CRC on ID fields. The CRC polynomial is X16 + X12 + X5 + 1; the ECC polynomial is X32 + X28 + X26 + X19 + X17 + X10 + X6 + X2 + 1. All shift registers are preset to hex F before calculating the checksums, which begin with the respective address marks. # **Diskette Function** The 5-1/4 inch diskette drive function is an integral part of the Fixed Disk and Diskette Drive Adapter. One or two diskette drives are attached to the adapter through an internal, daisy-chained, flat cable. The attachment will support 160K.-, 320K.-, and 1.2M.-byte diskette drives. The address assignments for diskette functions are shown in the following figure. | I/O Address | | | | |-------------|-----------|------------------------|---------------------------| | Primary | Secondary | Read | Write | | 3F2 | 372 | - | Digital Output Register | | 3F4 | 374 | Main Status Register | Main Status Register | | 3F5 | 375 | Diskette Data Register | Diskette Data Register | | 3F6 | 376 | - | Fixed Disk Register | | 3F7 | 377 | Digital Input Register | Diskette Control Register | **Diskette Function** The adapter is designed for a double-density, MFM-coded, diskette drive and uses write precompensation with an analog circuit for clock and data recovery. The diskette-drive parameters are programmable, and the diskette drive's write-protect feature is supported. The adapter is buffered on the I/O bus and uses the system board's direct memory access (DMA) for record data transfers. An interrupt level also is used to indicate when an operation is complete and that a status condition requires microprocessor attention. #### Digital Output Register (hex 3F2) The digital output register (DOR) is an output-only register used to control drive motors, drive selection, and feature enable. The bit definitions follow: | Bit 7 | Reserved | |-------|------------------------------------------------------------------| | Bit 6 | Reserved | | Bit 5 | Drive B Motor Enable | | Bit 4 | Drive A Motor Enable | | Bit 3 | Enable Diskette Interrupts and DMA | | Bit 2 | Diskette Function Reset | | Bit 1 | Set to a logical 0 | | Bit 0 | Drive Select—A 0 on this bit indicates that drive A is selected. | Note: A channel reset clears all bits. ## **Digital Input Register (hex 3F7)** The digital input register is an 8-bit, read-only register used for diagnostic purposes. The following are bit definitions for this register: | Bit 7 | Diskette Change | |-------|-------------------------------------| | Bit 6 | Write Gate | | Bit 5 | Head Select 3/Reduced Write Current | | Bit 4 | Head Select 2 | | Bit 3 | Head Select 1 | | Bit 2 | Head Select 0 | | Bit 1 | Drive Select 1 | | Bit 0 | Drive Select 0 | **Note:** Bits 0 through 6 apply to the currently selected fixed disk drive. These bits are valid for 50 microseconds after a write to the Drive Head Register. ### **Data Rates** The diskette function will support three data rates: 250,000, 300,000 and 500,000 bits per second. ## **Diskette Controller** The diskette controller has two registers to which the system unit's microprocessor has access: a status register and a data register. The status register may only be read and is used to facilitate the transfer of data between the processor and diskette controller. The 8-bit status register has the status information about the diskette and may be accessed at any time. The 8-bit data register (hex 3F5), which actually consists of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, and parameters, and provides diskette-drive status information. Data bytes are read from or written to the data register in order to program or obtain results after a particular command. The bits in the status register (hex 34F) are defined as follows: | Bit 7 | Request for Master (RQM)— The data register is ready to send or receive data to or from the processor. | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 6 | Data Input/Output (DIO)—The direction of data transfer between the diskette controller and the processor. If this bit is a 1, transfer is from the diskette controller's data register to the processor; if it is a 0, the opposite is true. | | Bit 5 | Non-DMA Mode (NDM)—The diskette controller is in the non-DMA mode. | | Bit 4 | Diskette Controller Busy (CB)— A Read or Write command is being executed. | | Bit 3 | Reserved | | Bit 2 | Reserved | | Bit 1 | Diskette Drive B Busy (DBB)— Diskette drive B is in the seek mode. | | Bit 0 | Diskette Drive A Busy (DAB)— Diskette drive A is in the seek mode. | ## **Diskette Control Register (hex 3F7)** This register is assigned two addresses, hex 3F7 (primary) and hex 377 (secondary). This is a four bit write only register. The bits are defined as follows: Bits 7 - 2 Reserved Bits 2 - 0 Diskette Data Rate— These bits select the diskette data rate as shown in the following figure: | Bit 0 | Bit 1 | Diskette<br>Data Rate | |-------|-------|-----------------------| | 0 | 0 | 500,000 bps | | l 0 | 1 | 300,000 bps | | 1 | 0 | 250.000 bps | | 1 | 1 | Unused | **Diskette Data Rate** #### Fixed Disk Register (hex 3F6) This register is assigned two addresses, 3F6 (primary) and 376 (secondary). This is a four bit write only register. The bits are defined as follows: | Bits 7 - 4 | Reserved | |------------|-------------------------------------------------------------------------------| | Bit 3 | A logical 0 enables reduced write current. A logical 1 enables head select 3. | | Bit 2 | A logical 1 enables reset fixed disk function. | | Bit 1 | A logical 0 enables fixed disk interrupts. | | Bit 0 | Reserved | **Note:** Bit 3 defines the function of the fixed disk control interface connector (pin 2). #### **Diskette Controller Commands** The diskette controller can perform 16 different commands. Each command is initiated by a multibyte transfer from the processor, and the result after execution of the command may also be a multibyte transfer back to the processor. Because of this multibyte interchange of information between the diskette controller and the processor, each command can be considered to consist of three phases: **Command Phase:** The processor issues a sequence of Write commands to the diskette controller that direct the controller to perform a specific operation. **Execution Phase:** The diskette controller performs the specified operation. **Result Phase:** After completion of the operation, status and other housekeeping information is made available to the processor through a sequence of Read commands to the processor. The following is a list of commands that may be issued to the diskette controller: - Read Data - Read Deleted Data - Write Data - Write Deleted Data - Read a Track - Read ID - Format a Track - Scan Equal - Scan Low or Equal - Scan High or Equal - Recalibrate - Sense Interrupt Status - Specify - Sense Drive Status - Seek - Invalid. #### **Symbol Descriptions** The following are descriptions of the symbols used in the "Command Definitions" later in this section. - Address Line 0—A logical 0 selects the main status register, and a 1 selects the data register. - C Cylinder Number—Contains the current or selected cylinder number in binary notation. - **D** Data—Contains the data pattern to be written to a sector. - **D7-D0** Data Bus—An 8-bit data bus in which D7 is the most-significant bit and D0 is the least- significant. - **DTL** Data Length—When N is 00, DTL is the data length to be read from or written to a sector. - **EOT** End of Track—The final sector number on a cylinder. - GPL Gap Length—The length of gap 3 (spacing between sectors excluding the VCO synchronous field). - H Head Address—The head number, either 0 or 1, as specified in the ID field. - HD Head—The selected head number, 0 or 1. (H = HD in all command words.) #### August 31, 1984 - HLT Head Load Time—The head load time in the selected drive (2 to 256 milliseconds in 2- millisecond increments for the 1.2M-byte drive and 4 to 512 milliseconds in 4 millisecond increments for the 320K-byte drive). - HUT Head Unload Time—The head unload time after a read or write operation (0 to 240 milliseconds in 16-millisecond increments for the 1.2M-byte drive and 0 to 480 milliseconds in 32- millisecond increments for the 320K-byte drive. - MF FM or MFM Mode—A 0 selects FM mode and a 1 selects MFM (MFM is selected only if it is implemented.) - MT Multitrack—A 1 selects multitrack operation. (Both HD0 and HD1 will be read or written.) - N Number—The number of data bytes written in a sector. - NCN New Cylinder—The new cylinder number for a seek operation - ND Non-Data Mode— This indicates an operation in the non-data mode. - PCN Present Cylinder Number—The cylinder number at the completion of a Sense interrupt status command (present position of the head). - **R** Record—The sector number to be read or written. - **R/W** Read/Write—This stands for either a 'read' or 'write' signal. - SC Sector—The number of sectors per cylinder. - SK Skip—This stands for skip deleted-data address mark. SRT This 4 bit byte indicates the stepping rate for the diskette drive as follows: #### 1.2M-Byte Diskette Drive - 1111 1 millisecond - 1110 2 milliseconds - 1101 3 milliseconds #### 320K-Byte Diskette Drive - 1111 2 milliseconds - 1110 4 milliseconds - 1101 6 milliseconds - ST 0—ST 3 Status 0–Status 3—One of the four registers that stores status information after a command is executed. - STP Scan Test—If STP is 1, the data in contiguous sectors is compared with the data sent by the processor during a scan operation. If STP is 2, then alternate sections are read and compared. - **US0-US1** Unit Select—The selected driver number encoded the same as bits 0 and 1 of the digital output register (DOR). ## **Controller Commands** The following are commands that may be issued to the controller. **Note:** An X is used to indicate a don't-care condition. Commands not shown in binary format are shown as bytes. #### **Read Data** **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | MT | MF | SK | 0 | 0 | 1 | 1 | 0 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0 | Τ | | | | | | | | GP | L | | | | | | | | DT | L | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R #### **Read Deleted Data** **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | MT | MF | SK | 0 | 1 | 1 | 0 | 0 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0 | Τ | | | | | | | | GP | L | | | | | | | | DT | L | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 C H R #### Write Data **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----|----|----|----|----|----|-----|-----| | MT | MF | 0 | 0 | 0 | 1 | 0 | 1 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0 | T | | | | | | | | GP | L | | | | | | | | DT | L | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R N #### Write Deleted Data **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |----|-----|----|----|----|----|-----|-----|--| | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 | | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | | С | | | | | | | | Н | | | | | | | | | | R | | | | | | | | | | N | | | | | | | | | | EOT | | | | | | | | | | GPL | | | | | | | | | | | | DT | L | | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R #### Read a Track **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | 0 | MF | SK | 0 | 0 | 0 | 1 | 0 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0 | Τ | | | | | | | | GP | L | | | | | | | | DT | L | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R N #### Read ID **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | 0 | MF | 0 | 0 | 1 | 0 | 1 | 0 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | **Result Phase:** The following bytes are issued by the processor in the command phase: STO ST1 ST2 C H R #### Format a Track **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | 0 | MF | 0 | 0 | 1 | 1 | 0 | 0 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | N | | | | | | | | | S | С | | | | | | | | G | PL | | | | | | | | D | | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R ## Scan Equal **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|-----|----|----|-----|-----| | MT | MF | SK | 1 | 0 | 0 | 0 | 1 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0. | T | | | | | | | | GP | L | | | | | | | | ST | Р | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R ## Scan Low or Equal **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|-----|----|----|-----|-----| | MT | MF | SK | 1 | 1 | 0 | 0 | 1 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0. | Τ | | | | | | | | GPI | L | | | | | | | | STI | Р | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R ## Scan High or Equal **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | MT | MF | SK | 1 | 1 | 1 | 0 | 1 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | С | | | | | | | | | Н | | | | | | | | | R | | | | | | | | | N | | | | | | | | | E0 | T | | | | | | | | GP | L | | | | | | | | ST | Р | | | | **Result Phase:** The following bytes are issued by the controller in the result phase: STO ST1 ST2 C H R #### Recalibrate **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |----|----|----|----|----|----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | Χ | Χ | Χ | Χ | Χ | 0 | US1 | US0 | Result Phase: This command has no result phase. ## **Sense Interrupt Status** **Command Phase:** The following bytes are issued by the processor in the command phase: **Result Phase:** The following bytes are issued by the controller in the result phase: STO PCN ## **Specify** **Command Phase:** The following bytes are issued by the processor in the command phase: Result Phase: This command has no result phase. #### **Sense Driver Status** **Command Phase:** The following bytes are issued by the processor in the command phase: **Result Phase:** The following bytes are issued by the controller in the result phase: ST3 #### Seek **Command Phase:** The following bytes are issued by the processor in the command phase: | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|----|----|----|----|----|-----|-----| | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | Χ | Χ | Χ | Χ | Χ | HD | US1 | US0 | | | | | NC | N | | | | **Result Phase:** This command has no result phase. ## Invalid **Command Phase:** The following bytes are issued by the processor in the command phase: **Result Phase:** The following byte is issued by the controller in the result phase: ST0 # **Command Status Registers** The following is information about the command status registers ST0 through ST3. ## **Command Status Register 0 (ST0)** The following are bit definitions for command status register 0. #### Bit 7–Bit 6 Interrupt Code (IC) - 00 Normal Termination of Command (NT)—The command was completed and properly executed. - O1 Abrupt Termination of Command (AT)—The execution of the command was started but not successfully completed. - 10 Invalid Command Issue (IC)—The issued command was never started. - Abnormal termination because, during the execution of a command, the 'ready' signal from the diskette drive changed state. - Bit 5 Seek End (SE)—Set to 1 when the controller completes the Seek command. - Bit 4 Equipment Check (EC)—Set if a 'fault' signal is received from the diskette drive, or if the 'track-0' signal fails to occur after 77 step pulses (Recalibrate Command). - Bit 3 Not Ready (NR)—This flag is set when the diskette drive is in the not-ready state and a Read or Write command is issued. It is also set if a Read or Write command is issued to side 1 of a single-sided diskette drive. - Bit 2 Head Address (HD)—Indicates the state of the head at interrupt. Bit 1-Bit 0 Unit select 0 and 1 (US 0 and 1)—Indicate a drive's unit number at interrupt. The following figure shows the binary values to select each drive: | Bit 1 | Bit 0 | Drive<br>Selected | |-------|-------|-------------------| | 0 | 0 | Α | | ) o | 1 | В | | 1 | 0 | Unused | | 1 | 1 | Unused | Unit Selection #### **Command Status Register 1 (ST1)** The following are bit definitions for command status register 1. - Bit 7 End of Cylinder (EC)—Set when the controller tries to gain access to a sector beyond the final sector of a cylinder. - Bit 6 Not Used—Always 0. - Bit 5 Data Error (DE)—Set when the controller detects a CRC error in either the ID field or the data field. - Bit 4 Overrun (OR)—Set if the controller is not serviced by the main system within a certain time limit during data transfers. - Bit 3 Not Used—This bit is always set to 0. - Bit 2 No Data (ND)—Set if the controller cannot find the sector specified in the ID register during the execution of a Read Data, Write Deleted Data, or Scan Command. This flag is also set if the controller cannot read the ID field without an error during the execution of a Read ID command or if the starting sector cannot be found during the execution of a Read Cylinder command. Bit 1 Not Writable (NW)—Set if the controller detects a 'write-protect' signal from the diskette drive during execution of a Write Data, Write Deleted Data, or Format Cylinder command. Bit 0 Missing Address Mark (MA)—Set if the controller cannot detect the ID address mark. At the same time, the MD of status register 2 is set. #### **Command Status Register 2 (ST2)** - Bit 7 Not Used—Always 0. - Bit 6 Control Mark (CM)—This flag is set if the controller encounters a sector that has a deleted data-address mark during execution of a Read Data or Scan command. - Bit 5 Data Error in Data Field (DD)—Set if the controller detects an error in the data. - Bit 4 Wrong Cylinder (WC)—This flag is related to ND (no data) and when the contents of C on the medium are different from that stored in the ID register, this flag is set. - Bit 3 Scan Equal Hit (SH)—Set if the contiguous sector data equals the processor data during the execution of a Scan command. - Bit 2 Scan Not Satisfied (SN)—Set if the controller cannot find a sector on the cylinder that meets the condition during a Scan command. - Bit 1 Bad Cylinder (BC)—Related to ND; when the contents of C on the medium are different from that stored in the ID register, and the contents of C is FF, this flag is set. Bit 0 Missing Address Mark in Data Field (MD)—Set if the controller cannot find a data address mark or a deleted data address mark when data is read from the medium. #### **Command Status Register 3 (ST3)** The following are bit definitions for command status register 3. | Bit 7 | Fault (FT)—Status of the | 'fault' | signal from the | |-------|--------------------------|---------|-----------------| | | diskette drive. | | | | Bit 6 | Write Protect (WP)—Status of the | |-------|-------------------------------------------------| | | 'write-protect' signal from the diskette drive. | | Bit 5 | Ready (RY)—Status of the | 'ready' | signal from | |-------|--------------------------|---------|-------------| | | the diskette drive. | | | - Bit 2 Head Address (HD)—Status of the 'side-select' signal from the diskette drive. - Bit 1 Unit Select 1 (US 1)—Status of the 'unit-select-1' signal from the diskette drive. - Bit 0 Unit Select 0 (US 0)—Status of the 'unit select 0' signal from the diskette drive. ## **Interfaces** The system interface is through the I/O channel. The address, DMA, and interrupt assignments are shown in the following figures. | I/O Address | | | | |-------------|-----------|------------------------|---------------------------| | Primary | Secondary | Read | Write | | 3F2 | 372 | | Digital Output Register | | 3F4 | 374 | Main Status Register | Main Status Register | | 3F5 | 375 | Diskette Data Register | Diskette Data Register | | 3F6 | 376 | _ | Fixed Disk Register | | 3F7 | 377 | Digital Input Register | Diskette Control Register | #### **Diskette Function** **Note:** DMA request is level 2 and interrupt request is level 6. | I/O Address | | | | |-------------|-----------|---------------------|---------------------| | Primary | Secondary | Read | Write | | 1F0 | 170 | Data Register | Data Register | | 1F1 | 171 | Error Register | Write Precomp | | 1F2 | 172 | Sector Count | Sector Count | | 1F3 | 173 | Sector Number | Sector Number | | 1F4 | 174 | Cylinder Low | Cylinder Low | | 1F5 | 175 | Cylinder High | Cylinder High | | 1F6 | 176 | Drive/Head Register | Drive/Head Register | | 1F7 | 177 | Status Register | Command Register | #### **Fixed Disk Function** **Note:** Interrupt request is level 14. The following operations are supported by this adapter: - 16 bit programmed I/O (PIO), data transfers to the fixed disk. All other transfers are 8 bits wide. - The I/O addresses, recognized by the adapter for either the fixed disk or the diskette function, are independently selected by jumpers. # **Interface Lines** The interface to the fixed disk drive consists of the Control cable and the Data cable. The following figures show signals and pin assignments for these cables. **Note:** Connection is through a 2-by-17 Berg connector. Pin 15 is reserved to polarize the connector. August 31, 1984 38 Personal Computer AT Fixed Disk and Diskette Drive Adapter **Note:** Connection is through a 2-by-10 Berg connector. Pin 8 is reserved to polarize the connector. The interface to the diskette drives is a single cable that carries both data and control signals. The signals and pin assignments are as follows. **Note:** Connection is through a 2-by-17 Berg connector. Pin 5 is reserved to polarize the connector. August 31, 1984 40 Personal Computer AT Fixed Disk and Diskette Drive Adapter # August 31, 1984 Fixed Disk and Diskette Drive Adapter (Sheet 1 of 9) Fixed Disk and Diskette Drive Adapter (Sheet 2 of 9) Fixed Disk and Diskette Drive Adapter (Sheet 3 of 9) Fixed Disk and Diskette Drive Adapter (Sheet 4 of 9) Fixed Disk and Diskette Drive Adapter (Sheet 5 of 9) 46 Fixed Disk and Diskette Drive Adapter (Sheet 6 of 9) Fixed Disk and Diskette Drive Adapter (Sheet 7 of 9) August 31, 1984 Personal Computer AT Fixed Disk and Diskette Drive Adapter 47 48 (I) POWER FOR UI DERIVED FROM 78M05 REGULATOR DECOUPLE UI (CLOSE) TO NEAREST DIGITAL GROUND USING. IMF (AP (STANDARD) Fixed Disk and Diskette Drive Adapter (Sheet 8 of 9) DECOUPLE LEVI CLOSE TO DEVICE TO NEAREST GROUND DECOUPLE VCO CLOSE USING . INF BETWEEN PINS 16 AND 9. PIN 9 MUST BE CONNECTED TO CLOSEST DIGITAL GROUND #### -+ 12 V (SHT 8) R36 I20Ω IN VR2 OU 78 MO5 (SHT 8) VREG 2 I CIT +5V R56 2K ⊥ C50 Τ .ΙμΕ L2 4JMH +5VA RD/REF R20 | I MEG | ±1% IZOPF 74LS00 +5VB ⊒ C20 1μF CR 10 R39 4.75 KΩ 1% R33 ₹ RI8 1,21 K 1% 74574 RNG2 RNG1 C7 - JuF R17 475Ω ±1% CIO 470 PF 5% R40 5.62K 1% (3-84) FFDDATA RZI I MEG +5VB +5VB R32 430 R CI2 CR7 (3-86) VCOFB 7-60 PF GROUND PLANE C -FDCLK (SHT 4) 220Ω GROUND PLANE C (i) DECOUPLE VCO USING .I HF CAP FROM PIN 16 TO PIN 9. CONNECT PIN 9 TO CLOSEST DIGITAL GROUND. CONNECT PIN 8 TO ANALOG GND "C" Fixed Disk and Diskette Drive Adapter (Sheet 9 of 9) **Notes:** Personal Computer Hardware Reference Library # IBM Personal Computer 20MB Fixed Disk Drive Adapter ## **Notes:** ## **Contents** | Description | 1 | |----------------------------|------------------------------------------------------------------------------------------------------------| | Fixed Disk Controller | 1 | | Programming Considerations | 3 | | Types of Drives | 3 | | Status Register | 4 | | Sense Bytes | 4 | | Data Register | 7 | | Programming Summary 14 | 4 | | nterface | 5 | | Connectors | 7 | | Logic Diagrams | 9 | | BIOS Listing | 3 | | x Index- | 1 | | E C E | Fixed Disk Controller Programming Considerations Types of Drives Status Register Sense Bytes Data Register | ## **Notes:** #### **Description** The 20MB Fixed Disk Drive Adapter attaches to one or two fixed disk drive units through an internal, daisy-chained, flat cable (data/control cable). The adapter is buffered on the I/O bus and uses the system board's direct memory access (DMA) for fixed-disk-drive data transfers. When the adapter is enabled, an interrupt request occurs on the IRQ-5 line to the 8259A Interrupt Controller. The 8259A then causes an interrupt hex 0D. The Fixed Disk Drive Adapter provides automatic 11-bit burst error detection and correction in the form of 32-bit error checking and correction (ECC). The device level control for the Fixed Disk Adapter is contained on a ROM module on the adapter. A listing of this device level control can be found in "BIOS Listing" of this section. **Warning:** The last cylinder on the fixed disk drive is reserved for diagnostic use. The diagnostic write test will destroy any data on this cylinder. #### **Fixed Disk Controller** The disk controller has three registers that may be accessed by the system unit's microprocessor: a status register, a data register, and a read-option-jumpers register. The 8-bit status register contains the status information of the disk controller, and can be accessed at any time. This register is read-only and is used to help the transfer of data between the system unit's microprocessor and the disk controller. The 8-bit data register (actually consisting of several registers in a stack with only one register presented to the data bus) stores data, commands, and parameters, and provides the disk controller's status information. Data bytes are read from, or written to the data register in order to program or obtain the results after a particular command. The controller-select pulse is generated by writing to port address hex 322. The following is a block diagram of the IBM 20MB Fixed Disk Drive Adapter. #### **Programming Considerations** #### **Types of Drives** The fixed disk drive adapter will accommodate any two of four different types of drives. The figure below shows the configuration of the different type drives. | Туре | Cylinders | Heads | Start of<br>Write Pre-Comp | Landing<br>Zone | |------|-----------|-------|----------------------------|-----------------| | 1 | 306 | 4 | 0 | 306 | | 2 | 615 | 4 | 300 | 615 | | 13 | 306 | 8 | 128 | 336 | | 16 | 612 | 4 | 0 | 663 | #### **Fixed Disk Types** The figure below shows the switch settings for the above mentioned drive types. Switches 1 and 2 set the parameters of Drive 0, and switches 3 and 4 set Drive 1. | | Driv | /e 0 | Driv | /e 1 | | |---------|------|------|--------|------|--| | | Swit | tch | Switch | | | | | 1 | 2 | 3 | 4 | | | Type 1 | 0n | 0n | 0n | 0n | | | Type 2 | Off | 0n | Off | 0n | | | Type 13 | Off | 0ff | 0ff | Off | | | Type 16 | 0n | Off | 0n | 0ff | | #### **Status Register** At the end of all commands from the system board, the disk controller sends a completion status byte to the system board. This byte informs the system unit's microprocessor if an error occurred during the execution of the command. The following shows the format of this byte. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---|---|---|---|---|---|---|---| | | 0 | 0 | d | 0 | 0 | 0 | е | 0 | Bit 5 This bit shows the logical unit number of the drive. Bit 1 When set, this bit shows an error has occurred during command execution. Bits 7, 6, 4, 3, 2, 0 These bits are set to zero. If the interrupts are enabled, the controller sends an interrupt when it is ready to transfer the status byte. Busy from the disk controller is unasserted when the byte is transferred to complete the command. #### **Sense Bytes** If the status register receives an error (bit 1 set), the disk controller requests four bytes of sense data. The format for the four bytes is as follows: | Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------------|------|-----|---------------|---|-------|------|---| | Byte 0 | Address<br>Valid | 0 | Eri | ror Type | | Error | Code | | | Byte 1 | 0 | 0 | d | Head Number | | | | | | Byte 2 | Cylinder | High | | Sector Number | | | | | | Byte 3 | Cylinder Low | | | | | | | | Remarks: d = drive #### **Disk Controller Error Tables** The following disk controller error tables list the error types and error codes found in byte 0. The address-valid bit (bit 7) is only set when the previous command required a disk address. Bit 6 is set to 0 (spare). | | Err<br>T | or<br>ype | | ror | Cod | de | | |------|-----------|-----------|---|-----|-----|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 0 0 0 0 0 | | | 0 | 0 | The controller did not detect any error during the execution of the previous operation. | | | | 0 | 0 | 0 | 0 | 0 | 1 | The controller did not detect an index signal from the drive. | | | 0 | 0 | 0 | 0 | 1 | 0 | The controller did not get a seek-complete signal from the drive after a seek operation (for all non-buffered step seeks). | | | 0 | 0 | 0 | 0 | 1 | 1 | The controller detected a write fault from the drive during the last operation. | | | 0 | 0 | 0 | 1 | 0 | 0 | After the controller selected the drive, the drive did not respond with a ready signal. | | | 0 | 0 | 0 | 1 | 0 | 1 | Not Used. | | | 0 | 0 | 0 | 1 | 1 | 0 | After stepping the maximum number of cylinders, the controller did not receive the track 00 signal from the drive. | | | 0 | 0 | 0 | 1 | 1 | 1 | Not Used. | | | 0 | 0 | 1 | 0 | 0 | 0 | The drive is still seeking. This status is reported by the test Drive Ready command for an overlap seek condition when the drive had not completed the seek. No time-out is measured by the controller for the seek to complete. | | | | r<br>pe | | ror Code | | le | | | | |------|-------------|---------|-----|--------------------------------------------------------------------------------------------------------------------|---|----|--------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | | | 0 1 | | 0 1 | | 0 | 0 | 0 | 0 | ID Read Error: The controller detected an ECC error in the target ID field on the disk. | | | 0 1 0 0 0 1 | | 1 | Data Error: The controller detected an<br>uncorrectable ECC error in the target sector<br>during a read operation. | | | | | | | | 0 | 1 | 0 | 0 | 1 | 0 | Address Mark: The controller did not detect the target address mark (AM) on the disk. | | | | | 0 | 1 | 0 | 0 | 1 | 1 | Not Used. | | | | | 0 | 1 | 0 | 1 | 0 | 0 | Sector Not Found: The controller found the correct cylinder and head, but not the target sector. | | | | | 0 | 1 | 0 | 1 | 0 | 1 | Seek Error: The cylinder or head address<br>(either or both) did not compare with the<br>expected target address as a result<br>of a seek. | | | | | 0 | 1 | 0 | 1 | 1 | 0 | Not Used. | | | | | 0 | 1 | 0 | 1 | 1 | 1 | Not Used. | | | | | 0 | 1 | 1 | 0 | 0 | 0 | Correctable Data Error: The controller detected a correctable ECC error in the target field. | | | | | 0 | 1 | 1 | 0 | 0 | 1 | Bad Track: The controller detected a bad<br>track flag during the last operation. No<br>retries are attempted on this error. | | | | | Error<br>Type | | Error | | rror Code | | | |------|---------------|---|-------|---|-----------|---|--------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 1 | 0 | 0 | 0 | 0 | 0 | Invalid Command: The controller had received an invalid command from the system unit. | | | 1 | 0 | 0 | 0 | 0 | 1 | Illegal Disk Address: The controller detected an address that is beyond the maximum range. | | | Erro<br>Ty | r<br>pe | Er | ror | Co | de | | |------|------------|---------|----|-----|----|----|-------------------------------------------------------------------------------------------------------------------------------------| | Bits | 5 | 4 | 3 | 2 | 1 | 0 | Description | | | 1 | 1 | 0 | 0 | 0 | 0 | RAM Error: the controller detected a data<br>error during the RAM sector-buffer<br>diagnostic test. | | | 1 | 1 | 0 | 0 | 0 | 1 | Program Memory Checksum Error: During<br>this internal diagnostic test, the controller<br>detected a program-memory checksum error. | | | 1 | 1 | 0 | 0 | 1 | 0 | ECC Polynomial Error: During the controller's internal diagnostic tests, the hardware ECC generator failed its test. | #### **Data Register** The system unit's microprocessor specifies the operation by sending the 6-byte device control block (DCB) to the controller. The figure below shows the format of the DCB, and defines the bytes that make up the DCB. | Bits | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |--------|----------|---------------------------|-------|---------------|-------|-------|---|---|--|--|--| | Byte 5 | i | Con | trol | Field | | | | | | | | | Byte 4 | l r | Interleave or Block Count | | | | | | | | | | | Byte 3 | | Cyl | inder | Low | | | | | | | | | Byte 2 | Cylinder | High | | Sector Number | | | | | | | | | Byte 1 | 0 | 0 | d | Н | ead N | umber | | | | | | | Byte 0 | | mmand<br>lass | | | 0 | pcode | | | | | | - Byte 5 Bits 7 through 0 contain the control field. - Byte 4 Bits 7 through 0 specify the interleave or block count. - Byte 3 Bits 7 through 0 are the eight least-significant bits of the cylinder number. - Bits 7 and 6 are the two most significant bits of the cylinder number. Bits 0 through 5 define the sector number. - Byte 1 Bit 5 identifies the drive number. Bits 4 through 0 contain the disk head number to be selected. Bits 6 and 7 are not used. - Byte 0 Bits 7, 6, and 5 identify the class of the command. Bits 4 through 0 contain the Opcode (see command byte on page 10 #### **Control Byte** Byte 5 is the control field of the DCB and allows the user to select options for several types of disk drives. The format of this byte is as follows: | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---|---|---|---|---|---|---|---| | | r | a | 0 | 0 | 0 | S | S | S | - Bit 7 Disables the four retries by the controller on all disk-access commands. Set this bit only during the evaluation of the performance of a disk drive. - Bit 6 If set to 0 during read commands, a reread is attempted when an ECC error occurs. If no error occurs during reread, the command will finish without an error status. If this bit is set to 1, no reread is attempted. - Bits 5, 4, 3 Set to 0. Bits 2, 1, 0 These bits define the type of drive and select the step option. See the following figure. | Bits 2, | 1, | 0 | | |---------|----|---|----------------------------------------------------------------------| | 0 | 0 | 0 | This drive is not specified and defaults to 3 milliseconds per step. | | 0 | 0 | 1 | N/A | | 0 | 1 | 0 | N/A | | 0 | 1 | 1 | N/A | | 1 | 0 | 0 | 200 microseconds per step. | | 1 | 0 | 1 | 70 microseconds per step (specified by BIOS). | | 1 | 1 | 0 | 3 milliseconds per step. | | 1 | 1 | 1 | 3 milliseconds per step. | ## **Command Byte** | Command | Data Cor | ntrol Block | Remarks | |-------------------------------------|----------|------------------|----------------------------------------------------------------| | T . D . | D | 7 ( 5 + 2 0 1 0 | | | Test Drive | Bit | 76543210 | d = drive (0 or 1) | | Ready | Byte 0 | 00000000 | x = don't care | | (Class 0,<br>Opcode 00) | Byte 1 | 0 0 d x x x x x | Bytes 2, 3, 4,<br>5, = don't care. | | Recalibrate | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | (Class 0,<br>Opcode 00) | Byte 0 | 00000001 | x = don't care | | opcode ou) | Byte 1 | 0 0 d x x x x x | r = retries | | | Byte 5 | r 0 0 0 0 s s s | s = Step Option Bytes 2, 3, 4, = don't care ch = cylinder high | | Reserved<br>(Class 0,<br>Opcode 02) | | | This Opcode is not used. | | Request Sense | Bit | 76543210 | d = drive (0 or 1) | | Status | Byte 0 | 00000011 | x = don't care | | (Class 0,<br>Opcode 03) | Byte 1 | 0 0 d x x x x x | Bytes 2, 3, 4,<br>5, = don't care. | | Format Drive | Bit | 76543210 | d = drive (0 or 1) | | (Class 0,<br>Opcode 04) | Byte 0 | 00000100 | r = retries | | Opcode 04) | Byte 1 | 0 0 d Head No. | s = Step Option | | | Byte 2 | ch 000000 | ch = cylinder high | | | Byte 3 | Cylinder Low | | | } | Byte 4 | 0 0 0 Interleave | Interleave 1 to 16 | | | Byte 5 | r 0 0 0 0 s s s | for 512-byte sectors. | | Ready Verify | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | (Class 0, | Byte 0 | 00000101 | r = retries | | Opcode 05) | Byte 1 | 0 0 d Head No. | s = Step Option | | | Byte 2 | ch Sector No. | a = retry option on | | | Byte 3 | Cylinder Low | data ECC | | | Byte 4 | Block Count | ch = cylinder high | | | Byte 5 | r a 0 0 0 s s s | for 512-byte sectors. | | <u> </u> | | | <u> </u> | | Command | Data Cor | ntrol Block | Remarks | |-------------------------------------|----------|-----------------------------------------|--------------------------| | | | | (-) | | Format Track | Bit | 76543210 | d = drive (0 or 1) | | (Class 0, Opcode 06) | Byte 0 | 00000110 | r = retries | | opcode od) | Byte 1 | 0 0 d Head No. | s = step option | | | Byte 2 | ch 000000 | ch = cylinder high | | | Byte 3 | Cylinder Low | | | | Byte 4 | 0 0 0 Interleave | Interleave 1 to 16 | | | Byte 5 | r 0 0 0 0 s s s | for 512-byte sectors. | | Format Bad | Bit | 76543210 | d = drive (0 or 1) | | Track<br>(Class 0, | Byte 0 | 00000111 | x = don't care | | Opcode 07) | <u> </u> | 0 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 | | | | Byte 1 | <u> </u> | s = Step Option | | | Byte 2 | ch 0 0 0 0 0 0 | ch = cylinder high | | | Byte 3 | Cylinder Low | | | 1 | Byte 4 | 0 0 0 Interleave | Interleave 1 to 16 | | | Byte 5 | r 0 0 0 0 s s s | for 512-byte sectors. | | Read<br>(Class 0, | Bit | 7 6 5 4 3 2 1 0 | d = drive (0 or 1) | | Opcode 08) | Byte 0 | 00001000 | r = retries | | | Byte 1 | 0 0 d Head No. | a = retry option on | | 1 | Byte 2 | ch Sector No. | data ECC error | | | Byte 3 | Cylinder Low | s = step option | | | Byte 5 | ra000sss | ch = cylinder high | | Reserved<br>(Class 0,<br>Opcode 09) | | | This Opcode is not used. | | Write | Bit | 76543210 | d = drive (0 or 1) | | (Class 0,<br>Opcode OA) | Byte 0 | 00001010 | r = retries | | | Byte 1 | 0 0 d Head No. | s = step option | | | Byte 2 | ch Sector No. | ch = cylinder high | | | Byte 3 | Cylinder Low | | | | Byte 4 | Block Count | | | | Byte 5 | r 0 0 0 0 s s s | | | L | | | | | Command | Data Cor | ntrol Block | Remarks | |---------------------------------------------------------------|--------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------| | Seek<br>(Class 0,<br>Opcode OB) | Bit Byte 0 Byte 1 Byte 2 | 7 6 5 4 3 2 1 0 0 0 0 0 1 0 1 1 0 0 d Head No. ch 0 0 0 0 0 0 | <pre>d = drive (0 or 1) r = retries s = Step Option x = don't care</pre> | | | Byte 3 Byte 4 Byte 5 | Cylinder Low x x x x x x x x x r 0 0 0 0 s s s | | | Initialize Drive Character- istics* (Class 0, Opcode OC) | Bit<br>Byte 0 | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | Read ECC<br>Burst Length<br>(Class O,<br>Opcode OD) | Bit<br>Byte O | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | Read Data<br>from Sector<br>Buffer<br>(Class O,<br>Opcode OE) | Bit<br>Byte 0 | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | Write Data to<br>Sector Buffer<br>(Class O,<br>Opcode OF) | Bit<br>Byte O | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | RAM<br>Diagnostic<br>(Class 7,<br>Opcode 00) | Bit<br>Byte O | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | Reserved<br>(Class 7,<br>Opcode 01)<br>Reserved<br>(Class 7, | | | This Opcode is not used. This Opcode is not used. | | Opcode 02) | | | | <sup>\*</sup>Initialize Drive Characteristics: The DBC must be followed by eight additional bytes. ``` Maximum number of cylinders Maximum number of heads (2 bytes) (1 byte) Start reduced write current cylinder (2 bytes) Start write precompensation cylinder (2 bytes) Maximum ECC data burst length (1 byte) ``` | Command | Data Cor | ntrol Block | Remarks | |------------------------------------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------| | Drive<br>Diagnostic<br>(Class 7,<br>Opcode 03) | Bit Byte 0 Byte 1 Byte 2 | 7 6 5 4 3 2 1 0 1 1 1 0 0 0 1 1 0 0 d x x x x x | <pre>d = drive (0 or 1) r = retries s = step option x = don't care</pre> | | | Byte 3 Byte 4 Byte 5 | x x x x x x x x x x x x x x x x x x x | X - doil t care | | Controller<br>Internal<br>Diagnostics<br>(Class 7,<br>Opcode 04) | Bit<br>Byte O | 7 6 5 4 3 2 1 0 | Bytes 1, 2, 3, 4, 5, = don't care. | | Read Long *<br>Track<br>(Class 7,<br>Opcode 05) | Bit Byte 0 Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 | 7 6 5 4 3 2 1 0 1 1 1 0 0 1 0 1 0 0 d Head No. ch Sector No. Cylinder Low Block Count r 0 0 0 0 s s s | <pre>d = drive (0 or 1) r = retries s = step option ch = cylinder high</pre> | | Write Long **<br>(Class 7,<br>Opcode 06) | Bit Byte 0 Byte 1 Byte 2 Byte 3 Byte 4 Byte 5 | 7 6 5 4 3 2 1 0 1 1 1 0 0 1 1 0 0 0 d Head No. ch Sector No. Cylinder Low Block Count r 0 0 0 0 s s s | <pre>d = drive (0 or 1) s = step option s = step option ch = cylinder high s = step option</pre> | <sup>\*</sup> Returns 512 bytes plus 4 bytes of ECC data per sector. \*\* Requires 512 bytes plus 4 bytes of ECC data per sector. #### **Programming Summary** The two least-significant bits of the address bus are sent to the system board's I/O port decoder, which has two sections. One section is enabled by the I/O read signal (-IOR) and the other by the I/O write signal (-IOW). The result is a total of four read/write ports assigned to the disk controller board. The address enable signal (AEN) is asserted by the system board when DMA is controlling data transfer. When AEN is active, the I/O port decoder is disabled. The following figure is a table of the read/write ports. | R/W | Port Address | Function | |---------------|--------------|-------------------------------------------------------------------------------------------| | Read<br>Write | | Read data (from controller to system unit)<br>Write data (from system unit to controller) | | Read<br>Write | 321<br>321 | Read controller hardware status.<br>Controller reset. | | Read<br>Write | 322<br>322 | Read option jumpers<br>Generate controller-select-pulse | | Read<br>Write | 323<br>323 | Not used.<br>Write pattern to DMA and interrupt<br>mask register. | #### **Interface** The following lines are used by the disk controller: - A0-A19 Positive true 20-bit address. The least-significant 10 bits contain the I/O address within the range of hex 320 to hex 323 when an I/O read or write is executed by the system unit. The full 20 bits are decoded to address the read-only memory (ROM) between the addresses of hex C8000 and hex C9FFF. - **DO–D7** Positive 8-bit data bus over which data and status information is passed between the system board and the controller. - **-IOR** This signal is active when the system board reads status or data from the controller under either programmed I/O or DMA control. - **-IOW** This signal is active when the system board sends a command or data to the controller under either programmed I/O or DMA control. - AEN This signal is active when the DMA in the system board is generating the I/O Read (-IOR) or I/O Write (-IOW) signals and has control of the address and data buses. - **RESET** This signal forces the disk controller to its initial power-up condition. - IRQ 5 This signal is active by the controller when enabled to interrupt the system board on the return ending status byte from the controller. - DRQ 3 This signal is activated by the controller when data is available for transfer to or from the controller under DMA control. This signal remains active until the system board's DMA channel activates the DMA-acknowledge signal (-DACK 3) in response. -DACK 3 This signal is active when negative, and is generated by the system board DMA channel in response to a DMA request (DRQ 3). #### **Connectors** The 20MB Fixed Disk Drive Adapter connector and interface specifications follow. # Logic Diagrams 20MB Fixed Disk Drive Adapter (Sheet 1 of 4) 20MB Fixed Disk Drive Adapter (Sheet 2 of 4) 20MB Fixed Disk Drive Adapter (Sheet 3 of 4) 20MB Fixed Disk Drive Adapter (Sheet 4 of 4) # **BIOS Listing** The BIOS Listing for the IBM 20MB Fixed Disk Drive Adapter follows. ``` PAGE 118,121 TITLE DISK2 ---- 10/28/85 FIXED DISK BIOS :-- INT 13H ------ FIXED DISK I/O INTERFACE THIS INTERFACE PROVIDES ACCESS TO FIXE THROUGH THE IBM FIXED DISK CONTROLLER. TO FIXED DISKS 012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678900123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234 THE BIOS ROUTINES ARE MEANT TO BE ACCESSED THROUGH SOFTWARE INTERRUPTS ONLY. ANY ADDRESSES PRESENT IN THE LISTINGS ARE INCLUDED ONLY FOR COMPLETENESS, NOT FOR REFERENCE. APPLICATIONS WHICH REFERENCE ABSOLUTE ADDRESSES WITHIN THE CODE SEGMENT VIOLATE THE STRUCTURE AND DESIGN OF BIOS. INPUT (AH = HEX 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 (DE) READ THE DESIRED SECTORS INTO MEMORY (AH)= 02H READ THE DESIRED SECTORS INTO MEMORY (AH)= 03H WRITE THE DESIRED SECTORS FROM MEMORY (AH)= 04H VERIFIT THE DESIRED SECTORS FROM MEMORY (AH)= 04H VERIFIT THE DESIRED SECTORS AH) (AH)= 05H FORMAT THE DESIRED TRACK AND SET BAD SECTOR FLAGS (AH)= 07H FORMAT THE DRIVE STARTING AT THE DESIRED TRACK (AH)= 07H FORMAT THE DRIVE STARTING AT THE DESIRED TRACK (AH)= 08H RETURN THE CURRENT DRIVE PARAMETERS INITIALIZE DRIVE PAIR CHARACTERISTICS INTERRUPT 41H POINTS TO DATA BLOCK (AH) = 09H INTERRUPT 41H POINTS TO DATA BLOCK READ LONG WRITE LONG NOTE: READ AND WRITE LONG ENCOMPASS 512 BYTES + 4 BYTES OF ECC SEEK (AH) = 0AH (AH) = 0BH (AH) = OCH (AH) = ODH (AH) = OEH (AH) = OFH SEEK ALTERNATE DISK RESET (SEE DL) READ SECTOR BUFFER, (RECOMMENDED PRACTICE BEFORE FORMATTING) TEST DRIVE READY RECALIBRATE CONTROLLER RAM DIAGNOSTIC DRIVE DIAGNOSTIC (AH) = 10H (AH) = 11H (AH) = 12H (AH) = 13H (AH) = 14H REGISTERS USED FOR FIXED DISK OPERATIONS - DRIVE NUMBER (80H-87H FOR DISK, VALUE CHECKED) - HEAD NUMBER (0-7D ALLOWED, NOT VALUE CHECKED) - SECTOR NUMBER (0-1023D, NOT VALUE CHECKED) (SEE CL) NOTE: HIGH 2 BITS OF CYLINDER NUMBER ARE PLACED IN THE HIGH 2 BITS OF THE CL REGISTER (10 BITS TOTAL) (AL) - NUMBER OF SECTORS (MAXIMUM POSSIBLE RANGE 1-80H, (INTERLEAVE VALUE FOR READ WRITE LONG 1-79H) (INTERLEAVE VALUE FOR FORMAT 1-16D) (ROT REQUIRED FOR VERIEY) THE STATUS OF CURRENT OPERATION STATUS BITS ARE DEFINED IN THE EQUATES BELOW CY = 0 SUCCESSFUL OPERATION (AH= 00H ON RETURN) CY = 1 FAILED OPERATION (AH HAS ERROR REASON) ERROR IIH INDICATES THAT THE DATA READ HAD A RECOVERABLE ERROR WHICH WAS CORRECTED BY THE ECC ALGORITHM. THE DATA IS PROBABLY GOOD, HOWEVER THE BIOS ROUTINE INDICATES AN ERROR TO ALLOW THE CONTROLLING PROGRAM A CHANCE TO DECIDE FOR ITSELF. THE ERROR MAY NOT RECUR IF THE DATA IS REWRITTEN. (AL) CONTAINS THE BURST LENGTH. DL = NUMBER OF CONSECUTIVE ACKNOWLEDGING DRIVES ATTACHED (0-2) (CONTROLLER CARD ZERD TALLY ONLY) DH = MAXIMUM USEABLE VALUE FOR CYLINDER NUMBER CL = MAXIMUM USEABLE VALUE FOR CYLINDER NUMBER CL = MAXIMUM USEABLE VALUE FOR SECTOR NUMBER AND CYLINDER NUMBER HIGH BITS IF AN ERROR OCCURS ON READ DRIVE PARAMETERS. AH = ERROR CODE (INIT_FAIL) AL = CX = DX = 0 REGISTERS WILL BE PRESERVED EXCEPT WHEN THEY ARE USED TO RETURN INFORMATION. NOTE: IF AN ERROR IS REPORTED BY THE DISK CODE, THE APPROPRIATE ACTION IS TO RESET THE DISK, THEN RETRY THE OPERATION. ``` ``` 104 ERROR RETURN STATUS (AH) = ??H WHEN CY= 1 106 107 108 109 SENSE FAIL WRITE FAULT WRITE FAULT UNDEF ERR TIME OUT BAD SEK BAD CONTLR DATA CORRECTED BAD ECC BAD BAD TRACK DMA BOUNDAY BAD TRACK DMA BOUNDAY RESET RECORD NOT FND BAD ARK BAD CMD MARK BAD CMD : SENSE OPERATION FAILED : WRITE FAULT ON SELECTED DRIVE : UNDEFINDE PEROR OCCURRED : ATTACHMENT FAILED TO RESPOND : SEEK OPERATION FAILED : CONTROLLER HAS FAILED : ECC CORRECTED DATA ERROR : BAD ECC ON DISK READ : BAD TRACK FLAG DETECTED : ARIWET TARABME ACROSS 64K BOUNDARY RESET FAILED RESET FAILED : REQUESTED SECTOR NOT FOUND : ADDRESS MARK NOT FOUND : BAD COMMAND PASSED TO DISK I/O = 00FF = 00CC = 00BB = 0080 = 0040 EQU EQU EQU EQU EQU EQU 0FFH 0CCH 0BBH 080H 040H 011H 0110H 009H 007H 005H 002H 002H 001H 0040 0020 0011 0010 000B EQU EQU EQU 0009 118 EQU 0005 120 121 122 123 0004 0002 0001 124 125 126 127 INTERRUPT AND STATUS AREAS SEGMENT AT 0H ORG INT LABEL ORG 0000 0034 0034 004C 0064 0064 0078 0078 0100 0104 00DH*4 : FIXED DISK INTERRUPT VECTOR HDISK INT DWORD 013H*4 : DISK INTERRUPT VECTOR ORG_VECTOR 013H*4 DWORD 019H*4 DWORD 01EH*4 DWORD 040H*4 DWORD 041H*4 LARFI LABEL ORG LABEL ORG LABEL ORG ; BOOTSTRAP INTERRUPT VECTOR 133 BOOT_VEC ; DISKETTE PARAMETERS DISKETTE_PARM DISK_VECTOR 138 139 ; FIXED DISK PARAMETER VECTOR HF_TBL_VEC LABEL DWORD 7COOH FAR ; BOOTSTRAP LOADER VECTOR 141 142 143 144 145 146 147 148 151 152 153 154 155 157 LABEL ENDS DATA SEGMENT AT 40H ORG 06CH 006C 006C ???? 007Z ???? 007Z ???? 0074 ?? 0075 ?? 0076 ?? 0077 ?? 006C ORG DW ORG DW ORG DB DB TIMER_LOW : TIMER LOW WORD 072H RESET_FLAG : 1234H IF KEYBOARD RESET UNDERWAY DISK STATUS HF NUM CONTROL BYTE PORT_OFF DATA ENDS ; FIXED DISK STATUS BYTE ; COUNT OF FIXED DISK DRIVES ; CONTROL BYTE DRIVE OPTIONS ; PORT OFFSET 0000 158 HARDWARE SPECIFIC VALUES 160 161 162 163 164 HARDWARE SPECIFIC VALUES - CONTROLLER I/O POORT > WHEN READ FROM: HF PORT+0 - READ DATA (FROM CONTROLLER TO CPU) HF PORT+1 - READ CONTROLLER HARDWARE STATUS (CONTROLLER TO CPU) HF PORT+3 - NOT USED - WHEN ON THE WEST OF 166 167 168 169 171 172 173 174 175 176 BYTE PTR [BP]-8 ; CMO BLOCK HEAD 0320H ; DISK PORT 021H ; 8259 PORT 020H ; 8259 PORT 020H ; END OF INTERRUPT COMMAND 0000100B ; DISK PORT | BUSY BIT 0000010B ; MODE BIT 00000010B ; MODE BIT 178 179 180 CMD_BLOCK HF_PORT INTA00 = 0320 = 0020 = 0021 = 0020 = 0008 = 0004 EQU EQU EQU EQU INTAGI INTAOI EOI RI_BUSY RI_BUS RI_IOMODE RI_REQ EQU 185 0002 EQU EQU 186 187 188 189 191 192 193 DMA_READ DMA_WRITE DMA DMA_HIGH 01000111B 01001011B 000H 082H ; CHANNEL 3 (047H) ; CHANNEL 3 (04BH) ; DMA ADDRESS ; PORT FOR HIGH 4 BITS OF DMA 0047 FOU 004B 0000 0082 EQU EQU EQU 00000000B ; CNTLR READY (00H) 0000 00000000B 00000011B 00000100B 00000101B 00000110B READY (00H) RECAL (01H) SENSE (03H) DRIVE (04H) T CHK (05H) TRACK (06H) BAD (07H) 0001 EQU 0003 0004 0005 EQU EQU EQU 195 196 197 198 199 0006 BAD READ 0007 EQU 200 0008 EQU 00001000B (08H) 00001000B 00001010B 00001100B 00001101B 00001110B EQU EQU EQU EQU EQU 0000 WRITE (OAH) WRITE SEEK INIT BURST BUFFR BUFFR RAM DRV 202 203 204 205 000B 000C 000D 206 000F (OFH) 11100000B 11100011B 11100100B 11100101B 0.0F0 FOU (FOH) 208 209 210 EQU EQU EQU 00E3 (E3H) (E4H) (E5H) CNTLR RLONG WLONG = 0008 = 0002 MAX_FILE S_MAX_FILE EQU ``` ``` 215 216 217 218 219 220 221 PACE ASSUME CS:CODE,DS:ABS0 ORG 0H DB 055H 0000 0000 55 0001 AA 0002 08 ; GENERIC BIOS HEADER ; 4K MODULE 08D 221 223 224 225 226 227 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 228 229 230 231 232 233 0003 EB 35 0008 BB 35 0008 35 39 58 37 32 39 31 20 28 43 29 20 43 47 50 59 52 40 47 48 54 20 49 42 40 20 20 43 47 52 50 2E 30 20 43 47 52 0025 23 31 39 38 32 20 0031 20 31 30 2F 32 38 003A 27 38 DISK_SETUP JMP DB PROC FAR SHORT L3 '59X7291 (C) COPYRIGHT IBM CORP.' : COPYRIGHT NOTICE ',1982 ,1985.' DB 10/28/85* DB : RELEASE MARKER 0031 20 31 30 2F 32 38 0031 28 35 0031 28 C0 0032 8E D8 0032 FA 0035 FA 0045 R : ADDRESS LOW RAM MOV CLI MOV MOV MOV MOV MOV MOV MOV AX, WORD PTR ORG_VECTOR WORD PTR DISK_VECTOR.AX AX, WORD PTR ORG_VECTOR-2 WORD PTR ORG_VECTOR-2,AX WORD PTR ORG_VECTOR-2,AX WORD PTR ORG_VECTOR-2,CS AX, OFFSET HD.INT.AX WORD PTR HD.INT.AX WORD PTR HD.INT.AX WORD PTR HD.INT.AX WORD PTR HD.INT.AC.CS HT.INT.AC.CS HT.INT : LOAD DISKETTE IP : STORE AT INT 40H : LOAD DISKETTE CS : STORE AT INT 40H : FIXED DISK HANDLER : AT INT 13H : FIXED DISK INTERRUPT : HANDLER AT INT 00H ; BOOTSTRAP ROUTINE AT ; INT 19H ; PARAMETER TABLE AT ; INT 41H MOV MOV MOV MOV STI 260 261 262 263 264 265 265 267 271 273 273 275 277 277 277 277 277 DS:DATA AX,DATA DS,AX DISK_STATUS,0 HF_NUM,0 PORT_OFF,0 CX,25H ASSUME MOV MOV MOV 0074 B8 ---- R 0077 8E D8 0079 C6 06 0074 R 00 007E C6 06 0075 R 00 0083 C6 06 0077 R 00 0088 B9 0025 ; ESTABLISH SEGMENT ; RESET THE STATUS INDICATOR ; ZERO COUNT OF DRIVES ; ZERO CARD OFFSET ; RETRY COUNT MOV 0088 B9 0025 0088 E8 0177 R 008E 73 05 0092 E2 F9 0154 R 0095 B9 0001 0098 BA 0080 0098 BA 1200 0096 CD 13 00A2 E9 0154 R 00A2 E9 0154 R 00A6 CD 13 00AA 73 03 00AC E9 0154 R 00AF 00AF C7 06 006C R 0000 00BB 75 06 00BD C7 06 006C R 019A 0088 CALL JNC LOOP JMP HD_RESET_1 ; RESET CONTROLLER ; TRY RESET AGAIN ERROR_EX CX,1 DX,80H AX,1200H 13H P7 MOV MOV MOV INT JNC JMP ; CONTROLLER DIAGNOSTICS ; CHECK THE INTERNAL RAM ; BUFFERS 278 279 280 281 282 283 284 285 286 287 MOV INT JNC JMP AX,1400H 13H CONTROLLER DIAGNOSTICS INTERNAL CHECKSUM AND ECC CIRCUITRY TEST. ERROR_EX MOV CMP JNE MOV TIMER_LOW,0 RESET_FLAG,1234H ; ZERO TIMER ; KEYBOARD RESET 288 289 290 291 292 293 294 295 296 297 P8 TIMER_LOW,410D ; SKIP WAIT ON RESET 00BD C7 06 00C3 00C3 FA 00C4 E4 21 00C6 24 FE 00C8 E6 21 00CA FB ; DISABLE INTERRUPTS ; TIMER ; ENABLE TIMER ; START TIMER ; INTERRUPTS ON AL, INTAOI AL, OFEH INTAOI, AL AND OUT STI OOCA HD_RESET_I P10 AX,1000H 13H P2 298 299 300 CALL ; RESET CONTROLLER JC MOV INT ; TEST TO SEE IF THE DRIVE ; IS READY 302 JNC 303 304 305 306 307 PIO. MOV AX,TIMER_LOW AX,446D CMP JB JMP ; 25 SECONDS SHORT ERROR_EX 00E1 00E1 B8 1100 00E4 CD 13 00E6 72 6C 308 309 MOV AX,1100H 13H : RECALIBRATE THE DRIVE O 310 311 312 313 314 ERROR_EX 00E8 B8 0900 00EB CD 13 00ED 72 65 MOV INT JC ; SET DRIVE PARAMETERS ; FOR DRIVE 0 I3H ERROR_EX 315 316 317 318 319 320 321 322 00EF B8 C800 00F2 8E C0 00F4 2B DB 00F6 B8 0F00 00F9 CD 13 00FB 72 57 AX,0C800H ES,AX BX,BX AX,0F00H MOV ; DMA TO BUFFER ; SET SEGMENT MOV SUB MOV INT ; WRITE SECTOR BUFFER ERROR_EX JC 323 00FD FE 06 0075 R 0101 BA 0213 0104 B0 00 0106 EE 0107 BA 0321 HF_NUM DX,213H AL,0 DX,AL DX,321H INC ; DRIVE ZERO RESPONDED ; EXPANSION BOX ; TURN BOX OFF ; TEST IF CONTROLLER ``` | I BM<br>D I SK | Personal Computer MACRO<br>2 10/28/85 FIXED DI | Assemble<br>SK BIOS | r Vers | ion 2.00 | 1<br>8-82-0 | <b>-4</b><br>5 | |--------------------------|---------------------------------------------------|---------------------|------------------------|-------------------------------------|-------------|----------------------------------------------------------------| | 329<br>330<br>331<br>332 | 010A EC<br>010B 24 0F<br>010D 3C 0F<br>010F 74 06 | | IN<br>AND<br>CMP<br>JE | AL,DX<br>AL,OFH<br>AL,OFH<br>BOX ON | ; | IS IN THE SYSTEM UNIT | | 333<br>334 | 0111 C7 06 006C R 01A4 | DOY ON | MOV | TIMER_LOW,420D | ; | CONTROLLER IS IN SYSTEM UNIT | | 335<br>336 | 0117 BA 0213<br>011A B0 FF | BOX_ON: | MOV | DX,213H | : | EXPANSION BOX | | 337<br>338 | 011C EE<br>011D B9 0001 | | OUT | AL, OFFH<br>DX, AL | ; | TURN BOX ON | | 339 | 0120 BA 0081 | | MOV | CX,1<br>DX,081H | ; | ATTEMPT NEXT DRIVES | | 340<br>341<br>342 | 0123<br>0123 2B C0<br>0125 CD 13 | P3: | SUB | AX,AX<br>13H | ; | RESET THE CONTROLLER | | 343<br>344<br>345 | 0127 72 42<br>0129 B8 1100<br>012C CD 13 | | JC<br>MOV<br>INT | POD_DONE<br>AX,01100H<br>13H | ; | RECALIBRATE THE DRIVE I | | 346<br>347<br>348 | 012E 73 0A<br>0130 A1 006C R<br>0133 3D 01BE | | JNC<br>MOV<br>CMP | P5<br>AX,TIMER_LOW<br>AX,446D | | 25 SECONDS | | 349<br>350 | 0136 72 EB<br>0138 EB 31 | | JB<br>JMP | P3<br>SHORT POD DONE | • | | | 351<br>352 | 013A<br>013A B8 0900 | P5: | MOV | AX,0900H | | INITIALIZE DRIVE CHARACTERISTICS | | 353<br>354 | 013D CD 13<br>013F 72 2A | | INT<br>JC | 13H<br>POD DONE | ; | FOR DRIVE 1 | | 355<br>356 | 0141 FE 06 0075 R<br>0145 81 FA 0081 | | INC<br>CMP | HF_NUM<br>DX,(80H + S_MAX_FILE | : - i | TALLY ANOTHER DRIVE | | 357<br>358 | 0149 73 20<br>014B 42 | | JAE<br>INC | DX POD_DONE | | | | 359<br>360 | 014C EB D5 | | JMP | P3 | | | | 361<br>362<br>363 | 014E 31 37 30 31 0D 0A<br>= 0006 | F17<br>F17L | DB<br>EQU | 1701',0DH,0AH<br>\$-F17 | ; | POST MESSAGE | | 364<br>365 | | ; | POD ERR | OR | | | | 366<br>367 | 0154<br>0154 BD 000F | ERROR_E | X:<br>MOV | BP,0FH | | POD ERROR FLAG | | 368<br>369 | 0157 2B F6<br>0159 B9 0006 | | SUB<br>MOV | SI,SI<br>CX,FI7L | | MESSAGE CHARACTER COUNT | | 370<br>371 | 015C B7 00<br>015E | OUT_CH: | MOV | вн,0 | | PAGE ZERO | | 372<br>373 | 015E 2E: 8A 84 014E R<br>0163 B4 0E | _ | MOV<br>MOV | AL,CS:F17[S1]<br>AH,14D | : | GET BYTE<br>VIDEO OUT | | 374<br>375 | 0165 CD 10<br>0167 46 | | INT | 10H<br>S1 | | DISPLAY CHARACTER<br>NEXT CHAR | | 376<br>377 | 0168 E2 F4<br>016A F9 | | LOOP<br>STC | OUT_CH | ; | DO MORE | | 378<br>379 | 016B<br>016B FA | POD_DON | E:<br>CLI | | | NO INTERRUPTS | | 380<br>381 | 016C E4 21<br>016E 0C 01 | | IN<br>OR | AL, INTAOI<br>AL, OIH | | READ THE INTERRUPT MASK<br>DISABLE THE TIMER | | 382<br>383 | 0170 E6 21<br>0172 FB | | OUT<br>STI | INTAO1,AL | | ENABLE INTERRUPTS | | 384<br>385 | 0173 E8 0232 R<br>0176 CB | | CALL | DSBL | į | DISABLE THE CARD MASKS | | 386<br>387 | 0177 | HD_RESE | T_1 | PROC NEAR | | | | 388<br>389 | 0177 51<br>0178 52 | | PUSH | CX<br>DX | | SAVE REGISTER | | 390<br>391 | 0179 B9 0100<br>017C | L6: | MOV | CX,0100H | : | RETRY COUNT | | 392<br>393 | 017C E8 076D R<br>017F 42 | | CALL<br>INC | PORT_0<br>DX | | ADDRESS PORT 1 | | 394<br>395 | 0180 EE<br>0181 EB 00 | | OUT<br>JMP | DX,AL<br>\$+2 | ; | RESET CARD<br>I/O DELAY AT LEAST +5us | | 396<br>397 | 0183 EB 00<br>0185 EB 00 | | JMP<br>JMP | \$+2<br>\$+2 | : | ALLOW TIME TO CLEAR THE<br>HARDWARE STATUS REGISTER | | 398<br>399 | 0187 EC<br>0188 24 3F | | IN<br>AND | AL,DX<br>AL,00111111B | ; | READ THE HARDWARE STATUS<br>MASK OFF UPPER 2 BITS AND CLEAR CY | | 400<br>401 | 018A 74 03<br>018C E2 EE | | JZ<br>LOOP | R3<br>L6 | į | EXIT IF REGISTER IS CLEARED WITH CY=0 TRY AGAIN | | 402<br>403 | 018E F9<br>018F | R3: | STC | | ; | SET ERROR CONDITION CY=1 | | 404<br>405 | 018F 5A<br>0190 59 | | POP<br>POP | CX | : | RESTORE REGISTER | | 406<br>407 | 0191 C3<br>0192 | HD_RESE | RET<br>T_1 | ENDP | | | | 408 | 0192 | DISK_SE | TUP | ENDP | | | ``` 409 410 411 412 413 414 415 416 417 418 419 THE FIXED DISK BIOS REPLACES THE INTERRUPT 19H BOOT STRAP VECTOR WITH A POINTER TO THIS BOOT ROUTINE AND RESETS THE DEFAULT DISK AND DISKETTE PARAMETER VECTORS THE BOOT BLOCK TO BE READ IN WILL BE ATTEMPTED FROM CYLINDER 0 SECTOR I OF THE DEVICE. THE BOOTSTRAP SEQUENCE IS: ATTEMPT TO LOAD FROM THE DISKETTE INTO THE BOOT LOCATION (1000)TC000H WHERE CONTROL IS TRANSFERRED. IF THE DISKETTE FAILS THE FIXED DISK IS TRIED FOR A VALIO BOOTSTRAP BLOCK, A VALIO BOOT BLOCK ON THE FIXED DISK CONSISTS OF THE BYTES 055H 0AAH AS THE LAST TWO BYTES OF THE BLOCK, IF THE BOVE FAILS CONTROL IS PASSED TO RESIDENT BASIC 426 427 428 429 430 431 432 0192 ; READ CONFIGURATION PARAMETERS ; IF XT OR PC, INTERRUPTS ARE DISABLED ; AT THIS POINT. RESET PARAMETER VECTORS 019A FA 019B C7 06 01A1 8C 0E 01A5 73 0A CL I MOV MOV WORD PTR HF_TBL_YEC,OFFSET FD_TBL WORD PTR HF_TBL_YEC+2,CS HO ; JMP IF ; JMP IF INT 15 FUNCTION IMPLEMENTED JNC 01A7 C7 06 0078 R 0227 R 01AD 8C 0E 007A R 01B1 01B1 FB WORD PTR DISKETTE_PARM,OFFSET DISKETTE_TBL WORD PTR DISKETTE_PARM+2,CS MOV MOV STI :---- ATTEMPT BOOTSTRAP FROM DISKETTE 01B2 2B D2 SUB ; DRIVE ZERO ;---- ESTABLISH ES:BX POINTER 01B4 8E C2 01B6 BB 7C00 R ES,DX BX,OFFSET BOOT_LOCN :---- CLEAR BOOT_LOCK 01B9 FC 01BA 33 C0 01BC B9 0100 01BF 8B FB 01C1 F3/ AB CLD XOR MOV MOV REP ; DIRECTION FORWARD AX,AX CX,256 DI,BX STOSW : CLEAR 256 WORDS ; POINT TO BOOT LOCATION BUFFER ; ZERO THE BOOT LOCATION BUFFER 466 467 468 469 470 471 473 474 475 476 477 478 01C3 B9 0004 01C6 01C6 51 01C7 2B C0 01C9 CD 13 01CB 72 08 ; SET RETRY COUNT ; IPL_SYSTEM ; SAVE RETRY COUNT ; RESET THE DISKETTE ; FILE IO CALL ; IF ERROR, TRY AGAIN MOV PUSH SUB AX,AX 13H H2 INT 01CD B8 0201 01D0 B9 0001 01D3 CD 13 01D5 59 01D6 73 09 AX,0201H CX,1 13H CX H3 ; READ IN THE SINGLE SECTOR ; SECTOR I, TRACK 0; ; FILE 10 CALL ; RECOVER RETRY COUNT ; CARRY FLAG SET BY UNSUCCESSFUL READ MOV MOV INT н2: POP JNC 480 481 ; IF TIME OUT, NO RETRY ; TRY FIXED DISK 01D8 80 FC 80 01DB 74 22 АН,80Н Н6 CMP 482 483 484 485 486 487 488 ; DO IT FOR RETRY TIMES ; UNABLE TO IPL FROM THE DISKETTE 01DD E2 E7 01DF EB 1E H1 SHORT H6 01E1 80 3E 7C00 R 06 01E6 72 3D СМР BYTE PTR BOOT_LOCN,06H ; CHECK FOR FIRST INSTRUCTION INVALID H10 ; IF BOOT NOT VALID, GO TO BASIC INSURE DATA PATTERN FIRST 8 WORDS NOT ALL EQUAL 01E8 BF 7C00 R 01EB B9 0008 01EE A1 7C00 R MOV MOV MOV CHECK DATA PATTERN CHECK THE NEXT 8 WORDS LOAD THE FIRST WORD DI.OFFSET BOOT_LOCK CX,8 AX,WORD PTR BOOT_LOCN 495 496 497 498 499 500 01F1 83 C7 02 01F4 3B 05 01F6 E1 F9 01F8 74 2B ADD CMP LOOPZ JZ DI,2 AX,[DI] H4 H10 : POINT TO NEXT WORD : CHECK DATA PATTERN FOR A FILL PATTERN BOOT NOT VALID, GO TO BASIC 01FA 01FA EA 7C00 ---- R H5: 501 . IMP BOOT_LOCN ATTEMPT BOOTSTRAP FROM FIXED DISK 01FF 01FF 2B C0 0201 CD 13 0203 B9 0003 0206 BA 0080 0209 51 020A 2B C0 020C CD 13 020E 72 08 : RESET DISKETTE SUB AX,AX : SET RETRY COUNT ; FIXED DISK ZERO ; IPL SYSTEM ; SAVE RETRY COUNT ; RESET THE FIXED DISK ; FILE IO CALL ; IF ERROR, TRY AGAIN CX,3 DX,0080H MOV MOV 508 509 510 511 513 514 515 516 517 518 519 520 H7: PUSH SUB INT CX AX,AX 13H ES AND BX ALREADY ESTABLISHED AX,0201H CX,1 13H CX H9 0210 B8 0201 0213 B9 0001 0216 CD 13 0218 59 0219 72 08 MOV MOV INT POP ; READ IN THE SINGLE SECTOR ; SECTOR I, TRACK 0 ; FILE IO CALL ; RECOVER RETRY COUNT ``` ``` AX, WORD PTR BOOT_LOCN+510D AX, 0AA55H ; TEST FOR GENERIC BOOT BLOCK H5 ; GO TO POOT LOCK 021B A1 7DFE R 021E 3D AA55 0221 74 D7 0223 0223 E2 E4 LOOP ; DO IT FOR RETRY TIMES :---- UNABLE TO IPL FROM THE DISKETTE OR FIXED DISK 0225 0225 CD 18 H10: : RESIDENT BASIC INT 0227 DISKETTE_TBL: : SRT=D, HD UNLOAD=OF - IST SPEC BYTE : HD LOAD=1, MODE=DMA - 2ND SPEC BYTE : MOTOR TIMEOUT AFTER OPERATION : 512 BYTES PER SECTOR : EOT (LAST SECTOR ON TRACK) : GAP LENGTH : DTL : GAR LENGTH : GAR LENGTH : GAR LENGTH : HEAD SETTLE TIME (MILLISECONDS) : MOTOR START TIME (1/8 SECOND) 11001111B 0227 CF 0228 02 0229 25 022A 02 022B 08 022C 2A 022D FF 022E 50 022F F6 0230 19 DB DB 25H 25H 2 8 02AH 0FFH 050H 0F6H DB DB DB DB DB MAKE SURE THAT ALL HOUSEKEEPING IS DONE BEFORE EXIT PROC DSBL NEAR SUB MOV CLI OUT ADD AL, AL DX, HF_PORT+3 : RESET INT/DMA MASK : LOAD FOR PORT ADDRESS 3 : DISABLE INTERRUPTS 552 553 554 555 556 557 558 DX,AL DX,4 DX,AL DX,4 DX,AL ADD OUT ADD 559 560 561 562 563 564 565 ; RESET INT/DMA MASK CARD 3 0245 B0 07 0247 E6 0A 0249 E4 21 024B 0C 20 024D E6 21 024F FB 0250 C3 0251 MOV OUT IN OR AL,07H DMA+10,AL AL,1NTA01 AL,020H ; SET DMA MODE TO DISABLE OUT STI RET ENDP 566 567 568 569 570 571 572 573 INTAO1,AL ; DISABLE IREQ 5 ; ENABLE INTERRUPTS DISK_10 ----- FIXED DISK BIOS ENTRY POINT rAR DS:DATA,ES:NOTHING DL,080H HARD_DISK 40H 0251 ASSUME CMP JAE INT 578 579 0251 80 FA 80 0254 73 05 0256 CD 40 0258 0258 CA 0002 ; TEST FOR FIXED DISK DRIVE ; YES, HANDLE HERE ; DISKETTE HANDLER 580 581 582 583 584 585 586 587 588 589 590 591 025B FB 025B FB 025C 0A E4 025E 75 09 0260 CD 40 0262 2A E4 0264 80 FA 81 0267 77 EF 0269 0269 80 FC 08 026C 75 03 026E E9 0380 R 0271 0271 0271 55 0272 88 EC 08 HARD_DISK: STI OR ; ENABLE INTERRUPTS AH, AH A3 40H AH, AH JNZ INT SUB CMP ; RESET NEC WHEN AH=0 DL, (80H+S_MAX_FILE-1) RET_2 ; DL IN LIMITS? 592 593 594 595 596 597 598 599 : GET PARAMETERS IS A SPECIAL CASE CMP АН,8 AZ GET_PARM_N : SAVE THE BASE POINTER : LOAD THE CMD BLOCK POINTER : ALLOCATE SPACE FOR THE COMMAND BLOCK : ON THE STACK: : SAVE REGISTERS DURING OPERATION PUSH SP,8 600 SUB 601 602 603 BX CX DX DS ES SI DI SI,DATA DS,SI 0277 53 0278 51 0279 52 027A 1E PUSH PUSH PUSH PUSH 605 PUSH PUSH PUSH MOV 606 027B 06 027C 56 027D 57 027E BE --- 0281 8E DE 607 608 609 610 611 613 614 615 616 617 618 : ESTABLISH DATA SEGMENT 0283 E8 02D0 R CALL DISK_IO_CONT : PERFORM THE OPERATION 0286 50 0287 E8 0232 R 028A B8 ---- R 028D 8E D8 028F 58 0290 8A 26 0074 PUSH CALL MOV MOV POP MOV POP POP POP POP POP AX DSBL ; BE SURE DISABLES OCCURRED AX,DATA DS,AX AX AH,DISK_STATUS ; ESTABLISH SEGMENT ; RESTORE THE REGISTERS ; GET STATUS FROM OPERATION 0290 8A 26 0074 R 0294 5F 0295 5E 0294 67 620 0295 5E 0296 07 0297 1F 0298 5A 0299 59 029A 5B 622 ES DS DX CX BX 623 624 625 626 627 029B 83 C4 08 029E 5D 029F 80 FC 01 02A2 F5 02A3 CA 0002 02A6 ; ADJUST FOR THE COMMAND BLOCK. ; RESTORE BASE POINTER ; SET THE CARRY FLAG TO INDICATE ; SUCCESS OR FAILURE ; THROW AWAY SAVED FLAGS ADD SP,8 628 POP CMP CMC AH,I 631 DISK_IO ENDP ``` ``` WORD OLS RESET TO SET T ; FUNCTION TRANSFER TABLE ; 000H ; 001H ; 002H ; 003H ; 004H 02A6 032E R 02A8 034T R 02A8 034T R 02AA 0359 R 02AE 0369 R 02BE 0369 R 02BE 036F R 02BE 036F R 02BE 036F R 02BE 056F 0 6356 6378 6441 6442 6445 6447 6447 6447 6449 6456 6553 004H 005H 006H 007H 008H 009H 00AH 00BH 00CH 00DH 00EH 010H 011H 012H 013H 654 656 657 658 659 660 661 662 664 665 PROC NEAR AH,01H RETURN_STATUS DISK_IO_CONT ; RETURN STATUS JE 02D5 80 EA 80 02D8 80 FA 08 02DB 73 49 SUB CMP JAE DL,080H DL,MAX_FILE BAD_COMMAND ; CONVERT DRIVE NUMBER TO 0 BASED RANGE ; LEGAL DRIVE TEST 666 667 02DD C6 06 0074 R 00 MOV DISK_STATUS,0 RESET THE STATUS INDICATOR 668 :---- SET UP COMMAND BLOCK 669 670 671 672 673 674 675 676 677 678 : SECTORS 0-16 FOR CONTROLLER : SET TO ZERO THE OP CODE : SECTOR AND HIGH 2 BITS CYLINDER : CYLINDER LOW INTERLEAVE / BLOCK COUNT : CONTROL BYTE (STEP OPTION) : SET THE CONTROL FILED 02E2 FE C9 02E4 C6 46 F8 00 02E8 88 4E FA 02EB 88 6E FB 02EE 88 46 FC 02F1 A0 0076 R 02F4 88 46 FD DEC MOV MOV MOV MOV MOV CL CMD_BLOCK+0,0 CMD_BLOCK+2,CL CMD_BLOCK+3,CH CMD_BLOCK+4,AL AL,CONTROL_BYTE CMD_BLOCK+5,AL ;---- CALCULATE THE PORT OFFSET 680 02F7 8A EA 02F9 80 CA 01 02FC FE CA 02FE D0 E2 0300 88 16 0077 R 0304 8A D5 0306 80 E2 01 0309 B1 05 0309 B MOV OR DEC SHL MOV MOV AND MOV SHL CH.DL : SAVE DL 681 CH,DL DL,1 DL,1 PORT_OFF,DL DL,CH DL,1 CL,5 DL,CL DL,DH 682 683 684 685 686 687 690 691 692 693 694 ; GENERATE OFFSET ; STORE OFFSET ; RESTORE DL ; MAKE DRIVE 0 OR I ; SHIFT COUNT ; RIVE NUMBER (0,1) ; HEAD NUMBER ; SET THE DRIVE AND HEAD OR MOV CMD_BLOCK+1,DL 0312 88 C8 0314 8A CD 0316 32 ED 0318 D1 E1 0318 BF II 031C 83 F9 2A 031F 73 05 0321 ZE: FF A4 02A6 R 0328 B0 00 0074 R 01 032B B0 00 0032B C3 032E ; CALCULATE JUMP ADDRESS ; GET INTO LOW BYTE ; ZERO HIGH BYTE ; *2 FOR TABLE LOOKUP ; PUT INTO SI FOR BRANCH ; TEST WITHIN RANGE MOV MOV XOR SAL CX, AX CL, CH ; Gf CH, CH ; Zf CX, 1 ; *: S1, CX ; Pt CX, MIL BAD COMMAND WORD PTR CS: [SI+OFFSET MI] 696 697 698 699 700 701 SAL MOV CMP JNB JMP BAD_COMMAND: ; GO DO THE COMMAND DISK_STATUS,BAD_CMD ; SET BAD COMMAND ERROR 702 703 MOV MOV ENDP RESET THE DISK SYSTEM (AH = 000H) : 708 709 710 711 712 713 714 715 716 717 718 719 720 721 DISK_RESET CALL INC OUT JMP JMP 0335 EB 00 0337 EB 00 0339 EC 033A 24 3F 033C 74 06 033E C6 06 0074 R 05 0343 C3 0344 C JMP IN AND JZ MOV 722 723 0344 E9 043F R JMP 724 725 726 727 728 729 730 731 732 733 734 735 INIT_DRV : SET THE DRIVE PARAMETERS DISK STATUS ROUTINE (AH = 001H): PROC NEAR AL,DISK_STATUS DISK_STATUS,0 0347 0347 A0 0074 R 034A C6 06 0074 R 00 034F C3 0350 RETURN_STATUS MOV MOV ; OBTAIN PREVIOUS STATUS ; RESET STATUS RETURN_STATUS ENDP DISK READ ROUTINE (AH = 002H): 0350 0350 B0 47 0352 C6 46 F8 08 0356 E9 055E R , AUC NEAR AL,DMA_READ CMD_BLOCK+0,READ_CMD DMA_OPN ENDP ; MODE BYTE FOR DMA READ DISK_READ ``` | 748<br>749 | | DISK W | RITE ROUTINE | (AH = 003H) ; | |-------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------| | 749<br>750<br>751<br>752<br>753<br>754<br>755<br>756<br>757 | 0359<br>0359 B0 4B<br>035B C6 46 F8 0A<br>035F E9 055E R<br>0362 | DISK_WRITE MOV MOV JMP DISK_WRITE | | ; MODE BYTE FOR DMA WRITE | | 758<br>759<br>760 | | DISK V | ERIFY | (AH = 004H) : | | 761<br>762<br>763<br>764<br>765<br>766<br>767 | 0362<br>0362 C6 46 F8 05<br>0366 E9 054F R<br>0369 | DISK_VERF MOV JMP DISK_VERF | | | | 768<br>769<br>770 | | FORMAT | TING (AH = | 005H 006H 007H) : | | 771<br>772<br>773<br>774<br>775 | 0369<br>0369 C6 46 F8 06<br>036D EB 0A<br>036F | FMT_TRK PROC<br>MOV<br>JMP<br>FMT_TRK ENDP | NEAR<br>CMD BLOCK+0,FMTTRK_CMD<br>SHORT FMT_CONT | ; FORMAT TRACK (AH = 005H) | | 776<br>777<br>778<br>779<br>780 | 036F<br>036F C6 46 F8 07<br>0373 EB 04<br>0375 | FMT_BAD PROC<br>MOV<br>JMP<br>FMT_BAD ENDP | NEAR<br>CMD_BLOCK+0,FMTBAD_CMD<br>SHORT FMT_CONT | ; FORMAT BAD TRACK (AH = 006H) | | 781<br>782<br>783<br>784 | 0375<br>0375 C6 46 F8 04<br>0379 | FMT_DRV PROC<br>MOV<br>FMT_DRV ENDP | NEAR<br>CMD_BLOCK+0,FMTDRV_CMD | ; FORMAT DRIVE (AH = 007H) | | 785<br>786<br>787<br>788 | 0379<br>0379 80 66 FA C0<br>037D E9 054F R | FMT_CONT:<br>AND<br>JMP | | ; ZERO OUT SECTOR FIELD | | 789<br>790<br>791 | | GET PA | RAMETERS | AH = 8) : | | 792<br>793<br>794<br>795<br>796<br>797<br>798 | 0380<br>0380<br>0380 1E<br>0381 06<br>0382 53 | GET_PARM_N<br>GET_PARM<br>PUSH<br>PUSH<br>PUSH | LABEL NEAR<br>PROC FAR<br>DS<br>ES<br>BX | ; GET DRIVE PARAMETERS<br>; SAVE REGISTERS | | 799<br>800<br>801<br>802<br>803 | 0383 2B C0<br>0385 8E D8<br>0387 C4 IE 0104 R | SUB<br>MOV<br>LES | DS:ABS0 AX,AX DS,AX BX,HF_TBL_VEC | ; ESTABLISH ADDRESSING | | 804<br>805<br>806<br>807<br>808 | 038B B8 R<br>038E 8E D8<br>0390 80 EA 80<br>0393 80 FA 08<br>0396 73 57 | MOV<br>MOV<br>SUB<br>CMP | DS:DATA AX,DATA DS,AX DL,80H DL,MAX_FILE | ; ESTABLISH SEGMENT<br>; TEST WITHIN RANGE | | 809<br>810<br>811<br>812<br>813 | 0396 73 57<br>0398 C6 06 0074 R 00<br>039D 8A EA<br>039F 80 CA 01<br>03A2 FE CA | JAE<br>MOV<br>MOV<br>OR<br>DEC | G4<br>DISK_STATUS,0<br>CH,DL<br>DL,1<br>DL | ; RESET THE STATUS INDICATOR<br>; SAVE THE DRIVE | | 814<br>815<br>816<br>817<br>818 | 03A4 D0 E2<br>03A6 88 16 0077 R<br>03AA 8A D5<br>03AC 80 E2 01<br>03AF 8A E2 | SHL<br>MOV<br>MOV<br>AND<br>MOV | DL,1<br>PORT_OFF,DL<br>DL,CH<br>DL,00000001B<br>AH,DL | ; GENERATE OFFSET<br>; STORE OFFSET<br>; RESTORE DL<br>; DRIVE 0 OR DRIVE 1 | | 819<br>820<br>821<br>822<br>823 | 03B1 E8 076D R<br>03B4 42<br>03B5 42<br>03B6 EC<br>03B7 80 FC 00 | CALL<br>INC<br>INC<br>IN<br>CMP | DX<br>DX<br>AL,DX<br>AH,0 | ; PORT_2 ADDRESS ; READ SWITCH SETTINGS ; DRIVE 0 OR ! | | 824<br>825<br>826 | 03BA 75 04<br>03BC DO E8<br>03BE DO E8 | JNZ<br>SHR<br>SHR | GO AL, 1<br>AL, 1 | ; RIGHT JUSTIFY THE SWITCH BITS | | 827<br>828<br>829<br>830<br>831<br>832 | 03C0<br>03C0 24 03<br>03C2 B1 04<br>03C4 D2 E0<br>03C6 2A F4 | GO:<br>AND<br>MOV<br>SHL<br>SUB<br>ADD | AL,00000011B<br>CL,4<br>AL,CL<br>AH,AH<br>BX,AX | ; ISOLATE THE TABLE BITS<br>; TABLE LENGTH IS 16 BYTES<br>; ADJUST | | 833<br>834<br>835<br>836 | 03C8 03 D8<br>03CA 26: 8B 07<br>03CD 2D 0002<br>03D0 8A E8 | MOV<br>SUB<br>MOV | AX.ES:[BX]<br>AX.2<br>CH.AL | : MAX NUMBER OF CYLINDERS<br>; ADJUST FOR 0-N<br>; AND RESERVE LAST TRACK | | 837<br>838<br>839 | 03D2 25 0300<br>03D5 D1 E8<br>03D7 D1 E8 | AND<br>SHR<br>SHR | AX,0300H<br>AX,1<br>AX,1 | ; HIGH TWO BITS OF CYLINDER | | 840<br>841<br>842 | 03D9 0C 11<br>03DB 8A C8 | OR<br>MOV<br>MOV | AL,011H<br>CL,AL<br>DH,ES:[BX][2] | ; SECTORS | | 843<br>844<br>845 | 03DD 26: 8A 77 02<br>03E1 FE CE<br>03E3 8A 16 0075 R<br>03E7 2B CO<br>03E9 | DEC<br>MOV<br>SUB | DH,ES:[BA][2] DH DL,HF_NUM AX,AX | ; HEADS<br>; O-N RANGE<br>; DRIVE COUNT | | 846<br>847<br>848<br>849 | 03E9 5B<br>03EA 07<br>03EB IF | POP<br>POP<br>POP | BX<br>ES<br>DS | ; RESTORE REGISTERS | | 850<br>851<br>852 | 03EC CA 0002<br>03EF<br>03EF C6 06 0074 R 07 | RET<br>G4:<br>MOV | 2<br>DISK STATUS, INIT FAIL | ; EXIT<br>: OPERATION FAILED | | 853<br>854<br>855<br>856 | 03F4 B4 07<br>03F6 2A C0<br>03F8 2B D2 | MOV<br>SUB<br>SUB<br>SUB | DISK_STATUS,INIT_FAIL AH,INIT_FAIL AL,AL DX,DX CX,CX | , S. ENATION LAILED | | 857<br>858<br>859 | 03FA 2B C9<br>03FC F9<br>03FD EB EA<br>03FF | STC<br>JMP<br>GET_PARM | G5<br>ENDP | ; SET ERROR FLAG<br>; EXIT | ``` : INITIALIZE DRIVE CHARACTERISTICS 863 FIXED DISK PARAMETER TABLE - THE TABLE IS COMPOSED OF A BLOCK DEFINED AS: HE TABLE IS COMPOSED OF A BLOCK DEFINED AS: (1 BYTE) - MAXIMUM NUMBER OF CYLINDERS (1 BYTE) - MAXIMUM NUMBER OF HEADS (1 BYTE) - STARTING REDUCED WRITE CURRENT CYL (1 BYTE) - STARTING REDUCED WRITE CURRENT CYL (1 BYTE) - GONTROL BYTE IDRIVE STEP OPTION (1 BYTE) - CONTROL BYTE IDRIVE STEP OPTION BIT 7 DISABLE DISK-ACCESS RETRIES BIT 5-3 ZERO BITS 5-3 ZERO (1 BYTE) - STANDARD TIME OUT VALUE (SEE BELOW) (1 BYTE) - TIME OUT VALUE FOR FORMAT DRIVE (1 BYTE) - TIME OUT VALUE FOR FORMAT DRIVE (1 BYTE) - SECTIORS ITACK (1 BYTE) - SECTIORS ITACK (1 BYTE) - RESERVED FOR FUTURE USE 869 870 871 872 873 874 875 884 884 885 886 887 888 - TO DYNAMICALLY DEFINE A SET OF PARAMETERS BUILD A TABLE OF VALUES AND PLACE THE CORRESPONDING VECTOR INTO INTERRUPT 41. NOTE: THE DEFAULT TABLE IS VECTORED IN FOR AN INTERRUPT 19H (BOOTSTRAP) 890 ON THE CARD SWITCH SETTINGS DRIVE 0 DRIVE 1 -1- -2- / -3- -4- : 898 899 900 901 TRANSLATION TABLE DRIVE 0 : DRIVE I : TABLE ENTRY 1/2 : 3/4 : 903 904 905 ON ON : ON ON : ON OFF : ON OFF : OFF ON : OFF ON : OFF OFF : OFF OFF : 910 911 912 913 914 915 916 917 918 03FF ;---- DRIVE TABLE 0 03FF 0132 0401 04 0402 0132 0404 0000 0406 0B 0407 05 0408 10 0409 C0 : MAX CYLINDERS : MAX HEADS : START REDUCED WRITE CURRENT CYL : START WRITE PRECOMPENSATION CYL : START WRITE RECOMPENSATION CYL : STANDARD BYTE : STANDARD TIME OUT : TIME OUT FOR FORMAT DRIVE : TIME FOR CHECK DRIVE : LANDING ZOME : SECTORS/TRACK : RESERVED DW DB DW DB DB DB DB DB DB DB 0306D 0306D 04D 0306D 0 0BH 919 920 921 922 923 924 925 00000101B 010H 0C0H 028H 0306D 017D 040A 28 926 927 928 929 930 931 040B 0132 040D 11 040E 00 :---- DRIVE TABLE I 040F 0264 0411 04 0412 0264 0414 0000 0416 0B 0417 05 0418 28 0419 E0 041A 42 041B 0297 041D 11 041E 00 : MAX CYLINDERS : MAX HEADS : MAX HEADS : START REDUCED WRITE CURRENT CYL : START WRITE PRECOMPENSATION CYL : START WRITE RECOMPENSATION CYL : STANDARD HIME OUT : TIME OUT FOR FORMAT DRIVE : TIME FOR CHECK DRIVE : LANDING ZOME : SECTORS/TRACK : RESERVED 932 DW DB DW DB DB DB DB DB DB 0612D 04D 0612D 0 0BH 000001018 028H 0E0H 042H 0663D 017D 938 939 940 941 942 943 944 945 946 947 DB ;---- DRIVE TABLE 2 : MAX CYLINDERS : MAX HEADS : MAX HEADS : START REDUCED WRITE CURRENT CYL : START WRITE PRECOMPENSATION CYL : START WRITE PRECOMPENSATION CYL : STANDARD HIME OUT : TIME OUT FOR FORMAT DRIVE : TIME FOR CHECK DRIVE : LAMDING ZOME : SECTORS/TRACK : RESERVED 041F 0267 0421 04 0422 0267 0424 012C DW DW DW DB 0615D 04D 0615D 0300D 948 949 950 951 952 953 954 955 956 957 958 0424 012C 0426 0B 0427 05 0428 28 0429 E0 042A 42 042B 0267 042D 11 042E 00 00000101B DB 028H 0E0H 042H DB DB DB DW DB 0615D 017D 960 961 962 963 964 965 966 967 968 970 971 ;---- DRIVE TABLE 3 : MAX CYLINDERS : MAX HEADS : MAX HEADS : START REDUCED WRITE CURRENT CYL : START WRITE PRECOMPENSATION CYL MCONTEOL BYE : STANDARD HIME OUT : TIME OUT FOR FORMAT DRIVE : TIME FOR CHECK DRIVE : LANDING ZONE : SECTORS/TRACK : RESERVED 042F 0132 0431 08 0432 0132 0434 0080 0436 0B 0306D DW DB DW DB DB DB DB DB DB 0306D 0128D 0128D 0BH 00000101B 028H 0E0H 042H 0336D 0436 0B 0437 05 0438 28 0439 E0 043A 42 043B 0150 043D 11 043E 00 017D ``` ``` INITIALIZE DRIVE 978 979 980 981 982 983 984 985 986 987 988 989 043F 043F C6 46 F8 0C 0443 C6 46 F9 00 0447 E8 0458 R 044A 72 0B MOV ;---- DO DRIVE ONE 044C C6 46 F8 0C 0450 C6 46 F9 20 0454 E8 0458 R 0457 0457 C3 CMD_BLOCK+0,INIT_DRY_CMD CMD_BLOCK+1,00100000B ; SET TO DRIVE I INIT_DRY_R ; SEND THE PARAMETERS MOV 990 991 992 993 994 995 996 997 998 CALL INIT_DRV_OUT: 996 997 0458 2A CO 999 045A 2A CO 999 045A 2A CO 1000 045D 73 01 1001 045F C3 1002 0460 1003 0460 8C D9 INIT_DRV_R SUB CALL JNC RET PROC NEAR AL, AL COMMAND ; ISSUE THE COMMAND ; DX = PORT 0 AFTER CALL MOV CX,DS ; SAVE SEGMENT ASSUME DS:ABS0 SUB AX,AX MOV DS,AX LES BX,HF_TBL_VEC MOV DS,CX 1005 1005 1006 0462 2B C0 1007 0464 8E D8 1008 0466 C4 IE 0104 R 1009 046A 8E D9 : ESTABLISH SEGMENT : LOAD THE TABLE VECTOR : RESTORE SEGMENT ASSUME DS:DATA DETERMINE PARAMETER TABLE OFFSET : USING CONTROLLER PORT TWO AND : DRIVE NUMBER SPECIFIER (0-1) : : INC DX : ADDRESS INC DX : ADDRESS IN AL, DX READ TH 1011 1013 1014 1015 1016 DX AL,DX AH,CMD_BLOCK+1 AH,00100000B B2 AL,1 AL,1 ; ADDRESS PORT 2 ; READ THE SWITCH SETTINGS ; DRIVE 0 OR 1 AL,011B CL,4 AL,CL AH,AH BX,AX AH,00001001B AND MOV SHL SUB ADD ; ISOLATE ; ADJUST MOV : SET MASK FOR DATA MODE CPU TO CARD ;---- SEND DRIVE PARAMETERS MOST SIGNIFICANT BYTE FIRST 1033 MOV CALL JC 1038 DI,0 INIT_DRV_S 1038 1039 048F BF 0000 1040 0492 E8 04E9 R 1041 0495 72 44 MOV CALL ; SEND LSB OF MAX CYLINDER 1041 0495 72 44 1042 1043 0497 BF 0002 1044 049A E8 04E9 R 1045 049D 72 3C D1,2 INIT_DRV_S MOV ; SEND THE MAXIMUM HEADS CALL 1045 0490 72 3C 1046 1047 049F BF 0004 1048 04A2 E8 04E9 R 1049 04A5 72 34 1050 DI,4 INIT_DRV_S B3 MOV ; SEND MSB OF REDUCE WRITE CURRENT ; CYLINDER 1050 1051 04A7 BF 0003 1052 04AA E8 04E9 R 1053 04AD 72 2C ; SEND LSB OF REDUCE WRITE CURRENT ; CYLINDER DI,3 INIT_DRV_S MOV CALL JC 1054 1054 1055 04AF BF 0006 1056 04B2 E8 04E9 R 1057 04B5 72 24 MOV CALL JC ; SEND MSB OF WRITE PRECOMP CYLINDER 04B7 BF 0005 04BA E8 04E9 R 04BD 72 IC MOV CALL DI,5 INIT_DRV_S : SEND LSB OF WRITE PRECOMP CYLINDER 1060 1060 04BA E8 04E9 R 1061 04BD 72 IC 1062 1063 04BF BF 0007 1064 04C2 E8 04E9 R 1065 04C5 72 14 1065 04C5 /2 14 1066 1067 04C7 BF 0008 1068 04CA 26: 8A 01 1069 04CD A2 0076 R 1071 04D0 2B C9 1072 04D2 B4 0F DI,8 AL,ES:[BX+DI] CONTROL_BYTE,AL ; LOAD THE CONTROL BYTE AND PLACE IN MEMORY AT 40:76H MOV MOV 1069 04CD A2 0076 R 1071 04DD 2B C9 1071 04DD 2B C9 1072 04DB 84 0F 1074 04D4 E8 06BD R 1075 04D7 73 09 1076 04D9 E 1078 04DB C6 06 0074 R 07 1079 04EC F9 1080 04EI C3 1081 04E2 A 1082 04E2 A 1082 04E6 C4 1084 04E8 C3 1085 04E6 C3 1086 04E8 C3 1086 04E8 C3 CX,CX AH,00001111B ; SET THE MASK FOR STATUS MODE ; GO WAIT FOR THE STATE TO HAPPEN ; JMP TO READ THE STATUS BYTE ; TRY AGAIN CALL JNC LOOP HD_WAIT B6 B5 MOV STC RET DISK_STATUS.INIT_FAIL ; OPERATION FAILED ; SET THE ERROR CONDITION DEC IN AND JNZ RET DX AL,DX AL,2 B3 : ADDRESS PORT 0 : READ STATUS BYTE OF THE OPERATION : MASK ERROR BIT : ERROR BIT SET? INIT DRY R ENDP ``` ``` 1088 ;---- SEND THE BYTE OUT TO THE CONTROLLER ; GO WAIT FOR REQUEST ; AFTER CALL DX = PORT 1 ; ADDRESS PORT 0 : WRITE THE DATA TO THE CARD 1102 1104 1105 04F4 1106 04F4 E8 050E R 1107 04F7 72 5F 1108 04F9 C6 46 F8 E5 1109 04FD 80 47 1110 04FF EB 5D 1111 0501 1112 1115 1104 PROC NEAR CHK_LONG G8 CMD_BLOCK+0,RD_LONG_CMD AL,DMA_READ SHORT DMA_OPN ENDP CALL JC MOV MOV RD_LONG 1115 1116 1117 0501 1118 0501 E8 050E R 1119 0504 72 52 1120 0506 C6 46 F8 E6 1121 050A B0 4B 1122 050C EB 50 WR_LONG CALL JC MOV MOV JMP WR_LONG PROC NEAR CHK_LONG G8 CMD_BLOCK+0,WR_LONG_CMD AL,DMA_WRITE SHORT DMA_OPN ENDP 1122 050C EB 50 1123 050C 1124 1125 050E 1126 050E 8A 46 FC 1127 0511 3C 80 1128 0513 F5 1129 0514 C3 1130 0515 1131 1132 PROC NEAR AL,CMD_BLOCK+4 AL,080H ; LOAD THE NUMBER OF SECTORS ; COMPARE WITH LIMITS ; SET THE CONDITION PROC NEAR CMD_BLOCK+0, SEEK_CMD SHORT NDMA_OPN FNDP NEAR CMD_BLOCK+0,RD_BUFF_CMD CMD_BLOCK+4,1 AL,DMA_READ SHORT DMA_OPN RD_BUFF PROC RD_BUFF ENDP WRITE SECTOR BUFFER NEAR CMD_BLOCK+0,WR_BUFF_CMD CMD_BLOCK+4,1 AL,DMA_WRITE SHORT DMA_OPN MOV MOV MOV JMP WR_BUFF ENDP TST_RDY PROC MOV JMP TST_RDY ENDP HDISK_RECAL MOV JMP HDISK_RECAL PROC NEAR CMD_BLOCK+0,RECAL_CMD SHORT NDMA_OPN ENDP ``` ``` CONTROLLER RAM DIAGNOSTICS 1183 1184 1185 053F 1186 053F C6 46 F8 E0 1187 0543 EB 0A 1188 0545 1190 1190 1191 1191 1192 1193 1194 1195 1196 0545 C6 46 F8 E3 1196 0548 1197 0548 PROC NEAR CMD_BLOCK+0,RAM_DIAG_CMD SHORT NDMA_OPR ENDP DRIVE DIAGNOSTICS (AH = 013H): CHK_DRV PROC MOV JMP CHK_DRV ENDP NEAR CMD BLOCK+0,CHK_DRY_CMD SHORT NDMA_OPN 1199 1200 1201 1202 1203 054B 1204 054B C6 46 F8 E4 1205 054F CONTROLLER INTERNAL DIAGNOSTICS (AH = 014H) : CNTLR_DIAG PROC NEAR CMD_BLOCK+0,CNTLR_DIAG_CMD ENDF MOV CALL JC JMP AL,02H COMMAND : ISSUE THE COMMAND GII SHORT G3 DISK_STATUS,DMA_BOUNDARY RET 1218 055D C3 1219 055E E8 06A5 R 1219 055E E8 06A5 R 1222 0656 172 F5 1222 0656 80 03 1223 0655 E8 05TC R 1224 0566 87 20 E 1225 056A 80 03 1223 0656 F4 1226 056E F4 1230 0571 24 DF 1231 0573 E6 21 1231 0573 E6 21 1232 0575 E8 0700 R 1234 0576 E8 05AD R 1235 0576 E8 05AD R 1236 0578 E8 05AD R 1236 0578 C3 DMA_OPN: CALL JC MOV CALL JC MOV DMA_SETUP ; SET UP FOR DMA OPERATION G8 AL,03H COMMAND ; ISSUE THE COMMAND G11 AL,03H DMA+10,AL : INITIALIZE THE DISK CHANNEL OUT 63. CLI IN AND OUT CALL ; NO INTERRUPTS ; READ THE MASK ; ENABLE IRQ-5 ; WRITE THE MASK OUT ; PROCEDURE DOES STI AL, INTAO1 AL, ODFH INTAO1, AL WAIT_INT ; SEE IF THERE IS AN ERROR ; EXIT ERROR_CHK COMMAND: THIS ROUTINE OUTPUTS THE COMMAND BLOCK 1238 1239 1240 1241 1241 1242 1243 1244 1245 1242 | 1243 | 1244 | 1245 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 1246 | 12 NEAR PORT_0 DX DX DX,AL DX CX,CX CALL INC INC OUT INC ; GET THE BASE ADDRESS ; ADDRESS PORT 2 ; ISSUE CONTROLLER SELECT PULSE ; ADDRESS PORT 3 ; WAIT COUNT ; WRITE DMA MASK REGISTER SUB OUT DEC : ADDRESS PORT 1 Y: IN AND CMP JE LOOP MOV STC RET AL,DX AL,OFH AL,RI_BUSY OR RI_BUS OR RI_REQ : CHECK FOR BUSY,COMMAND CI : AND REQUEST BITS WALT BUSY : KEEP TRYING ; SET THE ERROR CONDITION ; ERROR RETURN MOV DEC MOV SUB CL I ; SET FOR 6 BYTES OF COMMAND ; ADDRESS PORT 0 ; SAVE THE BASE POINTER ; SET FIRST BYTE OF COMMAND BLOCK ; NO INTERRUPTS IN COMMAND SEQUENCE CX,6 DX SI,BP BP,8 ; GET A COMMAND BYTE ; ALLOW AT LEAST 20s BETWEEN EACH BYTE ; ON SENDING THE COMMAND SEQUENCE. ; DO MORE ; RESTORE THE BASE POINTER ; INTERRUPTS BACK ON MOV OUT INC BP CM3 LOOP MOV STI RET COMMAND ENDP ``` ``` 1280 SENSE STATUS BYTES 1282 BYTE 0 BIT 7 BIT 6 BITS 5-4 BITS 3-0 ADDRESS VALID, WHEN SET SPARE, SET TO ZERO ERROR TYPE ERROR CODE 1286 1287 1288 1289 BITS 7-6 BIT 5 BITS 4-0 ZERO DRIVE (0-1) HEAD NUMBER 1294 1295 BITS 7-5 CYLINDER HIGH BITS 4-0 SECTOR NUMBER 1296 1297 1298 1299 1300 1302 1302 1303 05AD 1304 05AD AO 0074 R 1305 05BO 0A CO 1306 05B2 75 01 1307 05B4 C3 PROC AL,DISK_STATUS AL,AL G21 ; CHECK IF THERE WAS AN ERROR ; ANYTHING IN AL? 1308 1309 PERFORM SENSE STATUS : ; SENSE STATUS CAN BE ISSUED MULTIPLE ; TIMES MOV SUB CALL CMD_BLOCK+0,SENSE_CMD AL,AL COMMAND : WRITE ZERO IN INT/DMA MASK : ISSUE SENSE STATUS COMMAND : CANNOT RECOVER-EXIT WITH COMMAND : ERROR : SET INDEX POINTER TO ZERO : READ FOUR BYTES : SET MASK FOR DATA MODE CARD TO CPU DI,DI MOV CX,4 AH,00001011B G22: HD WAIT G24 DX AL,DX [DI+CMD_BLOCK],AL DI G22 ; GO WAIT FOR DATA INPUT STATE CALL JC DEC IN MOV INC : ADDRESS PORT 0 : READ THE DATA BYTE : STORE AWAY SENSE BYTES : NEXT DATA LOCATION : LOOP TILL ALL FOUR READ. : SET THE MASK FOR STATUS MODE : GO WAIT FOR STATUS STATE : GO WAIT FOR STATUS STATE LOOP AH,00001111B HD WAIT G24 DX AL,DX MOV CALL JC DEC ; ADDRESS PORT 0 ; READ THE STATUS BYTE ; SENSE OPERATION FAIL? ; GO GET THE ERROR. IN TEST AL,2 STAT_ERR JZ 1337 050F 74 0F 1338 05E1 C6 06 0074 R FF 1340 05E6 1341 05E6 F9 1342 05E7 C3 1343 05E8 1344 05E8 1344 05E8 06IE R 1346 05E8 06ER 1346 05E8 06ER 1347 05EC 066D R 1348 05EE 067A R 1349 05EE 067A R DISK_STATUS, SENSE_FAIL ; SET SENSE OPERATION FAIL MOV STC RET FNDP TYPE_0 TYPE_1 TYPE_2 TYPE_3 DW DW DW DW : ERROR TYPE JUMP TABLE 1349 1350 05F0 1351 05F0 8A 5E F8 1352 05F3 8A C3 1353 05F5 24 0F 1354 05F7 80 E3 30 1355 05FA 2A FF 1356 05FC B1 03 1356 05FC B1 03 STAT_ERR: BL,CMD_BLOCK+0 AL,BL AL,OFH BL,00110000B BH,BH MOV MOV AND AND SUB MOV SHR : GET ERROR BYTE ; ISOLATE THE TYPE OF ERROR BX,CL ; ADJUST WORD PTR CS:[BX + OFFSET T_0] 1369 1360 0605 1361 0605 00 20 40 CC 80 00 1362 20 1363 060C 00 40 1364 = 0009 TYPE0_TABLE DB LABEL BYTE 0,BAD_CNTLR,BAD_SEEK,WRITE_FAULT,TIME_OUT,0,BAD_CNTLR 0,BAD_SEEK EQU $-TYPE0_TABLE DB TYPE0_LEN 1364 = 0009 1365 1366 060E 1367 060E 04 10 02 00 04 1368 0613 40 00 00 11 0B 1369 = 000A LABEL BYTE RECORD NOT_FND,BAD_ECC,BAD_ADDR_MARK,0,RECORD_NOT_FND BAD_SEEK,0,0,DATA_CORRECTED,BAD_TRACK EQU $-TYPE!_TABLE TYPE I_TABLE 1370 1371 0618 1372 0618 01 02 01 1373 = 0003 1374 1375 061B 1376 061B 20 20 10 1377 = 0003 LABEL BYTE BAD_CMD,BAD_ADDR_MARK,BAD_CMD EQU $-TYPE2_TABLE TYPE2_TABLE TYPEZ_LEN LABEL BYTE BAD_CNTLR,BAD_CNTLR,BAD_ECC EQU $-TYPE3_TABLE TYPE3_TABLE DB TYPE3 LEN ``` ``` PAGE ;---- TYPE 0 ERROR MOV CMP JAE BX,OFFSET TYPEO_TABLE AL,TYPEO LEN UNDEF ERR L CS:TYPEO_TABLE ; CHECK IF ERROR IS DEFINED : TABLE LOOKUP ;---- TYPE 1 ERROR BX,OFFSET TYPEI_TABLE CX,AX AL,TYPEI LEN UNDEF ERR L CS:TYPEI TABLE DISK_STATUS,AL CL,08H CL,08H MOV MOV CMP JAE XLAT MOV ; CHECK IF ERROR IS DEFINED ; TABLE LOOKUP ; SET ERROR CODE ; CORRECTED ECC AND 1399 063C 80 F9 08 1400 053F 75 29 1400 054F 75 29 1400 054F 75 29 1400 054F 75 29 1400 064F 26 064F 26 064F 26 064F 26 068D 8 1410 064F 72 18 9 1400 064F 88 068D R 1410 065F 172 17 1411 0653 4A 1412 0666F 172 17 1411 0653 4A 1418 065F 84 1416 065C 72 06 1417 065F 84 1418 85 JNZ OBTAIN ECC ERROR BURST LENGTH MOV SUB CALL CMD_BLOCK+0,RD_ECC_CMD AL,AL COMMAND CDMMAND G30 AH,00001011B HD WAIT G30 DX AL,DX CL,AL AH,00001111B HD WAIT G30 DX AL,DX AL,DX AL,DX AL,DX AL,DX AL,DX AL,DX AL,DX AL,2 G30 DISK STATUS.E ; ISSUE THE COMMAND JC MOV CALL JC DEC : ADDRESS PORT 0 : READ THE LENGTH OF THE ERROR : CORRECTED AND SAVE IN CL : SET MASK FOR STATUS STATE : GO WAIT FOR STATUS STATE IN MOV MOV CALL JC DEC ; ADDRESS PORT 0 ; READ THE STATUS BYTE ; ERROR BIT SET? IN TEST DISK_STATUS, BAD_CNTLR ;---- TYPE 2 ERROR TYPE_2: MOV CMP JAE BX,OFFSET TYPE2_TABLE AL,TYPE2 LEN UNDEF_ERR L CS:TYPE2 TABLE DISK_STATUS,AL ; CHECK IF ERROR IS DEFINED : TABLE LOOKUP MOV : SET ERROR CODE ;---- TYPE 3 ERROR MOV CMP JAE XLAT MOV RET BX,OFFSET TYPE3_TABLE AL,TYPE3 LEN UNDEF ERR L CS:TYPE3 TABLE DISK_STATUS,AL ; CHECK IF ERROR IS DEFINED ; TABLE LOOKUP ; SET ERROR CODE UNDEF_ERR_L: DISK_STATUS, UNDEF_ERR ON ENTRY AH CONTAINS THE CONTROLLER BUS STATUS DECODE : MASK USED TO CHECK THE HARDWARE STATUS. PROC CX CX,CX HD_WAIT PUSH SUB ; SAVE CX ; SET THE LOOP COUNT PORT_0 CALL INC IN AND CMP JZ LOOP MOV ; PORT_1 ADDRESS ; READ THE HARDWARE STATUS ; CLEAR UPPER NIBBLE OF HARDWARE STATUS ; CHECK THE STATE WITH THE MASK ; JMP IF O.K WITH CARRY CLEARED ; TRY AGAIN DX — AL,DX AL,00001111B AL,AH L2 LI DISK_STATUS,TIME_OUT : SET ERROR CONDITION STC L2: POP : RESTORE CX СХ HD_WAIT ENDP ``` ``` DMA_SETUP THIS ROUTINE SETS UP FOR DMA OPERATIONS. : INPUT : (AL) = MODE BYTE FOR THE DMA (ES:BX) = ADDRESS TO READ/WRITE THE DATA ... - ADDRESS TO F DMA_SETUP PROC NEAR CMD_BLOCK+4,81H J1 CMP JB ; BLOCK COUNT OUT OF RANGE : SET THE ERROR CONDITION : NO MORE INTERRUPTS : SET THE FIRST/LAST F/F : SHIFT COUNT : OUTPUT THE MODE BYTE : GET THE ES VALUE : ROTATE LEFT : GET HELEST NIBBLE OF ES TO CH : ZERO THE LOW NIBBLE FROM SEGMENT : TEST FOR CARRY FROM ADDITION : CARRY MEANS HIGH 4 BITS MUST BE INC CLI OUT MOV OUT MOV ROL MOV AND ADD ADD DMA+12,AL CL,4 DMA+11,AL AX,ES AX,CL CH,AL AL,OFOH AX,BX CH,0 1501 1502 06C1 8B F0 1503 06C3 E6 06 1504 06C5 8A C4 1505 06C7 E6 06 1506 06C9 8A C5 1507 06CB 24 0F 1508 06CD E6 82 1501 SI,AX DMA+6,AL AL,AH DMA+6,AL AL,CH AL,OFH DMA_HIGH,AL ; SAVE START ADDRESS ; OUTPUT LOW ADDRESS MOV MOV MOV OUT MOV AND OUT ; OUTPUT HIGH ADDRESS ; GET HIGH 4 BITS 1509 00CD E6 82 1509 1510 1511 1512 06CF 8A 66 FC 1513 06DC 2D E4 1513 06DC 32 C0 1515 06DC 8A 76 FC 1516 06D 8A 76 FC 1516 06D 8A 76 FC 1517 06DF 74 06 1520 06DF 74 06 1522 06DD 80 7E F8 E6 1523 06EF 175 0F 1524 06ES 53 FF 1524 06ES 53 FF 1525 06ES 53 FF 1526 06ES 54 FF 1527 06EC 52 1528 06EC 54 1529 06EC 54 1529 06EC 54 1520 06EC 54 1520 06EC 54 1520 06EC 54 1520 06EC 54 1520 06EC 54 1520 06EC 55 1521 06EC 54 1523 06EC 54 1525 06EC 54 1525 06EC 55 1526 06EC 54 1527 06EC 54 1528 06EC 54 1528 06EC 54 1528 06EC 54 1529 06EC 55 1529 06EC 55 1529 06EC 54 1529 06EC 54 1529 06EC 54 1529 06EC 54 1529 06EC 55 1529 06EC 55 1529 06EC 56 0 ; OUTPUT THE HIGH 4 BITS TO PAGE REG ;---- DETERMINE COUNT MOV SHL XOR DEC AH,CMD_BLOCK+4 AH,1 AL,AL AX ; RECOVER BLOCK COUNT ; MULTIPLY BY 512 BYTES PER SECTOR ; CLEAR LOW BYTE ; CLEAR LOW BYTE ; AND DECREMENT VALUE BY ONE ;---- HANDLE READ AND WRITE LONG (516D BYTE BLOCKS) CMD_BLOCK+0,RD_LONG_CMD CMD_BLOCK+0,WR_LONG_CMD . INF ADD4: MOV PUSH SUB MOV AX,516D BX BH,BH ; ONE BLOCK (512) PLUS 4 BYTES ECC BL,CMD_BLOCK+4 PUSH MUL POP POP DEC BX DX BX AX : BLOCK COUNT TIMES 516 ; SAVE COUNT VALUE ; LOW BYTE OF COUNT MOV OUT MOV OUT STI MOV ADD AL,AH DMA+7,AL ; HIGH BYTE OF COUNT ; INTERRUPTS BACK ON ; RECOVER ADDRESS VALUE ; ADD, TEST FOR 64K OYERFLOW ; RETURN TO CALLER, ; CY SET BY ABOVE IF ERROR RET 1543 1544 0700 DMA_SETUP ENDP ``` ``` IBM Personal Computer MACRO Assembler Version 2.00 DISK2 ---- 10/28/85 FIXED DISK BIOS 10-28-85 WAIT_INT INT THIS ROUTINE WAITS FOR THE FIXED DISK CONTROLLER TO SIGNAL THAT AN INTERRUPT HAS OCCURRED. ASSUME DS: ABSO STI MOV BX, DS SUB AX, AX MOV DS, AX LES SI ; TURN ON INTERRUPTS ; SAVE DS BX,DS AX,AX DS,AX SI,HF_TBL_VEC : ESTABLISH SEGMENT : LOAD THE TABLE VECTOR ASSUME DS:DATA,ES:NOTHING 1561 1562 070B 8E DB 1563 1564 1565 1566 070D 2A FF 1567 070F 26: 84 1568 0713 8A 66 1569 0716 8B FC : RESTORE DS SET TIMEOUT VALUES 1566 070D 2A FF 1566 070D 2A FF 1567 070F 26: 8A 5C 09 1568 0713 8A 66 FB 1569 0716 80 FC 04 1570 0719 75 06 1571 1572 0718 26: 8A 5C 0A 1573 071F EB 09 1574 0721 80 FC E3 1575 0724 75 04 1575 0724 75 04 SUB MOV MOV CMP BH,BH BL,BYTE PTR ES:[SI][9] ; LOAD THE STANDARD TIME OUT AH, CMD_BLOCK+0 AH, FMTDRV_CMD JNZ BL,BYTE PTR ES:[SI][OAH] SHORT W4 AH,CHK_DRV_CMD W4 ; LOAD THE FORMAT DRIVE ; TIME OUT VALUE JMP CMP JNZ W5: 1575 0724 75 04 1576 1577 0726 26: 8A 5C 0B 1578 072A 1579 072A F8 1580 072B B8 9000 1581 072E CD 15 1582 0730 FB ; LOAD THE CHECK DRIVE ; TIME OUT VALUE ; CLEAR CY ; DEVICE WAIT INTERRUPT MOV BL, BYTE PTR ES:[SI][OBH] CLC MOV INT STI ; ENABLE INTERRUPTS FOR PC AND 1582 0730 FB 1583 1584 0731 2B C9 1585 1586 1586 1586 1587 1588 0733 E8 0760 R 1599 0738 42 1599 0736 A2 1591 0736 A0 20 1593 073A 75 0A 1594 073C E2 F5 1596 073C E2 F5 1596 073C E2 F5 ; XT MACHINES. ; SET THE LOOP COUNT SUB cx,cx ;---- WAIT FOR INTERRUPT W1: CALL PORT_0 DX AL,DX AL,020H W2 ; PORT_I ADDRESS ; READ_THE HARDWARE STATUS ; DID INTERRUPT OCCUR ; JUMP IF YES LOOP : INNER LOOP DEC 1598 073F 75 F2 1598 0741 C6 06 0074 R 80 1599 0741 C6 06 0074 R 80 1600 0746 4A 1602 0747 EC 1603 0748 24 02 1604 0744 08 06 0074 R 1605 074E 83 C2 03 1606 0751 32 C0 1607 0753 EE 1607 0755 C3 0 JNZ : OUTER LOOP MOV DISK_STATUS,TIME_OUT : ADDRESS PORT 0 : READ THE STATUS BYTE : ISOLATE THE ERROR BIT : SAVE IN THE STATUS : PORT 3 ADDRESS : ZERO" ; RESET INTERRUPT MASK DEC DX AL,DX AL,2 DISK_STATUS,AL DX,3 AL,AL DX,AL IN AND OR ADD XOR OUT WAIT_INT FNDP 1610 1611 1612 1613 1614 1615 1616 FIXED DISK INTERRUPT ODH ROUTINE IRQ-5 HD_INT PROC PUSH MOV OUT CL! IN OR OUT MOV OUT ST! MOV INT POP NEAR AX AL,07H DMA+10,AL ; SAVE WORK REGISTER ; SET DMA MODE TO DISABLE : NO INTERRUPTS : LOAD THE INTERRUPT ENABLE MASK : LURN OFF FIXED DISK IRQ-5 : REPLACE THE MASK : LOAD THE END OF INTERRUPT MASK : CLEAR THE ACTIVE INTERRUPT LEVEL : INTERRUPTS BACK ON : DEVICE POST : INTERRUPT AL, INTAO1 AL,020H INTAO1, AL AL,EOI INTAOO, AL AX,9100H 15H AX : INTERRUPT : RESTORE AX GENERATE PROPER PORT VALUE BASED ON THE PORT OFFSET NEAR DX,HF_PORT DL,PORT_OFF ; BASE VALUE ; ADD IN OFFSET VALUE (00.04.08.0C) MOV ADD PORT_0 ENDP END_ADDRESS CODE ENDS LABEL BYTE ``` END ## **Notes:** # Index | A | F | |-------------------------------------------------------|--------------------------------------------------| | addresses, port 14 | fixed disk controller 1 fixed disk drive types 3 | | BIOS listings 23 | I | | block diagram 2 | interface 15<br>interface signals<br>AEN 15 | | <b>C</b> | A0-A19 15<br>-DACK 3 16<br>DO-D7 15 | | command summary 10<br>connectors 17<br>control byte 8 | DRQ 3 15<br>-IOR 15<br>-IOW 15 | | controller, fixed disk 1 | IRQ 5 15<br>RESET 15 | | D data register. 7 | L | | data register 7<br>description 1 | logic diagrams 19 | | E | | error tables 5 port addresses 14 sense bytes 4 specifications 17 considerations 3 status register 4 switch settings 3 R T TTL levels 17 registers 1 # IBM Asynchronous Communications Adapter # **Contents** | Description | 1 | |----------------------------------------------------|-----| | Programming Considerations | | | Modes Of Operation | | | Line-Control Register | 5 | | Programmable Baud-Rate Generator | | | Line Status Register (LSR) | | | Interrupt Identification Register (IIR) | | | Interrupt Enable Register | | | Modem Control Register | | | Modem Status Register | | | Receiver Buffer Register | | | Transmitter Holding Register | 19 | | Selecting the Interface Format and Adapter Address | 20 | | Interrupts | 21 | | Interface | 23 | | Voltage Interchange Information | 24 | | INS8250 Functional Pin Description | 25 | | Specifications | 31 | | Logic Diagrams | 33 | | indov Indov | _ 1 | ### **Description** The Asynchronous Communications Adapter's system control signals and voltage requirements are provided through a 2- by 31-position card-edge connector. Two jumper modules are provided on the adapter. One jumper module selects either RS-232C or current-loop operation. The other jumper module selects one of two addresses for the adapter, so two adapters may be used in one system. An additional jumper is required on connector J13 if the adapter is to be installed in expansion slot 8 of an IBM Personal Computer XT or IBM Portable Personal Computer (see "Selecting the Interface Format and Adapter Address" in this section). The adapter is fully programmable and supports asynchronous communications only. It will add and remove start bits, stop bits, and parity bits. A programmable baud-rate generator allows operation from 50 baud to 9600 baud. Five-, six-, seven-, or eight-bit characters with 1, 1-1/2, or 2 stop bits are supported. A fully prioritized interrupt system controls transmit, receive, error, line status, and data set interrupts. Diagnostic capabilities provide loopback functions of transmit/receive and input/output signals. The major component of the adapter is an INS8250 LSI chip or functional equivalent. Features in addition to those listed above are: - Full double buffering eliminating the need for precise synchronization - Independent receiver clock input - False-start bit detection - Line-break generation and detection #### • Modem control functions: Clear to send (CTS) Request to send (RTS) Data set ready (DSR) Data terminal ready (DTR) Ring indicator (RI) Carrier detect (CD) All communication protocol is a function of the system microcode and must be loaded before the adapter is operational. All pacing of the interface and control signal status must be handled by the system software. The following figure is a block diagram of the IBM Asynchronous Communications Adapter. Asynchronous Communications Adapter Block Diagram ### **Programming Considerations** ### **Modes Of Operation** The different modes of operation are selected by programming the 8250 Asynchronous Communications Element. This is done by selecting the I/O address (hex 3F8 to 3FF primary, and hex 2F8 to 2FF secondary) and writing data out to the adapter. Address bits A0, A1, and A2, select the different registers that define the modes of operation. Also, bit 7—the divisor latch access bit (DLAB)—of the line-control register is used to select certain registers. | I/O Deco | ode (in Hex) | | | |--------------------------------------|--------------|------------------------------------|------------------| | Primary Alternate<br>Adapter Adapter | | Register Selected | DLAB State | | 3F8 | 2F8 | TX Buffer | DLAB = 0 (Write) | | 3F8 | 2F8 | RX Buffer | DLAB = 0 (Read) | | 3F8 | 2F8 | Divisor Latch LSB | DLAB = 1 | | 3F9 | 2F9 | Divisor Latch MSB | DLAB = 1 | | 3F9 | 2F9 | Interrupt Enable Register | | | 3FA | 2FA | Interrupt Identification Registers | | | 3FB | 2FB | Line Control Register | | | 3FC | 2FC | Modem Control Register | | | 3FD | 2FD | Line Status Register | | | 3FE | 2FE | Modem Status Register | | I/O Decodes | | Hex Addresses 3F8 to 3FF AND 2F8 TO 2FF | | | | | | | | | | | |----|-----------------------------------------|----|----|------------|----|----|--------|--------|--------|------|------------------------------------------------------------| | А9 | A8 | Α7 | A6 | <b>A</b> 5 | Α4 | А3 | A2 | Α1 | A0 | DLAB | Register | | 1 | 1/0 | 1 | 1 | 1 | 1 | 1 | x<br>0 | x<br>0 | x<br>0 | 0 | Receive Buffer (read).<br>Transmit<br>Holding Reg. (write) | | | | | | | | | 0 | 0 | 1 | 0 | Interrupt Enable | | | | | | | | | 0 | 1 | 0 | x | Interrupt Identification | | | | | | | | | 0 | 1 | 1 | x | Line Control | | | | | | | | | 1 | 0 | 0 | х | Modem Control | | | | | | | | | 1 | 0 | 1 | x | Line Status | | | | | | | | | 1 | 1 | 0 | х | Modem Status | | | | | | | | | 1 | 1 | 1 | х | None | | | i | | | | | | 0 | 0 | 0 | 1 | Divisor Latch (LSB) | | | | | | | | | 0 | 0 | 1 | 1 | Divisor Latch (MSB) | **Note:** Bit 8 will be logical 1 for the adapter designated as primary or a logical 0 for the adapter designated as alternate (as defined by the address jumper module on the adapter). A2, A1 and A0 bits are "don't cares" and are used to select the different register of the communications chip. #### **Address Bits** #### **INS8250** The INS8250 has a number of accessible registers. The system programmer may access or control any of the INS8250 registers through the system unit's microprocessor. These registers are used to control INS8250 operations and to transmit and receive data. The following figure provides a listing and description of the accessible registers. | Register/Signal | Reset Control | Reset State | |--------------------------------------|---------------------------|-----------------------------------------------------------------| | Interrupt Enable Register | Master Reset | All bits Low (0-3 Forced and 4-7 Permanent). | | Interrupt Identification<br>Register | Master Reset | Bit 0 is High, Bits 1 and 2 Low<br>Bits 3-7 are Permanently Low | | Line Control Register | Master Reset | All Bits Low | | Modem Control Register | Master Reset | All Bits Low | | Line Status Register | Master Reset | Except Bits 5 and 6 are High | | Modem Status Register | Master Reset | Bits 0-3 Low<br>Bits 4-7 - Input Signal | | SOUT | Master Reset | High | | INTRPT (RCVR Errors) | Read LSR/MR | Low | | INTRPT (RCVR Data Ready) | Read RBR/MR | Low | | INTRPT (RCVR Data Ready) | Read IIR/<br>Write THR/MR | Low | | INTRPT (Modem Status<br>Changes) | Read MSR/MR | Low | | OUT 2 | Master Reset | High | | RTS | Master Reset | High | | DTR | Master Reset | High | | OUT 1 | Master Reset | High | **Asynchronous Communications Reset Functions** ### **Line-Control Register** The system programmer specifies the format of the asynchronous data communications exchange through the line-control register. In addition to controlling the format, the programmer may retrieve the contents of the line-control register for inspection. This feature simplifies system programming and eliminates the need for separate storage in system memory of the line characteristics. The contents of the line-control register are as follows: **Bits 0 and 1:** These two bits specify the number of bits in each transmitted or received serial character. The encoding of bits 0 and 1 is as follows: | Bit 1 | Bit 0 | Word Length 5 Bits | | | | |-------|-------|--------------------|--|--|--| | 0 | 0 | 5 Bits | | | | | 0 | 1 | 6 Bits | | | | | 1 | 0 | 7 Bits | | | | | 1 | 1 | 8 Bits | | | | Bit 2: This bit specifies the number of stop bits in each transmitted or received serial character. If bit 2 is a logical 0, one stop bit is generated or checked in the transmitted or received data, respectively. If bit 2 is logical 1 when a 5-bit word length is selected through bits 0 and 1, 1-1/2 stop bits are generated or checked. If bit 2 is logical 1 when either a 6-, 7-, or 8-bit word length is selected, two stop bits are generated or checked. Bit 3: This bit is the parity enable bit. When bit 3 is a logical 1, a parity bit is generated (transmit data) or checked (receive data) between the last data word bit and stop bit of the serial data. (The parity bit is used to produce an even or odd number of 1's when the data word bits and the parity bit are summed.) Bit 4: This bit is the even parity select bit. When bit 3 is a logical 1 and bit 4 is a logical 0, an odd number of logical 1's is transmitted or checked in the data word bits and parity bit. When bit 3 is a logical 1 and bit 4 is a logical 1, an even number of bits is transmitted or checked. Bit 5: This bit is the stick parity bit. When bit 3 is a logical 1 and bit 5 is a logical 1, the parity bit is transmitted and then detected by the receiver as a logical 0 if bit 4 is a logical 1, or as a logical 1 if bit 4 is a logical 0. Bit 6: This bit is the set break control bit. When bit 6 is a logical 1, the serial output (SOUT) is forced to the spacing (logical 0) state and remains there regardless of other transmitter activity. The set break is disabled by setting bit 6 to a logical 0. This feature enables the system unit's microprocessor to alert a terminal in a computer communications system. Bit 7: This bit is the divisor latch access bit (DLAB). It must be set high (logical 1) to access the divisor latches of the baud-rate generator during a read or write operation. It must be set low (logical 0) to access the receiver buffer, the transmitter holding register, or the interrupt enable register. ### **Programmable Baud-Rate Generator** The INS8250 contains a programmable baud-rate generator that is capable of taking the clock input (1.8432 MHz) and dividing it by any divisor from 1 to $(2^{16}-1)$ . The output frequency of the band generator is 16 x the band rate (divisor # =(frequency input)/(baud rate x 16)). Two 8-bit latches store the divisor in a 16-bit binary format. These divisor latches must be loaded during initialization in order to ensure desired operation of the baud-rate generator. Upon loading either of the divisor latches, a 16-bit baud counter is immediately loaded. This prevents long counts on initial load. **Divisor Latch Least Significant Bit (DLL)** **Divisor Latch Most Significant Bit (DLM)** The following figure illustrates the use of the baud-rate generator with a frequency of 1.8432 MHz. For baud rates of 9600 and below, the error obtained is minimal. Note: The maximum operating frequency of the baud-rate generator is 3.1 MHz. In no case should the data speed be greater than 9600 baud. | Desired<br>Baud<br>Rate | Divisor<br>to Gen<br>16x ( | Percent Error Difference Between Desired and Actual | | |-------------------------|----------------------------|-----------------------------------------------------|-------| | | (Decimal) | (Hex) | | | 50 | 2304 | 900 | | | 75 | 1536 | 600 | - 1 | | 110 | 1047 | 417 | 0.026 | | 134.5 | 857 | 359 | 0.058 | | 150 | 768 | 300 | | | 300 | 384 | 180 | - | | 600 | 192 | OCO | _ | | 1200 | 96 | 060 | | | 1800 | 64 | 040 | _ | | 2000 | 58 | 03A | 0.69 | | 2400 | 48 | 030 | · — | | 3600 | 32 | 020 | - | | 4800 | 24 | 018 | | | 7200 | 16 | 010 | | | 9600 | 12 | 00C | _ | Baud Rate at 1.843 MHz #### Line Status Register (LSR) This 8-bit register provides status information to the system unit's microprocessor concerning the data transfer. The contents of the line status register are indicated and described in the following figure. #### Line Status Register (LSR) Bit 0: This bit is the receiver data ready (DR) indicator. Bit 0 is set to logical 1 whenever a complete incoming character has been received and transferred into the receiver buffer register. Bit 0 may be reset to a logical 0 either by the system unit's microprocessor reading the data in the receiver buffer register or by writing logical 0 into it from the system unit's microprocessor. Bit 1: This bit is the overrun error (OE) indicator. Bit 1 indicates that data in the receiver buffer register was not read by the system unit's microprocessor before the next character was transferred into the receiver buffer register, thereby destroying the previous character. The OE indicator is reset whenever the system unit's microprocessor reads the contents of the line status register. **Bit 2:** This bit is the parity error (PE) indicator. Bit 2 indicates that the received data character does not have the correct even or odd parity, as selected by the even-parity select bit. The PE bit is set to logical 1 upon detection of a parity error and is reset to logical 0 whenever the system unit's microprocessor reads the contents of the line status register. Bit 3: This bit is the framing error (FE) indicator. Bit 3 indicates that the received character did not have a valid stop bit. Bit 3 is set to logical 1 whenever the stop bit following the last data bit or parity is detected as a zero bit (spacing level). Bit 4: This bit is the break interrupt (BI) indicator. Bit 4 is set to logical 1 whenever the received data input is held in the spacing (logical 0) state for longer than a full-word transmission time (that is, the total time of start bit + data bits + parity + stop bits). **Note:** Bits 1 through 4 are the error conditions that produce a receiver line status interrupt whenever any of the corresponding conditions are detected. **Bit 5:** This bit is the transmitter-holding-register-empty (THRE) indicator. Bit 5 indicates that the INS8250 is ready to accept a new character for transmission. In addition, this bit causes the INS8250 to issue an interrupt to the system unit's microprocessor when the transmit-holding-register-empty interrupt enable is set high. The THRE bit is set to logical 1 when a character is transferred from the transmitter holding register into the transmitter shift register. The bit is reset to logical 0 concurrently with the loading of the transmitter holding register by the system unit's microprocessor. **Bit 6:** This bit is the transmitter-shift-register-empty (TSRE) indicator. Bit 6 is set to logical 1 whenever the transmitter shift register is idle. It is reset to logical 0 upon a data transfer from the transmitter holding register to the transmitter shift register. Bit 6 is a read-only bit. Bit 7: This bit is permanently set to logical 0. ### **Interrupt Identification Register (IIR)** The INS8250 has an on-chip interrupt capability that allows for complete flexibility in interfacing to all the popular microprocessors presently available. In order to provide minimum software overhead during data character transfers, the INS8250 prioritizes interrupts into four levels: receiver line status (priority 1), received data ready (priority 2), transmitter holding register empty (priority 3), and modem status (priority 4). Information indicating that a prioritized interrupt is pending, and the type of prioritized interrupt, is stored in the interrupt identification register. Refer to the "Interrupt Control Functions" table. The interrupt identification register (IIR), when addressed during chip-select time, freezes the highest priority interrupt pending, and no other interrupts are acknowledged until that particular interrupt is serviced by the system unit's microprocessor. The contents of the IIR are indicated and described in the following figure. Interrupt Identification Register (IIR) Bit 0: This bit can be used in either a hard-wired prioritized or polled environment to indicate whether an interrupt is pending, and the IIR contents may be used as a pointer to the appropriate interrupt service routine. When bit 0 is logical 1, no interrupt is pending, and polling (if used) is continued. Bits 1 and 2: These two bits of the IIR are used to identify the highest priority interrupt pending, as indicated in the "Interrupt Control Functions" table. Bits 3 through 7: These five bits of the IIR are always logical 0. | Interrupt ID<br>Register | | | i | Interrupt Set | and Reset Function | ons | |--------------------------|-------|-------|----------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | Bit 2 | Bit 1 | Bit 0 | Priority Interrupt<br>Level Type | | Interrupt<br>Source | Interrupt<br>Reset Control | | 0 | 0 | 1 | _ | None | None | _ | | 1 | 1 | 0 | Highest | Receiver<br>Line Status | Overrun Error<br>or<br>Parity Error<br>or<br>Framing Error<br>or<br>Break Interrupt | Reading the<br>Line Status<br>Register | | 1 | 0 | 0 | Second | Received<br>Data Available | Receiver<br>Data Available | Reading the<br>Receiver Buffer<br>Register | | 0 | 1 | 0 | Third | Transmitter<br>Holding<br>Register<br>Empty | Transmitter<br>Holding<br>Register<br>Empty | Reading the IIR Register (if source of interrupt) or Writing into the Transmitter Holding Register | | 0 | 0 | 0 | Fourth | Modem<br>Status | Clear to Send<br>or<br>Data Set Ready<br>or<br>Ring Indicator<br>or<br>Received Line<br>Signal Direct | Reading the<br>Modem Status<br>Register | **Interrupt Control Functions** ### **Interrupt Enable Register** This 8-bit register enables the four types of interrupt of the INS8250 to separately activate the chip interrupt (INTRPT) output signal. It is possible to totally disable the interrupt system by resetting bits 0 through 3 of the interrupt enable register. Similarly, by setting the appropriate bits of this register to logical 1, selected interrupts can be enabled. Disabling the interrupt system inhibits the interrupt identification register and the active (high) INTRPT output from the chip. All other system functions operate in their normal manner, including the setting of the line status and modem status registers. The contents of the interrupt enable register are indicated and described in the following figure. #### Interrupt Enable Register (IER) **Bit 0:** This bit enables the received-data-available interrupt when set to logical 1. **Bit 1:** This bit enables the transmitter-holding-register-empty interrupt when set to logical 1. Bit 2: This bit enables the receiver-line-status interrupt when set to logical 1. Bit 3: This bit enables the modem-status interrupt when set to logical 1. Bits 4 through 7: These four bits are always logical 0. #### **Modem Control Register** This 8-bit register controls the interface with the modem or data set (or a peripheral device emulating a modem). The contents of the modem control register are indicated and described as follows: #### Modem Control Register (MCR) Bit 0: This bit controls the data terminal ready (-DTR) output. When bit 0 is set to a high level, the -DTR output is forced to an active low. When bit 0 is reset to low level, the -DTR output is forced high. **Note:** The -DTR output of the INS8250 may be applied to an EIA inverting line driver (such as the DS1488) to obtain the proper polarity input at the succeeding modem or data set. Bit 1: This bit controls the request to send (-RTS) output. Bit 1 affects the -RTS output in a manner identical to that described above for bit 0. Bit 2: This bit controls the output 1 (-OUT 1) signal, which is an auxiliary user-designated output. Bit 2 affects the -OUT 1 output in a manner identical to that described above for bit 0. **Bit 3:** This bit controls the output 2 (-OUT 2) signal, which is an auxiliary user-designated output. Bit 3 affects the -OUT 2 output in a manner identical to that described above for bit 0. Bit 4: This bit provides a loopback feature for diagnostic testing of the INS8250. When bit 4 is set to logical 1, the following occurs: the transmitter serial output (SOUT) is set to the marking (logical 1) state; the receiver serial input (SIN) is disconnected; the output of the transmitter shift register is "looped back" into the receiver shift register input; the four modem control inputs (-CTS, -DSR, -RLSD, and -RI) are disconnected; and the four modem control outputs (-DTR, -RTS, -OUT 1, and -OUT 2) are internally connected to the four modem control inputs. In the diagnostic mode, data that is transmitted is immediately received. This feature allows the system unit's microprocessor to verify the transmit-data and receive-data paths of the INS8250. In the diagnostic mode, the receiver and transmitter interrupts are fully operational. The modem control interrupts also are operational, but the interrupts' sources are now the lower four bits of the modem control register instead of the four modem control inputs. The interrupts are still controlled by the interrupt enable register. The INS8250 interrupt system can be tested by writing into the lower four bits of the modem status register. Setting any of these bits to a logical 1 generates the appropriate interrupt (if enabled). The resetting of these interrupts is the same as in normal INS8250 operation. To return to normal operation, the registers must be reprogrammed for normal operation, then bit 4 of the modem control register must be reset to logical 0. Bits 5 through 7: These bits are permanently set to logical 0. # **Modem Status Register** This 8-bit register provides the current state of the control lines from the modem (or peripheral device) to the system unit's microprocessor. In addition to this current-state information, four bits of the modem status register provide change information. These bits are set to logical 1 whenever a control input from the modem changes state. They are reset to logical 0 whenever the system unit's microprocessor reads the modem status register. The content of the modem status register is indicated and described in the following figure. #### Modem Status Register (MSR) **Bit 0:** This bit is the delta clear to send (DCTS) indicator. Bit 0 indicates that the -CTS input to the chip has changed state since the last time it was read by the system unit's microprocessor. Bit 1: This bit is the delta data set ready (DDSR) indicator. Bit 1 indicates that the -DSR input to the chip has changed state since the last time it was read by the system unit's microprocessor. **Bit 2:** This bit is the trailing edge of the ring indicator (TERI) detector. Bit 2 indicates that the -RI input to the chip has changed from an on (logical 1) to an off (logical 0) condition. **Bit 3:** This bit is the delta received line signal detector (DRLSD) indicator. Bit 3 indicates that the -RLSD input to the chip has changed state. **Note:** Whenever bit 0, 1, 2, or 3 is set to logical 1, a modem status interrupt is generated. **Bit 4:** This bit is the complement of the clear to send (-CTS) input. If bit 4 (LOOP) of the modem control register (MCR) is set to logical 1, the bit is equivalent to RTS in the MCR. Bit 5: This bit is the complement of the data set ready (-DSR) input. If bit 4 of the MCR is set to logical 1, the bit is equivalent to DTR in the MCR. **Bit 6:** This bit is the complement of the ring indicator (-RI) input. If bit 4 of the MCR is set to logical 1, the bit is equivalent to OUT 1 in the MCR. **Bit 7:** This bit is the complement of the received line signal detect (-RLSD) input. If bit 4 of the MCR is set to logical 1, the bit is equivalent to OUT 2 of the MCR. # **Receiver Buffer Register** The receiver buffer register contains the received character, which is defined in the following figure. #### Receiver Buffer Register (RBR) Bit 0 is the least-significant bit and is the first bit serially received. # **Transmitter Holding Register** The transmitter holding register contains the character to be serially transmitted and is defined as follows: **Transmitter Holding Register (THR)** Bit 0 is the least-significant bit and is the first bit serially transmitted. # **Selecting the Interface Format and Adapter Address** The voltage or current-loop interface and adapter address are selected by plugging in programmed shunt modules with the locator dots up or down. See the following figure for the configurations. If the adapter is to be installed in expansion slot 8 of an IBM Personal Computer XT or IBM Portable Personal Computer, a jumper is required on connector J13. ## **Interrupts** One interrupt line is provided to the system. This interrupt is IRQ4 for a primary adapter, or IRQ3 for an alternate adapter, and is positive active. To allow the communications adapter to send interrupts to the system, bit 3 of the modem control register must be set to 1 (high). At this point, any interrupts allowed by the interrupt enable register will cause an interrupt. The data format will be as follows: Data bit 0 is the first bit to be transmitted or received. The adapter automatically inserts the start bit, the correct parity bit if programmed to do so, and the stop bit (1, 1-1/2, or 2 depending)on the command in the line-control register). #### Interface The communications adapter provides an EIA RS-232C-like interface. One 25-pin, D-shell, male connector is provided to attach various peripheral devices. In addition, a current-loop interface is also located in this same connector. A jumper block is provided to manually select either the voltage interface or the current-loop interface. The current-loop interface is provided to attach certain printers provided by IBM that use this particular type of interface. IBM recommends that the current loop not be used beyond a distance of 15.3 meters (50 feet) as measured by the length of cable between the two interconnected points. Pin 18 + receive current loop data Pin 25 - receive current loop return Pin 11 - transmit current loop data Pin 9 + transmit current loop return **Current Loop Interface** The voltage interface is a serial interface. It supports certain data and control signals, as follows: | Pin 2 | Transmitted Data | |--------|---------------------| | Pin 3 | Received Data | | Pin 4 | Request to Send | | Pin 5 | Clear to Send | | Pin 6 | Data Set Ready | | Pin 7 | Signal Ground | | Pin 8 | Carrier Detect | | Pin 20 | Data Terminal Ready | | Pin 22 | Ring Indicator | | | | The adapter converts these signals to or from TTL levels from or to EIA voltage levels. These signals are sampled or generated by the communications control chip. These signals can then be sensed by the system software to determine the state of the interface or peripheral device. # **Voltage Interchange Information** | Interchange Voltage | Binary State | Signal Condition | Interface<br>Control Function | |---------------------|--------------|------------------|-------------------------------| | Positive Voltage = | Binary (0) | = Spacing | = On | | Negative Voltage = | Binary (1) | = Marking | = Off | | | Invalid Levels | |----------|----------------| | + 15 Vdc | | | | On Function | | + 3 Vdc | | | 0 Vdc | Invalid Levels | | – 3 Vdc | | | – 15 Vdc | Off Function | | | Invalid Levels | The signal will be considered in the *marking* condition when the voltage on the interchange circuit, measured at the interface point, is more negative than -3 Vdc with respect to signal ground. The signal will be considered in the *spacing* condition when the voltage is more positive than +3 Vdc with respect to signal ground. The region between +3 Vdc and -3 Vdc is defined as the transition region, and considered an invalid level. The voltage that is more negative than -15 Vdc or more positive than +15 Vdc will also be considered an invalid level. During the transmission of data, the marking condition will be used to denote the binary state 1, and the spacing condition will be used to denote the binary state 0. For interface control circuits, the function is on when the voltage is more positive than +3 Vdc with respect to signal ground and is off when the voltage is more negative than -3 Vdc with respect to signal ground. # **INS8250 Functional Pin Description** The following describes the function of all INS8250 input/output pins. Some of these descriptions refer to internal circuits. **Note:** In the following descriptions, a low represents a logical 0 (0 Vdc nominal) and a high represents a logical 1 (+2.4)Vdc nominal). #### **Input Signals** Chip Select (CS0, CS1, -CS2), Pins 12-14: When CS0 and CS1 are high and -CS2 is low, the chip is selected. Chip selection is complete when the decoded chip select signal is latched with an active (low) address strobe (-ADS) input. This enables communications between the INS8250 and the system unit's microprocessor. **Data Input Strobe (DISTR, -DISTR), Pins 22 and 21:** When DISTR is high or -DISTR is low while the chip is selected, it allows the system unit's microprocessor to read status information or data from a selected register of the INS8250. **Note:** Only an active DISTR or -DISTR input is required to transfer data from the INS8250 during a read operation. Therefore, tie either the DISTR input permanently low or the -DISTR line input permanently high, if not used. **Data Output Strobe (DOSTR, -DOSTR), Pins 19 and 18:** When DOSTR is high or -DOSTR is low while the chip is selected, it allows the system unit's microprocessor to write data or control words into a selected register of the INS8250. **Note:** Only an active DOSTR or -DOSTR input is required to transfer data to the INS8250 during a write operation. Therefore, tie either the DOSTR input permanently low or the -DOSTR input permanently high, if not used. Address Strobe (-ADS), Pin 25: When low, provides latching for the register select (A0, A1, A2) and chip select (CS0, CS1, -CS2) signals. **Note:** An active -ADS input is required when the register select (A0, A1, A2) signals are not stable for the duration of a read or write operation. If not required, tie the ADS input permanently low. Register Select (A0, A1, A2), Pins 26-28: These three inputs are used during a read or write operation to select an INS8250 register to read or write to as indicated in the following table. Note that the state of the divisor latch access bit (DLAB), which is the most significant bit of the line-control register, affects the selection of certain INS8250 registers. The DLAB must be set high by the system software to access the baud-rate generator divisor latches. | DLAB | A2 | A1 | Α0 | Register | | |------|----|----|----|---------------------------------------|--| | 0 | 0 | 0 | 0 | Receiver Buffer (Read), Transmitter | | | ļ | | | | Holding Register (Write) | | | 0 | 0 | 0 | 1 | Interrupt Enable | | | × | 0 | 1 | 0 | Interrupt Identification (Read Only) | | | × | 0 | 1 | 1 | Line Control | | | × | 1 | 0 | 0 | Modem Control | | | × | 1 | 0 | 1 | Line Status | | | × | 1 | 1 | 0 | Modem Control Status | | | X | 1 | 1 | 1 | None | | | 1 | 0 | 0 | 0 | Divisor Latch (Least Significant Bit) | | | 1 | 0 | 0 | 1 | Divisor Latch (Most Significant Bit) | | Master Reset (MR), Pin 35: When high, clears all registers (except the receiver buffer, transmitter holding, and divisor latches), and the control logic of the INS8250. Also, the state of various output signals (SOUT, INTRPT, -OUT 1, -OUT 2, -RTS, -DTR) are affected by an active MR input. Refer to the "Asynchronous Communications Reset Functions" table. Receiver Clock (RCLK), Pin 9: This input is the 16 x baud-rate clock for the receiver section of the chip. Serial Input (SIN), Pin 10: Serial data input from the communications link (peripheral device, modem, or data set). Clear to Send (-CTS), Pin 36: The -CTS signal is a modem control function input whose condition can be tested by the system unit's microprocessor by reading bit 4 (CTS) of the modem status register. Bit 0 (DCTS) of the modem status register indicates whether the CTS input has changed state since the previous reading of the modem status register. **Note:** Whenever the CTS bit of the modem status register changes state, an interrupt is generated if the modem status interrupt is enabled. Data Set Ready (-DSR), Pin 37: When low, indicates that the modem or data set is ready to establish the communications link and transfer data with the INS8250. The -DSR signal is a modem-control function input whose condition can be tested by the system unit's microprocessor by reading bit 5 (DSR) of the modem status register. Bit 1 (DDSR) of the modem status register indicates whether the -DSR input has changed since the previous reading of the modem status register. **Note:** Whenever the DSR bit of the modem status register changes state, an interrupt is generated if the modem status interrupt is enabled. Received Line Signal Detect (-RLSD), Pin 38: When low, indicates that the data carrier had been detected by the modem or data set. The -RLSD signal is a modem-control function input whose condition can be tested by the system unit's microprocessor by reading bit 7 (RLSD) of the modem status register. Bit 3 (DRLSD) of the modem status register indicates whether the RLSD input has changed state since the previous reading of the modem status register. **Note:** Whenever the RLSD bit of the modem status register changes state, an interrupt is generated if the modem status interrupt is enabled. Ring Indicator (-RI), Pin 39: When low, indicates that a telephone ringing signal has been received by the modem or data set. The -RI signal is a modem-control function input whose condition can be tested by the system unit's microprocessor by reading bit 6 (RI) of the modem status register. Bit 2 (TERI) of the modem status register indicates whether the -RI input has changed from a low to high state since the previous reading of the modem status register. **Note:** Whenever the RI bit of the modem status register changes from a high to a low state, an interrupt is generated if the modem status interrupt is enabled. VCC, Pin 40: +5 Vdc supply. VSS, Pin 20: Ground (0 Vdc) reference. #### **Output Signals** Data Terminal Ready (-DTR), Pin 33: When low, informs the modem or data set that the INS8250 is ready to communicate. The -DTR output signal can be set to an active low by programming bit 0 (DTR) of the modem control register to a high level. The -DTR signal is set high upon a master reset operation. Request to Send (-RTS), Pin 32: When low, informs the modem or data set that the INS8250 is ready to transmit data. The -RTS output signal can be set to an active low by programming bit 1 (RTS) of the modem control register to a high level. The -RTS signal is set high upon a master reset operation. Output 1 (-OUT 1), Pin 34: User-designated output that can be set to an active low by programming bit 2 (-OUT 1) of the modem control register to a high level. The -OUT 1 signal is set high upon a master reset operation. Output 2 (-OUT 2), Pin 31: User-designated output that can be set to an active low by programming bit 3 (-OUT 2) of the modem control register to a high level. The -OUT 2 signal is set high upon a master reset operation. Chip Select Out (CSOUT), Pin 24: When high, indicates that the chip has been selected by active CS0, CS1, and -CS2 inputs. No data transfer can be initiated until the CSOUT signal is a logical 1. Driver Disable (DDIS), Pin 23: Goes low whenever the system unit's microprocessor is reading data from the INS8250. A high-level DDIS output can be used to disable an external transceiver (if used between the system unit's microprocessor and the INS8250 on the D7-D0 data bus) at all times, except when the system unit's microprocessor is reading data. Baud Out (-BAUDOUT), Pin 15: 16 x clock signal for the transmitter section of the INS8250. The clock rate is equal to the main reference oscillator frequency divided by the specified divisor in the baud-rate generator divisor latches. The -BAUDOUT may also be used for the receiver section by typing this output to the RCLK input of the chip. Interrupt (INTRPT), Pin 30: Goes high whenever any one of the following interrupt types has an active high condition and is enabled through the interrupt enable register: receiver error flag, received data available, transmitter holding register empty, or modem status. The INTRPT signal is reset low upon the appropriate interrupt service or a master reset operation. Serial Output (SOUT), Pin 11: Composite serial data output to the communications link (peripheral device, modem, or data set). The SOUT signal is set to the marking (logical 1) state upon a master reset operation. #### Input/Output Signals Data Bus (D7–D0), Pins 1–8: This bus comprises eight tri-state input/output lines. The bus provides bidirectional communications between the INS8250 and the system unit's microprocessor. Data, control words, and status information are transferred through the D7-D0 data bus. External Clock Input/Output (XTAL1, XTAL2), Pins 16 and 17: These two pins connect the main timing reference (crystal or signal clock) to the INS8250. # **Specifications** The following page shows the connecter pin assignments and specifications for the Asynchronous Communications Adapter. Note: To avoid inducing voltage surges on interchange circuits, signals from interchange circuits shall not be used to drive inductive devices, such as relay coils. #### **Connector Specifications** #### 32 Asynchronous Adapter ogic Diagrams **Asynchronous Communications Adapter (Sheet 1 of 1)** ## **Index** # A address strobe (-ADS) 26 ### B baud out (-BAUDOUT) 29 baud-rate generator 7, 9 BI (break interrupt) 11 break interrupt (BI) 11 #### C chip select (CS0, CS1, -CS2) 26 chip select (CS0, CS1, CS2) 25 chip select out (CSOUT) 29 clear to send (-CTS) 27 clear to send (CTS) 27 CTS (clear to send) 27 current-loop interface 20, 23 ### D data bus (D7-D0) 30 data input strobe (-DISTR) 26 data input strobe (DISTR) 26 data output strobe (-DOSTR) 26 data output strobe (DOSTR) 26 data ready (DR) 10 data set ready (-DSR) 27 data set ready (DSR) 27 data speed 9 data terminal ready (-DTR) 15, 29 DCTS (delta clear to send) 17, 27 DDSR (delta data set ready) 17, 27 delta clear to send (DCTS) 17, 27 delta data set ready (DDSR) 17, 27 delta received line signal detect (DRLSD) 17 diagnostic capabilities 1, 16 diagnostic mode 16 divisor latch access bit (DLAB) 3, 7, 26 divisor latches 7 DLAB (divisor latch access bit) 7, 26 DR (data ready) 10 driver disable (DDIS) 29 DRLSD (delta received line signal detect) 17 #### $\mathbf{E}$ external clock input/output 30 ### F FE (framing error) 11 framing error (FE) 11 ``` IIR (Interrupt Identification Register) 12, 14 input signals 25 -ADS (address strobe) 26 -CS2 (chip select) 25, 26 -CTS (clear to send) 27 -DISTR (data input strobe) 26 -DOSTR (data output strobe) 26 -DSR (data set ready) 27 -RI (ring indicator) 18, 28 -RLSD (received line signal detect) 18, 28 A0 (register select) 3, 26 A1 (register select) 3, 26 A2 (register select) 3, 26 CS0 (chip select) 25, 26 CS1 (chip select) 25, 26 DISTR (data input strobe) 26 DOSTR (data output strobe) 26 DSR (data set ready) 27 MR (master reset) 27 RCLK (receiver clock) 27 SIN (serial input) 16, 27 VCC 28 VSS 28 XTAL1 (external clock input/output) 30 input/output signals 30 D7-D0 (data bus) 30 XTAL2 (external clock input/output) 30 INS8250 4, 25 INS8250 functional pin description 25 interface 23 interrupt (INTRPT) 14, 30 interrupt enable register 14 interrupt identification register (IIR) 12, 14 interrupts 21 INTRPT (interrupt) 14, 30 ``` ### L line status register (LSR) 10 line-control register 5 logic diagrams 33 LSR (line status register) 10 ### M master reset (MR) 27 modem control function 2 modem control inputs 16 modem control interrupts 16 modem control outputs 16 modem control register 15 modem status 12 modem status interrupt 15, 17, 27 modem status register 16, 27, 28 modes of operation 3 # O OE (overrun error) 10 output signals 29 -BAUDOUT (baud out) 29 -DTR (data terminal ready) 15, 29 -OUT 1 (output 1) 15, 29 -OUT 2 (output 2) 16, 29 -RTS (request to send) 15, 29 CSOUT (chip select out) 29 DDIS (driver disable) 29 SOUT (serial output) 7, 16, 30 output 1 (-OUT 1) 15, 29 output 2 (-OUT 2) 16, 29 overrun error (OE) 10 #### P parity error (PE) 10 PE (parity error) 10 programmable baud-rate generator 7 programming considerations 3 ## R received line signal detect (-RLSD) 18, 28 receiver buffer register 18 receiver clock (RCLK) 27 register select (A0, A1, A2) 3, 26 request to send (-RTS) 15, 29 ring indicator (-RI) 28 #### S selecting the adapter address 20 selecting the interface format and Adapter Address 20 serial input (SIN) 16, 27 serial output (SOUT) 7, 16, 30 specifications 31 #### T TERI (trailing edge of the ring indicator) 17 THRE (transmitter-holding-register-empty) 11, 12 trailing edge of the ring indicator (TERI) 17 transmitter holding register 12, 19 transmitter-holding-register-empty (THRE) 11, 12 transmitter-shift-register-empty (TSRE) 11 TSRE (transmitter-shift-register-empty) 11 ### V voltage interchange information 24 voltage interface 24 Personal Computer Hardware Reference Library # Serial/Parallel Adapter # **Contents** | escription | 1 | |-----------------------------------|---| | Serial Portion of the Adapter | 1 | | Parallel Portion of the Adapter 2 | | | Specifications | | | ogic Diagrams 2 | 7 | # **Notes:** # **Description** The IBM Personal Computer AT Serial/Parallel Adapter provides a parallel port and a serial port. It plugs into a system-board expansion slot. All system-control signals and voltage requirements are provided through a 2- by 31-position card edge connector. # **Serial Portion of the Adapter** The serial portion of the adapter is fully programmable and supports asynchronous communications. It will add and remove start, stop, and parity bits. A programmable baud-rate generator allows operation from 50 baud to 9600 baud. Five-, six-, sevenand eight-bit characters with 1, 1.5, or 2 stop bits are supported. A prioritized interrupt system controls transmit, receive, error, and line status as well as data-set interrupts. The rear of the adapter has a 9-pin D-shell connector that is classified as an RS-232C port. When the optional IBM Communications Cable (9-Pin), which has a 9-pin D-shell connector on one end and a 25-pin D-shell connector on the other end, is connected to the adapter, the 25-pin end of the cable has all the signals of a standard EIA RS-232C interface. The following figure is a block diagram of the serial portion of the adapter. Serial Portion Block Diagram The serial portion of the adapter has a controller that provides the following functions: - Adds or deletes standard, asynchronous-communications bits to or from a serial data stream. - Provides full, double buffering, which eliminates the need for precise synchronization. - Provides a programmable baud-rate generator. - Provides modem controls (CTS, RTS, DSR, DTR, RI, and CD). #### **Communications Application** The serial output port may be addressed as either communications port 1 or communications port 2 as defined by jumper J1 (see the following figure). In this section hex addresses begin with an X which can be either a 3 for communications port 1 (interrupt level 4) or a 2 for communications port 2 (interrupt level 3). The data format will be as follows: Bit 0 is the first data bit to be sent or received. The controller automatically inserts the start bit, the correct parity bit (if programmed to do so), and the stop bit (1, 1.5, or 2, depending on the command in the line-control register). #### **Controller Specifications** The following describes the function of controller input/output signals. #### **Input Signals** -Clear to Send: (-CTS), Pin 36—The '-CTS' signal is a modem-control function input, the condition of which can be tested by the processor by reading bit 4 (-CTS) of the modem status register. Bit 0 (DCTS) of the modem status register indicates if the '-CTS' input has changed state since the previous reading. **Note:** Whenever the CTS bit of the modem status register changes state, an interrupt is generated if the modem-status interrupt is enabled. **-Data Set Ready:** (-DSR), Pin 37—When low, indicates the modem or data set is ready to establish the communications link and transfer data with the controller. The '-DSR' signal is a modem-control function input, the condition of which can be tested by the processor reading bit 5 (-DSR) of the modem status register. Bit 1 (DDSR) of the modem status register indicates if the '-DSR' input has changed since the previous reading. **Note:** Whenever the DSR bit of the modem status register changes state, an interrupt is generated if the modem-status interrupt is enabled. **-Data Carrier Detect:** (-DCD), Pin 38—When low, indicates the modem or data set detected a data carrier. The '-DCD' signal is a modem-control function input, the condition of which can be tested by the processor reading bit 7 (-DCD) of the modem status register. Bit 3 (DDCD) of the modem status register indicates if the '-DCD' input has changed state since the previous reading. **Note:** Whenever the DCD bit of the modem status register changes state, an interrupt is generated if the modem status interrupt is enabled. -Ring Indicator: (-RI), Pin 39—When low, indicates the modem or data set detected a telephone ringing signal. The '-RI' signal is a modem-control function input, the condition of which can be tested by the processor reading bit 6 (-RI) of the modem status register. Bit 2 (TERI) of the modem status register indicates if the '-RI' input has changed from an active to an inactive state since the previous reading. **Note:** Whenever the RI bit of the modem status register changes from an inactive to an active state, an interrupt is generated if the modem-status interrupt is enabled. VCC Pin 40—+5 Vdc supply VSS Pin 20—Ground (0 Vdc) reference #### **Output Signals** - **-Data Terminal Ready:** (-DTR), Pin 33—When active, informs the modem or data set that the controller is ready to communicate. The '-DTR' output signal can be set to an active level by programming bit 0 (-DTR) of the modem control register to an active level. The '-DTR' signal is set inactive upon a master reset operation. - **-Request to Send:** (-RTS), Pin 32—When active, informs the modem or data set that the controller is ready to send data. The '-RTS' output signal can be set to an active level by programming bit 1 (-RTS) of the modem control register to an active level. The '-RTS' signal is set inactive upon a master reset operation. - **-Output 1:** (-OUT 1), Pin 34—User-designated output that can be set to an active level by programming bit 2 (-OUT 1) of the modem control register to an inactive level. The '-OUT 1' signal is set inactive upon a master reset operation. Pin 34 is connected to an active source. - **-Output 2:** (-OUT 2), Pin 31—User-designated output that can be set to an active level by programming bit 3 (-OUT 2) of the modem control register to an inactive level. The '-OUT 2' signal is set inactive upon a master reset operation. Pin 31 controls interrupts to the system. #### **Controller-Accessible Registers** The controller has a number of accessible registers. The system programmer may gain access to or control any of the controller registers through the microprocessor. These registers are used to control the controller's operations and to transmit and receive data. The X in the register address determines the the port selected; 3 is for port 1 and 2 is for port 2. Specific registers are selected according to the following figure: | I/O Address | Register Selected | DLAB State | |-------------|-----------------------------------|------------| | XF8 | TX Buffer | 0 (Write) | | XF8 | RX Buffer | 0 (Read) | | XF8 | Divisor Latch LSB | 1 | | XF9 | Divisor Latch MSB | 1 | | XF9 | Interrupt Enable Register | 0 | | XFA | Interrupt Identification Register | | | XFB | Line Control Register | | | XFC | Modem Control Register | | | XFD | Line Status Register | | | XFE | Modem Status Register | | | XFF | Reserved | | #### **Controller-Accessible Registers** Transmitter Holding Register (hex XF8): The transmitter holding register (THR) contains the character to be sent. **Transmitter Holding Register** Bit 0 is the least-significant bit and the first bit sent serially. Receiver Buffer Register (hex XF8): The receiver buffer register (RBR) contains the received character. **Receiver Buffer Register** Bit 0 is the least-significant bit and the first bit received serially. **Programmable Baud-Rate Generator:** The controller has a programmable baud-rate generator that can divide the clock input (1.8432 MHz) by any divisor from 1 to 655,535 or 2<sup>16</sup>-1. The output frequency of the baud-rate generator is the baud rate multiplied by 16. Two 8-bit latches store the divisor in a 16-bit binary format. These divisor latches must be loaded during setup to ensure desired operation of the baud-rate generator. When either of the divisor latches is loaded, a 16-bit baud counter is immediately loaded. This prevents long counts on the first load. #### **Divisor Latch LSB (hex XF8)** **Divisor Latch Least Significant Bit** #### **Divisor Latch MSB (hex XF9)** **Divisor Latch Most Significant Bit** Interrupt Enable Register (hex XF9): This 8-bit register allows the four types of controller interrupts to separately activate the 'chip-interrupt' (INTRPT) output signal. The interrupt system can be totally disabled by resetting bits 0 through 3 of the interrupt enable register (IER). Similarly, by setting the appropriate bits of this register to logical 1, selected interrupts can be enabled. Disabling the interrupt system inhibits the 'IER' and the active 'INTRPT' output from the chip. All other system functions operate normally, including the setting of the line-status and modem-status registers. Interrupt Enable Register When set to logical 1, enables the received-data-available interrupt. - Bit 1 When set to logical 1, enables the transmitter-holding-register-empty interrupt. - Bit 2 When set to logical 1, enables the receiver-line-status interrupt. - Bit 3 When set to logical 1, enables the modem-status interrupt. - Bits 4–7 These four bits are always logical 0. Interrupt Identification Register (hex XFA): The controller has an on-chip interrupt capability that makes communications possible with all of the currently popular microprocessors. In order to minimize programming overhead during data character transfers, the controller prioritizes interrupts into four levels: receiver-line-status (priority 1), received-data-available (priority 2), transmitter-holding-register-empty (priority 3), and modem status (priority 4). Information about a pending prioritized interrupt is stored in the interrupt identification register (IIR). (See the figure "Interrupt Control Functions," later.) The IIR, when addressed during chip-select time, stops the pending interrupt with the highest priority, no other interrupts are acknowledged until the processor services that interrupt. #### Interrupt Identification Register Bit 0 This bit can be used in either hard-wired, prioritized, or polled conditions to indicate if an interrupt is pending. When bit 0 is logical 0, an interrupt is pending, and the IIR contents may be used as a August 31, 1984 pointer to the appropriate interrupt service routine. When bit 0 is logical 1, no interrupt is pending, and polling (if used) continues. Bits 1-2 These two bits identify the pending interrupt that has the highest priority, as shown in the following figure: | Interrupt<br>ID<br>Register | | Interrupt Set And Reset Functions | | | | | |-----------------------------|----------|-----------------------------------|-------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | Bit<br>2 | Bit<br>1 | Bit<br>O | Priority<br>Level | Interrupt<br>Type | Interrupt<br>Source | Interrupt<br>Reset Control | | 0 | 0 | 0 | - | None | None | - | | 1 | 1 | 0 | Highest | Receiver<br>Line<br>Status | Overrun Error<br>or<br>Parity Error<br>or<br>Framing Error<br>or<br>Break Interrupt | Reading the Line<br>Status Register | | 1 | 0 | 0 | Second | Received<br>Data<br>Available | Receiver Data<br>Available | Reading the Receiver<br>Buffer Register | | 0 | 1 | 0 | Third | Transmitter<br>Holding<br>Register<br>Empty | Transmitter<br>Holding<br>Register Empty | Reading the IIR<br>(if source of interrupt)<br>or writing into the<br>THR | | 0 | 0 | 0 | Fourth | Modem<br>Status | Clear to Send<br>or<br>Data Set Ready<br>or<br>Ring Indicator<br>or<br>Received Line<br>Signal Detect | Reading the Modem<br>Status Register | #### **Interrupt Priority** Bits 3–7 These five bits are always logical 0. **Line-Control Register (hex XFB):** The system programmer specifies the format of the asynchronous data communications exchange through the line control register. In addition to controlling the format, the programmer may retrieve the contents of the line control register for inspection. This feature simplifies system programming and eliminates the need to store line characteristics separately in system memory. #### **Line Control Register** Bits 0, 1 These two bits specify the number of bits in each serial character that is sent or received. The encoding of bits 0 and 1 is as follows: | Bit 0 | Bit 1 | Word Length (Bits) | |-------|-------|--------------------| | 0 | 0 | 5 | | 0 | 1 | 6 | | 1 | 0 | 7 | | 1 | 1 | 8 | #### **Word Length** - Bit 2 This bit specifies the number of stop bits in each serial character that is sent or received. If bit 2 is a logical 0, one stop bit is generated or checked in the data sent or received. If bit 2 is logical 1 when a 5-bit word length is selected through bits 0 and 1, 1-1/2 stop bits are generated or checked. If bit 2 is logical 1 when either a 6-, 7-, or 8-bit word length is selected, two stop bits are generated or checked. - Rit 3 This bit is the parity-enable bit. When bit 3 is logical 1, a parity bit is generated (transmit data) or checked (receive data) between the last data word and stop bit of the serial data. (The parity bit is used to produce an even or odd number of 1's when the data-word bits and parity bit are summed.) Bit 4 This bit is the even-parity-select bit. When bit 3 is a logical 1 and bit 4 is a logical 0, an odd number of logical 1's are sent or checked in the data word bits and parity bit. When both bit 3 and bit 4 are a logical 1, an even number of bits are sent or checked Bit 5 This bit is the stuck-parity bit. When bit 3 is a logical 1 and bit 5 is a logical 1, the parity bit is sent and then detected by the receiver as a logical 0, if bit 4 is a logical 1, or as a logical 1 if bit 4 is a logical 0. Bit 6 This bit is the set-break control bit. When bit 6 is set to a logical 1, the serial output (SOUT) is forced to the spacing (logical 0) state and remains there regardless of other transmitter activity. The set-break is disabled by setting bit 6 to logical 0. This feature enables the microprocessor to select a specific terminal in a computer communications system. Bit 7 This bit is the divisor-latch access bit (DLAB). It must be set high (logical 1) to gain access to the divisor latches of the baud-rate generator during a read or write operation. It must be set low (logical 0) to gain access to the receiver buffer, the transmitter holding register, or the interrupt enable register. Modem Control Register (hex XFC): This 8-bit register controls the data exchange with the modem or data set (an external device acting as a modem). #### **Modem Control Register** - Bit 0 This bit controls the '-data terminal ready' (-DTR) output. When bit 0 is set to logical 1, the -DTR output is forced active. When bit 0 is reset to logical 0, the '-DTR' output is forced inactive. - Bit 1 This bit controls the '-request-to-send' (-RTS) output. Bit 1 affects the '-RTS' output in the same way bit 0 affects the '-DTR' output. - Bit 2 This bit controls the '-Output 1' (-OUT 1) signal, which is a spare the programmer can use. Bit 2 affects the '-OUT 1' output in the same way bit 0 affects the '-DTR' output. - Bit 3 This bit controls the '-Output 2' (-OUT 2) signal, which is a spare the programmer can use. Bit 3 affects the '-OUT 2' output in the same way bit 0 affects the '-DTR' output. - Bit 4 This bit provides a loopback feature for diagnostic testing of the controller. When bit 4 is set to logical 1, the following occur: the 'transmitter serial output' (SOUT) is set to the active state; the 'receiver serial input' (SIN) is disconnected; the output of the transmitter shift register is "looped back" to the receiver shift register input; the four modem-control inputs ('-CTS', '-DSR', '-RLSD', and '-RI') are disconnected; and the four modem-control outputs ('-DTR', '-RTS', '-OUT 1' and '-OUT 2') are internally connected to the four modem control inputs. In the diagnostic mode, data sent is immediately received. This feature allows the processor to verify the transmit- and receive-data paths of the controller. In the diagnostic mode, the receiver and transmitter interrupts are fully operational, as are the modem-control interrupts. But the interrupts' sources are now the lower four bits of the modem control register (MCR) instead of the four modem-control inputs. The interrupts are still controlled by the interrupt enable register. The controller's interrupt system can be tested by writing to the lower six bits of the line status register and the lower four bits of the modem status register. Setting any of these bits to logical 1 generates the appropriate interrupt (if enabled). Resetting these interrupts is the same as for normal controller operation. To return to normal operation, the registers must be reprogrammed for normal operation, and then bit 4 of the MCR must be reset to logical 0. Bits 5–7 These bits are permanently set to logical 0. Line Status Register (hex XFD): This 8-bit register provides the processor with status information about the data transfer. #### Line Status Register - Bit 0 This bit is the receiver data ready (DR) indicator. It is set to logical 1 whenever a complete incoming character has been received and transferred into the receiver buffer register. Bit 0 may be reset to logical 0 by reading the data in the receiver buffer register. - Bit 1 This bit is the overrun error (OE) indicator. It indicates that data in the receiver's buffer register was not read by the processor before the next character was transferred into the register, thereby destroying the previous character. The OE indicator is reset whenever the processor reads the contents of the line status register. - Bit 2 This bit is the parity error (PE) indicator and indicates the received data character does not have the correct even or odd parity, as selected by the even-parity-select bit. The PE bit is set to logical 1 upon detection of a parity error, and is reset to logical 0 whenever the processor reads the contents of the line status register. - Bit 3 This bit is the framing error (FE) indicator. It indicates the received character did not have a valid stop bit. Bit 3 is set to logical 1 whenever the stop bit following the last data bit or parity bit is detected as a zero bit (spacing level). Bit 4 This bit is the break interrupt (BI) indicator. It is set to logical 1 whenever the received data input is held in the spacing state (logical 0) for longer than a full word transmission time (that is, the total time of start bit + data bits + parity bits + stop bits). **Note:** Bits 1 through 4 are error conditions that produce a receiver line-status interrupt whenever any of the corresponding conditions are detected. - This bit is the transmitter holding register empty (THRE) indicator. It indicates the controller is ready to accept a new character for transmission. In addition, this bit causes the controller to issue an interrupt to the processor when the THRE interrupt enable is set active. The THRE bit is set to logical 1 when a character is transferred from the transmitter holding register into the transmitter shift register. It is reset to logical 0 when the processor loads the transmitter holding register. - Bit 6 This bit is the transmitter empty (TEMT) indicator. It is set to logical 1 whenever the transmitter holding register (THR) and the transmitter shift register (TSR) are both empty. It is reset to logical 0 if THR or TSR contain a data character. - Bit 7 This bit is permanently set to logical 0. Modem Status Register (hex XFE): The 8-bit MSR provides the current state of the control lines from the modem (or external device) to the processor. In addition, four bits of the MSR provide change information. These four bits are set to logical 1 whenever a control input from the modem changes state. They are reset to logical 0 whenever the processor reads this register. #### **Modem Status Register** - Bit 0 This bit is the delta clear-to-send (DCTS) indicator. It indicates the '-CTS' input to the chip has changed state since the last time it was read by the processor. - Bit 1 This bit is the delta data-set-ready (DDSR) indicator. It indicates the '-DSR' input to the chip has changed state since the last time it was read by the processor. - Bit 2 This bit is the trailing-edge ring-indicator (TERI) detector. It indicates the '-RI' input to the chip has changed from an active condition to an inactive condition. - Bit 3 This bit is the delta data-carrier-detect (DDCD) indicator. It indicates the '-DCD' input to the chip has changed state. **Note:** Whenever bit 0, 1, 2, or 3 is set to a logical 1, a modem status interrupt is generated. Bit 4 This bit is the opposite of the '-clear-to-send' (-CTS) input. If bit 4 of the MCR loop is set to a logical 1, this bit is equivalent to RTS of the MCR. - Bit 5 This bit is the opposite of the '-data-set-ready' (-DSR) input. If bit 4 of the MCR is set to a logical 1, this bit is equivalent to DTR of the MCR. - Bit 6 This bit is the opposite of the '-ring-indicator' (-RI) input. If bit 4 of the MCR is set to a logical 1, this bit is equivalent to OUT 1 of the MCR. - Bit 7 This bit is the opposite of the '-data-carrier-detect' (-DCD) input. If bit 4 of the MCR is set to a logical 1, this bit is equivalent to OUT 2 of the MCR. ## Pin Assignment for Serial Port The following figure shows the pin assignments for the serial port in a communications environment. ## **Parallel Portion of the Adapter** The parallel portion of the adapter makes possible the attachment of various devices that accept eight bits of parallel data at standard TTL levels. The rear of the adapter has a 25-pin, D-shell connector. This port may be addressed as either parallel port 1 or 2. The port address is determined by the position of jumper J2, as shown in the following figure. The following figure is a block diagram of the parallel portion of the adapter. **Parallel Portion Block Diagram** ## **Printer Application** The following discusses the use of the parallel portion of the adapter to connect to a parallel printer. Hexadecimal addresses in this section begin with an X, which is replaced with a 3 to indicate port 1, or a 2 to indicate port 2. ## Data Latch (hex X78, X7C) Writing to this address causes data to be stored in the printer's data buffer. Reading this address sends the contents of the printer's data buffer to the system microprocessor. ## Printer Controls (hex X7A, X7E) Printer control signals are stored at this address to be read by the system microprocessor. The following are bit definitions for this byte. - Bit 7 Not used - Bit 6 Not used - Bit 5 Not used - **Bit 4** +IRQ Enable—A logical 1 in this position allows an interrupt to occur when '-ACK' changes from active to inactive. - Bit 3 +SLCT IN—A logical 1 in this bit position selects the printer. - Bit 2 -INIT—A logical 0 starts the printer (50-microsecond pulse, minimum). - **Bit 1** +AUTO FD XT—A logical 1 causes the printer to line-feed after a line is printed. - Bit 0 +STROBE—A 0.5-microsecond minimum, high, active pulse clocks data into the printer. Valid data must be present for a minimum of 0.5 microsecond before and after the strobe pulse. #### Printer Status - (hex X79, X7D) Printer status is stored at this address to be read by the microprocessor. The following are bit definitions for this byte. - Bit 7 -BUSY—When this signal is active, the printer is busy and cannot accept data. It may become active during data entry, while the printer is offline, during printing, when the print head is changing positions, or while in an error state. - Bit 6 -ACK—This bit represents the current state of the printer's '-ACK' signal. A 0 means the printer has received the character and is ready to accept another. Normally, this signal will be active for approximately 5 microseconds before '-BUSY' stops. Bit 5 +PE—A logical 1 means the printer has detected the end of paper. Bit 4 +SLCT—A logical 1 means the printer is selected. Bit 3 -Error—A logical 0 means the printer has encountered an error condition. Bit 2 Unused. Bit 1 Unused. Bit 0 Unused. #### **Parallel Interface** The adapter has a 25-pin, D-shell connector at the rear of the adapter. The following figure shows the signals and their pin assignments. Typical printer input signals also are shown. August 31, 1984 # **Specifications** The following figures list characteristics of the output driver. | Sink current | 24 mA | Max | |---------------------------|---------|-----| | Source Current | -2.6 mA | Max | | High-Level Output Voltage | 2.4 Vdc | Min | | Low-Level Output Voltage | 0.5 Vdc | Max | #### Parallel Data and Processor IRQ | Sink Current | 16 mA | Max | |---------------------------|---------|---------------| | Source Current | 0.55 mA | Max | | High Level Output Voltage | 5 Vdc | Minus Pull-Up | | Low Level Output Voltage | 0.4 Vdc | Max | #### Parallel Control | Sink Current | 24 mA | Max | |---------------------------|---------|-----| | Source Current | -15 mA | Max | | High Level Output Voltage | 2.0 Vdc | Min | | Low Level Output Voltage | 0.5 Vdc | Max | #### Parallel Processor Interface (Except IRQ) The following are the specifications for the serial interface. | Function | Condition | |----------|-------------------------------------------------| | On | Spacing condition (binary 0, positive voltage). | | Off | Marking condition (binary 1, negative voltage). | | Voltage | Function | |-------------------|----------| | Above +15 Vdc | Invalid | | +3 Vdc to +15 Vdc | On | | -3 Vdc to +3 Vdc | Invalid | | -3 Vdc to -15 Vdc | Off | | Below -15 Vdc | Invalid | #### **Serial Port Functions** **Notes:** Serial/Printer Adapter (Sheet 1 of 3) Serial/Printer Adapter (Sheet 2 of 3) Serial/Printer Adapter (Sheet 3 of 3) **Notes:** # IBM Binary Synchronous Communications Adapter # **Contents** | Description | |------------------------------| | Programming Considerations | | Typical Programming Sequence | | USART Programming 5 | | Interface 9 | | Specifications | | Logic Diagrams | # **Description** The IBM Binary Synchronous Communications (BSC) Adapter provides an RS-232C-compatible communications interface for the IBM Personal Computer family of products. All system control, voltage, and data signals are provided through a 2- by 31-position card-edge connector. External interface is in the form of Electronic Industries Association (EIA) drivers and receivers connected to an RS-232C, standard 25-pin, D-shell connector. The adapter is programmed to operate in a binary synchronous mode. Maximum transmission rate is 9600 bits per second (bps). The main feature of the adapter is an Intel 8251A Universal Synchronous/Asynchronous Receiver/Transmitter (USART). An Intel 8255A-5 Programmable Peripheral Interface (PPI) also is used for expanded modem operation, and an Intel 8253-5 Programmable Interval Timer provides time-outs and generates interrupts. The following is a block diagram of the BSC adapter. **BSC Adapter Block Diagram** # **Programming Considerations** Before starting data transmission or reception, the system unit programs the BSC adapter to define control and gating ports, timer functions and counts, and the communications environment. # **Typical Programming Sequence** The 8255A-5 Programmable Peripheral Interface (PPI) is set for the proper mode by selecting address hex 3A3 and writing the control word. This defines port A as an input, port B as an output for modem control and gating, and port C for 4-bit input and 4-bit output. An output to port C sets the adapter to the wrap mode, disallows interrupts, and gates external clocks (address = hex 3A2, data = hex 0D). The adapter is now isolated from the communication interface, and setup continues. Bit 4 of the PPI's port B brings the USART reset pin high, holds it, then drops it. This resets the internal registers of the USART. The PPI's port assignments are as follows: The USART uses the 8253-5 Programmable Interval Timer (PIT) in the synchronous mode for inactivity time-outs to interrupt the system unit after a preselected amount of time has elapsed from the start of a communication operation. Counter 0 is not used for synchronous operation. Counters 1 and 2 connect to #### 4 BSC Adapter interrupt-level 4 and, being programmed to terminal-count values, provide the desired time delay before generating a level-4 interrupt. These interrupts signal the system that a predetermined amount of time has elapsed without a TxRDY (level 4) or an RxRDY (level 3) interrupt being sent to the system unit. # **USART Programming** After the support devices on the BSC adapter are programmed, the USART is loaded with a set of control words that defines the communication environment. The control words consist of mode instructions and command instructions. Both the mode and command instructions must conform to a specified sequence for proper device operation. The mode instruction must be inserted immediately after a reset operation before using the USART for data communications. The required synchronization characters for the defined communication technique are then loaded into the USART (usually hex 32 for BSC). All control words written to the USART after the mode instruction will load the command instruction. Command instructions can be written to the USART in the data block any time during its operation. To return to the mode instruction, the master reset bit in the command instruction word is set to start an internal reset operation, which places the USART back into the mode instruction. Command instructions must follow the mode instructions or synchronization characters. The following represents a typical data block and shows the mode instruction and command instruction. #### **Typical Data Block** The following are the communications interrupt levels. - Interrupt level 4 - Transmit - Timer 1 - Timer 2 - Interrupt level 3 - Receive # The following are device addresses. | Hex Address | | | | · | |-------------|-----------|--------|----------------|---------------------------| | Primary | Alternate | Device | Register Name | Function | | 3A0 | 380 | 8255 | Port A Data | Internal/External Sensing | | 3A1 | 381 | 8255 | Port B Data | External Modem Interface | | 3A2 | 382 | 8255 | Port C Data | Internal Control | | 3A3 | 383 | 8255 | Mode Set | 8255 Mode Initialization | | 3A4 | 384 | 8253 | Counter 0 LSB | Not Used in Sync. Mode | | 3A4 | 384 | 8253 | Counter 0 MSB | Not Used in Sync. Mode | | 3A5 | 385 | 8253 | Counter 1 LSB | Inactivity Time Outs | | 3A5 | 385 | 8253 | Counter 1 MSB | Inactivity Time Outs | | 3A6 | 386 | 8253 | Counter 2 LSB | Inactivity Time Outs | | 3A6 | 385 | 8253 | Counter 2 MSB | Inactivity Time Outs | | 3A7 | 387 | 8253 | Mode Register | 8253 Mode Set | | 3A8 | 388 | 8251 | Data Select | Data | | 3A9 | 389 | 8251 | Command/Status | USART Status | **Device Address Summary** ## Interface The IBM Binary Synchronous Communications Adapter conforms to interface signal levels standardized by the Electronic Industries Association (EIA) RS-232C Standard. The following figure shows these levels. | Driver | EIA RS232C/CCITT V24-V28 Signal Levels | |-------------|----------------------------------------| | | | | +15 Vdc | | | | Active/Data = 0 | | +5 Vdc | | | 1 | | | | Invalid Level | | | · | | 1 | | | -5 Vdc | | | | Inactive/Data = 1 | | -15 Vdc ——— | | | | | | Receiver | EIA RS232C/CCITT V24-V28 Signal Levels | | | | | +25 Vdc | | | | | | | Active/Data = 0 | | +3 Vdc | | | +3 Vdc | | | | Invalid Level | | | | | -3 Vdc | | | | Inactive/Data = 1 | | | | | -25 Vdc | | | | | | <u> </u> | | **Interface Voltage Levels** Pins 11, 18, and 25 on the interface connector are not standardized by the EIA. These lines are designated as 'select standby,' 'test,' and 'test indicate.' 'Select standby' is used to support the switched network backup facility of a modem that provides this option. 'Test' and 'test indicate' support a modem wrap function on modems designated for business-machine, controlled-modem wraps. ## **Specifications** | | Signal Name — Description | Pin | | |--------------------|-----------------------------------|-----|----------------| | External<br>Device | No Connection | 1 | | | | Transmitted Data | 2 | | | | Received Data | 3 | | | | Request to Send | 4 | | | | Clear to Send | 5 | | | | Data Set Ready | 6 | | | | Signal Ground | 7 | | | | Received Line Signal Detector | 8 | | | | No Connection | 9 | | | | No Connection | 10 | Binary | | | Select Standby * | 11 | Synchronous | | | No Connection | 12 | Communications | | | No Connection | 13 | Adapter | | | No Connection | 14 | | | | Transmitter Signal Element Timing | 15 | | | | No Connection | 16 | 1 | | | Receiver Signal Element Timing | 17 | | | | Test (IBM Modems Only)* | 18 | | | | No Connection | 19 | | | | Data Terminal Ready | 20 | | | | No Connection | 21 | | | | Ring Indicator | 22 | | | | Data Signal Rate Selector | 23 | | | | No Connection | 24 | | | | Test Indicate (IBM Modems Only)* | 25 | | | | | | | <sup>\*</sup>Not standardized by EIA (Electronic Industries Association). ## **Logic Diagrams** Binary Synchronous Communications Adapter (Sheet 1 of 2) **Binary Synchronous Communications Adapter (Sheet 2 of 2)** # IBM Synchronous Data Link Control (SDLC) Communications Adapter ## **Contents** | Description 1 | |-----------------------------------------------| | 8273 SDLC Protocol Controller | | 8255A-5 Programmable Peripheral Interface 2 | | 8253-5 Programmable Interval Timer | | Programming Considerations 5 | | Initializing the Adapter (Typical Sequence) 5 | | 8253-5 Programmable Interval Timer 5 | | Address and Interrupt Information 6 | | Interface 7 | | Specifications 9 | | Logic Diagrams 11 | ## **Description** The IBM Synchronous Data Link Control (SDLC) Communications Adapter provides communications support to the system in a half-duplex synchronous mode. The adapter receives address, data, and control signals from the system board through the internal bus. Electronic Industries Association (EIA) drivers and receivers connect to an RS232-C standard 25-pin. D-shell, male connector. The adapter is programmed by communications software to operate in a half-duplex mode. Maximum transmission rate is 9600 bits per second, as generated by the attached modem or other data communications equipment. The SDLC adapter uses an Intel 8273 SDLC Protocol Controller and an Intel 8255A-5 Programmable Peripheral Interface (PPI) for an expanded external modem interface. An Intel 8253 Programmable Interval Timer (PIT) generates timing and interrupt signals. Internal test-loop capability is provided for diagnostic purposes. The following figure is a block diagram of the IBM SDLC Communications Adapter. **SDLC Communications Adapter Block Diagram** ### 8273 SDLC Protocol Controller The 8273 SDLC Protocol Controller has three operations—transmission, reception, and port read—with each operation consisting of three phases: **Command:** Commands and/or requirements for the operation are issued by the system unit's microprocessor. **Execution:** Executes the command, manages the data link, and may transfer data to or from memory using direct memory access (DMA), and thus freeing the system unit's microprocessor except for minimal interruptions. **Result:** Shows the effect of the command by returning the interrupt results. Support of these phases is through the internal registers and control blocks of the controller. ## 8255A-5 Programmable Peripheral Interface The 8255A-5 PPI has three 8-bit ports—A, B, and C. Descriptions of each bit of these ports follow. ## 8253-5 Programmable Interval Timer The 8253-5 PIT is driven by a microprocessor clock signal that is divided by 2. The PIT's three counters provide the following output: Counter 0 Programmed to generate a square-wave signal that is used as an input to timer 2. Also connected to port C, bit 5 of the PIT. **Counter 1** Connected to PPI port A, bit 7, and interrupt-level 4. Counter 2 Connected to PPI port A, bit 6, and interrupt-level 4. ## **Programming Considerations** ## **Initializing the Adapter (Typical Sequence)** Before the 8273 SDLC Protocol Controller is started, the support devices on the adapter must be set to the correct modes of operation. Setup of the 8255A-5 Programmable Peripheral Interface is accomplished by selecting the mode set address for the PPI and by writing the appropriate control word to hex 98 to set ports A, B, and C to the modes described previously in this section. Next, a bit pattern sent to port C disallows interrupts, sets wrap mode on, and gates the external clock pins (address is hex 382, data is hex 0D). The adapter is now isolated from the communications interface. The controller reset line is brought high through bit 4 of port B, held, then dropped. This action resets the internal registers of the controller. ## 8253-5 Programmable Interval Timer The PIT's counters 1 and 2 terminal-count values are set to values that will provide the desired time delay before a level-4 interrupt is generated. These interrupts may be used to indicate to the communication programs that a predetermined amount of time has elapsed without a result interrupt (interrupt-level 3). The terminal-count values for these counters are set for any time delay the programmer requires. Counter 0 also is set to mode 3 (generates square-wave signal used to drive counter 2 input). The counter modes are set up by selecting the address for the PIT's counter-mode register and by writing the control word for each individual counter to the device separately. When the support devices are set to the correct modes and the 8273 SDLC Protocol Controller is reset, it is ready to be set up for the operating mode that defines the communications environment in which it will be used. ## **Address and Interrupt Information** The following tables provide address and interrupt information for the SDLC adapter. | Hex Code | Device | Register Name | Function | |----------|--------|---------------------|------------------------------| | 380 | 8255 | Port A Data | Internal/External Sensing | | 381 | 8255 | Port B Data | External Modem Interface | | 382 | 8255 | Port C Data | Internal Control | | 383 | 8255 | Mode Set | 8255 Mode Initialization | | 384 | 8253 | Counter 0 LSB | Square Wave Generator | | 384 | 8253 | Counter 0 MSB | Square Wave Generator | | 385 | 8253 | Counter 1 LSB | Inactivity Time-Outs | | 385 | 8253 | Counter 1 MSB | Inactivity Time-Outs | | 386 | 8253 | Counter 2 LSB | Inactivity Time-Outs | | 386 | 8253 | Counter 2 MSB | Inactivity Time-Outs | | 387 | 8253 | Mode Register | 8253 Mode Set | | 388 | 8273 | Command/Status | Out = Command In = Status | | 389 | 8273 | Parameter/Result | Out = Parameter In = Status | | 38A | 8273 | Transmit INT Status | DMA/INT | | 38B | 8273 | Receive INT Status | DMA/INT | | 38C | 8273 | Data | DPC (Direct Program Control) | #### **SDLC Communications Adapter Device Addresses** | Interrupt Level 3 | Transmit/Receive Interrupt | | |----------------------------------------------|----------------------------------------------|--| | Interrupt Level 4 | Timer 1 Interrupt<br>Timer 2 Interrupt | | | | Clear to Send Changed Data Set Ready Changed | | | DMA Level 1 is used for Transmit and Receive | | | #### Interrupt Information ### Interface The SDLC Communications Adapter conforms to interface signal levels standardized by the Electronic Industries Association (EIA) RS232-C Standard. These levels are shown in the following figure. Additional lines used but not standardized by the EIA are pins 11, 18, and 25. These lines are designated as 'select standby,' 'test,' and 'test indicate,' respectively. 'Select standby' supports the switched network backup facility of a modem that has this option. 'Test' and 'test indicate' support a modem-wrap function for modems that are designed for business-machine controlled modem-wraps. Two jumpers on the adapter (P1 and P2) connect 'test' and 'test indicate' to the interface. ## **Specifications** <sup>\*</sup>Not standardized by EIA (Electronic Industries Association). ## **Logic Diagrams** The following pages contain the logic diagrams for the IBM Synchronous Data Link Control (SDLC) Adapter. SDLC Communications Adapter (Sheet 1 of 2) # **IBM Cluster Adapter** ## **Contents** | | <br> | <br> | · 1 . 5 12 18 | |-------|------|------|---------------| | • • | <br> | | 18 | | • • | <br> | | 18 | | • • • | | | | | | | | 83 | | | | | 83 | | | | | 84 | | | | | 90 | | | | | 90 | | | | | 91 | | | | | 94 | | | | | 96 | | | | | | | | | •••• | Indo | ## **Description** The Cluster Adapter is a 10.16 cm (4 inch) high by 25.4 cm (10 inch) wide communication adapter used for linking up to 64 IBM Personal Computers (PCs). The transmission rate is 375,000 bits per second (bps). A multi-drop bus architecture passively links (cluster operation is unaffected if the power to any station is off) the PCs to a coaxial cable. The coaxial cable bus can be a maximum length of 1 kilometer (3280 feet) and requires a 75-ohm ( $\Omega$ ) terminating resistor at both ends to minimize signal reflection. The coaxial cable drop can be a maximum length of 5 meters (16.4 feet) and a minimum length of 1 meter (3.3 feet). The following is an example of a cluster: The PCs share the bus through a distributed-access protocol called carrier sense multiple access with collision avoidance (CSMA/CA). With this protocol, each PC (station) that wants to transmit, calculates its own access-window wait time after no signal is sensed on the bus. The wait time differs for each station and changes with each transmission to prevent collisions (two stations transmitting at the same time). If cluster traffic is light (no signal is on the coaxial cable for approximately 2.8 milliseconds), a station that wants to transmit establishes cluster synchronization by transmitting all 1's (111 . . . 1) for 150 microseconds ( $\mu$ s), thereby forcing a carrier sense transition (On-to-Off). The station can then calculate its access-window wait time. Because the PCs are passively connected and operate under a distributed-access protocol, the operation of the cluster is unaffected if the power to any single station is off. The Cluster Adapter sends and receives frames consisting of link-control and information fields to and from other Cluster Adapters in the cluster. The Cluster Adapter consists of the following components: - 8031 8-bit Microcomputer - 8031 Accessible ROM - 8031 Accessible RAM - System Processor (8088) Interface - Adapter Status Register - 8088 Accessible ROM - 8255 Programmable Peripheral Interface (PPI) - Cyclic Redundancy Checking (CRC) Hardware - Cluster Interface The following is a block diagram of the Cluster Adapter: Cluster Adapter Block Diagram #### DANGER TO HELP PROTECT FROM LIGHTNING AND OTHER SOURCES OF ELECTRICAL SHOCK, IBM REQUIRES THAT THE COAXIAL CABLE SHIELDING BE GROUNDED, AND NEITHER THE FRAME NOR COVERS OF THE IBM PERSONAL COMPUTER CAN BE USED AS THE GROUNDING POINT. - To ensure proper operation of the cluster, the shielding of the coaxial cable cannot be grounded at more than one point. - If compliance to electrical codes require multiple ground points, then triaxial cable (double shielded) must be used. In using the triaxial cable, only the outer shielding can be grounded and under no circumstances should the outer shield be connected to the inner shield. - This installation should be performed by a licensed electrician. ## **8031 Microcomputer** The 8031 Microcomputer is the controlling processor for the Cluster Adapter. The 8031 has an 8K x 8-bit ROM, and a 4K x 8-bit static RAM. The 8031 consists of the following: - A processor - A dynamic 128 x 8-bit read/write data memory - 32 I/O lines - 2 16-bit timer/event counters - A five-source, two-priority-level, nested interrupt structure - A serial I/O port for multiprocessor communications - I/O expansion or a full duplex Universal Synchronous/Asynchronous Receiver/Transmitter (USART) - An on-chip oscillator and clock circuits. The 8031 also provides addressing for up to 64K bytes of program memory and 64K bytes of data memory. The 8031 is operated at 12 Megahertz (MHz), yielding a single-cycle time of 1 $\mu$ s. Program and data address spaces on the adapter are combined into a 64K-byte address space by ORing -Program Store Enable (-PSEN) and -Read (-RD). The memory address space includes not only the 8K x 8-bit ROM and 4K x 8-bit static RAM, but also the 8255 port and control registers and the 2653 registers necessary for CRC calculation. #### **8031 Ports** The 8031 on the Cluster Adapter provides external memory addresses through ports 0 and 2. - Port 0 is an 8-bit, open-drain, bidirectional, I/O port used as the multiplexed low-order address and data bus. - Port 2 is a bidirectional I/O port and provides the high-order address byte for the external memory. Port 1 of the 8031 is an 8-bit, bidirectional, I/O port used on the adapter for status conditions. Port 3 is an 8-bit, bidirectional, I/O port used as a serial port and as a source for external memory and serial-transmission control lines. ### The following is a summary of the 8031 port signals: | | Port 0 | Port 2 | Port 3 | Port 1 | |------|-----------------------------------|------------------------------------|--------------------------------------|-----------------------------------------| | | External Memory<br>Address | | | | | Bits | Low Order<br>Byte and<br>Data Bus | High Order<br>Address<br>Byte Only | Transmission<br>and Control<br>Lines | Status | | 7 | A7/D7 | A15 | -RD | Direction to 8031 | | 6 | A6/D6 | A14 | -WR | Error | | 5 | A5/D5 | A13 | -CRC INT | Communication<br>Port Busy | | 4 | A4/D4 | A12 | -RTS | RX Virtual I/O<br>Frame Available | | 3 | A3/D3 | A11 | +Internal Loop | RX Frame in (FIFO) | | 2 | A2/D2 | A10 | -Carrier Sense | Data Available for<br>8088 (0 = Active) | | 1 | A1/D1 | A9 | +TXD | Command or Data<br>Available for 8031 | | 0 | A0/D0 | A8 | +RXD | Command in<br>Progress | ### **Summary of 8031 Port Signals** #### Serial Transmission and Control Lines The serial transmission lines are: +Receive Data (+RXD) The +RXD line provides the serial port's receiver data input. +Transmit Data (+TXD) The +TXD line provides the serial port's transmitter data output. The serial transmission control lines are: -Request to Send (-RTS) The -RTS signal enables the adapter's transmitter to send data on the cluster cable bus. +Internal Loop The +Internal Loop line is used in the diagnostic mode. When high, it activates the internal loopback feature so the Cluster Adapter can receive the data it is transmitting without interference or being attached to the bus. -Carrier Sense is an input signal to port 3 that indicates the current state of the cluster; it is low (0) when the cluster is busy. The memory control lines are: -Write (-WR) The -WR line latches the data byte from port 0 into the external data memory. -Read (-RD) The -RD line enables external data memory to port 0. The interrupt line is: -CRC Interrupt (-CRC INT) The -CRC INT line is used to indicate a successful or unsuccessful comparison in CRC values. The signal source is -INT from the 2653 Polynomial Checker Generator. # 8K x 8-Bit ROM The 8K x 8-bit ROM contains the 8031 code necessary for hardware initialization and the data link control program (DLCP). The DLCP is the lowest level of software for the Cluster Adapter. The DLCP resides in the 8K by 8-bit ROM on the Cluster Adapter, which is accessible by the 8031 Microcomputer. # 4K x 8-Bit Static RAM The 4K x 8-bit static RAM is available to the 8031 for read/write storage necessary to implement the DLCP. The available space is used to buffer frames and to store control and cluster information. The 4K x 8-bit static RAM is implemented using two 2K x 8-bit static RAM modules. The following is the 8031 memory map: | Start Address (Hex) | Function | |---------------------|--------------------------------| | 0000 | DLCP ROM | | 2000 | RAM | | 3000 | 8255 Port A | | 3001 | 8255 Port B | | 3002 | 8255 Port C | | 3003 | 8255 Control | | 3004 | 2653 Character Register | | 3005 | 2653 Status Register | | 3006 | 2653 Mode Register | | 3007 | 2653 CRC Upper/Lower Registers | 8031 Memory Map ## 8088 Accessible ROM The 8088 (System Processor) accessible ROM is an 8K x 8-bit ROM and contains the 8088 code necessary to perform the remote initial program load (IPL) and power-on diagnostic functions. # **2653 Polynomial Generator Checker** The 2653 Polynomial Generator Checker is used by the 8031 Microcomputer to compute the Cyclic Redundancy Check (CRC) value for transmitted or received data blocks for error checking. The 2653 is programmed by the 8031 in the automatic mode to generate the American National Standards Institute (ANSI) CRC-16 values. Two 8-bit characters are read from the 2653 character register into the Block Check Character (BCC) generation unit to calculate the 16-bit check character. ## Programming is achieved as follows: - The Clear CRC command, hex 02, is issued to the 2653 command register at address hex 3005. - The Automatic Accumulation Mode command, hex 49, is issued to the 2653 mode register at address hex 3006. - The Start Accumulation command, hex 01, is issued to the 2653 command register at address hex 3005. - Characters to be accumulated are written to the character register at address hex 3004. The accumulated CRC value may be read by the 8031 from address hex 3007 (the 2653 CRC upper and lower registers) in two read operations. The 2653 alternately provides the upper and lower values. The 2653 is activated upon proper decoding of addresses in the range of hex 3004 through hex 3007 and the occurrence of -Read Strobe (-RS) or -Write (-WR). This allows the input to the -Read/Write (-R/W) pin of the 2653 to become stable prior to the fall of -Clear Entry 1 (-CE1), as required. # **Cluster Adapter I/O Register Definitions** The following defines the Cluster Adapter I/O registers: | Adapter | I/O Address<br>(Hex) | Device | |-----------|----------------------|-------------------------------| | Adapter 1 | 0790 | Adapter Status Register | | | 0791 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 0792 | Adapter Interrupt Register | | | 0793 | Adapter Reset Control | | Adapter 2 | 0В90 | Adapter Status Register | | | OB91 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | OB92 | Adapter Interrupt Register | | | 0В93 | Adapter Reset Control | | Adapter 3 | 1390 | Adapter Status Register | | | 1391 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 1392 | Adapter Interrupt Register | | | 1393 | Adapter Reset Control | | Adapter 4 | 2390 | Adapter Status Register | | | 2391 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 2392 | Adapter Interrupt Register | | | 2393 | Adapter Reset Control | Cluster Adapter I/O Registers # **Adapter Status Register** The adapter status is provided to the system data bus by a 74LS373 transparent latch. The following are the bit assignments: | Bit | Definition (1 = Active Unless Noted) | |-----|-------------------------------------------------| | 7 | Direction (1 = data expected from 8088 to 8031) | | 6 | Error | | 5 | Communication Port Busy | | 4 | RX Virtual I/O Frame Available | | 3 | RX Frame in First in First Out (FIFO) | | 2 | Data Available for 8088 (0 = active) | | 1 | Command/Data Available for 8031 | | 0 | Command in Progress | #### **Status Register Bit Definitions** The outputs of the transparent latch, though not enabled on the bus, continuously follow the inputs provided by the 8031 and 8255. Upon decoding of the read-status I/O address, the latch-enable input to the transparent latch goes low, latching the inputs of the current state and enabling the data onto the bus. The status bits are latched during the active read time to preserve the integrity of the data. When the outputs are disabled and the latch-enable input to the latch goes high at the end of the read cycle, the outputs of the transparent latch again monitor the inputs in real time. | Definition of Bits at Port 0791<br>(for Adapter 1)<br>(Command or Parameters for 8031) | | | |----------------------------------------------------------------------------------------|-----------------------|--| | Bit | Definition | | | 7 | Command or Data Bit 7 | | | 6 | Command or Data Bit 6 | | | 5 | Command or Data Bit 5 | | | 4 | Command or Data Bit 4 | | | 3 | Command or Data Bit 3 | | | 2 | Command or Data Bit 2 | | | 1 | Command or Data Bit 1 | | | 0 | Command or Data Bit 0 | | # Cluster Adapter Command/Data Register (Output) | | Definition of Bits at Port 0791<br>(for Adapter 1)<br>(Result or Data from 8031) | | | |-----|----------------------------------------------------------------------------------|--|--| | Bit | Definition | | | | 7 | Result or Data Bit 7 | | | | 6 | Result or Data Bit 6 | | | | 5 | Result or Data Bit 5 | | | | 4 | Result or Data Bit 4 | | | | 3 | Result or Data Bit 3 | | | | 2 | Result or Data Bit 2 | | | | 1 | Result or Data Bit 1 | | | | 0 | Result or Data Bit 0 | | | # Cluster Adapter Result/Data Register (Input) | | Definition of Bits at Port 0792 (for Adapter 1) | | | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Definitions | | | | 7-2 | Not used. | | | | 1 | Received Frame(s) Available. One or more information frames have been received and may be read using either the BIOS Receive Frame or Receive Virtual I/O Frame command (1 = active). | | | | 0 | Cluster BIOS Command Complete. The Cluster BIOS command intiated with the Initiate Transmit bit set is complete. The result must be obtained by issuing the same Cluster BIOS command with the Finish Transmit bit set (1 = active). | | | ## **Cluster Interrupt Status Bits** Note: Both bits 1 and 0 are set to indicate interrupt due to Cluster Status command complete. | Definition of Bits at Port 0793 (for Adapter 1) | | | |-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Bit | Definitions | | | 7-1 | Not used. | | | 0 | Reset Cluster Adapter. The adapter microprocessor as well as all other logic on the adapter will be held in a reset condition until there is an output with this Reset Adapter bit set to zero (1 = active). | | Note: Any output to the reset register will also disable the adapter from generating interrupts. # **Cluster Adapter Reset Register Bit Definitions** # **Cluster Adapter Interrupts** The Cluster Adapter may be set (one jumper selectable) to allow interrupts on either interrupt-level 3 or interrupt-level 7. An adapter error detected by diagnostic tests is reported if the interrupt jumper is missing. The received frames must be available or the Transmit operation complete (if initiated by a Transmit command with the Initiate Transmit bit set). Up to four Cluster Adapters can be installed at a station. Each adapter can be enabled/disabled and all are similar in operation. If enabled, the adapter generates interrupts on levels 3 or 7 provided one of the following conditions is met: - A received frame is available. - The Transmit Frame command is complete. - The Cluster Status command is complete. The following description is for adapter 1: - 1. Interrupts are enabled by executing an output instruction to the adapter's interrupt enable register. - 2. Interrupts are disabled by writing the hex 00 instruction to the adapter's reset register. Also, additional interrupts are disabled by generating the interrupt request. The adapter must be re-enabled after each interrupt if additional interrupts are desired. 3. To avoid resetting the adapter, data bit 0 must be set to a 0 when an output is sent to the adapter's reset register. No interrupt handler is provided for the cluster, and must be provided by the user who requires interrupt capability. The interrupt condition is provided in the adapter's interrupt register, as described in the Cluster Adapter Interrupt Status Bits table. # **Programming Considerations** The data link control program (DLCP) is the lowest level of software for the Cluster Adapter. The DLCP resides in the 8K by 8-bit ROM, which is accessible by the 8031 Microcomputer. The Cluster Adapter basic input/output system (BIOS) code resides in an 8K-byte 8088 accessible ROM on the Cluster Adapter at address hex D0000. Note: The Cluster Adapter decodes a 32K-byte range starting at hex D0000. High-level cluster BIOS commands are processed by the cluster BIOS into the appropriate low-level commands and parameters. The low-level commands and parameters are then passed to the 8031 Microcomputer, which performs the requested command. After the command is complete, the 8031 Microcomputer transfers the results back to the DLCP BIOS routine, which fills in the requester's link control block (LCB) with the results and then return through an interrupt return (IRET) to the requester that issued the INT hex 5A. The cluster BIOS level interface allows the higher layer communication program to transmit to and receive data from the specified destination through the bus. The basic unit of information transmitted using DLCP is a frame. A frame consists of a control field and an optional data field. The following functions are implemented in the DLCP to interface with the higher layer communication program and to ensure reliable data transfer between stations on the bus: - Higher layer communication program BIOS interface to the communication software - Frame assembly, reception and transmission - CRC generation and checking - Carrier sense multiple access with collision avoidance (CSMA/CA) - Error detection and recovery - Cluster status monitoring - Remote IPL # **Higher Layer Communication Program BIOS**Interface When the Power switch is set to On, the hex 5A software interrupt vector is set to the address of the Cluster Adapter BIOS by the adapter's self-test diagnostic code. #### Notes: - 1. The DLCP must be initialized before it can process most of its commands. - 2. Interrupt hex 5A is reserved for the Cluster Adapter BIOS and should not be changed. The higher layer communication program must access the Cluster Adapter BIOS through an interrupt hex 5A instruction. The program must set the Extra Segment (ES) Register output to the segment and the Base Index (BX) Register output to the offset of the Link Control Block (LCB) before invoking the cluster DLCP BIOS. All parameters, the return code, and the cluster status are passed through the LCB. #### The format of the LCB is shown below: | Link Control Block (LCB) | Number of Bytes | |--------------------------------------|-----------------| | Destination Station Physical Address | 1 | | Source Station Physical Address | 1 | | Command | 1 | | Buffer 1 Length | 2 | | Buffer 1 Address | 2 (Offset) | | | 2 (Segment) | | Buffer 2 Length | 2 | | Buffer 2 Address | 2 (Offset) | | | 2 (Segment) | | Return Code | 1 | | Cluster Status | 1 | | Select Adapter | 1 | #### Structure of Link Control Block (LCB) #### Notes: - 1. The internal variables and buffers of the DLCP are in the RAM resident on the adapter and are not directly accessible from the higher layer communication program. - 2. Select Adapter is used to select the adapter for which the command is intended (0 for adapter 1, 1 for adapter 2, 2 for adapter 3, and 3 for adapter 4). - 3. For the length and address fields, the word values are ordered least-significant byte first. The contents of buffer 1 and buffer 2 together form the information field of the frame. For example, buffer 1 can be used to store header bytes while buffer 2 can be used to store the actual data to be transferred. The return code indicates the success or failure of the function requested, and the error code if the function fails. The LCB status indicates the current status of the cluster. This field is valid as a result of the DLCP Status command. The LCB status field is also used by some commands to store an extended return code. # **Frame Transmission** Transmit or Transmit Virtual Information frames are sent by the DLCP to complete the corresponding DLCP BIOS commands. The DLCP on its own initiative transmits various frames. The following response frames are issued in response to a received frame: Ack Reception OK with no problems Frame Reject All receive buffers full Not Connected Not connected to sending station Bad Error Frame out of sequence (rejected) Duplicate Address Duplicate station address exists on the The following control frame is transmitted by the DLCP when the Power switch is set to On or at initialization: Initializing Broadcast to all stations to indicate that the source station is in the process of initializing and all connections to that station should be set to the disconnected state. Also, if any station has the same station address, it sends a duplicate-address response back to the initializing station. In addition, the DLCP determines if it is necessary to send a connect frame to establish connection with the destination station. If this station's Cluster Status table indicates that it is not connected to the destination station, the DLCP transmits a connect frame to establish connection and then transmits the information frame. If a not-connected control frame is received in response to the transmission of a frame, the DLCP transmits a connect frame to establish connection, then transmits the information frame. ## Frame Format The basic unit of information transmitted is a frame. The On-to-Off transition of the 'carrier sense' signal identifies the beginning of a frame, and the Off-to-On transition identifies the end. A frame consists of fixed control fields and an optional variable length information field. The following shows the format of a frame: | Field | Number of Bytes | Note | |-----------------------|-----------------|-------------| | Destination Address | 1 | Control | | Source Address | 1 | Field | | Transmit Window Token | 1 | | | Control | 1 | | | Sequence | 1 | | | Byte Count | 2 | | | Control CRC | 2 | 1 | | Information | 1 to 578 | Information | | Data CRC | 2 | Field | #### Frame Format Note: The minimum and maximum total number of bytes transmitted for a frame is 9 and 587, respectively. The transmission time for a frame ranges from approximately 1 millisecond (ms) for a minimum length frame up to approximately 16.5 ms for the maximum length frame. However, additional time may be required to gain access to the cluster before a frame can be sent. #### Control Field Format The control field consists of the following: **Destination Address** - The destination address can be any number from hex 00 through hex 3F; that is, 64 station addresses are supported. Address hex FF is reserved as the broadcast address that all stations respond to. Addresses hex FE through hex F0 are reserved for use as multicast addresses. **Source Address -** The source address is used to tell the DLCP the senders station address. The DLCP uses the source address as an index into a Cluster Status Table, which is used to maintain the status of connected stations and sequence numbers for each possible sender. Station addresses hex 00 through hex 3F are the only supported source addresses. Transmit Window Token - This value is updated for every transmission and is used in an algorithm to determine how long each station must wait after Carrier Sense Off before transmitting. **Control Byte -** The control byte is used to identify the function of a frame. There are two basic types of frames used in the cluster, information frames and control frames. Information frames are used to transfer information from one station to another, and control frames are used to assure reliable transfer of information across the cluster bus. - The following types of frames are used by the DLCP: - Acknowledge (hex 10) Confirm receipt of a frame. - **Initializing (hex 21)** Indicates that the source station is re-initializing. Existing connections to this station should be cleared. - Virtual Disk (hex 82) Identifies that this frame contains a data block and was transmitted as a result of the source station issuing a Transmit Virtual Frame DLCP command. One buffer is reserved for this frame. - Information (hex 83) Signifies the frame contains a data block and was transmitted as a result of the source station issuing a Transmit Frame DLCP command. There is a first-in-first-out (FIFO) buffer set aside for this frame. - Connect (hex 04) Establishes the virtual point-to-point connection between a pair of stations. - **Broadcast (hex 45)** Signifies that the frame is a broadcast or multicast frame. - Not Connected (hex 16) Indicates that the receiving station is not connected to the sending station. - Frame Reject (hex 17) Sent by the receiving station when it has received an information frame or a virtual disk frame and the DLCP does not have buffer space available to store the frame. - **Bad Error (hex 18)** Sent by the receiving station to indicate that a frame is out of sequence. - **Duplicate Address (hex 19)** Sent by the receiving station in response to an initializing control frame to indicate that more than one station has the same address. Are You There? (hex 1A) Sent to each station to poll for status in the cluster. Each station that is on sends a response to this query. An Acknowledge response frame is sent by stations that are initialized. A Frame Reject response is sent by stations that are not initialized. **Note:** The most-significant four bits of the frame-control byte have the following meaning: | Bit 7 | |-------| | Bit 6 | | Bit 5 | | Bit 4 | | | Frame Sequence Byte - If one of the acknowledge frames did not reach the transmitting station, the frame sequence byte is used to make sure that no duplicate information frames are received. The least-significant four bits in the Cluster Status Entry are used for maintaining a sequence number for transmitted and received frames. The first two bits are used for the sequence number for received frames. The two least-significant bits are used for the sequence number for transmitted frames. The sequence numbers are incremented each time a transmitting station sends an information frame and each time the receiving station accepts an information frame. If a mismatch occurs between the two stations, the sender marks the destination station in the disconnected state and sends a connect frame to try to reconnect with the destination station. If the connection attempt is successful, the frame is transmitted again. **Byte Count** - The byte count is the number of information bytes to be transmitted. If the frame is a control frame, the byte count is zero. There are two bytes allocated for the byte count. Control CRC - A 16-bit cyclic redundancy check (CRC) is calculated and appended to the end of the control block. A hardware CRC generator is used. The receiving station compares the control CRC received with the CRC calculated from the received data and makes sure they are the same. If they are not the same, the receiving station ignores the rest of the frame. **Data CRC** - A 16-bit CRC is calculated and appended to the end of the data block. The receiving station compares the data CRC received with the CRC calculated from the received information bytes and makes sure they are the same. If they are not the same, the receiving station ignores the received frame. ## **Information Field** This field is for an information frame only. The information field is absent in the control frames. The maximum number of information bytes that can be transmitted in a frame is 578. ## Cluster Access Protocol Collision avoidance is used with the Cluster Adapter. To avoid collisions, each station waits a different amount of time after 'carrier sense' goes inactive before transmitting. Stations get access to the cluster by timing from the end of the current transmission (-Carrier Sense On-to-Off transition) until its transmit time is reached, and then it may transmit. See also "Collision Avoidance (Medium or High Activity)" on page 30. Each station maintains two flags to determine that it is permitted to transmit. - 1. Synchronized Transmit Period. - Transmit Window. The Synchronized Transmit Period is set and the Transmit Window is cleared when the Carrier Sense Interrupt routine is entered. Also, timer 0 is reloaded with the count corresponding to this station's calculated Transmit Access Window. Timer 0 counts while 'carrier sense' is off and overflows when this station's Transmit Access Window is reached. Timer 0's overflow causes an interrupt that sets the Transmit Window flag and then reloads timer 0 with the count corresponding to the end of the synchronized transmit period. When timer 0 interrupts again on overflow, the Synchronized Transmit Period flag is reset to indicate that the synchronized transmit period is finished. # **Collision Avoidance (Medium or High Activity)** The following shows the timing during medium or high activity in the cluster: # **Collision Avoidance (Medium or High Activity)** TR =Time allocated for a receiver to start transmitting a response. Time delay for 1st Transmit Access Window. T1 = Time delay for 2nd Transmit Access Window. T2 = Time delay for 64th Transmit Access Window. T64 =SN =Station N's address with the bits in reverse order. Token = Transmit Window Token which is decremented by 2 for each transmitted frame. Delay time for Station N = $TR + ((Token + SN) \mod 128) x$ transmit window/2 #### **Notes:** - 1. TR is approximately 200 $\mu$ s. - 2. Transmit Access Window is approximately 40 $\mu$ s. A station must see its Transmit Window flag change from Off to On before it is permitted to transmit. The case where it does not see the change is covered in the next section. # **Collision Avoidance (Light Activity)** If cluster activity is light (1480 µs average access time since the previous transmission on the cluster) enough that the Synchronized Transmit Period (STP) flag is reset, then synchronization needs to be re-established to avoid collisions. The method used to re-establish synchronization is to transmit all 1's in the cluster for approximately 150 $\mu$ s and then to time the carrier sense On-to-Off condition to this station's transmit slot time. (See also "Collision Avoidance (Light Activity)" on page 33). ## **Collision Avoidance (Light Activity)** - TR = Time allocated for a receiver to start transmitting a response. - T1 = Time delay for 1st Transmit Access Window. - T2 = Time delay for 2nd Transmit Access Window. . T64 = Time delay for 64th Transmit Access Window. **Note:** Average cluster access time is 1480 $\mu$ s if the cluster is lightly loaded. A station that is initializing waits the time of two complete synchronization periods before sending its broadcast initializing frame to allow it to become synchronized with the cluster. If no frames are received in that time, it uses the procedure above to establish a synchronized transmit period. # **Frame Reception** The leading edge of the 'carrier sense' signal is used to interrupt the 8031 Microcomputer. The 8031 interrupt service routine updates its Transmit Window Token to the value transmitted with the frame, and also sets the timer 0 counter to the calculated Transmit Access Window based on the new token value. If the frame is not addressed to this station, the DLCP ignores the rest of the frame and leaves the interrupt routine. If the frame is addressed to the station, the DLCP checks the Cluster Adapter status to see if it can accept the frame. If this station is not connected to the source station then a not-connected control frame is transmitted to the source station. If the frame is out of sequence, an bad error control frame is transmitted to the source station. If the DLCP can accept the frame, a check is made that a receive buffer is available. If a buffer cannot be obtained, a frame-reject control frame is sent back to the transmitting station. This indicates that the frame cannot be accepted at this time and another attempt should be made. If the frame is received correctly, DLCP transmits an Acknowledge frame to the transmitting station and return the control to the interrupted 8031 program. # **Error Detection and Recovery** The DLCP can detect various cluster errors and tries to recover from them. If it is not able to recover after a specified number of retries, it notifies the calling program with the returned error code. The list of errors that can be detected is in the figure below: | Type of Error | Action Taken | Retry Count | (Seconds) | |-------------------------------|----------------------------------------------------------------------------|---------------------------------|------------------------------------------------------| | Cluster Busy Timeout | Report Error | N/A | 1.0 | | Cluster Access Timeout | Report Error | N/A | 13.0 | | No Response | Retransmit Frame | 8 | 0.20 | | Frame Reject | Retransmit Frame<br>after Delay | 1<br>2<br>3<br>4<br>5<br>6<br>7 | 0.24<br>0.09<br>0.16<br>0.25<br>0.36<br>0.49<br>0.64 | | Not Connected or Bad<br>Error | Transmit Connect<br>Control Frame and<br>If Successful<br>Retransmit Frame | N/A | N/A | | Command Timeout | Reset Adapter and<br>Report Error | N/A | 120.0 | # **Detectable Errors and Recovery** After correctly receiving a control frame or an information frame, the receiving station sends a response frame. If all receive buffers are in use, a Frame Reject response frame is transmitted. If the frame is out of sequence, a Bad Error response frame is transmitted. If the transmitting station did not get a confirmation of receipt after a certain time period, it assumes that the receiving station never got the frame and it transmits the same frame again. If the transmitting station still does not get a reply after eight retries, it assumes that the receiving station is not available and resets the Connected bit in the corresponding Cluster Adapter status entry. ## **Cluster Status Table** The DLCP keeps track of the status and sequence numbers for connection with stations 0 through 63 in the Cluster Table in the Cluster Adapter's RAM space. Offset 0 in the Cluster Table corresponds to the status for connection to station 0, offset 1 for station 1, and so on. The offset corresponding to a station's own address is used to store a duplicate-station address indicator. The bits for each Cluster Status Table byte are designated in the following chart: | Cluster Status Entry (1 Byte) | | | |-------------------------------|---|----------------------------| | С | 7 | 1 = Connected | | RB1 | 6 | Response ID | | RB0 | 5 | Response ID | | Р | 4 | 1 = Response Pending | | RS1 | 3 | Received Frame Sequence | | RSO | 2 | Received Frame Sequence | | TS1 | 1 | Transmitted Frame Sequence | | TS0 | 0 | Transmitted Frame Sequence | ## **Cluster Status Table Entry** Bit 7 - Connected (C) is set to 1 when your station has sent a connect frame and an acknowledge frame has been received, or when a connect frame has been received and an acknowledge has been sent. Connected is reset when a not-connected, bad error, or initializing control frame is received. # Bit 6, 5 - Response ID The following table defines the meaning of these two bits: | Bit 6<br>RB1 | Bit 5<br>RB0 | Type of Response | |--------------|--------------|------------------| | 0 | 0 | Acknowledge | | 0 | 1 | Frame Reject | | 1 | 0 | Not Connected | Response ID in Cluster Table Status Entry - Bit 4 Pending (P) is set to 1 by the transmitting station to indicate that it is waiting for an acknowledge frame from the destination station, and is reset by the interrupt handler when a response is received or upon a time-out. - Bit 3, 2 Received Frames Sequence Number is incremented every time a new data-sequenced information frame is successfully received. This sequence number and the transmitted frame sequence number are reset to 0 when a connection is established between two stations. - Bit 1, 0 Transmitted Frames Sequence Number is incremented every time a sequenced information frame is successfully transmitted; that is, an acknowledge is received from the destination station. # Remote IPL A vector is established at bootstrap vector INT hex 19 to the Remote System Reset Program Loader for the cluster, which is located in adapter 1's ROM. The original contents of the bootstrap vector are stored at vector INT hex 5B. The disk server station address is stored at the least-significant byte of vector INT hex E1. The number of the adapter from which to IPL is stored at the word corresponding to the segment at vector INT hex E1. The following actions are performed by the Remote System Reset Program Loader: - 1. The Remote System Reset Program Loader (in the Cluster Adapter's 8088 accessible ROM) uses a portion of the top 1K bytes of memory for variable and buffer space. - 2. The bootstrap vector is restored with its original vector (which was temporarily saved at INT hex 5B). The INT hex 5B vector is set to point to the adapter's diagnostic routines. - 3. The variables of DLCP are initialized by executing a DLCP BIOS Cluster Initialization command (hex 00) with parameters provided by a table of constants in the adapter's 8088 ROM. - 4. The user timer-interrupt vector at vector hex 1C is saved at interrupt vector hex E2 and replaced with the address of a routine to update a timer count variable used for time-outs by the Remote System Reset Program Loader. It is restored before this routine is left. - 5. A broadcast frame requesting IPL is sent using the DLCP BIOS command's Transmit Broadcast Frame (hex 08) to all stations in the cluster. The format of the data portion of the frame is: ``` Command = hex 91 (Request for IPL) ``` Session ID = hex 0000 (2 bytes) 6. An acknowledge information frame is expected with the following data: Command = hex 92 (Response to IPL request) Session ID = hex xxxx (2 bytes) Status = hex 00 (non-zero is irrecoverable error) xxxx = any hexidecimal number The server station's address is saved at the least-significant byte of vector INT hex E1. Up to eight retries are made unless a response from the disk server station is received. Approximately 4 seconds are allowed between retries. After the eight retries have been used, the user timer-interrupt vector is restored and then control is passed to the bootstrap routine. **Note:** If a Keep-Alive command is received from the disk server station, an additional 30 seconds is allowed. 7. Next, the Remote IPL program requests a data block containing program code from the disk server station. The request has the following form: Command = hex 93 Request IPL data block Session ID = hex xxxx (2 bytes) Status = hex 00 (Non-zero is a irrecoverable error) xxxx = any hexidecimal number The request is sent using the DLCP BIOS command's Transmit Frame (hex 03). Retries are made for up to 20 seconds if the return code indicates a Frame Reject or a No Response error. 8. The disk server sends a response containing the next data block. The response has the following form: Command = hex 94 Response with IPL data block Session ID = (2 bytes) hex xxxx Status = hex 00 (Non-zero is a irrecoverable error) Sector # = Relative sector number hex xxxx [0-512 bytes] Data Block = Data Block containing program code. xxxx = any hexidecimal number The DLCP BIOS Receive Frame command (hex 02) is issued to read the response frame containing the block of program code. Approximately 20 seconds are allowed to receive a valid response from the disk server station. If a Keep-Alive command is received from the disk server station, an additional 30 seconds are allowed. There is no limit to the number of Keep-Alive commands that are accepted. On time-out, the user timer-interrupt vector is restored and control is passed to the Bootstrap Loader by INT hex 19. The received sector number must start at zero and increment for each block of program code received. If the received sector number is incorrect or if the status is non-zero, then the user timer-interrupt vector is restored and control is passed to the bootstrap vector by INT hex 19. The sector number is two bytes long with the least-significant byte first in the received data. The received program code is inserted in memory starting at location hex 07C0:0000 and continuing upward. The end of the program code is determined when a frame is received that does not contain 512 bytes of program code. 9. The above two steps are repeated until the end of the program code is received. The user timer-interrupt vector is restored and control passes to the loaded program by a jump to hex 07C0:0000. #### Notes: - 1. The Remote IPL function is performed, even if local drives are attached, if the Remote IPL switch on Cluster Adapter 1 is On. Remote IPL is supported only for Cluster Adapter 1. The Remote IPL function can be stopped by pressing Control Break, and normal loading from local diskette drives occurs. - 2. For every block of data received, an arrow rotates in a clockwise direction on the screen. - 3. After power on or system reset, the cursor is moved to the right three columns for about 1 second. Special ROM diagnostic tests for the adapter can be executed by immediately pressing "Ctrl D" on the keyboard. Also, a request to load a general diagnostic program over the cluster can be selected by pressing "Ctrl L" at which time a blinking L is displayed. The adapter sends out a broadcast frame requesting a diagnostic program load. (The first data byte of the request frame is set to hex 90.) # **DLCP BIOS Commands** The DLCP BIOS commands are issued by the higher layer communication program to send and receive information through the cluster. The following are the DLCP BIOS commands: | Command Number (Hex) | Command Name | |----------------------|---------------------------| | 00 | Cluster Initialization | | 01 | Receive Virtual Frame | | 02 | Receive Frame | | 03 | Transmit Frame | | 04 | Reserved | | 05 | Display Cluster Status | | 06 | Cluster Status | | 07 | Status | | 08 | Broadcast Frame | | 09 | Transmit Virtual Frame | | 0A | Stop DLCP | | ОВ | Read Station Address | | ОС | Set Multicast Address | | OD | Check Command In Progress | | OE | Read IPL Switch | | OF | Start DLCP | | 10 | Dump Statistics | | 11 | Diagnostic Function 1 | | 12 | Diagnostic Function 2 | | 13 | Diagnostic Function 3 | | 14 | Diagnostic Function 4 | | 15 | Diagnostic Function 5 | | 16 | Diagnostic Function 6 | | 17 | Diagnostic Function 7 | **DLCP BIOS Commands** ## **DLCP Return Codes** The following table indicates the Return Codes that are defined for the cluster DLCP: | DLCP Return Codes | | | |-------------------|--------------------------------------------------------------------------------------|--| | Return Code | Meaning | | | Hex 00 | Successful Completion | | | Hex 30 | Initialization failed | | | Hex 31 | Cluster busy timeout (carrier sense active for 2 seconds) | | | Hex 32 | Duplicate station address on cluster | | | Hex 33 | No response from destination | | | Hex 34 | Frame rejected at destination | | | Hex 35 | Reserved | | | Hex 36 | Cluster access timeout (could not gain access to cluster within a 13 second timeout) | | | Hex 37 | Information field too long (more than 578 bytes) | | | Hex 38 | Information field empty | | | Hex 39 | DLCP command in progress | | | Hex 3A | Initialization required | | | Hex 3B | Received frame not available | | | Hex 3C | Error detected with 8031 (due to command timeout or other processor interface error | | | Hex 3D | Extended return code in cluster status field | | | Hex 3E | Invalid initialization parameters (too many or too large buffers specified) | | | Hex 3F | Previous DLCP BIOS command initiated with Initiate Transmit bit set is not complete | | #### **Cluster DLCP Return Codes** **Note:** A return code of hex 00 indicates successful completion of the DLCP BIOS command. Most of the other return codes indicate error conditions. ## Cluster Initialization (DLCP) = Hex 00 **Function:** This command initializes the DLCP and also transmits an initializing frame to inform others in the cluster. If another station in the cluster has the same address as this station, it sends a response frame indicating duplicate station address, and the return code is hex 32. The Initialization Control Block (ICB) must be built by the calling program with the initialization values indicated by the following: | Return Code | Definition | |-------------|------------------------------------------| | hex 00 | Successful completion | | hex 30 | Initialization failed | | hex 32 | Duplicate station address in the cluster | | hex 39 | Command in progress | | hex 3C | Error with 8031 | | hex 3E | Invalid initialization parameters | | | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 00 (Hex) | Unchanged | | Buffer 1 Length | = OF (Hex) | Unchanged | | Buffer 1 Address | Address of Initialization<br>Control Block (ICB) | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Cluster Initialization (DLCP) = Hex 00 #### **Initialization Control Block (ICB)** The calling program must set the buffer 1 address field in the LCB to the address of an initialization control block (ICB). The figure below shows the composition and bytes that make up the ICB: | Byte | Byte Definition | Value | | |------|-------------------------------------------------|---------|--| | 0 | (Bits) 7 6 5 4 3 2 1 0 | 0 | | | | (Value) 0 0 0 0 NVB MM1 MM2 | | | | 1 | Number of Large Buffers | 4 | | | 2 | Number of Small Buffers | 10 | | | 3 | Large Buffer Size | 584 ÷ 8 | | | 4 | Small Buffer Size | 40 | | | 5 | Maximum Number of Retries for No Response | 8 | | | 6 | Maximum Number of Retries for Rejected Frame | 2 | | | 7 | Transmit Access Window (TAW) | 40 ÷ 2 | | | 8 | Time Period Reserved for Response 200 | | | | 9 | Time from Frame Start to First Byte 150 | | | | 10 | Time Between Control Field and Data Field | 100 ÷ 2 | | | 11 | Timeout Waiting for Response to be Received 300 | | | | 12 | Timeout Waiting for Next Byte to be Received | 300 ÷ 6 | | | 13 | Timeout Waiting for Command to Complete | 7 | | | 14 | Timeout Waiting to Access Cluster | 200 | | Initialization Control Block (ICB) Byte 0 - Bits 7, 6, 5, 4, and 3 are reserved and must be set to 0. Bit 2 - No Virtual Buffer (NVB), when set to zero, allocates a receive buffer for Virtual Frames. Bit 1 and 0 - These bits are set to enable the first portion of all frames to be received (even if they are not addressed to this station). The following figure shows the Monitor Mode (MM) bit definitions: | MM1 | ммо | Monitor Mode Condition | | |-----|-----|------------------------------------------------------------------------------|--| | 0 | 0 | Normal Mode | | | 0 | 1 | Receives All Frames on Cluster | | | 1 | 0 | Invalid Setting | | | 1 | 1 | Receives Only Frames from or to Multicast<br>Address or This Station Address | | #### Monitor Mode Bit Definitions **Note:** In Monitor Mode, only the first portion of a frame (up to the size of the small buffer minus 7 bytes) is received. The first byte is set to the value of Transmit Window Token, and the second byte corresponds to the first data byte of the information field of the frame. - Byte 1 This byte indicates the number of large buffers allocated in the 8031 RAM for incoming frames. - Byte 2 This byte indicates the number of small buffers allocated in the 8031 RAM for incoming frames. - Byte 3 This byte indicates the large buffer size (each unit represents 8 bytes). Six bytes of the large buffer are reserved for control information. - Byte 4 This byte indicates the small buffer size (each unit represents 1 byte). Six bytes of the small buffer are reserved for control information. - Byte 5 This byte indicates the maximum number of times a frame is transmitted with no response from the destination station. - Byte 7 This byte is used to specify the Transmit Access Window (TAW) time period in $\mu$ s. For a 40 $\mu$ s TAW, set this byte to 20. After every transmitted frame, an Access Time Period is allocated, which is 64 times the TAW time period. - Byte 8 The value of this byte times TAW divided by 2 equals the amount of time ( $\mu$ s.) reserved after each frame for a response frame to be transmitted. - Byte 9 The value of this byte times 2 equals the delay in $\mu$ s after the start of a transmit frame before the first byte (destination) is transmitted. - Byte 10 The value of this byte times 2 equals the delay in $\mu$ s between the control field and data field of a frame. - Byte 11 The value of this byte times 6 equals the time allowed in $\mu$ s for a response frame to be received. - Byte 12 The value of this byte times 6 equals the time allowed in $\mu$ s for the next byte of a frame to be received. - Byte 13 The value of this byte times 16.7 equals the number of seconds allowed for any command in progress to finish before the 8031 indicates error hex 3C to the Cluster Adapter BIOS code. - Byte 14 The value of this byte times 67 milliseconds equals the amount of time allowed waiting to access the cluster before error hex 36 is returned. #### **Receive Virtual Frame = Hex 01** Function: This command is used to retrieve a data frame sent by the disk server (using Transmit Virtual Frame). #### Notes: - 1. There is only one virtual frame buffer for this type of data frame. - 2. The destination, command, and cluster status fields in the LCB are modified. | Return Code | Destination | | |-------------|------------------------------------------|--| | 1 00 | | | | hex 00 | Successful completion | | | hex 32 | Duplicate station address in the cluster | | | hex 37 | Information field too long | | | hex 38 | No information field present | | | hex 39 | Command in progress | | | hex 3A | Initialization required | | | hex 3B | No receive frame exists | | | hex 3C | Error detected with 8031 | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Destination | | Source | Don't Care | Source | | Command | = 01 (Hex) | Frame Control | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Length of Received Data if<br>Less Than Buffer 1 Length | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Length of Received Data<br>Placed in This Buffer | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Frame Sequence | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Receive Virtual I/O Frame = Hex 01 ### Receive Frame (from FIFO queue) = Hex 02 Function: This command is used to retrieve a data frame sent from another station (using Transmit Frame) from the First-In-First-Out (FIFO) queue. The FIFO queue can contain four full size frames and 10 small frames. **Note:** The field's destination, command, and cluster status in the LCB are modified. **Note:** If the adapter is in Monitor mode, the first byte returned is the Transmit Window Token. The second byte is the first data byte of the information field of the received frame. | Return Code | Definition | | |-------------|------------------------------------------|--| | hex 00 | Successful completion | | | hex 32 | Duplicate station address in the cluster | | | hex 37 | Information field too long | | | hex 38 | No information field present | | | hex 39 | Command in progress | | | hex 3A | Initialization required | | | hex 3B | No receive frame exists | | | hex 3C | Error detected with 8031 | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Destination | | Source | Don't Care | Source | | Command | = 02 (Hex) | Frame Control | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Length of Received Data if<br>Less Than Buffer 1 Length | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Length of Received Data<br>Placed in This Buffer | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Frame Sequence | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Receive Frame (from FIFO Queue) = Hex 02 ## Transmit Frame = Hex 03 Function: This command is used to transmit a data frame to another station where it can be retrieved by using the Receive Frame command. **Note:** See also "Special Transmit Mode Command Bits" on page 81 | Return Code | Definition | |-------------|--------------------------------------------------| | hex 00 | Successful completion | | hex 31 | Cluster always busy | | hex 32 | Duplicate station address in the cluster | | hex 33 | No response from destination | | hex 34 | Exceed allowed number of rejected frames | | hex 36 | Cluster access time-out | | hex 37 | Information field too long (frame is not sent) | | hex 38 | No information field present (frame is not sent) | | hex 39 | Command in progress | | hex 3A | Initialization required | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Destination | Unchanged | | Source | Don't Care | Unchanged | | Command | = 03 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Unchanged | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Transmit Frame = Hex 03 ## Display Cluster Status = Hex 05 **Function:** This command is used to determine and then display the cluster status. The On/Off status of 64 stations is displayed. Stations that have the Power switch set to On are displayed in reverse video. Your station is displayed in reverse video and blinking. If another station in the cluster has the same address as your station, a long beep sounds. Only those stations that are initialized can be displayed. Note: The screen should be cleared before issuing this command. Note: Type of status (destination field): hex 00 = report stations that are On hex FF = report stations that are initialized | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 31 | Cluster always busy | | hex 36 | Cluster access time-out | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|----------------------------------| | Field | Value at Entry | Value at Exit | | Destination | Type of Status | Unchanged | | Source | Don't Care | Unchanged | | Command | = 05 (Hex) | Unchanged | | Buffer 1 Length | Number of Stations<br>to Display | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Extended Return Code on<br>Error | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Display Cluster Status = Hex 05 This page explains the cluster status that may appear on your screen. NN is any station address from 0 to 63. The station you are using is indicated on the screen in blinking reverse video, and the box is marked by two asterisks. Stations that have their Power switches set to On are displayed in reverse video, and their boxes are marked by two Xs. Another station has the same address as your station; a long beep sounds every 3 seconds, the box is displayed in blinking reverse video, and is marked by an X and an asterisk. A station address not in the cluster is indicated by a box displayed in normal video and not marked with Xs or asterisks. #### Cluster Status = Hex 06 #### **Function:** This command determines the stations' On/Off status. The status bytes are stored in buffer 1 (as determined by the buffer 1 pointer in the LCB). The first byte's least-significant bit is the status of station 0. Bit 1 represents station 1. The least-significant bit of the second byte is the status of station 8, and so on. The number of stations checked is a parameter of this command. Only those stations that are initialized are reported. #### Notes: - Type of status (destination field): hex 00 = report stations that are On hex FF = report stations initialized - 2. See also "Special Transmit Mode Command Bits" on page 81 - 3. The size of the buffer required to store the cluster status bytes is (number of stations to check + 7) $\div 8$ . | Return Code | Definition | | |-------------|--------------------------|--| | hex 00 | Successful completion | | | hex 31 | Cluster always busy | | | hex 36 | Cluster access time-out | | | hex 39 | Command in progress | | | hex 3C | Error detected with 8031 | | | Link Control Block (LCB) | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------| | Field | Value at Entry | Value at Exit | | Destination | Type of Status | Unchanged | | Source | Don't Care | Unchanged | | Command | = 06 (Hex) | Unchanged | | Buffer 1 Length | Number of Stations to Check | Unchanged | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Extended Return Code on Error | | Select Adapter | <ul><li>= 0 for Adapter 1</li><li>= 1 for Adapter 2</li><li>= 2 for Adapter 3</li><li>= 3 for Adapter 4</li></ul> | Unchanged | Cluster Status = Hex 06 ### Status = Hex 07 Function: This command is used to return the status of the connection with a particular station. | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Stations for Which Unchanged Status is Desired | | | Source | Don't Care | Unchanged | | Command | = 07 (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Cluster Status | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Status = Hex 07 #### Transmit Broadcast Frame = Hex 08 Function: This command is used to transmit a data frame to another station where it can be retrieved by using the Receive Frame command. No acknowledgment to the frame is sent by the receiving stations. **Note:** Transmit Frame and Transmit Virtual Frames are converted to Broadcast Frames if the destination station number is greater than 127. **Note:** See also "Special Transmit Mode Command Bits" on page 81.. | Return Code | Definition | |-------------|--------------------------------------------------| | hex 00 | Successful completion | | hex 31 | Cluster always busy | | hex 32 | Duplicate station address in cluster | | hex 36 | Cluster access time-out | | hex 37 | Information field too long (frame is not sent) | | hex 38 | No information field present (frame is not sent) | | hex 39 | Command in progress | | hex 3A | Initialization required | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Destination | Unchanged | | Source | Don't Care | Unchanged | | Command | = 08 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Unchanged | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Transmit Broadcast Frame = Hex 08 ### Transmit Virtual Frame = Hex 09 This command is used to transmit a data frame Function: containing sector information from the disk server station. The information can be retrieved only by using the Receive Virtual Frame command. Note: See "Special Transmit Mode Command Bits" on page 81 | Definition | |--------------------------------------------------| | Successful completion | | Cluster always busy | | Duplicate station address in cluster | | No response from destination | | Frame rejected at destination | | Cluster access time-out | | Information field too long (frame is not sent) | | No information field present (frame is not sent) | | Command in progress | | Initialization required | | Error detected with 8031 | | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Destination | Unchanged | | Source | Don't Care | Unchanged | | Command | = 09 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Unchanged | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Transmit Virtual Disk Frame = Hex 09 # Stop DLCP = Hex 0A **Function:** This command is used to temporarily inhibit the DLCP from receiving or transmitting frames. Issue a Start DLCP command to leave the stopped state. | Definition | |--------------------------| | Successful completion | | Command in progress | | Initialization required | | Error detected with 8031 | | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 0A (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Dont' Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Stop DLCP = Hex 0A ### Read Station Address = Hex 0B Function: This command is used to return the address and state of the remote IPL switch of this station. | | urn Code | Definition | |----------------------------------------------------------------------------------------------|----------|---------------------| | hex 00 Successful completion<br>hex 39 Command in progress<br>hex 3C Error detected with 803 | 39 | Command in progress | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|------------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | This station's address | | Command | = OB (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | 00 = No IPL FF = IPL | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Read Address = Hex 0B #### Set Multicast Address = Hex 0C **Function:** This command is used to set the desired multicast address. The multicast address is a variation of the broadcast address (hex FF). More than one station may be assigned the same multicast address. A default value of hex FF is set when a cluster Initialization command is issued to the DLCP. A frame sent, using the Transmit Broadcast Frame command (8), to the group multicast address is received by all stations that share the multicast address. | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Desired Multicast<br>Address | Unchanged | | Source | Don't Care | Unchanged | | Command | = OC (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | <ul><li>= 0 for Adapter 1</li><li>= 1 for Adapter 2</li><li>= 2 for Adapter 3</li><li>= 3 for Adapter 4</li></ul> | Unchanged | Set Multicast Address = Hex 0C ## Check Inside DLCP Flag = Hex 0D Function: This command is used to return an indication that a DLCP command is already in progress. This command is necessary only for programs that call DLCP from inside an interrupt routine. If a DLCP command is already in progress, the interrupt routine should return to the interrupted program to allow the current DLCP command to finish. Return Code Definition hex 00 Command not in progress hex 39 Command in progress hex 3C Error detected with 8031 | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = OD (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Check Inside DLCP Flag = Hex 0D ### Read IPL Switch = Hex 0E Function: This command is used to read the state of the Remote IPL switch on the requesting station. | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | This station's address | | Command | = OE (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | IPL Switch (00 = No IPL<br>FF = IPL) | | Select Adapter | <ul><li>= 0 for Adapter 1</li><li>= 1 for Adapter 2</li><li>= 2 for Adapter 3</li><li>= 3 for Adapter 4</li></ul> | Unchanged | Read IPL Switch = Hex 0E # Start DLCP = Hex 0F Function: This command is used to release the DLCP from the stopped state. It enables the DLCP to receive and transmit frames. | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3A | Initialization required | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = OF (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Start DLCP = Hex 0F # **Dump Statistics = Hex 10** **Function:** This command is used to transfer the current communication statistics block from the adapter. | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 10 (Hex) | Unchanged | | Buffer 1 Length | 12 bytes | Unchanged | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | **Dump Statistics = Hex 10** #### **Communication Statistics Block (CSB)** The Cluster Adapter returns information regarding previous activity in the CSB. | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | The figure below shows the composition and definition of the CSB bytes: | Byte | Definition | |------|---------------------------------------------------| | 0 | Number of Times No Response Received (LSB) | | 1 | Number of Times No Response Received (MSB) | | 2 | Number of Times Frame Rejects Received | | 3 | Number of Control Frames Correctly Received (LSB) | | 4 | Number of Control Frames Correctly Received (MSB) | | 5 | Number of Data Frames Correctly Received (LSB) | | 6 | Number of Data Frames Correctly Received (MSB) | | 7 | Number of Control Frames with CRC Error | | 8 | Number of Data Frames with CRC Error | | 9 | Number of Duplicate Frames Received | | 10 | Number of Received Frames That Were Rejected | | 11 | Number of Transmit Collisions | #### Communication Statistic Block # Diagnostic Function 1 = Hex 11 **Function:** This command is used to run an internal diagnostic test. (Reserved for diagnostic use only.) | Bit 1 | Test adapter processor-to-processor interface | |-------|-------------------------------------------------------------------------------| | Bit 2 | Reserved | | Bit 3 | Test driver and receiver logic (terminating plug required for diagnostic use) | | Bit 4 | Test interrupt logic (set transmit interrupt status bit) | | Bit 5 | Test interrupt logic (set receive interrupt status bit) | | Bit 6 | Clear transmit and receive interrupt status bits (no interrupt) | | Bit 7 | Set transmit and receive interrupt status bits (no interrupt) | | Return Code | Definition | |-------------|--------------------------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | hex 3D | Error detected by 8031 diagnostic test | | | (reason for error in Cluster Status field) | | Link Control Block (LCB) | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------|----------------------| | Field | Value at Entry | Value at Exit | | Destination | Test Number ** | Unchanged | | Source | Don't Care | Unchanged | | Command | = 11 (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Don't Care | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Extended Return Code | | Select Adapter | <ul><li>= 0 for Adapter 1</li><li>= 1 for Adapter 2</li><li>= 2 for Adapter 3</li><li>= 3 for Adapter 4</li></ul> | Unchanged | **Diagnostic Function 1 = Hex 11** Note: \*\* Test number (Destination field) ## Diagnostic Function 2 = Hex 12 Function: This command is used to transfer data to the adapter's RAM from a buffer in system memory. The data in buffer 1 is transferred to the address specified by buffer 2 in the 8031 address space. (Reserved for diagnostic use only.) | Return Code | Definition | |-------------|--------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 12 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Set Offset to Address<br>in 8031 RAM Space<br>to Place Data | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | <ul><li>= 0 for Adapter 1</li><li>= 1 for Adapter 2</li><li>= 2 for Adapter 3</li><li>= 3 for Adapter 4</li></ul> | Unchanged | Diagnostic Function 2 = Hex 12 ## Diagnostic Function 3 = Hex 13 Function: This command is used to transfer data from the adapter's RAM to a buffer in system memory. The data is transferred starting at the address specified by the buffer 2 address (offset) in 8031 memory to buffer 1 in the main system's memory. (Reserved for diagnostic use only.) | Return Code | Definition | |------------------|----------------------------------------------| | hex 00<br>hex 39 | Successful completion<br>Command in progress | | hex 3C | Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 13 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Set Offset to Address<br>in 8031 RAM Space<br>from Which to get<br>Data | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Diagnostic Function 3 = Hex 13 ## Diagnostic Function 4 = Hex 14 Function: This command is used to transfer data to the 8031's internal RAM from a buffer in system memory. The data in buffer 1 is transferred to the address specified by buffer 2 address in 8031 memory. (Reserved for diagnostic use only.) **Note:** Extreme care must be used to prevent destroying data in the 8031's stack and registers in this internal chip RAM. Also, there are only 128 bytes of RAM. | Return Code | Definition | |------------------|----------------------------------------------| | hex 00 | Successful completion | | hex 39<br>hex 3C | Command in progress Error detected with 8031 | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 14 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Set Offset to Address<br>in 8031 on Chip<br>Space to Place Data | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Diagnostic Function 4 = Hex 14 ## Diagnostic Function 5 = Hex 15 Function: This command is used to transfer data from the 8031's internal RAM to a buffer in system memory. The data is transferred starting at the address specified by buffer 2 address (offset) in 8031 memory to buffer 1 in the main system's memory. (Reserved for diagnostic use only.) | Return Code | Definition | | |-------------|--------------------------|--| | hex 00 | Successful completion | | | hex 39 | Command in progress | | | hex 3C | Error detected with 8031 | | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|--------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 15 (Hex) | Unchanged | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | Buffer 1 Address | Points to Buffer 1 | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Set Offset to Address<br>in 8031 RAM from<br>Which to Get Data | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Unchanged | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Diagnostic Function 5 = Hex 15 ## Diagnostic Function 6 = Hex 16 Function: This command is used to execute an 8031 program at the address specified by the buffer 2 address field. A "Call" is made to that address and it is expected that the called program sets the 8031 accumulator to a return code value before returning. This return code is placed in the Cluster Status field if non-zero. (Reserved for diagnostic use only.) | Return Code | Definition | |-------------|----------------------------------------| | hex 00 | Successful completion | | hex 39 | Command in progress | | hex 3C | Error detected with 8031 | | hex 3D | Extended return code in cluster status | | Link Control Block (LCB) | | | |--------------------------|----------------------------------------------------------------------------------|----------------------| | Field | Value at Entry | Value at Exit | | Destination | Don't Care | Unchanged | | Source | Don't Care | Unchanged | | Command | = 16 (Hex) | Unchanged | | Buffer 1 Length | Don't Care | Unchanged | | Buffer 1 Address | Don't Care | Unchanged | | Buffer 2 Length | Don't Care | Unchanged | | Buffer 2 Address | Set Offset to Address<br>in 8031 RAM Space<br>where a Callable<br>Program Exists | Unchanged | | Return Code | Don't Care | Set to Return Code | | Cluster Status | Don't Care | Extended Return Code | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | Diagnostic Function 6 = Hex 16 #### Diagnostic Function 7 = Hex 17 Function: This command is used to transmit any type of frame to another station. For example, a control frame may be sent to another station. (Reserved for diagnostic use only.) | Return Code | Definition | |--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | hex 00<br>hex 31<br>hex 32<br>hex 33<br>hex 34<br>hex 36<br>hex 37 | Successful completion Cluster always busy Duplicate station address in cluster No response from destination Exceeded allowed rejected frames Cluster access time-out | | hex 39<br>hex 3A<br>hex 3C | Information field too long Command in progress Initialization required Error detected with 8031 | | | Link Control Block (LCB) | | | | | | |------------------|----------------------------------------------------------------------------------|--------------------|--|--|--|--| | Field | Value at Entry | Value at Exit | | | | | | Destination | Destination | Unchanged | | | | | | Source | Frame Type | Unchanged | | | | | | Command | = 17 (Hex) | Unchanged | | | | | | Buffer 1 Length | Length of Calling<br>Program's Buffer 1 | Unchanged | | | | | | Buffer 1 Address | Points to Calling<br>Program's Buffer 1 | Unchanged | | | | | | Buffer 2 Length | Length of Calling<br>Program's Buffer 2 | Unchanged | | | | | | Buffer 2 Address | Points to Calling<br>Program's Buffer 2 | Unchanged | | | | | | Return Code | Don't Care | Set to Return Code | | | | | | Cluster Status | Don't Care | Unchanged | | | | | | Select Adapter | = 0 for Adapter 1<br>= 1 for Adapter 2<br>= 2 for Adapter 3<br>= 3 for Adapter 4 | Unchanged | | | | | Diagnostic Function 7 = Hex 17 #### **Special Transmit Mode Command Bits** The three most-significant bits in the command field of the LCB have the following meanings for transmit commands: | Name | Bit | Meaning | |-------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Initiate Transmit | 7 | Initiate transmit operation but return before complete with return code set to immediate result. | | Finish Transmit | 6 | Wait for previously started transmit operation to complete. Return with return code in LCB set to result of transmit operation. | | Return Status | 5 | If the transmit operation is complete, the return code is set to hex 00 (transmit operation complete result available). Otherwise the return code is set to hex 3F (transmit operation not complete). | #### **Special Transmit Command Bits** #### Notes: 1. These special transmit command bits are valid only for the following DLCP BIOS commands: | Transmit Frame | (hex 03) | |------------------------|----------| | Cluster Status | (hex 06) | | Transmit Broadcast | (hex 08) | | Transmit Virtual Frame | (hex 09) | - 2. A transmit operation started with the Initiate Transmit bit set to 1 must be finished by issuing the same transmit command, with a different LCB and the Finish Transmit bit set to 1. If the immediate return code was not zero, the transmit operation is already complete. - 3. If an interrupt handler is being used for receive frames, an interrupt is also generated when the transmit operation is complete for transmit operations initiated with the Initiate Transmit bit set. The Transmit Interrupt status bit is set to 1 to indicate that the transmit operation is complete. This bit is bit 0 of adapter port hex 0792 (for adapter 1). #### Interface # **System Processor I/O Interface** Four Cluster Adapters can be installed at each station. The Cluster Adapter number is selected by switch positions 1 through 4 of switch block 2. These positions correspond to I/O address bits 10, 11, 12, and 13. An adapter is selected when a select switch is On, and the adapter receives a high level (1) on the corresponding I/O address bit. Note: High level is 1 and low level is 0. If multiple Cluster Adapters are installed at a station, each adapter can have only one address select switch set to On. A station cannot have two Cluster Adapters with the same address. #### Notes: - 1. When more than one address select switch is On, the Cluster Adapter decodes and responds to all I/O addresses selected. - Cluster Adapter 1 is the only adapter that decodes and responds to all memory addresses; therefore, if more than one Cluster Adapter is set as number 1 (C1), undesirable results - 3. If a Cluster Adapter does not have a select switch set to On, it does not respond. # **Cluster Adapter Switch Settings** Cluster Adapter addresses and functions can be selected by two eight-switch dual in-line package (DIP) switch blocks. The following shows the switch assignments: #### **Notes:** - 1. Switch 8 of switch block 1 selects remote initial program load (IPL) when in the On position. - 2. Switch 7 of switch block 1 is reserved. It must be in the Off position. | Switch | Legend | Function | |--------|--------|------------------------| | SW-8 | IPL | Remote IPL | | SW-7 | N/A | Reserved (Must be Off) | | SW-6 | A5 | Station Address Bit 5 | | SW-5 | A4 | Station Address Bit 4 | | SW-4 | А3 | Station Address Bit 3 | | SW-3 | A2 | Station Address Bit 2 | | SW-2 | A1 | Station Address Bit 1 | | SW-1 | Α0 | Station Address Bit 0 | #### **Switch Block 1 Bit Assignments** | Switch | Legend | Function | | |--------|--------|-------------------|--| | SW-8 | N/A | Reserved | | | SW-7 | RDY | I/O Channel Ready | | | SW-6 | N/A | Reserved | | | SW-5 | N/A | Reserved | | | SW-4 | C4 | Select Adapter 4 | | | SW-3 | С3 | Select Adapter 3 | | | SW-2 | C2 | Select Adapter 2 | | | SW-1 | C1 | Select Adapter 1 | | #### **Switch Block 2 Bit Assignments** The following shows the station-address switch settings on switch block 1. | | Switch Block 1 Switch Settings | | | | | | |---------|--------------------------------|------|------|------|------|------| | Station | SW 1 | SW 2 | SW 3 | SW 4 | SW 5 | SW 6 | | 0 | Off | Off | Off | Off | Off | Off | | 1 | On | Off | Off | Off | Off | Off | | 2 | Off | On | Off | Off | Off | Off | | 3 | On | On | Off | Off | Off | Off | | 4 | Off | Off | On | Off | Off | Off | | 5 | On | Off | On | Off | Off | Off | | 6 | Off | On | On | Off | Off | Off | | 7 | On | On | On | Off | Off | Off | | 8 | Off | Off | Off | On | Off | Off | | 9 | On | Off | Off | On | Off | Off | | 10 | Off | On | Off | On | Off | Off | | 11 | On | On | Off | On | Off | Off | | 12 | Off | Off | On | On | Off | Off | | 13 | On | Off | On | On | Off | Off | | 14 | Off | On | On | On | Off | Off | #### Notes: - 1. Bit switches 7 and 8 are not applicable to the station address. - 2. ''On'' represents the closed/on position. - 3. "Off" represents the open/off position. #### **Station Address Switch Settings** | | Switch Block 1 Switch Settings | | | | | | |---------|--------------------------------|------|------|------|------|------| | Station | SW 1 | SW 2 | SW 3 | SW 4 | SW 5 | SW 6 | | 15 | On | On | On | On | Off | Off | | 16 | Off | Off | Off | Off | On | Off | | 17 | On | Off | Off | Off | On | Off | | 18 | Off | On | Off | Off | On | Off | | 19 | On | On | Off | Off | On | Off | | 20 | Off | Off | On | Off | On | Off | | 21 | On | Off | On | Off | On | Off | | 22 | Off | On | On | Off | On | Off | | 23 | On | On | On | Off | On | Off | | 24 | Off | Off | Off | On | On | Off | | 25 | On | Off | Off | On | On | Off | | 26 | Off | On | Off | On | On | Off | | 27 | On | On | Off | On | On | Off | | 28 | Off | Off | On | On | On | Off | | 29 | On | Off | On | On | On | Off | | 30 | Off | On | On | On | On | Off | | 31 | On | On | On | On | On | Off | | 32 | Off | Off | Off | Off | Off | On | **Station Address Switch Settings** | | Switch Block 1 Switch Settings | | | | | | |---------|--------------------------------|------|------|------|------|------| | Station | SW 1 | SW 2 | sw 3 | SW 4 | SW 5 | SW 6 | | 33 | On | Off | Off | Off | Off | On | | 34 | Off | On | Off | Off | Off | On | | 35 | On | On | Off | Off | Off | On | | 36 | Off | Off | On | Off | Off | On | | 37 | On | Off | On | Off | Off | On | | 38 | Off | On | On | Off | Off | On | | 39 | On | On | On | Off | Off | On | | 40 | Off | Off | Off | On | Off | On | | 41 | On | Off | Off | On | Off | On | | 42 | Off | On | Off | On | Off | On | | 43 | On | On | Off | On | Off | On | | 44 | Off | Off | On | On | Off | On | | 45 | On | Off | On | On | Off | On | | 46 | Off | On | On | On | Off | On | | 47 | On | On | On | On | Off | On | | 48 | Off | Off | Off | Off | On | On | | 49 | On | Off | Off | Off | On | On | | 50 | Off | On | Off | Off | On | On | **Station Address Switch Settings** | | Switch Block 1 Switch Settings | | | | | | |---------|--------------------------------|------|------|------|------|------| | Station | SW 1 | SW 2 | SW 3 | SW 4 | SW 5 | SW 6 | | 51 | On | On | Off | Off | On | On | | 52 | Off | Off | On | Off | On | On | | 53 | On | Off | On | Off | On | On | | 54 | Off | On | On | Off | On | On | | 55 | On | On | On | Off | On | On | | 56 | Off | Off | Off | On | On | On | | 57 | . On | Off | Off | On | On | On | | 58 | Off | On | Off | On | On | On | | 59 | On | On | Off | On | On | On | | 60 | Off | Off | On | On | On | On | | 61 | On | Off | On | On | On | On | | 62 | Off | On | On | On | On | On | | 63 | On | On | On | On | On | On | #### **Station Address Switch Settings** The following I/O addresses are assigned to the Cluster Adapters: | Adapter | I/O Address<br>(Hex) | Device | |-----------|----------------------|-------------------------------| | Adapter 1 | 0790 | Adapter Status Register | | | 0791 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 0792 | Adapter Interrupt Register | | | 0793 | Adapter Reset Control | | Adapter 2 | 0890 | Adapter Status Register | | | 0891 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 0892 | Adapter Interrupt Register | | | 0893 | Adapter Reset Control | | Adapter 3 | 1390 | Adapter Status Register | | | 1391 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 1392 | Adapter Interrupt Register | | | 1393 | Adapter Reset Control | | Adapter 4 | 2390 | Adapter Status Register | | | 2391 | Adapter Command/Data (Output) | | | | Adapter Result/Data (Input) | | | 2392 | Adapter Interrupt Register | | | 2393 | Adapter Reset Control | #### Cluster Adapter I/O Summary The Adapter Reset command resets the 8031 and 8255 on a Cluster Adapter by writing a 1 to that adapter's Adapter Reset/Interrupt Disable port address. This sets a 74LS74 latch, which remains set until a 0 is written to the same port. The latch must remain set for a minimum of 2 $\mu$ s, which is the minimum reset time of the 8031 operating at 12 MHz. The interrupts on a Cluster Adapter can be disabled by writing a 0 to the Adapter Reset/Interrupt Disable port, when -IOW is active (0). The Cluster Adapter can drive the I/O Channel Ready line low in synchronization with the system clock when the processor reads from the adapter card. This enables a longer read cycle from the expansion slots. The option is selected by setting the I/O Channel Ready switch (switch 7 of switch block 2) to On. # **System Processor Memory Interface** The memory addresses assigned to the Cluster Adapter are hex D0000 through hex D7FFF. These addresses are fully decoded only on adapter 1, and are selected by setting the C1 select switch (SW2-1) to On. Each station must have one Cluster Adapter selected as number 1. # **System Processor Interrupt Interface** The Cluster Adapter provides an interrupt interface to the system processor with Interrupt Request 3 (IRQ3) or Interrupt Request 7 (IRQ7). The desired interrupt is selected using the interrupt select jumper on the Cluster Adapter. The selection of the interrupt is dependent on the programming requirements. The following is a sequence of the interrupt process for adapter 1: - 1. The system processor enables interrupts by writing to the adapter interrupt enable register at address hex 0792. - 2. Upon receipt of an interrupt condition, the 8031 sends a negative active (0) pulse of 10 μs on the port C bit 0 (PC0) line of the 8255 which is connected to IRQ3 or IRQ7. The low-to-high transition of this line prevents this adapter and other Cluster Adapters in the system from generating further interrupt requests. The 8031 processor also sets either Port C1 (PC1) or Port C2 (PC2) of the 8255 to indicate the source of the interrupt. PC1 corresponds to a transmit interrupt, and PC2 corresponds to a receive interrupt. If both PC1 and PC2 are set, the source of the interrupt is the completion of a Cluster Status command. - 3. The system processor reads I/O addresses hex 0792, 0B92, 1392, and 2392 on each Cluster Adapter to determine the cause of the interrupt. After all pending requests are handled, the system processor re-enables interrupts on all desired adapters. # **8255** Programmable Peripheral Interface (PPI) The 8255 is used to provide an asynchronous interface between the system processor and the 8031 Microcomputer without the use of interrupts or direct memory access (DMA). #### Port A Port A is operated in mode 2 as a strobed, bidirectional, I/O bus. In this mode, all eight bits of Port A (PA0 through PA7) are dedicated to data transfer between the microcomputer (8031) and the system processor (8088). #### Port B Port B is operated in mode 0. The low-order six bits (PB0 through PB5) provide the station address, and the high-order bit (PB7) provides the Remote IPL (On/Off) status. Bit 7 (PB6 is reserved). The source of information for Port B is switch block 1. When a bit switch is On, the bit is active (low). The microprocessor code in the 8031 complements the Port B information to produce logical 1 active bits. #### Port C When port C is operated in mode 2, five lines are dedicated as handshaking signals. The following four handshaking signals are used by the Cluster Adapter: • -Output Buffer Full (-OBF) A low signal on the -OBF (PC7) line indicates that the microcomputer (8031) has written data to Port A. -OBF provides status to the adapter status register. • -Acknowledge (-ACK) A low signal on the -ACK (PC6) line enables the tri-state output buffer of Port A to send out data to the system processor (8088); otherwise the output is in a high impedance state. #### Input Buffer Full (IBF) A high signal on the IBF (PC5) output indicates that data from the 8088 has been loaded into Port A. IBF provides input to the adapter status register and to the 8031. #### -Strobe Input (-STB) A low signal on the -STB (PC4) loads data from the 8088 into Port A. The following is a summary of the 8255 port signals: | | 8255 Port Signals | | | | | | |-----|-------------------|-----------------------|-------------------------|--|--|--| | Bit | Port A<br>Mode 2 | Port B<br>Mode 0 | Port C<br>Mode 2 | | | | | 7 | Data Bit 7 | Remote IPL | -OBF | | | | | 6 | Data Bit 6 | Reserved | -ACK | | | | | 5 | Data Bit 5 | Station Address Bit 5 | +IBF | | | | | 4 | Data Bit 4 | Station Address Bit 4 | -STB | | | | | 3 | Data Bit 3 | Station Address Bit 3 | Reserved | | | | | 2 | Data Bit 2 | Station Address Bit 2 | Receive Frame Interrupt | | | | | 1 | Data Bit 1 | Station Address Bit 1 | TX Complete Interrupt | | | | | 0 | Data Bit 0 | Station Address Bit 0 | Interrupt Request | | | | **Summary of 8255 Port Signals** #### **Cluster Bus Interface** The bus interface consists of a transmitter, receiver, carrier sense circuitry, and internal loopback-mode logic. They are the interface between the 8031 serial port and the $75\Omega$ coaxial cable. #### **Cluster Adapter Transmitter** The Cluster Adapter transmitter consists of an Am26LS29 tri-state, single-ended, line driver. This driver features a high capacitive-load drive capability with buffered outputs, individual rise-time control, and output short-circuit protection. To transmit data to the bus, the microprocessor code in the 8031 must first enable the -RTS signal on the port 3 interface. Data can then be sent to the bus bit-by-bit from +TXD on port 3. The transmitter is electrically isolated from the logic circuits on the Cluster Adapter by an HCPL-2531 high-speed optocoupler, which uses a light-emitting diode and an integrated light detector to obtain electrical insulation. #### **Cluster Adapter Receiver** The Cluster Adapter receiver consists of an Am26LS34 high-performance, differential line receiver. The received signal is amplified by a 5535 Operational Amplifier and is provided to the Am26LS34. To receive the digital data, the microprocessor code in the 8031 must ensure that the +Internal Loop signal on port 3 is inactive. Data can then be received bit-by-bit at port 3 from +RXD. The receiver is also electrically isolated from the logic circuits on the Cluster Adapter by an HCPL-2531 high-speed optocoupler. #### **Carrier Sense Circuitry** The carrier sense circuitry provides information about the state of This information is needed to implement the Cluster Adapter. the collision avoidance protocol. The amplified signal received from the bus is passed through a comparator to detect the negative voltage state (less than approximately -150 millivolts). This negative portion of the signal is inverted into +NRXD and then ORed with the positive portion (greater than approximately +150 millivolts) of the +RXD signal. The result is then sent to the clear input of a 74LS161 counter. As long as this ORed signal (CLR) is active (0), the counter is held reset. When the signal goes inactive (1), the counter begins counting on the rising edges of the 8031 + ALE signal. On the fourth + ALE pulse, the counter is disabled and the -Carrier Sense signal goes inactive (1). The time delay between the bus going inactive and -Carrier Sense going inactive is 1.5 $\mu$ s. #### **Internal Loopback Mode** The Cluster Adapter provides logic to allow the 8031 to receive the data it is transmitting without interference from the bus by wrapping the transmitter to the receiver on the Cluster Adapter. The adapter is placed into internal loopback mode when the 8031 microprocessor code sets the +Internal Loop signal active (1). This mode returns any data transmitted on +TXD to +RXD. Notice that -RTS may or may not be active. If -RTS is active, the data not only returns to +RXD, but also is transmitted to the bus. # **Specifications** # **Logic Diagrams** The following pages contain logic diagrams. Cluster Adapter (Sheet 2 of 3) Cluster Adapter (Sheet 3 of 3) #### **Index** #### A adapter reset 89 address switch settings 85 #### B BIOS interface 20 block diagram 3 #### C check inside DLCP flag 68 cluster access protocol 29 Cluster Adapter 1 adapter reset 89 address switch settings 85 BIOS interface 20 block diagram 3 bus interface 94 check inside DLCP flag 68 cluster access protocol 29 cluster initialization (DLCP initialization) 44 cluster status 58 cluster status table 35 collision avoidance 30 control field format 25 diagnostic function 1 73 diagnostic function 2 75 diagnostic function 3 76 diagnostic function 4 77 diagnostic function 5 78 diagnostic function 6 79 diagnostic function 7 80 display cluster status 55 DLCP BIOS commands 42 dump statistics 71 error detection and recovery 34 frame format 24 frame reception 33 frame transmission 22 I/O addresses 83 I/O register definitions 12 Intel 8031 memory map 10 Intel 8031 port signals 5 Intel 8255 port signals 91 interrupt interface 90 interrupts 16 Link Control Block (LCB) 21 memory interface 90 polynomial generator checker 10 programming considerations 18 read IPL switch 69 read station address 66 receive frame 51 receive virtual frame 49 remote IPL 37 set Multicast address 67 special transmit mode command bits 81 start DLCP 70 status 60 status register bit definitions 13 stop DLCP 65 switch blocks bit assignments 84 switch settings 84 transmit broadcast frame 61 transmit frame 53 transmit virtual frame 63 Cluster Adapter switch settings 84 cluster bus interface 94 cluster initialization (DLCP initialization) 44 cluster status 58 cluster status table 35 collision avoidance 30 control field format 25 # $\mathbf{D}$ data link control program (DLCP) 18 diagnostic function 1 73 diagnostic function 2 75 diagnostic function 3 76 diagnostic function 4 77 diagnostic function 5 78 diagnostic function 6 79 diagnostic function 7 80 display cluster status 55 DLCP BIOS commands 42 dump statistics 71 #### $\mathbf{E}$ error detection and recovery 34 # F frame format 24 frame reception 33 frame transmission 22 #### I I/O addresses 83 I/O register definitions 12 Intel 8031 memory map 10 Intel 8031 port signals 5 Intel 8255 port signals 91 interrupt interface 90 interrupts 16 # L link control block (LCB) 21 #### $\mathbf{M}$ memory interface 90 # P polynomial generator checker 10 programming considerations 18 #### R read IPL switch 69 read station address 66 #### Index-4 receive frame 51 receive virtual frame 49 remote IPL 37 #### S set multicast address 67 special transmit mode command bits 81 start DLCP 70 status 60 status register bit definitions 13 stop DLCP 65 switch blocks bit assignments 84 #### T transmit broadcast frame 61 transmit frame 53 transmit virtual frame 63 # IBM Game Control Adapter # **Contents** | Description 1 | l | |----------------------------|---| | Programming Considerations | 3 | | Address Decode | 3 | | Data Bus Buffer/Driver | 3 | | Trigger Buttons 3 | 3 | | Joystick Positions 3 | 3 | | I/O Channel Description | 1 | | Interface | | | Specifications | 7 | | Logic Diagram | ) | # **Description** The IBM Game Control Adapter allows up to four paddles or two joysticks to be attached to the system. This adapter fits into one of the system board's or expansion board's expansion slots. The game control interface cable attaches to the rear of the adapter. In addition, four inputs for switches are provided. Paddle and joystick positions are determined by changing resistive values sent to the adapter. The adapter, when used with system software, converts the present resistive value to a relative paddle or joystick position. On receipt of an output signal, four timing circuits are started. By determining the time required for the circuit to timeout (a function of the resistance), the paddle position can be determined. This adapter could be used as a general purpose I/O card with four analog (resistive) inputs plus four digital input points. **Game Control Adapter Block Diagram** # **Programming Considerations** #### Address Decode The select on the Game Control Adapter is generated by two 74LS138s as an address decoder. AEN must be inactive while the address is hex 201 in order to generate the select. The select allows a write to fire the one-shots, or a read to give the values of the trigger buttons and one-shot outputs. #### Data Bus Buffer/Driver The data bus is buffered by a 74LS244 buffer/driver. For an In from address hex 201, the Game Control Adapter will drive the data bus; at all other times, the buffer is left in the high impedance state. #### Trigger Buttons The trigger button inputs are read by an In from address hex 201. A trigger button is on each joystick or paddle. These values are seen on data bits 7 through 4. These buttons default to an open state and are read as 1. When a button is pressed, it is read as 0. Software should be aware that these buttons are not debounced in hardware. # **Joystick Positions** The joystick position is indicated by a potentiometer for each coordinate. Each potentiometer has a range of 0 to 100 kilohms that varies the time constant for each of the four one-shots. As this time constant is set at different values, the output of the one-shot will be of varying durations. All four one-shots are fired at once by an Out to address hex 201. All four one-shot outputs will go true after the fire pulse and will remain high for varying times depending on where each potentiometer is set. These four one-shot outputs are read by an In from address hex 201 and are seen on data bits 3 through 0. # I/O Channel Description **A9–A0:** Address lines 9 through 0 are used to address the Game Control Adapter. **D7–D0:** Data lines 7 through 0 are the data bus. **IOR, IOW:** I/O Read and I/O Write are used when reading from or writing to an adapter (In, Out). **AEN:** When active, the adapter must be inactive and the data bus driver inactive. +5 Vdc: Power for the Game Control Adapter. **GND:** Common ground. The following I/O channel lines are not used: MEMR, MEMW ALE, T/C DACK0-DACK3 CLK, OSC IRQ7–IRQ2 -5 Vdc DRQ3-DRQ1 +12 Vdc I/O CH RDY -12 Vdc I/O CH CK RESET DRV A19-A10 #### Interface The Game Control Adapter has eight input lines; four digital inputs and four resistive inputs. The inputs are read with one In from address hex 201 The four digital inputs each have a 1-kilohm pullup resistor to +5 Vdc. With no drives on these inputs, a 1 is read. For a 0 reading, the inputs must be pulled to ground. The four resistive pullups, measured to +5 Vdc, will be converted to a digital pulse with a duration proportional to the resistive load, according to the following equation: Time = $$24.2 \mu s + 0.011$$ (r) $\mu s$ The user must first begin the conversion by an Out to address hex 201. An In from address hex 201 will force the digital pulse to go high and remain high for the duration according to the resistance value. All four bits (bit 3-bit 0) function in the same manner: their digital pulse will all go high simultaneously and will reset independently according to the input resistance value. | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | | |--|-------|-------|-------|-------|-------|-------|-------|-------|--| | | | | | | | | | | | | | | | | | | 5 | | | | **Digital Inputs** Resistive Inputs The typical input to the Game Control Adapter is a set of iovsticks or game paddles. The joysticks will typically be a set of two (A and B). These will have one or two buttons each with two variable resistances each, with a range of 0 to 100 kilohms. One variable resistance will indicate the X coordinate and the other variable resistance will indicate the Y coordinate. The joystick should be attached to give the following input data: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | |--------|--------|--------|--------|------------|------------|------------|------------| | B-#2 | B-#1 | A-#2 | A-#1 | B-Y | B-X | A-Y | A-X | | Button | Button | Button | Button | Coordinate | Coordinate | Coordinate | Coordinate | The game paddles will consist of two (A and B) or four (A, B, C, and D) paddles. These will have one button each and one variable resistance each, with a range of 0 to 100 kilohms. The game paddles should be attached to give the following input data: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit O | |--------|--------|--------|--------|------------|------------|------------|------------| | D | С | В | Α | D | С | В | Α | | Button | Button | Button | Button | Coordinate | Coordinate | Coordinate | Coordinate | The following "Joystick Schematic Diagram" may be used for attaching game controllers. 15-Pin Male D-Shell Connector Note: Potentiometer for X- and Y-Coordinates has a range of 0 to 100 k-ohms. Button is normally open; closed when pressed. **Joystick Schematic Diagram** #### 6 Game Control Adapter # **Specifications** At Standard TTL Levels **Connector Specifications** Game Control Adapter (Sheet 1 of 1) # **Notes:** # Technical Reference Options and Adapters Volume 2 6322509