



# RTE Operating System Driver Writing Manual



### PRINTING HISTORY

The Printing History below identifies the Edition of this Manual and any Updates that are included. Periodically, Update packages are distributed which contain replacement pages to be merged into the manual, including an updated copy of this Printing History page. Also, the update may contain write-in instructions.

Each reprinting of this manual will incorporate all past Updates, however, no new information will be added. Thus, the reprinted copy will be identical in content to prior printings of the same edition with its user-inserted update information. New editions of this manual will contain new information, as well as all Updates.

To determine what manual edition and update is compatible with your current software revision code, refer to the appropriate Software Numbering Catalog, Software Product Catalog, or Diagnostic Configurator Manual.

| Fifth EditionF | 'eb | 1980 |                       |
|----------------|-----|------|-----------------------|
| Update 1       | Jul | 1981 | Manual enhancement    |
| Reprint        | Jul | 1981 | Update 1 incorporated |

#### NOTICE

The information contained in this document is subject to change without notice.

HEWLETT-PACKARD MAKES NO WARRANTY OF ANY KIND WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANT-ABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Hewlett-Packard shall not be liable for errors contained herein or for incidental or consequential damages in connection with the furnishing, performance or use of this material.

Hewlett-Packard assumes no responsibility for the use or reliability of its software on equipment that is not furnished by Hewlett-Packard.

This document contains proprietary information which is protected by copyright. All rights are reserved. No part of this document may be photocopied, reproduced or translated to another program language without the prior written consent of Hewlett-Packard Company.

## HP Computer Museum www.hpmuseum.net

For research and education purposes only.

#### **DOCUMENTATION MAP**



(Refer to the Documentation Map in the appropriate operating system manual for a complete list of related manuals.)

## **CONTENTS**

| Section I                              | Page  | Returning DCPC Channels to RTE 3-17                   |
|----------------------------------------|-------|-------------------------------------------------------|
| INTRODUCTION                           |       | Handling the DCPC Interrupt                           |
| Purpose                                | 1-1   | Intermixed DCPC and Non-DCPC Operations 3-19          |
| Scope                                  | 1-1   | Driver Automatic "Up"3-19                             |
| Supporting Documentation               | 1-1   | Power Fail Processing3-19                             |
|                                        |       | Power Down Sequence                                   |
| Section II                             | Page  | Power Up Sequence 3-20                                |
| RTE INPUT/OUTPUT STRUCTURE             |       | Restart I/O Sequence 3-21                             |
| Introduction                           | 2-1   | Program Scheduling by Drivers 3-22                    |
| Software I/O Structure                 |       | Determination of Operating System                     |
| Input/Output Device Drivers            |       | Environment                                           |
| System I/O Processor                   |       | Subroutines for Special Mapping Functions             |
| Base Page Communications Area          |       | (DMS Systems Only)                                    |
| Equipment Table                        |       | Mapping in RTE-III and RTE-M/III                      |
| Logical Unit Numbers                   |       | Mapping in RTE-IV                                     |
| Device Reference Table                 |       | Sample Standard RTE Driver                            |
| Computer Interrupt Mechanism           |       | Dample Standard 1012 Briver                           |
| Interrupt Table                        |       |                                                       |
| Driver Mapping Table (RTE-IV only)     |       | Section IV Page                                       |
| General Operation of RTE I/O           |       | WRITING PRIVILEGED RTE DRIVERS                        |
| I/O Initiation                         |       | Introduction                                          |
| I/O Continuation                       |       | General Privileged Driver Structure and Operation 4-3 |
| I/O Completion                         |       | Initiation Section                                    |
| 20 Completion                          | 2-17  | Privileged Section 4-6                                |
| Section III                            | Page  | Completion Section 4-9                                |
| WRITING STANDARD RTE DRIVERS           | 1 age | Privileged Driver Design Considerations               |
| Introduction                           | 3-1   | Communication With User Programs                      |
| General Driver Structure and Operation |       | (DMS Systems Only)                                    |
| Driver Naming Requirements             |       | Discussion of Sample DMS Privileged Driver 4-10       |
| Initiation Section                     |       | Initiation Section                                    |
| Functions of the Initiation Section    |       |                                                       |
|                                        |       | Privileged Section                                    |
| Continuation/Completion Section        |       | Completion Section                                    |
| Device Clear on Program Abort          |       | Time-Out Values for Privileged Drivers 4-12           |
| I/O Controller Time-Out                |       | Subroutines for Special Mapping Functions             |
| Driver Processing of Time-Out          |       | (DMS Systems Only)                                    |
| System Processing of Time-Out          |       | Mapping in RTE-III and RTE-M/III 4-13                 |
| DCPC Processing                        |       | Mapping in RTE-IV 4-15                                |
| RTE Control of DCPC Assignment         |       | Sample DMS Privileged Driver 4-17                     |
| DCPC Assignment by RTE                 | 3-13  | Sample Non-DMS Privileged Driver 4-18                 |
|                                        |       |                                                       |

## **ILLUSTRATIONS**

| Title                                 | Page          | Title                                      | Page |
|---------------------------------------|---------------|--------------------------------------------|------|
| Equipment Table Entry Format          | 2-5           | I/O Driver Initiation Section              | 3-4  |
| Expansion of CONWD (EQT Entry Word 6) | 2-6           | I/O Driver Continuation/Completion Section | 3-7  |
| Device Reference Table Entry Format   | 2-9           | DCPC Channel Assignment Words              | 3-13 |
| Device Reference Table                | 2-9           | Determining DCPC Assignment                | 3-16 |
| Interrupt Table                       | 2-12          | Standard RTE Driver Example                | 3-30 |
| Driver Mapping Table                  | $\dots 2$ -14 | DMS Privileged RTE Driver Example          | 4-18 |
| Unbuffered I/O Read Request           | 2-16          | Non-DMS Privileged RTE Driver Example      | 4-25 |

## **TABLES**

| Title                                         | Page     | Title              | Page       |
|-----------------------------------------------|----------|--------------------|------------|
| Base Page Communications Area — I/O Operation | ns . 2-3 | \$OPSY Word Format | <br>. 3-24 |

V

## INTRODUCTION

SECTION

ı

#### 1-1. PURPOSE

The RTE Operating System Driver Writing Manual is a reference for those users who wish to develop their own device drivers. A device driver provides the software interface between a peripheral device and the RTE operating system. Many drivers for HP peripherals have already been written and are available from HP. Users who wish to interface peripherals that are not supported by HP will require specialized drivers. The information in this manual will aid the user in the development of such routines.

Note that it is not the purpose of the manual to describe the various HP-supplied drivers in any detail. Each of these is described in a separate manual specific to the driver.

#### 1-2. SCOPE

The manual first provides the reader with a general description of the input/output (I/O) characteristics of the RTE family of operating systems. The techniques and requirements for developing device drivers are then presented in subsequent sections.

Since all of the RTE operating systems have the same general I/O structure, the manual can be used to develop general purpose drivers for use in any of these RTE systems. There are some areas where differences between operating systems may affect driver structure and operation; these areas are clearly pointed out in the text with notations such as "RTE-IV only" or "RTE-III only." Phrases such as "RTE-III only" should be interpreted as referring to both RTE-III (disc-based system) and RTE-M/III (memory-based equivalent of RTE-III).

#### 1-3. SUPPORTING DOCUMENTATION

To use this manual effectively, the reader should be thoroughly familiar with HP Assembly Language and with the Programming and Operating Manual for the RTE system in which the driver is to be used. Refer to the Documentation Map at the front of this manual for information on these and other available manuals. For specific information on an HP supplied driver, refer to the appropriate driver manual.

## RTE INPUT/OUTPUT STRUCTURE

SECTION

#### 2-1. INTRODUCTION

In RTE, centralized control and logical referencing of input and output (I/O) operations effect simple device-independent programming. By means of several user-defined I/O tables, I/O drivers, and program EXEC calls, the programmer is relieved of most I/O problems. To understand the software I/O characteristics of RTE, the user should be familiar with two hardware related terms used in this manual:

I/O Controller A combination of I/O card, cable, and (for some devices) controller box used

to control one or more I/O devices on a computer I/O select code.

I/O Device A physical unit (or portion of a unit) identified in the RTE operating system

by means of an Equipment Table entry and a subchannel assignment.

Each I/O device is interfaced to the computer through an I/O controller. This controller is associated with one or more of the computer I/O select codes. Interrupts from controllers on specific select codes are directed to specific memory locations in the computer for system processing.

It is also important to note the difference between a synchronous device and a non-synchronous device. An interrupt from a synchronous device controller must be processed within a specified time period, or the data will be lost. Examples of synchronous devices are moving-head disc drives and nine-track magnetic tape drives. Non-synchronous devices have no such requirement, and interrupts from these device controllers can be serviced whenever the computer is able to do so. Examples of non-synchronous devices include paper tape punches and readers.

#### 2-2. SOFTWARE I/O STRUCTURE

The RTE I/O structure is made up of two general types of software (the system I/O processor and the various device drivers) and a number of I/O tables and a communications area (the Equipment Table, the Device Reference Table, the Interrupt Table, the Driver Mapping Table (RTE-IV only), and the Base Page Communications Area). These tables and areas are used for communication between the system and the drivers, and for control of the many I/O operations that can be in progress simultaneously. Each component of the I/O structure is discussed individually in this subsection. A summary of the overall I/O process is given in the next subsection.

#### INPUT/OUTPUT DEVICE DRIVERS

Input/output device drivers provide the software interface between peripheral I/O devices and the operating system. Drivers are responsible for the initiation, continuation, and completion of all data transfers between an I/O device and the computer. Drivers communicate with the system directly via parameter passing, and indirectly through the various tables and communications areas (particularly the Equipment Table and the Base Page Communications Area) that are discussed later in this subsection.

There are two types of drivers; standard and privileged. Standard drivers are simpler and can be used for most asynchronous devices and some high speed and synchronous devices (if DCPC transfers are used); these drivers are discussed in Section III. Privileged drivers are more complex and are generally used for high speed and synchronous devices that require driver interaction on each data word transferred (i.e., DCPC transfers cannot be used); these drivers are discussed in Section IV.

#### SYSTEM I/O PROCESSOR

The system I/O processor (RTIOC) provides the software interface between user programs that perform I/O and the drivers that actually handle the I/O operations. RTIOC checks user I/O calls for validity, suspends programs while their I/O is in progress (if necessary), calls drivers to initiate the I/O data transfers, directs controller interrupts to the appropriate drivers, and restarts programs suspended for I/O. The mechanism for communication between RTIOC and user programs is the EXEC call and its associated parameters. Communication between RTIOC and drivers is handled directly via parameters and indirectly through the various I/O tables discussed in this section.

Two general areas within RTIOC are discussed in this manual; IOC and CIC. The Input/Output Control module (IOC) is entered when a user program makes an I/O request. IOC is responsible for initiating the I/O transfer by calling the appropriate driver. The Central Interrupt Control module (CIC) is entered when a device controller interrupt is detected. CIC is responsible for calling the correct driver to handle the interrupt.

#### BASE PAGE COMMUNICATIONS AREA

A block of storage in base page contains the system's communications area and is used by RTE to define request parameters, I/O tables, scheduling lists, operating parameters, memory bounds, etc. The RTE Assembler allows absolute references to addresses less than octal 2000 so that user programs can read information from the base page. Programs cannot alter the base page, however, because of the memory protect feature of RTE. Table 2-1 illustrates the portion of the Base Page Communications Area that pertains to I/O operations. The meaning and use of the various words illustrated in the table will become clear in subsequent sections of this manual. (For a complete description of the Base Page Communications Area, refer to the appropriate RTE System Programming and Operating Manual.)

Table 2-1. Base Page Communications Area — I/O Operations

| OCTAL<br>LOCATION                                                                      | CONTENTS                                                                               | DESCRIPTION                                                                               |
|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| •                                                                                      |                                                                                        |                                                                                           |
| 01650                                                                                  | EQTA                                                                                   | Address of Equipment Table (EQT)                                                          |
| 01651                                                                                  | EQT#                                                                                   | Number of EQT entries                                                                     |
| 01652                                                                                  | DRT                                                                                    | Address of Device Reference Word 1 Table                                                  |
| 01653                                                                                  | LUMAX                                                                                  | Number of logical units (in Device Reference Table)                                       |
| 01654                                                                                  | INTBA                                                                                  | Address of Interrupt Table                                                                |
| 01655                                                                                  | INTLG                                                                                  | Number of Interrupt Table entries                                                         |
| 01656                                                                                  | TAT                                                                                    | Address of Track Assignment Table (disc-based systems only)                               |
| 01657                                                                                  | KEYWD                                                                                  | Address of keyword block                                                                  |
| 01660<br>01661<br>01662<br>01663<br>01664<br>01665<br>01666<br>01667<br>01670<br>01671 | EQT1<br>EQT2<br>EQT3<br>EQT4<br>EQT5<br>EQT6<br>EQT7<br>EQT8<br>EQT9<br>EQT10<br>EQT11 | Addresses of first 11 words of current EQT entry (see location of 01771 for last 4 words) |
| 01673                                                                                  | CHAN                                                                                   | Current DCPC Select Code (6 or 7)                                                         |
|                                                                                        |                                                                                        |                                                                                           |
| 01717                                                                                  | XEQT                                                                                   | ID segment address of current program                                                     |
| :                                                                                      |                                                                                        |                                                                                           |
| 01737                                                                                  | DUMMY                                                                                  | I/O channel of privileged interrupt card (0 if none)                                      |
| :                                                                                      |                                                                                        |                                                                                           |
| 01770                                                                                  | MPTFL                                                                                  | Memory Protect On/Off (0/1) flag.                                                         |
| 01771<br>01772<br>01773<br>01774                                                       | EQT12<br>EQT13<br>EQT14<br>EQT15                                                       | Addresses of last 4 words of current EQT entry                                            |

#### **EQUIPMENT TABLE**

The Equipment Table (EQT) is used to maintain a list of all the I/O equipment in the system. This table consists of a number of EQT entries, with one EQT entry for each I/O controller defined in the system at generation time. The EQT entry contains all of the information required by the system and the associated driver to operate the equipment, including: the I/O select code in which the controller is interfaced to the computer, the driver type, and the various requirements and specifications of the controller or driver (e.g., DCPC, buffering, time-out, power fail, etc.). To distinguish between multiple I/O devices connected to a single controller, the system also inserts the subchannel number of the device being referenced into the EQT entry before calling the driver.

The format of each EQT entry is illustrated in Figure 2-1. Some information in the EQT entry is static; other parts are dynamic. Information marked <A> is fixed at generation time (or, for the I/O select code number in RTE-IV, at reconfiguration time) and never changes during on-line operation of the system. Words marked <B> are also fixed at generation time (or, for RTE-IV, at reconfiguration time) but can be changed on-line via operator commands. Information marked  $\ge$ C> is modified or set up for the driver prior to each I/O initialization; it informs the driver of the nature of the request. Words marked  $\ge$ D> are not used by the system and are therefore available to the driver for use as temporary storage for the duration of each I/O request.

EQT words 9 and 10 are available for use as temporary storage unless optional parameters were specified in the EXEC call. For the case of an EXEC call with the control word's Z bit clear, EQT words 9 and 10 contain the values of the optional parameters. If the Z bit was set, however, EQT word 9 contains the address of the optional buffer while word 10 contains the length of the buffer.

| ļ <u>-</u>                                                  |                                                                                                                                                                                                        |                                                                      | CONTENTS                      |                                      |               |
|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------|--------------------------------------|---------------|
|                                                             | 5 14 13 12 11                                                                                                                                                                                          | 10 9                                                                 | 8 7 6                         | 5 4 3                                | 2 1 1 1 0     |
| 1                                                           | I/O REQUEST LIST                                                                                                                                                                                       | POINTER <0                                                           | >                             |                                      |               |
| 2                                                           | R DRIVER "INITIATI                                                                                                                                                                                     | ON" SECTION                                                          | ADDRESS <a></a>               |                                      |               |
| 3                                                           | DRIVER "CONTINU                                                                                                                                                                                        | ATION/COMPL                                                          | ETION" SECTION                | ADDRESS <a< td=""><td>&gt;</td></a<> | >             |
| 4                                                           | (A> <b> <e> <e> <c<br>D B P S T</c<br></e></e></b>                                                                                                                                                     | SUBCHA                                                               | NNEL # <c></c>                | I/O SELECT CO                        | DDE # <a></a> |
| 5                                                           | AV <f> EQUIPMENT T</f>                                                                                                                                                                                 | PE CODE <a< td=""><th>&gt; STATUS</th><td><e></e></td><td></td></a<> | > STATUS                      | <e></e>                              |               |
| 6                                                           | CONWD (CURRENT I/O RE                                                                                                                                                                                  | QUEST WORD)                                                          | <b>&lt;</b> C>                |                                      |               |
| 7                                                           | REQUEST BUFFER ADDRI                                                                                                                                                                                   | SS <b>&lt;</b> C>                                                    |                               |                                      |               |
| 8                                                           | REQUEST BUFFER LENGT                                                                                                                                                                                   | H <b>&lt;</b> C>                                                     |                               |                                      |               |
| 9                                                           | TEMPORARY STORAGE <                                                                                                                                                                                    | D> OR OP                                                             | TIONAL PARAMET                | TER < C >                            |               |
| 10                                                          | TEMPORARY STORAGE <                                                                                                                                                                                    | D > OR OP                                                            | TIONAL PARAMET                | ER < C >                             |               |
| 11                                                          | TEMPORARY STORAGE F                                                                                                                                                                                    | OR DRIVER <                                                          | (D)                           | . <u>.</u>                           |               |
| 12                                                          | TEMPORARY STORAGE<br>FOR DRIVER <d></d>                                                                                                                                                                | OR EQTE                                                              | XTENSION SIZE,<br>Y ≺A>       |                                      |               |
| 13                                                          | TEMPORARY STORAGE OR EQT EXTENSION STARTING FOR DRIVER <d> ADDRESS, IF ANY <a></a></d>                                                                                                                 |                                                                      |                               |                                      |               |
| 14                                                          | 14 DEVICE TIME-OUT RESET VALUE <b></b>                                                                                                                                                                 |                                                                      |                               |                                      |               |
| 15                                                          | 15 DEVICE TIME-OUT CLOCK <c></c>                                                                                                                                                                       |                                                                      |                               |                                      |               |
| <a> = F</a>                                                 | WHERE THE LETTERS IN BRACKETS (<>) INDICATE THE NATURE OF EACH DATA ITEM, AS FOLLOWS: <a> = FIXED AT GENERATION TIME (OR, FOR I/O SELECT CODE # IN RTE-IV, AT RECONFIGURATION TIME); NEVER CHANGES</a> |                                                                      |                               |                                      |               |
| <b> = FIXED AT GENERATION TIME; CAN BE CHANGED ON-LINE.</b> |                                                                                                                                                                                                        |                                                                      |                               |                                      |               |
| <c> = SET UP OR MODIFIED AT EACH I/O INITIALIZATION.</c>    |                                                                                                                                                                                                        |                                                                      |                               |                                      |               |
| <d> = AVAILABLE FOR USE AS TEMPORARY STORAGE BY DRIVER.</d> |                                                                                                                                                                                                        |                                                                      |                               |                                      |               |
| 1                                                           | <e> = CAN BE SET BY DRIVER.</e>                                                                                                                                                                        |                                                                      |                               |                                      |               |
| 1                                                           | AINTAINED BY SYSTEM.                                                                                                                                                                                   |                                                                      |                               |                                      |               |
| AND WHERE:                                                  | D /2-                                                                                                                                                                                                  | TED VED 505 -                                                        | VOTEM ::05                    |                                      |               |
| I/O REQUE                                                   | ST LIST POINTER = POI<br>ENT                                                                                                                                                                           | RY. FIRST ENT                                                        |                               | RRENT REQUEST                        |               |
|                                                             | A = 1 IF                                                                                                                                                                                               | DCPC WAS ALI                                                         | LOCATED DYNAM NUATION (RTE-IV | ICALLY AT REQU                       | JEST          |
|                                                             |                                                                                                                                                                                                        | DCPC REQUIR                                                          |                               | D GIVE I /                           |               |
|                                                             |                                                                                                                                                                                                        |                                                                      | <br>OUTPUT BUFFERIN           | NG USED                              |               |
|                                                             | P = 1 iF                                                                                                                                                                                               | DRIVER IS TO                                                         | PROCESS POWER                 | FAIL                                 |               |
| ·                                                           | S = 1 IF                                                                                                                                                                                               | DRIVER IS TO                                                         | PROCESS TIME-O                | JT                                   |               |
|                                                             |                                                                                                                                                                                                        | DEVICE TIMES<br>H I/O REQUES                                         | O OUT (SYSTEM SE              | TS TO ZERO BEF                       | ORE           |
| SUBCHANN                                                    | EL# = LAS                                                                                                                                                                                              | T SUBCHANNE                                                          | L ADDRESSED                   |                                      |               |

Figure 2-1. Equipment Table Entry Format (Sheet 1 of 2)

I/O SELECT CODE # I/O SELECT CODE FOR THE I/O CONTROLLER (LOWER NUMBER IF A MULTI-BOARD INTERFACE) ΑV = I/O CONTROLLER AVAILABILITY INDICATOR: 0 = AVAILABLE FOR USE 1 DISABLED (DOWN) **BUSY (CURRENTLY IN OPERATION)** 2 WAITING FOR AN AVAILABLE DCPC CHANNEL EQUIPMENT TYPE CODE IN GENERAL, INDICATES TYPE OF DEVICE ON THIS CON-TROLLER. WHEN THIS OCTAL NUMBER IS LINKED WITH "DVY", IT IDENTIFIES THE DEVICE'S SOFTWARE DRIVER ROUTINE. SOME STANDARD EQUIPMENT TYPE CODES ARE: 00 TO 07 = PAPER TAPE DEVICES OR CONSOLES 00 TELEPRINTER (OR KEYBOARD CONTROL DEVICE) = PHOTOREADER 01 = PAPER TAPE PUNCH 02 = 264X SERIES TERMINALS 05 = MULTI-POINT DEVICES 07 = UNIT RECORD DEVICES 10 TO 17 = PLOTTER 10 11 CARD READER = LINE PRINTER 12 MARK SENSE CARD READER 15 20 TO 37 = MAGNETIC TAPE/MASS STORAGE DEVICES 23 = 9 TRACK MAGNETIC TAPE = 7900 MOVING HEAD DISC 31 = 7905/06/20 MOVING HEAD DISC 32 = FLEXIBLE DISC DRIVES 33 36 = WRITABLE CONTROL STORE = HPIB 37 **= INSTRUMENTS** 40 TO 77 **STATUS** ACTUAL PHYSICAL STATUS OR SIMULATED STATUS AT THE END OF EACH OPERATION. CONWD COMBINATION OF USER CONTROL WORD AND USER REQUEST CODE WORD IN THE I/O EXEC CALL (SEE BELOW).

Figure 2-1. Equipment Table Entry Format (Sheet 2 of 2)



Figure 2-2. Expansion of CONWD Word (EQT Entry Word 6)

If the number of words marked <D> does not provide sufficient temporary storage for the driver, additional space can be allocated at generation time by specifying that an EQT entry extension is needed for a particular EQT entry. This space can only be used to extend the referenced EQT entry and therefore should only be allocated for drivers that need the additional space. When an EQT entry extension is specified, EQT entry words 12 and 13 are used to identify the location and length of the extension (since the extension does not immediately follow the EQT entry) and therefore should not be modified by the driver. Otherwise, these words are available as temporary storage.

For programming convenience, the addresses of each word in the current EQT entry (except for words in the extension, if an extension exists) are placed in the Base Page Communications Area by the system before calling the driver to initiate or continue an I/O operation. A driver should use these addresses instead of computing them from the EQT entry number and the start of the Equipment Table. In this way, the driver can remain independent of the actual organization of the Equipment Table in memory.

All Equipment Table entries are located sequentially in memory beginning with EQT entry number 1. The address of the first entry and the total number of entries in the table can be found in the Base Page Communications Area.

#### LOGICAL UNIT NUMBERS

Logical unit numbers (LU's) provide the RTE user with the capability of logically addressing the physical devices defined by the Equipment Table. LU numbers are maintained by the Device Reference Table (see below), and their definition can be changed on-line by the LU operator request. This scheme allows the programmer to reference changeable logical units instead of fixed physical units.

The function of Logical Units 0 through 6 are predefined in the RTE system as follows:

- 0 "bit bucket" (null device, no entry in Device Reference Table)
- 1 system console
- 2 reserved for system (system disc subchannel in disc-based systems)
- 3 reserved for system (auxiliary disc subchannel in disc-based systems)
- 4 standard output device
- 5 standard input device
- 6 standard list device

Logical Unit 8 is recommended for the magnetic tape device, if one is present in the system. Peripheral discs must be assigned logical units greater than 6. Additional logical units may be assigned for any functions desired.

#### DEVICE REFERENCE TABLE

The Device Reference Table (DRT) is part of the mechanism by which logical unit numbers for I/O are implemented. RTE users request I/O by specifying a logical unit number. The DRT is used to translate this logical unit number into a physical device, as specified by an EQT entry number and subchannel. The DRT is also used to queue requests for I/O on a device when it is

unavailable (down). (The DRT is not used to queue requests when the device is up. The request list for available (i.e., up) devices originates from word 1 of the EQT entry as illustrated in Figure 2-1.)

Each DRT entry is two words long. There is one entry for each logical unit number defined at generation time, beginning with logical unit 1. The format of each entry is illustrated in Figure 2-3. The first word of the entry contains several items, including: 1) the EQT entry number of the controller assigned to the logical unit, and 2) the subchannel number of the specific device on that controller to be referenced. The second word of each entry contains the status of the logical unit: up (available) or down (unavailable). If the device is down, word two also contains a pointer to the list of requests waiting to access the LU.



Figure 2-3. Device Reference Table Entry Format



Figure 2-4. Device Reference Table

The DRT table is actually split into two separate parts. The first part contains word 1 of each DRT entry, and the second part contains word 2 of each DRT entry. This format is illustrated in Figure 2-4. The starting address and length of part one of the table can be found in the Base Page Communications Area. Part two is located in memory immediately following part one and has the same length as part one.

#### COMPUTER INTERRUPT MECHANISM

When a device controller interrupts RTE, the computer transfers control to one of a group of memory locations on base page known as the interrupt trap cells. The I/O select code of the interrupting controller determines the location of the transfer. For example, interrupts from select code 12 cause a transfer to memory location 12. Interrupts from select code 13 cause a transfer to memory location 13, and so on. Select code numbers range from 4 to 77 (octal). Thus, the group of memory locations from 4 to 77 (octal) comprises the entire set of interrupt trap cells.

Transferring control to an interrupt trap cell causes the instruction located there to be executed. For all devices operating under the control of CIC, this instruction is a JSB LINK,I, where LINK is a base page link containing the address of the entry point to CIC. This instruction is initially set up by the RTE generator, and is reset into the trap cell each time the system is rebooted. The fact that the JSB instruction references an indirect address causes the computer to hold off any further interrupts for one instruction after the JSB. This gives CIC a chance to issue a CLF 0 instruction (which disables the interrupt system entirely) to prevent further interrupts from occurring while the current one is being processed.

Since CIC is entered at the same location for all device controller interrupts under its control, a method is needed by which the select code of the interrupting device controller can be determined. CIC obtains the interrupting select code number by accessing the contents of the computer's Central Interrupt Register via an LIA 4 instruction. CIC can then use this information to index into the Interrupt Table (see next subsection) to determine how to process the interrupt.

The interrupt trap cells are not limited to containing a JSB LINK,I instruction (where LINK contains the address of CIC). Other instructions can be placed in a trap cell by the generator or by a system routine. However, the trap cell should not contain any instruction other than a HALT instruction or a JSB indirect to an interrupt processing routine (such as CIC or a user-written routine) that saves the state of the machine on entry and restores it to its original state on exit. This includes saving and restoring the registers, state of the memory protect fence, etc.

Specifically, I/O instructions and NOP instructions must not be put into trap cells because they do not provide any way to restore the system to its original state. Microcode macro's (i.e., jumps to microcoded routines) may be used if a microcoded driver is used to process the interrupts.

Note that if a JSB instruction is placed in the interrupt trap cell, it must reference an indirect address. The indirect address keeps the interrupt system suppressed for one instruction after the JSB, as explained above. This allows the interrupt processing routine to issue a CLF 0 instruction to prevent further interrupts from occurring while the state of the machine is being saved. (Note that the generator automatically provides a base page link for all JSB instructions it places in the interrupt trap cells. A JSB indirect instruction is created whenever an "ENT," "PRG," or "EQT" entry is specified during generation.)

Systems without the power fail/automatic restart feature have a HALT 4 instruction inserted by the generator into the power fail interrupt trap cell (memory location 4). As a result, the computer will halt when a power fail interrupt occurs. An example of a JSB to a user-written interrupt processing routine is discussed later in the "Writing Privileged Drivers" section of this manual.

#### INTERRUPT TABLE

The Interrupt Table directs CIC's action when an interrupt occurs on any I/O select code that contains a JSB LINK,I instruction (where LINK contains the address of CIC). CIC can call a driver, schedule a specified program, or handle the interrupt itself.

There is one Interrupt Table entry for each I/O select code from 6 up to the highest select code defined in the system at generation. (Systems with I/O reconfiguration ability at boot-up (e.g., RTE-IV) always include Interrupt Table entries for all select codes, even if some select codes were not defined in the initial generation.) Each Interrupt Table entry is one word long and can have three possible values: zero, positive, or negative.

1. If the entry is zero, the select code is undefined in the Interrupt Table. Any interrupts on this select code are illegal and cause the following message to be printed:

#### ILL INT xx

where xx is the octal I/O select code number. RTE then clears the interrupt flag on the select code and returns to the suspended process at the point of interruption. (Note that an Interrupt Table entry can also be zero if interrupts on the associated select code are handled by a special routine instead of by CIC and a driver. Refer to the "Writing Privileged Drivers" section later in this manual for more information on this subject.)

- 2. If the contents of the entry are positive, the entry contains the address of the EQT entry associated with the controller on the select code.
- 3. If the contents are negative, the entry contains the negative of the address of the ID segment of the program to be scheduled whenever an interrupt occurs on the select code. If such a program is not dormant when an interrupt occurs on the select code, the following message is output to the system console:

#### SC03 INT xxxxx

where xxxxx is the program name. RTE then clears the interrupt flag on the select code and control is returned to the suspended process at the point of interruption.

All Interrupt Table entries are located sequentially in memory beginning with the entries for I/O select codes 6 and 7 (DCPC). This format is illustrated in Figure 2-5. There are no entries for I/O select codes 4 and 5 because the system is able to process interrupts from these select codes (power fail interrupts, memory protect violations, etc.) without the need for an Interrupt Table entry. The address of the first word of the table and the number of entries in the table can be found in the Base Page Communications Area.

#### NOTE

The reader should not confuse the interrupt trap cell area of the computer, which is located on base page, with the Interrupt Table of RTE, which is located elsewhere. The interrupt trap cells are those memory locations (4 to 77 octal) to which control is transferred when an interrupt occurs. The Interrupt Table, on the other hand, is merely a convenient way for RTE to record what action CIC should take when an interrupt occurs on a select code under CIC's control.



Figure 2-5. Interrupt Table

#### DRIVER MAPPING TABLE (RTE-IV ONLY)

In the RTE-IV Operating System, drivers can be placed in one of two areas: in the System Driver Area (SDA) or in one of the driver partitions. Most standard drivers are placed in driver partitions. The SDA is primarily used for privileged drivers, drivers that do their own mapping, and very large drivers. (For more information on driver placement, refer to the appropriate operating system reference and/or generation manual.)

The Driver Mapping Table (DMT) is used to record where a driver resides in physical memory and other static and dynamic information about the driver and the location of the I/O request buffer.

There is one DMT entry associated with each EQT entry defined at generation time. Each entry is two words long, as illustrated in Figure 2-6. Word 1 is set up at generation time and its contents are never changed. It indicates whether the driver resides in the System Driver Area (SDA) or in a driver partition. If it is in the SDA, it also indicates whether or not the driver is doing its own memory mapping. (See the "Subroutines for Special Mapping Functions" subsection later in this manual.) If the driver is in a partition, word 1 also indicates the starting physical memory page number of the driver partition in which it is located.

Word 2 of the DMT entry is dynamic in nature and is set up at each I/O initialization of the associated EQT entry. This word indicates whether the I/O request buffer is located within a disc resident program, memory resident program, or system area. If a disc resident program is making the request and the I/O request buffer is located within the program (i.e., an unbuffered request), word 2 also indicates the physical memory page number of the disc resident program's base page. This information is used to save time on setting up the proper map when processing interrupts handled by the driver.





Figure 2-6. Driver Mapping Table

#### 2-3. GENERAL OPERATION OF RTE I/O

Input/Output transfers in RTE can be conveniently broken into three parts for discussion: initiation, continuation, and completion. A user program is involved only in the initiation and completion phases; the system I/O processor and the device drivers are involved in all three phases. The following is a simplified discussion of each phase. (As an aid to understanding this explanation, the general flow of events for an unbuffered I/O READ request is illustrated in Figure 2-7.)



Figure 2-7. Unbuffered I/O READ Request

#### I/O INITIATION

A user program makes an EXEC call to initiate I/O transfers. Parameters passed along with this call specify the logical unit, control information, buffer location, buffer length, and type of request (READ, WRITE, or CONTROL) to be made. The user request is channelled to the IOC (Input/Output Control) module of the system by the RTE request processor. The request is checked for legality and rejected if any errors are found. If there are no errors, the logical unit number supplied is used to index into the DRT (Device Reference Table) to determine which I/O controller (EQT entry number) and device (subchannel) are actually being referenced. The I/O request is then linked into the request list for the referenced controller.

If the device controller is available (i.e., no prior requests are pending), the parameters of the request are put into the associated EQT entry, the addresses of the EQT entry words are set into the Base Page Communications Area for convenience, the proper map (System or User) is enabled (performed in systems with Dynamic Mapping only), and the "initiation" section of the driver is called. This section initializes the device controller, starts the data transfer or control function, and returns to IOC.

IOC then returns to the system's dispatching module to begin execution of the highest priority scheduled program. If the operation was successfully initiated by the driver, the data transfer is now under way.

#### I/O CONTINUATION

When the device controller finishes transferring a data word, or block of words, it interrupts the computer. This causes a transfer to one of the interrupt locations in the computer's memory, and the instruction located there is executed. For most I/O devices, this instruction is a JSB LINK,I (where LINK contains the address of the entry point to CIC). Execution of this instruction causes control to be transferred to CIC, the Central Interrupt Control module of the system. CIC obtains the number of the interrupting select code from the computer's Central Interrupt Register and uses it to index into the Interrupt Table.

For those I/O processes operating under the control of CIC and a driver, the Interrupt Table tells CIC which EQT entry is associated with the interrupting select code. CIC looks at the EQT entry, determines which driver is responsible for handling the interrupt, enables the correct map (System or User) in systems with Dynamic Mapping, and calls the driver's "continuation/completion" section to process the interrupt. The driver either accepts the data from the device (read operation) or sends more data to the device (write operation) and restarts the device. Return is then made to CIC with a code indicating that more interrupts are expected. This process (interrupt, CIC, driver, CIC) is repeated once for each word or block of words transferred until the entire transfer is complete.

#### I/O COMPLETION

Eventually the driver will determine that the required amount of data has been transferred and that the I/O process is now complete. The driver then returns to CIC with a special code indicating that the I/O operation is complete and can be terminated; no more interrupts are expected.

CIC, in turn, transfers control back to IOC to terminate the I/O process. IOC causes the program that made the initial I/O request to be placed back into the scheduled list and checks to see if there are any other I/O requests pending for this controller. If at least one request is pending, the initiation section of the driver is again called to begin the next operation. IOC then returns control to the system's dispatching module to begin execution of the highest priority scheduled program.

## WRITING STANDARD RTE DRIVERS

SECTION

Ш

#### 3-1. INTRODUCTION

This section describes in detail the structure, operation, and design of standard RTE drivers. Standard drivers are fairly simple in structure and can generally be used to control most asynchronous devices. They can also be used to control synchronous and high-speed devices if these devices are driven under DCPC control. DCPC processing is also described in this section.

An alternate method for controlling synchronous and high-speed devices is to employ the more complex privileged driver. Section IV of this manual describes the differences in the design of privileged drivers versus standard drivers. Thus, if the user wishes to design a privileged driver, the material in this section should be read and understood before continuing with the privileged driver discussion in Section IV.

Note that the operation of RTE requires that synchronous and high-speed devices be driven either by a standard driver utilizing DCPC transfers, or by a privileged driver. This is necessary to ensure that interrupts from such devices are serviced within the required response time. The reader should keep this requirement in mind when deciding upon the type of driver to be written.

#### 3-2. GENERAL DRIVER STRUCTURE AND OPERATION

An I/O driver, operating under control of the Input/Output Control (IOC) and Central Interrupt Control (CIC) modules of RTE, is responsible for all data transfers between an I/O device controller and the computer. Each driver is written in two functional sections: an initiation section and a continuation/completion section. The initiation section is responsible for starting up the device and initiating the first data transfer. The continuation/completion section is responsible for processing each interrupt generated by the device under its control. This involves accepting data from the device (read operation), sending more data to the device (write operation), and then restarting the device to continue the transfer. Eventually, the continuation/completion section determines that a sufficient amount of data has been transferred and terminates the I/O operation.

A standard RTE driver operates with the interrupt system disabled (or effectively disabled, if the system contains a Privileged Interrupt card. Refer to the "Writing Privileged Drivers" section of this manual.) This means that once a driver is entered to process an interrupt, no other interrupts (except privileged interrupts) can be serviced until the driver completes its operation and returns to CIC. (CIC turns the interrupt system back on to allow other interrupts to occur.) Drivers should therefore be coded as efficiently as possible to minimize the amount of time that the interrupt system is disabled and the processing of other interrupts is delayed.

#### 3-3. DRIVER NAMING REQUIREMENTS

To facilitate the identification of driver programs and entry points, the following naming scheme has been devised. This scheme must be incorporated into the design of all RTE drivers so that the RTE system generator programs can identify the drivers and relocate them in the proper memory area of the operating system.

- a. Driver names must be five characters in length, beginning with the characters "**DV**" and ending with a two-digit octal number (known as the equipment type code of the device).
- b. The initiation and continuation/completion sections must have entry points whose names are four characters in length, beginning with the character "I" or "C" respectively, and ending with the same two-digit octal number used in the driver name.

Thus, if "nn" is the octal equipment type code, Ixnn and Cxnn are the entry point names of the initiation and continuation/completion sections respectively. **DVynn** is the driver name.

The user is allowed some flexibility in the choice of the "x" (in Ixnn and Cxnn) and "y" (in **DVynn**) characters referred to above. This flexibility allows several drivers with the same octal equipment type code to have unique names and entry points. The rules for the choice of "x" and "y" are:

```
If "y" is "R" then "x" = "."

If "y" is not "R" then "x" = "y"
```

Using the above rules, a driver named DVR66 has entry points I.66 and C.66. A driver named DVA66 has entry points IA66 and CA66.

The octal equipment type code (nn) can be any octal number between 00 and 77. A table of "standard" type codes is given in Figure 2-1. Care should be taken to choose the type code and/or "x" and "y" characters so that new driver names and entry points do not conflict with those of any standard HP drivers or other user written drivers present in the system.

#### 3-4. INITIATION SECTION

The IOC module of RTE calls the driver initiation section when an I/O transfer is initiated. (Note that the initiation section may also be entered when a DCPC channel is assigned by IOC in response to a dynamic DCPC request by the driver. Refer to the "DCPC Processing" subsection of this manual.) Prior to actually entering the driver initiation section, IOC sets up all the information needed by the driver to process the call in the associated EQT entry and in the Base Page Communications Area, as follows:

a. Locations EQT1 through EQT15 in the Base Page Communications Area are set to contain the addresses of each word of the EQT entry associated with the call. Base page word EQT1 is set to contain the address of EQT entry word 1, base page word EQT2 is set to contain the address of EQT entry word 2, and so on. If the driver uses DCPC (that is, if bit 15 of EQT entry word 4 is set), IOC also assigns a DCPC channel to the driver and stores the DCPC channel number in base page word CHAN.

- b. Words 6 through 10 of the EQT entry pointed to by the Base Page Communications Area are set to contain the request parameters from the user's EXEC call (request code, subfunction, buffer address, buffer length, and optional parameters, if present). Note that EQT entry word 6 (CONWD) contains the CONWD from the user's EXEC call, modified to contain the request code in bits 0 and 1 in place of the logical unit. The subchannel being referenced by the call is placed into bits 6 through 10 of EQT entry word 4.
- c. CIC also sets up and enables the correct map (System or User) needed by the driver to process the call. (This step is performed in systems with Dynamic Mapping only.)

After performing these tasks, IOC enters the driver directly via a jump subroutine to the initiation entry point Ixnn (JSB Ixnn). Upon entry, the A-register contains the I/O select code of the controller being referenced in the call. (This same information is present in bits 0 through 5 of EQT entry word 4.) Later, when the driver has completed (or rejected, if necessary) the initialization procedure, it must return to IOC via a jump indirect through the Ixnn entry point (JMP Ixnn,I).

Once entered, the driver is free to use EQT entry words 6 through 13 in any way, but words 1 through 4 and 14 must not be altered. If an EQT entry extension was specified at generation, the space in the extension is also available to the driver. In this case words 12 and 13 (which define the extension) must not be modified. The driver can also update the status field in word 5, if appropriate, but this must be done without altering the rest of word 5. Finally, EQT entry word 15 may be modified, if desired, to set a time-out value for the device. (Refer to the "I/O Controller Time-Out" subsection in this manual.)

#### FUNCTIONS OF THE INITIATION SECTION

As part of the general I/O structure of RTE, the initiation section of a standard driver performs the functions illustrated in Figure 3-1. A more detailed description of the initiation section functions is given below.

- a. Checks for power fail/automatic restart entry by examining bit 15 of EQT entry word 5, which is set to 1 only on this type of entry. If bit 15 is set, the appropriate power fail/automatic restart processing should be done. This check need only be made by drivers that are designed to process power fail interrupts (as described in the "Power Fail Processing subsection of this manual).
- b. Rejects the request by following the procedure described in step "g" if:
  - 1. A status check of the device or controller indicates that it is inoperable, or
  - 2. The request code or other parameters are illegal.



Figure 3-1. I/O Driver Initiation Section

- c. Configures all I/O instructions in the driver to reference the specific I/O select code (and DCPC channel, if used) of the device controller.
- d. Initializes DCPC, if used. (Refer to the "DCPC Processing" subsection of this manual.)
- e. Initializes software flags and activates the device controller. All variable information pertinent to the transmission must be saved in the EQT entry associated with the controller because the driver may be called for another controller before the first operation is complete.
- f. Optionally sets the device controller time-out clock (EQT entry word 15) to modify the time-out value inserted there by the system. (Refer to the "I/O Controller Time-Out" subsection of this manual.)
- g. Returns to IOC (via **JMP I***xnn*,**I**) with the A-register set to indicate initiation or rejection (and the cause of the rejection) as follows:

If A = 0 the operation was initiated successfully.

If A = 1,2,3 The operation was rejected, where:

1 = read or write illegal for device

2 = control request illegal or undefined,

3 = equipment malfunction or not ready

If A = 4 the operation was immediately completed. This means that the driver was able to completely satisfy the request without the need of a subsequent interrupt and that the program making the I/O call can be rescheduled immediately. The B-register should be set to the positive number of words or characters (depending upon which the user specified) transferred. This value is known as the transmission log.

If A = 5 a DCPC channel is required but none was assigned by IOC. This can only occur when the "DCPC channel required" bit is not set in the EQT entry, and the driver decides that it needs a DCPC channel to process this specific call. (Refer to the "DCPC Processing" subsection of this manual.)

If A=6 a DCPC channel was assigned by IOC but the driver did not use it and wants to give it up. After IOC deallocates the channel, processing continues as for a successful initiation return (A=0). (RTE-IVB only.)

If A = 7 - 99

the program making the I/O request is aborted (unless the no-abort bit was set in the call), and an I/O error message is printed on the system console. (Note that this return can be used for unbuffered user I/O requests only. This therefore excludes the use of return codes 6 through 99 on any Class, buffered or system I/O request.) The error message has the following format:

IOxx yyyyy NNNNN ABORTED

where: xx = the return code from the driver (decimal 06 to decimal 99).

yyyyy = the address of the aborted I/O request in program NNNNN, and

NNNNN =the name of the program that made the I/O request.

This type of return can be used by drivers to generate their own I/O error messages at the system console. Note that certain codes are reserved for system use, as follows:

| Return Code | Reserved for                         |
|-------------|--------------------------------------|
| 7 - 59      | HP system modules and system drivers |
| 60 - 99     | user written drivers                 |

#### 3-5. CONTINUATION/COMPLETION SECTION

The CIC module of RTE calls the continuation/completion section of a driver whenever an interrupt is recognized on an I/O controller associated with the driver. Before calling the driver to process the interrupt, CIC issues a clear flag instruction (CLF) to the interrupting select code, sets the addresses of the associated EQT entry into the Base Page Communications Area, and sets the interrupt source code (I/O select code of interrupting controller) into the A-register. (The interrupting I/O select code address is also available in EQT entry word 4.)

CIC also sets up and enables the correct map (System or User) needed by the driver to process the call. (This step is performed in systems with Dynamic Mapping only.) The driver is then entered with the correct map enabled by executing a jump subroutine to the continuation/completion section of the driver at entry point Cxnn (JSB Cxnn). This call has the following format:

| Location | Action                                          |
|----------|-------------------------------------------------|
|          | (Set A-register equal to interrupt source code) |
| P        | JSB Cxnn                                        |
| P+1      | Completion return from Cxnn                     |
| P+2      | Continuation return from Cxnn                   |
| P+3      | Get/give up DCPC continuation return from       |
|          | Cxnn (RTE-IVB only)                             |
| 3.6      |                                                 |

The return points from **Cxnn** to CIC indicate whether:

- 1. the transfer has been completed.
- 2. the transfer is continuing (i.e., further interrupts are expected from the device controller).
- 3. the driver is requesting the allocation or deallocation of a DCPC channel.

The continuation/completion section of the driver is flowcharted in Figure 3-2 and performs the following functions. Note that steps "a" through "e" are always executed whenever the driver is entered at Cxnn. Then, depending on whether the I/O operation is now complete or is still continuing, the driver executes either step "f" (completion return) or step "g" (continuation return) respectively.



Figure 3-2. I/O Driver Continuation/Completion Section

- a. Checks whether bits 14 0 of EQT entry word 1 (the controller I/O request list pointer) equal zero. If so, a spurious interrupt has occurred (i.e., no I/O operation was in progress on the controller). The driver can handle the spurious interrupt in one of two ways:
  - 1. Ignore the interrupt by setting EQT entry word 15 (the time-out clock) to zero to prevent time-out and making a continuation return as described in step "g" below.
  - 2. Ignore the interrupt and have RTE display a message by making a completion return as described in step "f" below. No special A-register return value is needed. Upon return from the driver, RTE looks at the I/O request list pointer and, if the pointer is zero, displays the following message on the system console (where the "sc" indicates the interrupting select code):

#### ILL INT sc

- b. If the interrupt is valid (i.e., bits 14 0 of word 1 are non-zero), the driver configures all I/O instructions in the continuation/completion section to reference the interrupting select code.
- c. Checks to see if a time-out has occurred on the device by checking bit 11 of EQT entry word 4. If this bit is set, the device has timed-out, and any required time-out processing should be done. Note that this check need only be made by drivers that are designed to process time-out interrupts (as described in the "I/O Controller Device Time-Out" subsection of this manual). Drivers not processing time-out are not entered on device time-out.
- d. If both the DCPC and the device controller interrupts are expected, but only the device controller interrupt is significant, the DCPC interrupt can be ignored by making a continuation return to CIC as described in step "g" below. (Refer to the "DCPC Processing" subsection of this manual for a method to suppress the DCPC interrupt entirely.)
- e. Performs the input or output of the next data item if the device is driven under program control. One of three possible actions is then taken:
  - 1. If the transfer is not complete, the driver follows the procedure described in step "g" below to make a continuation return.
  - 2. If the transfer is complete, the driver follows the procedure described in step "f" below to make a completion return.
  - 3. If the driver detects a transmission error, it can reinitiate the transfer and attempt a retransmission. A counter for the number of retry attempts can be kept in the EQT entry. After initiating each retry, the driver makes a continuation return to CIC as described in step "g" below.
- f. (Completion Return.) At the end of a successful transfer or after completing the retry procedure, the driver performs the following steps before returning to CIC:
  - 1. Sets the actual or simulated device controller status into bits 7 through 0 of EQT entry word 5 without altering the rest of word 5.
  - 2. Sets the number of words or characters (depending on which the user requested) transmitted into the B-register. This value is known as the transmission log.
  - 3. Clears the device controller (and DCPC if used).

 Sets the A-register to indicate successful or unsuccessful completion and the reason, as follows:

If A = 0 the operation was successfully completed.

If A = 1,2,3,4 the operation was not completed, where:

1 = device or controller malfunction or not ready

2 = end-of-tape or end-of-information

3 = transmission parity error

4 = device time-out

- 5. Return to CIC at P+1 (JMP Cxnn, I).
- g. (Continuation return.) When the driver wishes to continue the transfer (i.e., additional interrupts are expected), the driver performs the following steps before returning to CIC at P+2:
  - 1. Sets the device controller (and DCPC if used) for the next transfer or retry.
  - 2. Optionally sets the device time-out clock (EQT entry word 15) to modify the value inserted there by the system. (Refer to the "I/O Controller Time-Out" subsection of this manual.)
  - 3. Returns to CIC at P+2 or (for RTE-IVB) P+3 as follows:

ISZ Cxnn

JMP Cxnn,I

or

ISZ Cxnn

ISZ Cxnn

JMP Cxnn.I

For the P+3 return, the content of the A-register determines the action taken by the system. The A-register should be set as follows:

A = 5 request the allocation of a DCPC channel. After assigning a DCPC channel, the system will reenter the driver at Lxnn.

A=6 request the deallocation of a DCPC channel. After releasing the DCPC channel, the system continues processing as if this were a P+2 continuation return.

#### 3-6. DEVICE CLEAR ON PROGRAM ABORT

If an I/O suspended program is aborted while waiting for a controller, the system attempts to clear the controller by issuing a clear control request to the driver (i.e., request code 3, subfunction code 00, as indicated in EQT entry word 6). All drivers written for use in RTE must be prepared to handle this request even if no other control requests are supported for the controller.

If the controller can be cleared without interrupt (i.e., immediately), the driver should perform the clear operation and return to IOC with the A-register equal to 2 (control request illegal) or 4 (immediate completion). Either return is sufficient in this case; they are both treated equivalently by the system.

If an interrupt is required, the driver should return with the A-register equal to 0. In this case, the system forces a one second time-out for the controller. When the device controller interrupts, the driver should complete the clear operation and make a successful completion return

(A-register=0) to CIC at P+1. However, if the interrupt does not occur within the one second time-out, the system itself issues a clear control command (CLC) to the controller's select code(s). Note that in this case the driver is not entered to process the time-out even if it had previously set the "driver processes time-out" bit in EQT entry word 4. (Refer to the "I/O Controller Time-Out" subsection in this manual.)

# 3-7. I/O CONTROLLER TIME-OUT

Each I/O controller can have a time-out clock to prevent indefinite I/O suspension. Indefinite I/O suspension can occur when a program initiates I/O, and the device controller fails to return a flag indicating that the transfer is complete. This can occur as the result of either a hardware malfunction or improper program encoding. Without the controller time-out, the program making the I/O call would remain in I/O suspension indefinitely, awaiting the completion indication from the device controller.

EQT entry words 14 and 15 function as an I/O controller's time-out clock. EQT entry word 15 is the actual working clock. Prior to each call to the driver, word 15 is set to a value "m," where "m" is a negative number of ten millisecond time intervals. Thereafter, this counter is incremented by one at each ten millisecond tick of the system's real-time clock. If the controller does not interrupt within the required time interval (i.e., before the counter in EQT entry word 15 goes to 0), it is considered as having "timed-out."

The EQT entry word 15 clock for each controller can be individually set by either of the following two methods:

- a. The system always inserts the contents of EQT entry word 14 (a negative number) into EQT entry word 15 before the initiation or continuation/completion section of a driver is entered. Word 14 can be preset to "m" by entering a time-out value during the EQT entry phase of generation, or it can be set or modified on-line with the TO operator request.
- b. When the driver initiates I/O and expects to be entered due to a subsequent interrupt, the driver itself can set the value "m" into EQT entry word 15 just before it exits. The value "m" can either be coded permanently into the driver or can be passed to the driver as an I/O request parameter.

#### NOTE

The system always inserts the contents of EQT entry word 14 into EQT entry word 15 before entering a driver, with the following exceptions: 1) if an initiation call is being made and word 15 is already non-zero, it is not reset, and 2) if a continuation call is being made and word 14 is zero, word 15 is not reset. In any case, a time-out value inserted by the driver directly into word 15 overrides any value previously set by the system.

A time-out value of zero is equivalent to not using the time-out feature for a particular controller. If a time-out parameter is not entered, its value remains zero and time-out is disabled for the controller.

Time-out is enabled for a controller only while the controller is processing an I/O request. The working time-out clock (EQT entry word 15) is set as described above. If the controller does not time-out, the clock is then cleared by the system after one of these driver returns:

- 1. An Initiation return indicating a rejected initiation request (A-register not equal to zero).
- 2. A Completion return.

## DRIVER PROCESSING OF TIME-OUT

When a controller times-out, a driver has the option of performing its own time-out processing, or of letting the system handle it entirely. A driver that processes its own time-outs indicates this to the system by setting bit 12 of EQT entry word 4. Since the system never clears this bit, it needs to be set only once. When bit 12 is set, the following action takes places upon controller time-out:

- a. Bit 11 in EQT entry word 4 is set by the system.
- b. The driver is entered at Cxnn with the A-register set to the I/O select code of the controller that timed-out. (The same information is available in EQT entry word 4.)
- c. The driver recognizes that the entry is for time-out by examining bit 11 of EQT entry word 4. When bit 11 is set, a time-out has occurred, and the driver should perform whatever processing is necessary. This can involve completing the operation in progress or restarting the device and continuing the operation. If the latter option is taken, the driver should clear bit 11 prior to exiting in case it is entered again prior to completion of the operation. This enables the driver to distinguish between a normal continuation entry (bit 11 = 0) and another time-out entry (bit 11 = 1). Note that IOC only clears bit 11 prior to entering the driver at Ixnn on an initiation call.
- d. The driver may decide to continue (i.e., restart the device) or complete (i.e., terminate) the operation, as follows:
  - 1. If the driver decides to complete the operation, it sets the A-register equal to 4 (to indicate that a time-out has occurred), sets the B-register equal to the transmission log, and returns to CIC at P+1. This causes CIC to set the LU down and to print the following message:

I/O TO L #x E #y S #z

where:

#x is the LU number being set down,

#y is the number of the EQT entry associated with this LU, and

#z is the subchannel associated with this LU.

It is also possible to complete the operation without having a message printed. To do this, the driver simply makes a normal completion return (A-register = 0, B-register = transmission log) to CIC at P+1.

In either case (A = 4 or A = 0), CIC reschedules the calling program and passes it the transmission log returned by the driver.

2. If the driver decides to continue the operation, it makes a normal continuation return to CIC at P+2.

#### SYSTEM PROCESSING OF TIME-OUT

When a time-out occurs and bit 12 of EQT entry word 4 is not set, the system handles the interrupt itself in the following way:

- a. The program that made the initial I/O request is rescheduled and a zero transmission log is returned to it.
- b. The LU is set down and the following message is printed:

where:

#x is the LU being set down,

#y is the number of the EQT entry associated with this LU, and

#z is the subchannel associated with this LU.

c. A clear control (CLC) instruction is issued to the controller's select code(s) through the EQT entry number located in the Interrupt Table.

Note that the driver is never entered for time-out processing when bit 12 of EQT entry word 4 is zero. This means that only those drivers that set bit 12 to indicate that they are to process time-out need to check for a time-out entry.

Since the system issues a CLC instruction to the controller's select code(s), each controller interface card requires an entry in the Interrupt Table during generation. Otherwise, the system would not be able to issue the CLC instruction when a controller timed-out.

# 3-8. DCPC PROCESSING

The Dual Channel Port Controller (DCPC) feature of the HP 21XX series of computers can be used to transfer blocks of data between I/O devices and the computer at high data transfer rates. The DCPC transfers are initiated in software, but the actual word-by-word transfer is handled under hardware control. Words are transferred to or from the computer via a "cycle stealing" technique that operates concurrently with the normal execution of programs. This design eliminates the overhead associated with driver processing of individual interrupts and allows synchronous and high-speed devices to be controlled by standard RTE drivers.

This subsection discusses some of the aspects of DCPC transfers in the RTE operating systems. It is assumed that the reader is already familiar with the general techniques of DCPC programming as described in the appropriate computer reference manual.

# RTE CONTROL OF DCPC ASSIGNMENT

RTE controls the allocation of the two DCPC channels available via the first two words of the Interrupt Table. Interrupt Table entry word 1 records the current assignment of DCPC channel 1, and word 2 records the current assignment of DCPC channel 2. This arrangement is illustrated in Figure 3-3. This figure also illustrates the format of each individual DCPC Assignment Word. (Note that DCPC channels 1 and 2 generate interrupts on I/O select codes 6 and 7, respectively, and hence are often referred to as DCPC channels 6 and 7.)



Figure 3-3. DCPC Channel Assignment Words

Each DCPC Channel Assignment Word in the Interrupt Table can be in one of two states; assigned or unassigned. If the entire word is zero, the respective DCPC channel is unassigned, and is therefore available for use. A non-zero word implies that the DCPC channel is currently assigned. Bits 0 through 14 contain the address of the EQT entry (which in turn points to the driver) to which the DCPC channel has been allocated. Once a DCPC channel is allocated, a driver can set bit 15 in the appropriate DCPC Channel Assignment Word as a flag to the operating system. Use of this flag is fully explained later in this subsection.

#### DCPC ASSIGNMENT BY RTE

Before a driver can initiate a DCPC transfer, it must be assigned by RTE the exclusive use of a DCPC channel. This prevents simultaneous access to the channel by several drivers. A driver can be assigned a DCPC channel in the following two ways:

#### PREFERRED METHOD

If the driver's EQT entry had a "D" specified at generation time, the "DCPC channel required" bit is permanently set in the EQT entry (EQT entry word 4, bit 15). In this case, the system always assigns a DCPC channel to the driver at each I/O initiation. The assigned DCPC channel number can be found (at initiation only) in the Base Page Communications Area word CHAN. It should then be saved in one of the temporary storage words of the EQT entry since it is not available in CHAN on later entries to the driver for the same I/O request.

#### ALTERNATE METHODS

If a driver needs a DCPC channel only for a certain subset of the functions that it performs, it can dynamically ask the system to assign it a DCPC channel as required. In this case, the DCPC option is not selected for the driver's EQT entry at generation time, and hence the "DCPC channel required" bit is not set in the EQT entry.

A driver can dynamically request a DCPC channel from either its Initiation or (RTE-IVB) Continuation/Completion sections. Each method is described below.

#### ALTERNATE METHOD I — INITIATION REQUEST

The driver will be entered at **I**xnn without a DCPC channel assigned by IOC. The driver must analyze the request and determine if a DCPC channel is required. If so, the driver requests a DCPC channel from IOC by returning via a jump indirect through **I**xnn (**JMP I**xnn,**I**) with the A-register equal to 5. IOC then assigns a DCPC channel and recalls the driver.

However, IOC does not differentiate between the initial call to the driver and the recall with the DCPC channel assigned. The EQT entry is set up identically in both cases, and the driver is entered at **Lxnn**. Furthermore, it is possible that the driver may never be recalled with the DCPC channel assigned for a particular I/O request. For example, this can occur if the program making the request is aborted before IOC has a chance to assign the DCPC channel. If the program is aborted, the driver will not be entered again until another program requests I/O for a device under the driver's control.

Thus, a driver can never know from the calling parameters or from its past history whether it is being called for the first time for an I/O request (i.e., no DCPC channel is assigned) or whether it is being recalled with a DCPC channel now assigned. The only way the driver can distinguish between these two cases is to access the two DCPC Channel Assignment Words (in the Interrupt Table) to determine whether a DCPC channel is currently assigned to the driver.

If the value in either DCPC Channel Assignment Word is equal to the address of the EQT entry currently being serviced by the driver, that DCPC channel is currently assigned to the driver. The driver can then assume that it has been recalled with a DCPC channel assigned, and can initiate the transfer on that DCPC channel. If neither value matches, no DCPC channel is assigned to the driver, and it must return to IOC to request that one be assigned. (Note that in this case the driver cannot use Base Page Communications Area word CHAN as an indication of whether or not it has been assigned a DCPC channel. This is because CHAN indicates only which channel was last assigned to any driver; not to whom it was assigned.)

The following code illustrates the DCPC assignment check technique. In reviewing this and subsequent examples, remember that the Base Page Communications Area word INTBA contains the address of the Interrupt Table, and that base page word EQT1 contains the address of the EQT entry currently being serviced by the driver.

| *       | Execute this code if DCPC required                |
|---------|---------------------------------------------------|
| INTBA,I | Access DCPC Channel Assignment Words              |
| EQT1    | Is DCPC channel 1 assigned to this driver?        |
| CH1     | Yes, configure and initiate transfer on channel 1 |
| EQT1    | Is DCPC channel 2 assigned to this driver?        |
| CH2     | Yes, configure and initiate transfer on channel 2 |
| =B5     | No. A DCPC channel is not assigned. Set           |
| Ixnn, I | A = 5 to request one from IOC, and return.        |
|         | INTBA,I EQT1 CH1 EQT1 CH2 =B5                     |

Note that if a driver obtains a DCPC channel in this way, a special procedure must also be followed to return the DCPC channel to RTE. The return procedure is discussed in the "Returning DCPC Channels to RTE" subsection.

# ALTERNATE METHOD II — CONTINUATION REQUEST (RTE-IVB only)

Alternately, the driver can request a DCPC channel from IOC by returning via a jump indirect through **C**xnn with the A-register equal to 5 as follows:

```
(Set A-register to 5)
ISZ Cxnn
ISZ Cxnn
JMP Cxnn,I
```

IOC then assigns a DCPC channel and recalls the driver, entering at **Lxnn**. In this case, IOC does not reset the EQT entry before entering at **Lxnn**.

The Initiation section of the driver can determine if this method is being used to acquire a DCPC channel by examining bit 15 of word 3 in the EQT. If this bit is set, then the Initiation section was entered as a result of a DCPC request from the driver's Continuation section. The DCPC channel assigned is available in Base Page Communications Area word CHAN.

Note that a DCPC channel obtained this way must be returned to RTE by a special procedure. The return procedure is discussed in the "Returning DCPC Channels to RTE" subsection.

#### DETERMINING THE DCPC ASSIGNMENT METHOD

These alternate methods of obtaining a DCPC channel are more complex than the preferred method and should only be used by drivers that: 1) process a mixture of DCPC and non-DCPC operations, and 2) cannot afford to tie up a DCPC channel during the non-DCPC operations.

It should also be noted that the Initiation section of the driver may have to use different methods to determine if a DCPC channel was assigned by IOC. Figure 3-4 summarizes these methods.



Figure 3-4. Determining DCPC Assignment

Regardless of the method used to obtain a DCPC channel, RTE records the assignment by putting the address of the EQT entry being assigned the DCPC channel into the appropriate DCPC Channel Assignment Word in the Interrupt Table.

If a DCPC channel is not available, the requesting EQT is set into a "waiting for DCPC" state. As soon as another driver releases a DCPC channel, the lowest-numbered EQT waiting for DCPC is assigned the DCPC channel, and its I/O request is initiated.

## RETURNING DCPC CHANNELS TO RTE

As soon as a driver completes a DCPC transfer and the associated I/O request, the DCPC channel must be returned to the available pool so that it can be used by other drivers. This occurs in two different ways, depending on how the DCPC channel was assigned:

- 1. If the DCPC channel was assigned automatically (PREFERRED METHOD discussed above), the DCPC channel is returned automatically by RTE when the driver makes its completion return to CIC. No special driver processing is required.
- 2. If the DCPC channel was assigned as the result of a specific request by the driver (ALTERNATE METHOD discussed above), the driver must explicitly inform RTE of this fact when the I/O request is completed. This is done by setting the sign bit in the A-register on the completion return to CIC. This bit may be set at all times even when the driver has not been assigned a DCPC channel. However, some extra system overhead is created if the sign bit is set when not required. Note that the sign bit is set in addition to the normal completion code, as illustrated below:

LDA COMCD Set A = completion code determined earlier

IOR =B100000 Set sign bit to indicate dynamic DCPC assignment

JMP Cxnn,I Return to CIC

In either of the above cases, RTE implements the return of the DCPC channel by clearing the appropriate DCPC Channel Assignment Word in the Interrupt Table. DCPC Channel 1 Assignment Word (Interrupt Table word 1) is cleared if DCPC channel 1 was assigned to the driver; DCPC Channel 2 Assignment Word (Interrupt Table word 2) is cleared if DCPC channel 2 was assigned to the driver. No action is taken if a DCPC channel was not assigned to the driver.

In RTE-IVB, a driver may also return a DCPC channel assigned to it through an Initiation or a Continuation return. In each case, the A-register having value 6 selects this deallocate DCPC option. IOC will deallocate the DCPC channel, if one was indeed allocated, and then proceed as for a normal Initiation or Continuation return. In addition, if a DCPC channel is deallocated from a Continuation return, IOC will check to see if another EQT is waiting for a DCPC channel. If so, IOC assigns the DCPC channel to that EQT and initiates its I/O request, thus increasing DCPC utilization.

#### HANDLING THE DCPC INTERRUPT

An end-of-operation interrupt is generated by the DCPC hardware when a DCPC transfer is complete. Depending upon the nature of the device under control, the associated driver may or may not wish to recognize the DCPC interrupt.

If the driver does not require or use the DCPC completion interrupt, it can be disabled by issuing a clear control instruction (CLC) to the DCPC select code (6 or 7) after initializing the DCPC transfer. No further special processing is necessary.

If the driver uses the DCPC completion interrupt, some special processing must be included in the driver to ensure that the completion interrupt occurs only at the correct time in systems using a Privileged Interrupt card. (These systems are described more fully in Section IV.)

The following potential problem exists: In systems using a Privileged Interrupt card, the interrupt system is always ON, even when a driver is executing. It is therefore possible that a

driver using DCPC could start the DCPC transfer and be interrupted by its own DCPC completion interrupt before it had a chance to complete the initiation procedure and return to IOC.

To eliminate this problem, a scheme has been designed to hold off the DCPC completion interrupt until the standard driver using DCPC completes the initiation procedure and returns to IOC. This scheme requires the cooperation of the standard driver utilizing DCPC and of both RTE and any privileged drivers present in the system, as follows: After disabling the interrupt system and initializing the DCPC transfer, the standard driver clears control on the DCPC select code (6 or 7) to inhibit the completion interrupt while the standard driver completes the initiation procedure. The standard driver also sets a flag to inform RTE that the standard driver actually needs the interrupt, and that RTE should reenable the interrupt later, after the driver returns to IOC.

The flag is also used by privileged drivers. A privileged driver disables the DCPC completion interrupts upon entry so that the privileged driver will not be interrupted while processing the privileged interrupt. A privileged driver will reenable a DCPC completion interrupt before exiting only if it is needed by a standard driver (as indicated by the flag being set).

Bit 15 of each DCPC Channel Assignment word in the Interrupt Table is used as the flag for the respective DCPC channel. If this flag is set, RTE and the privileged drivers will reenable the DCPC interrupt on the correct DCPC channel at the appropriate time. No action is taken if the flag is not set.

The section of code listed below illustrates the special processing required when a standard driver uses the DCPC completion interrupt. Note that although this processing must be included in all drivers using DCPC, it need only be executed when the driver is operating in a privileged system. The type of system in which a driver is operating can be determined by examining base page word DUMMY. If DUMMY is 0, the system is non-privileged (i.e., no Privileged Interrupt card is present); otherwise the system is privileged (i.e., a Privileged Interrupt card is present).

| CLF 0                                       | Disable the interrupt system                                                                                                                   |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| STC DCPC,C                                  | Initiate transfer on DCPC channel                                                                                                              |
| CLA CPA DUMMY JMP X                         | Bypass section below if  DUMMY = 0 (non-privileged system)  and special processing not needed.                                                 |
| CLC DCPC LDB INTBA LDA CHAN CPA = D7 INB    | Clear DCPC control to inhibit DCPC interrupt. Set B = address of the appropriate DCPC Channel Assignment word in the Interrupt Table           |
| LDA B,I<br>IOR =B100000<br>STA B,I<br>STF 0 | Set bit 15 of DCPC channel assignment entry equal to 1 as flag to system to turn DCPC interrupts back on later. Reenable the interrupt system. |
| EQU *                                       | Continue processing.                                                                                                                           |

X

#### INTERMIXED DCPC AND NON-DCPC OPERATIONS

Occasionally a driver may have a special requirement to intermix a series of non-DCPC operations with DCPC operations during the same I/O request. If it is necessary or desirable to retain assignment of the DCPC channel throughout the non-DCPC operation, the following special processing is required: the software flag in bit 15 of the appropriate DCPC channel assignment word should be cleared prior to beginning the non-DCPC operations. This prevents the system from reenabling the DCPC completion interrupt when it is not desired. Note that this processing need only be done if the flag was previously set under the conditions discussed in the preceeding paragraphs.

## 3-9. DRIVER AUTOMATIC "UP"

A driver has the capability of automatically returning its EQT entry and all associated LU's to the "up" state through a JMP instruction. For example, if a driver makes a not ready, parity error, end-of-information, or time-out return to the system, the system sets the associated LU and EQT entry into the "down" state. If the driver subsequently detects an interrupt (or time-out) entry that signals that the controller is now ready, it may return the EQT entry and associated LU's to the "up" state as follows:

#### JMP \$UPIO

The device controller's EQT entry and all associated LU's are reset to the up (available) state by \$UPIO. If an I/O request is pending, \$UPIO restarts the request by entering the driver at the initiation entry point Ixnn.

#### 3-10. POWER FAIL PROCESSING

When an RTE system is generated, the user has the option of including DVP43, the power fail/automatic restart driver, and AUTOR, the automatic restart program. If DVP43 is not included, the system executes a HALT 4 when power is restored to the computer.

If the power fail/automatic restart modules are included in the generation, they enable the system to recover automatically from a power failure. Power fail/automatic restart processing can be divided into three parts:

- a. The power down sequence.
- b. The power up sequence.
- c. The sequence required to restart any I/O transfers that were in progress when the power fail occurred. (A driver has the option of restarting its own I/O, or of letting the system restart it from the beginning of the request. These two alternatives are discussed below.)

# POWER DOWN SEQUENCE

When a power fail occurs, a power fail interrupt is generated and DVP43 is entered to process the interrupt. In the brief period of time available before the system becomes completely inoperable, DVP43 performs the following steps to save the state of the machine:

- a. Stops all DCPC transfers.
- b. Saves all user accessible registers (A,B,E,O . . .).
- c. Saves the status of the memory protect fence. Also saves the status of the Dynamic Mapping System (DMS) in systems which include the DMS feature.
- d. Saves all map registers (System Map, User Map, and the two DCPC maps). This step is performed in systems with Dynamic Mapping only.

DVP43 then executes a HALT 4 instruction before power fails completely.

# POWER UP SEQUENCE

When power is restored to the computer, an interrupt is generated and DVP43 is reentered to process the interrupt. DVP43 performs the following steps to restart the system:

- a. Sets a software flag to prevent resaving the state of the machine if a subsequent power failure occurs before the system is completely restored.
- b. Reenables the power fail hardware.
- c. Restores the state of the memory protect fence. Also restores all map registers and the status of the Dynamic Mapping System in systems which include the DMS feature.
- d. Saves the time of the power fail.
- e. Finds the power fail EQT entry (i.e., the EQT entry associated with DVP43) and sets up a very short time out on this EQT entry by setting EQT entry word 15 (the time-out clock) to -1. This causes DVP43 to be reentered after one tick of the real-time clock. DVP43 can then begin to restart any I/O transfers that were in progress at the time of the power failure.
- f. Restarts the real-time clock.
- g. Restores all user-accessible registers.
- h. Clears the software flag that was set in step "a", so that the state of the machine will be saved as usual on any subsequent power failures.
- i. Returns to the suspended process (i.e., the process that was in operation when the power fail occurred) at the point of interruption.

# RESTART I/O SEQUENCE

As soon as the power fail EQT entry times-out, DVP43 is entered again since it previously set the "driver processes time-out" bit. DVP43 now attempts to restart any I/O transfers that were in progress at the time of the power fail by performing the following steps:

- a. Makes the following checks for each I/O controller:
  - 1. Checks bits 14 and 15 of EQT entry word 5. The value of bits 14 and 15 indicate whether the I/O controller was "down" or "busy" at the time of the power failure.
  - 2. Checks bit 13 of EQT entry word 4 to see if the driver associated with the EQT entry is prepared to process a power fail/automatic restart entry. Drivers that are prepared to process power fail/automatic restart entries will have previously set bit 13 to one. Otherwise, this bit is zero. (Note that the system never clears bit 13, so a driver only needs to set it once.)
  - 3. Checks to see if any EQT entries are currently waiting for a DCPC channel.
- b. Depending upon the above information, one of the following three actions is taken for each controller or device in the system:
  - Case 1. Controller (EQT entry) busy and "driver processes time-out" bit set:

If the controller was reading or writing data when the power fail occurred and the driver is designed to handle power fail, the driver has the responsibility to recover from the power fail in the best possible manner. The system simply sets bit 15 of EQT entry word 5 to 1 to indicate that a power fail has occurred, and enters the driver at the initiation entry point **I**xnn.

Case 2. Controller waiting for a DCPC channel.

If the controller was waiting for a DCPC channel when the power failure occurred, no action is taken. The I/O transfer will be initiated as usual when a DCPC channel is released by another driver.

#### Case 3. All other EQT entries

For all EQT entries not falling under Case 1 or Case 2 above, DVP43 makes a call to \$UPIO to up the EQT entry and all associated LU's. (See the "Driver Automatic Up" subsection of this manual.) \$UPIO restarts any I/O requests that were in progress (i.e., EQT entry was busy) or pending (i.e., EQT entry or LU was down) at the time of the power failure. This is done by resetting the parameters of the original call into the EQT entry and reentering the driver at the initiation point Ixnn.

After the above action is taken for each I/O controller in the system, an HP-supplied program called AUTOR (auto-restart) is scheduled. AUTOR sends the time of power failure to all user consoles on the system (thereby reenabling all terminals). Note that the request sent to user consoles (drivers 00 and 05) by AUTOR specifies number of characters to be output, not number of words.

AUTOR is written in FORTRAN, with the source tape supplied so that it can be easily modified for site-specific applications.

# 3-11. PROGRAM SCHEDULING BY DRIVERS

Occasionally some I/O applications may require that a driver schedule a program to perform a certain task. The system list processor, \$LIST, has several calls available that provide drivers with this capability. These calls are illustrated below. All of these calls cause a program to be scheduled. They differ only in the format of the calling sequence, and in the type of information that each call may specify is to be stored in the ID segment of the program to be scheduled.

Method 1. (Used to put five parameters in the ID segment and then schedule the program.)



This call causes the system to place whatever number (0-5) of optional parameters are supplied into the temporary storage area of the ID segment of the program whose ASCII name is contained in the variable PNAME. The system then schedules the program to run at its own priority.

Method 2. (Same as Method 1, except that the ID segment address rather than the program name is supplied. Note that in some RTE systems a driver may not be able to search the ID Segment Table for a program's ID segment address. It is therefore recommended that drivers scheduling programs do so by specifying the program's name (function code 701 call to \$LIST), rather than the ID segment address.)

|           | DEF RTN OCT IDADR DEF P1 DEF P2 | Return point. (Must be immediately after call.) ID segment address of program to be scheduled. Address of up to five optional parameters to be placed in program's ID segment |
|-----------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | DEF P3<br>DEF P4<br>DEF P5      |                                                                                                                                                                               |
| RTN       |                                 | Return point. Must be located immediately after call. (See below for error status return in A & B-registers)                                                                  |
| P1        | OCT A                           | Up to five optional parameters to be placed in                                                                                                                                |
| <b>P2</b> | OCT B                           | program's ID segment (temporary storage area)                                                                                                                                 |
| P3        | OCT C                           | prior to scheduling it.                                                                                                                                                       |
| P4        | OCT D                           |                                                                                                                                                                               |
| P5        | OCT E                           |                                                                                                                                                                               |

This call causes the system to place whatever number (0-5) of optional parameters are supplied into the temporary storage area of the ID segment specified by IDADR. The system then schedules the program associated with the ID segment to run at its own priority.

Method 3. (Used to put a value into the "B-register at suspension" word in the ID segment and then schedule the program. This call can be used to set the B-register to point to a scheduling parameter storage area. The scheduled program can then recover the parameters via a call to subroutine RMPAR. The driver should make sure that the parameters are placed in a memory area that is mapped with the user program.)

|     | EXT \$LIST |                                                        |
|-----|------------|--------------------------------------------------------|
|     | •          |                                                        |
|     |            |                                                        |
|     | JSB \$LIST |                                                        |
|     | OCT 601    |                                                        |
|     | OCT IDADR  | ID segment address of program to be scheduled.         |
|     | OCT BVAL   | Value to be put into "B-register at suspension" word   |
| RTN | •          | Return is always made to here by \$LIST                |
|     | •          | (See below for error status return in A & B-registers) |
|     | •          |                                                        |

This call causes the system to place the value BVAL into the "B-register at suspension" word of the ID segment specified by IDADR. If this value is an address that points to a set of scheduling parameters, the program can recover the parameters by making a call to subroutine RMPAR. The system then schedules the program associated with the ID segment to run at its own priority.

#### Error Conditions:

When \$LIST returns from any of the program schedule calls described above, the A and B-registers indicate whether or not the program was successfully scheduled, as follows:

If A = 0 the program was successfully scheduled. (The

B-register contains the ID segment address of

the scheduled program.)

If A is non-zero the program could not be scheduled. The B-reg-

ister indicates the reason, as follows:

B = 3 Illegal status (program not dormant)

B = 5 No such program.

# 3-12. DETERMINATION OF OPERATING SYSTEM ENVIRONMENT

There are times when it may be necessary for a driver to know the operating system within which it is executing. The system entry point \$OPSY provides this and other information in the form of one-word table, as illustrated in Table 3-1.

Table 3-1. \$OPSY Word Format

| System                                                          | \$OPSY<br>Value*            | Bit 15                | Bit 3                      | Bit 2<br>0=RTE-M<br>1=RTE  | Bit 1 0=No DMS 1=DMS  | Bit 0  0 =64 Word Disc 1=128 Word Disc |
|-----------------------------------------------------------------|-----------------------------|-----------------------|----------------------------|----------------------------|-----------------------|----------------------------------------|
| RTE-M/I<br>RTE-M/II<br>RTE-M/III<br>RTE-II<br>RTE-III<br>RTE-IV | -7<br>-15<br>-5<br>-3<br>-1 | 1<br>1<br>1<br>1<br>1 | 1<br>0<br>1<br>1<br>1<br>0 | 0<br>0<br>0<br>1<br>1<br>1 | 0<br>0<br>1<br>0<br>1 | 1<br>1<br>1<br>1<br>1                  |

\*Note: All unspecified bits are set to 1.

\$OPSY can be referenced simply by loading it into a register and testing the appropriate bits. This technique is illustrated below:

EXT \$OPSY

LDA \$OPSY
AND MASK

Access \$OPSY information
Isolate appropriate bits

Take appropriate action

In Dynamic Mapping Systems (\$OPSY bit 1=1), it may also be necessary to determine whether the System Map or User Map is currently enabled. This can be done in a driver by accessing the status of the Dynamic Mapping System via an RSA instruction, and looking at bit 12. Bit 12 is 0 if the System Map is enabled, and 1 if the User Map is enabled. The following code illustrates this procedure:

| RSA       | Access Dynamic Mapping System Status |
|-----------|--------------------------------------|
| ALF       | Position Bit 12 into Bit 0           |
| SLA       | System Map Enabled?                  |
| JMP USER  | No, User Map Enabled.                |
| JMP SYSTM | Yes, System Map Enabled              |
|           |                                      |



# 3-13. SUBROUTINES FOR SPECIAL MAPPING FUNCTIONS (DMS SYSTEMS ONLY)

By using the Dynamic Mapping System (DMS) feature of the 21MX series of computers, RTE provides the capability for addressing memory configurations larger than 32K words. This is accomplished by translating memory addresses through one of four "memory maps." A memory map consists of a set of hardware registers. These registers provide the interface between memory addresses used by programs (logical memory addresses) and actual memory addresses (physical memory addresses). There are four distinct maps: the System Map, the User Map, and the two DCPC maps. The DCPC maps are loaded (i.e., set up) by the system as necessary to describe the logical memory configuration required by the currently executing program or DCPC transfer.

Prior to entering a driver to process an I/O request, RTE loads and enables the correct map (System or User) needed to describe the buffer of the request. The driver can access the buffer through the request buffer address word in the EQT without having to consider which map contains the buffer.

Certain drivers may, however, need to access a buffer in addition to the primary request buffer. If a driver is entered with the System Map enabled (e.g., when the primary request buffer is in System Available Memory or System Common), it must access the second buffer through the User Map if the second buffer is located in the program making the I/O request. In addition, the driver must load the User Map since the current contents of the map may or may not describe the desired program.

Subroutine \$XDMP can be called by standard drivers to reload the User Map to describe the program containing the second buffer. The driver user \$XDMP as follows.

- 1. Save the contents of the current User Map.
- 2. Load the A-register with the ID Segment address of the program containing the second buffer.
- 3. Call \$XDMP (JSB \$XDMP) to load the User Map for the program specified in the A-register.
- 4. Check for an error return. \$XDMP returns with the A-register set to zero if the specified program was not in memory and the User Map could not be set up.
- 5. If no error was detected, access the second buffer through the newly loaded User Map.
- 6. After all accesses to the second buffer have been made, restore the User Map to its original contents and continue with normal operation.

Notice that the use of \$XDMP requires that the driver know the ID Segment address of the program making the I/O request. Since the driver can not be sure that this ID Segment address is available on base page or in the EQT, the program making the I/O request should cooperate with the driver and pass its ID Segment address. This could be done by using one of the optional parameters and letting the driver retrieve the address through the appropriate optional parameter word in the EQT or by including the address in one of the words of the primary request buffer.

The recommended procedure for using \$XDMP and accessing the second buffer is somewhat different in RTE-III and RTE-IV. Each of these procedures is described in a separate section below.

#### NOTE

Subroutine \$XDMP can be called by standard RTE drivers only. Privileged drivers wishing to perform the same function must use subroutine \$PVMP, which is described in Section IV of this manual.

# MAPPING IN RTE-III AND RTE-M/III

Any standard driver operating in RTE-III may use subroutine \$XDMP to perform the memory map switching discussed above. The driver first saves the current state of the User Map registers and the Dynamic Mapping System, and then calls \$XDMP to reload the User Map registers to describe the user program. The driver can then enable the User Map and access the memory described by it. After all accesses have been made, the driver reenables the System Map and restores the original state of the User Map registers before continuing with its normal processing under the System Map.

Note that subroutine \$XDMP need only be used to reload the User Map registers when the driver is entered with the System Map enabled. The calling sequence is as follows:

| EXT \$XDMP |                                                 |
|------------|-------------------------------------------------|
| •          |                                                 |
|            |                                                 |
| RSA        | Get Dynamic Malping System (DMS) status         |
| ALF        | Position bit 12 into bit 0                      |
| SLA        | Is System Map Enabled?                          |
| JMP USER   | No, so do not need to execute code below        |
|            | Normal driver processing under System Map       |
| RSA        | Get Dynamic Mapping System (DMS) status         |
| RAL,RAL    | Position current status in upper bits           |
| STA DMSST  | Save status for later.                          |
| IDA MADAD  | 0.14. 11. 0.77. 25                              |
| LDA MAPAD  | Set A = address of User Map storage area        |
| IOR SIGN   | Set sign bit indicating STORE Map in memory     |
| USA        | Save current User Map in memory for later.      |
| LDA IDADR  | Get ID address of program that contains buffer  |
| JSB \$XDMP | Call \$XDMP to set up User Map for this program |
| SZA, RSS   | Check for error return                          |
| JMP ERROR  | Error exists, go handle it                      |
| TITE CONTE |                                                 |
| UJP CONT   | No errors. Enable new User Map and continue     |
|            |                                                 |

CONT .

Process buffer under new User Map

.

SJP NEXT Reenable System Map

NEXT LDA MAPAD Access address of User Map storage area

USA Restore original contents of User Map

JRS DMSST NXT Restore original DMS status (i.e., System Map)

NXT .

Proceed with normal processing under System Map

MAPAD DEF MAP Address of User Map storage area

MAP BSS 32 User Map storage area

SIGN OCT 100000

IDADR BSS 1 Storage for ID segment address
DMSST BSS 1 Temporary storage for DMS status

Remember that any driver using \$XDMP must save the original contents of the User Map before calling \$XDMP. It must also restore the original User Map before continuing with its normal operation under the System Map. Also remember that if the driver accesses the memory described by the User Map by enabling the map, it must save and restore the DMS status in addition to the original contents of the User Map. The example above illustrates this procedure.

#### NOTE

The driver could also access the buffer in the user program through a series of cross-map loads and stores without actually enabling the User Map. This is in fact the recommended procedure for using \$XDMP in an RTE-IV system, and use of it by a driver would allow the same driver to be used in either type of system.

#### MAPPING IN RTE-IV

Drivers in RTE-IV may be located in one of the Driver Partitions or in the System Driver Area of memory. If a driver resides in a driver partition, RTE automatically includes the correct driver partition as it loads and enables the correct map (System or User) prior to entering the driver. If one of these drivers is entered under the System Map and needs to access a second buffer in the program which made the I/O request the driver can use the \$XDMP subroutine as described in the previous second.

The other location for a driver in RTE-IV is the System Driver Area (SDA) of memory. Drivers are placed in SDA by specifying either "M" or "S" in the EQT entry definition phase during system generation. The "S" option specifies that the driver will be entered under the appropriate map (System or User) depending on the location of the I/O request buffer. The "M" option specifies that the driver will always be entered under the System Map regardless of the location of the I/O buffer.

The "S" and "M" options also differ in the types of checks performed by RTE prior to entering the driver. If the "S" option is selected and the I/O buffer is in the user program, RTE will check to see if SDA is included in the program's logical address space (map). If not, RTE aborts the program with an IO11 error, "Type 4 program made an unbuffered I/O request to a driver that did not do its own mapping." If the "M" option is selected, RTE will not check to see if the I/O request buffer and SDA are in the same logical address space; rather, RTE enters the driver under the System Map, assuming that the driver will perform any needed mapping. This is why the "M" option is sometimes called the "driver does its own mapping" option.

Thus, a driver in SDA operating under the System Map may need to access a buffer in a User Map for two reasons. The first reason is to access a second buffer located in the user program. The second is when an "M" option driver must process an I/O request with the request buffer, and possibly a second buffer, located in the user program. In either case, the driver can use the \$XDMP subroutine to reload the User Map to describe the appropriate program.

The procedure for using \$XDMP is as follows: The driver first saves the current contents of the User Map registers, and then calls \$XDMP to reload the User Map to describe the desired program. The driver can then use a series of cross-map loads and stores to access the buffer described by the User Map. Note that the User Map should not be enabled since drivers in SDA are not necessarily included in all users' maps. After all accesses have been made, the driver restores the original state of the User Map registers before continuing with its normal processing.

The following example shows how an SDA driver operating under the System Map might use the \$XDMP subroutine to access a buffer in a user program.

|                               | EXT \$XDMP                                       |                                                                                                                                                           |
|-------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               |                                                  | Normal SDA driver processing under System Map                                                                                                             |
|                               | LDA MAPAD<br>IOR SIGN<br>USA                     | Set A = address of User Map storage area<br>Set sign bit indicating STORE Map in memory<br>Save current User Map in memory for later                      |
|                               | LDA IDADR<br>JSB \$XDMP<br>SZA, RSS<br>JMP ERROR | Get ID address of program that contains buffer<br>Call \$XDMP to set up User Map for this program<br>Check for error return<br>Error exists, go handle it |
|                               | •                                                | No errors. Access buffer via series of<br>cross-map loads and stores, since System<br>Map is still enabled                                                |
|                               | LDA MAPAD<br>USA                                 | Access address of User Map storage area<br>Restore original contents of User Map                                                                          |
|                               |                                                  | Proceed with normal processing under System Map                                                                                                           |
| MAPAD<br>MAP<br>SIGN<br>IDADR | DEF MAP<br>BSS 32<br>OCT 100000<br>BSS 1         | Address of User Map storage area User map storage area Storage for ID segment address                                                                     |

Remember that the driver using this routine must save the current contents of the User Map registers before calling \$XDMP, and must restore the registers to their original value after all accesses have been made to the buffer. The example above illustrates this procedure.

#### NOTE

Before a standard driver in SDA is entered to process an I/O request, the system automatically reloads the User Map registers to describe the requesting program if the I/O buffer is located in the program. This is done regardless of whether the driver is entered under the System Map or the User Map. Thus, if the driver is entered under the System Map, and if the buffer that the driver wishes to access is located within the calling program, some processing time can be saved by not calling \$XDMP to reload the User Map registers. A call to \$XDMP is not needed in this case since the system has already reloaded the User Map registers with the correct information. The driver must still access the buffer via cross-map loads and stores however.

# 3-14. SAMPLE STANDARD RTE DRIVER

The sample driver illustrated in Figure 3-5 demonstrates some of the principles involved in writing a standard I/O driver for the RTE operating system. Note that this driver is for tutorial purposes only and is not one of the drivers supplied with the system.

```
PAGE 0002 #01 ** STANDARD RTE DRIVER EXAMPLE **
0001
                    ASMB , L
0003
     00000
                          NAM BYR70
                                      ** STANDARD RIE DRIVER EXAMPLE **
0004*
0005*
0006
                          ENT 1.70, C.70
0007*
0008*
0009* DRIVER 70 OPERATES UNDER THE CONTROL OF THE 1/0 CONTROL (100)
0010* AND THE CENTRAL INTERRUPT CONTROL (CIC) MODULES OF RTE.
0011* THIS DRIVER IS RESPONSIBLE FOR CONTROLLING OUTPUT
0012* TRANSMISSION TO A 16 BIT EXTERNAL DEVICE.
0013* I.70 IS THE ENTRY POINT FOR THE *INITIATION* SECTION
0014* AND C.70 IS THE ENTRY POINT FOR THE *CONTINUATION/COMPLETION*
0015* SECTION.
0017* NOTE THAT THIS DRIVER DOES NOT PROCESS TIME-OUTS OR
0018* POWER FAIL.
                   THESE PROCEDURES ARE LEFT ENTIRELY UP TO
0019* THE SYSTEM.
0020*
0021* REMEMBER THAT RTE SETS THE ADDRESSES OF EACH WORD OF
0022* THE 15 WORD EQT ENTRY FOR THE DEVICE BEING SERVICED INTO
0023* THE BASE PAGE COMMUNICATIONS AREA ON EACH ENTRY TO THE
0024* DRIVER
0025* THIS DRIVER REFERENCES THESE ADDRESSES THROUGH VARIABLES
0026* EQT1 THROUGH EQT15.
0027*
```

Figure 3-4. Standard RTE Driver Example

```
0028* ************
0029* * INITIATION SECTION *
0030* *************
0031*
0032* THE INITIATION SECTION IS CALLED FROM 1/0 CONTROL (10C) TO
0033* INITIALIZE A DEVICE AND INITIATE AN OUTPUT OPERATION
0034*
0035* THE CALLING SEQUENCE FOR THE INITIATION SECTION IS:
0036*
                   (SET A = SELECT CODE OF I/O DEVICE)
0037*
              P
                  JSB I.70
0038*
              P+1 (RETURN POINT)
0039*
0040*
              ON RETURN, A REGISTER INDICATES STATUS, AS FOLLOWS:
0041*
0042*
0043*
                    A = 0,
                            OPERATION SUCCESSFULLY INITIATED
                    A NOT O, OPERATION REJECTED FOR THE FOLLOWING
0044*
0045*
                             REASON:
0046*
                             A = 1 = ILLEGAL READ REQUEST
0047*
                             A = 2 = ILLEGAL CONTROL REQUEST
0048*
0049*
0050* (NOTE, HOWEVER, THAT A "CLEAR" CONTROL REQUEST FROM THE
0051* SYSTEM WILL BE PROCESSED BY THE DRIVER, AS REQUIRED.)
0052*
0053* *******************
0054* * CONTINUATION/COMPLETION SECTION *
0055* *******************
0056*
0057* THE CONTINUATION/COMPLETION SECTION IS CALLED BY CENTRAL
 PAGE 0003 #01 ** STANDARD RTE DRIVER EXAMPLE **
0058* INTERRUPT CONTROL (CIC) TO CONTINUE OR COMPLETE AN OPERATION WHEN
>059 * AN INTERRUPT IS DETECTED ON THE DEVICE
0060*
0461* THE CALLING SEQUENCE FOR THE COMPLETION SECTION IS:
0062*
0063*
                   (SET A = SELECT CODE OF I/O DEVICE)
0064*
             Ρ
                   JSB C.70
             P+1 COMPLETION RETURN
0065*
0066*
             P+2 CONTINUATION RETURN
0067*
*8300
              ON RETURN, A & B REGISTERS INDICATE STATUS, AS FOLLOWS:
0069*
0070*
                    ON A COMPLETION RETURN:
0071 *
                    A = 0, SUCCESSFUL COMPLETION, WITH
0072*
0073*
                           B = NUMBER OF WORDS TRANSMITTED
0074*
0075*
                    A = 2, TRANSMISSION ERROR DETECTED
0076*
0077*
                    ON A CONTINUATION RETURN, THE REGISTERS ARE
0078*
                    MEANINGLESS
0079*
0080* RECORD FORMAT:
0081*
0082*
          THIS DRIVER PROVIDES A 16 BIT BINARY WORD
0083*
          TRANSFER ONLY.
0084*
```

Figure 3-4. Standard RTE Driver Example (Continued)

```
PAGE 0004 #01 ** STANDARD DRIVER - INITIATION SECTION **
0086*
3087*
0088*
                          * INITIATION SECTION *
0089*
0090*
0091
     00000 000000 I.70 NOP
                                        ENTRY FROM IOC
0092*
                          JSB SETIO
                                        CONFIGURE I/O INSTRUCTIONS FOR DEVICE
0093 00001 016100R
0094*
                                        GET CONTROL WORD OF REQUEST, AND
                          LDA EQT6,I
0095 00002 161665
0096 00003 012115R
                          AND = 83
                                        ISOLATE THE REQUEST TYPE
00974
                                        IF REQUEST IS FOR INPUT
0098 00004 052116R
                          CPA =B1
                          JMP I.70,1
0099 00005 126000R
                                        THEN REJECT IT (A = 1 = ILLEGAL READ)
                                        IF REQUEST IS FOR OUTPUT
0100 00006 052117R
                          CPA = 82
0101
      00007 026017R
                          JMP D.X1
                                        THEN GO PROCESS WRITE REQUEST
0102*
0103* CONTROL REQUEST CHECK IF IT IS A "CLEAR" CONTROL REQUEST
0104* IF SO, ASSUME IT WAS ISSUED BY SYSTEM, CLEAR DEVICE, AND RETURN
0105*
0106 00010 161665
                          LDA EQT6, I
                                        ACCESS CONTROL WORD
     00011 012120R
                          AND =83700
                                        ISOLATE SUBFUNCTION
0107
0108
     00012 002002
                          SZA
                                        "CLEAR" REQUEST?
0109
                          JMP REJCT
                                        NO, SO REJECT REQUEST AS ILLEGAL
     - 00013 026015R
0110*
0111 00014 106700 I.O
                         CLC SC
                                        YES, CLEAR DEVICE AND RETURN
0112*
0113* REQUEST ERROR - CAUSE REJECT RETURN TO IOC
0114*
     00015 062117R REJCT LDA = 82
                                        SET A = 2 FOR ILLEGAL CONTROL REQUEST
0115
                          JMP 1 70,1
                                        AND RETURN (A = 2 = ILLEGAL CONT. REQ.)
0116
      00016 126000R
0117*
0118* WRITE REQUEST PROCESSING
0119*
                                        GET REQUEST BUFFER ADDRESS
      00017 161666 D.X1 LDA EQT7,I
0120
                                         AND SET IT AS CURRENT ADDRESS
0121
      00020 171670
                          STA EQT9,I
      00021 161667
                          LDA EQT8,I
                                         GET REQUEST BUFFER LENGTH
0122
      00022 003004
                                         MAKE HEGATIVE AND
0123
                          CMA, INA
                          STA EQTIO, I
     00023 171671
                                         AND SAVE AS REMAINING BUFFER LENGTH
0124
     00024 002002
0125
                          SZA
                                         IS BUFFER LENGTH = 0?
9126
      00025 026031R
                           JMP D.X3
                                         NO, PROCESS AS USUAL
                                         YES, SO MAKE IMMEDIATE COMPLETION RETURN
      00026 062121R
                          LDA =B4
0127
0128
      00027 006400
                           CLB
                                         SET TRANSMISSION LOG = 0 INTO B
                           JMP I 70,I
                                         AND RETURN (A = 4 = IMMED. COMPLETION)
0129
      00030 126000R
0130*
0131* CALL THE CONTINUATION/COMPLETION SECTION TO WRITE FIRST WORD
0132*
                                         ADJUST RETURN ADDRESS SO WILL
0133
      00031 062114R D.X3 LDA P2
0134
      00032 072036R
                           STA C.70
                                         RETURN HERE (INITIATION SECTION)
0135
      00033 026047R
                           JMP D.X2
                                         GO TO COMPLETION SECTION
0136*
     00034 002400 IEXIT CLA
                                         NOW RETURN TO IOC WITH
0137
5138
      00035 126000R
                           JMP I .70,I
                                         OPERATION INITIATED (A = 0 = 0K)
0139*
```

Figure 3-5. Standard RTE Driver Example (Continued)

```
PAGE 0005 #01 ** STANDARD DRIVER - CONTINUATION/COMPLETION SECTION **
0141*
1142*
0143*
                          * CONTINUATION/COMPLETION SECTION *
0144*
                          0145 *
0146
     00036 000000 C.70 NOP
                                        CONTINUATION/COMPLETION ENTRY POINT
0147*
0148
     00037 016100R
                          JSB SETIO
                                        CONFIGURE I/O INSTRUCTIONS
0149*
                                        CHECK FOR SPURIOUS INTERRUPT
0150
     00040 161660
                          LDA EQTI,I
0151
      00041 012122R
                          AND = B77777
                                        ISOLATE I/O REQUEST LIST PTR (15 BITS)
      00042 002002
                                        IS A REQUEST IN PROGRESS?
0152
                          SZA
      00043 026047R
                          JMP D.X2
                                        YES, GO PROCESS REQUEST
0153
0154*
                                        NO, SPURIOUS INTERRUPT-ZERO TIME-OUT CLK
0155
     00044 171774
                          STA EQT15, I
     00045 036036R
                                        ADJUST RETURN TO P+2 (CONTINUATION)
0156
                          ISZ C.70
0157
      00046 126036R
                          JMP C.70,I
                                        MAKE CONTINUATION RETURN TO CIC
0158*
0159
      00047 002400 D.X2 CLA
                                        IF CURRENT BUFFER LENGTH = 0,
0160
      00050 151671
                          CPA EQT10, I
                                        THEN GO TO STATUS
                                        SECTION. (I.E., TRANSFER DONE NOW)
0161
      00051 026063R
                          JMP I.3
0162*
                                        GET CURRENT BUFFER ADDRESS
0163 00052 165670
                          LDB EQT9,I
0164*
0165 00053 135670
                          ISZ EQT9,I
                                        ADD 1 FOR NEXT WORD
0166
      00054 160001
                          LDA B.I
                                        GET WORD TO BE WRITTEN TO DEVICE
      00055 135671
                                        INCREMENT WORD COUNT ALSO
0167
                          ISZ EQTIO, I
                                        IGNORE P+1 SKIP IF LAST WORD
0168
      00056 000000
                          NOP
0169*
      00057 102600 I.1
0170
                          OTA SC
                                        OUTPUT WORD TO INTERFACE
0171
      00060 103700 I/2
                          STC SC.C
                                        TURN DEVICE ON
0172*
0173
      00061 036036R
                          ISZ C.70
                                        ADJUST RETURN TO P+2 (CONTINUATION)
0174 00062 126036R
                          JMP C.70,I
                                        MAKE CONTINUATION RETURN
0175*
0176* STATUS AND COMPLETION SECTION
0177*
      00063 102500 I.3
0178
                                        GET STATUS WORD FROM DEVICE
                          LIA SC
0179
      00064 012123R
                          AND =877
                                         STRIP OFF UNUSED BITS
0180
      00065 070001
                           STA B
                                         SAVE IN B TEMPORARILY
      00066 161664
0181
                          LDA EQT5,I
                                         REMOVE PREVIOUS STATUS
0182
      00067 012124R
                           AND = B177400
                                        BITS IN EQT WORD 5
0183
      00070 030001
                           IOR B
                                         OR IN NEW BITS
      00071 171664
                           STA EQTS, I
0184
                                         AND RESET INTO EQT WORD 5
0185*
0186
      00072 002400
                           CLA
                                         SET A = 0 = OK RETURN CODE
0187
      00073 056121R
                           CPB = B4
                                         ERROR STATUS BIT ON?
0188
      00074 062117R
                          LDA =B2
                                         YES, SET A = 2 = ERROR RETURN
0189*
0190 00075 165667
                           LOB EQTS,I
                                         SET B = TRANSMISSION LOG
0191*
0192 00076 106700 I.4
                           CLC SC
                                         CLEAR DEVICE CONTROLLER
1193*
0194 00077 126036R
                                         MAKE COMPLETION RETURN TO CIC
                           JMP C.70,I
0195*
```

Figure 3-5. Standard RTE Driver Example (Continued)

```
PAGE 0006 #01 ** STANDARD DRIVER - SUBROUTINE SETIO **
0197*
1198*
0199*
                         * SUBROUTINE SETIO *
0200*
                         ***********
0201*
0202* SUBROUTINE (SETIO) CONFIGURES ALL I/O INSTRUCTIONS IN DRIVER
0203*
0204 00100 000000 SETIO NOP
                                       ENTRY POINT
0205*
0206 00101 032113R
                         IOR LIA
                                       COMBINE LIA WITH 1/0
0207 00102 072063R
                                       SELECT CODE AND SET IN CODE
                         STA I.3
0208*
0209 00103 042125R
                         ADA = B100
                                       CONSTRUCT OTA INSTRUCTION
0210 00104 072057R
                         STA I.1
0211*
0212 00105 042126R
                         ADA = 81100
                                       CONSTRUCT STC.C INSTRUCTION
0213 00106 072060R
                         STA I.2
0214*
0215 00107 022127R
                                       CONSTRUCT CLC INSTRUCTION
                         XOR = B5000
                         STA I.0
0216 00110 072014R
0217 00111 072076R
                         STA I.4
0218*
                        JMP SETIO, I
0219 00112 126100R
                                       RETURN
0220*
```

Figure 3-5. Standard RTE Driver Example (Continued)

```
PAGE 0007 #01 ** STANDARD DRIVER - DATA AREA **
Q222*
)223*
0224*
                           * DATA AREA *
0225*
0226*
0227* CONSTANT AND STORAGE AREA
0228*
      00000
                           EQU 0
0229
                                         A-REGISTER
0230
      00001
                    8
                          EQU 1
                                         B-REGISTER
0231*
0232
      00000
                    SC
                           EQU 0
                                         DUMMY I/O SELECT CODE HUMBER
0233
     00113 102500 LIA
                          LIA 0
                                         CODE FOR LIA INSTRUCTION
                          DEF IEXIT-1
0234
     00114 000033R P2
                                         RETURN POINT IN INITIATION SECTION
0235*
0236* ** BASE PAGE COMMUNICATIONS AREA DEFINITIONS **
0237*
0238 01650
                           EQU 16508
0239*
0240 01660
                    EQT1
                          EQU .+8
0241
      01661
                    EQT2
                          EQU .+9
                           EQU .+10
0242
      01662
                    EQT3
0243
      01663
                    EQT4
                           EQU .+11
0244
      01664
                    EQT5
                          EQU .+12
0245
      01665
                    EQT6
                          EQU .+13
0246
      01666
                    EQT?
                          EQU .+14
$247
      01667
                    EQT8
                          EQU .+15
                              . +16
0248
      01670
                    EQT9
                          EBN
0249
      01671
                    EQT10 EQU .+17
                    EQT11 EQU .+18
0250
      01672
0251
      01771
                    EQT12 EQU .+81
0252
      01772
                    EQT13 EQU .+82
0253
      01773
                    EQT14 EQU .+83
0254
      01774
                    EQT15 EQU .+84
0255*
0256*
      00115 000003
      00116 000001
      00117 000002
      00120 003700
      00121 000004
      00122 077777
      00123 000077
      00124 177400
      00125 000100
      00126 001100
      00127 005000
0257
                           END)
** NO ERRORS *TOTAL **RTE ASMB 760924**
```

Figure 3-5. Standard RTE Driver Example (Continued)

# WRITING PRIVILEGED RTE DRIVERS

SECTION

IV

# 4-1. INTRODUCTION

Peripheral devices that are synchronous in nature, or that generate interrupts at very high rates, need special attention in an RTE system. Such devices cannot be controlled by standard RTE drivers on a word-by-word transfer basis, because this method cannot guarantee that the interrupts generated by such device controllers will be processed within the required response time. There are two reasons why the response time may be exceeded:

- 1. An interrupt is not recognized immediately by RTE if the interrupt system is disabled at the time the interrupt occurs. For example, this happens if the interrupt occurs while a standard driver is processing a previous interrupt, or while RTE itself is executing.
- 2. Once an interrupt is recognized, the system overhead required to direct the interrupt to the appropriate driver for processing may be too long.

One way to guarantee a fast interrupt response time is to utilize DCPC transfers for synchronous and high speed devices. The special DCPC hardware allows the transfer to occur simultaneously with other RTE operations, thereby eliminating the above problems.

However, DCPC transfers do not allow the driver to perform any processing that might be required on each data word as it is transferred. For example, it might be necessary to check a parity bit on each word as it is received from the device. Thus, a special interrupt processing method is needed for any high speed or synchronous device that requires driver interaction on each data word transferred. This interrupt processing method must have the following properties:

- a. The ability to recognize interrupts immediately, regardless of what other RTE operation is in progress.
- b. A means to eliminate the system overhead associated with processing an interrupt.
- c. Driver interaction on each data word transferred.

Privileged interrupt processing was specifically designed to meet these criteria. This method requires that a special I/O card, known as the Privileged Interrupt card, be present in the system. The Privileged Interrupt card is inserted in the computer such that it physically separates the I/O cards into two groups. All devices whose I/O cards are in lower-numbered (i.e., higher priority) select codes are known as privileged devices; these are the high speed and synchronous devices that require driver interaction on each word transferred. The I/O cards of all other devices in the system are placed in higher-numbered (i.e., lower priority) select codes and are known as non-privileged devices.

Systems with Privileged Interrupt cards are referred to as privileged systems, and a special type of RTE driver (known as a privileged driver) is required for each privileged controller present in the system. Standard RTE drivers are used for the remaining non-privileged devices.

The Privileged Interrupt card can be any standard I/O card that contains the normal control and flag flip-flop circuitry. Because of the position of the Privileged Interrupt card in the I/O priority chain, setting of the control flip-flop on the card holds off all interrupts from the non-privileged device controllers, while at the same time allowing the privileged device controllers to interrupt.

When a Privileged Interrupt card is present in the system and a non-privileged interrupt occurs (or when the system is requested to perform some function via an EXEC call or operator request), RTE performs the following functions before entering the standard driver (or system routine) to process the interrupt:

- a. Disables the interrupt system and saves the state of the machine.
- b. Sets the control flip-flop on the Privileged Interrupt card to hold off any further non-privileged interrupts.
- c. Disables the DCPC completion interrupts. These interrupts are not held off by the Privileged Interrupt card since the DCPC completion interrupts occur on the highest priority select codes (6 and 7).
- d. Reenables the interrupt system and enters the driver to process the interrupt.

The above means that a privileged system processes standard (i.e., non-privileged) interrupts and requests for system functions with the interrupt system in a hold-off state, rather than with the interrupt system disabled (as it does in non-privileged systems). The privileged interrupts are always enabled and can interrupt any process taking place and be serviced almost immediately.

When servicing of the non-privileged interrupt is completed, RTE clears the control flip-flop on the Privileged Interrupt card and reenables the DCPC completion interrupts if they are needed by the standard driver using DCPC. This returns the system to a state where any interrupt (privileged or non-privileged) can occur and be recognized almost immediately.

To eliminate the system overhead associated with processing interrupts, the contents of the interrupt trap cells for the privileged device controllers are changed from a JSB LINK,I instruction (where LINK contains the address of the entry point to CIC), to a JSB \$JPNN,I instruction (where \$JPNN contains the address of the entry point of the privileged interrupt routine). When a privileged interrupt occurs, the privileged routine is entered directly, rather than from CIC. This eliminates the system overhead. The tradeoff is that the privileged driver must be somewhat more complex than a standard driver, since it must perform some of the housekeeping duties normally handled by CIC.

RTE records a system as privileged by storing at generation time (or, for RTE-IV, at reconfiguration time) the I/O select code address of the Privileged Interrupt card in Base Page Communications Area word DUMMY. Systems without a Privileged Interrupt card have a zero in base page word DUMMY.

In general, privileged drivers are very similar to standard drivers; thus most of the material presented in Section III for standard drivers also applies to privileged drivers. Since only the differences are pointed out in this section, the reader should be familiar with the material presented in Section III before continuing with the privileged driver considerations described below.

# 4-2. GENERAL PRIVILEGED DRIVER STRUCTURE AND OPERATION

Privileged drivers are responsible for the initiation, continuation, and completion of all I/O requests for privileged devices. Since privileged drivers operate independently of RTE, there are several additional requirements and restrictions that must be followed to ensure the integrity of the operating system and the proper operation of the driver. These restrictions and requirements are described in subsequent subsections.

Privileged drivers are generally designed in three sections: 1) an initiation section, 2) a privileged section, and 3) a completion section. The driver must have a name in the form **DVynn**, and the initiation and completion entry points must have names in the forms **Lxnn** and **Cxnn** respectively. The rules for the choice of "x," "y" and "nn" are the same as those given previously for standard drivers. There are no special rules for the entry point name of the privileged section. For consistency with **Lxnn** and **Cxnn**, it is suggested that a name such as **Pxnn** be chosen, where "x" and "nn" agree with the characters chosen for **Lxnn** and **Cxnn**.

IOC calls the initiation section of a privileged driver when an I/O request for a privileged device is made. This call has the same format as the call to the initiation section of a standard driver (see Section III of this manual).

The privileged section of a privileged driver is somewhat similar to the continuation section of a standard driver. The privileged section is entered on each interrupt from the privileged device controller and is responsible for reading or writing the next data word and restarting the device. Since the privileged section is entered directly from the trap cell on interrupt (rather than from CIC), it must save and restore the state of the computer on entry and exit. (These tasks are performed by CIC for standard drivers.)

The completion section of a privileged driver has an entry point named Cxnn, and is responsible for returning to RTE when the I/O transfer is complete.

The overall operation of a privileged I/O request from initiation to completion is summarized below:

- a. The privileged driver is called by a standard EXEC I/O call.
- b. If the request is being made by a user program and the call is not buffered, the calling program is placed into I/O suspension.
- c. The interrupt trap cell for the privileged device controller is changed by the privileged driver from a JSB LINK,I instruction (where LINK contains the address of the entry point to CIC) to a JSB \$JPNN,I instruction (where \$JPNN contains the address of the privileged section entry point, **P**xnn).
- d. Each time the device controller interrupts, the system overhead is circumvented because the privileged section **P***xnn* is entered directly.
- e. After each interrupt, if another data transfer is still required to satisfy the buffer length, the device controller is restarted and the privileged section is exited.
- f. When the entire data buffer has been filled, the driver needs a way to inform RTE that the

transfer is complete. This is accomplished by allowing the driver to time-out, which causes IOC to reenter the driver at *Cxnn*.

- g. **C**xnn returns the transmission log (via the B-register) and a successful completion indication (via the A-register) to IOC.
- h. IOC then reschedules the program that made the I/O request.

# 4-3. INITIATION SECTION

The initiation section of a privileged driver performs the functions listed below. The list is similar to the one given earlier for standard drivers with the exception that no DCPC processing can be done by privileged drivers. (See the "Privileged Driver Design Considerations" subsection of this manual.)

- a. Checks for power fail/automatic restart entry by examining bit 15 of EQT entry word 5, which is set to 1 only on this type of entry. If bit 15 is set, the appropriate power fail/automatic restart processing should be done. This check need only be made by drivers that are designed to process power fail interrupts (as described in the "Power Fail Processing" subsection of this manual).
- b. Configures all I/O instructions in the driver to reference the specific I/O select code of the device controller. This step is done only on the first entry to the driver since there is one privileged driver for each privileged device controller in the system. (See the "Privileged Driver Design Considerations" subsection of this manual.)
- c. Clears bit 12 in EQT entry word 4 if time-outs are to be handled by the system. This bit will be reset to 1 by the privileged section when it sets up to complete the call.
- d. Rejects the request and follows the procedure described in step "f" if:
  - 1. A status check of the device or controller indicates that it is inoperable, or
  - 2. The request code or other parameters are illegal.
- e. Initializes software flags and activates the device controller. All variable information pertinent to the transmission can be saved in the EQT entry associated with the controller, providing that the driver saves the addresses of the EQT entry internally in the driver itself at initiation. These addresses are not available on base page on subsequent entries to the driver. (See the "Privileged Driver Design Considerations" subsection of this manual.)
- f. Returns to IOC (via **JMP L**xnn, **I**) with the A-register set to indicate initiation or rejection (and the cause of the rejection) as follows:
  - If A = 0 the operation was initiated successfully.
  - If A = 1,2,3 the operation was rejected, where:
    - 1 = read or write illegal for device
    - 2 = control request illegal or undefined,
    - 3 = equipment malfunction or not ready

If A = 4 the operation was immediately completed. This means that the driver was able to completely satisfy the request without the need of a subsequent interrupt and that the program making the I/O call can be rescheduled immediately. The B-register should be set to the number of words or characters (depending upon which the user specified) transferred. This value is known as the transmission log.

If A = 5 this return must NOT be used by privileged drivers.

If A=6-99 the program making the I/O request is aborted (unless the no-abort bit was set in the call) and an I/O error message is printed on the system console. (Note that this return can be used for unbuffered I/O requests only. This therefore excludes the use of return codes 6 through 99 on any Class, buffered or system I/O request.) The error message has the following format:

IOxx yyyyy NNNNN ABORTED

where: xx = the return code from the driver (decimal 06 to decimal

yyyyy = the address of the aborted I/O request in program NNNNN, and

NNNNN = the name of the program that made the I/O request.

This type of return can be used by drivers to generate their own I/O error messages at the system console. Note that certain codes are reserved for system use, as follows:

| Return Code | Reserved for                  |  |  |
|-------------|-------------------------------|--|--|
| 6 - 59      | HP system modules and drivers |  |  |
| 60 - 99     | user written drivers          |  |  |

Before returning to IOC, the initiation section modifies the trap cell for the privileged device controller to contain a JSB \$JPNN,I instruction, where \$JPNN contains the address of the privileged section entry point **P**xnn. This causes all interrupts from the privileged device controller to be directed immediately to the privileged section of the driver. The driver needs to perform this step only once since the contents of the trap cell are not modified by any other program or system routine.

In setting up the trap cell, the driver must be sure that it is operating with the System Map enabled so that it has access to the trap cells. This can be ensured by having the calling program reference a buffer in SYSTEM COMMON when making the I/O request to the driver. (See the "Communication with User Programs" subsection later in this manual.)

An alternative method of setting up the trap cell is to point the trap cell directly at the privileged section entry point when the system is generated. This is done by entering

sc,ENT,Pxnn (where "sc" is the select code of the privileged controller) during the Interrupt Table definition phase of the generation. When the generator detects an entry of this form it places a JSB \$JPNN,I instruction (where \$JPNN contains the address of Pxnn) into the appropriate interrupt trap cell. The generator also places a zero in the corresponding Interrupt Table entry to indicate that interrupts on the select code are not handled by RTE. This method requires that the privileged section entry point, Pxnn, be declared as an entry point in the privileged driver (via the ENT pseudo-instruction).

# 4-4. PRIVILEGED SECTION

When a privileged interrupt occurs, the operation currently in progress is suspended, and the privileged section of the driver is entered directly via the JSB \$JPNN,I instruction in the trap cell. In addition to the normal tasks associated with continuing the data transfer, the privileged section is required to perform several housekeeping functions that are normally performed by CIC. This includes saving and restoring the state of the computer on entry and exit and disabling the DCPC completion interrupts so that the driver's operation is not interrupted.

The privileged section of a privileged driver performs the following functions:

- a. Executes the following tasks done by CIC for standard drivers:
  - 1. Disables the entire interrupt system with a CLF 0 instruction so that the driver is not interrupted while performing the housekeeping functions.
  - 2. Disables the DCPC completion interrupts by issuing a CLC 6 instruction and a CLC 7 instruction. The DCPC completion interrupts are associated with I/O select codes 6 and 7, and therefore precede the Privileged Interrupt card in the I/O priority chain. Interrupts from these device controllers are not held off by the Privileged Interrupt card and must be disabled to prevent an interrupt from occurring while the privileged driver is executing.
  - 3. Saves the current contents of all program accessible registers (A,B,E,O, and, if present, X and Y) in a local buffer. These registers must be restored to their original contents before exiting the driver.
  - 4. Saves the previous state of the memory protect fence. When an interrupt occurs, the memory protect fence (if ON) is automatically turned off. The driver can determine the previous state of the memory protect fence (which is the state to which it should be restored after processing the interrupt) by examining Base Page Communications Area word MPTFL. If MPTFL equals zero, memory protect was ON when the privileged interrupt occurred and the privileged section must turn the fence back on before exiting. If MPTFL is non-zero, memory protect was OFF, and the privileged section must not restore the memory protect fence.
  - Sets base page word MPTFL to 1 to indicate that the memory protect fence is now OFF.
  - 6. Saves the status of the Dynamic Mapping System so that it can be restored to its original state before returning to the point of interruption. This is done by executing an SSM instruction. (Applicable to systems with Dynamic Mapping only.)

- 7. Reenables the interrupt system by executing an STF 0 instruction. This allows a higher priority privileged controller (if one exists) to interrupt the driver. All non-privileged interrupts are held off because the flag is still set on the card that caused the privileged interrupt.
- b. Checks whether bits 0 14 of EQT entry word 1 (the controller I/O request list pointer) equal zero. If so, a spurious interrupt has occurred (i.e., no I/O operation was in progress at the time of the interrupt). The driver ignores the interrupt as follows:
  - 1. Disables the interrupt system via a CLF 0 instruction so that the driver is not interrupted while clearing the controller.
  - 2. Clears the control and flag flip-flops on the controller (usually via a CLC DEVIC,C instruction).
  - 3. Proceeds to step "e-3" below to restore the computer to its original state before exiting.
- c. Performs the input or output of the next data item. One of the following three actions is then taken:
  - 1. If the transfer is not complete, the driver follows the procedure described in step "e" below to return to the suspended process at the point of interruption.
  - 2. If the transfer is complete, the driver follows the procedure described in step "d" below to set up for a completion return to IOC.
  - 3. If the driver detects a transmission error, it may reinitiate the transfer and attempt a retransmission. A counter for the number of retry attempts can be kept in the EQT entry. After initiating each retry, the driver follows the procedure described in step "e" below to return to the suspended process at the point of interruption.
- d. Once the transfer is complete, the driver needs a way to indicate this fact to RTE so that the program that made the I/O request can be rescheduled. This is accomplished by letting the driver time-out. To do this, the driver performs the following steps:
  - 1. Disables the interrupt system with a CLF 0 instruction so that no interruptions occur while the time-out is being set up and the computer is being restored to its original state.
  - 2. Turns off the device controller to prevent further interrupts (usually with a CLC instruction).
  - 3. Sets the time-out clock (EQT entry word 15) to −1 to cause a time-out of the privileged device controller at the next tick of the real time clock. This will cause the completion section of the driver to be entered from IOC so that a normal completion return can be made to RTE.
  - 4. Sets the "driver processes time-out" bit in EQT entry word 4 to one so that the driver will be reentered when the time-out occurs.
  - 5. Follows the procedure described in step "e-3" below to restore the computer to its original state before exiting.

- e. Before returning to the point of interruption, the privileged section performs the following steps to restore the computer to its original state upon entry:
  - 1. Disables the interrupt system so that no interruptions occur while the computer is being restored to its original state.
  - 2. Encodes the device controller to initiate the next data transfer, usually via a STC DEVIC,C instruction. Note that the device controller must not be encoded until the interrupt system is disabled and the driver is about to return to the point of interruption. If the device controller were encoded earlier, the driver might be reentered at Pxnn by the next interrupt before completely servicing the previous interrupt. Clearing of the flag on the privileged device controller's I/O card will also reallow any lower priority interrupts to be recognized by the system when the interrupt system is reenabled.
  - 3. Checks to see if either of the DCPC completion interrupts needs to be reenabled, as follows:

If the memory protect fence was initially OFF, the driver must not reenable the DCPC completion interrupts. If the memory protect fence was initially OFF, the privileged driver interrupted the operation of the system or another privileged driver. These routines operate with the DCPC completion interrupts disabled and assume that the completion interrupts will remain disabled if they are interrupted.

If the memory protect fence was initially ON, the DCPC completion interrupts are turned back on only if the standard driver currently using the DCPC channel needs the interrupt. Standard drivers that need the DCPC completion interrupt set bit 15 of the appropriate DCPC Assignment Control Word (in the Interrupt Table) to 1 as a flag. (See the "DCPC Processing" subsection earlier in this manual.) If bit 15 is set, a privileged driver must reenable the appropriate DCPC completion interrupt by issuing a STC 6 or STC 7 instruction. If bit 15 is not set, the privileged driver must not reenable the interrupt.

- 4. Restores all saved registers to their original values.
- 5. Restores base page word MPTFL to its original value. (This word is used to indicate the current status (ON/OFF) of the memory protect fence).
- 6. Turns the interrupt system back on via a STF 0 instruction to allow other interrupts to occur.
- 7. Turns the memory protect fence back on via a STC 5 instruction if the fence was ON initially.
- 8. Performs one of the following actions depending on whether or not the system includes the Dynamic Mapping feature:
  - i. Restores the Dynamic Mapping System to its original value at interrupt and returns to the suspended process at the point of interruption by executing a jump and restore status (JRS) instruction indirect through the entry point **Pxnn**. (Performed only in systems with the Dynamic Mapping feature.)

ii. Returns to the suspended process at the point of interruption via a jump indirect through the entry point **P**xnn. (Performed only in systems without the Dynamic Mapping feature.)

#### NOTE

If the memory protect fence was turned on in step 7, execution of the JRS instruction (in step 8) to restore DMS status can only be performed if the System Map is currently enabled. An attempt to execute it with the User Map enabled will result in a DMS violation. Thus, if the driver switches to operation under the User Map for any reason, the System Map must be reenabled before executing the JRS instruction. The explanation of map switching given in the "Subroutines for Special Mapping Functions" subsection of this manual illustrates this procedure.



#### 4-5. COMPLETION SECTION

When the time-out set up by the privileged section occurs, IOC enters the continuation section of the privileged driver at entry point Cxnn. The continuation section sets the A-register equal to the appropriate completion code and the B-register equal to the transmission log. It then returns to IOC via a jump indirect through the entry point Cxnn (JMP Cxnn, I). The return point (P+1) and allowable completion codes (0-4) are the same as those described earlier for the completion section of a standard driver.

#### 4-6. PRIVILEGED DRIVER DESIGN CONSIDERATIONS

Privileged drivers operate independently of RTE. In fact, the operation of the RTE operating system itself may be suspended while a privileged interrupt is being serviced. As a result, the writer of a privileged driver must adhere to the following design requirements:

- a. Privileged drivers must not use any of the features or request calls of RTE. Calling a system process might involve entering RTE while it is processing another request. This cannot be allowed because RTE is not reentrant.
- b. Privileged drivers cannot use either DCPC channel because it is very difficult to coordinate the use of DCPC with the operating system and other drivers that may be using DCPC.
- c. If a privileged driver wishes to use the EQT entry for temporary storage, the initiation section must read the EQT entry addresses from the Base Page Communications Area and save them internally in the driver. These addresses are not available in base page on subsequent interrupts since the privileged driver is entered directly from the trap cell instead of from CIC. (CIC is the module that places these addresses into the base page before calling a standard RTE driver to process an interrupt.)
- d. Since privileged drivers are required to keep information relating to the I/O request internally (see "c" above), a separate privileged driver is required for each privileged

device controller present in the system. For each additional controller of the same type, an additional copy of the privileged driver must be generated into the system. Each copy of the driver must have unique names for **DVynn**, **Ixnn**, **Pxnn**, and **Cxnn**.

# 4-7. COMMUNICATION WITH USER PROGRAMS (DMS SYSTEMS ONLY)

Privileged drivers are automatically entered with the System Map enabled when a privileged interrupt occurs. If the I/O request buffer for the privileged call is located in a user program, the driver will have to switch maps before it can access the buffer. Any privileged driver in a DMS system should therefore be designed for user communication through SYSTEM COMMON or the Subsystem Global Area (SSGA) to avoid the overhead of map switching. These areas can be specified at generation to be included in both the System Map and User Map, and hence can be accessed directly by both user programs and privileged drivers without any map switching.

Otherwise, if the I/O request buffer is located in a user program, some map switching will have to be done before the privileged driver can access the buffer. This map switching procedure is described in detail in the "Subroutines for Special Mapping Functions" subsections of this manual.

### 4-8. DISCUSSION OF SAMPLE DMS PRIVILEGED DRIVER

The following discussion describes Figure 4-1, an example of a privileged driver written specifically for use in a system with the Dynamic Mapping feature. (Figure 4-2 shows a similar driver written specifically for a system that does not include the Dynamic Mapping feature.) For the purposes of the discussion, this driver has been given the generalized name of DVYNN.

The device controller transfers one word of data each time it interrupts, and the data is stored in a buffer passed to the driver via the call parameters. Note that the design of the DMS privileged driver assumes that the I/O request buffer is located in SYSTEM COMMON for two reasons: 1) it ensures that the driver's initiation section is entered with the System Map enabled. This is necessary for the proper operation of the trap cell modification technique used in that section; 2), it allows the driver to place data values directly in the I/O request buffer without any map switching.

Note that the driver does not process power fail interrupts nor does it process any time-outs, except for the time-out it creates as a means to complete the I/O request and return to IOC.

### INITIATION SECTION

Refer to the partial listing of the sample privileged driver in Figure 4-1 (or 4-2). A standard I/O call to input from the device causes the calling program to be I/O suspended and the driver to be entered at **Ixnn**.

Since this driver can control just one device controller, there is no need to configure the I/O instructions more than once. Therefore, the driver is configured the first time it is entered, and

the switch at "FIRST" is set so that the configuration code is not executed on any subsequent entry to the driver. The initiation section also saves the addresses of those EQT entry words that will be used by the privileged section since these addresses will not be available in base page on subsequent interrupts.

The modification of the trap cell is also performed just once (as part of the configuring routine) and is not modified again on any later entries into the initiation section. The trap cell is altered so that the device controller interrupts are channelled to the privileged section of the driver (**Pxnn**) instead of to CIC. The JSB \$JPNN,I instruction (where \$JPNN contains the address of **Pxnn**) is established by coding a JSB instruction on the base page (see listing).

The request code is checked for validity. All write requests and control requests (except a "clear" control request from the system) are rejected. For read requests, a counter is established for the number of readings to be taken, and the buffer address for the storage of the data is saved. The "driver processes time-out" bit in EQT entry word 4 is cleared so that any unexpected time-outs are handled by the system. This bit is later reset to 1 by the privileged section when it sets up a time-out as a means of returning to IOC at the end of the I/O request. Finally, the initiation section sets up and encodes the device controller to begin a read operation and returns to IOC.

#### PRIVILEGED SECTION

When the device controller interrupts, the privileged section (Pxnn) is entered directly as a result of the controller's trap cell modification.

Because entry is made directly into **Pxnn**, **Pxnn** must do the housekeeping that is normally done by CIC when a standard interrupt occurs. Thus, before **Pxnn** can turn the interrupt system back on to allow higher priority privileged interrupts to be recognized, **Pxnn** must ensure that the DCPC channels cannot interrupt, save the user-programmable registers, save the old memory protect status, and set its new status. For systems with Dynamic Mapping, **Pxnn** must also save the Dynamic Mapping System status at the time of interrupt.

**Pxnn** then loads and stores the data in the next unfilled buffer word. If there is yet another data point to be taken, **Pxnn** sets up the device controller for the next reading, disables the interrupt system, encodes the device controller, restores memory protect status and its flag, restores the user programmable registers, turns the interrupt system back on, and exits. For systems with Dynamic Mapping, **Pxnn** must also restore the Dynamic Mapping System status to its original value. All of this basically resets the system to its state before **Pxnn** was entered.

When the last reading is taken, **Pxnn** disables the interrupt system, turns off the device controller, and sets up the privileged controller's EQT so that a time-out will occur at the next tick of the real-time clock. **Pxnn** then resets the system to its original state and returns to the suspended process at the point of interruption.

### COMPLETION SECTION

The status of the device controller and the driver is now unchanged until the Time Base Generator (TBG) interrupts. The TBG causes a time-out of the privileged controller (because a -1 was set into EQT entry word 15), which in turn causes IOC to pass control to the completion

section at *Cxnn*. The completion section simply sets the A- and B-registers to the status and transmission log, respectively, and returns to IOC. IOC then reschedules the calling program and initiates any remaining requests for the controller as if it were a standard (non-privileged) controller.

### 4-9. TIME-OUT VALUES FOR PRIVILEGED DRIVERS

If the user wishes to specify a time-out value for the privileged controller (to prevent indefinite suspension in the event that the controller malfunctions), the time-out value must be long enough to cover the entire period from I/O initiation to completion. This is different from the time-out value for a standard driver, which is normally only long enough to cover the expected time between interrupts from the standard device controller.

Each time IOC or CIC enters a standard driver to initiate or continue an I/O request, it resets the time-out clock (EQT entry word 15) to the value specified at generation. However, since privileged drivers are not entered from CIC on interrupt, the time-out value is inserted into the privileged controller's time-out clock only at initiation. If this value is not long enough to cover the entire I/O transfer period, a time-out will occur while the data transfer is still in progress, and the transfer will be prematurely terminated. This can be prevented by specifying a suitably long time-out value, or by specifying a time-out value of zero (which disables the time-out feature entirely).

The time-out value set by the user to prevent indefinite suspension should not be confused with the time-out set up by the privileged driver to complete the call and return to IOC. In the latter case, the driver overrides the user-specified time-out by inserting its own value (-1) directly into the time-out clock before returning.

# 4-10. SUBROUTINES FOR SPECIAL MAPPING FUNCTIONS (DMS SYSTEMS ONLY)

The mapping considerations for the initiation and continuation/completion sections of privileged drivers are the same as those for standard RTE drivers (see Section III of this manual). Prior to entering either of these sections, RTE will load and enable the correct map (System or User) needed to describe the I/O request buffer.

The privileged section of a privileged driver requires special mapping considerations however. The System Map will always be enabled when the privileged section is entered since this section is entered directly from the interrupt trap cell. If the I/O buffer is not accessible under the System Map, the privileged section must reload the User Map to describe the appropriate program before accessing the buffer. Therefore, if the privileged driver only processes I/O requests from buffers in System Common or System Available Memory, the privileged section can access the I/O buffer directly without making special mapping considerations.

Subroutine \$PVMP can be used by privileged drivers to perform any needed map switching. The driver user \$PVMP as follows:

- 1. Save the contents of the current User Map.
- 2. Load the A-register with the ID Segment address of the program containing the buffer.

- 3. Call \$PVMP (JSB \$PVMP) to load the User Map for the program specified in the A-register.
- 4. Check for an error return. \$PVMP returns with the A-register set to zero if the specified program was not in memory and the User Map could not be set up.
- 5. If no error was detected, access the buffer through the newly loaded User Map.
- 6. After all accesses to the buffer have been made, restore the User Map to its original contents and continue with normal operation.

Notice that the use of \$PVMP requires that the driver know the ID Segment address of the program making the I/O request. Since the driver can not be sure that this ID Segment address is available on base page or in the EQT, the program making the I/O request should cooperate with the driver and pass its ID Segment address. This could be done by using one of the optional parameters and letting the driver retrieve the address through the appropriate optional parameter word in the EQT.

The recommended procedure for using \$PVMP is somewhat different in RTE-III and RTE-IV. Each of these procedures is described in a separate section below.

#### NOTE

Subroutine \$PVMP can be called by privileged RTE drivers only. Standard drivers wishing to perform the same function must use subroutine \$XDMP, which is described in Section III of this manual.

#### MAPPING IN RTE-III AND RTE-M/III

Before entering the initiation or continuation section of a privileged driver, IOC enables the correct map needed to process the call, as follows:

- a. When the I/O request buffer is located in SYSTEM COMMON or System Available Memory, IOC enables the System Map before entering the driver.
- b. When the I/O request buffer is located in the calling program, IOC enables the User Map before entering the driver.

However, the System Map is always enabled upon entry to the privileged section, since the privileged section is entered directly from the interrupt trap cell.

Since the buffer, in general, may be located in either the User Map (program not swappable) or the System Map, the driver needs to identify which map is used. If necessary, the driver can then use \$PVMP to access the buffer while in the privileged section.

In the following example, the initiation section of the privileged driver checks the status of the Dynamic Mapping System and sets a flag to indicate whether the System or User Map is enabled. The initiator also retrieves the ID Segment address of the program making the I/O request. Note that the driver is assuming that the program making the I/O request has cooperated with the driver and placed its ID Segment address in the first optional parameter.

The privileged section of the driver then saves the current state of the User Map registers and Dynamic Mapping System. After the driver has determined that the User Map is needed, it calls \$PVMP to reload the User Map registers to describe the calling program. The driver then switches to operation under this map and accesses the memory described by it. After all accesses have been made, the driver reenables the System Map and restores the original state of the User Map registers before continuing with its normal processing under the System Map.

|       | EXT \$PVMP                         |                                                                                                                                      |  |  |
|-------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|
| IXNN  | NOP .                              | Initiation Section entry point<br>(System Map or User Map enabled depending on location of<br>I/O request buffer.)                   |  |  |
|       |                                    |                                                                                                                                      |  |  |
|       | CLA<br>STA IDADR<br>RSA            | Clear IDADR signifying System Map used<br>Access Dynamic Mapping System Status                                                       |  |  |
| *     | ALF<br>SLA,RSS<br>JMP PROCD        | Position bit 12 into bit 0 System Map enabled? Yes, System map enabled No, user map enabled                                          |  |  |
|       | LDA EQT9,I<br>STA IDADR            | Access address of program making request<br>Save for use of Privileged Section later                                                 |  |  |
| PROCD | NOP                                |                                                                                                                                      |  |  |
|       |                                    | Continue Initiation Section processing                                                                                               |  |  |
| PXNN  | JMP IXNN,I<br>NOP                  | Return to IOC<br>Privileged Section entry point (System Map Enabled)                                                                 |  |  |
|       |                                    | Normal driver processing under System Map                                                                                            |  |  |
|       | RSA<br>RAL,RAL<br>STA DMSST        | Get Dynamic Mapping System (DMS) status<br>Position current status in upper bits<br>Save status for later                            |  |  |
|       | LDA MAPAD<br>IOR SIGN<br>USA       | Set A = address of User Map storage area<br>Set sign bit indicating Store Map in memory<br>Save current User Map in memory for later |  |  |
| *     | LDA IDADR<br>SZA,RSS<br>JMP CONT   | Access IDADR to determine if User or System Map used<br>System Map used?<br>Yes, System Map used<br>No, User Map used                |  |  |
| 4-14  | JSB \$PVMP<br>SZA,RSS<br>JMP ERROR | Call \$PVMP to set up User Map for this program<br>Check for error return<br>Error exists, go handle it                              |  |  |
| 4-14  |                                    |                                                                                                                                      |  |  |

|              | UJP CONT     | No, errors. Enable new User Map and continue.   |  |
|--------------|--------------|-------------------------------------------------|--|
| CONT         | •            |                                                 |  |
|              | •            | Process buffer under new User Map.              |  |
|              | LDA IDADR    | Determine if System or User Map is used         |  |
|              | SZA,RSS      | System Map used?                                |  |
|              | JMP NXT      | Yes, System Map used                            |  |
| *            |              | No, User Map used                               |  |
|              |              |                                                 |  |
|              | SJP NEXT     | Reenable System Map                             |  |
| NEXT         | LDA MAPAD    | Access address of User Map storage area         |  |
|              | USA          | Restore original contents of User Map           |  |
|              | JRS DMSSTNXT | Restore original DMS status (i.e., System Map)  |  |
| NXT          |              | Enable Interrupt System.                        |  |
| .,,          | · ·          | music meerrape system.                          |  |
|              |              | Proceed with normal processing under System Map |  |
|              |              |                                                 |  |
| MAPAD        | DEF MAP      | Address of User Map storage area                |  |
| MAP          | BSS 32       | User Map storage area                           |  |
| SIGN         | OCT 100000   |                                                 |  |
| <b>IDADR</b> | BSS 1        | ID segment address saved by initiation section  |  |
| DMSST        | BSS 1        | Temporary storage for DMS status                |  |

Remember that any driver using this routine must save the original contents of the User Map registers before calling \$PVMP. It must also restore the original User Map after all accesses to the buffer have been made. Also remember that if the driver accesses the memory described by the User Map by enabling the map, it must save and restore the DMS status in addition to the original contents of the User Map. The example above illustrates this procedure.

#### NOTE

The privileged driver could also access the buffer in the user program through a series of cross-map loads and stores without actually enabling the User Map. This in fact is the recommended procedure for using \$PVMP in an RTE-IV system, and use of it by a privileged driver would allow the same privileged driver to be used in either type of system.

#### MAPPING IN RTE-IV

Privileged drivers in RTE-IV must reside in the System Driver Area (SDA) of memory since the privileged section is always entered under the System Map directly from the trap cell. The driver can be placed in SDA by selecting either the "M" or "S" option during the EQT entry definition phase of system generation (see Section III of this manual for a discussion of the "M" and "S" options). The initiation and continuation/completion sections of the driver may be entered under either the System Map or the User Map depending on the location of the I/O buffer and the option selected at generation. The privileged section, however, will always be entered under the System Map.

If the I/O buffer being processed by the driver is located in System Common on System Available Memory, the privileged driver will always have access to the buffer under the System Map. If, however, the I/O buffer is located in the user program, the driver must consider two possible situations in which it is operating under the System Map while the buffer is in the User Map.

- 1. The initiation and continuation/completion sections of the driver have to access the buffer through the User Map if the "M" option was selected.
- 2. The privileged section must access the buffer through the User Map regardless of the option selected.

A privileged driver that needs to access a buffer in a user program while operating under the System Map can use the \$PVMP subroutine to reload the User Map to describe the desired program.

In the following example of an "S" option privileged driver, the initiation section of the driver checks the DMS status and sets a flag to indicate whether the System Map or User Map is enabled. If the User Map was enabled, the initiator also retrieves the ID Segment address of the program making the I/O request. Note that the driver is assuming that the program has cooperated and placed its ID Segment address in the first optional parameter.

The privileged section of the driver then saves the current contents of the User Map. If the User Map is needed to access the buffer, the privileged section then calls \$PVMP to reload the User Map registers to describe the calling program. The driver then uses a series of cross-map loads and stores to access the buffer described by the User Map. Note that the User Map should not be enabled since drivers in SDA are not necessarily included in all users' maps. After all accesses have been made, the driver restores the original state of the User Map registers before continuing with its normal processing under the System Map.

|       | EXT \$PVMP                  |                                                                                                              |
|-------|-----------------------------|--------------------------------------------------------------------------------------------------------------|
| IXNN  | NOP                         | Initiation Section entry point (System Map or User Map enabled depending on location of I/O request buffer.) |
|       | CLA<br>STA IDADR<br>RSA     | Clear IDADR signifying System Map used<br>Access Dynamic Mapping System Status                               |
| *     | ALF<br>SLA,RSS<br>JMP PROCD | Position bit 12 into bit 0 System Map enabled? Yes, System map enabled No, user map enabled                  |
|       | LDA EQT9,I<br>STA IDADR     | Access address of program making request<br>Save for use of Privileged Section later                         |
| PROCD | NOP                         |                                                                                                              |
|       | ·<br>·                      | Continue Initiation Section processing                                                                       |

| PXNN        | JMP IXNN,I<br>NOP    | Return to IOC<br>Privileged Section entry point (System Map Enabled)                  |
|-------------|----------------------|---------------------------------------------------------------------------------------|
|             | •                    | Normal driver processing under System Map.                                            |
|             | LDA MAPAD            | Set A = address of User Map storage area                                              |
|             | IOR SIGN<br>USA      | Set sign bit indicating Store Map in memory Save current User Map in memory for later |
|             | LDA IDADR<br>SZA,RSS | Access IDADR to determine if User or System Map used System Map used?                 |
| *           | JMP SYACC            | Yes, System Map used — access buffer directly<br>No, User Map used                    |
|             | JSB \$PVMP           | Call \$PVMP to set up User Map for this program                                       |
|             | SZA,RSS<br>JMP ERROR | Check for error return  Error exists, go handle it                                    |
|             |                      |                                                                                       |
|             |                      | No errors. System Map is still enabled. Access                                        |
|             |                      | buffer via a series of cross-map loads and stores since SDA drivers are not included  |
|             | •                    | in all User Maps.                                                                     |
|             |                      | Museum                                                                                |
|             | LDA MAPAD<br>USA     | Access address of User Map storage area Restore original contents of User Map         |
|             | USA                  | nestore original contents of Oser Map                                                 |
|             | ·<br>·               | Proceed with normal processing under System Map                                       |
| MAPAD       | DEF MAP              | Address of User Map storage area                                                      |
| MAP<br>SIGN | BSS 32<br>OCT 100000 | User Map storage area                                                                 |
| IDADR       | BSS 1                | ID segment address saved by initiation section                                        |

Remember that any driver using this routine must save the original contents of the User Map registers before calling \$PVMP and must restore the registers to their original value after all accesses to the buffer have been made. The example above illustrates this procedure.

### 4-11. SAMPLE DMS PRIVILEGED DRIVER

The sample driver illustrated in Figure 4-1 demonstrates some of the principles involved in writing a privileged I/O driver for use in an RTE system with Dynamic Mapping. Note that this driver is for tutorial purposes only and is not one of the drivers supplied with the system.

### 4-12. SAMPLE NON-DMS PRIVILEGED DRIVER

The sample driver illustrated in Figure 4-2 demonstrates some of the principles involved in writing a privileged I/O driver for use in an RTE system without Dynamic Mapping. Note that this driver is for tutorial purposes only and is not one of the drivers supplied with the system.

```
PAGE 0002 #01 ** RTE DMS PRIVILEGED DRIVER EXAMPLE **
0001
                    ASMB, L
3003*
     00000
0004
                           NAM DVYNN** RTE DMS PRIVILEGED DRIVER EXAMPLE**
0005
                           SUP
0006*
0007
                          EHT IXHN, CXHN
♦ 8 0 0 0
0009**********************************
0010* SAMPLE RTE PRIVILEGED DRIVER DVYNN - FOR DMS SYSTEMS *
0011********************
0012*
0013* HANDLES USER PROGRAM REQUESTS TO READ FROM A PRIVILEGED
0014* CONTROLLER
0015+
0016* USER PROGRAM CALLING SEQUENCE:
0017*
0018*
        JSB EXEC
                       CALL EXEC
       DEF RODE REQUEST CODE (MUST BE READ REQUEST)
DEF CONWD CONTROL WORD
DEF BUFFR ADDRESS OF BUFFER (MUST BE IN SYSTEM COMMON)
DEF LENTH LENGTH OF BUFFER
0019*
0020*
0021*
0022*
0023*
0024*
0025* CAUTION:
0026*
0027* THIS DRIVER WILL NOT WORK WITH MORE THAN ONE PRIVILEGED
2028* CONTROLLER. IF MORE THAN ONE PRIVILEGED CONTROLLER
0029* EXISTS IN A SYSTEM, DVYNN MUST BE
0030* RE-ASSEMBLED WITH ALL NAMES CONTAINING "NN" CHANGED SO
0031* THAT EACH COPY OF THE DRIVER HAS UNIQUE ENTRY POINTS.
0032* THEN ONE DRIVER PER CONTROLLER MUST BE PUT
0033* INTO THE SYSTEM AT GENERATION TIME.
0034*
0035* NOTE:
0036*
0037* 1.) THE DESIGN OF THIS DRIVER ASSUMES THAT THE I/O
*8500
          BUFFER BEING PROCESSED IS LOCATED IN SYSTEM COMMON.
          THIS CAUSES THE DRIVER TO BE ENTERED WITH THE
0039*
0040*
          SYSTEM MAP ENABLED. THIS IS NECESSARY FOR THE
          CORRECT OPERATION OF THE TRAP CELL MODIFICATION
0041 *
0042*
          TECHNIQUE ILLUSTRATED BELOW. IN ADDITION, THE
0043*
         BUFFER IN SYSTEM COMMON ALLOWS THE DRIVER TO PUT THE
0044*
          DATA VALUES DIRECTLY INTO THE BUFFER, WITHOUT
0045*
          THE NEED FOR MAP SWITCHING
0046*
0047* 2.) THIS DRIVER DOES NOT PROCESS POWER FAIL INTERRUPTS.
0048*
0049* 3.) THIS DRIVER DOES NOT PROCESS ANY TIME-OUTS EXCEPT
0050*
          FOR THE TIME-OUT THAT IT CREATES AS A MEANS TO
0051*
          COMPLETE THE T/O REQUEST AND RETURN TO TOC
0052*
```

Figure 4-1. DMS Privileged RTE Driver Example

```
PAGE 0003 #01 ** DMS PRIVILEGED DRIVER - INITIATION SECTION **
0054*
1055*
0056*
                        * INITIATION SECTION *
0057*
                        **********
0058*
0059
     00000 000000 IXNN HOP
                                        INITIATION SECTION ENTRY POINT
0060 00001 072200R
                          STA SCODE
                                        SAVE SELECT CODE OF CONTROLLER
0061*
0062 00002 066203R
                         LDB FIRST
                                        ACCESS FIRST TIME THROUGH FLAG
0063 00003 006002
                                        IS THIS THE FIRST TIME THRU?
                          SZB
0064 00004 026020R
                          JMP INIT
                                        NO, SO SKIP CONFIGURATION CODE
0065*
0066* CONFIGURE I/O INSTRUCTIONS
0067*
                                        CREATE LIA INSTRUCTION
0068 00005 032217R
                          IOR LIA
0069*
0070*
0071 *
0072*
0073* MODIFY TRAP CELL
0074*
0075 00006 062220R
                          LDA #JSB
                                        SET TRAP CELL TO
0076 00007 172200R
                          STA SCODE, I
                                        JSB $JPNN,I ($JPNN=ADDR OF PXNN)
0077*
0078* SAVE EQT ADDRESSES
0079*
     00010 061774
                          LDA EQT15
                                        SAVE EQT15
0800
0081
      00011 072215R
                          STA EQ15
0082
     00012 061663
                          LDA ERT4
                                        EQT 4
0083
      00013 072214R
                          STA EQ4
                          LDA EQT1
      00014 061660
                                        AND EQT1
0084
0085
     00015 072213R
                          STA EQ1
                                        ADDRESSES
*3800
                                        SET FLAG TO PREVENT CONFIGURING ON
      00016 002404
0087
                          CLA, INA
0088 00017 072203R
                          STA FIRST
                                        SUBSEQUENT INITIATIONS
0089*
0090* CLEAR THE "DRIVER PROCESSES TIME-OUT" BIT TO ALLOW
0091* NORMAL TIME-OUT OPERATION
0092*
0093 00020 161663 INIT LDA EQT4, I
                                        ACCESS EQT WORD 4
0094
     00021 012221R
                          AND =8167777 CLEAR BIT 12
0095
      00022 171663
                          STA EQT4,I
                                        AND RESET EQT WORD 4
0096*
0097* CHECK THE REQUEST CODE
0098*
      00023 161665
                          LDA EQT6,I
                                        ACCESS REQUEST CODE
0099
                          AND =83
0100
     00024 012222R
                                        ISOLATE REQUEST TYPE
0101
      00025 052223R
                          CPA =81
                                        READ REQUEST?
0102
      00026 026041R
                          JMP PROC
                                        YES, GO PROCESS READ REQUEST
0103*
0104 00027 052222R
                          CPA =83
                                        CONTROL REQUEST?
0105 00030 026033R
                          JMP CHTRL
                                        YES, GO PROCESS CONTROL REQUEST
$106*
0107 00031 002404
                                        NO, SO REJECT AS ILLEGAL WRITE REQUEST
                          CLA, INA
0108 00032 126000R
                          JMP IXMN.I
0109*
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0004 #01 ** DMS PRIVILEGED DRIVER - INITIATION SECTION **
0110* CONTROL REQUEST. CHECK IF IT IS A "CLEAR" CONTROL REQUEST 0111* IF SO, ASSUME IT WAS ISSUED BY SYSTEM, CLEAR DEVICE, AND RETURN.
0112*
0113 00033 161665 CNTRL LDA EQT6,I
                                           ACCESS CONTROL WORD
0114 00034 012204R
                           AND -B3700
                                           ISOLATE SUBFUNCTION
                                           "CLEAR" REQUEST?
0115 00035 002002
                            SZA
                                           NO, SO REJECT AS ILLEGAL CONTROL REQUEST
                            JMP REJUT
0116 00036 026037R
0117*
                                           EXECUTE CODE TO CLEAR CONTROLLER
0118*
0119*
0120*
0121*
0122 00037 062225R REJCT LDA =B2
0123 00040 126000R JMP IXNN
                                           REJECT AS ILLEGAL CONTROL REQUEST
                           JMP IXNN, I
0124*
0125% SET UP FOR THE DATA TRANSFER
0126*
0127 00041 161667 PROC LDA EQT8,I
                                           ACCESS & OF CONVERSIONS REQUIRED
                                           NEGATE FOR CONVERSION COUNTER
0128 00042 003004
                           CMA, INA
0129
      00043 072201R
                            STA CVCTR
                                           AND SAVE
                                           REJECT IF
0130
      00044 002021
                            SSA,RSS
                                           NUMBER <0
0131
      00045 026037R
                            JMP REJCT
                            LDA EQT7,I
                                           SAVE DATA BUFFER ADDRESS
      00046 161666
0132
0133 00047 072202R
                            STA DAPTR
                                           FOR PXNN
0134%
0135* INITIATE A READ AND RETURN
0136*
01.37
      00050 016053R
                            JSB READ
                                           START A READ
     00051 103700 I.1
                            STC SC,C
                                           ENCODE DEVICE
01.38
0139 00052 002400
                            CLA
0140 00053 126000R
                            JMP IXNN, I
                                           RETURN TO IOC
0141*
0142* SUBROUTINE TO INITIATE A READ
01.43*
0144 00054 000000 READ NOP
                                           ROUTINE CONTAINING
                                           CONFIGURED I/O
0145*
                                           INSTRUCTIONS TO
0146*
0147*
                                           SET UP THE DEVICE
0148*
                                           TO INITIATE ONE READING
                            JMP READ, I
0149 00055 126054R
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0005 #01 ** DMS PRIVILEGED DRIVER - PRIVILEGED SECTION **
0150+
1151 *
                        ***********
♦ 152 *
                        * PRIVILEGED SECTION *
0153*
                        ******
0154*
0155* SAVE STATE OF COMPUTER AT INTERRUPT
0156*
                                        PRIVILEGED SECTION ENTRY POINT
0157 00055 000000 PXNN NOP
0158*
                          CLF 0
0159 00056 103100
                                        TURN OFF INTERRUPT SYSTEM
0160*
     00057 106706
                          CLC 6
                                        TURN OFF DCPC COMPLETION INTERRUPTS
0161
     00060 106707
                          CLC 7
0162
0163*
0164
      00061 072204R
                          STA ASV
                                        SAVE REGISTERS
      00062 076205R
                          STB BSV
0165
      00063 001520
                          ERA, ALS
0166
     00064 102201
0167
                          SOC
     00065 002004
0168
                          INA
     00066 072206R
0169
                          STA EBSV
     00067 105743
                          STX XSV
                                        SAVE X REGISTER
0170
0171
      00071 105753
                          STY YSV
                                        SAVY Y REGISTER
                          SSM DHSTS
                                        SAVE DYNAMIC MAPPING SYSTEM STATUS
0172
     00073 105714
0173*
                                        SAVE OLD MEMORY PROTECT FLAG
                          LDA HPTFL
0174 00075 061770
     00076 072212R
                          STA MPFSV
0175
0176
      00077 002404
                          CLA, INA
                                        SET MEMORY PROTECT FLAG TO OFF
0177 00100 071770
                          STA MPTFL
                                        SINCE MEMORY PROTECT IS NOW OFF
0178*
                                        TURN INTERRUPT SYSTEM BACK ON
0179 00101 102100
                          STF 0
0180*
0181* CHECK FOR SPURIOUS INTERRUPT
0182*
                                        ACCESS REQUEST LIST POINTER WORD
0183 00102 162213R
                          LDA EQ1, I
     00103 012226R
                          AND =877777
                                        ISOLATE REQUEST LIST POINTER
6184
                                        IS A REQUEST IN PROGRESS?
01:85
      00104 002002
                          SZA
0186
      00105 026111R
                          JMP PREAD
                                         YES, GO PROCESS INTERRUPT
0187*
0188
      00106 103100
                          CLF 0
                                        HO, TURN OFF INTERRUPT SYSTEM
                                        RESET CONTROLLER, AND
0189
     00107 107700 I.2
                          CLC SC,C
                                        IGNORE SPURIOUS INTERRUPT BY RETURNING
                          JMP EXIT
0190 00110 026121R
0191*
0192* PROCESS READ REQUEST
0193*
0194 00111
                    PREAD EQU *
0195*
                                         LOAD IN DATA FROM DEVICE
                                         VIA CONFIGURED I/O INSTRUCTIONS
0196*
0197*
0198*
                           STA DAPTR, I
                                         STORE WORD IN DATA BUFFER
      00111 172202R
0199
0200
      00112 036201R
                          ISZ CYCTR
                                         IS THIS THE LAST CONVERSION?
0201 00113 002001
                          RSS
0202 00114 026164R
                           JMP DONE
                                         YES, GO SET UP TO TERMINATE CALL
0203*
0204 00115 036202R
0205 00116 016053R
                          ISZ DAPTR
                                         NO, SET UP FOR NEXT CONVERSION
                           JSB READ
                                         INITIATE IT
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0006 #01 ** DMS PRIVILEGED DRIVER - PRIVILEGED SECTION **
0206*
)207* RESTORE MACHINE TO ORIGINAL STATE ON INTERRUPT
0208*
0209 00117 103100
                          CLF 0
                                        TURN OFF INTERRUPT SYSTEM TEMPORARILY
0210*
     00120 103700 I.3
0211
                          STC SC.C
                                        ENCODE DEVICE
0212*
                                        ACCESS PREVIOUS STATE OF MEMORY PROTECT
0213 00121 062212R EXIT LDA MPFSV
0214 00122 002002
                          SZA
                                        WAS MEMORY PROTECT ON?
                                        NO, SO DO NOT TURN ON DOPC INTERRUPTS
0215 00123 026134R
                          JMP EXIT1
0216*
                                        YES, TURN DCPC COMPLETION INTERRUPTS
0217 00124 065654
                          LDB INTBA
0218 00125 160001
                          LDA B, I
                                        BACK ON IF THEY WERE ON INITIALLY.
0219
      00126 002020
                          SSA
                                        ON/OFF STATUS IS INDICATED BY BIT 15
                          STC 6
                                        OF EACH DCPC ASSIGNMENT WORD IN THE
0220 00127 102706
                                        INTERRUPT TABLE
     00130 006004
                          INB
0221
      00131 160001
                          LDA B, I
0222
     00132 002020
0223
                          SSA
0224 00133 102707
                          STC 7
0225*
      00134 062206R EXIT1 LDA EOSY
                                        RESTORE E AND O REGISTERS
0226
0227
      00135 103101
                          CLO
0228
      00136 000036
                          SLA, ELA
      00137 102101
                          STF 1
0229
                          LDB BSV
                                        RESTORE B-REGISTER
0230
      00140 066205R
0231
      00141 105745
                          LDX XSY
                                        RESTORE X REGISTER
                          LDY YSY
                                        RESTORE Y REGISTER
      00143 105755
0232
0233*
                          LDA MPFSY
                                         RESTORE MEMORY PROTECT FLAG
     00145 062212R
0234
                                         IN BASE PAGE
0235 00146 071770
                          STA MPTFL
     00147 002002
                          SZA
                                         WAS MEMORY PROTECT ON AT INTERRUPT?
0236
0237
      00150 026157R
                          JMP EXIT2
                                         H C
0238 *
0239
     00151 062204R
                          LDA ASY
                                         YES, RESTORE A-REGISTER
                          STF 0
0240
      00152 102100
                                         TURN ON INTERRUPT SYSTEM
      00153 102705
                          STC 5
                                         SET MEMORY PROTECT ON
0241
0242 00154 105715
                          JRS DMSTS PXNN, I
                                                RESTORE DMS STATUS AND RETURN
                                                (NOTE: EXECUTION OF A "JRS"
0243*
0244*
                                                INSTRUCTION AFTER TURNING THE
                                                MEMBRY PROTECT FENCE ON IS
0245*
                                                ALLOWED ONLY IF THE SYSTEM MAP
0246*
                                                IS CURRENTLY ENABLED. THIS
0247*
                                                DRIVER HAS BEEN DESIGNED SUCH
0248*
                                                THAT THIS IS ALWAYS THE CASE.
0249±
0250+
      00157 062204R EXIT2 LDA ASY
                                         NO, RESTORE A-REGISTER
0251
                           STF 0
                                         TURN ON INTERRUPTS
      00160 102100
0252
0253 00161 105715
                           JRS DASTS PXNN, I
                                                RESTORE DMS STATUS AND RETURN
0254*
0255* THIS CODE SETS UP THE TIME OUT TO COMPLETE THE CALL
0256*
      00164 103100 DONE CLF 0
                                         TURN OFF THE INTERRUPT SYSTEM
0257
                                         TURN OFF PRIVILEGED DEVICE
                           CLC SC
1258
      00165 106700 I.4
                           CCA
                                         SET TIME OUT FOR
      00166 003400
0259
0260
      00167 172215R
                           STA EQ15,I
                                         ONE TICK AND SET
                                         BIT12 IN EQT4 SO
0261
      00170 162214R
                           LDA EQ4, I
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0007 #01 ** DMS PRIVILEGED DRIVER - PRIVILEGED SECTION **
                            IOR BIT12 RTIOC WILL
STA EQ4,I CALL CANN ON TIME-OUT
JMP EXIT GO TO EXIT ROUTINE
0262 00171 032216R
)263 00172 172214R
0264 00173 026121R
 PAGE 0008 #01 ** DMS PRIVILEGED DRIVER - COMPLETION SECTION **
0266*
1267*
                           *************
0268*
                           * COMPLETION SECTION *
0269*
                           *************
0270*
0271 00174 000000 CXNN NOP
                                            COMPLETION SECTION ENTRY POINT
0272*
                                          SET A = 0 = NORMAL RETURN
SET B = TRANSMISSION LOG
RETURN TO 100
0273 00175 002400
                             CLA
0274 00176 165667
                             LDB EQT8,I
                            JMP CHNN'I
0275 00177 126174R
                                              RETURN TO TOC
¢276*
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0009 #01 ** DNS PRIVILEGED DRIVER - DATA AREA **
0278*
>279* CONSTANT AND STORAGE AREA
0280*
0281
     00000
                          EQU 0
0282
     00001
                   В
                          EQU 1
     00000
                          EQU 0
                                      DUNMY I/O SELECT CODE NUMBER
0283
0284*
0285
     00200 000000 SCODE BSS 1
0286
     00201 000000
                   CYCTR BSS 1
     00202 000000
0287
                   DAPTR BSS 1
     00203 000000 FIRST BSS 1
0288
0289
     00204 000000 ASY
     00205 000000 BSY
0290
                          8 S S 1
0291
     00206 000000
                   EOSV BSS 1
     00207 000000
0292
                   XSY
                          BSS
     00210 000000
0293
                   YSY
                          888
0294
     00211 000000 DMSTS BSS 1
0295
     00212 000000 MPFSY BSS 1
0296
     00213 000000 EQ1
                          BSS 1
9297
      00214 000000 EQ4
                          BSS 1
     00215 000000 EQ15 BSS 1
0298
     00216 010000 BIT12 OCT 10000
0299
0300 00217 102500 LIA
                        LIA O
41060
0302* BASE PAGE COMMUNICATIONS AREA DEFINITION
4505¢
0304
     01650
                          EQU 1650B
0305
     01654
                    INTBA EQU .+4
0306
     01660
                    EQT1 EQU .+8
                         EQU .+11
0307
      01663
                    EQT4
                         EQU .+13
8080
     01665
                   EQT6
0309
     01666
                   EQ17
                         EQU .+14
                   EQT8 EQU .+15
0310
     01667
                    EQT15 EQU .+84
0311
      01774
0312
      ¢1770
                    MPTFL EQU .+80
0313*
0314* CODE TO SET UP JSB $JPNN, I INSTRUCTION ON BASE PAGE
0315*
0316 00000
                          CR B
                                        RESET LOCATION COUNTER TO BASE PAGE
      00000 000055R $JPNN DEF PXNN
0317
                                       PRIV. SECTION ENTRY POINT ADDR
0318*
0319 00220
                          ORR
                                       RESET LOCATION COUNTER TO RELOCATABLE
0320 00220 114000B $JSB JSB $JPNN,I JSB INSTR. TO PRIV SECTION, INDIRECT
0321*
0322
                          END
** NO ERRORS *TOTAL **RTE ASMB 760924**
```

Figure 4-1. DMS Privileged RTE Driver Example (Continued)

```
PAGE 0002 #01 ** RTE NON-DMS PRIVILEGED DRIVER EXAMPLE **
0001
                   ASMB, L
1003+
0004 00000
                                   ** RTE NON-DMS PRIVILEGED DRIVER EXAMPLE *
                         HAM DVYNN
0005*
0006
                         ENT IXNN,CXNN
0007*
0009* SAMPLE RTE PRIVILEGED DRIVER DVYNN - FOR NON-DMS SYSTEMS *
0011*
0012* HANDLES USER PROGRAM REQUESTS TO READ FROM A PRIVILEGED
0013* CONTROLLER
0014*
0015* USER PROGRAM CALLING SEQUENCE:
0016*
0017*
       JSB EXEC
                      CALL EXEC
0018*
       DEF *+5
                      RETURN POINT
0019*
       DEF ROBBE
                      REQUEST CODE (MUST BE READ REQUEST)
       DEF CONWD
                      CONTROL WORD
0020*
0021*
       DEF BUFFR
                      ADDRESS OF BUFFER (MUST BE IN COMMON)
0022*
       DEF LENTH
                     LENGTH OF BUFFER
0023*
0024* CAUTION:
0025*
0026* THIS DRIVER WILL NOT WORK WITH MORE THAN ONE PRIVILEGED
0027* CONTROLLER. IF MORE THAN ONE PRIVILEGED CONTROLLER
0028* EXISTS IN A SYSTEM, DVYNN MUST BE
0029* RE-ASSEMBLED WITH ALL NAMES CONTAINING "NN" CHANGED SO
0030* THAT EACH COPY OF THE DRIVER HAS UNIQUE ENTRY POINTS.
0031* THEN ONE DRIVER PER CONTROLLER MUST BE PUT
0032* INTO THE SYSTEM AT GENERATION TIME.
0033*
0034* HOTE:
0035*
0036* 1.) THIS DRIVER DOES NOT PROCESS POWER FAIL INTERRUPTS.
0037*
0038* 2.) THIS DRIVER DOES NOT PROCESS ANY TIME-OUTS EXCEPT
         FOR THE TIME-OUT THAT IT CREATES AS A MEANS TO
0039*
          COMPLETE THE I/O REQUEST AND RETURN TO IOC
0040+
0041*
```

Figure 4-2. Non-DMS Privileged RTE Driver Example

```
PAGE 0003 #01 ** NON-DMS PRIVILEGED DRIVER ~ INITIATION SECTION **
0043*
3044*
                       ¢ 0 45 *
                       * INITIATION SECTION *
0046*
                       *******
0047*
0048 00000 000000 IXNN HOP
                                       INITIATION SECTION ENTRY POINT
                         STA SCODE
0049 00001 072162R
                                      SAVE SELECT CODE OF CONTROLLER
0050*
0051
     00002 066165R
                         LDB FIRST
                                       ACCESS FIRST TIME THROUGH FLAG
0052 00003 006002
                                       IS THIS THE FIRST TIME THRU?
                         SZB
0053 00004 026020R
                         JMP INIT
                                       NO, SO SKIP CONFIGURATION CODE
0054*
0055* CONFIGURE I/O INSTRUCTIONS
0056*
0057 00005 032176R
                                       CREATE LIA INSTRUCTION
                         IOR LIA
0058*
0059*
0060*
0061*
0062* MODIFY TRAP CELL
0063*
0064 00006 062177R
                         LDA $JSB
                                       SET TRAP CELL TO
                         STA SCODE,I
0065 00007 172162R
                                       JSB $JPNN, I ($JPNN=ADDR OF PXNN)
#6600
0067* SAVE ERT ADDRESSES
0068*
                                       SAVE EQT15
     00010 061774
                         LDA EQT15
0069
0070
      00011 072174R
                         STA EQ15
      00012 061663
0071
                         LDA EQT4
                                       EQT4
     00013 072173R
0072
                         STA EQ4
0073 00014 061660
                         LDA EQT1
                                       AND EQT1
0074
      00015 072172R
                                       ADDRESSES
                         STA EQ1
0075*
0076 00016 002404
                                       SET FLAG TO PREVENT CONFIGURING ON
                         CLA, INA
     00017 072165R
                         STA FIRST
                                       SUBSEQUENT INITIATIONS
0077
0078*
0079* CLEAR THE "DRIVER PROCESSES TIME-OUT" BIT TO ALLOW
0080* NORMAL TIME-OUT OPERATION
0081 *
0082 00020 161663 INIT LDA EQT4,I
                                       ACCESS EQT WORD 4
     00021 012200R
                          AND = B167777
0083
                                       CLEAR BIT 12
0084
      00022 171663
                          STA EQT4,I
                                       AND RESET EQT WORD 4
0085*
0086* CHECK THE REQUEST CODE
0087*
                                       ACCESS REQUEST CODE
0088 00023 161665
                         LDA EQT6,I
      00024 012201R
                          AND =B3
                                       ISOLATE REQUEST TYPE
0089
      00025 052202R
                          CPA =B1
                                       READ REQUEST?
0090
      00026 026041R
                          JMP PROC
0091
                                       YES, GO PROCESS READ REQUEST
0092*
0093 00027 052201R
                         CPA =B3
                                       CONTROL REQUEST?
0094 00030 026033R
                          JMP CHTRL
                                       YES, GO PROCESS CONTROL REQUEST
0095*
0096 00031 002404
                          CLA, INA
                                       NO, SO REJECT AS ILLEGAL WRITE REQUEST
0097 00032 126000R
                          I'HHKI AMP
6098*
```

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

```
PAGE 0004 #01 ** NON-DMS PRIVILEGED DRIVER - INITIATION SECTION **
0099* CONTROL REQUEST, CHECK IF IT IS A "CLEAR" CONTROL REQUEST
0100* IF SO, ASSUME IT WAS ISSUED BY SYSTEM, CLEAR DEVICE, AND RETURN.
0101*
0102
      00033 161665 CNTRL LDA EQT6,I
                                         ACCESS CONTROL WORD
      00034 012203R
                                         ISOLATE SUBFUNCTION
0103
                          AND =#3700
                                         "CLEAR" REQUEST?
0104
     00035 002002
                          SZA
0105
      00036 026037R
                          JMP REJUT
                                         NO, SO REJECT AS ILLEGAL CONTROL REQUEST
01.06*
                                         EXECUTE CODE TO CLEAR CONTROLLER
01.07*
0108*
0109*
0110*
                                         REJECT AS ILLEGAL CONTROL REQUEST
0111 00037 062204R REJUT LDA =B2
0112
      00040 126000R
                           JMP IXNN, I
0113*
0114* SET UP FOR THE DATA TRANSFER
0115*
     U0041 161667 PROC LDA EQT8,I
                                         ACCESS & OF CONVERSIONS REQUIRED
0116
0117
      00042 003004
                                         NEGATE FOR CONVERSION COUNTER
                          CMA, INA
0118 00043 072163R
                           STA CVCTR
                                         AND SAVE
0119
      00044 002021
                                         REJECT IF
                          SSA, RSS
0120
                          JMP REJCT
      00045 026037R
                                         NUMBER <0
0121
      00046 161666
                          LDA EQT7,I
                                         SAVE DATA BUFFER ADDRESS
0122
     -00047 072164R
                           STA DAPTR
                                         FOR PXNN
0123*
0124* INITIATE A READ AND RETURN
0125*
0126 00050 016053R
                                         START A READ
                           JSB READ
                           STC SC,C
0127
      00051 103700
                                         ENCODE DEVICE
                    1.1
0128
      00052 002400
                           CL.A
0129
      00053 126000R
                           JMP IXNN, I
                                         RETURN TO IOC
0130*
0131* SUBROUTINE TO INITIATE A READ
0132*
0133 00054 000000 READ
                                         ROUTINE CONTAINING
0134*
                                         CONFIGURED IZO
0135*
                                         INSTRUCTIONS TO
0136*
                                         SET UP THE DEVICE
0137*
                                         TO INITIATE ONE READING
0138 00055 126054R
                           JMP READ, I
```

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

```
PAGE 0005 001 ** NON-DMS PRIVILEGED DRIVER - PRIVILEGED SECTION **
0139*
3140 *
                        * PRIVILEGED SECTION *
0141*
                        ****************
0142 *
0143*
0144* SAVE STATE OF COMPUTER AT INTERRUPT
0145*
                                        PRIVILEGED SECTION ENTRY POINT
0146
      00055 000000 PXNN NOP
0147*
                          CLF 0
                                        TURN OFF INTERRUPT SYSTEM
0148 00056 103100
0149*
                                        TURN OFF DEPE COMPLETION INTERRUPTS
                          CLC 6
0150
     00057 106706
0151 00060 106707
                          CLC 7
0152*
                                        SAVE REGISTERS
                          STA ASV
0153
      00061 072166R
     00062 076167R
                          STB BSV
0154
      00063 001520
                          ERA, ALS
0 1 5 5
0156
      00064 102201
                          soc
     00065 002004
01:57
                          INA
                          STA EOSY
0158 00066 072170R
0159*
0160 00067 061770
                          LDA MPTFL
                                        SAVE OLD MEMORY PROTECT FLAG
                          STA MPFSV
0161
     00070 072171R
     00071 002404
                          CLA, INA
                                         SET MEMORY PROTECT FLAG TO OFF,
0162
0163 00072 071770
                                        SINCE MEMORY PROTECT IS NOW OFF
                          STA MPTFL
0164*
0165 00073 102100
                          STF 0
                                         TURN INTERRUPT SYSTEM BACK ON
0166*
0167* CHECK FOR SPURIOUS INTERRUPT
0168*
0169 00074 162172R
                          LDA EQ1, I
                                         ACCESS REQUEST LIST POINTER WORD
                                         ISOLATE REQUEST LIST POINTER
0170 00075 012205R
                          AND = B77777
0171 00076 002002
                          SZA
                                         IS A REQUEST IN PROGRESS?
0172 00077 026103R
                          JMP PREAD
                                         YES, GO PROCESS INTERRUPT
0173*
0174 00100 103100
                          CLF 0
                                         NO, TURN OFF INTERRUPT SYSTEM
0175 00101 107700 I.2
0176 00102 026113R
                          CLC SC,C
                                         RESET CONTROLLER, AND
                           JMP EXIT
                                         IGNORE SPURIOUS INTERRUPT BY RETURNING
0177*
0178* PROCESS READ REQUEST
0179*
                   PREAD EQU +
0180 00103
                                         LOAD IN DATA FROM DEVICE
0181 *
                                         VIA CONFIGURED I/O INSTRUCTIONS
0182 *
0 t 83 *
0184*
0185 00103 172164R
                           STA DAPTR, I
                                         STORE WORD IN DATA BUFFER
0186 00104 036163R
                          ISZ CVCTR
                                         IS THIS THE LAST CONVERSION?
0187 00105 002001
                                         N O
                           RSS
                           JMP DONE
                                         YES, GO SET UP TO TERMINATE CALL
0188 00106 026146R
0189*
0190 00107 036164R
                           ISZ DAPTR
                                         NO. SET UP FOR NEXT CONVERSION
$191 00110 016053R
                           JSB READ
                                         INITIATE IT
0192*
0193* RESTORE MACHINE TO ORIGINAL STATE ON INTERRUPT
0194*
```

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

| PAGE                 | 0006  | <b>•</b> 01 **              | NON-DMS     | PRIVILEGED D     | RIVER - PRIVILEGED SECTION **                                               |
|----------------------|-------|-----------------------------|-------------|------------------|-----------------------------------------------------------------------------|
| 1:95                 | ^^111 | 103100                      |             | CLF 0            | TURN OFF INTERRUPT SYSTEM TEMPORARILY                                       |
| 196*                 | 00111 | 103100                      |             | CLF V            | TURN OFF INTERROFT STRIET TERFORMRILL                                       |
| 197                  | 00112 | 103700                      | 1.3         | STC SC.C         | ENCODE DEVICE                                                               |
| 198*                 |       |                             |             |                  |                                                                             |
| 199                  | 00113 | 062171                      | REXIT       | LDA MPFSV        | ACCESS PREVIOUS STATE OF MEMORY PROTE                                       |
| 200                  | 00114 | 002002                      |             | SZA              | WAS MEMORY PROTECT ON?                                                      |
| 201                  | 00115 | 026126                      | R           | JMP EXIT1        | HO, SO DO NOT TURN OH DCPC INTERRUPTS                                       |
| 202*                 |       |                             |             |                  |                                                                             |
|                      |       | 065654                      |             | LDB INTOA        | YES, TURN DOPC COMPLETION INTERRUPTS                                        |
| 204                  |       | 160001                      |             | LDA B, I         | BACK ON IF THEY WERE ON INITIALLY.                                          |
|                      |       | 102706                      |             | SSA<br>STC 6     | ON/OFF STATUS IS INDICATED BY BIT 15<br>OF EACH DCPC ASSIGNMENT WORD IN THE |
|                      |       | 006004                      |             | INB              | INTERRUPT TABLE                                                             |
|                      |       | 160001                      |             | LDA B.I          | INTERRUFT THOLE                                                             |
| 209                  |       | 002020                      |             | SSA              |                                                                             |
| 210                  |       | 102707                      |             | STC 7            |                                                                             |
| 211*                 |       |                             |             |                  |                                                                             |
| 0212                 | 00126 | 062170                      | R EXIT1     | LDA EOSV         | RESTORE E AND O REGISTERS                                                   |
| 213                  |       | 103101                      |             | CLO              |                                                                             |
| 214                  |       | 900036                      |             | SLA, ELA         |                                                                             |
| 215                  |       | 102101                      |             | STF 1            |                                                                             |
| 0216                 |       | 066167                      | R           | LDB BSY          | RESTORE B-REGISTER                                                          |
| 0217*                |       |                             |             |                  | DESTADE MEMORY PROTECT STAD                                                 |
| 0218                 |       | 062171                      |             | LDA MPFSV        |                                                                             |
| 0219<br>0220         |       | 071770<br>  0020 <b>0</b> 2 |             | STA MPTFL<br>SZA | IN BASE PAGE WAS MEMORY PROTECT ON AT INTERRUPT?                            |
| 0220                 |       | 026143                      |             | JMP EXIT2        | NO                                                                          |
| 4222*                |       | , AS D 1 4 3                | ĸ           | OUL EVIIS        | NO                                                                          |
| 0223                 |       | 062166                      | R           | LDA ASV          | YES, RESTORE A-REGISTER                                                     |
| 0224                 |       | 102100                      |             | SIF 0            | TURN ON INTERRUPT SYSTEM                                                    |
| 0225                 |       | 102705                      |             | STC 5            | SET MEMORY PROTECT ON                                                       |
| 0226                 | 00142 | 126055                      | R           | JAP PARRIT       | RETURN TO POINT OF INTERRUPTION                                             |
| 0227*                |       |                             |             |                  |                                                                             |
| 0228                 |       |                             |             |                  | NO, RESTORE A-REGISTER                                                      |
| 0229                 |       | 102100                      |             | STF 0            | TURN ON INTERRUPT SYSTEM                                                    |
| 0230                 | _     | 126055                      | R           | JWB BXHN'I       | RETURN TO POINT OF INTERRUPTION                                             |
| 0231*                |       |                             | ** U.S. *** |                  | COMPLETE THE CALL                                                           |
| 0232*<br>0233*       |       | CODE SE                     | 15 07 18    | 15   TWE ON! IN  | COMPLETE THE CALL                                                           |
| ∨233*<br><b>0234</b> |       | 5 103100                    | DONE        | CLF 0            | TURN OFF THE INTERRUPT SYSTEM                                               |
|                      |       | 7 105700                    |             | CLC SC           | TURN OFF PRIVILEGED DEVICE                                                  |
| Q236                 |       | 003400                      |             | CCA              | SET TIME OUT FOR                                                            |
| 0237                 |       | 172174                      |             | STA EQ15,I       | ONE TICK AND SET                                                            |
| 0238                 |       | 2 162173                    |             | LDA EQ4, I       | BIT12 IN EQT4 SO                                                            |
| 0239                 |       | 3 032175                    |             | IOR BIT12        | RTIOC WILL                                                                  |
| 0240                 |       | 172173                      |             | STA E04, I       | CALL CXNN ON TIME-DUT                                                       |
| 0241                 |       | 5 026113                    |             | JMP EXIT         | GO TO EXIT ROUTINE                                                          |

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

```
PAGE 0007 #01 ** NON-DMS PRIVILEGED DRIVER - COMPLETION SECTION **
0243*
3244*
0245*
                              * COMPLETION SECTION *
0246*
                              *****
0247*
0248 00156 000000 CXNN NOP
                                                  COMPLETION SECTION ENTRY POINT
0249*
0250 00157 002400 CLA NO, SET A = 0 = HORMAL RETURN
0251 00160 165667 LDB E018,I SET B = TRANSMISSION LOG
0252 00161 126156R JMP CXNN,I MAKE COMPLETION RETURN (P+1) TO 10C
```

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

```
PAGE 0008 #01 ** NON-DMS PRIVILEGED DRIVER - DATA AREA **
0254*
)255* CONSTANT AND STORAGE AREA
0256*
0257
      00000
                    Ŕ
                           E 28 0
0258
     00001
                    В
                           EQU 1
0259
      00000
                    S C
                           EQU 0
                                        DUMMY I/O SELECT CODE NUMBER
0260*
0261
      00162 000000 SCODE BSS 1
      00163 000000
                    CVCTR BSS 1
9262
      00164 000000
                    DAPTR BSS 1
0263
0264
      00165 000000
                    FIRST BSS 1
0265
      00166 000000
                    ASV
                           BSS 1
0266
      00167 000000
                    BSV
                           BSS
                    EOSV BSS
0267
      00170 000000
0268
     00171 000000
                    MPFSY BSS 1
0269
     00172 000000
                    ERI
                           BSS 1
0270
     00173 000000
                    E 9.4
                           BSS 1
0271
     00174 000000
                    E015 BSS 1
                    BIT12 OCT 10000
0272
      00175 010000
0273 00176 102500
                    LIA
                           LIS 0
0274*
0275* BASE PAGE COMMUNICATIONS AREA DEFINITION
0276*
     01650
0277
                           EQU 1650B
                    INTBA EQU .+4
0278
     01654
0279
     01660
                    EQT1
                          6.68
                               . +8
     01663
9280
                    EQT4
                           EQU .+11
0281
      01665
                    EQT6
                          EQU .+13
0282
      01666
                    EQT7
                          EQU .+14
0283
     01667
                    EQTS EQU .+15
0284
      01774
                    EQ115 EQU .+84
0285
      01770
                    MPTFL EQU .+80
0286*
0287* CODE TO SET UP JSB $JPNN, I INSTRUCTION ON BASE PAGE
0288*
0289
      00000
                                         RESET LOCATION COUNTER TO BASE PAGE
                           ORB
     00000 000055R $JPNN DEF PXNN
0290
                                         PRIV. SECTION ENTRY POINT ADDR
0291*
0292
      00177
                           ORR
                                         RESET LOCATION COUNTER TO RELOCATABLE
0293
      00177 114000B $JSB JSB $JPNN,I
                                       JSB INSTR. TO PRIV SECTION, INDIRECT
0294*
      00200 167777
      00201 000003
      00202 000001
      00203 003700
      00204 000002
      00205 077777
0295
                           END
** NO ERRORS *TOTAL **RTE ASMB 760924**
```

Figure 4-2. Non-DMS Privileged RTE Driver Example (Continued)

|  |  | \$ |
|--|--|----|
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |
|  |  |    |

## **READER COMMENT SHEET**

RTE Operating System Driver Writing Manual

|                                     |                                                      | 3                 |                           |                     |
|-------------------------------------|------------------------------------------------------|-------------------|---------------------------|---------------------|
|                                     | 92200-93005                                          |                   | July 1981                 |                     |
|                                     | Upo                                                  | date No           | _                         |                     |
|                                     |                                                      | (If Applicable)   |                           |                     |
| We welcome your Please use addition | evaluation of this manual.<br>al pages if necessary. | Your comments and | suggestions help us impro | ve our publications |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   |                           |                     |
|                                     |                                                      |                   | 44-10-                    |                     |
| FROM:                               |                                                      |                   |                           |                     |
| Name                                |                                                      |                   |                           | -                   |
| Company                             |                                                      |                   |                           | -                   |
| Address                             |                                                      |                   |                           | -                   |
|                                     |                                                      |                   |                           |                     |



# **BUSINESS REPLY MAIL**

FIRST CLASS PERMIT NO. 141 CUPERTINO, CA.

- POSTAGE WILL BE PAID BY -

**Hewlett-Packard Company** 

Data Systems Division 11000 Wolfe Road Cupertino, California 95014

ATTN: Technical Marketing Dept.

NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES



FOLD

FOLD

### Arranged alphabetically by country

#### Product Line Sales/Support Key

Key Product Line

Analytical

**CM** Components

C Computer Systems

CP Computer Systems Primary Service Responsible Office (SRO)

CS Computer Systems Secondary SRO

Electronic Instruments & Measurement Systems

**Medical Products** 

MP **Medical Products Primary SRO** 

MS Medical Products Secondary SRO

**Personal Computing Products** 

Sales only for specific product line

Support only for specific product line

IMPORTANT: These symbols designate general product line capability. They do not insure sales or support availability for all products within a line, at all locations. Contact your local sales office for information regarding locations where HP support is available for specific products.

HP distributors are printed in italics.

#### **ANGOLA**

Telectra Empresa Técnica de Equipamentos Eléctricos, S.A.R.L. R. Barbosa Rodrigues, 41-I DT. Caixa Postal 6487 LUANDA Tel: 355 15,355 16 A\*, E, M, P

#### **ARGENTINA**

Hewlett-Packard Argentina S.A. Avenida Santa Fe 2035 Martinez 1640 BUENOS AIRES Tel: 798-5735, 792-1293 Telex: 122443 AR CIGY Cable: HEWPACKARG

Biotron S.A.C.I.v.M Avenida Paseo Colon 221

9 Piso 1399 BUENOS AIRES

A.E.CP.P

Tel: 30-4846, 30-1851, 30-8384 Telex: (33)17595 BIONAR Cable: BIOTRON Argentina

Fate S.A. Electronica Bartolomeu Mitre 833 1036 BUENOS AIRES Tel: 74-41011, 74-49277, 74-43459

Telex: 18137, 22754

#### **AUSTRALIA**

A\*.CM.CS.E.MS.P

A,CM,CS,E,MS,P

Adelaide, South Australia Pty. Ltd.

Hewlett-Packard Australia Ptv.Ltd 153 Greenhill Road PARKSIDE, S.A. 5063 Tel: 272-5911 Telex: 82536 Cable: HEWPARD Adelaide

#### Brisbane, Queensland Office

Hewlett-Packard Australia Pty.Ltd. 5th Floor Teachers Union Building 495-499 Boundary Street SPRING HILL, Queensland 4000 Tel: 229-1544 Telex: 42133 Cable: HEWPARD Brisbane

#### Canberra, Australia Capital Office

Hewlett-Packard Australia Ptv.Ltd. 121 Wollongong Street FYSHWICK, A.C.T. 2069 Tel: 804244 Telex: 62650 Cable: HEWPARD Canberra A\*,CM,CS,E,MS,P

### Melbourne, Victoria Office

Hewlett-Packard Australia Ptv.Ltd. 31-41 Joseph Street BLACKBURN, Victoria 3130 Tel: 89-6351 Telex: 31-024 Cable: HEWPARD Melbourne A.CM.CP.E.MS.P

#### Perth, Western Australia Office

Hewlett-Packard Austalia Pty.Ltd. 141 Stirling Highway
NEDLANDS, W.A. 6009 Tel: 386-5455 Telex: 93859 Cable: HEWPARD Perth

#### Sydney, New South Wales Office

Hewlett-Packard Australia Pty.Ltd. 17-23 Talavera Road NORTH RYDE, N.S.W. 2113 P.O. Box 308 Tel: 887-1611 Telex: 21561 Cable: HEWPARD Sydney

A,CM,CP,E,MS,P

A.CM.CS.E.MS.P

**AUSTRIA** Hewlett-Packard Ges.m.b.h. Grottenhofstrasse 94 Verkaufsburo Graz 8052 GRAZ Tel: 21-5-66 Telex: 32375

CM,C.E. Hewlett-Packard Ges.m.b.h. Wehlistrasse 29 P.O. Box 7

A-1205 VIENNA Tel: (222) 35-16-210 Telex: 135823/135066 A,CM,CP,E,MS,P

#### RAHRAIN

Green Salon P.O. Box 557 RAHRAIN Tel: 5503 Telex: 884 19 Wael Pharmacy P.O. Box 648 RAHRAIN

Tel: 54886, 56123 Telex: 8550 WAEL GJ

#### BELGIUM

Hewlett-Packard Belgium S.A./N.V. Bivd de la Woluwe, 100 Woluwedal B-1200 BRUSSELS Tel: (02) 762-32-00 Telex: 23-494 paloben bru A,CM,CP,E,MP.P

#### BRAZIL

Hewlett-Packard do Brasil I.e.C. I Ida Alameda Rio Negro, 750 ALPHAVILLE 06400 Barueri SP

Tel: 421-1311 Telex: 011 23602 HPBR-BR Cable: HEWPACK Sao Paulo

A.CM.CP.E.MS Hewlett-Packard do Brasil I.e.C.

Ltda. Avenida Epitacio Pessoa, 4664 22471 RIO DE JANEIRO-RJ

Tel: 286-0237 Telex: 021-21905 HPBR-BR Cable: HEWPACK Rio de Janeiro A.CM.E.MS.P

### BURUNDI

Typomeca S.P.R.L. B.P. 553 BUJUMBURA Tel: 2659

#### CANADA

#### Alberta

Hewlett-Packard (Canada) Ltd. 210, 7220 Fisher Street S.E. CALGARY, Alberta T2H 2H8 Tel: (403) 253-2713 Telex: 610-821-6141 A,CM,CP,E\*,MS,P\* Hewlett-Packard (Canada) Ltd.

11620A-168th Street EDMONTON, Alberta T5M 3T9 Tel: (403) 452-3670 Telex: 610-831-2431

A,CM,CP,E,MS,P

**British Columbia** Hewlett-Packard (Canada) Ltd. 10691 Shellbridge Way RICHMOND, British Columbia V6X 2W7

Tel: (604) 270-2277 Telex: 610-922-5059 A.CM.CP.E\*.MS.P\*

#### Manitoba

Hewlett-Packard (Canada) Ltd. 380-550 Century Street WINNIPEG, Manitoba R3H 0Y1 Tel: (204) 786-6701 A,CM,CS,E,MS,P\*

Nova Scotia

Hewlett-Packard (Canada) Ltd. P.O. Box 931 900 Windmill Road DARTMOUTH, Nova Scotia B2Y 3Z6 Tel: (902) 469-7820 Telex: 610-271-4482 CM,CP,E\*,MS,P\*

#### Ontario

Hewlett-Packard (Canada) Ltd. 552 Newbold Street LONDON, Ontario N6E 2S5 Tel: (519) 686-9181 Telex: 610-352-1201 A.CM.CS.E\*.MS.P\*

Hewlett-Packard (Canada) Ltd. 6877 Goreway Drive MISSISSAUGA, Ontario L4V 1M8 Tel: (416) 678-9430 Telex: 610-492-4246 A,CM,CP,E,MP.P

Hewlett-Packard (Canada) Ltd. 1020 Morrison Drive OTTAWA, Ontario K2H 8K7 Tel: (613) 820-6483 Telex: 610-563-1636

#### Quebec

A.CM.CP.E\*.MS.P\*

Hewlett-Packard (Canada) Ltd. 17500 South Service Road Trans-Canada Highway KIRKLAND, Quebec H9J 2M5 Tel: (514) 697-4232 Telex: 610-422-3022 A,CM,CP,E,MP,P

#### CHILE

Jorge Calcagni y Cia. LIda. Arturo Burhie 065 Casilla 16475 SANTIAGO 9 Tel: 220222 Telex: JCALCAGNI A.CM.E.M Olympia (Chile) Ltd. Rodrico de Araya 1045

Casilla 256-V SANTIAGO 21 Tel: 25-50-44

Telex: 40-565

### **COLOMBIA**

Instrumentación H. A. Langebaek & Kier S.A. Aparlado Aéreo 6287 BOGOTÁ 1, D.E. Carrera 7 No. 48-75 BOGOTA, 2 D.E. Tel: 287-8877 Telex: 44400 Cable: AARIS Bogola A,CM,E,M,P

### **COSTA RICA**

Cientifica Costarricense S.A. Avenida 2, Calle 5 San Pedro de Montes de Oca Apartado 10159 SAN JOSÉ Tel: 24-38-20, 24-08-19 Telex: 2367 GALGUR Cable: GALGUR CM.E.M

#### **CYPRUS**

Telerexa Ltd. P.O. Box 4809 14C Stassinos Avenue NICOSIA Tel: 45628 Telex: 2894 E,**M**,P

#### **CZECHOSLOVAKIA**

Hewlett-Packard Obchodni Zastupitelstvi v CSSR Post. schranka 27 CS-118 01 PRAHA 011 Tel: 66-296 Telex: 121353 IHC

#### DENMARK

Hewlett-Packard A/S Datavei 52 DK-3460 BIRKEROD Tel: (02) 81-66-40 Telex: 37409 hpas dk A CM CP F MS P Hewlett-Packard A/S Navervei 1 DK-8600 SILKEBORG

Tel: (06) 82-71-66

Telex: 37409 hpas dk

CM CS F

**ECUADOR** CYEDE Cia. Ltda. P.O. Box 6423 CCI Avenida Eloy Alfaro 1749 **O**UITO Tel: 450-975, 243-052

Telex: 2548 CYEDE ED Cable: CYEDE-Quito A CM E.P.

Hospitalar S.A. Casilla 3590 Robles 625 **O**UITO

Tel: 545-250, 545-122 Cable: HOSPITALAR-Quito

#### **EGYPT**

Samitro Sami Amin Trading Office 18 Abdel Aziz Gawish ABDINE-CAIRO Tel: 24-932

International Engineering Associates 24 Hussein Hegazi Street

Kasr-el-Aini CAIRO Tel: 23-829 Telex: 93830

Informatic For Computer Systems 22 Talaal Harb Street CAIRO Tel: 759006

Telex: 93938 FRANK UN

#### **EL SALVADOR**

IPESA Boulevard de los Heroes Edificio Sarah 1148 SAN SALVADOR Tel: 252787 A.C.CM.E.P

#### **FINLAND**

Hewlett-Packard Oy Revontulentie 7 SF-02100 ESP00 10 Tel: (90) 455-0211 Telex: 121563 hewpa sf A,CM,CP,E,MS,P

#### FRANCE

Hewlett-Packard France Le Ligoures Bureau de Vente de Aix-en-Provence Place Romée de Villeneuve F-13090 AIX-EN-PROVENCE Tel: (42) 59-41-02 Telex: 410770F A,CM,CS,E,MS,P\*



### Arranged alphabetically by country

FRANCE (Cont.) Hewlett-Packard France Boile Postale No. 503 F-25026 BESANCON 28 Rue de la Republique F-25000 BESANCON Tel: (81) 83-16-22 C.M

Hewlett-Packard France Bureau de Vente de Lyon Chemin des Mouilles Boite Postale No. 162 F-69130 ECULLY Cédex Tel: (78) 33-81-25 Telex: 310617F A,CM,CP,E,MP

Hewlett-Packard France Immeuble France Evry Tour Lorraine Boulevard de France F-91035 EVRY Cédex Tel: (60) 77-96-60 Telex: 692315F CM.E

Hewlett-Packard France 5th Avenue Raymond Chanas F-38320 EYBENS Tel: (76) 25-81-41 Telex: 980124 HP GRENOB EYBE

CM,CS

Hewlett-Packard France Bâtiment Ampère Rue de la Commune de Paris Boite Postale 300 F-93153 LE BLANC MESNIL Tel: (01) 865-44-52 Telex: 211032F CM,CP,E,MS

Hewlett-Packard France Le Montesquieu Avenue du President JF Kennedy F-33700 MERIGNAC Tel: (56) 34-00-84 Telex: 550105F CM,CP,E,MS

Hewlett-Packard France 32 Rue Lothaire F-57000 METZ Tel: (87) 65-53-50 CM.CS

Hewlett-Packard France F-91947 Les Ulis CédexORSAY Tel: (1) 907-78-25 Telex: 600048F A,CM,CP,E,MP,P

Hewlett-Packard France Paris Porte-Maillot 13, 15 25 Boulevard De L'Amiral Bruix F-75782 PARIS Cédex 16 Tel: (01) 502-12-20 Telex: 613663F CM,CP,MS,P

Hewlett-Packard France 2 Allee de la Bourgonette F-35100 RENNES Tel: (99) 51-42-44 Telex: 740912F CM,CS,E,MS,P\*

Hewlett-Packard France 4 Rue Thomas Mann Boite Postale 56 F-67200 STRASBOURG Tel: (88) 28-56-46 Telex: 890141F CM,CS,E,MS,P\*

Hewlett-Packard France 20 Chemin de la Cénière F-31081 TOULOUSE Cédex Tel: (61) 40-11-12 Telex: 531639F A,CM,CS,E,P1

Hewlett-Packard France Bureau de Vente de Lille Immeuble Péricentre Rue Van Gooh F-59650 VILLENEUVE D'ASQ Tel: (20) 91-41-25 Telex: 160124F CM,CS,E,MS,P\*

#### **GERMAN FEDERAL** REPUBLIC

Hewlett-Packard GmbH Technisches Büro Berlin Keithstrasse 2-4 D-1000 BERLIN 30 Tel: (030) 24-90-86 Telex: 018 3405 hpbin d A,CM,CS,E,X,M,P

Hewlett-Packard GmbH Technisches Büro Böblingen Herrenberger Strasse 110 D-7030 BÖBLINGEN Tel: (07031) 667-1 Telex: 07265739 bbn or 07265743 A,CM,CP,E,MP,P

Hewlett-Packard GmbH Technisches Büro Dusseldorf Emanuel-Leutze-Strasse 1 D-4000 DUSSELDORF Tel: (0211) 5971-1 Telex: 085/86 533 hpdd d A,CM,CP,E,MS,P

Hewlett-Packard GmbH Vertriebszentrale Frankfurt Berner Strasse 117 Postfach 560 140 D-6000 FRANKFURT 56 Tel: (0611) 50-04-1 Telex: 04 13249 hpffm d A,CM,CP,E,MP,P

Hewlett-Packard GmbH Technisches Büro Hamburg Kapstadtring 5 D-2000 HAMBURG 60 Tel: (040) 63804-1 Telex: 21 63 032 hphh d A,CM,CP,E,MS,P

Hewlett-Packard GmbH Technisches Büro Hannover Am Grossmarkt 6 D-3000 HANNOVER 91 Tel: (0511) 46-60-01 Telex: 092 3259 A,CM,CS,E,MS,P

Hewlett-Packard GmbH Technisches Büro Mannheim Rosslauer Weg 2-4 D-6800 MANNHEIM Tel: (621) 70050 Telex: 0462105 A.C.E

Hewlett-Packard GmbH Technisches Büro Neu Ulm Messerschmittstrasse 7 D-7910 NEU ULM Tel: Telex: C.E

Hewlett-Packard GmbH Technisches Büro Nürnberg Neumeyerstrasse 90 D-8500 NÜRNBERG Tel: (0911) 56-30-83 Telex: 0623 860 CM,CS,E,MS,P

Hewlett-Packard GmbH Technisches Büro München Eschenstrasse 5 D-8021 TAUFKIRCHEN Tel: (089) 6117-1 Telex: 0524985 A,CM,CP,E,MS,P

#### **GREAT BRITAIN**

Hewlett-Packard Ltd. Trafalgar House Navigation Road ALTRINCHAM Chesire WA14 1NU Tel: (061) 928-6422 Telex: 668068 A,C,E,M

Hewlett-Packard Ltd. Oakfield House, Oakfield Grove Clifton BRISTOL BS8 2BN Tel: 36806 Telex: 444302

Hewlett-Packard Ltd. 14 Wesley Street CASTLEFORD Yorkshire WF10 1AE Tel: (0977) 550016 Telex: 5557355

Hewlett-Packard Ltd. Fourier House 257-263 High Street LONDON COLNEY Herts., AL2 1HA Tel: (0727) 24400 Telex: 1-8952716 C.E

Hewlett-Packard Ltd Tradax House, St. Mary's Walk MAIDENHEAD Berkshire, SL6 1ST

Tel: (0628) 39151 E,P

Hewlett-Packard Ltd. 308/314 Kings Road READING, Berkshire Tel: 61022 Telex: 84-80-68 CM,P

Hewlett-Packard Ltd. Quadrangle 106-118 Station Road REDHILL, Surrey Tel: (0737) 68655 Telex: 947234 C,E Hewlett-Packard Ltd. Westminster House 190 Stratford Road SHIRLEY, Solihull

West Midlands B90 3BJ Tel: (021) 7458800 Telex: 339105

Hewlett-Packard Ltd. King Street Lane WINNERSH, Wokingham Berkshire RG11 5AR Tel: (0734) 784774 Telex: 847178 A.C.E.M

### GREECE

Kostas Karavnnis 8 Omirou Street ATHENS 133 Tel: 32-30-303, 32-37-371 Telex: 21 59 62 RKAR GR E.M.P

"Plaiso" G. Gerados 24 Stournara Street ATHENS Tel: 36-11-160 Telex: 21 9492

#### **GUATEMALA**

**IPESA** Avenida Reforma 3-48 Zona 9 **GUATEMALA CITY** Tel: 316627, 314786, 664715 Telex: 4192 Teletro Gu A,C,CM,E,M,P

#### HONG KONG

Hewlett-Packard Hong Kong, Ltd. G.P.O. Box 795 5th Floor, Sun Hung Kai Centre 30 Harbour Road HONG KONG

Tel: 5-8323211 Telex: 66678 HEWPA HX Cable: HP ASIA LTD Hong Kong

Schmidt & Co. (Hong Kong) Ltd. Wing On Centre, 28th Floor Connaught Road, C. HONG KONG Tel: 5-455644 Telex: 74766 SCHMX HX A.M

#### **ICELAND**

Elding Trading Company Inc. Hafnarnvoli-Tryggvagolu P.O. Box 895 IS-REYKJAVIK Tel: 1-58-20, 1-63-03

#### INDIA

Blue Star Ltd. Bhavdeen Sladium Road AHMEDABAD 380 014 Tel: 42932 Telex: 012-234 Cable: BLUEFROST

Blue Star Ltd. 11 Magarath Road BANGALORE 560 025 Tel: 55668 Telex: 0845-430 Cable: BLUESTAR A,CM,C,E Rive Star Ltd. Band Box House Prabhadevi

BOMBAY 400 025 Tel: 422-3101 Telex: 011-3751 Cable: BLUESTAR A,M Blue Star Lid.

Sahas

Prabhadevi BOMBAY 400 025 Tel: 422-6155 Telex: 011-4093 Cable: FROSTBLUE A,CM,C,E,M Blue Star Ltd. 7 Hare Street

414/2 Vir Savarkar Marg

CALCUTTA 700 001 Tel: 12-01-31 Telex: 021-7655 Cable: BLUESTAR A,M

Blue Star Ltd. Meenakshi Mandiram XXXXV/1379-2 M. G. Road COCHIN 682-016 Tel: 32069 Telex: 085-514 Cable: BLUESTAR

Blue Star Ltd. 133 Kodambakkam High Road MADRAS 600 034 Tel: 82057 Telex: 041-379 Cable: BLUESTAR A.M

Blue Star Ltd. Bhandari House, 7th/8th Floors 91 Nehru Place NEW DELHI 110 024 Tel: 682547 Telex: 031-2463 Cable: BLUESTAR A,CM,C,E,M Blue Star Ltd.

1-1-117/1 Sarojini Devi Road SECUNDERABAD 500 033 Tel: 70126 Telex: 0155-459 Cable: BLUEFROST A.E

Blue Star Ltd. T.C. 7/603 Poornima Maruthankuzhi TRIVANDRUM 695 013 Tel: 65799 Telex: 0884-259 Cable: BLUESTAR

#### **INDONESIA**

BERCA Indonesia P.T. P.O.Box 496/Jkl. Jin. Abdul Muis 62 JAKARTA Tel: 373009 Telex: 31146 BERSAL IA Cable: BERSAL JAKARTA A,C,E,M,P BERCA Indonesia P.T. P.O. Box 174/Sby J.L. Kulei No. 11 SUBAEE-SURABAYA Tel: 68172 Telex: 31146 BERSAL SD Cable: BERSAL-SURABAYA A \*,E,M,P

Hewlett-Packard Trading S.A. Mansoor City 9B/3/7 BAGHDAD Tel: 551-49-73 Telex: 2455 HEPAIRAQ IK

#### **IRELAND** Hewlett-Packard Ireland Ltd. Kestrel House

Clanwilliam Court Lower Mount Street DUBLIN 2, Eire Tel: 680424, 680426 Telex: 30439 A,C,CM,E,M,F Cardiac Services Ltd. Kilmore Road Artane DUBLIN 5, Eire Tel: (01) 35 1820 Telex: 30439

### Arranged alphabetically by country

#### **ISRAEL**

Electronics Engineering Division Motorola Israel Ltd. 16 Kremenetski Street P.O. Box 25016 TEL-AVIV 67899 Tel: 338973 Telex: 33569 Motil IL Cable: BASTEL Tel-Aviv A,CM,C,E,M,P

#### ITALY

Hewlett-Packard Italiana S.p.A. Traversa 99C Giulio Petrone, 19 I-70124 BARI Tel: (080) 41-07-44

Hewlett-Packard Italiana S.p.A. Via Martin Luther King, 38/111 1-40132 BOLOGNA Tel: (051) 402394 Telex: 511630 CM,CS,E,MS

Hewlett-Packard Italiana S.p.A. Via Principe Nicola 43G/C I-95126 CATANIA Tel: (095) 37-10-87 Telex: 970291 C.P

Hewlett-Packard Italiana S.p.A. Via G. Di Vittorio 9 1-20063 CERNUSCO SUL NAVLIGLIO Tel: (2) 903691 Telex: 334632 A,CM,CP,E,MP,P

Hewlett-Packard Italiana S.p.A. Via Nuova san Rocco A Capodimonte, 62/A 1-80131 NAPOLI Tel: (081) 7413544 A,CM,CS,E

Hewlett-Packard Italiana S.p.A. Viale G. Modugno 33 I-16156 GENOVA PEGLI Tel: (010) 68-37-07 E,C

Hewlett-Packard Italiana S.p.A. Via Turazza 14 1-35 100 PADOVA Tel: (49) 664888 Telex: 430315 A,CM,CS,E,MS

Hewlett-Packard Italiana S.p.A. Viale C. Pavese 340 I-00144 ROMA Tel: (06) 54831 Telex: 610514 A,CM,CS,E,MS,P\*

Hewlett-Packard Italiana S.p.A. Corso Giovanni Lanza 94 I-10133 TORINO Tel: (011) 682245, 659308 Telex: 221079 CM.CS.E.

#### **JAPAN**

Yokogawa-Hewlett-Packard Ltd. Inque Building 1348-3, Asahi-cho ATSUGI, Kanagawa 243 Tel: (0462) 24-0451 CM.C\*.E

Yokogawa-Hewlett-Packard Ltd. 3-30-18 Tsuruya-cho Kanagawa-ku, Yokohama-Shi KANAGAWA, 221 Tel: (045) 312-1252 Telex: 382-3204 YHP YOK CM.CS.E

Yokogawa-Hewlett-Packard Ltd. Sannomiya-Daiichi Seimei-Bldg. 5F 69 Kyo-Machi Ikuta-Ku KOBE CITY 650 Japan Tel: (078) 392-4791

Yokogawa-Hewlett-Packard Ltd. Kumagaya Asahi Yasoji Bldg 4F 4-3 Chome Tsukuba KUMAGAYA, Saitama 360 Tel: (0485) 24-6563 CM,CS,E

Yokogawa-Hewlett-Packard Ltd. Mito Mitsui Building 4-73, San-no-maru, 1-chome MITO, Ibaragi 310 Tel: (0292) 25-7470 CM.CS.E

Yokogawa-Hewlett-Packard Ltd. Sumitomo Seimei Bldg 11-2 Shimo-sasaiima-cho Nakamura-ku NAGOYA, Aichi 450 Tel: (052) 581-1850 CM.CS.E.MS

Yokogawa-Hewlett-Packard Ltd. Chuo Bidg., 4th Floor 5-4-20 Nishinakajima, 5-chome Yodogawa-ku, Osaka-shi **OSAKA**, 532 Tel: (06) 304-6021 Telex: YHPOSA 523-3624

A,CM,CP,E,MP,P\* Yokogawa-Hewlett-Packard Ltd. 29-21 Takaido-Higashi 3-chome Suginami-ku TOKYO 168 Tel: (03) 331-6111 Telex: 232-2024 YHPTOK A,CM,CP,E,MP,P\*

#### **JORDAN**

Mouasher Cousins Company P.O. Box 1387 AMMAN Tel: 24907, 39907 Telex: 21456 SABCO JO

### **KOREA**

Samsung Electronics 4759 Shinkil, 6 Dong Youngdeungpo-Ku, Tel: 8334311, 8334312 Telex: SAMSAN 27364 A.C.E.M.P

#### KUWAIT

Al-Khalidya Trading & Contracting P.O. Box 830 Safat KUWAIT Tel: 42-4910, 41-1726 Telex: 2481 Areeg kl A.E.M Photo & Cine Equipment P.O. Box 270 Safat KUWAIT Tel: 42-2846, 42-3801 Telex: 2247 Matin

### **LUXEMBOURG**

Hewlett-Packard Belgium S.A./N.V. Blvd de la Woluwe, 100 Woluwedal B-1200 BRUSSELS Tel: (02) 762-32-00 Telex: 23-494 paloben bru A,CM,CP,E,MP,P

#### MALAYSIA

Hewlett-Packard Sales (Malaysia) Sdn Bhd Suite 2.21/2.22 Bangunan Angkasa Raya Jaian Ampang KUALA LUMPUR Tel: 483544 Telex: MA31011 A,CP,E,M,P Protel Engineering Lot 319, Salok Rd. P.O. Box 1917 KUCHING, SARAWAK Tel: 535-44 Telex: MA 70904 Promal Cable: Proteleng AEM

#### **MEXICO**

Hewlett-Packard Mexicana, S.A. de Avenida Periferico Sur No. 6501 Tepepan, Xochimilco MEXICO CITY 23, D.F. Tel: (905) 676-4600 Telex: 017-74-507 A,CP,E,MS,P Hewlett-Packard Mexicana, S.A. de Rio Volga 600

Colonia del Valle MONTERREY, N.L. Tel: 78-42-93, 78-42-40, 78-42-41 Telex: 038-410

#### MOROCCO Dolbeau

81 rue Karalchi CASABLANCA Tel: 3041-82, 3068-38 Telex: 23051, 22822 Gerep

2 rue d'Agadir Boite Postale 156 CASARLANCA Tel: 272093 272095 Telex: 23 739

#### **NETHERLANDS** Hewlett-Packard Nederland B.V.

Van Heuven Goedhartiaan 121

NL 1181KK AMSTELVEEN P.O. Box 667 NL 1080 AR AMSTELVEEN Tel: (20) 47-20-21 Telex: 13 216 A,CM,CP,E,MP,P Hewlett-Packard Nederland B.V. Bongerd 2 NL 2906VK CAPPELLE, A/D ljessel P.O. Box 41 NL2900 AA CAPELLE, Ijssel Tel: (10) 51-64-44 Telex: 21261 HEPAC NL A,CM,CP

#### **NEW ZEALAND**

Hewlett-Packard (N.Z.) Ltd. 169 Manukau Road P.O. Box 26-189 Epsom, AUCKLAND Tel: 68-7159 Cable: HEWPACK Auckland CM,CS,E,P\*

Hewlett-Packard (N.Z.) Ltd. 4-12 Cruickshank Street P.O. Box 9443 Kilbirnie, WELLINGTON 3 Tel: 877-199 Cable: HEWPACK Wellington CM,CP,E,P

Northrop Instruments & Systems Eden House, 44 Khyber Pass Road P.O. Box 9682 Newmarket, AUCKLAND Tel: 794-091

Northrop Instruments & Systems Terrace House, 4 Oxford Terrace P.O. Box 8388 CHRISTCHURCH

Northrop Instruments & Systems Sturdee House 85-87 Ghuznee Street P.O. Box 2406 WELLINGTON Tel: 850-091 Telex: NZ 3380 A,M

#### **NIGERIA**

Tel: 64-165

A.M

N6B/S70 Oyo Road Oluseun House P.M.B. 5402 IBADAN Tel: 461577 Telex: 31231 TEIL NG A, E, M, PThe Electronics Instrumentations 144 Agege Motor Road, Mushin P.O. Box 6645

The Electronics Instrumentations

#### **NORTHERN IRELAND**

Cardiac Services Company 95A Finaghy Road South BELFAST BT 10 OBY Tel: (0232) 625-566 Telex: 747626

### NORWAY

Mushin, LAGOS

A.E.M.P

Hewlett-Packard Norge A/S Folke Bernadottesvei 50 P.O. Box 3558 N-5033 FYLLINGSDALEN (BERGEN) Tel: (05) 16-55-40 Telex: 16621 hpnas n CM,CS,E Hewlett-Packard Norge A/S Oesterndalen 18

P.O. Box 34 N-1345 OESTERAAS Tel: (02) 17-11-80 Telex: 16621 hpnas n A\*,CM,CP,E,MS,P

#### OMAN Khimji Ramdas P.O. Box 19

MUSCAT Tel: 72-22-17, 72-22-25 Telex: 3289 BROKER MB MUSCAT

#### **PAKISTAN**

Mushko & Company Ltd. 10. Bazar Road Sector G-6/4 ISLAMABAD Tel: 28624 Cable: FEMUS Rawalpindi

Mushko & Company Ltd. Oosman Chambers Abdullah Haroon Road KARACHI 0302 Tel: 511027, 512927 Telex: 2894 MUSHKO PW Cable: COOPERATOR Karachi A.E.M.P

#### PANAMA

Electrónico Balboa, S.A. Apartado 4929 Panama 5 Calle Samuel Lewis Edificio "Alfa" No. 2 CIUDAD DE PANAMA Tel: 64-2700 Telex: 3480380 Cable: ELECTRON Panama A,CM,E,M,P Foto Internacional, S.A. P.O. Box 2068 Free Zone of Colon COLON 3 Tel: 45-2333 Telex: 3485126

#### **PERU** Cómpania Electro Médica S.A.

Los Flamencos 145. San Isidro Casilta 1030 LIMA 1 Tel: 41-4325 Telex: Pub. Booth 25424 SISIDRO Cable: ELMED Lima A.CM.E.M.P

Cable: IMPORT COLON/Panama

### **PHILIPPINES**

The Online Advanced Systems Corporation Rico House, Amorsolo Cor. Herrera Street Legaspi Village, Makati P.O. Box 1510 Metro MANILA Tel: 85-35-81, 85-34-91, 85-32-21 Telex: 3274 ONLINE A, C, E, MElectronic Specialists and

690-B Epifanio de los Santos Avenue Cubao, QUEZON CITY P.O. Box 2649 Manila

Tel: 98-96-81, 98-96-82, 98-96-83 Telex: 742-40287

#### **POLAND**

Proponents Inc.

Buro Informasji Technicznej Hewlett-Packard Ul Slawki 2, 6P PLOO-950 WARSZAWA Tel: 39-59-62, 39-67-43 Telex: 812453 hepa pl



### Arranged alphabetically by country

#### PORTUGAL

Telectra-Empresa Técnica de Equipmentos Eléctricos S.a.r.l. Rua Rodrigo da Fonseca 103 P.O. Box 2531 P-LISBON 1 Tel: (19) 68-60-72 Telex: 12598 A,C,E,P

#### Mundinlei

Intercambio Mundial de Comércio S.a.r.l P.O. Box 2761 Avenida Antonio Augusto de Aguiar 138

P-LISBON Tel: (19) 53-21-31, 53-21-37 Telex: 16691 munter p

#### **PUERTO RICO**

Hewlett-Packard Puerto Rico P.O. Box 4407 CAROLINA, Puerto Rico 00630 Calle 272 Edificio 203 Urb. Country Club RIO PIEDRAS, Puerto Rico 00924 Tel: (809) 762-7255 Telex: 345 0514

#### **QATAR**

Nasser Trading & Contracting P.O. Box 1563 DOHA Tel: 22170 Telex: 4439 NASSER

Scilecharabia P.O. Box 2750 !'DOHA Tel: 329515 Telex: 4806 CMPARB

#### **ROMANIA**

Hewlett-Packard Reprezentanta Boulevard Nicolae Balcescu 16 BUCURESTI Tel: 130725

Telex: 10440

#### SAUDI ARABIA

Modern Electronic Establishment P.O. Box 193 AL-KHOBAR

Tel: 44-678, 44-813 Telex: 670136 Cable: ELECTA AL-KHOBAR C.E.M.P

Modern Electronic Establishment P.O. Box 1228, Baghdadiah Street JEDDAH

Tel: 27-798 Telex: 401035 Cable: ELECTA JEDDAH C.E.M.P

Modern Electronic Establishment P.O. Box 2728 RIYADH Tel: 62-596, 66-232

Telex: 202049 C.E.M.P

#### SCOTLAND

Hewlett-Packard Ltd. Royal Bank Buildings Swan Street BRECHIN, Angus, Scotland Tel: 3101, 3102 CM.CS

Hewlett-Packard Ltd SOUTH QUEENSFERRY West Lothian, EH30 9TG GB-Scotland Tel: (031) 3311000 Telex: 72682

#### **SINGAPORE**

A.CM.E.M

Hewlett-Packard Singapore (Pty.) P.O. Box 58 Alexandra Post Office SINGAPORE, 9115 6th Floor, Inchcape House 450-452 Alexandra Road SINGAPORE 0511 Tel: 631788 Telex: HPSGSO RS 34209 Cable: HEWPACK, Singapore A,CP,E,MS,P

#### **SOUTH AFRICA**

Hewlett-Packard South Africa (Pty.) P.O. Box 120 Howard Place Pine Park Center, Forest Drive, Pinelands CAPE PROVINCE 7450 Tel: 53-7955, 53-7956, 53-7957

Telex: 57-0006 A,CM,CS,E,MS,P

Hewlett-Packard South Africa (Pty.) P.O. Box 37066 Overport

**DURBAN 4067** Tel: 28-4178, 28-4179, 28-4110

Hewlett-Packard South Africa (Pty.) P.O. Box 33345

Glenstantia 0010 TRANSVAAL 1st Floor East Constantia Park Ridge Shopping Centre

Constantia Park PRETORIA Tel: 98-1126 or 98-1220 Telex: 32163

Hewlett-Packard South Africa (Pty.)

Daphny Street Private Bag Wendywood SANDTON 2144

Tel: 802-5111, 802-5125 Telex: 89-84782 Cable: HEWPACK Johannesburg A,CM,CP,E,MS,P

#### SPAIN Hewlett-Packard Española S.A.

c/Entenza, 321 E-BARCELONA 29 Tel: (3) 322-24-51, 321-73-54 Telex: 52603 hpbee A.CM,CP,E,MS,P Hewlett-Packard Española S.A. c/San Vicente S/N Edificio Albia II,7 B E-BILBAO 1 Tel: (944) 423-8306, 423-8206 A,CM,E,MS Hewlett-Packard Española S.A.

Calle Jerez 3 E-MADRID 16 Tel: 458-2600 Telex: 23515 hpe A,CM,E,MP,P

Hewlett-Packard Española S.A. Colonia Mirasierra Edificio Juban c/o Costa Brava 13, 2. E-MADRID 34 Tel: 734-8061, 734-1162

CM,CP Hewlett-Packard Española S.A. Av Ramón y Cajal 1-9 Edificio Sevilla 1, E-SEVILLA 5 Tel: 64-44-54, 64-44-58 Telex: 72933 A,CM,CS,MS,P Hewlett-Packard Española S.A.

C/Ramon Gordillo, 1 (Entlo.3) E-VALENCIA 10 Tel: 361-1354, 361-1358

CM,CS,P

#### SWEDEN

Hewlett-Packard Sverige AB Enighetsvägen 3, Fack P.O. Box 20502 S-16120 BROMMA Tel: (08) 730-0550 Telex: (854) 10721 MESSAGES Cable: MEASUREMENTS STOCKHOLM A,CM,CP,E,MS,P

Hewlett-Packard Sverige AB Sunnanvagen 14K S-22226 LUND Tel: (46) 13-69-79 Telex: (854) 10721 (via BROMMA office) CM.CS

Hewlett-Packard Sverige AB Vastra Vintergatan 9 S-70344 OREBRO Tel: (19) 10-48-80 Telex: (854) 10721 (via BROMMA office) CM,CS

Hewlett-Packard Sverige AB Frötallisgatan 30 S-42132 VÄSTRA-FRÖLUNDA Tel: (031) 49-09-50 Telex: (854) 10721 (via BROMMA office) CM,CS,E,P

#### SWITZERLAND

Hewlett-Packard (Schweiz) AG Clarastrasse 12 CH-4058 BASLE Tel: (61) 33-59-20 A.CM

Hewlett-Packard (Schweiz) AG 47 Avenue Blanc CH-1202 GENEVA Tel: (022) 32-30-05, 32-48-00 CM CP

Hewlett-Packard (Schweiz) AG 29 Chemin Château Bloc CH-1219 LE LIGNON-Geneva Tel: (022) 96-03-22 Telex: 27333 hpag ch Cable: HEWPACKAG Geneva A,CM,E,MS,P

Hewlett-Packard (Schweiz) AG Zurcherstrasse 20 Allmend 2 CH-8967 WIDEN Tel: (57) 50-111 Telex: 59933 hpag ch Cable: HPAG CH A.CM.CP.E.MS.P

#### SYRIA

General Electronic Inc. Nuri Basha-Ahnat Ebn Kays Street P.O. Box 5781 DAMASCUS Tel: 33-24-87 Telex: 11215 ITIKAL Cable: ELECTROBOR DAMASCUS

Sawah & Co. Place Azmé Boile Postale 2308 DAMASCUS

Tel: 16-367, 19-697, 14-268 Telex: 11304 SATACO SY Cable: SAWAH, DAMASCUS

### **TAIWAN**

Hewlett-Packard Far East Ltd. Kaohsiung Branch 68-2, Chung Cheng 3rd Road Shin Shin, Chu KAOHSIUNG Tel: 24-2318, 26-3253

CS.E.MS.P Hewlett-Packard Far East Ltd. Taiwan Branch 5th Floor 205 Tun Hwa North Road TAIPEI Tel:(02) 751-0404 Cable:HEWPACK Taipei

A.CP.E.MS.P Hewlett-Packard Far East Ltd. Taichung Branch #33, Cheng Yih Street 10th Floor, Room 5 TAICHUNG

Tel: 289274 Ing Lih Trading Co. 3rd Floor 18, Po-la Road TAIPEI

Tel: Telex Cable: INGLIH TAIPEI

### **THAILAND**

UNIMESA Co. Ltd. Floom Research Building 2538 Sukhumvil Ave Bangchak, BANGKOK Tel: 393-2387, 393-0338 Telex: TH81160, 82938, 81038 Cable: UNIMESA Bangkok A,C,E,M

Bangkok Business Equipment Ltd. 5/5-6 Dejo Road BANGKOK Tel: 234-8670, 234-8671,

234-8672 Cable: BUSIQUIPT Bangkok

### TRINIDAD & TOBAGO

Caribbean Telecoms Ltd. P.O. Box 732 50/A Jerningham Avenue PORT-OF-SPAIN Tel: 624-4213, 624-4214 A.CM.E.M.P

#### **TUNISIA**

Tunisie Electronique 31 Avenue de la Liberte **TUNIS** Tel: 280-144 E.P

Corema 1 ter. Av. de Carthage TUNIS Tel: 253-821 Telex: 12319 CABAM TN

#### TURKEY

Teknim Company Ltd. Riza Sah Pehievi Caddesi No. 7 Kavaklidere, ANKARA Tel: 275800 Telex: 42155

EMA, Muhendislik Kolleklif Sirkeli Mediha Eldem Sokak 41/6 YUksel Caddesi, ANKARA Tel: 17-56-22 Cable: Emalrade

#### UNITED ARAB EMIRATES

Emilac LId. P.O. Box 1641 SHARJAH Tel: 354121, 354123 Telex: 68 136 E.M.P.C

#### UNITED KINGDOM

see: GREAT BRITAIN NORTHERN IRELAND SCOTLAND

#### UNITED STATES

Alabama Hewlett-Packard Co. 700 Century Park South Suite 128 BIRMINGHAM, AL 35226

Tel: (205) 822-6802 CM,CS,MP

Hewlett-Packard Co. P.O. Box 4207 8290 Whitesburg Drive, S.E. HUNTSVILLE, AL 35802 Tel: (205) 881-4591 CM,CP,E,M\*

### Alaska

Hewlett-Packard Co. 1577 "C" Street, Suite 252 ANCHORAGE, AK 99510 Tel: (206) 454-3971 CM.CS\*

#### Arizona

Hewlett-Packard Co. 2336 East Magnolia Street PHOENIX, AZ 85034 Tel: (602) 273-8000 A.CM.CP.E.MS Hewlett-Packard Co. 2424 East Aragon Road TUCSON, AZ 85702 Tel: (602) 889-4631

### CM, CS, E, MS Arkansas

Hewlett-Packard Co. P.O. Box 5646 Brady Station LITTLE ROCK, AR 72215 Tel: (501) 376-1844, (501) 664-8773 CM MS

### Arranged alphabetically by country

#### **UNITED STATES (Cont.)**

California

Hewlett-Packard Co. 7621 Canoga Avenue CANOGA PARK, CA 91304 Tel: (213) 702-8300 A,CM,CP,E,P

Hewlett-Packard Co. 1579 W. Shaw Avenue FRESNO, CA 93771 Tel: (209) 224-0582 CM.MS

Hewlett-Packard Co. 1430 East Orangethorpe FULLERTON, CA 92631 Tel: (714) 870-1000 CM.CP.E.MP

Hewlett-Packard Co. 5400 W. Rosecrans Boulevard LAWNDALE, CA 90260 P.O. BOX 92105 LOS ANGELES, CA 90009 Tei: (213) 970-7500 CM,CP,MP

Hewlett-Packard Co. 3939 Lankershim Blvd. NORTH HOLLYWOOD, CA 91604 Tel: (213) 877-1282 Regional Headquarters

Hewlett-Packard Co. 3200 Hillview Avenue PALO ALTO, CA 94304 Tel: (415) 857-8000 CM,CP,E

Hewlett-Packard Co. 646 W. North Market Boulevard SACRAMENTO, CA 95834 Tel: (916) 929-7222 A\*,CM,CP,E,MS

Hewlett-Packard Co. 9606 Aero Drive P.O. Box 23333 SAN DIEGO, CA 92123 Tel: (714) 279-3200 CM,CP,E,MP

Hewlett-Packard Co. 3003 Scott Boulevard SANTA CLARA, CA 95050 Tel: (408) 988-7000 A,CM,CP,E,MP

Hewlett-Packard Co. 454 Cariton Court SO. SAN FRANCISCO, CA 94080 Tel: (415) 877-0772 CM.CP

Colorado Hewlett-Packard Co. 24 Inverness Place, East ENGLEWOOD, CO 80112 Tel: (303) 771-3455 A.CM.CP.E.MS

Connecticut
Hewlett-Packard Co.
47 Barnes Industrial Road South
P.O. Box 5007
WALLINGFORD, CT 06492
Tel: (203) 265-7801
A,CM,CP.E.MS

Florida Hewlett-Packard Co. P.O. Box 24210 2727 N.W. 62nd Street FORT LAUDERDALE, FL 33309 Tel: (305) 973-2600 CM.CP.E.MP

Hewlett-Packard Co. 4080 Woodcock Drive, #132 Brownett Building JACKSONVILLE, FL 32207 Tel: (904) 398-0663 CM,C\*,E\*,IMS\*\* Hewlett-Packard Co. P.O. Box 13910 6177 Lake Ellenor Drive ORLANDO, FL 32809 Tel: (305) 859-2900 A,CM,CP,E,MS

Hewlett-Packard Co. 6425 N. Pensacola Blvd. Suite 4, Building 1 PENSACOLA, FL 32575 Tel: (904) 476-8422 A,CM,MS

Hewlett-Packard Co. 110 South Hoover, Suite 120 Vanguard Bidg. TAMPA, FL 33609 Tel: (813) 872-0900 A\*,CM,CS,E\*,M\*

Georgia Hewlett-Packard Co. P.O. Box 105005 2000 South Park Place ATLANTA, GA 30339 Tel: (404) 955-1500

Telex: 810-766-4890

A,CM,CP,E,MP Hewlett-Packard Co. Executive Park Suite 306 P.O. Box 816 AUGUSTA, GA 30907 Tel: (404) 736-0592 CM,MS

Hewlett-Packard Co. P.O. Box 2103 1172 N. Davis Drive WARNER ROBINS, GA 31098 Tel: (912) 922-0449 CM F

Hawaii

Hewlett-Packard Co. Kawaiahao Plaza, Suite 190 567 South King Street HONOLULU, HI 96813 Tel: (808) 526-1555 A,CM,CS,E,MS

Idaho Hewlett-Packard Co. 11311 Chinden Boulevard BOISE, ID 83707 Tel: (208) 376-6000 CM.CS.M\*

illinois Hewleti-Packard Co. 211 Prospect Road BLOOMINGTON, IL 61701 Tel: (309) 663-0383 CM CS MS\*\*

Hewlett-Packard Co. 1100 31st Street DOWNERS GROVE, IL 60515 Tel: (312) 960-5760 CM CP

Hewlett-Packard Co. 5201 Tollview Drive ROLLING MEADOWS, IL 60008 Tel: (312) 255-9800 A,CM,CP,E,MP

Indiana Hewiett-Packard Co. P.O. Box 50807 7301 No. Shadeland Avenue INDIANAPOLIS, IN 46250 Tel: (317) 842-1000 A,CM,CS,E.MS

Hewlett-Packard Co. 2415 Heinz Road IOWA CITY, IA 52240 Tel: (319) 351-1020 CM,CS,E\*,MS Kansas

Hewlett-Packard Co. 1644 S. Rock WICHITA, KA 67207 Tel: (316) 265-5200 CM CS

Kentucky

Hewlett-Packard Co. 10170 Linn Station Road Suite 525 LOUISVILLE, KY 40223 Tel: (502) 426-0100 A.CM.CS.MS

Louisiana Hewlett-Pack

Hewlett-Packard Co. P.O. Box 1449 3229 Williams Boulevard KENNER, LA 70062 Tel: (504) 443-6201 A,CM,CS,E,MS

Marvland

Hewlett-Packard Co. 7121 Standard Drive HANOVER, MD 21076 Tel: (301) 796-7700 A.CM.CP.E.MS

Hewlett-Packard Co. 2 Choke Cherry Road ROCKVILLE, MD 20850 Tel: (301) 948-6370 Telex: 710-828-9685 A.CM.CP.E.MP

Massachusetts Hewlett-Packard Co. 32 Hartwell Avenue

32 Hartwell Avenue **LEXINGTON**, MA 02173 Tel: (617) 861-8960 A,CM,CP,E,MP

Michigan

Hewlett-Packard Co. 23855 Research Drive FARMINGTON HILLS, MI 48024 Tel: (313) 476-6400 A,CM,CP,E,MP Hewlett-Packard Co. 4326 Cascade Road S.E. GRAND RAPIDS, MI 49506

Tel: (616) 957-1970 CM,CS,MS Minnesota Hewlett-Packard Co.

Hewlett-Packard Co. 2025 W. Larpenteur Ave. ST. PAUL, MN 55113 Tel: (612) 644-1100 A,CM,CP,E,MP

Mississippi Hewiett-Packard Co. P.O. Box 5028 322 N. Mart Plaza JACKSON, MS 39216 Tel: (601) 982-9363 CM.MS

Missouri Hewlett-Packard Co. 11131 Colorado Avenue KANSAS CITY, MO 64137 Tel: (816) 763-8000 Telex: 910-771-2087 A,CM,CS,E,MS

Hewlett-Packard Co. 1024 Executive Parkway ST. LOUIS, MO 63141 Tel: (314) 878-0200 A,CM,CP,E,MP Nebraska

Hewlett-Packard 7101 Mercy Road Suite 101, IBX Building OMAHA, NE 68106 Tel: (402) 392-0948 CM MS

Nevada

Hewlett-Packard Co. Suite D-130 5030 Paradise Blvd. LAS VEGAS, NV 89119 Tel: (702) 736-6610 CM.MS\*\*

**New Jersey** 

Hewlett-Packard Co. Crystal Brook Professional Building Route 35 EATONTOWN, NJ 07724

A\*,CM,C\*,E\*,P\* Hewlett-Packard Co. W120 Century Road PARAMUS, NJ 07652 Tel: (201) 265-5000

Tel: (201) 542-1384

A,CM,CP,E,MP Hewlett-Packard Co. 60 New England Avenue West PISCATAWAY, NJ 08854 Tel: (201) 981-1199 A.CM,CP,E

**New Mexico** 

Hewlett-Packard Co. P.O. Box 11634 11300 Lomas Blvd., N.E. ALBUQUERQUE, NM 87123 Tel: (505) 292-1330 Telex: 910-989-1185 CM.CP.E.MS

New York Hewlett-Packard Co. 5 Computer Drive South ALBANY, NY 12205 Tel: (518) 458-1550 Telex: 710-444-4691

A,CM,CS,E,MS Hewlett-Packard Co. 9600 Main Street CLARENCE, NY 14031 Tel: (716) 759-8621 Telex: 710-523-1893

Hewlett-Packard Co. 200 Cross Keys Office FAIRPORT, NY 14450 Tel: (716) 223-9950 Telex: 510-253-0092 CM,CP,E,MS

Hewlett-Packard Co. No. 1 Pennsylvania Plaza 55th Floor 34th Street & 8th Avenue NEW YORK, NY 10119 Tel: (212) 971-0800 CM.CP.E\* M\*

Hewlett-Packard Co. 5858 East Molloy Road SYRACUSE NY 13211 Tel: (315) 455-2486 A.CM.CS.E.MS

Hewlett-Packard Co. 3 Crossways Park West WOODBURY, NY 11797 Tel: (516) 921-0300 Telex: 510-221-2183 A.CM.CP.E.MS

North Carolina Hewlett-Packard Co.

Hewlett-Packard Co. P.O. Box 15579 2905 Guess Road (27705) DURHAM, NC 27704 Tel: (919) 471-8466 C,M Hewlett-Packard Co. 5605 Roanne Way GREENSBORO, NC 27409 Tel: (919) 852-1800 A,CM,CP,E,MS

Ohio

Hewlett-Packard Co. 9920 Carver Road CINCINNATI, OH 45242 Tel: (513) 891-9870 CM,CP,MS

Hewlett-Packard Co. 16500 Sprague Road CLEVELAND, OH 44130 Tel: (216) 243-7300 Telex: 810-423-9430 A,CM,CP,E,MS

Hewlett-Packard Co. 962 Crupper Ave. COLUMBUS, OH 43229 Tel: (614) 436-1041 CM,CP,E\*

Hewlett-Packard Co. 330 Progress Rd. DAYTON, OH 45449 Tel: (513) 859-8202 A,CM,CP,E\*,MS

Oklahoma

Hewlett-Packard Co. P.O. Box 366 1503 W. Gore Bivd., Suite #2 LAWTON, OK 73502 THI (405) 248-4248

Hewlett-Packard Co. P.O. Box 32008 304 N. Meridan Avenue, Suite A OKLAHOMA CITY, OK 73107 Tel: (405) 946-9499 A\*,CM,CP,E\*,MS Hewlett-Packard Co. Suite 121

Suite 121 9920 E. 42nd Street TULSA, OK 74145 Tel: (918) 665-3300 A\*\*,CM,CS,M\*

Oregon

Hewleti-Packard Co. 1500 Valley River Drive, Suite 330 EUGENE, OR 97401 Tel: (503) 683-8075

Hewlett-Packard Co. 9255 S. W. Pioneer Court WILSONVILLE, OR 97070 Tel: (503) 682-8000 A,CM,CP,E\*,MS

Pennsylvania Hewlett-Packard Co.

1021 8th Avenue King of Prussia Industrial Park KING OF PRUSSIA, PA 19406 Tel: (215) 265-7000 Telex: 510-660-2670 A,CM,CP,E,MP

Hewlett-Packard Co. 111 Zeta Drive PTTTSBURGH, PA 15238 Tel: (412) 782-0400 A,CM,CP,E,MP

South Carolina Hewlett-Packard Co. P.O. Box 6442 6941-0 N. Trenholm Road COLUMBIA, SC 29260 Tel: (803) 782-6493 CM.CS.E.MS

### Arranged alphabetically by country

#### **UNITED STATES (Cont.)**

South Carolina (Cont.) Hewlett-Packard Co. 814 Wade Hampton Blvd. Suite 10

GREENVILLE, SC 29609 Tel: (803) 232-0917

#### Tennessee

Hewlett-Packard Co. P.O. Box 22490 224 Peters Road Suite 102 KNOXVILLE, TN 37922 Tel: (615) 691-2371 A\*.CM.MS

Hewlett-Packard Co. 3070 Directors Row MEMPHIS, TN 38131 Tel: (901) 346-8370 A,CM,CS,MS

Hewlett-Packard Co. Suite 103 478 Craighead Street NASHVILLE, TN 37204 Tel: (615) 383-9136 CM,MS\*

Hewlett-Packard Co. Suite 310W 7800 Shoalcreek Blvd. AUSTIN, TX 78757 Tel: (512) 459-3143

Hewlett-Packard Co. Suite C-110 4171 North Mesa EL PASO, TX 79902 Tel: (915) 533-3555 CM,CS,E\*,MS\*

Hewlett-Packard Co. 5020 Mark IV Parkway FORT WORTH, TX 76106 Tel: (817) 625-6361 CM.C'

Hewlett-Packard Co. P.O. Box 42816 10535 Harwin Street HOUSTON, TX 77036 Tel: (713) 776-6400 A,CM,CP,E,MP

Hewlett-Packard Co 3309 67th Street Suite 24 LUBBOCK, TX 79413 Tel: (806) 799-4472

Hewlett-Packard Co. P.O. Box 1270 930 E. Campbell Rd. RICHARDSON, TX 75081 Tel: (214) 231-6101 A.CM,CP,E,MP

Hewlett-Packard Co. 205 Billy Mitchell Road SAN ANTONIO, TX 78226 Tel: (512) 434-8241 CM,CS,E,MS

Utah Hewlett-Packard Co. 3530 W. 2100 South Street SALT LAKE CITY, UT 84119

Tel: (801) 974-1700 A.CM.CP.E.MS Virginia

Hewlett-Packard Co. P.O. Box 9669

2914 Hungary Spring Road RICHMOND, VA 23228 Tel: (804) 285-3431 A,CM,CP,E,MS

Hewlett-Packard Co P.O. Box 4786 3110 Peters Creek Road, N.W. ROANOKE, VA 24015 Tel: (703) 563-2205 CM,CS,E\*\*

Hewlett-Packard Co. P.O. Box 12778 5700 Thurston Avenue Suite 111

VIRGINIA BEACH, VA 23455 Tel: (804) 460-2471 CM,CS,MS

#### Washington

Hewlett-Packard Co. 15815 S.E. 37th Street BELLEVUE, WA 98006 Tel: (206) 643-4000 A.CM.CP.E.MP Hewlett-Packard Co. Suite A 708 North Argonne Road SPOKAN", WA 99206 Tel: (509) 922-7000

### West Virginia

CM CS

Hewlett-Packard Co. 4604 MacCorkle Ave., S.E. CHARLESTON, WV 25304 Tel: (304) 925-0492 A,CM,MS

#### Wisconsin

Hewlett-Packard Co. 150 S. Sunny Slope Road BROOKFIELD, WI 53005 Tel: (414) 784-8800 A.CM.CS.E . MP

#### URUGUAY

Pablo Ferrando S.A.C. e.l. Avenida Italia 2877 Casilla de Correo 370 MONTEVIDEO Tel: 403102 Telex: 901 Public Booth Para Pablo Ferrando 919520 Cable: RADIUM Montevideo A, CM, E, M

Guillermo Kraft del Uruguay S.A. Avda. Libertador Brig. Gral. Lavalleja 2083 MONTE VIDEO

Tel: 234588, 234808, 208830 Telex: 6245 ACTOUR UY

#### U.S.S.R.

Hewlett-Packard Co. Representative Office Pokrovsky Blvd. 4/17 KV12 MOSCOW 101000 Tel: 294-2024 Telex: 7825 HEWPACK SU

#### **VENEZUELA**

Hewlett-Packard de Venezuela C.A. Apartado 50933 3A Transversal Los Ruices Norte Edificio Segre 2Y3 CARACAS 1071 Tel: 239-4133, 239-4777, 239-4244 Telex: 25146 HEWPACK Cable: HEWPACK Caracas

#### YUGOSLAVIA

A,CP,E,MS,P

Iskra-Commerce-Representation of Hewlett-Packard Sava Centar Delegacija 30 Milentija Popovica 9 11170 BEOGRAD Tel: 638-762 Telex: 12042, 12322 YU SAV CEN Iskra-Commerce-Representation of Hewlett-Packard Koprska 46 6 1000 LJUBLJANA Tel: 321674, 315879 Telex:

#### ZAMRIA

R. J. Tilbury (Zambia) Ltd. P.O. Box 2792 LUSAKA Tel: 81243 A.E.M.P

#### ZIMBABWE

Field Technical Sales 45 Kelvin Road, North P.B. 3458 SALISBURY Tel C,E,M,P

#### **FOR COUNTRIES AND** AREAS NOT LISTED:

#### CANADA

#### Ontario

Hewlett-Packard (Canada) Ltd. 6877 Goreway Drive MISSISAUGA, Ontario L4V 1M8 Tel: (416) 678-9430 Telex: 610-492-4246

#### **EASTERN USA**

#### Marvland

Hewlett-Packard Co. 4 Choke Cherry Road Rockville MD 20850 Tel: (301) 258-2000

#### MIDWESTERN USA

#### Illinois

Hewlett-Packard Co. 5201 Tollview Drive **ROLLING MEADOWS, IL 60008** Tel: (312) 255-9800

#### SOUTHERN USA

#### Georgia

Hewlett-Packard Co. P.O. Box 105005 450 Interstate N. Parkway ATLANTA, GA 30339 Tel: (404) 955-1500

#### **WESTERN USA**

#### California

Hewlett-Packard Co. 3939 Lankersim Blvd LOS ANGELES, CA 91604 Tel: (213) 877-1282

#### FUROPEAN AREAS NOT LISTED, CONTACT

#### SWITZERLAND

Hewlett-Packard S.A 7 Rue du Bois-du-Lan CH-1217 MEYRIN 2, Switzerland Tel: (022) 83-81-11 Telex: 27835 hose Cable: HEWPACKSA Geneve

#### **EAST EUROPEAN AREAS** NOT LISTED, CONTACT

#### **AUSTRIA**

Hewlett-Packard Ges.m.b.h. Wehlistrasse 29 P.O. Box 7 A-1205 VIENNA Tel: (222) 35-16-210 Telex: 135823/135066

#### MEDITERRANEAN AND MIDDLE EAST AREAS NOT LISTED, CONTACT

#### GREECE

Hewlett-Packard S.A. Mediterranean & Middle East Operations 35, Kolokotroni Street Platia Kefallariou GR-Kifissia, ATHENS, Greece Tel: 808-0359, 808-0429 Telex: 21-6588 Cable: HEWPACKSA Athens

#### INTERNATIONAL AREAS NOT LISTED, CONTACT

#### **OTHER AREAS**

Hewlett-Packard Co Intercontinental Headquarters 3495 Deer Creek Road PALO ALTO, CA 94304 Tel: (415) 857-1501 Telex: 034-8300 Cable: HEWPACK

