SY26-3823-1 File No. S370-30

# Systems

-

# **OS/VS2 I/O Supervisor Logic**

VS2 Release 1



## Second Edition (March 1973)

This edition replaces the previous edition (numbered SY26-3823-0) and makes that edition obsolete.

This edition applies to Release 1.6 of OS/VS2 and to all subsequent releases of that system unless otherwise indicated in new editions or technical newsletters.

Significant technical and editorial changes made in this edition are outlined in "Summary of Amendments" following the list of figures. Each technical change is marked by a vertical line to the left of the change.

Information in this publication is subject to significant change. Any such changes will be published in new editions or technical newsletters. Before using the publication, consult the latest *IBM System/360 and System/370 Bibliography*, GA22-6822, and the latest *IBM System/370 Advanced Function Bibliography*, GC20-1763, and the technical newsletters that amend those bibliographies, to learn which editions and technical newsletters are applicable and current.

Requests for copies of IBM publications should be made to the IBM branch office that serves you.

Forms for readers' comments are provided at the back of this publication. If the forms have been removed, comments may be addressed to IBM Corporation, Programming Center—Publishing, Department D58, Monterey and Cottle Roads, San Jose, California 95193. All comments become the property of IBM.

© Copyright International Business Machines Corporation 1972, 1973

# PREFACE

This publication, when used with the program listings, enables you to understand the internal operation of the I/O supervisor and to makes changes to it when necessary.

This publication does not replace the program listings; it supplements them and makes the information in them more accessible. This publication has the following sections:

- "Introduction," which contains information about the I/O supervisor's services and overall operation.
- "Method of Operation," which contains diagrams that describe the operation of the I/O supervisor. The diagrams are high-level and are designed to guide you to a particular area of the program listing.
- "Program Organization." which contains a functional organization chart for each of the main functions of the I/O supervisor, and describes what each routine does.
- "Directories," which contains cross-reference lists that include a data area directory, module directory, and routine directory.
- "Data Areas," which contains descriptions of the interrelationship and content of data areas and control blocks that are used primarily by the I/O supervisor.
- "Diagnostic Aids," which contains information to help you interpret the program listings and diagnose program failures.
- "Appendix A: Supporting SVC Routines," which contains information about supporting SVC routines.
- "Appendix B: Alternate Path Retry," which contains information about the alternate path selective retry option and its relationship to the I/O supervisor.
- "Appendix C: Direct-Access Volume Verification," which contains information about the direct-access volume verification option and its relationship to the I/O supervisor.
- "Appendix D: Dynamic Device Reconfiguration," which contains information about the dynamic device reconfiguration option and its relationship to the I/O supervisor.
- "Appendix E: Program Check Recovery Subroutine," which contains information about the program check recovery subroutine.
- "Appendix F: Shared Direct-Access Storage Device," which contains information about the shared direct-access storage device option and its relationship to the I/O supervisor.
- "Appendix G: I/O Supervisor—OLTEP Synchronizing Module (IECIOCTS)," which contains the requirements of the Online Test Executive Program for the I/O supervisor.
- "Appendix H: Device-Dependent Error Routines," which describes device-dependent error routines and contains information about writing error recovery messages to the operator.
- "Glossary of Terms, Acronyms, and Abbreviations," which contains definitions of terms used in this publication along with the meanings of the acronyms and abbreviations used.

## How to Use This Publication

Before using this publication, read the "Introduction" to establish perspective, and then at least scan the remainder of the publication to familiarize yourself with its content. This publication is primarily a reference manual because each section contains a specific type of information. You will be better able to service the program when you can refer quickly to the section containing the type of information you need.

The "Method of Operation" section contains diagrams, each consisting of two pages. The first page (left or upper) is the actual diagram. The second page (right or lower) consists of expanded text and references to other diagrams and flowcharts. The diagrams are at a high level; therefore, some of the I/O supervisor functions are not shown. The routine directory (see "Directories" can be used to find entry points into the routines that are not included in the diagrams.

### **Referenced System and Data Management Publications**

The following publications (listed in order-number order) are referenced throughout this publication:

- OS/VS Recovery Management Logic, GC27-7239
- OS/VS2 Planning and Use Guide, GC28-0600
- OS/VS Data Management for System Programmers, GC28-0631
- OS/VS2 Debugging Guide, GC28-0632
- OS/VS Service Aids, GC28-0633
- OS/VS Utilities, GC35-0005
- OS/VS Message Library: VS2 System Messages, GC38-1002
- OS/VS Message Library: VS2 System Codes, GC38-1008
- OS/VS2 Supervisor Logic, SY27-7244
- OS/VS2 System Data Areas, SY28-0606
- OS/VS OLTEP Logic, SY28-0637
- OS/VS SYS1.LOGREC Error Recording Logic, SY28-0639

Other OS/VS publications are listed in the IBM System/360 and System/370 Bibliography, GA22-6822.

# CONTENTS

### Page

### iii Preface

- iv How to Use This Publication
- iv Referenced System and Data Management Publications

#### vii Figures

### ix Summary of Amendments

- ix Release 1.6
- ix CCW Translation Header BEBLK
- ix IOS Support of 3333 Disk Storage and Control

#### 1 Introduction

- 1 The User and the I/O Supervisor
- 3 The Page Supervisor and VS Subsystems
- 3 The I/O Supervisor and the Control Program
- 6 The I/O Supervisor
- 8 Concept of Logical Channels

#### 11 Method of Operation

### 47 Program Organization

- 47 Description of Routines
- 53 Directories
- 53 Data Area Directory
- 57 Module Directory
- 63 Routine Directory

### 65 Data Areas

- 67 Data Area Layouts
- 67 Alternate Path Table
- 68 Appendage Vector Table
- 68 BEBLK (Beginning-End-Block)
- 69 Channel Address Word
- 70 Channel Command Word
- 71 CCW Translation Header BEBLK
- 73 Channel Error Block Table
- 74 Channel Status Word
- 75 Channel Table
- 76 Device Statistics Table
- 79 Device Table

5

- 80 Indirect Address List
- 81 Logical Channel Word
- 83 Page Fix List
- 84 Program Controlled Interrupt Modify Parameter List
- 84 Program Status Word
- 86 Request Queue Element
- 88 Start Input/Output Extend Parameter List
- 88 Volume Statistics Table

### Page

- 91 Diagnostic Aids
- 91 General Register Assignments
- 91 System Completion Codes
- 93 Problem Determination Area
- 94 Patch Area at IECINT
- 94 Generalized Trace Facility

### 97 Appendix A: Supporting SVC Routines

- 97 Purge Routine (SVC 16)
- 99 Removing Elements From Logical Channel Queues
- 99 Removing Elements From the Supervisor's Request Block Queues
- 99 Removing Elements From the Supervisor's Asynchronous Exit Queues
- 100 The IOB Chain
- 101 The Quiesce Option
- 102 Purging A Virtual I/O Request
- 102 Restore Routine (SVC 17)
- 102 DEVTYPE Routine (SVC 24)
- 103 IOHALT Routine (SVC 33)
- 103 VOLSTAT Routine (SVC 91)
- 104 TCB EXCP (SVC 92) (TSO only)
- 104 Extended SVC Routine (SVC 109)

#### 105 Appendix B: Alternate Path Retry

- 105 The Selective Retry Function
- 105 The Vary Path Functions
- 107 Appendix C: Direct-Access Volume Verification
- 109 Appendix D: Dynamic Device Reconfiguration
- 111 Appendix E: Program Check Recovery Subroutine
- 113 Appendix F: Shared Direct-Access Storage Device
- 115 Appendix G: I/O Supervisor-OLTEP Synchronizing Module (IECIOLTS)
- 117 Appendix H: Device-Dependent Error Routines
- 117 Writing Error Recovery Messages to the Operator
- 118 Individual Routines
- 119 1052 Error Routine
- 121 1287 and 1288 Error Routines
- 124 1403 and 1443 Error Routines
- 126 1419 and 1275 Error Routines
- 129 2501 and 2520 Error Routines
- 131 2250 Error Routine
- 133 2260 and 1053 Error Routines
- 135 2305, 2314, 2319, 3330, and 3333 Error Routines
- 139 2400 and 3400 Tape Series Error Routines
- 146 2495 Error Routine
- 148 2540 Error Routine
- 150 3211 Error Routine
- 153 3505 and 3525 Error Routines
- 157 Glossary of Terms, Acronyms, and Abbreviations
- 161 Index

٤

C

Page

| 0  |        |            |                                                      |
|----|--------|------------|------------------------------------------------------|
| 2  | Figure | 1.         | The User and the I/O Supervisor                      |
| 4  | Figure | 2.         | Characteristics of I/O Requesters                    |
| 5  | Figure | 3.         | The I/O Supervisor and the Control Program           |
| 6  | Figure | 4.         | I/O Supervision                                      |
| 7  | Figure | 5.         | I/O Supervisor Functions                             |
| 8  | Figure | 6.         | Logical Channel-Physical Channel Relationships       |
| 12 | Figure | 7.         | I/O Supervisor                                       |
| 14 | Figure | 8.         | EXCP Supervisor                                      |
| 16 | Figure | 9.         | Validity Check Routine                               |
| 18 | Figure | 10.        | Get Request Element Routine                          |
| 20 | Figure | 11.        | Start I/O Routine for Tape                           |
| 20 | Figure | 12.        | Start I/O Routine for DASD                           |
|    | -      | 12.        | SIO Subroutine                                       |
| 24 | Figure | 13.<br>14. | Post Start I/O Routine                               |
| 26 | Figure |            |                                                      |
| 28 | Figure | 15.        | Page Fix Routine<br>CCW Translator                   |
| 30 | Figure | 16.        |                                                      |
| 32 | Figure | 17.        | I/O Interruption Supervisor (Part 1)                 |
| 34 | Figure | 18.        | I/O Interruption Supervisor (Part 2)                 |
| 36 | Figure | 19.        | Channel Restart Routine                              |
| 38 | Figure | 20.        | Channel Search Routine                               |
| 40 | Figure | 21.        | Sense Subroutine                                     |
| 42 | Figure | 22.        | Error Routine Interface                              |
| 44 | Figure | 23.        | Error EXCP Routine                                   |
| 48 | Figure | 24.        | Functional Organization, EXCP Supervisor             |
| 49 | Figure | 25.        | Functional Organization, I/O Interruption Supervisor |
| 50 | Figure | 26.        | Functional Organization, Error EXCP Supervisor       |
| 54 | Figure | 27.        | Data Area Directory                                  |
| 58 | Figure | 28.        | Module Directory                                     |
| 63 | Figure | 29.        | Routine Directory                                    |
| 66 | Figure | 30.        | Data Area Relationships                              |
| 67 | Figure | 31.        | Alternate Path Table                                 |
| 68 | Figure | 32.        | Appendage Vector Table                               |
| 69 | Figure | 33.        | Beginning-End-Block                                  |
| 70 | Figure | 34.        | Channel Address Word                                 |
| 70 | Figure | 35.        | Channel Command Word                                 |
| 72 | Figure | 36.        | CCW Translation Header BEBLK                         |
| 73 | Figure | 37.        | Translation Control Blocks                           |
| 74 | Figure | 38.        | Channel Error Block Table                            |
| 74 | Figure | 39.        | Channel Error Block Table Entry                      |
| 75 | Figure | 40.        | Channel Status Word                                  |
| 76 | Figure | 41.        | Channel Table                                        |
| 76 | Figure | 42.        | Channel Table Entry                                  |
| 77 | -      | 43.        |                                                      |
| 78 | Figure | 44.        | Device Statistics Table Entries                      |
| 79 | Figure | 45.        |                                                      |
| 80 | Figure | 46.        |                                                      |
| 81 | Figure | 47.        | •                                                    |
| 82 | Figure | 48.        | Logical Channel Queues                               |
| 82 | Figure | 49.        | Logical Channel Word                                 |
| 83 | Figure | 50.        | Page Fix List                                        |
| 84 | Figure | 51.        | PCI Modify Parameter List Entry                      |
|    | 0      |            |                                                      |

- 85 Figure 52. Program Status Word87 Figure 53. Request Queue Element

### Page

| 88   | Figure     | 54. | SIO Extend Parameter List                                                  |
|------|------------|-----|----------------------------------------------------------------------------|
| 89   | Figure     | 55. | Volume Statistics Table Entry                                              |
| 91   | Figure     | 56. | General Register Assignments                                               |
| 92   | Figure     | 57. | System Completion Codes for I/O Operations                                 |
| 95   | Figure     | 58. | GTF Interfaces                                                             |
| 96   | Figure     | 59. | Purge Routine Parameter List                                               |
| 99   | Figure     | 60. | Quiesce I/O Parameter List                                                 |
| 100  | Figure     | 61. | Purge Routine                                                              |
| 101  | Figure     | 62. | Purge Routine IOB Chain                                                    |
| 105  | Figure     | 63. | Vary Path Command Processing                                               |
| 111  | Figure     | 64. | Operation of PCRS During a Program Check                                   |
| 116  | Figure     | 65. | IECIOLTS Addressing Scheme and Bit Settings                                |
| 120  | Figure     | 66. | 1052 Error Analysis Sequence (Module IGE0000D)                             |
| 120  | Figure     | 67. | 1052 Sense Bits, IOB Flags, and IOB Error Counts                           |
| 122  | Figure     | 68. | 1287 and 1288 Error Analysis Sequence                                      |
| 123  | Figure     | 69. | 1287 and 1288 Sense Bits, IOB Flags, and IOB Error Counts                  |
| 124  | Figure     | 70. | 1403 and 1443 Error Analysis Sequence (Module IGE0000G)                    |
| 125  | Figure     | 71. | 1403 and 1443 Sense Bits, IOB Flags, and IOB Error Counts                  |
| 127  | Figure     | 72. | 1419/1275 Error Analysis Sequence (Module IGE0011E)                        |
| 128  | Figure     | 73. | 1419/1275 Sense Bits, IOB Flags, and IOB Error Counts                      |
| 130  | Figure     | 74. | 2501, and 2520 Error Analysis Sequence (Module IGE0000E)                   |
| 131  | Figure     | 75. | 2501 and 2520 Sense Bits, IOB Flags, and IOB Error Counts                  |
| 132  | Figure     | 76. | 2250 Error Analysis Sequence (Module IGE0010A)                             |
| 133  | Figure     | 77. | 2250 Sense Bits, IOB Flags, and IOB Error Counts                           |
| 134  | Figure     | 78. | 2260 and 1053 Error Analysis Sequence (Load 1–IGE0010B or Load 2–IGE0100B) |
| 135  | Figure     | 79. | 2260 and 1053 Sense Bits, IOB Flags, and IOB Error Counts                  |
| 137  | Figure     | 80. | 2314 and 2319 Error Analysis Sequence (Module IEC23XXF)                    |
| 138  | Figure     | 81. | 2305, 3330, and 3333 Error Analysis Sequence (Module IEC23XXF)             |
| 140  | Figure     | 82. | 2305, 2314, 2319, 3330, and 3333 Sense Bits, IOB Flags, and IOB            |
|      | U          |     | Error Counts                                                               |
| 141  | Figure     | 83. | 2400/3400 Error Analysis Sequence (Load 1-IGE00001, Load                   |
|      | -          |     | 2-IGE0100I, Load 3-IGE0200I, Load 4-IGE0300I, Load                         |
|      |            |     | 5-IGE0400I, or Load 6-IGE0900I)                                            |
| 142  | Figure     | 84. | 2400/3400 Sense Bits, IOB Flags, and IOB Error Counts                      |
| 147  | Figure     | 85. | 2495 Error Analysis Sequence (Module IGE0011A)                             |
| 147  | Figure     | 86. | 2495 Sense Bits, IOB Flags, and IOB Error Counts                           |
| 149  | Figure     | 87. | 2540 Error Analysis Sequence (Load 1–IGE0001C or Load                      |
| 1.50 | <b>D</b> : | 0.0 | 2–IGE0101C)                                                                |
| 150  | Figure     | 88. | 2540 Sense Bits, IOB Flags, and IOB Error Counts                           |
| 151  | Figure     | 89. | 3211 Sense Bits, IOB Flags, and IOB Error Counts                           |
| 153  | Figure     | 91. | 3505/3525 Error Analysis Sequence (Module IGE0001A)                        |
| 154  | Figure     | 92. | 3505/3525 Sense Bits, IOB Flags, and IOB Error Counts                      |

# SUMMARY OF AMENDMENTS

# Release 1.6

## **CCW Translation Header BEBLK**

The CCW translation header block has been deleted and a new data area, the CCW translation header BEBLK, has been added. The CCW translation header BEBLK combines the functions of the old data areas, the CCW translation header block and the BEBLK. (Note that the addresses of the real CCWs have been deleted from the BEBLK.) If the channel program requires a second BEBLK (other than the header BEBLK), the format of the BEBLK will be the same as that described in the "Data Areas" section under BEBLK (Beginning-End Block).

The TSTHDR field of the RQE now points to the page fix list before translation, and to the CCW translation header BEBLK during and after translation.

### IOS Support of the IBM 3333 Disk Storage and Control

IOS now fully supports the IBM 3333 Disk Storage and Control. The 3333 is functionally equivalent to the 3330 Disk Storage. All references to the 3330 also apply to the 3333.

• 

# **INTRODUCTION**

Following execution of the statements or instructions written by programmers to cause I/O activity, a sequence of events begins in which the I/O supervisor plays a major role. This section defines that role and describes the environment in which it is performed.

An I/O operation can be described as the sequence of events beginning with the execution of the statement or instruction a programmer writes to cause data to be written on or read from an I/O device, and ending when all related activity is completed. Although the I/O supervisor plays a major role in an I/O operation, it is not the only control program element involved. This section establishes the scope and objectives of the I/O supervisor.

# The User and the I/O Supervisor

Three methods a programmer can use to request an I/O operation are shown in Figure 1. The actions taken by the I/O supervisor in satisfying the request are shown below the horizontal line that divides the figure. Specific input data must always be provided to the I/O supervisor, but the extent to which the programmer must define that input data depends upon how he requests the I/O operation.

The user of a higher-level language (PL/I, for example) describes files and writes OPEN and GET statements. When his program is executed, one PL/I subroutine uses a DCB macro instruction to build a data control block (DCB), and an OPEN macro instruction to cause data management routines to build a channel program, and input/output block (IOB), a data extent block (DEB), and an event control block (ECB). Another PL/I subroutine uses a GET macro instruction, and a data management routine executes an EXCP macro instruction that causes entry to the I/O supervisor.

Adjacent to the steps taken by a programmer who uses a higher-level language are shown the steps a programmer must take when he is using an assembler language and chooses to use an access method. With an access method, a programmer must essentially do what the PL/I compiler did; that is, he must himself write all needed DCB, OPEN, and GET macro instructions.

The user of an EXCP macro instruction must provide directly all of the input that is required by the I/O supervisor. He may use the DCB and OPEN macro instructions, and he may use the I/O appendages—user-written routines that receive control at appropriate exits in the I/O supervisor code—but he must write his own channel program, and he must build his own IQB and ECB. To request any kind of I/O activity, he must use the EXCP macro instruction.

The EXCP user has the option, at OPEN time, to specify the use of I/O appendages during the progress of I/O operations associated with his data set. These appendages gain control at specific points in the I/O supervisor. They gain control:

- During page fixing
- During extent checking, if an out-of-extent condition is detected
- Prior to issuing the SIO instruction
- If a PCI interruption is received
- If a normal channel end interruption is detected
- If any abnormal condition is detected with a primary interruption

I/O appendages give the EXCP user a means of extending and altering I/O operations. For further information about I/O appendages, see OS/VS Data Management for System Programmers.



2 OS/VS2 I/O Supervisor Logic

Note from Figure 1 how a higher-level language compiler uses access method routines, and note also the similarity between what access method routines do and what a programmer must do when he uses the EXCP macro instruction.

### The Page Supervisor and VS Subsystems

The page supervisor and VS subsystems uses the EXCPVR macro instruction to request I/O services from the I/O supervisor. (The EXCPVR macro instruction is not available to other users of the I/O supervisor.) The EXCPVR macro instruction generates a calling sequence to the I/O supervisor that creates linkages and issues an SVC 114. The basic difference between an SVC 114 request and SVC 0 request is that an SVC 114 request needs little or no translation service and thus can be processed faster than an SVC 0 request.

VS subsystems prepare channel programs (CCW chains) in fixed virtual address space using real data addresses. Subsystems also fix pages for their own control blocks, I/O appendages, and data areas.

Consequently, the I/O supervisor does not fix pages for subsystems'control blocks, I/O appendages, channel programs, or data areas, and does not translate the CCW data addresses to real addresses. However, the I/O supervisor does translate the CCW start address to *real* at EXCPVR time, and also translates the address of the last CCW+8 in the CSW to *virtual* when an I/O interruption occurs.

The page supervisor prepares CCWs and control blocks in nonpageable storage, so page fixing or address translation operations are not performed by the I/O supervisor.

## The I/O Supervisor and the Control Program

Many control program elements are involved in I/O operations besides the I/O supervisor. Their functions are supporting functions needed to coordinate the actions of the I/O supervisor with other system actions. The general system environment of the I/O supervisor is shown in Figure 1.

When an EXCP macro instruction is encountered during assembly of a processing program, the assembler obtains the corresponding macro expansion from the SYS1.MACLIB data set and inserts it into the object program. The last instruction in the EXCP macro expansion is an SVC 0 instruction.

During execution of the processing program, the SVC 0 instruction causes an SVC interruption and immediate entry to the supervisor's SVC first level interruption handler (SVC FLIH). The SVC FLIH is always given control after SVC interruptions. It refers to a list of SVC numbers (called an SVC table) to determine 1) what SVC routine is to service the request and 2) whether or not the needed SVC routine is of the type that is contained in *real* storage. In the case of SVC 0, the routine to be given control is always the first of the two major I/O supervisor routines; the EXCP supervisor and the I/O interruption supervisor.

In giving control to the EXCP supervisor, the SVC FLIH passes the address of the input/output block (IOB), the key item of input data, to the I/O supervisor, and identifies the requester type. See Figure 2 for the characteristics of I/O requesters.

Because channels cannot translate virtual storage addresses, IOS tranlates any virtual addresses used in the channel program. Figure 3 shows the interface between the I/O supervisor and control program.

IOS also ensures that the pages pertaining to the requested I/O operation are fixed in real storage. For virtual requesters, IOS passes control to the page supervisor to fix pages for:

| Type of<br>Requester             | CCW Chain<br>Location  | CCW Translation<br>Requirements                         | Page Fixing<br>Requirements                                                 | SVC Generated                            |
|----------------------------------|------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------|
| Virtual                          | Pageable<br>storage    | IOS must<br>translate<br>CCW chains.                    | Control blocks<br>and appendages<br>must be fixed.                          | EXCP macro<br>generates an<br>SVC 0.     |
| Fixed (VS<br>subsystems<br>only) | Pageable<br>storage    | CCW chains have<br>been translated<br>by the requester. | Control blocks<br>and appendages<br>have been<br>fixed by the<br>requester. | EXCPVR macro<br>generates an<br>SVC 114. |
| Nonpageable                      | Nonpageable<br>Storage | None                                                    | None                                                                        | EXCP macro<br>generates an<br>SVC 0.     |
| Page<br>Supervisor               | Nonpageable<br>Storage | None                                                    | None                                                                        | EXCPVR macro<br>generates an<br>SVC 114. |

### Figure 2. Characteristics of I/O Requesters

- I/O areas specified in the channel program
- Control blocks (IOB, DCB, DEB, ECB/DECB and AVT)
- I/O appendages

Using input data it obtains from addresses in the IOB, the EXCP supervisor either starts the I/O device or, if the needed device is unavailable, schedules the I/O request by placing an element representing the request into a queue.

For virtual requesters, starting the I/O device involves building a real channel program equivalent to the requester's virtual channel program and then having the channel begin executing the real channel program. The real channel program is built in the system queue area (SQA) of real storage.

The EXCP supervisor then gives control to the supervisor's type 1 Exit routine. All type 1 SVC routines (except those abnormally terminated) pass control to the type 1 Exit routine.

If the routine in which the request for the I/O operation was made is still the highest-priority task in the system, the type 1 Exit routine restores the environment that existed at the time of the interruption and returns control to the dispatcher routine. The dispatcher routine either returns control to the requesting routine or to a routine of a new task with a higher priority.

The next event occurs asynchronously. When the device has completed its part of the I/O operation, it causes an I/O interruption. Following I/O interruptions, control is given to the supervisor's I/O first-level interruption handler (I/O FLIH). The I/O FLIH saves a record of the interrupted environment and gives control to the second of the two major I/O supervisor routines, the I/O interruption supervisor.

For virtual and fixed requesters, the I/O interruption supervisor must retranslate the address of the "last CCW+8" in the CSW to the corresponding virtual address; it must also interface with the page supervisor to unfix any pages that were fixed specifically for the I/O operation just completed. In addition, it now frees the real storage area used for translating the CCWs of virtual requesters.

The I/O interruption supervisor signals the requester that the I/O operation is completed (the task supervisor's post routine posts the requester's event control block), and starts other devices on the channel in response to any requests that were queued while the device, data set, or channel was busy with the request just completed.

While the I/O interruption handler processes on interruption, one or more other interruptions may occur. Because I/O interruptions are disabled, they are stacked (saved



Introduction

S

by the hardware), thus creating a pending interruption. After an interruption is processed and the user is posted, the I/O supervisor enables the system for the I/O interruptions. At this time, one of the stacked interruptions is fielded and processed. This process continues until all pending interruptions have been fielded and all queued I/O requests that can be started have been started. The I/O supervisor enables the system for I/O interruptions one last time to check whether there are any more interruptions to be processed. If there are none, the I/O supervisor exits to the I/O FLIH.

When the I/O interruption supervisor returns control to the I/O FLIH, control via the dispatcher, is routed either to the requesting routine or to a routine of a higher-priority task.

# The I/O Supervisor

The overall objective of the I/O supervisor is to make sure that a requested I/O operation is performed. To achieve its objective, the I/O supervisor performs three major functions: starting I/O operations, terminating I/O operations, and restarting I/O operations (for error-correction purposes). These functions, the two major I/O supervisor routines, and the general control flow to and from the routines, are shown in Figure 4.

Note: The EXCP supervisor and error EXCP supervisor share most of the same routines. However, since their functions are separate and distinct, they are treated separately throughout this manual.



Figure 4. I/O Supervision

The basic control flow to and from the EXCP supervisor and the I/O interruption supervisor has already been shown in Figure 1. However, for restarting I/O operations, an SVC 15 instruction (rather than an SVC 0 instruction) causes entry to the EXCP supervisor for retry of an error condition.

In Figure 5 the major functions are expressed in more detail. The three coordinative functions have been added: scheduling I/O operations, starting scheduled I/O operations, and scheduling restarts of I/O operations.

The first flow diagram in Figure 5 shows the flow for a straightforward I/O operation where the Start I/O instruction is accepted and there is no need to schedule I/O device activity. This flow is shown separately to illustrate how the request queue is checked following completion of every I/O operation. The queue is checked repeatedly until no pending requests remain. If after terminating an I/O operation, the status indicators



Figure 5. I/O Supervisor Functions

show an error condition to exist, the I/O interruption supervisor invokes a user-written or IBM-supplied error correction routine. Error routines can request a retry by issuing an SVC 15 instruction, which will result in entry to the error EXCP supervisor for the retry.

The second flow diagram in Figure 5 shows the flow for an I/O operation that could not be started immediately. Note that the request queue is examined after a restart of the I/O operation is scheduled, just as it is when an I/O operation is terminated.

# **Concept of Logical Channels**

The queues into which request elements are placed when I/O activity cannot be started immediately do not always correspond one-for-one with the physical channels attached to a system. Rather, they correspond to logical channels. A logical channel is the set of all physical channels by which a device can be reached.

Queuing in logical queues makes possible path-device groups in which a common set of paths can be tried for each device of a group. The result is simplified alternate-path logic.

Unless a switching device or a two-channel switch is installed, providing multiple-path capability, every physical channel is also a logical channel and there is a one-for-one correspondence. With switching devices, however, the relationship between physical and logical channels varies, depending upon both the number of switches and their placement.

A system without two-channel switches is shown symbolically at the top of Figure 6. Because each device can only be reached via one path, each physical channel is also a logical channel.



### Figure 6. Logical Channel—Physical Channel Relationships

Also shown in Figure 6 is a system in which a switching device connects two control units. Devices B and C can then be reached via channel 1 or channel 2. Devices B and C are both in the logical channel comprising physical channels 1 and 2.

Another configuration with a switching device is shown at the right in Figure 6. This time, devices B, C, and D may be reached via channels 1, 2, and 3; devices B, C, and D are all in the same logical channel.

Except for the 2870 Multiplexor Channel, all devices attached via the same multiplexor channel will always be in the same logical channel. The devices attached via a 2870 Multiplexor Channel may be contained in more than one logical channel, however, because each of the four optional selector subchannels is considered separately.

• :

, , ,

· . . .. .

₹4

.

# **METHOD OF OPERATION**

This section contains diagrams that are designed to give you a general knowledge of the I/O supervisor's operation and to guide you through the program listing. To do this effectively, the diagrams must be kept at a high level. Therefore, there are some functions of the I/O supervisor that are not shown. Use the I/O supervisor routine directory (Figure 27) to find entry points into the listing for routines that are not included in this section.

Each diagram consists of two pages. The (upper) first is the actual diagram. The second (lower) page consists of expanded text, references to other diagrams, and flowcharts, and a program organization chart that highlights a particular function of the I/O supervisor.



۰

.



,

\*

**Extended Description** 





Figure 7. (Part 2 of 2) I/O Supervisor

Method of Operation 13



Figure 8. (Part 1 of 2) EXCP Supervisor

.

æ

### Exte



.

.

| tendeo | tended Description                                                                                                                                                                                                                                                                                                                                                             |        |  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|
| ١      | Various fields within the control blocks are checked to prevent vital system data from being destroyed.                                                                                                                                                                                                                                                                        | 9      |  |
| 2      | An RQE is built for each I/O request. If the request cannot be immediately satisfied, the RQE is placed in the logical channel request queue for that device. For virtual and fixed requestors, the pages involved in the requested I/O operation are fixed in real storage. This prevents the pages from being moved into auxiliary storage through normal paging operations. | 10     |  |
| 3      | The Start I/O module builds any device-dependent prefix CCW chains needed.<br>The SIO subroutine is entered to translate the virtual channel program and<br>execute the SIO instruction.                                                                                                                                                                                       | 11, 12 |  |
| 4      | The Post Start I/O routine processes the condition codes that resulted from the Start I/O and translates the CCW address in the CSW back to virtual. The IOB and UCB are updated and the RQE is dequeded before exiting to the supervisor's Type 1 exit routine.                                                                                                               | 14     |  |

.

.



# Figure 8. (Part 2 of 2) EXCP Supervisor





.

,

Figure 9. (Part 1 of 2) Validity Check Routine

.

٠



2 The IOB's pointer to the DCB must be the same as the DEB's pointer to the DCB. If not, the ABEND routine is entered. Figure

10

23

If the system has the protection feature, a non-supervisor requester's key must equal the storage key in the DEB. The ABEND routine is entered if the keys do not match.

The UCB is invalid if the UCBID field is not all 1's.

3

4

5 If this routine is entered from the supervisor's SVC First Level Interruption Handler, the Get Request Element routine is entered to build an RQE for this request.

If this routine is entered from the Error EXCP routine, the address of the logical channel word is calculated and placed in a register. The Error EXCP routine is then reentered.









Figure 10. (Part 1 of 2) Get Request Element Routine

. #



To Supervisor's Type 1 Exit Routine



• Ordered Seek - In order of the cylinder address of the requested DASD.

Figure 10. (Part 2 of 2) Get Request Element Routine



ĸ.

.

Figure 11. (Part 1 of 2) Start I/O Routine for Tape

٠

٠





### Figure 11. (Part 2 of 2) Start I/O Routine for Tape.

Method of Operation 21



5

4

Figure 12. (Part 1 of 2) Start I/O Routine for DASD

.

٠







Exit To Supervisor's Type 1 Exit Routine

Figure 12. (Part 2 of 2) Start I/O Routine for DASD



Ł

.

24 OS/VS2 I/O Supervisor Logic

ŧ





14

XCPPIO

Process Condition Codes

Exit

To Supervisor's Type 1 Exit Routine



đ

.

Figure 14. (Part 1 of 2) Post Start I/O Routine

٤





#### Figure 14. (Part 2 of 2) Post Start I/O Routine



•

Figure 15. (Part 1 of 2) Page Fix Routine

.



**Extended Description** 

1

2

3

4

#### Figure

A block to be used as a page-fix list is acquired from the SQA space owned by IOS. The TSTHDR field of the RQE points to the page-fix list until translation time.

The user can make entries in the page-fix list for I/O appendages and other data. A maximum of seven entries are permitted. Ten entries may be specified with a special return vector (+4). The user must also include entries for his DCB, DECB, and IOB.

Pages for the IOB, ECB, DCB, AVT, and IOS appendages must all be fixed in real storage. Those that are not already fixed are added to the page-fix list.

The Page Supervisor fixes all of the pages that are specified by the page-fix list. If the page is not already in real storage, an I/O operation (page-in) is requested.







Figure 16. (Part 1 of 2) CCW Translator

Figure Space is obtained from the IOS owned SOA for a CCW translation header BEBLK. The TSTHDR field of the RQE is updated to point to the header BEBLK. The page-1 fix list obtained earlier is now pointed to by the HDRPGLK field of the header BEBLK. If the channel program exceeds the capacity of the header BEBLK, additional space is required to complete the translation and subroutine TCCWM300 is entered. This 2 routine acquires SQA space for a new BEBLK. The new BEBLK is initialized and a TIC CCW is placed in the previous channel program segment. This TIC CCW contains a pointer to the first CCW slot in the new BEBLK. CCW translation continues. 15 If the data area specified by the CCW crosses a page boundary, the page fix list is checked to ensure the page is fixed, and an IAL is generated. The IAL address is placed into the CCW's data address field. When the channel program is executed, 4 data transfer begins with the first address of the IAL and continues until a 2K boundary is reached. It then continues data transfer from the next address in the IAL. This is repeated until the count in the CCW expires. Translation of the unresolved TICs can be completed by referencing the BEBLKs. The virtual addresses in the BEBLKs are scanned until a match is made with the TIC's 6 virtual data address. The corresponding real address is then stored in the TIC command. 16 The starting address of the real channel program is put into the HDRTICL field of 7 the header BEBLK for use by the SIO routine.



**Extended** Description

### Method of Operation 3



Figure 17. (Part 1 of 2) I/O Interruption Supervisor (Part 1)



.

To Supervisor's Type 1 Exit Routine

Extended Description

5

7

#### Figure

The CSW Translator is entered at TRATCSW. If it was a virtual or fixed request, the real CCW address in the CSW is replaced by the corresponding virtual CCW address found in the BEBLK.

Catastrophic errors are:

- Channel Control Check
- Interface Control Check
- Channel Data Check



Figure 17. (Part 2 of 2) I/O Interruption Supervisor (Part 1)



Figure 18. (Part 1 of 2) I/O Interruption Supervisor (Part 2)

t

#### Extended Description

Figure



L

.

To Supervisor's Type 1 Exit Routine

## 8 The seven low-order bytes of the CSW are placed into the IOB. 13 The Unfix/Free routine of the CCW Translator is entered at TRAUFRE. Pages used for control blocks and appendages are unfixed, and space in the SQA that was used for the page-fix list and translation header record is freed.

.

Figure 18. (Part 2 of 2) I/O Interruption Supervisor (Part 2)



.

.

\*

.

Figure 19. (Part 1 of 2) Channel Restart Routine

#### **Extended Description**



| xtende | ed Description                                                                                                                                                                                                            | Figure |  |  |  |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|--|
| 2      | If there is an interruption pending, the I/O Interruption Supervisor is reentered at IECINT.                                                                                                                              | 17     |  |  |  |  |  |
| 3      | The Channel Search routine is entered at INTCSn to determine if another I/O operation can be started on this logical channel. The channel table contains the Channel Search routine entry point for each logical channel. |        |  |  |  |  |  |
| 6      | Same as 2                                                                                                                                                                                                                 |        |  |  |  |  |  |

#### Figure 19. (Part 2 of 2) Channel Restart Routine



ŧ

Figure 20. (Part 1 of 2) Channel Search Routine

ŧ

#### **Extended Description**

#### Figure











.

Figure 21. (Part 1 of 2) Sense Subroutine

٠



Extended Description





Figure 21. (Part 2 of 2) Sense Subroutine





ť

.



To Supervisor's Type 1 Exit Routine

Figure 22. (Part 2 of 2) Error Routine Interface

#### Extended Description

1

2

3

7

#### Figure

An X'41' in the completion code byte of the IOB, IOBCD, indicates a permanent error. An X'OC' in the DCBFL byte of the DCB indicates IOS ERPs are to be used. The completion code, IOBCOD, is set to: <u>X'44' (Intercepted Request)</u> if this request is an intercepted I/O request. <u>X'41' (Permanent Error) if</u> this request is not related to a previous request that resulted in a permanent error.

.

Unchanged if this request is related to a previous request that resulted in a permanent error.

An X'40' is placed into the DCBFL byte to indicate error correction is in progress.



¥

.

Figure 23. (Part 1 of 2) Error EXCP Routine

\*

# SOR Extended Description Figure iOR I The Validity Check routine is executed to ensure various fields within the control blocks are valid. If any of the tests are not satisfied, the ABEND routine, IEA0AB00, is entered. 9 I If this is not a permanent error, the 'I/O Error Routine in Control' flag in the DCB is turned off before exiting to the Channel End Appendage. 9

.





FLIH at DISMIS

Figure 23. (Part 2 of 2) Error EXCP Routine

#### **PROGRAM ORGANIZATION**

This section contains functional organization charts and a description of the individual routines. There is a functional organization chart for each of the three functions of the I/O supervisor.

#### **Description of Routines**

In Figure 24, 25, and 26 the major I/O supervisor routines are grouped according to the functions that they perform. Brief descriptions of the routines and optional user-written appendage routines follow.

Abnormal end appendage: Optional user-written appendage to which the I/O interruption supervisor exits when there is an error associated with the processing of I/O.

Attention Routine Interface: Determines the address of the appropriate Attention routine; invokes the Attention routine.

Channel Command Word Translator routine: Converts the virtual channel program to a real channel program.

**Channel Check Handler routine:** Builds error recovery procedure interface block to indicate cause of channel failure; builds inboard record to describe environment at time of failure.

**Channel Check Handler Routine Interface:** Places a code into register 15 that indicates which IOS routine intercepted the channel failure and branches to the Channel Check Handler routine.

**Channel end appendage:** Optional user-written appendage to which the I/O interruption supervisor exits after a channel end interruption before indicating to the user how his I/O request ended. Also entered when channel end interruption is accompanied by either a wrong length indicator or a unit exception, or by both conditions.

**Channel Restart routine:** Scans logical channel queues. Selects RQEs representing requests for I/O activity that can be started. Starts the I/O activity. For direct-access devices, first starts all seeks, then starts the data transfer.

Channel Search routines: One for every physical channel. "Driver" type routines consisting mostly of branch instructions. Direct the search of logical channel queues and the starting of I/O activity.

Channel Status Word Translator routine: Converts the real CSW address to a virtual address for virtual requesters.

**Dequeue subroutine:** Locates an RQE in a logical channel queue, removes it from the queue, and returns it to the freelist.

**End-of-extent appendage:** Optional user-written appendage to which the EXCP supervisor exits when the execution of I/O request will violate the extent limits of a direct-access device.

Enqueue subroutine: Places an RQE into a logical channel queue. Normally queues by order of arrival. Optionally queues by requestor's priority or by seek address.

**Error Recovery routine:** Determines if I/O activity can be retried. Supervises retry attempts.

Error Routine Interface: Prepares for and invokes, or schedules the execution of, an error recovery routine.













To I/O Interruption Supervisor (25)

#### Figure 26. Functional Organization, Error EXCP Supervisor

**EXCP Validity Check routine:** Does most of the housekeeping for the EXCP supervisor. Checks for a valid DCB, DEB, IOB, and UCB. With Protection feature uses Validity Check subroutine to check storage keys of input data areas.

Get Request Element routine: Obtains an RQE from the freelist and initializes it. If device is unavailable, causes the RQE to be queued in logical channel request queue.

Page Fix Routine: Fixes pages in real storage for control blocks and appendages.

**Program-controlled interrupt appendage:** Optional user-written appendage to which I/O interruption supervisor exits when program-controlled interruption (PCI) is indicated. Returns control to I/O interruption supervisor where the modified CCW is translated, if a virtual request and normal processing continues.

**Post Routine Interface:** Invokes the supervisor's Post routine, passing to it an event completion code and the address of the requester's ECB. The Post routine posts the requester's ECB.

**Post Start I/O routine:** Routes control, depending upon resulting condition codes of the Start I/O instruction and status bits in the CSW (if the CSW was stored).

Quiesce Complete subroutine: Invokes the supervisor's Post routine, passing to it an event completion code and the address of the purge parameter list. The Post routine posts the Purge routine ECB.

Sense subroutine: Issues a Start I/O instruction to cause a Sense command to be executed. Places the first two bytes of sense data in the requester's IOB.

1

1

System Environment Recording Routine Interface: Places an error code into the machine check new PSW. Uses a Load PSW instruction to invoke the SER0 or SER1 routine.

Start I/O appendage: Optional user-written routine to which the EXCP supervisor exits before the execution of the Start I/O (SIO) instruction for a requested I/O operation.

**Start I/O routine for direct-access devices:** Prepares an I/O supervisor channel program consisting of three CCWs: a Seek command, a Set File Mask command, and a Transfer-in-Channel command. The 2314 direct-access device uses the Start I/O subroutine twice, once to perform a stand-alone seek and once to perform the data transfer.

Start I/O routine for magnetic-tape devices: Prepares an I/O supervisor channel program that may consist of two CCWs (normal start, restart, or opposite direction recovery), or three CCWs (operations following a cyclic redundancy check condition). The last CCW contains a Transfer-in-Channel command containing the address of the requester's first CCW. Uses the Start I/O subroutine.

Start I/O routine for unit record and communications devices: Initializes a register with the address of the requester's first CCW. Uses the Start I/O subroutine.

Start I/O subroutine: Prepares the CAW and issues a Start I/O instruction. Does some checking of resulting condition codes.

**Test Channel routine:** For selector channels, issues a Test Channel instruction. Causes the RQE to be queued if the channel is unavailable. Tries all channels of multiple-path arrangements. Does not issue a Test Channel instruction for byte-multiplexor channels.

**Trap routines:** One for each device class. Perform device-dependent functions following channel-end and device-end interruptions.

Validity Check subroutine: Checks storage keys of areas containing IOB, DCB, and ECB against the requester's protection key; checks that DEB storage key is 0.



#### DIRECTORIES

This section contains cross-reference lists that include a data area directory, module directory and a routine directory.

#### **Data Area Directory**

Figure 27 contains a summary of information about the major data areas used by the I/O supervisor. The column headings and their meanings are:

Data Area Name: The name of the data area and its abbreviation, if there is one.

**Beginning Symbol:** Meaningful only for data areas contained in the nucleus. This symbol identifies the beginning of the data area, and can be used to locate the data area in the program listings.

Creation: Contains some indication as to the origin of the data area.

Permanent Storage Assignment means that the area is part of the hardware and always occupies the real-storage location shown in the "Storage Area" column.

Requester means that creation and maintenance of the data area is the responsibility of the requester of the I/O activity. All requesters do not have to explicitly create the needed data areas. (See Figure 1 and its accompanying text.)

System Generation means that the data area is created during system generation. (This means that space is set aside for the area during system generation.)

Supervisor means that the area is created and maintained by the supervisor portion of the control program.

**Storage Area:** Indicates where the data area can be found in real storage. Where "Requester's" appears in this column, the data area is obtained by the requester when it is needed; consequently, its location is not fixed.

Size: The size of the data area.

Means of Access: The most commonly used way of referring to the data area or one of its entries.

| Data Area Name                 | Beginning<br>Symbol | Creation                                                                               | Storage Area           | Size                                                                          | Means of Access                                                                                                                                                                                                                 |
|--------------------------------|---------------------|----------------------------------------------------------------------------------------|------------------------|-------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Alternate Path<br>Table        | SCPCHnB             | System<br>Generation                                                                   | Nucleus                | Three to Five<br>Fullwords,<br>Depending Upon<br>No. of Paths to<br>a Device  | Beginning symbol.                                                                                                                                                                                                               |
| Beginning-End<br>Block (BEBLK) | BEBNXTB             | I/O Supervisor                                                                         | SQA                    | 136 Bytes                                                                     | TSTHDR field of the RQE.                                                                                                                                                                                                        |
| Channel Address<br>Word (CAW)  | CAWLOC              | Permanent<br>Storage<br>Assignment                                                     | 72(48)                 | Word                                                                          | Beginning symbol.                                                                                                                                                                                                               |
| Channel Command<br>Word (CCW)  |                     | By Requester<br>when Needed.<br>IOS CCWs are<br>Created<br>during System<br>Generation | Requester's<br>Nucleus | Doubleword                                                                    | Address at requester's first CCW<br>is contained at off-sets IOBST<br>(start) or IOBSRS (restart) fields<br>of IOB.<br>Access to IOS CCWs varies<br>with device type and                                                        |
| Channel Error                  | СЕВТАВ              | System                                                                                 | Nucleus                | 24 Bytes                                                                      | circumstances.<br>Beginning Symbol.                                                                                                                                                                                             |
| Block Table                    |                     | Generation                                                                             |                        |                                                                               |                                                                                                                                                                                                                                 |
| Channel Status<br>Word (CSW)   | CSWLOC              | Permanent<br>Storage<br>Assignment                                                     | 64(40)                 | Doubleword                                                                    | Beginning symbol.                                                                                                                                                                                                               |
| Channel Table                  | IECCST              | System<br>Generation                                                                   | Nucleus                | One-Word<br>Entry for<br>Each Physical<br>Channel                             | To locate entry for specific<br>channel, channel number is<br>multiplied by four and added to<br>beginning address of table.                                                                                                    |
| Data Control<br>Block (DCB)    |                     | By Requester                                                                           | Requester's            | Varies with<br>Access Method                                                  | Symbolic names equated to offsets of files.                                                                                                                                                                                     |
| Data Extent<br>Block (DEB)     |                     | By Requester                                                                           | Requester's            | Varies with<br>Devices and<br>Access method                                   | Symbolic names equated to offsets of fields.                                                                                                                                                                                    |
| Device Statistics<br>Fable     | IECSTB              | System<br>Generation                                                                   | Nucleus                | One 10-Byte<br>Entry for Each<br>Device, plus<br>One 10 Byte<br>Control Field | Normally, the address of an entry<br>for a device is obtained by<br>multiplying the statistics table<br>index in the device's UCB by 10<br>and adding the result to the<br>beginning address of the device<br>statistics table: |
|                                |                     |                                                                                        |                        |                                                                               | STATAB x 10 + Beginning Address                                                                                                                                                                                                 |
|                                |                     |                                                                                        |                        |                                                                               | When there are more than 256 devices, however, the following method is used:                                                                                                                                                    |
|                                |                     |                                                                                        |                        |                                                                               | (STATAB) + 256) x 10 + Beginning<br>Address                                                                                                                                                                                     |
|                                |                     | Area Directory                                                                         |                        |                                                                               | 1 1001 000                                                                                                                                                                                                                      |

2

Figure 27. (Part 1 of 3) Data Area Directory

| Data Area Name                 | Beginning<br>Symbol | Creation                           | Storage Area | Size                                                                               | Means of Access                                                                                                                                                                                                                  |
|--------------------------------|---------------------|------------------------------------|--------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                |                     |                                    |              |                                                                                    | In the above, n is the number one<br>or two to indicate the second and<br>third 256-entry group in the device<br>statistics table. The UCB addresses<br>in the control field of the table are<br>used to determine the number n. |
|                                |                     |                                    |              |                                                                                    | For the 2314 Direct-Access Storage<br>Facility, the low-order four bits of<br>the fifth sense byte are added to the<br>statistics table index before the<br>index is used.                                                       |
| Device Table                   | DEVTAB              | System<br>Generation               | Nucleus      | One 6-Byte<br>Entry for Each<br>Queuing Option<br>Selected for Each<br>Device Type | Desired entry located by adding device<br>table index from UCB to beginning<br>address of table. A specific field<br>within the entry is then located by<br>adding the field's offset to the<br>above sum.                       |
| Event Control<br>Block (ECB)   |                     | By Requester                       | Requester's  | Word                                                                               | Via address contained at offset 5 of the IOB.                                                                                                                                                                                    |
| Indirect Address<br>List (IAL) | IALCHAIN            | I/O Supervisor                     | SQA          | 136 Bytes                                                                          | HDRINDL field of the CCW translation header BEBLK.                                                                                                                                                                               |
| Input/Output<br>Block (IOB)    |                     | By Requester                       | Requester's  | 32 Bytes, plus a<br>Variable Amount<br>that Depends Upon<br>the Access Method      | Initially, address is provided<br>in register 1 by requester. It<br>is moved to and maintained in<br>register 2 (IOBREG).                                                                                                        |
| Logical Channel<br>Table (LCH) | LCHTAB<br>IECILCH   | System<br>Generation               | Nucleus      | One Doubleword<br>Logical Channel<br>Word for Each<br>Logical                      | To locate a needed logical<br>channel word, the logical<br>channel index in the UCB is<br>multiplied by 8 and added to the<br>beginning address of the<br>logical channel table.                                                 |
| Page Fix List<br>(PGFX)        | FXLSTCHN            | NI/O Supervisor                    | SQA          | 136 Bytes                                                                          | Before CCW translation, the<br>TSTHDR field of RQE.<br>HDRPGLK field of the translation<br>header BEBLK.                                                                                                                         |
| Program Status<br>Word (PSW)   |                     | Permanent<br>Storage<br>Assignment |              |                                                                                    |                                                                                                                                                                                                                                  |
| SVC Old PSW<br>I/O Old PSW     | SVCOPSW<br>IOPSWO   |                                    |              | 32(20)<br>56(38)                                                                   | Beginning symbol.<br>Beginning symbol.                                                                                                                                                                                           |

ŀ

t

Ð

1

A .....

| |-

| I | Data Area Name                 | Beginning<br>Symbol | Creation             | Storage Area | Size                                                                                                                                                                          | Means of Access                                                                                                                                                                                                                                                                   |
|---|--------------------------------|---------------------|----------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | Request Queue<br>Element (RQE) | TSTAR<br>TECIOQET   | System<br>Generation | Nucleus      | 20 Bytes<br>20 Bytes                                                                                                                                                          | Varies depending upon status of request:                                                                                                                                                                                                                                          |
|   |                                |                     |                      |              |                                                                                                                                                                               | Address of RQE available for<br>assignment is contained in location<br>NEXAVL.                                                                                                                                                                                                    |
|   |                                |                     |                      |              |                                                                                                                                                                               | Address of assigned (but not queued) RQE is contained in requester 1 (TSTREG).                                                                                                                                                                                                    |
|   |                                |                     |                      |              |                                                                                                                                                                               | Address of the first RQE in a logical<br>channel queue is contained in the<br>LCHFTS field of the logical channel<br>word for that queue.                                                                                                                                         |
|   | Fask Control<br>Block (TCB)    |                     | By Supervisor        | Nucleus      | 171 Bytes                                                                                                                                                                     | Symbolic names equated to offsets of fields.                                                                                                                                                                                                                                      |
|   | Franslation<br>Header BEBLK    | BEBNXTB             | I/O Supervisor       | SQA          | 136 Bytes                                                                                                                                                                     | TSTHDR field of the RQE.                                                                                                                                                                                                                                                          |
|   | Unit Control<br>Block (UCB)    |                     | System<br>Generation | Nucleus      | Variable from 24<br>10 288 Bytes.<br>one UCB for Each<br>Device Address<br>Defined for the<br>System.                                                                         | Initially, via address<br>contained in the UCB address<br>field of DEB. The address is<br>moved to the request queue<br>element. Following<br>interruptions, the address of<br>the UCB for the device that<br>caused the interruption is<br>obtained via the UCB lookup<br>table. |
| ι | UCB Lookup Table               | UCGTAB<br>IECILKI   | System<br>Generation | Nucleus      | Variable, depending<br>upon Number and<br>Addresses of Devices,<br>Control Units, and<br>Channels, and Number<br>of Zero Entries<br>Eliminated by Table-<br>Building Routine. | Beginning symbol.<br>r                                                                                                                                                                                                                                                            |
|   | Volume Statistics<br>Fable     |                     | System               | Nucleus      | 24 Bytes for Each<br>Entry                                                                                                                                                    | Via address contained in field<br>at offset 49 of the UCB<br>containing the volume. Each<br>entry is effectively an<br>extension to a UCB.                                                                                                                                        |

#### Module Directory

Figure 28 contains information about the physical structure of the I/O supervisor. The column headings and their meanings are:

Symbolic Name: The symbolic name of a table, routine, object module, or control section.

Description: The type of item to which the symbolic name applies.

**Object Module Name:** The name of the object module containing the item. The microfiche cards containing program listings are ordered by object module name.

Control Section Name: The name of the control section containing the item.

**Publication References:** Places in this publication where more information about the item can be found.

Library: The data set normally containing the item.

| Code | Data Set     |
|------|--------------|
| NUC  | SYS1.NUCLEUS |
| SVC  | SYS1.LPALIB  |

If SVC Routine: Information about I/O supervisor SVC routines. There are four types of SVC routines.

Type 1 SVC routines are part of the nucleus and are disabled (masked) for all interruptions except machine check interruptions.

Type 2 SVC routines are part of the nucleus but may be enabled (interruptable) for part of their operation.

Type 3 SVC routines are nonresident and may be enabled.

Type 4 SVC routines are nonresident and may be enabled.

Name: The name of the item being described.

When the control section name for an item is not the same as the object module name, the item will have two entries in the table—one filed by control section name and the other filed by object module name. Therefore, it is unnecessary to check beyond the first column when looking for a symbolic name.

The three major groups of routines that make up the I/O supervisor—the EXCP supervisor, the I/O interruption supervisor, and the error EXCP supervisor—are contained in the control program nucleus. As a result, there are no CSECT names or load module names in these three major groups of routines. Linkage parameter lists, usually associated with multi-load routines, are also unnecessary. Therefore entry points are not of the formal one-or-two-entries-only type (due to stringent parameter list requirements), but rather are ordinary symbolic labels, undistinguishable from other symbolic labels.

|                  |                    | Object   | Control         |                          |             | Macro    |            | If SVC Routine                                         |
|------------------|--------------------|----------|-----------------|--------------------------|-------------|----------|------------|--------------------------------------------------------|
| Symbolic<br>Name | Description        | Module   | Section<br>Name | Publication<br>Reference | Library Typ | Instruc- | SVC<br>No. | Name                                                   |
| CAWLOC           | Table              | *        | *               | Data Areas               |             |          |            | Channel Address Word                                   |
| CSWLOC           | Table              | *        | *               | Data Areas               |             |          |            | Channel Status Word                                    |
| DEVTAB           | Table              | *        | *               | Data Areas               | NUC         |          |            | Device Table                                           |
| IEAQFX00         | Object<br>Module   | IEAQFX00 | IEAQFX00        | All                      | NUC         |          |            | IOS Nucleus                                            |
| IECCST           | Table              | *        | *               | Data Areas               | NUC         |          |            | Channel Table                                          |
| IECILCH          | Table              | *        | *               | Data Areas               | NUC         |          |            | Logical Channel Table                                  |
| IECILK1          | Table              | *        | *               | Data Areas               | NUC         |          |            | UCB Lookup Table                                       |
| IECINT           | Routine            | *        | *               | Program<br>Organization  | NUC         |          |            | I/O Interruption Supervisor                            |
| ECINTRP          | Object<br>Module   | IECINTRP | IECINTRP        | Method of Operation      | NUC         |          |            | Error Interpreter Routine                              |
| IECIOQET         | Table              | *        | *               | Data Areas               | NUC         |          |            | Request Queue Element Table                            |
| ECIPRTS          | Object<br>Module   | IECIPRTS | IGC016          | Appendix A               | SVC 2       | PURGE    | 16         | Purge Routine (TSO)                                    |
| ECIPR16          | Object<br>Module   | IECIPR16 | IGC016          | Appendix A               | SVC 2       | PURGE    | 16         | Purge Routine                                          |
| ECSTB            | Table              | *        | *               | Data Areas               | NUC         |          |            | Statistics Table                                       |
| ECWTORA          | Control<br>Section | IGE0125C | IECWTORA        | Appendix H               | SVC         |          |            | Write-to-Operator Routine,<br>Load 1 of 5 <sup>1</sup> |
| ECWTORB          | Control<br>Section | IGE0125C | IECWTORB        | Appendix H               | SVC         |          |            | Write-to-Operator Routine,<br>Load 2 of 5 <sup>1</sup> |
| IECWTORC         | Control<br>Section | IGE0225C | IECWTORC        | Appendix H               | SVC         |          |            | Write-to-Operator Routine,<br>Load 3 of 5 <sup>1</sup> |
| ECWTORD          | Control<br>Section | IGE0325C | IECWTORD        | Appendix H               | SVC         |          |            | Write-to-Operator Routine,<br>Load 4 of 5 <sup>1</sup> |
| ECWTORE          | Control<br>Section | IEC0425C | IECWTORE        | Appendix H               | SVC         |          |            | Write-to-Operator Routine,<br>Load 5 of 5 <sup>1</sup> |
| EC1052A          | Control<br>Section | IGE0000D | IEC1052A        | Appendix H               | SVC         |          |            | 1052, 3210, and 3215 Error<br>Routine                  |
| EC1402A          | Control<br>Section | IGE0001C | IEC1402A        | Appendix H               | SVC         |          |            | 2540 Error Routine,<br>Load 1 of 2                     |
| EC1402B          | Control<br>Section | IGE0101C | IEC1402B        | Appendix H               | SVC         |          |            | 2540 Error Routine,<br>Load 2 of 2                     |
| EC1403A          | Control<br>Section | IGE0000G | IEC1403A        | Appendix H               | SVC         |          |            | 1403 and 1443 Error Routine                            |
| IEC1442A         | Control<br>Section | IGE0000E | IEC1442A        | Appendix H               | SVC         |          |            | 2501, 2520, and 1442 Error<br>Routine                  |
| EC23XXF          | Object<br>Module   | *        | *               | Appendix H               | NUC         |          |            | 2305, 2314, 2319, 3330, and<br>3333 Error Routine      |

\* Refer to installation system generation listing.

ľ

 $1 \ \ \, \text{Do not confuse with the Write-to-Operator SVC routine (SVC 35), described in other OS/VS publications.}$ 

Figure 28. (Part 1 of 5) Module Directory

|                  |                    | Object    | Control         |                                                    |           |      | Macro    |            | If SVC Routine                                      |
|------------------|--------------------|-----------|-----------------|----------------------------------------------------|-----------|------|----------|------------|-----------------------------------------------------|
| Symbolic<br>Name | Description        | Module    | Section<br>Name | Publication<br>Reference                           | Library ' | Туре | Instruc- | SVC<br>No. | Name                                                |
| IEC24001         | Control<br>Section | IGE09001  | IEC24001        | Appendix H                                         | SVC       |      |          |            | 2400/3400 Tape Series Erro<br>Routine, Load 6 of 7  |
| IEC3211A         | Control<br>Section | IGE000F   | IEC3211A        | Appendix H                                         | SVC       |      |          |            | 3211 Error Routine                                  |
| IEC3211B         | Control<br>Section | IGE0100F  | IEC3211B        | Appendix H                                         | SVC       |      |          |            | 3211 Error Routine                                  |
| IEC3420J         | Control<br>Section | IGE08001  | IEC3420J        | Appendix H                                         | SVC       |      |          |            | 2400/3400 Tape Series<br>Error Routine, Load 7 of 7 |
| 1GC000           | Routine            | *         | *               | Method of<br>Operation,<br>Program<br>Organization | NUC       | 1    | EXCP     | 0          | EXCP Supervisor                                     |
| IGC0001G         | Object<br>Module   | IGC00001G | SVC017          | Appendix A                                         | SVC       | 3    | RESTORE  | 17         | Restore Routine                                     |
| IGC0003C         | Object<br>Module   | IGC0003C  | IGC00033        | Appendix A                                         | SVC       | 3    | IOHALT   | 33         | IOHALT Routine                                      |
| IGC00033         | Control<br>Section | IGC0003C  | IGC00033        | Appendix A                                         | SVC       | 3    | IOHALT   | 33         | IOHALT Routine                                      |
| IGC0009A         | Object<br>Module   | IGC0009A  | IGC0009A        | Appendix A                                         | SVC       | 3    | -none-   | 91         | VOLSTAT Routine                                     |
| IGC0010A         | Object<br>Module   | IGC0010A  | IGC0010A        | Appendix H                                         | SVC       |      |          |            | Loads 2305/3330/3333                                |
| IGC0024          | Control<br>Section | IGC0002D  | IGC0024         | Appendix A                                         | SVC       | 3    | DEVTYPE  | 24         | DEVTYPE Routine                                     |
| IGC015           | Routine            | *         | *               | Method of<br>Operation,<br>Program<br>Organization | NUC       | 1    | -none-   | 15         | Error EXCP Supervisor                               |
| IEC016           | Control<br>Section | IECIPRTS  | IGC016          | Appendix A                                         | SVC       | 2    | PURGE    | 16         | Purge Routine (TSO)                                 |
| IGC016           | Control<br>Section | IECIPR16  | IGC016          | Appendix A                                         | SVC       | 2    | PURGE    | 16         | Purge Routine                                       |
| IGC092           | Routine            | *         | *               | Appendix A                                         | NUC       | 1    | -none-   | 92         | TCB EXCP Routine (TSO                               |
| IGE0000D         | Object<br>Module   | IGE0000D  | IEC1052A        | Appendix H                                         | SVC       |      |          |            | 1052, 3210, and 3215<br>Error Routine               |
| IGE0000E         | Object<br>Module   | IGE0000E  | IEC1442A        | Appendix H                                         | SVC       |      |          |            | 2501 and 2520 Routine                               |
| 1GE0000F         | Object<br>Module   | IGE0000F  | IEC3211A        | Appendix H                                         | SVC       |      |          |            | 3211 Error Routine                                  |
| IGE0000G         | Object<br>Module   | IGE0000G  | IEC1403A        | Appendix H                                         | SVC       |      |          |            | 1403 and 1443 Error<br>Routine                      |

Figure 28. (Part 2 of 5) Module Directory

1

P

|                  |                  | Object                   | Control                    |                          |              | M                         |            | If SVC Routine                                         |
|------------------|------------------|--------------------------|----------------------------|--------------------------|--------------|---------------------------|------------|--------------------------------------------------------|
| Symbolic<br>Name | Description      | Object<br>Module<br>Name | Control<br>Section<br>Name | Publication<br>Reference | Library Type | Macro<br>Instruc-<br>tion | SVC<br>No. | Name                                                   |
| GE00001          | Object<br>Module | IGE00001                 | IGE00001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series<br>Error Routine, Load 1 of 7    |
| GE0001C          | Object<br>Module | IGE0001C                 | IEC1402A                   | Appendix H               | SVC          |                           |            | 2540 Error Routine,<br>Load 1 of 2                     |
| GE0010A          | Object<br>Module | IGE0010A                 | IGE0010A                   | Appendix H               | SVC          |                           |            | 2250 Error Routine                                     |
| IGE0010B         | Object<br>Module | IGE0010B                 | IGE0010B                   | Appendix H               | SVC          |                           |            | 2260 and 1053 Error Routine,<br>Load 1 of 2            |
| IGE0011A         | Object<br>Module | IGE0011A                 | IGE0011A                   | Appendix H               | SVC          |                           |            | 2495 Error Routine                                     |
| IGE0011C         | Object<br>Module | IGE0011C                 | IGE0011C                   | Appendix H               | SVC          |                           |            | 1287 Error Routine                                     |
| IGE0011D         | Object<br>Module | IGE0011D                 | IGE0011D                   | Appendix H               | SVC          |                           |            | 1288 Error Routine                                     |
| IGE0011E         | Object<br>Module | IGE0011E                 | IGE0011E                   | Appendix H               | SVC          |                           |            | 1419/1275 Error Routine                                |
| IGE0025C         | Object<br>Module | IGE0025C                 | IECWTORA                   | Appendix H               | SVC          |                           |            | Write-to-Operator Routine,<br>Load 1 of 5 <sup>1</sup> |
| IGE0025E         | Object<br>Module | IGE0025E                 | IGE0025E                   | Appendix A               | SVC          |                           |            | I/O Purge Routine                                      |
| IGE0100F         | Object<br>Module | IGE0100F                 | IEC3211B                   | Appendix H               | SVC          |                           |            | 3211 Error Routine,<br>Load 2 of 2                     |
| IGE01001         | Object<br>Module | IGE0100I                 | IGE01001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series<br>Error Routine, Load 2 of 7    |
| IGE0101C         | Object<br>Module | IGE0101C                 | IEC1402B                   | Appendix H               | SVC          |                           |            | 2540 Error Routine,<br>Load 2 of 2                     |
| IGE0110 <b>B</b> | Object<br>Module | IGE0110B                 | IGE0110B                   | Appendix H               | SVC          |                           |            | 2260 and 1053 Error Routine,<br>Load 2 of 2            |
| IGE0125C         | Object<br>Module | IGE0125C                 | IECWTORB                   | Appendix H               | SVC          |                           |            | Write-to-Operator Routine,<br>Load 2 of 5 <sup>1</sup> |
| IGE0125E         | Object<br>Module | IGE0125E                 | IGE0125E                   | Appendix C               | SVC          |                           |            | Volume Verification Routine,<br>Load 1 of 2            |
| GE02001          | Object<br>Module | IGE02001                 | IGE02001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series Error<br>Routine, Load 3 of 7    |
| IGE0225C         | Object<br>Module | IGE0225C                 | IECWTORC                   | Appendix H               | SVC          |                           |            | Write-to-Operator Routine,<br>Load 3 of 51             |
| IGE0225E         | Object<br>Module | IGE0225E                 | IGE0225E                   | Appendix C               | SVC          |                           |            | Volume Verification Routine<br>Load 2 of 2             |
| IGE03001         | Object<br>Module | IGE03001                 | IGE03001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series Error<br>Routine, Load 4 of 7    |

 $1\ \ Do not confuse with the Write-to-Operator SVC routine (SVC 35), described in other OS/VS publications.$ 

Figure 28. (Part 3 of 5) Module Directory

|                  |                    |                          | Castal                     |                          |              | N/                        |            | If SVC Routine                                          |
|------------------|--------------------|--------------------------|----------------------------|--------------------------|--------------|---------------------------|------------|---------------------------------------------------------|
| Symbolic<br>Name | Description        | Object<br>Module<br>Name | Control<br>Section<br>Name | Publication<br>Reference | Library Type | Macro<br>Instruc-<br>tion | SVC<br>No. | Name                                                    |
|                  | Control<br>Section | IGE0325C                 | IECWTORD                   | Appendix H               | SVC          |                           |            | Write-to-Operator Routine,<br>Load 4 of 5 <sup>1</sup>  |
|                  | Object<br>Module   | IGE04001                 | IGE04001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series Error<br>Routine, Load 5 of 7     |
|                  | Control<br>Section | IGE0425C                 | IECWTORE                   | Appendix H               | SVC          |                           |            | Write-to-Operator Routine,<br>Load 5 of 5 <sup>1</sup>  |
|                  | Object<br>Module   | IGE0425F                 | IGE0425F                   | Program<br>Organization  | SVC          |                           |            | System Environment Recording<br>Message Routine         |
| IGE0800I         | Object<br>Module   | IGE0800I                 | IEC3420J                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series Error<br>Routine, Load 7 of 7     |
| IGE09001         | Object<br>Module   | IGE09001                 | IEC24001                   | Appendix H               | SVC          |                           |            | 2400/3400 Tape Series<br>Error Routine, Load 6 of 7     |
| IGFCAT           | Routine            | *                        | IGFCAT                     | Program<br>Organization  | NUC          |                           |            | Channel Check Handler<br>Routine                        |
| IGX00015         | Object<br>Module   | IGX00015                 | IGX00015                   | Appendix A               | SVC          |                           |            | Extended SVC Routine                                    |
| INTAPR01         | Routine            | *                        | *                          | Appendix B               | NUC          |                           |            | Alternate Path Retry<br>Routine                         |
| INTATT           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Attention Routine Interface                             |
| INTCS            | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Channel Search Routine                                  |
| INTDAT           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Trap Routine for Direct-Access<br>Devices               |
| INTERR           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Error Routine Interface                                 |
| INTSEN           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Sense Subroutine                                        |
| INTTAT           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Trap Routine for Magnetic<br>Tape Devices               |
| INTURT           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Trap Routine for Unit Record and Communications Devices |
| INT027           | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Channel Restart Routine                                 |
| IONPSW           | Table              | *                        | *                          | Data Areas               |              |                           |            | I/O New PSW                                             |
| IOPSWO           | Table              | *                        | *                          | Data Areas               |              |                           |            | I/O Old PSW                                             |
| PRGCOMA          | Routine            | *                        | *                          | Program<br>Organization  | NUC          |                           |            | Quiesce Complete Subroutine                             |

\* Refer to installation system generation listing.

1 Do not confuse with the Write-To-Operator SVC routine (SVC35 described in the other OS/VS publications.

Figure 28. (Part 4 of 5) Module Directory

|                  |                    | Object         | Control         |                          |              |   | Macro            |            | If SVC Routine                                                     |  |
|------------------|--------------------|----------------|-----------------|--------------------------|--------------|---|------------------|------------|--------------------------------------------------------------------|--|
| Symbolic<br>Name | Description        | Module<br>Name | Section<br>Name | Publication<br>Reference | Library Type |   | Instruc-<br>tion | SVC<br>No. | Name                                                               |  |
| SERR01           | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | SER CCH/MCH Routine<br>Interface                                   |  |
| SVCOPSW          | Table              | *              | *               | Data Areas               |              |   |                  |            | SVC Old PSW                                                        |  |
| WC017            | Control<br>Section | IGC0001G       | SVC017          | Appendix A               | SVC          | 3 | RESTORE          | 17         | Restore Routine                                                    |  |
| ΓSTAR            | Table              | *              | *               | Data Areas               | NUC          |   |                  |            | Request Queue Element Table                                        |  |
| ALCHK            | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Validity Check Subroutine                                          |  |
| КСРСН            | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Test Channel Routine                                               |  |
| KCPPDQ           | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Dequeue Subroutine                                                 |  |
| KCPPIO           | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Post Start I/O Routine                                             |  |
| XCPPNQ           | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Enqueue Subroutine                                                 |  |
| XCPPST           | Routine            | *              | *               | Program<br>Organization  | NUC          |   |                  |            | Post Routine Interface                                             |  |
| XCPSIO           | Routine            | *              | *               | Method of Operation      | NUC          |   |                  |            | Start I/O Subroutine                                               |  |
| XCPTST           | Routine            | *              | *               | Method of Operation      | NUC          |   |                  |            | Get Request Element<br>Routine                                     |  |
| XIODSKI          | Routine            | *              | *               | Method of<br>Operation   | NUC          |   |                  |            | Start 1/O Routine for<br>Direct-Access Devices                     |  |
| XIOTPE           | Routine            | *              | *               | Method of Operation      | NUC          |   |                  |            | Start I/O Routine for<br>Magnetic Tape Devices                     |  |
| XIOUR            | Routine            | *              | *               | Method of<br>Operation   | NUC          |   |                  |            | Start I/O Routine for<br>Unit Record and<br>Communications Devices |  |
| XVCK01           | Routine            | *              | *               | Method of<br>Operation   | NUC          |   |                  |            | EXCP Validity Check<br>Routine                                     |  |

\* Refer to installation system generation listing.

Figure 28. (Part 5 of 5) Module Directory

62 OS/VS2 1/O Supervisor Logic

# **Routine Directory**

1

þ

Figure 29 lists the routines that make up the I/O supervisor's nucleus. The routines are listed alphabetically by name with their entry point and reference.

| Routine Name                    | Entry Point | Method of<br>Operation<br>Figure | Program<br>Operation<br>Figure |
|---------------------------------|-------------|----------------------------------|--------------------------------|
| ABTERM interface                | XERX04      |                                  |                                |
| Alternate Path Retry            | INTAPR01    |                                  |                                |
| Attention Routine Interface     | INTATT      |                                  | 25                             |
| CCW Translator                  | TRATCCW     | 16                               | 24                             |
| Channel Check Handler           | IGFCAT      |                                  | 25                             |
| Channel Check Handler Interface | SERR01      |                                  | 25                             |
| Channel Restart                 | INT027      | 19                               | 25                             |
| Channel Search                  | INTCSn      | 20                               | 25                             |
| CSW Translate                   | TRATCSW     |                                  |                                |
| DAVV Attention                  | INTATN      |                                  |                                |
| ODR Appendage Support Interface | DDRAPNVT    |                                  |                                |
| DEB Validity Check              | DEBVAL      | 9                                |                                |
| Dequeue                         | XCPPDQ      |                                  |                                |
| Direct Access Extent Test       | EXTTST      |                                  |                                |
| Direct Access Trap              | INTDAT      |                                  |                                |
| Enqueue Subroutine              | XCPPNQ      |                                  | 24,26                          |
| Error EXCP                      | IECXCPER    | 23                               | 26                             |
| Error Recovery Routine          |             |                                  | 26                             |
| Error Routine Interface         | INTERR      | 22                               | 25,26                          |
| EXCP Supervisor                 | XEXCP       | 8                                |                                |
| FIFO Enqueue                    | XCPENQ      |                                  |                                |
| Get Request Element             | XCPTST      | 10                               |                                |
| ню                              | IECIHIO     |                                  |                                |
| /O Interruption Supervisor      | IECINT      | 17                               |                                |
| Inline Fix/Unfix Subroutine     | ILFXS100    |                                  |                                |
| Local GETMAIN Subroutine        | GTFRM000    |                                  |                                |
| Machine Check Handler           | IGFNUC00    |                                  | 25                             |
| Machine Check Handler Interface | IERR01      |                                  | 25                             |
|                                 | XCPSEQ      |                                  | 25                             |
| Ordered Seek Enqueue            |             | ····                             | 23                             |
| Page Exception Handler          | IECXPGEY    |                                  | ••••                           |
| Page Fix                        | TRAFIXA     | 15                               | 24                             |
| Page-Fix Appendage Interface    | PGFXINT     | ••••                             |                                |
| Post Routine Interface          | XCPPST      |                                  | 25                             |
| Post Start I/O                  | XCPPIO      | 14                               | 24                             |
| Priority Enqueue                | XCPPRQ      |                                  |                                |
| Program Check Recovery          | IECCPL00    |                                  |                                |

|                                           |             | Method of<br>Operation | Program<br>Operation |
|-------------------------------------------|-------------|------------------------|----------------------|
| Routine Name                              | Entry Point | Figure                 | Figure               |
| Quiesce Complete Subroutine               | PRGCOMA     |                        | 25                   |
| RMS Channel Restart Interface             | INTRMS      |                        |                      |
| RMS Module Loader Interface               | IECRMS      |                        |                      |
| Sense Subroutine                          | INTSEN      | 21                     | 25                   |
| Service Interface Routine                 | IEASIRBE    |                        |                      |
| SIO Subroutine                            | XCPSIO      | 13                     | 24                   |
| Start I/O Routine for DASD                | XIODSK      | 12                     | 24                   |
| Start I/O Routine for Tape                | XIOTPE      | 11                     | 24                   |
| Start I/O Routine for UR and TP           | XIOUR       |                        | 24                   |
| Start I/O Routine for 2305                | XEUSIO      |                        | 24                   |
| System Environment Recording              | IEAMCH00    |                        | 25                   |
| System Environment Recording<br>Interface | SERR01      |                        | 25                   |
| Test Channel                              | XCPTCH      |                        | 24                   |
| TSO TCB EXCP Interface                    | IECXPT      |                        |                      |
| Unfix/Freemain                            | TRAUFRE     |                        |                      |
| Unit Record Trap                          | INTURT      |                        |                      |
| Validity Check                            | XVCK01      | 9                      | 24                   |
| Figure 29. (Part 2 of 2) Routine Di       | irectory    |                        |                      |

# **DATA AREAS**

The major paths by which I/O supervisor routines can reach specific data areas are shown in Figure 30. The longer paths are seldom used, because pointers to major data areas are normally maintained in registers. For example IOBREG, which is register 2, will normally contain the address of the IOB for a request in process. One exception is the Purge routine, which must use the longer paths in locating and removing elements from queues.



| Offset | Field Name                                                                                                                                   | Content                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1(1)   | DEBTCBAD                                                                                                                                     | Task Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17(11) | DEBUSRPG                                                                                                                                     | First IOB in Purge Chain                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25(19) | DEBDCBAD                                                                                                                                     | Data Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 33(21) | DEBUCBAD                                                                                                                                     | Unit Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5(5)   | IOBECB                                                                                                                                       | Event Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 17(11) | IOBST                                                                                                                                        | Requester's Channel Program                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21(15) | IOBDCB                                                                                                                                       | Data Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0(0)   | LCHFTS                                                                                                                                       | First RQE in Logical Channel Queue                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2(2)   | LCHLTS                                                                                                                                       | Last RQE in Logical Channel Queue                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0(0)   | TSTLNK                                                                                                                                       | Next RQE in Logical Channel Queue                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2(2)   | TSTUCB                                                                                                                                       | Unit Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5(5)   | TSTIOB                                                                                                                                       | Input/Output Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9(9)   | TSTDEB                                                                                                                                       | Data Extent Block                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12(0C) | TSTKEY                                                                                                                                       | Protect Key                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13(0D) | TSTTCBAD                                                                                                                                     | Task Control Block                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16(10) | TSTHDR                                                                                                                                       | Page-fix list before translation. Translation<br>Header BEBLK during and after translation.                                                                                                                                                                                                                                                                                                                                                                                  |
| 10(A)  | UCBLCI                                                                                                                                       | Value which, when multiplied by 8, becomes an index<br>to the logical channel word for the logical channel<br>containing device.                                                                                                                                                                                                                                                                                                                                             |
|        | 1(1)<br>17(11)<br>25(19)<br>33(21)<br>5(5)<br>17(11)<br>21(15)<br>0(0)<br>2(2)<br>0(0)<br>2(2)<br>5(5)<br>9(9)<br>12(0C)<br>13(0D)<br>16(10) | 1(1)         DEBTCBAD           17(11)         DEBUSRPG           25(19)         DEBDCBAD           33(21)         DEBUCBAD           5(5)         IOBECB           17(11)         IOBST           21(15)         IOBDCB           0(0)         LCHFTS           2(2)         LCHLTS           0(0)         TSTLNK           2(2)         TSTUCB           5(5)         TSTIOB           9(9)         TSTDEB           12(0C)         TSTKEY           13(0D)         TSTHDR |

.

#### Figure 30. Data Area Relationships

#### **Data Area Layouts**

This section contains descriptions of the principle data areas used by routines of the I/O supervisor. Refer to OS/VS2 System Data Areas for data areas that are common to other VS functions.

The symbolic names shown in individual data area fields represent the offset, in bytes, from the beginning of a table to the field. Access is gained to a specific field by using an instruction in which the beginning address of the table (usually contained in a register) is the base address, and the symbolic field name represents the displacement.

Usage of the data area fields can be traced in the I/O supervisor listings by first locating the symbolic field names in the cross-reference table at the back of the listings and then noting where the names are used. Where no symbolic name appears in a data area field, the field is not referred to by the I/O supervisor.

#### **Alternate Path Table**

The alternate path table (Figure 31) contains a record of the paths by which a device can be reached. There is one alternate path table for each logical channel that contains more than one channel. In the listings, an alternate path table immediately precedes the Test Channel routine for its associated channel.

| Channel | Address | Path N    | umber      |     |                                                 |
|---------|---------|-----------|------------|-----|-------------------------------------------------|
| .,      | ·       |           | "          | 1   | Two to Four Fullword<br>Entries, Depending Upon |
| ,,      | · · ·   |           | ,,         | 1   | Number of Alternate Paths                       |
|         | i "     | "         | ,,         |     |                                                 |
| No. (   | f Paths | Sum of Pa | th Numbers | 1 } | Control Entry.                                  |

Figure 31. Alternate Path Table

### **Appendage Vector Table**

The Appendage Vector Table (AVT, Figure 32) contains the virtual address of each I/O appendage and the number of pages that must be fixed for each appendage. The first byte of each 4-byte field contains the number of pages to be fixed for the appendage whose virtual address is in the remaining three bytes of the field.

| Dec | Hex |        |                                                         |
|-----|-----|--------|---------------------------------------------------------|
| 0   | 0   | APGEOE | End of Extent (EOE)                                     |
| 4   | 4   | APGSIO | Start I/O (SIO) and<br>Page-Fix Appendage.<br>See Note. |
| 8   | 8   | APGPCI | Program Controlled<br>Interrupt (PCI)                   |
| 12  | 0C  | APGCHE | Channel End (CE)                                        |
| 16  | 10  | APGABE | Abnormal End (XCE)                                      |

Note: If bit 0 of byte 4 is set to 1, the SIO appendage contains the page fix (PGFX) appendage. If bit 1 of byte 4 is set to 1, the SIO appendage is entered even if ERP is active.

| Field  | Dec  | Hex  | Field | Dec  | Hex  |
|--------|------|------|-------|------|------|
| APGABE | 0016 | 0010 | CE    | 0013 | 000D |
| APGCHE | 0012 | 000C | EOE   | 0001 | 0001 |
| APGEOE | 0000 | 0000 | PCI   | 0009 | 0009 |
| APGPCI | 0008 | 0008 | SIO   | 0005 | 0005 |
| APGSIO | 0004 | 0004 | XCE   | 0017 | 0011 |

Figure 32. Appendage Vector Table

### **BEBLK (Beginning-End Block)**

A beginning-end block (BEBLK, Figure 33) contains the real copy of the CCWs and the beginning and ending addresses of the user's virtual CCWs, of which these CCWs are the equivalent. A BEBLK can map up to 15 contiguous CCWs. If two CCW extents are mapped, then up to 14 CCWs and a second set of beginning and ending addresses of the user's virtual CCWs are contained in the BEBLK. The second extent information is located directly after the last CCW required for the first range.



### **Channel Address Word**

A channel refers to the Channel Address Word (CAW, Figure 34) during execution of a start I/O instruction. It provides the channel with a means of determining the real storage location from which it should fetch the first CCW. The CAW is permanently assigned to real storage location 72.

| Dec        | Hex                             |                   |                |  |  |  |  |  |
|------------|---------------------------------|-------------------|----------------|--|--|--|--|--|
| 0          | 0                               | CAWLOC            |                |  |  |  |  |  |
|            |                                 | Protection<br>Key | Address of CCW |  |  |  |  |  |
| Field      | <u>_</u>                        | Dec               | Hex            |  |  |  |  |  |
| CAW<br>CCW | LOC<br>Addre                    | 0000<br>ss 0001   | 0000<br>0001   |  |  |  |  |  |
| Fig        | Figure 34. Channel Address Word |                   |                |  |  |  |  |  |

# **Channel Command Word**

The Channel Command Word (CCW, Figure 35) indicates to a channel what I/O operation should be started. For operations involving data transfer, the CCW also indicates the real storage location into which data is to be placed or read from, and how many bytes of data are to be transferred.

| Command<br>Code | Data Ad                                        | dress | Flags* 000 Count                                                                                                                                     |
|-----------------|------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 78                                             |       | 31         32         36         37         39         40         47         48         63                                                           |
| *Flags and      | Masks                                          |       |                                                                                                                                                      |
| lag             |                                                |       |                                                                                                                                                      |
| Field           | Contains                                       | Hex   | Means                                                                                                                                                |
| Flags           | Chain-data                                     |       |                                                                                                                                                      |
| -               | (CD) flag                                      | X'80' | The data area designated by the next CCW to be used with current operation.                                                                          |
|                 | Chain-command                                  |       |                                                                                                                                                      |
|                 | (CC) flag                                      | X'40' | The operation specified by the command code of the next CCW is to be initiated on normal completion of the current operation.                        |
|                 | Suppress-incorrect-<br>length indicator (SILI) | X'20' | The incorrect length status bit in the channel status word is not to be set by the channel if an incorrect length condition is detected.             |
|                 | Skip flag                                      | X'10' | Data transfer to storage is suppressed. Valid only for read, read backward, and sense operations.                                                    |
|                 | PCI flag                                       | X'08' | The channel causes an interruption when this CCW is fetched.                                                                                         |
|                 | Indirect address                               |       |                                                                                                                                                      |
|                 | flag                                           | X′04′ | The channel references the indirect address list at the<br>start of the I/O operation and whenever a 2K<br>boundary is reached during data transfer. |

#### Figure 35. Channel Command Word

# **CCW Translation Header BEBLK**

The CCW translation header BEBLK (Figure 36) contains the addresses of the first and last CCWs in the corresponding virtual channel program. This BEBLK can map up to 12 contiguous CCWs. If two CCW extents are mapped, then up to 11 CCWs and a second set of beginning and ending addresses of the user's virtual CCWs are contained in the header BEBLK. The second extent information is located directly after the last CCW of the first extent. This block also contains pointers required for translation of the entire channel program. Figure 37 shows the interrelationship of the translation control blocks.



72 OS/VS2 I/O Supervisor Logic



## **Channel Error Block Table**

The optional alternate path retry routines use the channel error block table (Figure 38). It contains entries (Figure 39) used to keep track of the failing paths to a device. (Alternate path retry routines remove failing paths from contention so that retries are only attempted on remaining nonfailing paths.)





| Dec   | Hex    |                                   |                      |                                            |
|-------|--------|-----------------------------------|----------------------|--------------------------------------------|
| 0     | 0      | CEBINA                            | CEBCHMSK             | CEBRQE                                     |
|       |        | Active/In-<br>active<br>indicator | Failing path<br>mask | Address of<br>RQE for fail-<br>ing request |
| Field |        | Dec                               | Hex                  |                                            |
| CEBC  | нмѕк   | 000                               | 1 0001               |                                            |
| CEBIN |        | 0000                              |                      |                                            |
| CEBR  | QE     | 0002                              | 2 0002               |                                            |
| Elene | - 20 0 | Ne ann al Trance                  | Dia da Tabi          | Entre                                      |

Figure 39. Channel Error Block Table Entry

# **Channel Status Word**

The Channel Status Word (CSW, Figure 40) indicates to a program the status of an I/O device, control unit, channel, and subchannel. The CSW is assigned permanently to real storage location 64. After an I/O interruption, the channel stores information in the CSW, and also during execution of the start I/O, test I/O, and halt I/O instructions.

| Dec                    | Hex                                                     |                                                                                                   |                                                                                                          |                                                                                                                                |                                                                                                                                                                                                                                                                 |   |  |
|------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|
| 0                      | 0                                                       | Protection K                                                                                      | ey                                                                                                       | Address of Last CCW + 8                                                                                                        |                                                                                                                                                                                                                                                                 |   |  |
| 4                      | 4                                                       | Statu                                                                                             | s                                                                                                        |                                                                                                                                | Count                                                                                                                                                                                                                                                           |   |  |
| Cour<br>Prote<br>*Stat | ess of Lite<br>ection K<br>tus<br>gs and M<br>g<br>d Co | asks<br>He><br>ntains<br>Valu<br>e 1 X'80<br>X'40<br>X'10<br>X'02<br>X'02<br>X'02<br>X'02<br>X'01 | e A<br>Si Ci<br>Si Ci<br>Si Ci<br>Si Ci<br>D<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci<br>Ci | ttent<br>ttent<br>tatus<br>ontro<br>usy<br>hanne<br>evice<br>nit ch<br>nit ch<br>rograi<br>rograi<br>rograi<br>roteci<br>hanne | Hex<br>1001<br>1006<br>1000<br>1004<br>Means<br>tion<br>s modifier<br>ol unit end<br>hel end<br>e end<br>check<br>exception<br>am controlled interruption<br>rect length<br>am check<br>ction check<br>hel data check<br>hel control check<br>ace control check | - |  |
|                        |                                                         | X'01                                                                                              | ' C                                                                                                      | haini                                                                                                                          | ing check                                                                                                                                                                                                                                                       |   |  |

Figure 40. Channel Status Word

# **Channel Table**

The channel table consists of entries containing address of channel search routines, arranged in channel number order (Figure 41). It is used when a channel becomes free and a channel-dependent channel search routine is needed to select requests that should be started next. The format of a channel table entry is shown in Figure 42.





| Dec             | Hex                 |                                           |                  |                 |                        |
|-----------------|---------------------|-------------------------------------------|------------------|-----------------|------------------------|
| 0               | 0                   | Address<br>of Channe<br>Search<br>Routine | el               | Channel<br>Mask | Reserved               |
| Field           |                     |                                           | Dec              | Hex             |                        |
|                 | ss of Chai<br>utine | nnel Search                               | 0000             | 0000            |                        |
| *Chan<br>Reserv | nel Mask<br>red     |                                           | 2 0002<br>3 0003 |                 |                        |
| * Flags         | and Mas             | <u><s< u=""></s<></u>                     |                  |                 |                        |
| Flag<br>Field   |                     | Contains                                  |                  | Hex<br>Value    | Means                  |
|                 | el Mask             |                                           |                  | X'80'           | Channel 0              |
| Chann           | CINNASK             |                                           |                  | X'40'           | Channel 1              |
|                 |                     |                                           |                  | X'20'           | Channel 2              |
|                 |                     |                                           |                  | X'10'           | Channel 3              |
|                 |                     |                                           |                  | X'08'           | Channel 4              |
|                 |                     |                                           |                  | X'04'           | Channel 5              |
|                 |                     |                                           |                  | X'02'<br>X'01'  | Channel 6<br>Channel 7 |
|                 |                     |                                           |                  |                 | 0.12.11101 /           |



# **Device Statistics Table**

The device statistics table contains counters that are used to keep track of the number of times error conditions have occurred on I/O devices.

There is one 10-byte entry in the device statistics table for each I/O device in a system; in addition, there is a 10-byte control field at the beginning of the table which is used in locating entries to be updated (Figure 43).

In the case of the 3400 tape devices, a 20-byte statistics table entry is allocated for each device in a system.





There are four general formats of device statistics table entries (Figure 44). Bytes 0 through 7 of every entry contain as many four-bit counters as are needed to keep the relevant statistics for the device. Bytes 8 and 9 of each entry are work areas into which error routines place bit patterns indicating which counters are to be incremented.

#### Unit Record Devices

| 0(0)<br>Temporary<br>Read<br>Failures | Temporary<br>Write<br>Failures | 1(1)      | Bus-Out<br>Check  | 2(2)<br>Equipment<br>Check | Overrun | 3(3)<br>Device<br>Dependent<br>(Sense Byte 6) | Device<br>Dependent<br>  (Sense Byte 7) |
|---------------------------------------|--------------------------------|-----------|-------------------|----------------------------|---------|-----------------------------------------------|-----------------------------------------|
| 4(4)                                  |                                | 5(5)      |                   | 6(6)                       |         | 7(7)                                          |                                         |
| 8(8)<br>Work                          | Area                           | 9(9)<br>W | √ork Ar <b>ea</b> |                            |         |                                               |                                         |

#### 2400/3400 Series Magnetic Tape Devices

| 0(0)<br>Temporary<br>Read<br>Failures     | Temporary<br>Write<br>Failures      | 1(1)<br>Intervention<br>Required | Bus-Out<br>Check              | 2(2)<br>Equipment<br>Check               | Overrun  | 3(3)<br>Ward<br>Count<br>Zero        | Data<br>Converter<br>Check |
|-------------------------------------------|-------------------------------------|----------------------------------|-------------------------------|------------------------------------------|----------|--------------------------------------|----------------------------|
| 4(4)<br>Read/Write<br>Vert. Red.<br>Check | Longitudinal<br>Redundancy<br>Check | 5(5)<br>Skew                     | Cyclic<br>Redundancy<br>Check | 6(6)<br>Skew Reg.<br>Vert. Red.<br>Check | Noise    | 7(7)<br>Read<br>Opposite<br>Recovery | Channel<br>Data<br>Check   |
| 8(8)<br>Work Area                         |                                     | 9(9)<br>Work                     | Area                          |                                          | <b>_</b> |                                      |                            |

2314 Devices

ę

| 0(0)<br>Temporary<br>Read<br>Failures | Temporary<br>Write<br>Failures | 1(1)                                | Bus-Out<br>Check            | 2(2)<br>Equipment<br>Check            | Overrun | 3(3)<br>Track<br>Condition<br>Check  | Seek<br>Check |
|---------------------------------------|--------------------------------|-------------------------------------|-----------------------------|---------------------------------------|---------|--------------------------------------|---------------|
| 4(4)<br>Unsafe                        |                                | 5(5)<br>Serializer/<br>Deserializer | Control<br>Unit<br>Tag Line | 6(6)<br>Arithmetic<br>Logical<br>Unit |         | 7(7)<br>Missing<br>Address<br>Marker |               |
| 8(8)<br>Work                          | Area                           | 9(9)<br>Work                        | Area                        |                                       |         |                                      |               |

3410 Series Magnetic Tape Devices

| 0(0)               |                           | 1(1)               |                          | 2(2)                         |                            | 3(3)                       |                                   |
|--------------------|---------------------------|--------------------|--------------------------|------------------------------|----------------------------|----------------------------|-----------------------------------|
|                    |                           | N                  | Noise                    |                              | VRC                        |                            | LRCR                              |
|                    |                           | 1                  | ,0                       | 3,                           | 0                          | 3                          | ,1                                |
| 4(4)               |                           | 5(5)               |                          | 6(6)                         |                            | 7(7)                       |                                   |
| EDC,               | /CRC                      | Envelop            | Envelope Check           |                              | Skew                       | Spare                      | Spare                             |
| 3                  | ,3                        | 3,4                |                          | 0,5                          | 3,2                        | 3,7                        | 4,3                               |
| ID Expo            | k Bit<br>ansion           | Masi<br>2,0-       |                          | 10(A)<br>Write TM<br>Check   | Parity<br>Compare          | 11(B)<br>Tach<br>Check     | False<br>End Mark                 |
| 5,3                |                           | 0 1 2 3            | 4 5 6 7                  | 5,2                          | 5,4                        | 5,5                        | 5,6                               |
| 12(C)<br>Spare     | Feed-<br>Through<br>Check | 13(D)<br>Spare     | End<br>Velocity<br>Check | 14(E) No<br>Readback<br>Data | Start<br>Velocity<br>Check | 15(F)<br>Spare             | Spare                             |
| 8,0                | 8,1                       | 8,2                | 8,3                      | 8,4                          | 8,5                        | 8,6                        | 8,7                               |
| 16(10)<br>Not Used | Not Used                  | 17(11)<br>Not Used | Not Used                 | 18(12)<br>Backw              | rard                       | 19(13)<br>Bus Out<br>Check | Tape Unit<br>Positioning<br>Check |
| 9,0                | 9,1                       | 9,2                | 9,3                      | 3,                           | 6                          | 0,2                        | 4,0                               |

Figure 44. (Part 1 of 2) Device Statistics Table Entries

| 0(0)                   |                               |                             |   | 1(1)                              |                                          | 2(2)                                            |                                         | 3(3)                                           | 3(3)                           |  |
|------------------------|-------------------------------|-----------------------------|---|-----------------------------------|------------------------------------------|-------------------------------------------------|-----------------------------------------|------------------------------------------------|--------------------------------|--|
|                        |                               |                             |   | Nois                              | e                                        | Read W                                          | rite VRC                                | MTE,                                           | /LRCR                          |  |
|                        |                               |                             |   | 1,                                | 0                                        | 3                                               | ,0                                      | 3                                              | ,1                             |  |
| 4(4)                   |                               |                             |   | 5(5)                              |                                          | 6(6)                                            |                                         | 7(7)                                           | [                              |  |
|                        | EDC/                          | CRC                         |   | Envelope C                        | heck /VRC                                | Overrun                                         | Skew                                    | C-Compare                                      | Write<br>Trigger VRC           |  |
|                        | 3                             | ,3                          |   | 3                                 | , 4                                      | 0,5                                             | 3,2                                     | 3,7                                            | 4,3                            |  |
| 8(8)<br>PE<br>ID<br>CH | Mask<br>Expa                  |                             |   | 9(9) Track in<br>Mask Bi<br>2,0-7 |                                          | 10(A)<br>Write TM<br>Check                      | Start Read<br>Check                     | 11(B)<br>Partial Record                        | Excessive Post<br>Amble or TM  |  |
| 5,3                    | 1 1                           |                             | Ρ | 0 1 2 3                           | 4 5 6 7                                  | 5,2                                             | 5,4                                     | 5,5                                            | 5,6                            |  |
| 12(C<br>IBG            | )<br>Drop<br>e Writing<br>8,0 | Feed-Throug<br>Check<br>8,1 | h | 13(D)<br>Spare<br>8,2             | Early Begin<br>Read Back<br>Check<br>8,3 | 14(E)<br>Early End<br>Read Back<br>Check<br>8,4 | Slow Begin<br>Read Back<br>Check<br>8,5 | 15(F)<br>Slow End<br>Read Back<br>Check<br>8,6 | Velocity Retry<br>8,7          |  |
| 16(10                  | 0)                            |                             |   | 17(11)                            |                                          | 18(12)                                          |                                         | 19(13)                                         | 1                              |  |
| No                     | ot Used                       | Vel. Chang<br>During Writ   |   | Not Used                          | Not Used                                 | Ba                                              | ckward                                  | Bus Out<br>Check                               | ALU Hardware<br>Err <b>o</b> r |  |
|                        | 9,0                           | 9,1                         |   | 9,2                               | 9,3                                      |                                                 | 3,6                                     | 0,2                                            | 4,0                            |  |

Figure 44. (Part 2 of 2) Device Statistics Table Entries

# **Device Table**

The device table (Figure 45) provides the I/O supervisor with a means for obtaining the addresses of certain device and queuing-option dependent routines. The format of a device table entry is shown in Figure 46.

| Priority Queuing Entry     | Unit Record Device        |
|----------------------------|---------------------------|
| FIFO Queuing Entry         | f Entries                 |
| Priority Queuing Entry     | Magnetic Tape Device      |
| FIFO Queuing Entry         | <b>Entries</b>            |
| Priority Queuing Entry     |                           |
| FIFO Queuing Entry         | Direct Access Device      |
| Ordered Seek Queuing Entry | )                         |
| Priority Queuing Entry     | <b>Telecommunications</b> |
| FIFO Queuing Entry         | Device Entries            |
| Priority Queuing Entry     | Graphics Device           |
| FIFO Queuing Entry         | <b>Entries</b>            |
| Priority Queuing Entry     | Dummy Device              |
| FIFO Queuing Entry         | <b>Entries</b>            |

Figure 45. Device Table

| Dec                                           | Hex                           |                                                         |                                                  |                                 |  |  |  |  |
|-----------------------------------------------|-------------------------------|---------------------------------------------------------|--------------------------------------------------|---------------------------------|--|--|--|--|
| 0                                             | 0                             | DV                                                      | TENQ                                             | DVTSIO                          |  |  |  |  |
|                                               |                               | Address of enqueue routine                              |                                                  | Address of start<br>I/O routine |  |  |  |  |
| 4                                             | 4                             | DV                                                      | TTRP                                             | DVTSEN                          |  |  |  |  |
|                                               |                               | Address<br>routine                                      | of trapcode                                      | Address of sense routine        |  |  |  |  |
| Field<br>DVTENQ<br>DVTSEN<br>DVTSIO<br>DVTTRP |                               | <u>Dec</u><br>0000<br>0006<br>0002<br>0004<br>Device Ta | Hex<br>0000<br>0006<br>0002<br>0004<br>ble Entry |                                 |  |  |  |  |
| Figu                                          | Figure 46. Device Table Entry |                                                         |                                                  |                                 |  |  |  |  |

# **Indirect Address List**

1

The Indirect Address List (IAL, Figure 47) contains the beginning address of the data areas that are not contiguous in real storage.

The real CCW's data address points to the IAL. Data transfer begins with the first address in the IAL and continues until a 2K boundary is reached. It then proceeds from the second address in the IAL. This process continues until the end of the data area is reached.



Figure 47. Indirect Address Lis

# Logical Channel Word

The Logical Channel Word (LCH, Figure 48) is an 8-byte data area which is used primarily to define the bounds of a logical channel queue. There is one logical channel word for each logical channel queue. All of the logical channel words together make up a table called the *logical channel table*. The format of a logical channel word is shown in Figure 49.



Figure 48. Logical Channel Queues

Dec Hex 0 0 LCHFTS LCHLTS Address of first RQE in logical channel Address of last RQE in logical channel queue queue 4 4 LCHSRH LCHTCH Work area Address of test channel routine Field Dec Hex LCHFTS 0000 0000 0002 0004 LCHLTS 0002 LCHSRH 0004 LCHTCH 0006 0006 Figure 49. Logical Channel Word

# Page Fix List

The Page Fix List (PGFX), built by the page fix routine, contains the address of pages that should not be removed from real storage through normal paging operations. Entries are made for control blocks and up to five appendages. The user page fix appendage, if provided, can also make entries into the list. Figure 50 shows the format of the page fix list.



|   | Field                                                                | DEC                                  | HEX                                  | Options                                          | and Flags                                                                                                       |
|---|----------------------------------------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
|   | Fix Entry 1<br>Fix Entry 2                                           | 0008<br>0016                         | 0008<br>0010                         | Options-                                         | -bits 1-7 valid on first entry only                                                                             |
|   | Fix Entry 3<br>Fix Entry 4<br>Fix Entry 5                            | 0024<br>0032<br>0040                 | 0018<br>0020<br>0028                 | <u>Hex</u><br>X'80'                              | <u>Means</u><br>Continuation flag                                                                               |
|   | Fix Entry 6<br>Fix Entry 7<br>Fix Entry 8                            | 0048<br>0056<br>0064                 | 0030<br>0038<br>0040                 | X'40'<br>X'20'<br>X'10'                          | Fix request<br>Free request<br>Page load to be done                                                             |
|   | Fix Entry 9<br>Fix Entry 10                                          | 0072<br>0080                         | 0048<br>0050                         | X'08'<br>X'02'                                   | Release option<br>Long term fix                                                                                 |
|   | Fix Entry 11<br>Fix Entry 12<br>Fix Entry 13                         | 0088<br>0096<br>0104                 | 0058<br>0060<br>0068                 | Flags-va                                         | lid on End Address entry                                                                                        |
| ł | Fix Entry 14<br>Fix Entry 15<br>Fix Entry 16<br>FXLSTCHN<br>FXLSTNXT | 0112<br>0120<br>0128<br>0000<br>0004 | 0070<br>0078<br>0080<br>0000<br>0004 | Hex<br>X'80'<br>X'40'<br>X'20'<br>X'10'<br>X'08' | <u>Means</u><br>Last entry<br>Null entry<br>Real address option for fix<br>Error flag<br>Suspend option for fix |

Figure 50. Page Fix List

### **Program Controlled Interrupt Modify Parameter List**

A Program Control Interrupt (PCI) appendage builds the PCI modify parameter list to define to the I/O interruption supervisor the CCWs that were modified during the execution of the PCI appendage. The I/O interruption supervisor then modifies the real channel program in the SQA according to the changes made by the PCI appendage.

Figure 51 shows the format of an entry in the list.



Figure 51. PCI Modify Parameter List Entry

### **Program Status Word**

The Program Status Word (PSW, Figure 52) is a two-way communication link between a CPU and a program. All PSWs occupy permanently assigned virtual storage locations. The PSWs to which the I/O supervisor refers are:

| Name        | Location | Symbolic Name |
|-------------|----------|---------------|
| SVC Old PSW | 32(20)   | SVCOPSW       |
| I/O Old PSW | 56(38)   | IOPSWO        |
| I/O New PSW | 120(78)  | IONPSW        |

Dec Hex

0

4

1

| 0 | OROOATIE            | Protection<br>Key and<br>1MWP | Condition Code<br>and Program<br>Mask | 00 |  |  |
|---|---------------------|-------------------------------|---------------------------------------|----|--|--|
| 4 | Instruction Address |                               |                                       |    |  |  |

| Field          |          | Dec   | Hex                                    |
|----------------|----------|-------|----------------------------------------|
| * 1 MWP        |          | 0001  | 0001                                   |
| Condition Co   | de       | 0002  | 0002                                   |
| Instruction A  | ddress   | 0004  | 0004                                   |
| * Program Ma   | sk       | 0002  | 0002                                   |
| Protection Ke  | ev.      | 0001  | 0001                                   |
| *0R00ATIE      |          | 0000  | 0000                                   |
| * Flags and Ma | asks     |       |                                        |
| Flag           |          | Hex   |                                        |
| Field          | Contains | Value | Means                                  |
| 1 MWP          |          | X'08' | EC mode bit must be set to 1.          |
|                |          | X'04' | Machine check interruptions can occur. |
|                |          | X'02' | The CPU is in the wait state.          |
|                |          | X'01' | The CPU is in the problem state.       |
|                |          | X'00' | The CPU is in the supervisor state.    |
| 0R00ATIE       |          | X'80' | Enabled for monitor calls              |
|                |          | X'40' | Enabled for program event recording    |
|                |          | X'20' | 0                                      |
|                |          | X'10' | 0                                      |
|                |          | X'08' | 31-bit addressing                      |
|                |          | X'04' | Dynamic address translation            |
|                |          | X'02' | Enabled for I/O interruptions          |
|                |          | X'01' | Enabled for external interruptions     |
| Program Masl   | ĸ        | X'08' | Fixed point overflow                   |
|                |          | X'04' | Decimal overflow                       |
|                |          | X'02' | Exponent underflow                     |
|                |          | X'01′ | Significance                           |
|                |          |       |                                        |

Figure 52. Program Status Word

#### **Request Queue Element**

The Request Queue Element (RQE, Figure 53) contains the address of the major control blocks needed to process a request for I/O activity.

During system generation, a number of RQEs are created to equal the maximum number of a new I/O operations that can be processed simultaneously by the new operating system. Except for the last, each of these unassigned RQEs contains only the address of the next RQE; the last RQE contains ones in its address, or link field. The chain of unassigned RQEs is called a freelist.

When a request for I/O activity is received by the I/O supervisor, it removes one RQE from the freelist, and the RQE is initialized with the addresses of control blocks needed to process the request.

When a request cannot be started immediately, the RQE is placed into a logical channel queue. The RQE remains in the queue until the needed device and a path to the device becomes available and, optionally, until high-priority requests for the same device and path are satisfied.

During the I/O activity, the address of the RQE is in the UCBLTS field of the UCB. An RQE is returned to the freelist when all I/O activity associated with the request it represents is completed.

All of the RQEs are located contiguously in real storage and are sometimes referred to as the request queue element table. The term table is used loosely, however, because access is gained to the specific RQEs by way of pointers and not by offsets from the beginning of the table.

| Hex |
|-----|
|     |
|     |

| 0  | 0  | TSTLNK<br>Address of next<br>RQE                                                                                                                        |    | TSTUCB<br>Address of UCB |  |  |
|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------------------------|--|--|
| 4  | 4  |                                                                                                                                                         |    | TSTIOB<br>ddress of IOB  |  |  |
| 8  | 8  | TSTPR<br>Priority                                                                                                                                       | Ad | TSTDEB<br>dress of DEB   |  |  |
| 12 | 0C | TSTKEY<br>Requester's<br>Protection<br>Key                                                                                                              | Ad | TSTTCBAD<br>dress of TCB |  |  |
| 16 | 10 | TSTHDR<br>CCW Translation flags; address of page-fix<br>list before CCW translation and address of<br>header BEBLK during and after CCW<br>translation. |    |                          |  |  |

| Field    | Dec  | Hex  |
|----------|------|------|
| TSTDEB   | 0009 | 0009 |
| *TSTHDR  | 0016 | 0010 |
| TSTIOB   | 0005 | 0005 |
| TSTKEY   | 0012 | 000C |
| TSTLNK   | 0000 | 0000 |
| TSTPR    | 0008 | 0008 |
| TSTTCB   | 0004 | 0004 |
| TSTTCBAD | 0013 | 000D |
| TSTUCB   | 0002 | 0002 |

#### \*Flags and Masks

| Flag   | 0           | Hex   | Maria                                                                                                                          |
|--------|-------------|-------|--------------------------------------------------------------------------------------------------------------------------------|
| Field  | Contains    | Value | Means                                                                                                                          |
| TSTHDR | CCW         | X'80' | Fixed requester                                                                                                                |
|        | Translation |       | SVC 114                                                                                                                        |
|        | Flags       | X'40' | Virtual requester                                                                                                              |
|        |             | X'20' | Nonpageable requester                                                                                                          |
|        |             | X'10' | Page supervisor is requester                                                                                                   |
|        |             | X'08' | Translation in progress                                                                                                        |
|        |             | X'04' | Translation complete                                                                                                           |
|        |             | X'02  | Used by an SVC 114 request to<br>re-execute a channel program out<br>of the channel-end appendage<br>following error recovery. |
|        |             | X'01' | RQE has been queued on LCH                                                                                                     |

# Figure 53. Request Queue Element

#### Start Input/Output Extend Parameter List

A Start Input/Output (SIO) appendage (Figure 54) builds the SIO extend parameter list to define to the EXCP supervisor all of the CCWs that might be used in an I/O operation. The EXCP supervisor then translates all of the CCWs referenced on the list before issuing the start I/O instruction to the I/O device. Each entry in the list has the following format.

- If bit 0 of byte 0 of the count field is a 0, the count field specifies the number of contiguous CCWs in the string to be translated. The EXCP supervisor then translates the CCW string to real addresses. If the first CCW in the string has already been translated the EXCP supervisor assumes the entire string has been translated and bypasses the entry.
- If bit 0 of byte 0 of the count field is a 1, the count field specifies the maximum number of indirect address words required for the CCW. This implies that the CCW data address or length can change. The count is the maximum CCW data length to be used divided by 2K. Such entries must refer to CCWs within the CCW strings specified in the list. The EXCP supervisor constructs a corresponding real CCW with the indirect address word bit, bit 37(25), set to one and creates an indirect address list whether or not it is required.



Figure 54. SIO Extend Parameter List

### **Volume Statistics Table**

The volume statistics table contains information and statistics pertaining to volumes on 2400/3400 series magnetic tape devices. It contains one entry for each 2400 and 3400 magnetic tape device in a system.

The address of each entry is contained in the UCB for the device containing the volume. The entries may or may not be contiguous. The format of each entry varies according to the options selected at system generation time. If neither the error volume analysis (EVA) nor the error statistics by volume (ESV) options are selected, an entry will consist of only the first 8 bytes shown in Figure 55. If only EVA was specified, each entry will consist of the first 16 bytes whown. If ESV or both ESV and EVA were specified, the length of each entry will be the full 24 bytes.

For 3400 series magnetic-tape units, the length of each entry is always 24 bytes.

For 3400 series magnetic-tape units, the length of each entry is always 24 bytes.



\*'Mode Set' when tape device has extended sense.

| Field                  | Dec  | Hex  | Field                  | Dec  | Hex  |
|------------------------|------|------|------------------------|------|------|
| CCW for Read-Opposite  |      |      | Read Error Threshold   | 0010 | 000A |
| Recovery               | 0000 | 0000 | Reserved               | 0019 | 0013 |
| Cleaner Actions        | 0022 | 0016 | Start I/O              | 0014 | 000E |
| Erase Gaps             | 0020 | 0014 | Statistics Update Mask | 0008 | 0008 |
| Noise Blocks           | 0018 | 0012 | Temporary Read Errors  | 0012 | 000C |
| Permanent Read Errors  | 0016 | 0010 | Temporary Write Errors | 0013 | 000D |
| Permanent Write Errors | 0017 | 0011 | Write Error Threshold  | 0011 | 000B |

Figure 55. Volume Statistics Table Entry



# **DIAGNOSTIC AIDS**

This section contains information to help you interpret the program listings and diagnose program failures.

### **General Register Assignments**

Figure 56 shows the general register assignments for the resident parts of the I/O supervisor (EXCP Supervisor, I/O Interruption Supervisor, and Error EXCP Supervisor). Assignments for other routines can be found in the prologs to the routine listings.

| Register | Symbol                     | Assignment                                                                                                 |  |  |
|----------|----------------------------|------------------------------------------------------------------------------------------------------------|--|--|
| 0        | REG0                       | Temporary storage                                                                                          |  |  |
| 1        | TSTREG                     | RQE Address (For assigned but not-queued RQE)                                                              |  |  |
| 2        | IOBREG                     | IOB address                                                                                                |  |  |
| 3        | BASREG3                    | Base register for translator                                                                               |  |  |
| 3        | DEBREG                     | DEB address                                                                                                |  |  |
| 4        | BASREG5                    | Third base register                                                                                        |  |  |
| 4        | DCBREG                     | DCB address                                                                                                |  |  |
| 5        | BASREG                     | Base register for I/O supervisor                                                                           |  |  |
| 6        | BASREG4                    | Second base register for translator                                                                        |  |  |
| 6        | UAREG                      | Channel and unit address                                                                                   |  |  |
| 7        | UCBREG                     | UCB address                                                                                                |  |  |
| 8        | LNKGRI                     | Second Base register                                                                                       |  |  |
| 9        | ICREG<br>HDRREG<br>TCCWREG | Work register<br>Pointer to CCW translation header BEBLK<br>Pointer to CCW translation header BEBLK        |  |  |
| 10       | WKREG1                     | Work register                                                                                              |  |  |
| 11       | WKREG2                     | Work register                                                                                              |  |  |
|          | PRFXREG                    | Prefix storage address register                                                                            |  |  |
| 12       | WKREG3<br>LINKRG3          | Spare work/linkage register                                                                                |  |  |
| 13       | BEBREG                     | Address of current BEBLK                                                                                   |  |  |
| 13       | LCHREG                     | Logical channel word address                                                                               |  |  |
| 14       | LNKRG2                     | Linkage register                                                                                           |  |  |
| 15       | APBSRG                     | Used for calculating addresses of appendages to be invoked and used as a base register for the appendages. |  |  |
| Figure 5 | 6. General Reg             | gister Assignments                                                                                         |  |  |

## System Completion Codes

I

When a task is terminated abnormally, a three-digit system completion code printed in the storage dump generally indicates why. See OS/VS Message Library: VS2 System Codes for a complete list of system completion codes. The meanings of the codes produced when abnormal termination results from trouble during input/output processing are shown in Figure 57.

| Code | Explanation                                                                                                                                                                                                                                                                                                | Comments                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | An error was detected during EXCP processing; the<br>storage protection key of the IOB, ECB, or DCB was not<br>the same as the protection key field in the DEB.                                                                                                                                            | This system completion code will result if a program<br>check occurs while the DCB, ECB, or IOB is being<br>loaded for IOS EXCP validity checking. Typical causes<br>are premature freeing or overrunning of control blocks.<br>If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, and 92 in the IOS problem<br>determination area. |
| )    | An error was detected when an I/O operation was<br>requested; the storage protection key of the DEB was<br>not zero or the DEB validity check routine IFGDEBCK<br>returned to IOS with a nonzero return code.                                                                                              | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0 and 64 in the IOS problem determination area.                                                                                                                                                                                                                                             |
| )    | The control block chain between the IOB, DCB, DEB,<br>and UCB was invalid. The control program found that<br>one of the blocks was incorrectly modified or built.                                                                                                                                          | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0 and 64 in the IOS problem determination area.                                                                                                                                                                                                                                             |
| 0    | An unexpected program interruption occurred during processing of IOS. Note that the program interruption can be due to a page exception.                                                                                                                                                                   | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, 92, and 96 in the IOS problem<br>determination area.                                                                                                                                                                                                                             |
| 0    | <ul> <li>An SVC 114 was issued with one of the following conditions:</li> <li>The 'SVC114 authorization' bit was not set in the DEB.</li> <li>The protection key was not zero.</li> <li>The request was not issued in supervisor state.</li> <li>The authorization bit was not set in the JSCB.</li> </ul> | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offset 0 in the IOS problem determination area.                                                                                                                                                                                                                                                     |
| )    | A program check occurred in a supervisor service routine called by IOS.                                                                                                                                                                                                                                    | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, and 92 in the IOS problem<br>determination area.                                                                                                                                                                                                                                 |
| D    | An error occurred when IOS attempted to fix a page for this EXCP request.                                                                                                                                                                                                                                  | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, and 212 in the IOS problem<br>determination area.                                                                                                                                                                                                                                |
| 0    | A program check occurred in a user appendage or an attention routine.                                                                                                                                                                                                                                      | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, and 92 in the IOS problem<br>determination area.                                                                                                                                                                                                                                 |
| 00   | In translating CCWs out of the PCI appendage, IOS found one of the following:                                                                                                                                                                                                                              | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of                                                                                                                                                                                                                                                                                                        |
|      | <ul> <li>A buffer or channel program area had not been fixed.</li> <li>An invalid IAL entry in the SIO extent list.</li> </ul>                                                                                                                                                                             | offsets 0 and 64 in the IOS problem determination area.                                                                                                                                                                                                                                                                                                                                                     |
| 0    | Too many entries were specified by the page fix appendage in its page fix list.                                                                                                                                                                                                                            | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, and 84 in the IOS problem determination<br>area.                                                                                                                                                                                                                                     |
| 00   | A page which was referenced within the control blocks,<br>channel program, user page-fix list, or an appendage of<br>IOS which was not within the user's region, LSQA,<br>nucleus, SQA, or LPA.                                                                                                            | If an abnormal termination dump is available, see<br>"Problem Determination Area" for the meaning of<br>offsets 0, 64, 84, and 212 in the IOS problem<br>determination area.                                                                                                                                                                                                                                |

# **Problem Determination Area**

•

•

If an abnormal termination dump is available, the TCB field (TCBIOSAB) at offset 192 will contain a pointer to the IOS problem determination area. The format of this area is:

| Offset |     | t   | Field Description, Contents, Meaning                                                                             |  |  |  |
|--------|-----|-----|------------------------------------------------------------------------------------------------------------------|--|--|--|
|        | Dec | Hex |                                                                                                                  |  |  |  |
|        | 0   | 0   | Registers at the time of error                                                                                   |  |  |  |
|        | 64  | 40  | Contents of the RQE                                                                                              |  |  |  |
|        | 84  | 54  | Program check PSW at the time of the program check, or first page fix list if this is an ABEND 800, C00, or D00. |  |  |  |
|        | 92  | 5C  | ILC and interruption code                                                                                        |  |  |  |
|        | 96  | 60  | Only meaningful on page faults. This field contains the address causing the last page fault.                     |  |  |  |
|        | 212 | D4  | Second page fix list if it exists.                                                                               |  |  |  |

### Patch Area at IECINT

At IECINT is a 17-word storage area that can be used for diagnostic work. Since its location is not standard but differs for each system, refer to the address constant at label IOSORG for the true address.

#### **Generalized Trace Facility**

The Generalized Trace Facility (GTF) provides a method of tracing program events and recording information about these events. The trace records that are generated by GTF are stored internally in a table or recorded externally on a data set that becomes input to the AMDPRDMP service aid program. AMDPRDMP edits and formats the trace records as specified by an EDIT control statement.

٠

The I/O supervisor interfaces with GTF when it is optioned by using monitor call instructions (GTF hooks). Figure 58 shows the location of the GTF hooks and the information that is traced.

More information about GTF can be obtained from the following publications:

OS/VS Service Aids OS/VS2 Debugging Guide

| Location                             | Function                                                                                           | Register Contents                                                                                                                                          | Information Traced                                                                                                                                                                                         |
|--------------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| After label<br>INT001C               | Detects the occurrence<br>of an I/O interrupt with<br>an associated UCB.<br>(Normal I/O interrupt) | <ul> <li>R7 - UCB address</li> <li>R10 - Real CCW address from the CSW if an RQE exists for this request.</li> <li>R10 - Zero if no RQE exists.</li> </ul> | I/O Old PSW<br>CSW (Contains the virtual CCW<br>address+8 if it was a virtual<br>request.)<br>RQE<br>JOBNAME<br>DDNAME<br>Sense bytes 0 - 3.<br>I/O interrupt code.<br>Real CCW address+8.<br>TCB address. |
| After labels<br>INT001 and<br>INT00A | Detects the occurrence<br>of an I/O interrupt with-<br>out an associated UCB.                      | N/A                                                                                                                                                        | I/O Old PSW<br>CSW (Contains the real CCW<br>address.)<br>I/O interrupt code.                                                                                                                              |
| After label<br>XCP110D               | Detects the occurrence<br>of SIOs in the SIO<br>subroutine.                                        | R1 - RQE address.<br>R6 - Device address.<br>R10 - SIO condition code in low<br>order byte.                                                                | CSW (Contains real CCW address)<br>CAW (Contains real CCW address)<br>RQE<br>JOBNAME<br>TCB address.<br>SIO condition code.<br>Device address.<br>Virtual address of the virtual chan<br>nel program.      |
| After label<br>INT024C               | Detects an I/O interrupt with PCI status.                                                          | R7 - UCB address.<br>R10 - Real CCW address+8                                                                                                              | I/O Old PSW<br>CSW<br>RQE<br>JOBNAME<br>DDNAME<br>Sense bytes 0-3.<br>Real CCW address.<br>I/O interrupt code.<br>TCB address.                                                                             |

Figure 58. GTF Interfaces

6



### **APPENDIX A: SUPPORTING SVC ROUTINES**

The SVC routines described in this appendix are not generally used during normal processing of requests for I/O operations. They do, however, provide users with a capability for referring to, obtaining, and changing some of the data used in processing the I/O requests.

# Purge Routine (SVC 16)

The Purge routine stops the processing of I/O requests by removing request queue elements (RQEs) from queues. Depending upon the options specified in a parameter list which is provided as input (Figure 59), the Purge routine can remove RQEs from:

- A logical channel queue
- The supervisor's request block queues
- The supervisor's asynchronous exit queue
- The DDR wait queue

The Purge routine can remove the elements representing all requests for a particular data set or task. The method to be used is indicated in the seventh bit of the options field in the parameter list. The general flow of control within the Purge routine is shown in Figure 62. The PURGE macro instruction is described in OS/VS Data Management for System Programmers.

| •      | PRGFLG<br>Flags           |         | PRGQPL<br>Address of Quiesce I/O Parameter List |  |
|--------|---------------------------|---------|-------------------------------------------------|--|
| 12(0C) |                           | 13 (OD) |                                                 |  |
|        | PRGCTR<br>Quiesce Count   |         | PRGCHN<br>Address of First Link in Chain        |  |
| 8(8)   |                           | 9(9)    |                                                 |  |
|        | PRGCOD<br>Completion Code |         | PRGTCB<br>Address of Task Control Block         |  |
| 4(4)   |                           | 5(5)    |                                                 |  |
|        | PRGOPT<br>Purge Options   |         | PRGDEB<br>Address of Data Extent Block          |  |
| 0(0)   |                           | 1(1)    |                                                 |  |

Figure 59. Purge Routine Parameter List

#### **Removing Elements From Logical Channel Queues**

If all requests for a particular data set are to be purged, the Purge routine examines the data extent block (DEB) for the data set, and removes all RQEs from the logical channel queue for the device or devices whose unit control block (UCB) addresses are contained in the DEB. When an active shared device is allocated with a purged request, the I/O supervisor sets the UCB's HIO flag to issue a RELEASE to the device if its UCB reserve count field is zero.

When the elements for all requests associated with a particular task are to be purged, the Purge routine scans the entire request element table to locate and remove the RQEs for the task.

#### **Purge Routine Parameter List**

| RQEs. (A X'48' completion code is used.)        0       Allow the activity to quiesce.        1       Halt the I/O activity. (The effect of the Hai I/O instruction is simulated if the operation is a seek.)        0       Purge only related requests.              Purge only related requests.          0         Normal purge.           0         Normal purge.           1         Purge the asynchronous exit queue, the reque block queue, the logical channel queue, and DDR wait queue.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Offset | Bytes and<br>Alignment | Field<br>Name                                                                          | Field Description, Contents, Meaning                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>entries in the data extent block (DEB) chain, starting with the DEB whose address is in PRGDEB.</li> <li>1</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0(0)   | 1                      | PRGOPT                                                                                 | Purge options.                                                                                                                                                                            |
| <ul> <li>whose address is in PRGDEB.</li> <li>.0</li> <li>Do not post the event control blocks for the purged request queue elements.</li> <li>.1</li> <li>Post the event control blocks for the purged RQEs. (A X'48' completion code is used.)</li> <li>.0</li> <li>Allow the activity to quiesce.</li> <li>.1</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |                        |                                                                                        | entries in the data extent block (DEB)<br>chain, starting with the DEB whose<br>address is in PRGDEB.                                                                                     |
| <ul> <li>purged request queue elements.</li> <li>1 Post the event control blocks for the purged RQEs. (A X 4% completion code is used.)</li> <li>0 Allow the activity to quiesce.</li> <li>1 Halt the I/O activity. (The effect of the Hal I/O instruction is simulated if the operation is a seek.)</li> <li>0 Purge all requests.</li> <li> 0 Purge the asynchronous exit queue, the requeblock queue, the logical channel queue, and DDR wait queue.</li> <li> 1 Purge the asynchronous exit queue, the requeblock queue, the logical channel queue, and DDR wait queue.</li> <li> 1 Purge the asynchronous exit queue, the requests in error, and the DDR wait queue.</li> <li></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |                        | 1                                                                                      | whose address is in PRGDEB.                                                                                                                                                               |
| RQEs. (A X'48' completion code is used.)        0       Allow the activity to quiesce.        1       Halt the I/O activity. (The effect of the Hai I/O instruction is simulated if the operation is a seek.)        0       Purge only related requests.              Purge only related requests.          0         Normal purge.           0         Normal purge.           0         Normal purge.           0         Purge the asynchronous exit queue, the reque block queue, the logical channel queue, and DDR wait queue.          0         Purge by data extent block.               Not used.         1(1)       .3         PRGDEB       Address of data extent block.         4(4)       1         PRGCOD       Purge routine completion code.         5(5)       .3       PRGTCB         Address of task control block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |                        | .0                                                                                     |                                                                                                                                                                                           |
| <ul> <li>.0 Allow the activity to quiesce.</li> <li>.1 Halt the I/O activity. (The effect of the Hai I/O instruction is simulated if the operation is a seek.)</li> <li>0 Purge all requests.</li> <li>0. Normal purge.</li> <li>1 Purge TCB list.</li> <li>0. Normal queue.</li> <li>1 Purge the asynchronous exit queue, the requests in error, and the DDR wait queue.</li> <li>1. Purge by task control block.</li> <li>1. Purge by task control block.</li> <li></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        |                        | .1                                                                                     | Post the event control blocks for the purged RQEs. (A X'48' completion code is used.)                                                                                                     |
| I/O instruction is simulated if the operation is a seek.)        0       Purge all requests.        1       Purge only related requests.        0       Normal purge.        1       Purge TCB list.        0       Purge the asynchronous exit queue, the request for queue, the logical channel queue, and DDR wait queue.        1       Purge the asynchronous exit queue, the requests in error, and the DDR wait queue.        1       Purge by data extent block.        1.       Purge by data extent block.        1.       Purge by data extent block.        1.       Purge by data extent block.          Not used.         1(1)       .3       PRGDEB         Address of data extent block.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |                        |                                                                                        | Allow the activity to quiesce.                                                                                                                                                            |
| <ul> <li>1</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                        | 1                                                                                      | I/O instruction is simulated if the operation                                                                                                                                             |
| <ul> <li> 0 Normal purge.</li> <li> 1 Purge TCB list.</li> <li> 0 Purge the asynchronous exit queue, the requelock queue, the logical channel queue, and DDR wait queue.</li> <li> 1 Purge the asynchronous exit queue, the requests in error, and the DDR wait queue.</li> <li>Bypass the request blocks.</li> <li> 0. Purge by data extent block.</li> <li> 1 Purge by task control block. When this bit is the setting of bit 0 is ignored.</li> <li>x Not used.</li> <li>1(1) . 3 PRGDEB Address of data extent block.</li> <li>4(4) 1 PRGCOD Purge routine completion code.</li> <li>5(5) . 3 PRGTCB Address of task control block.</li> <li>8(8) 1 PRGCTR Quiesce count. The number of active reque queue elements for which I/O activity has a yet been completed.</li> <li>9(9) . 3 PRGCHN Address of the first link in the chain of IOE which are purged. The first IOB in the chain. The last IOB in the chain will contain ones in the low-order byte of the readdress (IOBRST) field.</li> <li>12(C) 1 PRGFLG Purge flags.</li> <li>0 Purge and wait.</li> <li> 0 DEQ before WAIT.</li> <li> 0 DEQ before WAIT (set before system 1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |                        | 0                                                                                      |                                                                                                                                                                                           |
| <ul> <li> 1 Purge TCB list.</li> <li> 0 Purge the asynchronous exit queue, the reque block queue, the logical channel queue, and DDR wait queue.</li> <li> 1 Purge the asynchronous exit queue, the requests in error, and the DDR wait queue. Bypass the request blocks.</li> <li> 0. Purge by data extent block.</li> <li> 1. Purge by task control block. When this bit i the setting of bit 0 is ignored.</li> <li>x Not used.</li> <li>1(1) . 3 PRGDEB Address of data extent block.</li> <li>4(4) 1 PRGCOD Purge routine completion code.</li> <li>5(5) . 3 PRGTCB Address of task control block.</li> <li>8(8) 1 PRGCTR Quiesce count. The number of active reque queue elements for which I/O activity has the yet been completed.</li> <li>9(9) . 3 PRGCHN Address of the first link in the chain of IOE which are purged. The first IOB in the chain will contain ones in the IOEBUSPRG fiet the DEB. It will point to the first IOB in the chain will contain ones in the low-order byte of the readdress (IOBRST) field.</li> <li>12(C) 1 PRGFLG Purge flags.</li> <li>0 Purge and wait.</li> <li>1 Wait entry.</li> <li>0 Purge and wait.</li> <li> 0 DEQ before WAIT.</li> <li> 0 No DEQ before WAIT (set before system I</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |                        |                                                                                        |                                                                                                                                                                                           |
| <ul> <li>0 Purge the asynchronous exit queue, the reques block queue, the logical channel queue, and DDR wait queue.</li> <li>1 Purge the asynchronous exit queue, the requassynchronous exit queue removing only RC requests in error, and the DDR wait queue. Bypass the request blocks.</li> <li>0. Purge by data extent block.</li> <li>1. Purge by task control block. When this bit is the setting of bit 0 is ignored.</li> <li>x Not used.</li> <li>1(1) . 3 PRGDEB Address of data extent block.</li> <li>4(4) 1 PRGCOD Purge routine completion code.</li> <li>5(5) . 3 PRGTCB Address of task control block.</li> <li>8(8) 1 PRGCTR Quiesce count. The number of active reque queue elements for which I/O activity has a yet been completed.</li> <li>9(9) . 3 PRGCHN Address of the first link in the chain of IOE which are purged. The first link can be loca in the user's area, or in the DEB/SPRG fie the DEB. It will point to the first IOB in the chain. The last IOB in the chain will contain ones in the low-order byte of the readdress (IOBRST) field.</li> <li>12(C) 1 PRGFLG Purge flags.</li> <li>0 Purge and wait.</li> <li> Wait entry.</li> <li>0 Purge and wait.</li> <li> No DEQ before WAIT.</li> <li> No DEQ before WAIT (set before system 1</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |                        |                                                                                        |                                                                                                                                                                                           |
| <ul> <li>asynchronous exit queue removing only RC requests in error, and the DDR wait queue. Bypass the request blocks.</li> <li></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                        | 0                                                                                      | Purge the asynchronous exit queue, the request<br>block queue, the logical channel queue, and the<br>DDR wait queue.                                                                      |
| 1.Purge by task control block. When this bit is<br>the setting of bit 0 is ignored.<br>X1(1).3PRGDEBAddress of data extent block.4(4)1PRGCODPurge routine completion code.5(5).3PRGTCBAddress of task control block.8(8)1PRGCTRQuiesce count. The number of active reque<br>queue elements for which I/O activity has a<br>yet been completed.9(9).3PRGCHNAddress of the first link in the chain of IOE<br>which are purged. The first link can be loca<br>in the user's area, or in the DEBUSPRG fie<br>the DEB. It will point to the first IOB in<br>the chain. The last IOB in the chain will<br>contain ones in the low-order byte of the re<br>address (IOBRST) field.12(C)1PRGFLGPurge flags.<br>012(C)1PRGFLGPurge flags.<br>00Purge entry.<br>1No DEQ before WAIT.<br>(set before system I)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                        | 1                                                                                      |                                                                                                                                                                                           |
| the setting of bit 0 is ignored.<br>Not used.1(1).3PRGDEBAddress of data extent block.4(4)1PRGCODPurge routine completion code.5(5).3PRGTCBAddress of task control block.8(8)1PRGCTRQuiesce count. The number of active reque<br>queue elements for which I/O activity has a<br>yet been completed.9(9).3PRGCHNAddress of the first link in the chain of IOE<br>which are purged. The first link can be loca<br>in the user's area, or in the DEBUSPRG file<br>the DEB. It will point to the first IOB in<br>the chain. The last IOB in the chain will<br>contain ones in the low-order byte of the re<br>address (IOBRST) field.12(C)1PRGFLG<br>O<br>Purge entry.<br>1Purge flags.<br>Numerical entry.<br>Numerical entry.<br> |        |                        |                                                                                        |                                                                                                                                                                                           |
| 1(1). 3PRGDEBAddress of data extent block.4(4)1PRGCODPurge routine completion code.5(5). 3PRGTCBAddress of task control block.8(8)1PRGCTRQuiesce count. The number of active reque<br>queue elements for which I/O activity has a<br>yet been completed.9(9). 3PRGCHNAddress of the first link in the chain of IOE<br>which are purged. The first link can be loca<br>in the user's area, or in the DEBUSPRG fie<br>the DEB. It will point to the first IOB in<br>the chain. The last IOB in the chain will<br>contain ones in the low-order byte of the re<br>address (IOBRST) field.12(C)1PRGFLG<br>0Purge flags.<br>010Purge and wait.<br>DEQ before WAIT.<br>No DEQ before WAIT (set before system I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |                        |                                                                                        | the setting of bit 0 is ignored.                                                                                                                                                          |
| 4(4)       1       PRGCOD       Purge routine completion code.         5(5)       .3       PRGTCB       Address of task control block.         8(8)       1       PRGCTR       Quiesce count. The number of active reque queue elements for which I/O activity has a yet been completed.         9(9)       .3       PRGCHN       Address of the first link in the chain of IOE which are purged. The first link can be loca in the user's area, or in the DEBUSPRG fie the DEB. It will point to the first IOB in the chain. The last IOB in the chain will contain ones in the low-order byte of the readdress (IOBRST) field.         12(C)       1       PRGFLG       Purge flags.         0       Purge entry.       1       Wait entry.         .0       Return before wait.       1       Purge and wait.         .0       DEQ before WAIT.        No DEQ before WAIT (set before system I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1(1)   | 3                      |                                                                                        | Address of data extent block                                                                                                                                                              |
| <ul> <li>8(8) 1 PRGCTR Quiesce count. The number of active reque queue elements for which I/O activity has a yet been completed.</li> <li>9(9) . 3 PRGCHN Address of the first link in the chain of IOE which are purged. The first link can be loca in the user's area, or in the DEBUSPRG fie the DEB. It will point to the first IOB in the chain. The last IOB in the chain will contain ones in the low-order byte of the re address (IOBRST) field.</li> <li>12(C) 1 PRGFLG Purge flags.<br/>0 Purge entry.<br/>1 Wait entry.<br/>0 Return before wait.<br/>.1 DEQ before WAIT.<br/> No DEQ before WAIT (set before system I)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |                        |                                                                                        |                                                                                                                                                                                           |
| queue elements for which I/O activity has a<br>yet been completed.9(9).3PRGCHNAddress of the first link in the chain of IOE<br>which are purged. The first link can be loca<br>in the user's area, or in the DEBUSPRG file<br>the DEB. It will point to the first IOB in<br>the chain. The last IOB in the chain will<br>contain ones in the low-order byte of the re<br>address (IOBRST) field.12(C)1PRGFLG<br>0<br>Purge entry.<br>1<br>No meta entry.<br>0<br>Purge and wait.<br><br>DEQ before WAIT.<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 5(5)   | . 3                    | PRGTCB                                                                                 | Address of task control block.                                                                                                                                                            |
| <ul> <li>which are purged. The first link can be local in the user's area, or in the DEBUSPRG file the DEB. It will point to the first IOB in the chain. The last IOB in the chain will contain ones in the low-order byte of the readdress (IOBRST) field.</li> <li>12(C) 1 PRGFLG Purge flags.</li> <li>0 Purge entry.</li> <li>1 Wait entry.</li> <li>.0 Return before wait.</li> <li>.1 Purge and wait.</li> <li>.0 DEQ before WAIT.</li> <li>.1 No DEQ before WAIT (set before system I</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8(8)   | 1                      | PRGCTR                                                                                 | Quiesce count. The number of active request queue elements for which I/O activity has not yet been completed.                                                                             |
| 0Purge entry.1Wait entry0.Return before wait1.Purge and wait0.DEQ before WAIT1.No DEQ before WAIT (set before system )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 9(9)   | . 3                    | PRGCHN                                                                                 | the chain. The last IOB in the chain will contain ones in the low-order byte of the restart                                                                                               |
| purged).<br>x Not used.<br>x Not used.<br>x Not used.<br>x. Not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12(C)  | 1                      | 0<br>1<br>.0<br>.1<br>.0<br>.1<br><br><br><br><br><br><br><br><br><br><br><br><br><br> | Purge entry.<br>Wait entry.<br>Return before wait.<br>Purge and wait.<br>DEQ before WAIT.<br>No DEQ before WAIT (set before system DEB<br>purged).<br>Not used.<br>Not used.<br>Not used. |

4

r



\* Field for Last Entry is X \*80\*

Figure 60. Quiesce I/O Parameter List

| -      |                        |                             | -                                                                                                                                            |  |  |  |
|--------|------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Offset | Bytes and<br>Alignment | Field Des                   | scription                                                                                                                                    |  |  |  |
| 0(0)   | 1                      | Temporary count field.      |                                                                                                                                              |  |  |  |
| 1(1)   | . 3                    | Not used.                   |                                                                                                                                              |  |  |  |
| 8(8) 8 |                        | First parameter list entry. |                                                                                                                                              |  |  |  |
|        |                        | Byte<br>0<br>1-3<br>4       | Description<br>Not used.<br>IOB chain field.<br>QPL flags.                                                                                   |  |  |  |
|        |                        |                             | 0         More entries follow.           1         Last entry.           .0         Not a current entry.           .1         Current entry. |  |  |  |
|        |                        | 5-7                         | Address of TCB to be purged.                                                                                                                 |  |  |  |

#### Quiesce I/O Parameter List (TSO Only)

Additional parameter list entries may be present.

#### **Removing Elements From the Supervisor's Request Block Queues**

To remove elements from a supervisor request block queue, the Purge routine obtains the address of the first request block in the queue from the TCB whose address is passed as input. When no TCB address is passed, it assumes that the current TCB is the input TCB. The Purge routine then scans the entire request block queue. For each system interruption request block (SIRB) and interruption request block (IRB) in the queue, the Purge routine removes the RQEs containing a DEB address which matches the input DEB address (for a purge by data set); or removes the RQEs containing a TCB address which matches the address of the input TCB (for a purge by task).

Descriptions of the SIRB and IRB are contained in OS/VS2 System Data Areas.

### **Removing Elements From the Supervisor's Asynchronous Exit Queues**

To remove request queue elements from the supervisor's asynchronous exit queue, the Purge routine first obtains the address of the queue from the communications vector table. It then scans the entire asynchronous exit queue, removing every RQE containing a DEB address which matches the input DEB address (for a purge by data set); or removing every RQE containing a TCB address which matches the address of the input TCB (for a purge by task). When a TCB address is not passed as input for a purge by task request, the Purge routine uses the current TCB for the matches.

The communications vector table is described in OS/VS2 System Data Areas.

# The IOB Chain

The Purge routine links the IOBs for purged requests together in a chain beginning at the address specified in the third word of the Purge routine parameter list (Figure 61). A RESTORE macro instruction could then be used to restart the requests. The Purge routine does not create an IOB chain when the halt I/O option is specified with the purge-by-TCB option.

4



#### Figure 61. Purge Routine

# The Quiesce Option

When the quiesce option is specified, the Purge routine increments two counters by one for each I/O request awaiting completion:

- A main purge counter in the parameter list
- A secondary counter in each effected DEB

Thus, if there is a request to quiesce activity for a specific data set, both counters will have a count of one. If there is a request to quiesce the activity on all data sets of a task, however, there will be counts in each DEB counter reflecting the number of not-yet-completed requests for the data sets, and there will be a total count in the main counter.

Every time the Purge routine increments a counter, it places a pointer to the purge parameter list into the 'address of purge parameter list' field of the DEB. Also, after it has put the total count in the main counter, the Purge routine issues a WAIT macro instruction.

When I/O activity has been completed for a request, the I/O interruption supervisor will enter its Quiesce Complete subroutine (entry point PRGCOMA or PRGCOMB) if it finds an address in the 'address of purge parameter list' field of the DEB for the newly completed activity. The Quiesce Complete subroutine decrements both the main and secondary counters by one. If a DEB secondary counter is zeroed, the 'address of purge



Figure 62. Purge Routine IOB Chain

parameter list' field in the DEB is also zeroed. When the main counter in the parameter list is zeroed, indicating the quiesce is complete, the Quiesce Complete subroutine posts the purge ECB. If the main counter is not zeroed, the Quiesce Complete subroutine return control to the I/O interruption supervisor.

# Purging a Virtual I/O Request

When purging a virtual I/O request, the CCW translation status must be considered before returning the RQE to the freelist. If translation is finished, the purge routine links to the I/O supervisor to unfix the pages and to return the SQA space that was gotten for this request to IOS. The RQE is then returned to the freelist.

If CCW translation is not finished, a paging I/O operation is in progress. In this case, the RQE is quiesced and the address of the purge parameter list is placed into the DEB. The purge routine then processes the next RQE. When the paging I/O operation is finished, the CCW translator examines the DEB to see if the RQE it was translating was purged. If it was, it completes the purge as stated in the previous paragraph.

# **Restore Routine (SVC 17)**

The Restore routine restarts the processing of requests that have been dequeued by means of the Purge routine if Halt I/O option was not specified with the purge-by-task option. Using a pointer to the first IOB in a chain of IOBs that it receives as input in register 1, the Restore routine issues an SVC 0 or an SVC 114 for each IOB in the chain, depending on the type of I/O operation purged.

The RESTORE macro instruction is described in OS/VS Data Management for System Programmers.

# **DEVTYPE Routine (SVC 24)**

The DEVTYPE routine supplies information about the characteristics of I/O devices. The instructions in the expansion of the Locate Device Characteristics (DEVTYPE) macro instruction place parameters into general registers, and the DEVTYPE routine uses the parameters to identify the device and to find where it should place the output information.

The DEVTYPE macro instruction is described in the publication OS/VS Data Management for System Programmers.

Using the DD name it receives as input, the DEVTYPE routine finds the corresponding task input/output table (TIOT) entry, and uses it to locate the proper UCB. The DEVTYPE routine then obtains the device type field from the UCB and places it into the first word of the output area.

If the DEVTAB parameter was not specified, the output area will contain two words of information. The DEVTYPE routine determines the maximum block size from the device charactersitics table (if the device is a direct-access device) or from internal constants, and moves it to the second word of the output area.

If the DEVTAB parameter was specified in the DEVTYPE macro instruction, and the device is a direct-access device, the DEVTYPE routine will provide three additional words of information. The DEVTYPE routine locates the device characteristics table via the communication vector table, moves the appropriate entry into the low-order three words of the output area, and moves the blocksize field to the second word of the output area.

Before relinquishing control, the DEVTYPE routine places a return code into register 15. A return code of 00 indicates that the request was completed successfully. A return code of 04 indicates one of the following conditions:

- No output area specified: The area parameter was not included in the DEVTYPE macro instruction.
- DD name not found: No TIOT entry exists that corresponds to the DD name supplied.
- Invalid UCB unit type field: The UCB unit type field (byte 4 of the device code field) does not specify a direct-access, tape, or unit record device.

A return code of 08 indicates that an invalid output area address was specified.

# **IOHALT Routine (SVC 33)**

The IOHALT routine stops all activity on the teleprocessing device whose unit control block (UCB) address is passed in register 1. It does not stop activity on nonteleprocessing devices.

The IOHALT routine checks the validity of the UCB address it receives by matching it against the UCB addresses in the UCB lookup table. If the address passed is valid and if the device to be stopped is a teleprocessing device, the IOHALT routine gives control to the resident Halt I/O routine (entry point IECIHIO), which issues a Halt I/O instruction and returns. The IOHALT routine places a completion code into register 15 before relinquishing control:

| Code (Hex.) | Meaning                                                               |
|-------------|-----------------------------------------------------------------------|
| 00          | The device was stopped.                                               |
| 04          | The device is not running.                                            |
| 08          | The device was not stopped because it is not a teleprocessing device. |
| 0C          | The device was not stopped because the UCB address was invalid.       |

# **VOLSTAT Routine (SVC 91)**

The first load module of the VOLSTAT routine constructs error-statistics-by-volume (ESV) records and, depending upon what was specified during system generation, writes them on either the console output device or the system management facilities (SYS1.MAN) data set.

Data management Close and EOV routines pass control to the VOLSTAT routine when the volume is demounted.

The VOLSTAT routine obtains error statistics from the volume statistics table, and obtains other identifying information from the UCB, DCB, or JFCB and DEB. After writing an ESV record, the VOLSTAT routine clears the counters in the volume statistics table and returns control to the Close or EOV routine.

The second load module is called to read the buffered log data of an IBM 2305 Fixed Head Storage, IBM 3330 Disk Storage, or IBM 3333 Disk Storage and Control. This load module is activated when a new volume is mounted or when the operator enters a HALT EOD command.

# TCB EXCP (SVC 92) (TSO only)

The TCB EXCP routine allows the user to specify, in register 0, a TCB address associated with the IOB address passed in register 1. The specified TCB will be the one associated with the RQE.

# **Extended SVC Routine (SVC 109)**

The Extended SVC routine is used by the Task Termination routine to ensure that a task cannot leave outstanding I/O requests.

The routine checks each RQE in the system, unless outstanding teleprocessing-based I/O is found. If an RQE is assigned, the TCB is checked for an equal condition. If the equal condition is found, the UCB is checked for a teleprocessing-device indicator. If the device indicator is found, an ABEND is issued.

If there are no RQEs assigned for the terminating task, an SVC 3 is issued. If the assigned RQEs do not represent the teleprocessing-associated I/O, the Extended SVC routine issues the PURGE macro to call the Purge routine (SVC 16). If an IOB chain for the Restore routine (SVC 17) results, an ABEND is issued. If no IOB chain is built, an SVC 3 is issued.

# APPENDIX B: ALTERNATE PATH RETRY

In systems with the alternate path selective retry option, when a device can be reached by more than one path and there is a failure of one of the paths, the others are automatically tried, one by one, either until the operation is successful or until the error is declared permanent. In addition, the operator is provided with a 'vary path' command by which he may add or remove paths to a device. The two alternate path retry functions are called 'selective retry' and 'vary path,' respectively.

# **The Selective Retry Function**

Without alternate path retry, each time there is a channel failure and the Test Channel routine is entered preparatory to retrying the I/O activity, it selects a path for the retry from the alternate path table. The selected path may or may not be the failing channel, because the alternate path table is not changed after I/O errors.

With alternate path retry, the Test Channel routine refers to the path mask field of the unit control block for the requested device rather than to the alternate path table, and failing paths are removed from the path mask when channel errors occur.

Error recovery routines pass control to the Alternate Path Retry routine before attempting each restart. The Alternate Path Retry routine obtains and saves the original path mask from the requested device's unit control block in a table called the channel error block table. It then turns off the failing channel's bit in the channel mask field of the unit control block and returns control to the I/O error routine, which begins the retry attempts.

To prevent a situation where all paths would become unavailable, the Alternate Path Retry routine restores the original path mask to the unit control block if the last available path is about to be used. The I/O error routine may then initiate the retry cycle again, depending upon whether the specified number of retries has been reached.

# **The Vary Path Function**

When the operator issues any command, job management command processing routines are entered. For the 'vary path' command, the Vary Path Command Processor routine is given control (Figure 63). It adds or removes paths to a device by setting bits in the path mask table of a unit control block on or off.





# APPENDIX C: DIRECT-ACCESS VOLUME VERIFICATION

If the direct-access volume verification (DAVV) option is selected during system generation, the input/output supervisor checks the serial numbers of newly mounted volumes against serial numbers in the unit control blocks (UCBs) for the devices containing the volumes. It issues messages to the operator when the wrong volumes have been mounted.

When an operator readies a device after mounting a volume, he causes an I/O interruption and entry to the I/O interruption supervisor. If the UCB for that device contains a volume serial number, the I/O interruption supervisor sets a flag in the UCB for the device to indicate that volume verification is to be performed. The next time there is a request for activity on the device, the I/O supervisor, having checked the flag, schedules module IGE0025E. When IGE0025E gains control, it checks the flag in the UCB to determine if volume verification is required. If it is, control is transferred to module IGE0125E, the first module of the two-module volume verification routine.

Module IGE0125E tests if the UCB volume serial number is zeros or if the data management bit is set. If either condition exists, an SVC 15 instruction is issued to execute the user's channel program. If, however, there is a volume serial number in the UCB and the mount bit is not on, module IGE0125E constructs a channel program to read the volume label for the mounted volume and issues an SVC 15 instruction to cause the channel program to be executed. When it receives control a second time, after the volume label has been read, module IGE0125E matches the volume serial number of the mounted volume against the serial number in the UCB for the device. When the serial numbers agree, IGE0125E uses an SVC 15 instruction to cause the originally requested activity to be performed. If the volume serial numbers do not agree, or if the channel program was terminated in error IGE0125E invokes the second module of the Volume Verification routine, IGE0225E. The second module issues a demount message for the mounted volume and a mount message for the volume whose serial number appears in the UCB.

If an I/O error occurs during reading of the volume label, 10 retries are attempted. If the condition cannot be corrected, IGE0125E invokes IGE0225E to issue an error message.



# APPENDIX D: DYNAMIC DEVICE RECONFIGURATION

In systems with the dynamic device reconfiguration (DDR) option, a volume mounted and in use on one device can be removed and taken to another device where the activity on the volume will be resumed. Volumes can be moved at the request of an operator or, when there is a permanent I/O error, at the request of the system. Such moves can be made without restarting a job to cause device reallocation by job management routines, because I/O supervisor DDR routines effectively reallocate by exchanging the device-dependent information in the unit control blocks of the two already allocated devices. The affected devices may be contained in different logical channels, because DDR routines also transfer the request queue elements for any queued requests for the devices to the correct logical channel queues.

Refer to OS/VS Recovery Management Logic for detailed information on DDR.



# APPENDIX E: PROGRAM CHECK RECOVERY SUBROUTINE

The Program Check Recovery Subroutine (PCRS) is assembled within I/O supervisor code. PCRS works with the two sections of the Program Check Handler, Prolog and ABTERM, to clean up the I/O supervisor control blocks and queues, and to terminate tasks. PCRs gains control from the Prolog section of the Program Check Handler when a program check error occurs in a task in the I/O supervisor, its appendages, or any routine branched to by the I/O supervisor. See Figure 64 for the general flow of control.

Preparations for processing a program check begin before an error occurs. The I/O supervisor, when it first gets control of an RQE, saves the address of the RQE in a special save area SVRQE. This allows the PCRS to determine the interrupted task without depending on the passing of registers between the routines which gain control at a program check. PCRS dequeues the RQE from its logical channel queue by using the address at SVRQE, and sets the flags in UCBFL1 to zero, to clear them for the next RQE. Finally, PCRS determines the associated TCB for the task, checks it validity, and determines the proper ABEND code. Control passes from PCRS to the ABTERM section of the Program Check Handler, which schedules the termination. The program check error handling ends when ABTERM gives control back to the I/O supervisor which places the RQE in the freelist and exits either to the SVC First Level Interruption Handler routine, if the program check occurred during an SVC 0, or to the Channel Restart routine, if the program check occurred during an SVC 15 or an I/O interruption. Now the I/O supervisor readies itself for a new RQE by zeroing out the special save area SVRQE.



Figure 64. Operation of PCRS During a Program Check

Two exceptional conditions may arise: there may be no RQE associated with the program check, indicated by the save area SVRQE being zero, and a recurrence may occur in PCRS.

When there is no valid RQE, PCRS determines whether an SVC 0 was in process, and if so, the task pointed to by the current TCB is abnormally terminated with the appropriate completion code. If there is no valid RQE and either an SVC 15 or interruption is in process, abnormal termination is not attempted.

In case of recurrence, the Program Check Recovery Subroutine determines if there is a valid RQE, and if so, determines if there is a valid TCB. If a valid RQE and TCB can be determined the task is abnormally terminated with the appropriate completion code. If there is no valid RQE or no valid TCB, processing is handled the same way as when there is no valid RQE.

# APPENDIX F: SHARED DIRECT-ACCESS STORAGE DEVICE

The shared direct-access storage device (DASD) option allows one direct-access device to be shared between two CPUs. The I/O supervisor must, therefore, provide special code to allow successful data transfer between the device and each CPU. Since a program seeking access to a shared-file device may require either exclusive use of the device or shared use of the device, the I/O supervisor uses two special command codes, release and reserve. Reserve (X'B4') manipulates the switching device to allow exclusive use of the device by the CPU; release (X'94') manipulates the switching device to allow shared use of the device by the CPU.

A program requiring exclusive use of the shared device must issue a RESERVE macro. This causes the reserve count in the UCB to be incremented. Once the reserve command is issued, the other CPU has no access to the device until a release command is issued to the device. The I/O supervisor issues a release command if the reserve count field is zero. This count field is decremented each time the user issues a DEQ macro.

Regardless of whether or not the user has issued a RESERVE macro, the I/O supervisor must also issue a reserve command with every stand-alone seek, regardless of the value in the reserve count fields. This prevents the other CPU from moving the access mechanism once it has been positioned for the first CPU. If the reserve count is zero, a release is issued with the data transfer channel program to free the device for the other CPU.

If a unit check or a channel error requires a sense operation to be done, a read home address and record zero channel program is chained to the sense command; if the reserve count in the UCB is zero, the sense command is changed to a release command—a special type of sense command. The home address and record zero data, read into the UCB's work area, is required by the device-dependent error recovery procedure. The release command frees the device for possible use by the second CPU during the first CPU's error recovery cycle.

If an active shared device is associated with a purged request, the UCB's HIO flag is set by the purge routine. This causes the I/O supervisor to issue a release to the device, if its reserve count is zero.

# APPENDIX G: I/O SUPERVISOR—OLTEP SYNCHRONIZING MODULE (IECIOLTS)

The Online Test Executive Program (OLTEP) requires the following special support from the I/O supervisor:

- Attention-interruption posting
- Device-end posting when device-end occurs separately from channel-end
- Return SIO condition codes when either of above functions is active
- Exclusive use of a channel by OLTEP
- Bypassing of the system channel programs for tape devices and direct access devices
- Specific exposure path selection for multiple exposure devices

The I/O supervisor maintains the module IECIOLTS which coordinates the I/O supervisor functions requested by OLTEP. The address of this routine is contained in the I/O supervisor-OLTEP vector table, IECOLTVT.

To indicate that OLTEP requires assistance from the I/O supervisor, the SVC 59 instruction sets a series of switches in the IECOLTSW field of IECOLTVT. The I/O supervisor exits from four places in its code to check these switches:

- It exits during the Test Channel routine.
- It exits during the Halt I/O routine.
- It exits during the Start I/O routine.
- It exits during the SIO module for multiple exposure devices.

If OLTEP indicates a channel function on a 2880 channel, control passes from the Test Channel routine in the I/O supervisor to the subroutine in IECIOLTS at label OLTCHN. Processing in that subroutine determines whether or not OLTEP has exclusive control of a channel.

The SIO appendage in IECIOLTS at label SIOAPP is entered normally. This appendage checks the bypass function bit. If it is on, normal I/O channel programs are bypassed and OLTEP operations continue on that channel.

If OLTEP indicates either device-end or attention posting, control passes from the halt I/O routine in the I/O supervisor to the subroutine in IECIOLTS at label OLTHLT. This subroutine determines if IOS may issue an HIO on the input device.

Special OLTEP multiple exposure device code in the I/O supervisor exits to IECIOLTS at label OLTEXP to select a specific-exposure access path for OLTEP.

More information about the routines and appendages in IECIOLTS can be found in OS/VS OLTEP Logic.

The I/O supervisor uses the addressing scheme shown in Figure 65 to gain access to IECOLTVT.



1

Figure 65. IECIOLTS Addressing Scheme and Bit Settings

# **APPENDIX H: DEVICE-DEPENDENT ERROR ROUTINES**

Device-dependent error routines gain control from the contents supervisor. See OS/VS2 Supervisor Logic. Even though each routine has specific characteristics tailored for each device type, the basic programming techniques are similar. Each routine sets the IOB error indicator bits, examines the sense and CSW status bits that are stored in the IOB to determine the type of error, and attempts to recovery from the error, if at all possible, by retrying the channel program by means of a direct branch for direct-access devices or an SVC 15 instruction for devices other than direct-access.

The IOB exception flag (IOBEX) and error flag (IOBERR) are turned on by all the device-dependent error routines. These settings serve a three-fold purpose: both flags on indicate that an error routine is in process; IOBEX on and IOBERR off indicate a permanent error; and both flags off indicate a successful retry. The tables included for each error routine explain the sense bit settings and describe when retry is or is not attempted.

The sense and CSW bits that are stored in the IOB are checked by the device-dependent error routines. By checking the IOBFL1 field of the IOB, chaining types are determined. If the IOBFL1 field indicates data and command chaining, no error retry is attempted; if it indicates command chaining; error retry is attempted from the address of the CCW which caused the error; and if it indicates data chaining or no chaining, the error is retried from the first CCW. By checking the CSW status bits in the IOB, the error routine determines the type of error that occurred. The bits tested, the priority of the testing, and the labels in the error routine to which control goes are shown in the tables listed for each device-dependent routine.

The device-dependent error routines attempt retry of the channel program by issuing an SVC 15 instruction. If the retry succeeds, the IOB exception bit and errors flags are reset to zero, and normal processing continues. The number of retries attempted depends on the device.

If the CSW status contains a unit check, the device-dependent routine (except for a 2305, 3330, and 3333) gives control to the statistics update routine to update the statistics table.

# Writing Error Recovery Messages to the Operator

When an error is uncorrectable or when a condition exists that could be changed by operator action, an I/O error routine invokes the I/O supervisor's Write-to-Operator routine, which composes a message to be written on the console output device (Diagram 12). The Write-to-Operator routine handles three messages: Uncorrectable Input/Output Error (IEA000I), Inoperative Path (IEA001I), and Intervention Required (IEA000A). It uses a WTO macro instruction to cause them to be written on the console output device.

The I/O supervisor Write-to-Operator routine is contained in five modules. The first (IGE0025C) determines which modules to invoke and produces the 'intervention required' message. The second (IGE0125C) determines which message is to be written and invokes either the third (IGE0225C) or fifth (IGE0425C) load to produce the 'uncorrectable input/output error' message. Load four (IGE0325C) produces 'start I/O condition code 3 error' messages. The full text of each message is in OS/VS Message Library: VS2 System Messages.

# **Individual Routines**

The routine descriptions that follow all have the same organization: a brief description of any characteristics of the routine or device that could be of use in interpreting the listings; a table, the Error Analysis Sequence Table, showing the order of examination of sense and status bits with pointers to the listings: and a table showing the meanings of IOB sense bits, flags, and error count fields for the particular device.

The tables are to be used as guides in getting to and interpreting the listings, which should be considered the final authority. Also:

- Cross references may sometimes point to approximately where in a listing some action is taken. This is because some functions cannot be grouped 'cleanly.' As a result, some studying may be required to check fully what happens when a particular condition arises.
- The explanations of sense bit meanings are meant to be quick-reference guides. More information can be found in the publications mentioned with each routine.
- The priority of examination of status and sense bits is a design priority. In some cases a variation will be found in the implementation.

The examination of status and sense bits is usually performed by a small utility-type routine called the Error Interpreter routine, which is used in common by the error routines. It determines which status or sense bits are on, and returns control to requesting error routines at the instruction sequences where the errors can be handled.

Each time the Error Interpreter routine is entered, it checks one bit. An arrangement of offset values and addresses in a list within the requesting I/O error routine directs the Error Interpreter. The list indicates which bits are to be tested and in what order, and it also contains the addresses of the instruction sequences to be used for 'on' conditions.

If a channel error has occurred, the error recovery routine that is entered will have available to it an 8-byte area called the error recovery procedure interface block. This is produced by the Channel Check Handler routine and includes information that could be of use in determining whether or not a restart should be attempted.

Descriptions of routines in the remainder of this appendix appear in numerical order according to the first (or only) device number indicated in the name of the routine. (Some routines serve more than one device, but the related routine description is included only once.) For example, "2260 and 1053 Error Routines" is included only once, among the 22xx routines; it is not also included among the 10xx routines. The table that follows indicates which devices (left column) are handled by which routines (right column).

| Device                            | Name of Routine                                    |
|-----------------------------------|----------------------------------------------------|
| 1052 Printer                      | 1052 Error Routine                                 |
| 1053 Printer                      | 2260 and 1053 Error Routines                       |
| 1275 Optical Reader Sorter        | 1419 and 1275 Error Routines                       |
| 1287 Optical Reader               | 1287 and 1288 Error Routines                       |
| 1288 Optical Page Reader          | 1287 and 1288 Error Routines                       |
| 1403 Printer                      | 1403 and 1443 Error Routines                       |
| 1419 Magnetic Character<br>Reader | 1419 and 1275 Error<br>Routines                    |
| 1443 Printer                      | 1403 and 1443 Error Routines                       |
| 2250 Display Unit                 | 2250 Error Routine                                 |
| 2260 Display Station              | 2260 and 1053 Error Routines                       |
| 2305 Fixed Head Storage           | 2305, 2314, 2319, 3330, and 3333<br>Error Routines |

| 2314 Direct-Access Storage<br>Facility          | 2305, 2314, 2319, 3330, and 3333<br>Error Routines |
|-------------------------------------------------|----------------------------------------------------|
| 2319 Direct-Access Storage<br>Facility          | 2305, 2314, 2319, 3330, and 3333<br>Error Routines |
| 2400 Series Magnetic Tape<br>Units              | 2400 and 3400 Tape Series<br>Error Routines        |
| 2495 Tape Cartridge Reader                      | 2495 Error Routine                                 |
| 2501 Card Reader                                | 2501 and 2520 Error Routines                       |
| 2520 Card Read Punch                            | 2501 and 2520 Error Routines                       |
| 2540 Card Read Punch                            | 2540 Error Routine                                 |
| 3211 Printer                                    | 3211 Error Routine                                 |
| 3330 Disk Storage                               | 2305, 2314, 2319, 3330, and 3333<br>Error Routines |
| 3333 Disk Storage and Control                   | 2305, 2314, 2319, 3330, and 3333<br>Error Routines |
| 3410 Magnetic Tape                              | 2400 and 3400 Tape Series<br>Error Routines        |
| 3420 Magnetic Tape                              | 2400 and 3400 Tape Series<br>Error Routines        |
| 3505 Card Reader                                | 3505 and 3525 Error Routines                       |
| 3525 Card Punch with Read<br>and Punch Features | 3505 and 3525 Error Routines                       |

## **1052 Error Routine**

Special considerations are necessary for errors on the IBM 1052 Printer-Keyboard. Messages can be issued through the Write-to-Operator routine only for read errors. The operator is notified of other types of errors by use of the console alarm bell.

The 1052 error routine attempts recovery from channel data checks. The 1052 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The 1052 error routine uses bits M0 and M1 in the third byte of the IOB flags field to control its procedure on subsequent entries after an error. If both bits are set to 0, the Error Interpreter routine is used to determine the type of error. If M0 has been set to 1, a permanent error has occurred and control has been received from the Error EXCP routine to ring the console alarm. If M1 has been set to 1, 'intervention required' has been signaled, and the original channel program is to be retried.

The error analysis sequence for the 1052 is shown in Figure 66. The meanings of the sense bits, IOB flags, and IOB error counts are shown in Figure 67. More information can be obtained from *IBM System/360 Component Descriptions and Operating Procedures: IBM 1052 Printer-Keyboard Model 7 with IBM 2150 Console*, GA22-6877.

### Sense Byte 0 Meanings and Actions Taken

#### Bit 0: Command Reject

This bit is set when an invalid command code is detected. The IOB error flag is turned off and the IOB exception flag is turned on indicating a permanent error. Control is returned to the I/O supervisor via an SVC 15 instruction for abnormal termination.

### Bit 1: Intervention Required

This bit is set when the printer runs out of forms or when the not-ready key has been depressed. The error routine places the control command to ring the console alarm in the reposition modifier field of the IOB. The modifier flag 1 is set in the IOB to signal the Unit Record SIO routine to build a CCW employing this command code. Bit M1 is

|           | Status       | Sense    |        |                         | Applic | able to: |         |
|-----------|--------------|----------|--------|-------------------------|--------|----------|---------|
| Priority  | Bit          | Byte     | Bit    | Condition               | Read   | Write    | Pointer |
| 1         | 45           |          |        | Channel Control Check   | x      | Х        | ERR530  |
| 1         | 46           |          |        | Interface Control Check | x      | Х        | ERR530  |
| 2         | 47           |          |        | Chaining Check          | х      | х        | ERR524A |
| 3         | 38           |          |        | Unit Check              | х      | x        | ERR501  |
| 4         |              | 0        | 7      | Should Not Occur        | х      | x        | ERR504  |
| 5         |              | 0        | 6      | Should Not Occur        | х      | x        | ERR504  |
| 6         |              | 0        | 5      | Should Not Occur        | х      | x        | ERR504  |
| 7         |              | 0        | 4      | Should Not Occur        | х      | x        | ERR504  |
| 8         |              | 0        | 3      | Equipment Check         | Х      | x        | ERR506  |
| 9         |              | 0        | 1      | Intervention Required   | х      | x        | ERR509  |
| 10        |              | 0        | 2      | Bus-Out Check           | х      | x        | ERR510  |
| 11        |              | 0        | 0      | Command Reject          | х      | x        | ERR518A |
| 12        | 44           |          |        | Channel Data Check      | х      | x        | ERR525  |
| 13        | 42           |          |        | Program Check           | х      | х        | ERR518A |
| 14        | 43           |          |        | Protection Check        | Х      | x        | ERR518A |
| 15        | 39           |          |        | Unit Exception          | Х      |          | ERR518B |
| 16        | 41           |          |        | Incorrect Length        | x      | x        | ERR518A |
| Figure 66 | 6. 1052 Erre | or Analy | sis Se | quence (Module IGE0000  | D)     |          |         |

set in the IOB and control returned by SVC 15. The intervention-required condition does not terminate a read or write operation that is already in progress.

# Bit 2: Bus-Out Check

This bit is set when a parity error is detected on a command or data byte. The error routine sets the bus-out flag in the IOB and retries the user's channel program via SVC 15. If the error recurs, the control command to ring the console alarm is placed in the reposition modifier field of the IOB, and modifier flag 1 is set to signal the Unit

| _                                | Bit O                                                        | Bit 1                            | Bit 2                             | Bit 3                     | Bit 4                                | Bit 5                                | Bit 6                                | Bit 7                                               |
|----------------------------------|--------------------------------------------------------------|----------------------------------|-----------------------------------|---------------------------|--------------------------------------|--------------------------------------|--------------------------------------|-----------------------------------------------------|
| Sense Byte O                     | Command<br>Reject                                            | Intervention<br>Required         | Bus-Out<br>Check                  | Equipment<br>Check        |                                      |                                      |                                      |                                                     |
| IOBFL1                           | 00 No Cha<br>01 Comman<br>10 Data Ch<br>11 Comman<br>Data Ch | nd Chaining<br>paining<br>nd and | Error<br>Routine<br>in<br>Control | Modifier<br>Flag 1        |                                      | Exceptional<br>Condition             |                                      | 0 Start<br>1 Restart                                |
| IOBFL3                           |                                                              |                                  | Write<br>Error<br>Count           | Bus-Out<br>Error<br>Count | Control<br>Bit<br>M1                 | Message<br>Type                      | Control<br>Bit<br>MO                 | Logout<br>Flag                                      |
| Error Counts<br>IOBECT<br>Byte 1 |                                                              |                                  |                                   |                           | Multiple<br>Console<br>Support Retry | Multiple<br>Console<br>Support Retry | Multiple<br>Console<br>Support Retry | Channel Data<br>Check and<br>MCS Retry              |
| Error Counts<br>IOBECT<br>Byte 2 |                                                              |                                  |                                   |                           |                                      |                                      |                                      | Channel Control<br>Check, Interfac<br>Control Check |

Figure 67. 1052 Sense Bits, IOB Flags and, IOB Error Counts

Record SIO routine to construct a CCW with this command. IOB bit M0 is set and control returned via SVC 15. Five retries are attempted on console devices of systems with multiple console support.

Bit 3: Equipment Check

This bit is set when one of the following occurs:

- Keyboard parity error.
- Keyboard-printer compare check.
- Printer failed to take a mechanical cycle during a read or write operation.

If the error occurred on a read command, a permanent error is assumed and the Write-to-Operator routine is invoked; it writes a message (IEA000I) indicating failure to read input messages. For write errors, the error routine retries the channel program via SVC 15. On the second occurrence of the error, the console bell is rung via the procedure described above for bus-out check. Five retries are attempted on console devices of systems with multiple console support.

Bits 4-7: Should Not Occur

If any of these bits is set, a catastrophic error is assumed. A permanent error is signaled to the Unit Record SIO routine and control is returned via SVC 15. Five retries are first attempted on console devices of systems with multiple console support.

# 1287 and 1288 Error Routines

The IBM 1287 Optical Reader error routine (module IGE0011C), 1287 Error routine (module IGE0011C) and the IBM 1288 error routine (module IGE0011D) attempt recovery from channel data checks. They also examine the error recovery procedure interface block to determine whether they should attempt recovery from channel control checks and interface control checks.

The error analysis sequence for the 1287 and 1288 is shown in Figure 68. The meanings of sense bits, IOB flags, and IOB error counts for the devices are shown in Figure 69. More information can be obtained from the following publications:

- IBM 1287 Optical Reader Component Description and Operating Procedures, GA21-9064
- IBM 1288 Optical Page Reader Model 1 Component Description, GA21-9081

#### **Sense Byte Meanings**

Byte 0, Bit 0: Command Reject

This bit is set when the command is incorrect for the operating mode, such as a Mark Line command in document mode or a normal command in CE diagnostic mode. An invalid command sequence, such as two consecutive ejects, will also cause the bit to be set.

Byte 0, Bit 1: Intervention Required

This bit is set when the device is not in ready status.

#### Byte 0, Bit 2: Bus-Out Check

This bit indicates that invalid parity has occurred in a command or data.

Byte 0, Bit 3: Equipment Check

One of the following has occurred: (1) the device was unable to completely read a line or field, (2) the 1287 or 1288 could not locate the reference mark, or (3) the 1288 failed to find a timing mark.

Byte 0, Bit 4: Data Check

The optical reader has sent at least one reject character or substitute character.

| riority | Status<br>Bit | Sense<br>Byte |   | Condition               | Pointer  |
|---------|---------------|---------------|---|-------------------------|----------|
| 1       | 45            |               |   | Channel Control Check   | ERR0041  |
| 2       | 46            |               |   | Interface Control Check | ERR0041  |
| 3       | 44            |               |   | Channel Data Check      | ERR0041  |
| 4       | 32            |               |   | Control Unit End        | ERR0041  |
| 5       | 38            |               |   | Unit Check              | ERR0041  |
| 6       |               | 1             | 3 | Should Not Occur        | ERR006   |
| 6       |               | 1             | 5 | Should Not Occur        | ERR006   |
| 6       |               | 1             | 6 | Should Not Occur        | ERR006   |
| 6       |               | 1             | 7 | Should Not Occur        | ERR006   |
| 7       |               | 1             | 0 | Tape Mode (1287 only)   | ERR006   |
| 8       |               | 0             | 7 | Should Not Occur        | ERR006   |
| 9       |               | 0             | 3 | Equipment Check         | ERR006C  |
| 10      |               | 0             | 6 | Non-Recovery            | ERR006C  |
| 11      |               | 0             | 1 | Intervention Required   | ERR006C  |
| 12      |               | 0             | 2 | Bus-Out Check           | ERR006C  |
| 13      |               | 0             | 4 | Data Check              | ERR006C  |
| 14      |               | 0             | 5 | Overrun                 | ERR006C  |
| 15      |               | 0             | 0 | Command Reject          | ERR006C  |
| 16      |               | 1             | 4 | Invalid Operation       | ERR006C  |
| 17      | 47            |               |   | Chaining Check          | ERR004B1 |
| 18      | 42            |               |   | Program Check           | ERR004B1 |
| 19      | 43            |               |   | Protection Check        | ERR004B1 |
| 20      | 41            |               |   | Incorrect Length        | ERR004B1 |

Byte 0, Bit 5: Overrun

An overrun condition occurs when the channel fails to service the optical reader in time and at least one character is lost.

Byte 0, Bit 6: Non-recovery

The operator must reload and restart the optical reader because (1) the document or tape is jammed, (2) the runout key was depressed while a document or tape was being processed, or (3) the scanner door was open when the device was not in the line display mode.

Byte 0, Bit 7: Keyboard Correction

The 1287 has displayed at least one unreadable character for online correction.

Byte 1, Bit 0: Tape Mode

The 1287 Model 2 is operating in the tape mode.

Byte 1, Bit 1: End of Page (1288)

The bottom of the page has been detected while reading in the unformatted document mode.

Byte 1, Bit 1: Late Stacker Select (1287)

The Stacker Select command did not arrive in time and the document was placed into the reject stacker.

|                                       | Bit O                                                                        | Bit 1                        | Bit 2                             | Bit 3              | Bit 4                | Bit 5                    | Bit 6            | Bit 7                                                       |
|---------------------------------------|------------------------------------------------------------------------------|------------------------------|-----------------------------------|--------------------|----------------------|--------------------------|------------------|-------------------------------------------------------------|
| Sense Byte O                          | Command<br>Reject                                                            | Intervention<br>Required     | Bus-Out<br>Check                  | Equipment<br>Check | Data<br>Check        | Overrun                  | Non-<br>Recovery | Keyboard<br>Correction<br>(1285, 128)<br>Tape Mode<br>Only) |
| Sense Byte 1<br>(1287, 1288 Only)     | Tape Mode<br>(1287 Only)                                                     | Late SS<br>or End of<br>Page | No<br>Document<br>Found           |                    | Invalid<br>Operation |                          |                  |                                                             |
| IOBFLI                                | 00 No Chainir<br>01 Command (<br>10 Data Chair<br>11 Command c<br>Dota Chair | Chaining<br>ning  <br>nnd    | Error<br>Routine<br>in<br>Control |                    |                      | Exceptional<br>Condition |                  | 0 Start<br>1 Restart                                        |
| IOBFL3                                |                                                                              |                              |                                   |                    |                      | Message<br>Type          |                  | Logout<br>Flag                                              |
| IOBINCAM<br>(Byte 1)                  | Data Check Count                                                             |                              |                                   |                    |                      |                          |                  |                                                             |
| IOBINCAM<br>(Byte 2)                  | Incorrect Length Count                                                       |                              |                                   |                    |                      |                          |                  |                                                             |
| IOB<br>Error Counts<br>Byte 1         | Equipment Check Count                                                        |                              |                                   |                    |                      |                          |                  |                                                             |
| IO <b>B</b><br>Error Counts<br>Byte 2 |                                                                              | Overrun                      | Error Count                       |                    | Bus-Out<br>Count     | Chainin                  | g Check Count    |                                                             |

## Figure 69. 1287 and 1288 Sense Bits, IOB Flags, and IOB Error Counts

Byte 1, Bit 2: No Document Found

A document did not enter the reading station after the last eject command and there was no jam.

Byte 1, Bit 3: Not Used

Byte 1, Bit 4: Invalid Operation

Invalid information was specified in the load format instruction. For example: bit 2, 3, 4, or 5 of the fourth byte represents bits not used; fewer than four bytes were transmitted; or an uninstalled font was specified in the CCW.

Byte 1, Bits 5-7: Not Used

# 1403 and 1443 Error Routines

The IBM 1403 Printer and IBM 1443 Printer error routine attempts recovery from the special condition where channel data checks occur with bus-out checks. The 1403 and 1443 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence for the 1403 and 1443 is shown in Figure 70. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 71. More information can be obtained from the following publications:

- IBM 1403 Printer Component Description, GA24-3073
- IBM 1443 Printer Models 1 to 4 and N1; IBM 1445 Printer Models 1 and N1, GA24-3120

|          | Status | Sense | ;   |                         |         |
|----------|--------|-------|-----|-------------------------|---------|
| Priority | Bit    | Byte  | Bit | Condition               | Pointer |
| 1        | 45     |       |     | Channel Control Check   | ERR051  |
| 1        | 46     |       |     | Interface Control Check | ERR051  |
| 2        | 47     |       |     | Chaining Check          | ERR071  |
| 3        | 38     |       |     | Unit Check              | ERR053  |
| 4        |        | 0     | 6   | Should Not Occur        | ERR052F |
| 5        |        | 0     | 3   | Equipment Check         | ERR052F |
| 6        |        | 0     | 1   | Intervention Required   | ERR054  |
| 7        |        | 0     | 2   | Bus-Out Check           | ERR056  |
| 8        |        | 0     | 7   | Channel 9               | ERR059  |
| 9        |        | 0     | 0   | Command Reject          | ERR052E |
| 10       | 44     |       |     | Channel Data Check      | ERR067  |
| 11       | 42     |       |     | Program Check           | ERR063  |
| 12       | 43     |       |     | Protection Check        | ERR063  |
| 13       | 39     |       |     | Unit Exception          | ERR064  |
| 14       | 41     |       |     | Incorrect Length        | ERR068  |

The sequence shown above is for the 1403 without the Universal Character Set (UCS) feature, and for the 1443.

For 1403s with UCS, bits 4 and 5 of sense byte 0 mean 'data check' and 'parity check,' respectively. Their priority falls between 9 and 10 and 5 and 6, respectively.

| 9.1 | 0 | 4 | Data Check   | ERR052E |
|-----|---|---|--------------|---------|
| 5.1 | 0 | 5 | Parity Check | ERR052D |
|     |   | - |              | /       |

Figure 70. 1403 and 1443 Error Analysis Sequence (Module IGE0000G)

### Sense Byte 0 Meanings and Actions Taken

## Bit 0: Command Reject

This bit is set when one of the following occurs:

- A Read Backward command is received.
- A carriage instruction to space more than three lines is received.
- A carriage instruction to skip to channel 0, 13, 14, or 15 of the carriage control tape is received.
- Any command is received which the device is not designed to execute.

| _                                | Bit O                                                         | Bit 1                         | Bit 2                             | Bit 3                                                 | Bit 4                                 | Bit 5                                   | Bit 6                                | Bit 7                                   |
|----------------------------------|---------------------------------------------------------------|-------------------------------|-----------------------------------|-------------------------------------------------------|---------------------------------------|-----------------------------------------|--------------------------------------|-----------------------------------------|
| Sense Byte O                     | Command<br>Reject                                             | Intervention<br>Required      | Bus-Out<br>Check                  | Equipment<br>Check                                    | Data<br>Check<br>Typebar<br>Selection | Parity<br>Error<br>Typebar<br>Selection |                                      | Channel                                 |
| IOBFL1                           | 00 No Chai<br>01 Comman<br>10 Data Ch<br>11 Comman<br>Data Ch | d Chaining<br>aining<br>d and | Error<br>Routine<br>in<br>Control |                                                       |                                       | Exceptional<br>Condition                |                                      | O Start<br>1 Resta                      |
| IOBFL3                           |                                                               | Entry<br>Bit                  | UCS Parity<br>Error<br>Count      | Bus-Out<br>or Channel<br>Data Check<br>Error<br>Count |                                       | Message<br>Type                         |                                      | Logout<br>Flag                          |
| Error Counts<br>IOBECT<br>Byte 1 |                                                               |                               |                                   |                                                       | Multiple<br>Console<br>Support Retry  | Multiple<br>Console<br>Support Retry    | Multiple<br>Console<br>Support Retry | Multiple<br>Console<br>Support R        |
| Error Counts<br>IOBECT<br>Byte 2 |                                                               |                               |                                   |                                                       |                                       |                                         |                                      | Channel Co<br>Check, Inte<br>Control Ch |

### Figure 71. 1403 and 1443 Sense Bits, IOB Flags, and IOB Error Counts

The error is considered permanent.

#### Bit 1: Intervention Required

This bit indicates a not-ready condition due to one of the following:

- The printer has run out of forms or the forms have jammed.
- The Stop Key has been depressed.
- The cover interlock switch is open.
- The typebar motor switch is set to the OFF or REMOVE position.

When this bit and bit 7 (Channel 9) are on, the error is handled as a Channel 9 condition. In all cases, an Intervention Required message is issued to the operator who must correct the condition. When the intervention required condition alone is corrected, the last operation is repeated.

#### Bit 2: Bus-Out Check

This bit indicates that a parity error has occurred on a bus-out command or data byte. If this bit is set during the initial selection of a control unit or a device, the operation is retried. If it is set during channel end, the error is automatically considered permanent unless it occurs on the console device of a system having the Multiple Console Support feature, where it is retried five times.

### Bit 3: Equipment Check

This bit indicates that a program-correctable malfunction was detected in the printer or in its controls. The malfunctions are buffer or hammer checks on the 1403 and typebar-synchronization errors on the 1443. These errors are reset by the next Write or Control command. Five retries are attempted on systems with multiple console support before the error is considered permanent, if the printer is being used as a console. Otherwise, the error is considered to be permanent, and no retry is attempted.

#### Bit 4: Data Check (1403 Only)

If the 1403 has the Universal Character Set (UCS) feature, this bit is set when a code in a data record sent to the printer does not match a code in the UCS feature storage. (Without UCS, this bit should not be set.) The error is automatically considered permanent unless it occurs on the console device of a system having the Multiple Console Support feature, where it is retried five times.

Bit 5: Parity Error (1403 Only)

If the 1403 has the Universal Character Set (UCS) feature, this bit indicates a parity error was detected in data being written into or read from UCS feature storage. If the error occurs while the UCS storage is being loaded, one retry is attempted. If it occurs at any other time, the error is considered permanent. In systems having the Multiple Console Support feature, five retries are attempted for console devices.

### Bits 4 and 5: Typebar Selection (1443 Only)

The combination of these two bits indicates the position of the typebar selector switch.

| Bit 4 | Bit 5 | Switch Setting   |
|-------|-------|------------------|
| 0     | 0     | 52-character set |
| 0     | 1     | 13-character set |
| 1     | 0     | 39-character set |
| 1     | 1     | 63-character set |

These bits can be changed only by repositioning the typebar selector switch. They are considered normal, and the error routine continues the channel program.

### Bit 6: Should Not Occur

If this bit is set, a catastrophic error is assumed. The logout flag is set in the IOB, a permanent error is signaled to the Error EXCP routine, and control is returned via SVC 15.

### Bit 7: Channel 9

This bit is set when a hole is sensed in channel 9 of the carriage control tape.

## 1419 and 1275 Error Routines

The IBM 1419 Magnetic Character Reader and IBM 1275 Optical Reader Sorter error routine attempts recovery from channel data checks. The 1419/1275 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence is shown in Figure 72. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 73. Sense byte 2 is applicable only to the secondary control unit of systems with the Dual Address Adapter feature.

More information can be obtained from the following publications:

- IBM 1219 Reader Sorter, IBM 1419 Magnetic Character Reader, GA24-1499
- IBM 1419 Magnetic Character Reader and IBM 1275 Optical Reader Sorter, Device-Dependent BSAM Program Logic Manual, GY21-0012

## Sense Byte Meanings

Byte 0, Bit 0: Command Reject

This bit is set when an invalid command is received. Invalid commands include:

- Two Read commands without an intervening Stacker Select command when the 1419 is in program-sort mode
- A Stacker Select command given for an auto-selected document
- A second Stacker Select command after one has been accepted for a document
- A Write command given when the machine is not in diagnostic mode

| Priority | Status<br>Bit | Sense<br>Byte | Bit | Condition               | Pointer |
|----------|---------------|---------------|-----|-------------------------|---------|
| 1        | 45            |               |     | Channel Control Check   | ERR020  |
| 2        | 46            |               |     | Interface Control Check | ERR020  |
| 3        | 44            |               |     | Channel Data Check      | ERR020  |
| 4        | 38            |               |     | Unit Check              | ERR020  |
| 5        |               | 0             | 3   | Should Not Occur        | ERR051  |
| 6        |               | 0             | 7   | Document Spacing Error  | ERR051  |
| 7        |               | 0             | 1   | Intervention Required   | ERR051  |
| 8        |               | 0             | 2   | Bus-Out Check           | ERR051  |
| 9        |               | 0             | 4   | Data Check              | ERR051  |
| 10       |               | 0             | 5   | Overrun                 | ERR051  |
| 11       |               | 0             | 6   | Auto Select             | ERR051  |
| 12       |               | 0             | 0   | Command Reject          | ERR051  |
| 13       | 47            |               |     | Chaining Check          | ERR069  |
| 14       | 42            |               |     | Program Check           | ERR069  |
| 15       | 43            |               |     | Protection Check        | ERR069  |
| 16       | 41            |               |     | Incorrect Length        | ERR069  |

For the secondary control unit, the following sense bytes are examined in place of those shown above:

|    | 5                  | 2     | 2      | Bus-Out Check              | ERR061 |
|----|--------------------|-------|--------|----------------------------|--------|
|    | 6                  | 2     | 4      | Should Not Occur           | ERR061 |
|    | 7                  | 2     | 3      | Should Not Occur           | ERR061 |
|    | 8                  | 2     | 1      | Intervention Required      | ERR061 |
|    | 9                  | 2     | 7      | Operator Attention         | ERR061 |
|    | 10                 | 2     | 0      | Command Reject             | ERR061 |
|    | 11                 | 2     | 5      | Late Stacker Select        | ERR061 |
|    | 12                 | 2     | 6      | Auto Select                | ERR061 |
| Fi | gure 72. 1419/1275 | Error | Analys | is Sequence (Module IGE001 | 1E)    |

Byte 0, Bit 1: Intervention Required

This bit indicates that operator attention is needed for one or more of the following reasons:

- Document jam
- Full stacker
- Sort-check
- Endorser stop
- End-of-transport stop
- Film stop
- Batch number advance check stop
- Motor not running

Byte 0, Bit 2: Bus-Out Check

This bit is set for parity errors on information coming from the CPU via the interface.

Byte 0, Bit 3: Should Not Occur

|                                                  | Bit O                                                                 | Bit 1                    | Bit 2                             | Bit 3                    | Bit 4                             | Bit 5                            | Bit 6                     | Bit 7                           |
|--------------------------------------------------|-----------------------------------------------------------------------|--------------------------|-----------------------------------|--------------------------|-----------------------------------|----------------------------------|---------------------------|---------------------------------|
| Sense Byte O                                     | Command<br>Reject                                                     | Intervention<br>Required | Bus-Out<br>Check                  |                          | Data<br>Check                     | Overrun                          | Auto-<br>Select           |                                 |
| Sense Byte 1                                     |                                                                       |                          | Document<br>Under<br>Read Head    | Amount<br>Field<br>Valid | Process<br>Control<br>Field Valid | Account<br>Number<br>Field Valid | Transit<br>Field<br>Valid | Serial<br>Number<br>Field Valid |
| Sense Byte 2<br>(Secondary<br>Control Unit Only) | Command<br>Reject                                                     | Intervention<br>Required | Bus-Out<br>Check                  |                          |                                   | Late<br>Stacker                  | Auto-<br>Select           | Operator<br>Attention           |
| IOBF L1                                          | 00 No Chaini<br>01 Command<br>10 Data Chai<br>11 Command<br>Data Chai | Chaining<br>ning<br>and  | Error<br>Routine<br>in<br>Control |                          |                                   | Exceptional<br>Condition         |                           |                                 |
| IOBF L2                                          |                                                                       | Sense<br>Bit             | Purge<br>Flag                     |                          |                                   |                                  |                           |                                 |
| I OBF L3                                         |                                                                       |                          |                                   |                          |                                   | Permanent<br>Error               |                           | Logout<br>Flag                  |

#### Figure 73. 1419/1275 Sense Bits, IOB Flags, and IOB Error Counts

Byte 0, Bit 4: Data Check

This bit indicates that one or more of the selected fields in the document was not read correctly.

Byte 0, Bit 5: Overrun

This bit is set when a character is not accepted. The field containing the error is identified by a 0 in bits 3 to 7 of sense byte 1.

Byte 0, Bit 6: Auto-Select

This bit is set when a document is automatically selected into the reject pocket. A 51-column card turns the indicator on if the 51-column feature is not installed. If a Stacker Select command is issued for an auto-selected document, the command reject bit will be set.

- Byte 0, Bit 7: Should Not Occur
- Byte 1, Bit 0: Should Not Occur
- Byte 1, Bit 1: Should Not Occur
- Byte 1, Bit 2: Document Under Read Head

This bit is normally used in diagnostic mode only.

Byte 1, Bit 3: Amount Field Valid — When this field is selected at the operator panel, and is read without error (including symbols), the bit is set to one.

Byte 1, Bit 4: Process Control Field Valid — When this field is selected at the operator panel, and is read without error (including symbols), the bit is set to one.

- Byte 1, Bit 5: Account Number Field Valid —When this field is selected at the operator panel, and is read without error (including symbols), the bit is set to one.
- Byte 1, Bit 6: Transit Field Valid When this field is selected at the operator panel, and is read without error (including symbols), the bit is set to one.
- Byte 1, Bit 7: Serial Number Field Valid —When this field is selected at the operator panel, and is read without error (including symbols), the bit is set to one.

Byte 2 (Secondary Control Unit Only):

Byte 2, Bit 0: Command Reject

This bit is set when an invalid command is received by the secondary control unit (SCU). The following commands are considered invalid in the SCU:

- Read
- Read Backwards
- Write

Byte 2, Bit 1: Intervention Required See byte 0, bit 1.

Byte 2, Bit 2: Bus-Out Check This bit is set for parity errors on information coming from the CPU via the interface.

Byte 2, Bit 3: Should Not Occur

Byte 2, Bit 4: Should Not Occur

Byte 2, Bit 5: Late Stacker Select.

This bit is set when a Stacker Select command is given for a document which has passed the select station. The document is rejected.

Byte 2, Bit 6: Auto-Select This bit is set when a Stacker Select command is issued for a document that is auto-selected.

Byte 2, Bit 7: Operator Attention

This bit is set when the Update switch is off and a Stacker Select command is issued to effect batch-numbering update.

## 2501 and 2520 Error Routines

The IBM 2501 Card Reader and 2520 Card Read Punch error routine attempts recovery from channel data checks on 2501 and 2520 read errors. Each read operation is retried once.

The error analysis sequence is shown in Figure 74. The meanings of the sense bits, IOB flags, and IOB error counts are shown in Figure 75. More information about the individual devices can be obtained from the following publications:

- IBM 2501 Models B1 and B2 Component Description and Operating Procedures, GA21-9026
- IBM 2520-B1, B2, and B3 Component Description and Operating Procedures, GA21-9027

| Priority | Status<br>Bit | Sense<br>Byte |   | Condition               | Pointer |
|----------|---------------|---------------|---|-------------------------|---------|
| 1        | 45            |               |   | Channel Control Check   | ERR002  |
| 1        | 46            |               |   | Interface Control Check | ERR002  |
| 2        | 38            |               |   | Unit Check              | ERR002  |
| 3        |               | 0             | 6 | Should Not Occur        | ERR004  |
| 4        |               | 0             | 3 | Equipment Check         | ERR008  |
| 5        |               | 0             | 7 | Should Not Occur        | ERR004  |
| 6        |               | 0             | 1 | Intervention Required   | ERR036  |
| 7        |               | 0             | 2 | Bus-Out Check           | ERR013  |
| 8        |               | 0             | 4 | Data Check              | ERR017  |
| 9        |               | 0             | 5 | Overrun                 | ERR020  |
| 10       |               | 0             | 0 | Command Reject          | ERR006  |
| 11       | 44            |               |   | Channel Data Check      | ERR035  |
| 12       | 47            |               |   | Chaining Check          | ERR029  |
| 13       | 42            |               |   | Program Check           | ERR029  |
| 14       | 43            |               |   | Protection Check        | ERR029  |
| 15       | 39            |               |   | Unit Exception          | ERR029  |
| 16       | 41            |               |   | Incorrect Length        | ERR029  |

#### Sense Byte 0 Meanings and Actions Taken

Bit 0: Command Reject

This bit is set when a Read Backward command is issued, or when any other command is received which the device has not been designed to execute. The error is considered permanent.

Bit 1: Intervention Required

This bit is set when one of the following occurs:

- The power is off.
- Cards are not registered at the read station.
- The stacker is full.
- The feed check light is on.
- The stop key has been depressed.
- The chip box is full, or has been removed.
- There are no cards in the hopper and the End-of-File light is not on.
- The cover interlock switch is open.

A message is given to the operator, who must take action. Upon correction of the condition, the interrupted operation is repeated.

### Bit 2: Bus-Out Check

This bit is set when a parity error has occurred on bus-out during transfer of command or data bytes, but not during the time period of address-out or command-out proceed. For a command byte one retry is attempted. If the error is not corrected it is considered permanent. For a data byte, the card is already punched and the error is considered permanent. However, on a 2501, the error is automatically retried once.

|              | Bit O                                                              | Bit 1                       | Bit 2                             | Bit 3                             | Bit 4                 | Bit 5                    | Bit 6            | Bit 7                |
|--------------|--------------------------------------------------------------------|-----------------------------|-----------------------------------|-----------------------------------|-----------------------|--------------------------|------------------|----------------------|
| Sense Byte O | Command<br>Reject                                                  | Intervention<br>Required    | Bus-Out<br>Check                  | Equipment<br>Check                | Data<br>Check         | Overrun                  |                  |                      |
| IOBF L1      | 00 No Chair<br>01 Command<br>10 Data Cha<br>11 Cammand<br>Data Cha | Chaining<br>lining<br>  and | Error<br>Routine<br>in<br>Control |                                   |                       | Exceptional<br>Condition |                  | 0 Start<br>1 Restart |
| IOBFL3       | Entry<br>Bit                                                       |                             | Read<br>Error<br>Count            | <b>Bus-</b> Out<br>Error<br>Count | Data<br>Check<br>Flag | Message<br>Type          | Overrun<br>Count | Logout<br>Flag       |

#### Figure 75. 2501 and 2520 Sense Bits, IOB Flags, and IOB Error Counts

Bit 3: Equipment Check

- This bit is set when one of the following occurs:
- An invalid card code is detected during a punch operation.
- During a read or punch operation an error is detected during the 9-bit match.

The invalid card code part of equipment check is not set during card image punch.

If the error occurs during a punch operation other than QSAM, it is automatically considered permanent. With QSAM an error occurring during a punch operation is retried. If it occurs during a read operation, one retry is attempted.

#### Bit 4: Data Check

This bit is set when an invalid card code is detected during a read operation. This error pertains to the last card for which data was sent. A message is typed and an operator must reposition the cards for one retry. If the error persists, it is considered permanent.

### Bit 5: Overrun

This bit is set if during a read operation the interface has not transmitted a character by the time the next character is to be read into the register. The operator must reposition the cards. The operation is retried once and if the error persists it is considered permanent, and a message is written to the console.

Bits 6 and 7: Should Not Occur

If either of these bits is set, a catastrophic error is assumed. A permanent error is signaled to the Error EXCP routine and control is returned via SVC 15.

# 2250 Error Routine

The IBM 2250 Display Unit error routine attempts recovery from channel data checks. The 2250 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence for the 2250 is shown in Figure 76. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 77. More information can be obtained from the following publications:

• IBM System/360 Component Description: IBM 2250 Display Unit Model 1, GA27-2701 • IBM System/360 Component Description: IBM 2250 Display Unit Model 2; IBM 2840 Display Control Model 1, GA27-2702

## Sense Byte 0 Meanings and Actions Taken

#### Bit 0: Command Reject

This bit is set when there is an invalid modifier bit in a command or an invalid invalid command sequence. The error is considered permanent.

Bit 1: Should Not Occur

When this bit is set, a catastrophic error is assumed. The logout flag in the IOB is set and the permanent error procedure is performed.

Bit 2: Bus-Out Check

This bit is set when a parity error is detected on a command or data byte during bus-out. The operation is retried once. If the retry is unsuccessful, a message is written to the operator.

Bit 3: Equipment Check (Model 2); Should Not Occur on Others (See Bit 1).

Bit 4: Data Check

This bit is set when a buffer parity error is detected either during a read operation or during image regeneration. The operation is retried once. If the retry is unsuccessful, a message is written to the operator.

Bit 5: Should Not Occur (See Bit 1)

#### Bit 6: Buffer Running

This bit indicates that regeneration is in process. When accompanied by Command Reject, a permanent error is assumed.

|          | Status | Sense |     |                         | Applicab | le to  |         |
|----------|--------|-------|-----|-------------------------|----------|--------|---------|
| Priority | Bit    | Byte  | Bit | Condition               | 2250-1   | 2250-2 | Pointer |
| 1        | 45     |       |     | Channel Control Check   | х        | х      | ASRON   |
| 2        | 46     |       |     | Interface Control Check | x        | x      | ASRON   |
| 3        | 44     |       |     | Channel Data Check      | x        | x      | TESTST  |
| 4        | 38     |       |     | Unit Check              | x        | x      | MAINER  |
| 5        |        | 0     | 1   | Should Not Occur        | x        |        | SEROUT  |
| 5        |        | 0     | 3   | Should Not Occur        | x        | x      | SEROUT  |
| 5        |        | 0     | 5   | Should Not Occur        | x        | x      | SEROUT  |
| 5        |        | 0     | 7   | Should Not Occur        | x        | x      | SEROUT  |
| 6        |        | 0     | 2   | Bus-Out Check           | x        | x      | B01CHK  |
| 7        |        | 0     | 4   | Data Check              | x        | x      | DATACX  |
| 8        |        | 0     | 0   | Command Reject          | х        | х      | PERMER  |
|          |        | 0     | 0   | Command Reject          | Note 1   |        | PERMER  |
| 9        |        | 0     | 6   | Buffer Running          | х        | х      |         |
| 10       | 42     |       |     | Program Check           | х        | х      | PERMER  |
| 11       | 43     |       |     | Protection Check        | x        | х      | PERMER  |
| 12       | 41     |       |     | Incorrect Length        | х        | х      | PERMER  |

Bit 7: Should Not Occur (See Bit 1)

Note: For an unbuffered 2250 Model 1 the following changes are necessary:

a. Command Reject with Buffer Running is a 'Should Not Occur' condition with Priority 5, Pointer SEROUT.

b. Priorities 10, 11, and 12 become 9, 10, and 11, respectively.

Figure 76. 2250 Error Analysis Sequence (Module IGE0010A)

|                               | Bit O                                                              | Bit 1                           | Bit 2                             | Bit 3                           | Bit 4                  | Bit 5                    | Bit 6                               | Bit 7                    |
|-------------------------------|--------------------------------------------------------------------|---------------------------------|-----------------------------------|---------------------------------|------------------------|--------------------------|-------------------------------------|--------------------------|
| Sense Byte O                  | Command<br>Reject                                                  |                                 | Bus-Out<br>Check                  | Equipment<br>Check<br>(Model 2) | Data<br>Check          |                          | Buffer<br>Running                   |                          |
| Sense Byte 1                  | Light<br>Pen<br>Defect                                             | End<br>Order<br>Sequence        | Character<br>Mode                 |                                 |                        | 2840<br>Output<br>Check  | 2840<br>Input<br>Check              |                          |
| IOBFLI                        | 00 No Chair<br>01 Command<br>10 Data Cha<br>11 Command<br>Chaining | Chaining<br>ining<br>and Data   | Error<br>Routine<br>in<br>Control |                                 |                        | Exceptional<br>Condition |                                     | 0 Start<br>1 Restart     |
| IOBFL2                        | Halt I/O<br>issued                                                 | Sense<br>Flag                   |                                   |                                 |                        |                          | Film<br>Unit<br>Flag                |                          |
| 10BFL3                        |                                                                    | ·                               |                                   |                                 |                        | Message<br>Type          |                                     | Logout<br>Flag           |
| 10B<br>Error Counts<br>Byte 1 | Bus-Out 1<br>Retry<br>Indicator                                    | Bus-Out 2<br>Retry<br>Indicator | Data<br>Check                     | Equipment<br>Check              | 2840<br>Input<br>Check | 2840<br>Output<br>Check  | Abnormal<br>End<br>Appendage<br>Bit | Channel<br>Data<br>Check |
| IOB<br>Error Counts<br>Byte 2 | Interface<br>Control<br>Check or<br>Channel<br>Control<br>Check    |                                 |                                   |                                 |                        |                          |                                     |                          |

# Figure 77. 2250 Sense Bits, IOB Flags, and IOB Error Counts

# 2260 and 1053 Error Routines

The IBM 2260 Display Station and IBM 1053 Printer error routine attempts recovery from channel data checks. The 2260 and 1053 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence for the 2260 and 1053 is shown in Figure 78. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 79. More information can be obtained from the publication *IBM System/360 Component Description: IBM 2260 Display Station; IBM 2848 Display Control,* GA27-2700.

| Priority | Status<br>Bit | Sense<br>Byte |   | Condition                          | Applical<br>2260 | ble to<br>1053 | Pointer     | Load <sup>1</sup> |
|----------|---------------|---------------|---|------------------------------------|------------------|----------------|-------------|-------------------|
| 1        | 45            |               |   | Channel Control Check              | х                | Х              | ASRON       | 1                 |
| 2        | 46            |               |   | Interface Control Check            | х                | Х              | ASRON       | 1                 |
| 3        | 44            |               |   | Channel Data Check                 | х                | х              | TESTST      | 1                 |
| 4        | 38            |               |   | Unit Check                         | х                | х              | MAINER      | 1                 |
| 5        |               | 0             | 4 | Should Not Occur                   | х                | х              | SEROUT      | 1                 |
| 5        |               | 0             | 5 | Should Not Occur                   | х                | х              | SEROUT      | 1                 |
| 5        |               | 0             | 6 | Should Not Occur                   | х                | х              | SEROUT      | 1                 |
| 6        |               | 0             | 3 | Equipment Check                    | х                |                | EC          | 1                 |
| 7        |               | 0             | 1 | Intervention Required              |                  | х              | 2260-SEROUT | 1                 |
| 8        |               | 0             | 2 | Bus-Out Check<br>Initial Selection | х                | х              | B01         | 1                 |
| 8        |               | 0             | 2 | Bus-Out Check<br>Data Transfer     | х                |                | ISBUSOUT    | 1                 |
| 8        |               | 0             | 2 | Bus-Out Check<br>Data Transfer     |                  | х              | ISBUSOUT    | 1                 |
| 9        |               | 0             | 0 | Command Reject                     | х                | Х              | PERMER      | 1                 |
| 10       | 42            |               |   | Program Check                      | х                | Х              | PERMER      | 1                 |
| 11       | 43            |               |   | Protection Check                   | х                | Х              | PERMER      | 1                 |
| 12       | 41            |               |   | Incorrect Length                   | Х                | х              | PERMER      | 1                 |

<sup>1</sup>Only first-time equipment check errors are handled by load 2.

Figure 78. 2260 and 1053 Error Analysis Sequence (Load 1—IGE0010B or Load 2—IGE0100B)

## Sense Byte Meanings and Actions Taken

Bit 0: Command Reject. This bit is set when there is an invalid modifier bit in a command, or an invalid command sequence. The error is considered permanent.

#### Bit 1: Intervention Required

This bit is set when a 1053 Write command is given but the 1053 is not ready. A message is written to the operator.

### Bit 2: Bus-Out Check

This bit is set when a parity error is detected on a command or data byte during bus-out. Processing depends upon when the bus-out check occurred and what command was last executed:

If the bus-out check occurred during initial selection, or during data transmission for the 2260 after a Write Line Address or an Erase command, one retry is attempted. If the retry is unsuccessful a message is written to the operator.

If the bus-out check occurred during data transmission for the 2260 after a Write Buffer Storage command, one retry is attempted, but before that retry an Erase Buffer Storage command is issued. If the retry is unsuccessful, a message is written to the operator.

## Bit 3: Equipment Check

This bit is set when a parity error is detected during a manual read input operation. The second load of the 2260 and 1053 error routine erases the message in error and displays an error message on the screen. No automatic retry occurs. If a retry is desired, the necessary coding must be included in the user's program. (If the error occurs a second time, the user's program should consider it permanent.)

|                               | Bit O                                                              | Bit 1                         | Bit 2                             | Bit 3                                  | Bit 4 | Bit 5                    | Bit 6                               | Bit 7                |
|-------------------------------|--------------------------------------------------------------------|-------------------------------|-----------------------------------|----------------------------------------|-------|--------------------------|-------------------------------------|----------------------|
| Sense Byte O                  | Command<br>Reject                                                  | Intervention<br>Required      | Bus-Out<br>Check                  | Equipment<br>Check                     |       |                          |                                     |                      |
| IOBFLI                        | 00 No Chain<br>01 Commanc<br>10 Data Cha<br>11 Commanc<br>Data Cha | l Chaining<br>pining<br>I and | Error<br>Routine<br>in<br>Control |                                        |       | Exceptional<br>Condition |                                     | 0 Start<br>1 Restart |
| IOBF L2                       |                                                                    | Sense<br>Flag                 |                                   |                                        |       |                          | Film<br>Unit<br>Flag                |                      |
| IOBFL3                        |                                                                    |                               |                                   |                                        |       | Message<br>Type          |                                     | Logout<br>Flag       |
| IOB<br>Error Counts<br>Byte 1 | Bus-Out<br>Count 1                                                 | Bus-Out<br>Count 2            | Bus-Out<br>Count 3                | Error<br>Routine<br>Channel<br>Program |       | Channel<br>Data<br>Check | Abnormal<br>End<br>Appendage<br>Bit | Check                |
| IOB<br>Error Counts<br>Byte 2 | Interface<br>Control<br>Check or<br>Channel<br>Control<br>Check    |                               |                                   |                                        |       |                          |                                     |                      |

Figure 79. 2260 and 1053 Sense Bits, IOB Flags, and IOB Error Counts

Bits 4-7: Should Not Occur

If one of these bits is set, a catastrophic error condition is assumed. The logout bit in the IOB is set, and a permanent error procedure is performed.

### 2305, 2314, 2319, 3330, and 3333 Error Routines

This routine is resident and is generated by a macro during system generation to service the types of devices at an installation.

This routine attempts recovery from channel data checks. It also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

Channel programs are usually restarted from the beginning to avoid a repositioning problem, command and data chaining problems, and to simplify the handling of errors within errors.

When a 'track condition check' error occurs, the home address record and record 0 are read to determine whether the track is defective or is an alternate track. A bit in the UCB is checked to determine whether the home address and record 0 have already been read by DSS; if not, ERP does the read. If the track is defective, the address of the alternate track is used in a Seek command, and the the operation is resumed on the alternate track. If the track condition check occurred on an alternate track, the defective track's address, plus 1, is used in a Seek command and the operation is resumed on the new track. When a 'no-record-found' error occurs, a console message is not issued if the access arm has been positioned at the correct track. A 'permanent error' indicator is set in the input/output block.

When the overflow incomplete bit (sense byte 1, bit 7) is set, only a partial record has been read or written, and a CCW is constructed so the remainder of the record can be processed. When the 'overflow incomplete' bit is set and the 'file mask violation', 'end-of-cylinder', or 'track condition check' bit is also set, the error routine assumes that the first record of the continuation track is properly identified as record number 1.

This error routine handles cylinder and head switching for both sequential and split cylinders.

A bit in the CVT is checked prior to the ERP attempting to cause any transients to be loaded. This bit is turned on by NIP at IPL time and turned off when NIP has proceeded far enough to allow transients to be loaded.

When a permanent I/O error is detected for the Paging Supervisor, a Deferred Incident Record is built by the ERP for subsequent recording into SYS1.LOGREC. This record contains, essentially, the same information as the non-Paging Supervisor permanent I/O SYS1.LOGREC record. See OS/VS SYS1.LOGREC Error Recording Logic for more information about error recording.

- When a 2305, 3330, or 3333 presents a unit check, IOS performs a sense I/O command for 24 bytes and then enters the resident direct access ERPs. The ERP then checks the error indications in the CSW and sense bits according to the following precedence table (Figure 81) until a bit is found on. The action referred to will then be performed.
- The control units for a 2305, 3330, and 3333 have an error correction capability known as the Error Correction Function, or ECF. If a data check occurs in a count or key area, the control unit performs ECF internally. If a data check occurs in the data field, the sense bytes contain a displacement and a 3-byte correction code for the ERP to use in correcting the error. The ECF supplied by a 3330, 3333, and 2305 corrects up to three contiguous bytes of data.
  - A 3330 or 3333 control unit presents the displacement to the error starting from the beginning of the data field, which allows the ERP to apply the correction code when data chaining is being performed in the data field. Because a 2305 control unit presents the displacement from the last byte transferred, the ERP only corrects the last segment if data chaining in the data field is used. If the error is not in the last segment, up to ten retries are performed, but the correction code is not applied.

For the Paging Supervisor and subsystem I/O, the ERP leaves Relocate Mode to apply the correction code.

The error analysis sequence for the IBM 2314 and 2319 Direct-access Storage Facility is shown in Figure 80. Figure 81 shows the error analysis sequence for the IBM 2305 Fixed Head Storage, 3330 Disk Storage, and 3333 Disk Storage and Control. The meanings of sense bits, IOB flags, and IOB error counts for all of the direct access devices are given in Figure 82. More information about the individual devices can be obtained from the following publications:

- IBM System/360 Component Descriptions: 2314 Direct Access Storage Facility and 2844 Auxiliary Storage Control, GA26-3599
- IBM System/360 Component Descriptions: 2835 Storage Control and 2305 Fixed Head Storage, GA26-1589
- Reference Manual for 3830 Storage Control and 3330 Disk Storage, GA26-1592
- Reference Manual for 3333 Disk Storage and Control, GA26-1615

| Priority | Status<br>Bit    | Sense<br>Byte |    | Condition               | Pointer |
|----------|------------------|---------------|----|-------------------------|---------|
| 1        | • 45             | Bytt          | DR | Channel Control Check   | ERNT    |
| 2        | • <del>4</del> 5 |               |    | Interface Control Check | ERNT    |
| 3        | 44               |               |    | Channel Data Check      | ERNT    |
| 4        |                  | 0             | 2  |                         |         |
|          |                  |               | 3  | Equipment Check         | ERNT    |
| 5        |                  | 1             | 4  | No Record Found         | ERNT    |
| 6        |                  | 0             | 7  | Seek Check              | ERNT    |
| 7        |                  | 0             | 1  | Intervention Required   | ERNT    |
| 8        |                  | 0             | 2  | Bus-Out Check           | ERNT    |
| 9        |                  | 0             | 4  | Data Check              | ERNT    |
| 10       |                  | 0             | 5  | Overrun                 | ERNT    |
| 11       |                  | 1             | 6  | Missing Address Markers | ERNT    |
| 12       |                  | 0             | 0  | Command Reject          | ERNT    |
| 13       |                  | 0             | 6  | Track Condition Check   | ERNT    |
| 14       |                  | 1             | 1  | Track Overrun           | ERNT    |
| 15       |                  | 1             | 2  | End of Cylinder         | ERNT    |
| 16       |                  | 1             | 5  | File Protect            | ERNT    |
| 17       | 38               |               |    | Unit Check              | ERNT    |
| 18       | 47               |               |    | Chaining Check          | ERNT    |
| 19       | 42               |               |    | Program Check           | ERNT    |
| 20       | 43               |               |    | Protection Check        | ERNT    |
| 21       | 39               |               |    | Unit Exception          | ERNT    |
| 22       | 41               |               |    | Incorrect Length        | ERNT    |

IEC23XXF logs statistics in the System Data Recording work area.

Figure 80. 2314 and 2319 Error Analysis Sequence (Module IEC23XXF)

#### Sense Byte 0 Meanings and Actions Taken

#### Bit 0: Command Reject

When this bit and bit 5 of sense byte 1 (File Protected) are set, the write inhibit portion of the file mask has been violated.

When this bit and bit 3 of byte 1 (Invalid Command Sequence) are set, one of the following has occurred:

- A Write command was not preceded by the necessary Search or Write command.
- A Set File Mask, Reserve, or Release command has been issued in a chain where a previous Set File Mask command was given.
- Head switching is being attempted in a command chain not containing a previous seek.
- Space count has been chained from a Write command.
- A formatting command is being attempted after record 0 on a defective track or following a record which is flagged as an overflow record.

When this bit and bit 7 of byte 0 (seek check) are set, the 2841 detected an invalid seek address or was given a seek address consisting of fewer than six bytes. A seek is not initiated.

| Priority | Status<br>Bit | Sense<br>Byte |     | Condition               | Pointer |
|----------|---------------|---------------|-----|-------------------------|---------|
| 1        | 45            | 2900          | 2.0 | Channel Control Check   | ERNT    |
| 2        | 46            |               |     | Interface Control Check | ERNT    |
| 3        | 44            |               |     | Channel Data Check      | ERNT    |
| 4        | 47            |               |     | Chaining Check          | ERNT    |
| 5        |               | 1             | 0   | Permanent Error         | ERNT    |
| 6        |               | 0             | 3   | Equipment Check         | ERNT    |
| 7        |               | 0             | 2   | Bus-Out Check           | ERNT    |
| 8        |               | 0             | 1   | Intervention Required   | ERNT    |
| 9        |               | 0             | 0   | Command Reject          | ERNT    |
| 10       |               | 1             | 4   | No Record Found         | ERNT    |
| 11       |               | 0             | 5   | Overrun                 | ERNT    |
| 12       |               | 1             | 1   | Invalid Track Format    | ERNT    |
| 13       |               | 0             | 4   | Data Check              | ERNT    |
| 14       |               | 1             | 2   | End of Cylinder         | ERNT    |
| 15       |               | 1             | 5   | File Protect            | ERNT    |
| 16       |               | 1             | 7   | Overflow                | ERNT    |
| 17       | 38            |               |     | Unit Check              | ERNT    |
| 18       | 42            |               |     | Program Check           | ERNT    |
| 19       | 43            |               |     | Protection Check        | ERNT    |
| 20       | 39            |               |     | Unit Exception          | ERNT    |
| 21       | 41            |               |     | Incorrect Length        | ERNT    |

IEC23XXF logs statistics in the System Data Recording work area.

Figure 81. 2305, 3330, and 3333 Error Analysis Sequence (Module IEC23XXF)

When the 'command reject' bit is on and the File Protected, Invalid Command Sequence, or Seek Check bits mentioned above are not on, one of the following has occurred:

- An invalid command was given.
- An invalid file mask was given.
- The sum of a key length plus data length exceeds 2<sup>16</sup>-1.
- An IPL command was given after a Set File Mask command.
- Command out has been presented in response to a request for the first byte of a Write Home Address CCW.

#### Bit 1: Intervention Required

This bit indicates that the device is not physically attached to the system, or is physically attached but is not available for use because the file motor is not on, a cover is open, etc.

#### Bit 2: Bus-Out Check

This bit is set when a parity error is detected during information transfer from the channel to the control unit. The check is an odd parity check which is made on control, write, and search operations. (Parity errors which are detected during command transfer result in bus-out checks and not command reject.) Ten retries are attempted. If the error remains uncorrected, a message is written to the operator and the control unit is considered inoperative.

.

|                                     | Bit 0                               | Bit 1                      | Bit 2                             | Bit 3                                                    | Bit 4                    | Bit 5                              | Bit 6                                       | Bit 7                  |
|-------------------------------------|-------------------------------------|----------------------------|-----------------------------------|----------------------------------------------------------|--------------------------|------------------------------------|---------------------------------------------|------------------------|
|                                     |                                     |                            |                                   |                                                          |                          | 5105                               |                                             |                        |
| Sense Byte 0<br>2305, 3330,<br>3333 | Command<br>Reject                   | Intervéntion<br>Required   | Bus-Out<br>Check                  | Equipment<br>Check                                       | Data<br>Check            | Overrun                            |                                             |                        |
| Sense Byte 0<br>2314, 2319          | Command<br>Reject                   | Intervention<br>Required   | Bus-Out<br>Check                  | Equipment<br>Check                                       | Data<br>Check            | Overrun                            | Track<br>Condition<br>Check                 | Seek<br>Check          |
| Sense Byte 1<br>2305, 3330,<br>3333 | Permanent<br>Error                  | Invalid<br>Track<br>Format | End of<br>Cylinder                |                                                          | No<br>Record<br>Found    | File<br>Protected                  | Write<br>Inhibit<br>(3330 and<br>3333 only) | Operation<br>Incomplet |
| Sense Byte 1<br>2314, 2319          | Data Check<br>in Count<br>Area      | Track<br>Overrun           | End of<br>Cylinder                | Invalid<br>Command<br>Sequence                           | No<br>Record<br>Found    | File<br>Protected                  | Missing<br>Address<br>Market                | Overflow<br>Incomplet  |
| Sense Byte 2<br>2305, 3330,<br>3333 | Buffered<br>Log Full<br>(2305 only) | Correctable                |                                   | Environmental<br>Data Present<br>(3330 and<br>3333 only) |                          |                                    |                                             |                        |
| IOBF L1                             | 10 Data C<br>11 Comm                | hand Chaining<br>Chaining  | Error<br>Routine<br>in<br>Control |                                                          |                          | Exceptional<br>Condition           | Overflow<br>Indicator                       | 0 Start<br>1 Resta     |
| IOB€L2                              | Halt<br>Input/<br>Output            | Sense<br>Bit               | Purge<br>Flag                     | Read<br>Home<br>Address<br>Flag                          | No End<br>Extent<br>Flag | Track<br>Address<br>Update<br>Flag |                                             |                        |
| IOBFL3                              | Indicator 1                         | Track<br>Condition<br>Flag | No<br>Record<br>Found             | Bus-Out<br>Error<br>Count                                | Restore<br>Flag          | Message<br>Түре                    |                                             | Log-Out<br>Flag        |

### Figure 82. 2305, 2314, 2319, 3330, and 3333 Sense Bits, IOB Flags, and IOB Error Counts

#### Bit 3: Equipment Check

This bit indicates a malfunctioning control unit or device. A message is written to the operator. Except for 2305, 3330, and 3333, the conditions that cause this bit to be set are defined in sense byte 2, bits 0, 2, 4, and 5.

Bit 4: Data Check

I

L

This bit is set when an error is defected in the information received from the device. Data Check will usually occur when an attempt is made to read a record which overflows a track. For 2305, 3330, and 3333, if the correctable bit (byte 2, bit 1) is on, the Error Correction Function is used.

#### Bit 5: Overrun

This bit is set when a chained CCW is received too late to be properly executed or when channel response is too slow during data transfer. Ten retries are attempted. If the retries are unsuccessful the error is considered permanent and a message is written to the operator. An overrun condition always results in an immediate stop of data transmission. For Write operations, the record area is padded with zeros.

#### Bit 6: Track Condition Check

This bit is set when one of the following conditions has occurred:

- Any single track command other than Search Home Address, Read Home Address, or Read Record 0 is executed on a defective track.
- Any multitrack command other than Search Home Address, Read Home Address, or Read Record 0 causes a switch to a defective track, or an overflow operation is attempted to a defective track.
- Any multitrack command or overflow operation attempts to switch from an alternate, or defective track on which a read or search type command has been executed.

#### Bit 7: Seek Check

This bit is set when the device is unable to successfully complete a seek because:

- The seek address is invalid. Command Reject (byte 0, bit 0) is also set.
- The seek address consists of fewer than six bytes. Command Reject (byte 0, bit 0) is also set.
- The access mechanism has malfunctioned.
- The last three bytes at the track's home address are not identical to the last three bytes of the seek address.

#### 2400 and 3400 Tape Series Error Routines

The IBM 2400/3400 Tape Series error routine uses two operations designed to clear or circumvent sections of the tape that are presumably contaminated or defective. These operations are (1) the tape cleaner action and (2) the erase gap action.

The tape cleaner action is a "shoe shining" operation in which the tape is run back and forth to produce a wiping action both at the read head and at the tape cleaner blade. This action transfers contaminants from the read head to the tape and from the tape to the cleaner blade.

If the tape is being read forward, the cleaner action consists of a backward motion (toward the supply reel) equal in length to five records, followed by a forward motion equal in length to four records, positioning the read/write head at the beginning of the record that was being read when the data check occurred.

If the tape is being read backward, the cleaner action consists of a backward motion equal in length to four records, followed by a forward motion equal in length to five records, positioning the read/write head at the end of the record that was being read when the data check occurred.

The erase gap action is performed whenever a write error is detected. It consists of erasing a 3-1/2 inch portion of the tape, starting at the beginning of the write area assumed to be defective. This action treats the error as unrecoverable; the gap is a detour around the defective area.

The noise bit (byte 1, bit 0) is set if a data check occurs and: phase encoding (PE) is used; or non-return-to-zero-inverse (NRZI) encoding is used. If a data check occurs and

the noise bit is not set, it is assumed that the data check may have been caused by too short a record block. In this case, the record length is checked, and if it is less than 12 bytes, the record block is defined as a "noise block." Noise blocks are skipped and treated as permanent errors except when found by an integrated emulator on 7-track tapes; then all noise blocks are returned to the emulator for further processing. The DEBOFLGS field of the DEB identifies the tape as an emulator tape.

The error routines also treat parity errors differently on 7-track tapes being read by an integrated emulator. Rather than being a permanent error, the parity is switched (DEBVMOD field of the DEB) and the block reread in the alternate parity until 10 read-recovery sequences have been executed (40 retries) or the read is successful. After 10 read-recovery sequences, the parity is switched back to the original parity and the block is reread until 10 read-recovery sequences have been executed (a permanent error) or the read is successful.

When an ending status (channel end, device end, or unit check) appears in the channel status word, the 2400/3400 error routine increments the 'block count' field of the data control block by the amount shown in the 'block count increment' field of the input/output block (IOB).

If an error remains uncorrected after retry attempts, or if no retries are attempted, a message (IEA000I) is written to the operator. For all error conditions except 'command reject, load point, data converter check' and 'not capable,' the logout flag of the IOB is set before entry to the I/O supervisor's Write-to-Operator routine. This is an indication to the I/O supervisor's Write-to-Operator routine to invoke the Outboard Recorder after

|          | Status |      |     |                              | Applica | able to: |         |         |                   |  |
|----------|--------|------|-----|------------------------------|---------|----------|---------|---------|-------------------|--|
| Priority | Bit    | Byte | Bit | Condition                    | Read    | Write    | Control | Pointer | Load <sup>1</sup> |  |
| 1        | 45     |      |     | Channel Control Check        | Х       | х        | х       | ER2404B | 4                 |  |
| 2        | 46     |      |     | Interface Control Check      | Х       | X        | х       | ER2404B | 4                 |  |
| 3        | 38     |      |     | Unit Check                   | Х       | х        | х       | ER2404B | 4                 |  |
| 4        |        | 0    | 3   | Equipment Check              | X       | X        | x       | ER2404A | 4                 |  |
| 5        |        | 0    | 2   | Bus-Out Check                | Х       | Х        | х       | ER2404A | 4                 |  |
| 6        |        | 0    | 1   | Intervention Required        | х       | х        | х       | ER2404A | 4                 |  |
| 7        |        | 0    | 0   | Command Reject               | Х       | Х        | х       | ER2404A | 4                 |  |
| 8        |        | 0    | 5   | Overrun                      | Х       | х        |         | ER2404A | 4                 |  |
| 9        |        | 1    | 4   | Load Point                   | Х       | Х        |         | ER2404A | 4                 |  |
| 10       |        | 0    | 4   | Data Check                   | х       | х        | х       | ER2404A | 4                 |  |
| 11       |        | 7    | 4   | Data Security Erase          |         |          | х       | ER2402A | 2                 |  |
| 12       | 44     |      |     | Channel Data Check           | х       | х        | х       | ER2404A | 4                 |  |
| 13       |        | 0    | 7   | Data Converter Check         | х       |          |         | ER2404A | 4                 |  |
| 14       |        | 1    | 7   | Not Capable                  | х       |          |         | ER2404A | 4                 |  |
| 15       |        | 5    | 3   | PE ID Burst Check            |         | X        | x       | ER2401A | 1                 |  |
| 16       |        |      |     | No Previous Sense Bits<br>On | x       | x        | х       | ER2404A | 4                 |  |
| 17       | 47     |      |     | Chaining Check               | х       |          |         | ER2404B |                   |  |
| 18       | 42     |      |     | Program Check                | x       | x        | x       | ER2404B | 4                 |  |
| 19       | 43     |      |     | Protection Check             | х       |          |         | ER2404B | 4                 |  |
| 20       | 41     |      |     | Incorrect Length             | x       | x        |         | ER2404B | 4                 |  |

<sup>1</sup>Only errors that occur during Read-opposite recovery are handled by Load 3.

Figure 83. 2400/3400 Error Analysis Sequence (Load 1—IGE0000I, Load 2—IGE0100I, Load 3—IGE0200I, Load 4—IGE0300I, Load 5—IGE0400I, or Load 6—IGE0900I)

|                               | Bit 0                                                           | Bit 1                               | Bit 2                                          | Bit 3                         | Bit 4                                               | Bit 5                                               | Bit 6                     | Bit 7                      |
|-------------------------------|-----------------------------------------------------------------|-------------------------------------|------------------------------------------------|-------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------|----------------------------|
| Sense Byte O                  | Command<br>Reject                                               | Intervention<br>Required            | Bus-Out<br>Check                               | Equipment<br>Check            | Data<br>Check                                       | Overrun                                             | Word<br>Count<br>Zero     | Data<br>Converter<br>Check |
| Sense Byte 1                  | Noise<br>Bit                                                    | Unit<br>Status<br>A                 | Unit<br>Status<br>B                            | 7-Track<br>Tape<br>Unit       | Tape<br>At Load<br>Point                            | Unit in<br>Write<br>Status                          | File<br>Protect<br>Status | Not<br>Capable             |
| Sense Byte 2                  |                                                                 |                                     |                                                |                               |                                                     |                                                     | Multi<br>Error            | Track<br>Exists            |
| Sense Byte 3                  | Read/Write<br>Vertical<br>Redundan-<br>cy Check                 | Longitudinal<br>Redundancy<br>Check | Skew                                           | Cyclic<br>Redundancy<br>Check | Skew<br>Register<br>Vertical<br>Redundancy<br>Check | Phase<br>Encoding                                   | Backward                  | C-Compare                  |
| Sense Byte 4                  | <br>                                                            | Reject<br>Tape<br>Unit              | Read<br>Clock                                  | Write<br>Clock                | Delay<br>Counter                                    | C<br>Sequence                                       | B<br>Sequence             | A<br>Sequence              |
| IOBFL 1                       | 10 Data C<br>11 Comm                                            | and Chaining<br>haining             | Error<br>Routine<br>In<br>Control              | Reposition<br>Tape            | Cyclic<br>Redundancy<br>Check<br>Bıt                | Exceptional<br>Condition                            |                           | 0 Start<br>1 Restart       |
| IOBFL 2                       |                                                                 | Sense<br>Bit                        | Purge<br>Flag                                  |                               | Read/Write<br>Unit<br>Exception                     | Use Read<br>Opposite<br>Recovery<br>CCW from<br>IOB |                           |                            |
| IOBFL 3                       | Noise<br>Message<br>Given                                       | IOB<br>Entry<br>Bit                 | Tape<br>Cleaning<br>Bit                        | Control<br>Flag               | Read<br>Opposite<br>Recovery                        | Messäge<br>Type                                     | Control<br>Unit<br>Busy   | Logout<br>Flag             |
| IOB<br>Error Counts<br>Byte 1 | Interface<br>Control<br>Check or<br>Channel<br>Control<br>Check | Chan                                | run, Bus-Out C<br>nel Data Check<br>ning Check |                               |                                                     | Clean                                               | er Control Cou            | int                        |
| IOB<br>Error Counts           | Write                                                           |                                     |                                                | Read Data Che                 | ck Counts                                           |                                                     |                           |                            |
| Byte 2                        | Indicator                                                       |                                     | Error Routine<br>ERG Data Che                  |                               |                                                     | ERG Data Che                                        |                           |                            |

#### Figure 84. 2400/3400 Sense Bits, IOB Flags, and IOB Error Counts

it writes the message. See OS/VS SYS1.LOGREC Error Recording Logic for information about outboard recording.

The error analysis sequence for the 2400/3400 is shown in Figure 83. The meanings of the sense bits, IOB flags, and IOB error counts are shown in Figure 84. More information can be obtained from the following publications:

• IBM System/360 Component Description: 2400 Series Magnetic Tape Units,

2803/2804 Tape Controls, and 2816 Switching Unit, Model 1, GA22-6866

- IBM System/360 Component Description: 3803/3420 Magnetic Tape Subsystems, GA32-0020
- IBM 3410/3411 Magnetic Tape Subsystem Component Summary, GA32-0015

#### Sense Byte 0 Meanings and Actions Taken

Byte 0 Bit 0: Command Reject

This bit is set when a command is received which the device has not been designed to execute. The error is considered permanent.

#### Byte 0 Bit 1: Intervention Required

This bit indicates a not-ready condition. Actions taken depend upon whether a device end status was also received:

With no device end, unit status B (sense byte 1, bit 2) is examined. If 0, the device is assumed not to exist and the error is considered permanent. If unit status B is 1, a message is given the operator. When he readies the device, the operation is attempted again.

With device end, if a Rewind Unload command was the last command executed, a successful completion is assumed and processing continues. Otherwise, the condition is ignored and the scan of sense bits is continued.

#### Byte 0 Bit 2: Bus-Out Check

This bit is set when even parity appears on the information bus lines from the channel to the control unit. The command is attempted again. The tape is first repositioned if the bus-out check occurred during a write operation.

#### Byte 0 Bit 3: Equipment Check

This bit is set when a unit fails to respond to a set read or a set write status when instructed, or becomes not ready during execution of a tape motion operation. The error is considered permanent.

#### Byte 0 Bit 4: Data Check

During a read or read backward operation: If the noise bit (byte 1, bit 0) is off and the blocksize is less than 12 bytes, the noise block flag in the statistics update mask is set and regular operation is resumed with the next block (except when 7-track tapes are being read by an integrated emulator, in which case the noise block is passed back to the emulator).

If the noise bit is off, but the blocksize is 12 bytes or greater, or if noise bit is on, a read recovery sequence is initiated. This sequence consists of the following steps:

- 1. Reposition the tape.
- 2. Issue the Track-in-Error command to send error information (byte 2, bit 7) to the tape control unit.
- 3. Re-read the tape. If error persists, post (or repost) the applicable flag bit (representing a temporary 'read' error) in temporary storage.
- 4. Repeat steps one through three for a total of four rereads unless a good read is obtained.
- 5. Perform a tape cleaner action and increment the temporary cleaner action counter in the Volume Statistics Table.

A total of ten read recovery sequences can be initiated. If the error is not cleared by that time, a read-opposite recovery sequence is initiated, provided that none of the following conditions exists:

• Data chaining is being performed.

- Data conversion mode and 7-track tape are being used.
- The original CCW count is less than the physical block size on the tape.
- "Suppress data transfer" is specified in the original CCW.

During a write or write tape mark operation: reposition the tape, issue an erase gap, issue a mode set (if 7-track), and reissue the command.

3400 write: repeat this procedure until successful or until 14 retries have been attempted. If the error persists after 14 retries, go to step 1 below.

2400 write: (2400/3420 write tapemark) repeat this procedure until successful or until 15 retries have been attempted. If the error persists after 15 retries, go to step 2 below.

Step 1. Change the failing write CCW to a "loop-write-to-read" CCW. The write CCW must not be a command or data chained from or to any of the CCWs in the original failing CCW chain. After the loop-write-to-read has been completed, the failing write CCW is issued to complete the fifteenth retry.

Step 2. Provide an operator message, post completed with error condition, and exit to operating system.

During an ERG: reissue the command. Repeat this procedure until 3 retries have been attempted. If the error persists, provide an operator message, post completed with error condition, and exit to the operating system.

#### Byte 0 Bit 5: Overrun

This bit is set when service is requested but data cannot be transferred during a read, write, or read backward operation. Five retries are attempted. Before each retry, the tape is repositioned. *Note:* A data check during overrun suppresses the overrun indication.

Byte 0 Bit 6: Word Count Zero

This bit is set during a write operation if transfer of data is prevented before the first byte is written. This indicator is ignored.

#### Byte 0 Bit 7: Data Converter Check

This bit is set when an error occurs during operation of the data conversion feature. The error is considered permanent.

#### Other Actions Taken

#### Byte 1 Bit 7: Not Capable

Set on some models when density handling features are not compatible with actual tapedensity. No retries are attempted.

#### Byte 5 Bit 3: Phase Encoding ID Burst Check

Reposition to load point with a Rewind command and reissue the command. Repeat this procedure until successful, or until 14 retries have been attempted. A Loop-write-to-read command is issued and the fifteenth write retry is issued.

#### Byte 7 Bit 4: Data Security Erase Error

Print a message to the operator and record as a permanent error.

#### Unexpected Device End

Print a message to the operator and reissue the command.

#### Channel Data Check

This status bit is set when a channel detects a parity error in the information transferred to or from virtual storage during an I/O operation. Five retries are attempted. The tape is repositioned before each retry of a read or write operation.

**Chaining Check** 

This status bit is set when channel overrun occurs during data chaining on read operations. Five retries are attempted. The tape is repositioned before each retry.

Interface Control Check

Channel Control Check

An interface control check is caused by an invalid signal on the I/O interface; channel control check is caused by any machine malfunction affecting channel controls. Actions taken by the 2400/3400 error routine are shown below. Error recovery procedure interface bytes (ERPIB) are supplied by the Channel Check Handler routine.

No retries are attempted when:

- ERPIB byte 4, bit 7 is on (unconditional no-retry).
- ERPIB byte 6, bit 3 or 4 or 5 is off (retry code invalid, unit status invalid, or command address invalid).
- ERPIB are not produced.
- ERPIB byte 7, bits 0 and 1 are both on (system reset).
- ERPIB byte 4, bit 2 is on (Test I/O with no pending interruption stored a CSW).
- ERPIB byte 4, bit 3 is on (Halt I/O stored a CSW).
- ERPIB byte 4, bits 0 and 1 are both on or both off.
- ERPIB byte 4, bit 5 is off (if unit check).
- There is a unit check and an equipment check.
- The interface control check or channel control check occurred during tape repositioning (unless cc = 1).

Retries are attempted when none of the above conditions exists and ERPIB termination codes and retry combinations are:

- Termination code 10, retry code 010. Write command—retry once.
- Termination code 01, retry code 011 or 101. Write or Read command—reposition and retry once. For other commands (except Set, Mode, and Transfer-in-Channel) the operation is considered complete and no recovery is attempted.

If the device is one of the 3400 series, retries are attempted when any of the following conditions exist:

- Read or Read Backward, termination code of 00, 01, or 10, and sequence code 001.
- Write, termination code 00, 01, or 10, and sequence code 001.
- Control (Read/Write), termination code 00, 01, or 10, and sequence code 001.
- Control (Rewind/Unload/Mode Set), termination code 00, 01, or 10, and sequence code 001 or 010.
- Sense, termination code 00 or 01, and sequence code 001, 010, 011, or 101.
- For all other termination and sequence code combinations, the errors are not retriable.

### 2495 Error Routine

The IBM 2495 Tape Cartridge Reader error routine attempts recovery from channel data checks. The 2495 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence is shown in Figure 85. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 86.

More information can be obtained from the following publication: IBM System/360 Component Description, IBM 2495 Tape Cartridge Reader, GA27-2726

#### Bit 0: Command Reject

This bit is set when:

- An invalid command is received and the control unit is not busy.
- A Read command is received after end-of-tape is encountered.
- A Control Rewind or Control Backspace command is received when the tape is in the load position.
- A Control Backspace command is received immediately following a position check caused by another Control Backspace command.

No retries are attempted.

#### Bit 1: Intervention Required

This bit is set when a command is received and the control unit is in the not-ready state because:

- The stop key was depressed.
- The hopper is empty and the end-of-file key has not been depressed.
- The power is off.
- The stacker is full.
- An auto-loader malfunction occurred.

The requester's RQE is queued so that when the tape drive is made ready the command will be reissued.

#### Bit 2: Bus-Out Check

This bit is set when a command with even parity appears on a bus-out operation. If the bit is set during initial selection, the operation is retried once. On the second occurrence, the error is considered permanent.

#### Bit 3: Equipment Check

This bit is set when:

- The leader is disconnected.
- The tape is jammed.
- The tape is not repositioned.
- A motion detection device fails.

The error is considered permanent.

#### Bit 4: Data Check

This bit is set when a byte with even parity is detected in the data register during a Read command. The tape is backspaced one byte and the remaining portion is read. The sequence is repeated up to ten times. The UCB extension is used as a work area for constructing a backspace CCW, a residual read CCW, and, for command chaining,

| Priority | Status<br>Bit | Sense<br>Byte | Bit | Condition                       | Pointer |
|----------|---------------|---------------|-----|---------------------------------|---------|
| 1        | 45            |               |     | Channel Control Check           | ERR033  |
| 2        | 46            |               |     | Interface Control Check         | ERR033  |
| 3        | 44            |               |     | Channel Data Check              | ERR033  |
| 4        | 42            |               |     | Program Check                   | ERR033  |
| 5        | 43            |               |     | Protection Check                | ERR033  |
| 6        | 38            |               |     | Unit Check                      | ERR033  |
| 7        |               | 0             | 5   | Should Not Occur                | ERR046  |
| 7        |               | 0             | 7   | Should Not Occur                | ERR046  |
| 8        |               | 0             | 3   | Equipment Check                 | ERR046  |
| 9        |               | 0             | 2   | Bus-Out Check                   | ERR046  |
| 10       |               | 0             | 1   | Intervention Required           | ERR046  |
| 11       |               | 0             | 6   | Position Check                  | ERR046  |
| 12       |               | 0             | 4   | Data Check                      | ERR046  |
| 13       |               | 0             | 0   | Command Reject                  | ERR046  |
| 14       |               |               |     | None of the Above Sense Bits On | ERR046  |
| None     | 39            |               |     | Unit Exception                  | ERR033  |
| None     | 41            |               |     | Incorrect Length                | ERR033  |

|                               | Bit O                                                                | Bit 1                    | Bit 2                                  | Bit 3                  | Bit 4         | Bit 5                    | Bit 6             | Bit 7                |
|-------------------------------|----------------------------------------------------------------------|--------------------------|----------------------------------------|------------------------|---------------|--------------------------|-------------------|----------------------|
| Sense Byte O                  | Command<br>Reject                                                    | Intervention<br>Required | Bus-Out<br>Check                       | Equipment<br>Check     | Data<br>Check |                          | Position<br>Check |                      |
| IOBFL 1                       | 00 No Chain<br>01 Command<br>10 Data Chai<br>11 Command<br>Data Chai | Chaining<br>ning<br>and  | Error<br>Routine<br>in<br>Control      |                        |               | Exceptional<br>Condition | Unrelated<br>Flag | 0 Start<br>I Restart |
| IOBF L 2                      |                                                                      | Sense<br>Bit             | Purge<br>Flag                          |                        |               |                          |                   |                      |
| IOBFL 3                       |                                                                      | IOB<br>Entry<br>Flag     | Read<br>Channel<br>Data Check<br>Count | Bus-Out<br>Error Count |               | Message<br>Type          |                   | Logout<br>Flag       |
| IOB<br>Error Counts<br>Byte 1 |                                                                      | Read Pos<br>Check C      |                                        |                        |               | Read<br>Check            | Data<br>: Count   | L                    |

Figure 86. 2495 Sense Bits, IOB Flags, and IOB Error Counts

ł

à,

a transfer-in-channel to the next user CCW. If the error remains after ten retries, it is considered permanent.

Bit 5: Should Not Occur

When this bit is set, a catastrophic error is assumed.

Bit 6: Position Check (Read Command)

This bit is set when a Read command causes the reading of tape past the stop code, beyond the end of valid data. The stop code was not detected or was ignored by the program. The tape is backspaced one byte and the data is reread. The sequence is repeated up to ten times. If the error remains, it is considered permanent. The UCB extension is used as a work area for constructing a backspace CCW, a residual read CCW, and, for command chaining, a transfer-in-channel to the next user CCW.

#### Bit 6: Position Check (Control)

This bit is set by indicate that a Control Backspace command has caused backspacing to the beginning of the tape. No retries are attempted.

#### Bit 7: Should Not Occur

When this bit is set, a catastrophic error is assumed.

#### **2540 Error Routine**

The IBM 2540 Card Read Punch error routine attempts recovery from channel data checks. Read operations are retried five times; punch operations are retried once, if a bus-out check resulted from the channel data check. The 2540 error routine also examines the error recovery procedure interface block to determine whether it should attempt recovery from channel control checks and interface control checks.

The error analysis sequence is shown in Figure 87. The meanings of sense bits, IOB flags, and IOB error counts are shown in Figure 88. More information can be obtained from the following publications:

- IBM System/360 Component Description and Operating Procedures: IBM 2540 Card Read Punch, GA21-9033
- IBM 2821 Control Unit, GA24-3312

#### Sense Byte 0 Meanings and Actions Taken

Bit 0: Command Reject

The setting of this bit indicates one of the following:

- A Read Backward or a Write command was issued to the reader.
- A Read Backward control other than NOP or a Read Feed and Stacker Select command was issued to a punch without the Punch-Feed-Read feature.
- A Read Backward or Control command was issued to a punch with the Punch-Feed-Read feature.
- An incorrect sequence of instructions was issued.
- An invalid command was received.

The error is considered permanent.

#### Bit 1: Intervention Required

The setting of this bit indicates a not-ready condition due to one of the following:

- Cards are not at each station (not end-of-file for the reader).
- The stacker is full.
- The hopper is empty (not end-of-file for the reader).
- The Stop key was depressed.
- The chipbox is full or has been removed.

| Priority | Status<br>Bit | Sense<br>Byte | Bit | Condition                   |   | cable to:<br>Punch C | ontrol | Pointer | Load |
|----------|---------------|---------------|-----|-----------------------------|---|----------------------|--------|---------|------|
| 1        | 45            |               |     | Channel Control Check       | x | х                    | х      | ERR551  | 1    |
| 1        | 46            |               |     | Interface Control Check     | x | х                    | х      | ERR551  | 1    |
| 2        | 47            |               |     | Chaining Check              | x | Х                    | х      | ERR546  | 1    |
| 3        | 44            |               |     | Channel Data Check          | х |                      |        | ERR524  | 1    |
| 4        | 38            |               |     | Unit Check                  | X | Х                    | х      | ERR525  | 1    |
| 5        |               | 0             | 5   | Should Not Occur            | х | х                    | х      | ERR546  | 1    |
| 5        |               | 0             | 7   | Should Not Occur            | X | Х                    | х      | ERR546  | 1    |
| 6        |               | 0             | 3   | Equipment Check             | х | Х                    |        | ERR528  | 1    |
| 7        |               | 0             | 1   | Intervention Required       | Х | Х                    |        | ERR552  | 2    |
| 8        |               | 0             | 2   | Bus-Out Check               | X | х                    |        | ERR534  | 2    |
| 9        |               | 0             | 4   | Data Check                  | Х |                      |        | ERR536  | 2    |
| 10       |               | 0             | 0   | Command Reject              | x | Х                    | Х      | ERR548  | 2    |
| 11       |               | 0             | 6   | Unusual Command<br>Sequence | х |                      |        | ERR555  | 2    |
| 12       | 42            |               |     | Program Check               | Х | Х                    | х      | ERR543  | 2    |
| 13       | 43            |               |     | Protection Check            | х | Х                    | Х      | ERR543  | 2    |
| 14       | 39            |               |     | Unit Exception              | x |                      |        | ERR543  | 2    |
| 15       | 41            |               |     | Incorrect Length            | Х | х                    |        | ERR 543 | 2    |

• There is a card jam.

A message is given the operator, who must take action. Upon correction of the condition, the interrupted operation is repeated.

#### Bit 2: Bus-Out Check

ž

This bit is set when a parity error has occurred on bus-out on a command or data byte (bus-out is a data transfer from the processing unit to the control unit). When this error is detected, no punching occurs. The operation is retried once and if the error occurs a second time it is considered to be permanent.

#### Bit 3: Equipment Check

This bit is set after one of the following:

- A hole count error
- A buffer parity error
- A translate check
- An address check

The error applies to the card that preceded the one from which data was transmitted; it is considered permanent. If the error occurred during the processing of a Read command, the operation is retried five times. If the error occurred during a QSAM operation, one retry is attempted.

#### Bit 4: Data Check

This bit is set when an invalid card code is detected. The operation is retried five times. On the sixth occurrence, it is denoted as a permanent error.

Bit 5: Should Not Occur

|                                  | Bit O                                                              | Bit 1                    | Bit 2                             | Bit 3                     | Bit 4          | Bit 5                                          | Bit 6                                   | Bit 7                                                     |
|----------------------------------|--------------------------------------------------------------------|--------------------------|-----------------------------------|---------------------------|----------------|------------------------------------------------|-----------------------------------------|-----------------------------------------------------------|
| Sense O                          | Command<br>Reject                                                  | Intervention<br>Required | Bus-Out<br>Check                  | Equipment<br>Check        | Data<br>Check  |                                                | Unusual<br>Command<br>S <b>equen</b> ce |                                                           |
| IOBFL 1                          | 00 No Chair<br>01 Command<br>10 Data Cha<br>11 Command<br>Data Cha | Chaining<br>ining<br>and | Error<br>Routine<br>in<br>Control |                           |                | Exceptional<br>Condition                       |                                         | 0 Start<br>1 Restart                                      |
| IOBFL 2                          |                                                                    |                          |                                   |                           |                |                                                |                                         | QSAM<br>Access<br>Method                                  |
| IOBFL 3                          | Indicator 1                                                        | Entry<br>Flag            | Read<br>Error<br>Count            | Bus-Out<br>Error<br>Count | Punch<br>Relay | Message<br>Type                                | QSAM<br>Count                           | Logout<br>Flag                                            |
| Error Counts<br>IOBECT<br>Byte 2 | Accept<br>Unusual<br>Command<br>Sequence                           |                          |                                   |                           |                | L<br>Check, Channel [<br>k, Equipment Che<br>t |                                         | Channel Con-<br>trol Check,<br>Interface<br>Control Check |

#### Figure 88. 2540 Sense Bits, IOB Flags, and IOB Error Counts

Bit 6: Unusual Command Sequence

This bit is set when there are two consecutive reads without an intervening feed. The error is considered permanent.

Bit 7: Should Not Occur

### 3211 Error Routine

The IBM 3211 Printer error routine attempts recovery from channel data checks only if they occur with bus-out checks. A channel data check occurring alone is not considered an error.

The 3211 error routine also attempts recovery from channel control checks and interface control checks.

In addition to handling the normal functions of an error recovery procedure, the 3211 ERP compiles data for device dependent OBR records. These records are then recorded on SYS1.LOGREC by the recording module IGE0625F. The following information will be recorded:

- 1. FCB Parity Check—Carriage Control Address Register (CCAR) and the FCBID in the UCB
- 2. PLB Parity Check—Diagnostic Check Read Data and the first 10 positions of the PLB
- 3. UCS Parity Check—Contents of UCS buffer and the UCSID in the UCB

See OS/VS SYS1.LOGREC Error Recording Logic for more information about the SYS1.LOGREC data set recording.

The error recovery procedure for the 3211 Printer is shown in Figure 89. The meanings of sense bits, IOB flags and IOB error counts are shown in Figure 90.

| Priority | Status<br>Bit | Sense<br>Byte |   | Condition               | Pointer |
|----------|---------------|---------------|---|-------------------------|---------|
| 1        | 45            |               |   | Channel Control Check   | ERR031  |
| 1        | 46            |               |   | Interface Control Check | ERR031  |
| 2        | 47            |               |   | Chaining Check          | ERR070  |
| 3        | 38            |               |   | Unit Check              | ERR040  |
| 4        |               | 1             | 5 | Command Suppress        | ERR050A |
| 5        |               | 0             | 3 | Equipment Check         | ERR051  |
| 6        |               | 0             | 2 | Bus-Out Check           | ERR052  |
| 7        |               | 0             | 4 | Data Check              | ERR055E |
| 8        |               | 0             | 5 | Buffer Parity Check     | ERR053  |
| 9        |               | 0             | 0 | Command Reject          | ERR071  |
| 10       |               | 0             | 6 | Load Check              | ERR070  |
| 11       |               | 0             | 1 | Intervention Required   | ERR055  |
| 12       |               | 0             | 7 | Channel 9               | ERR064A |
| 13       | 44            |               |   | Channel Data Check      | ERR061  |
| 14       | 42            |               |   | Program Check           | ERR062  |
| 15       | 43            |               |   | Protection Check        | ERR062  |
| 16 .     | 41            |               |   | Incorrect Length        | ERR063  |
| 17       | 39            |               |   | Unit Exception          | ERR064  |

More information can be obtained from the following publication: IBM 3211 Printer and 3811 Control Unit Component Description, GA24-5343.

|              |                                                         |                               |                                       |                              |                              | [                         |                           |                          |
|--------------|---------------------------------------------------------|-------------------------------|---------------------------------------|------------------------------|------------------------------|---------------------------|---------------------------|--------------------------|
|              | Bit O                                                   | Bit 1                         | Bit 2                                 | Bit 3                        | Bit 4                        | Bit 5                     | Bit 6                     | Bit 7                    |
| Sense Byte O | Command<br>Reject                                       | Intervention<br>Required      | Bus-Out<br>Check                      | Equipment<br>Check           | Data<br>Check                | Buffer<br>Parity<br>Error | Load Check                | Channel 9                |
| Sense Byte 1 | Command<br>Retry                                        | Print<br>Check                | Print<br>Quality                      | Line<br>Position             | Forms<br>Check               | Command<br>Suppress       | Mechanical<br>Motion      |                          |
| Sense Byte 2 | Carriage<br>Fail to<br>Move                             | Carriage<br>Sequence<br>Check | Carriage<br>Stop<br>Check             | Platen<br>Fail to<br>Advance | Platen<br>Fail to<br>Retract | Forms<br>Jam              | Ribbon<br>Motion          | Train<br>Overl∞ad        |
| Sense Byte 3 | UC SB<br>Parity                                         | PLB<br>Parity                 | FCB<br>Parity                         | Coil<br>Protect              | Hammer<br>Fire<br>Check      | Field<br>Engineering      | UCSAR<br>Sync<br>Check    | Sep Sync<br>Check        |
| IOBFL1       | 00 - No Cha<br>01 - Comman<br>10 - Data Ch<br>11 - Both | d Chaining                    | Error<br>Routine<br>in<br>Control     |                              |                              | Exceptional<br>Condition  |                           | 0 – Start<br>1 – Restart |
| IOBFL3       | MCS<br>Flag                                             | Entry<br>Flag                 | Command<br>Suppress<br>Error<br>Count | Bus-Out<br>Error<br>Count    | Buffer<br>Flag               | Message<br>Type           | TPER<br>Flag              | Logout<br>Flag           |
| IOBECT       | FCB<br>Count                                            |                               |                                       |                              | FCB<br>Count                 | UCS<br>Count              | Channel<br>Error<br>Count |                          |
| IOBECT+1     |                                                         | ~                             |                                       |                              |                              | MCS<br>Count              | MCS<br>Count              | MCS<br>Count             |

Figure 90. 3211 Sense Bits, IOB Flags, and IOB Error Counts

2

**(** .

#### Sense Byte 0 Meanings and Actions Taken

#### Bit 0: Command Reject

This bit is set during Initial Selection when a command other than those defined for the printer is given. The error is considered permanent.

Bit 1: Intervention Required

This bit indicates a not-ready condition due to one of the following:

- Platen failure
- Ribbon motion or ribbon skew
- Jammed or torn forms
- Carriage Stop-Release Off
- Interlock condition

An 'Intervention Required' message is issued for the operator; when the condition is corrected the last operation is repeated. If this occurs with channel 9 (bit 7) the message is given to the operator, but the error is handled as a channel 9 condition. The operator has the option of forcing a permanent error by pressing the Cancel button on the 3211.

1

Bit 2: Bus-Out Check

This results when the control unit receives a data byte or a command byte with invalid parity. The operation is retried once in a non-multiple console support system and 5 times in an MCS system.

Bit 3: Equipment Check

This bit indicates a malfunction that affects the operation in process. The specific condition will be indicated by a bit in byte 1.

#### Bit 4: Data Check

This bit signifies that there is an incomparable code in the UCSB or in the FCB. An 'Intervention Required' message will be written to the operator and when the condition is corrected the previous operation will be retried. The operator will have the option of causing a permanent error by pressing the Cancel button on the 3211.

#### Bit 5: Buffer Parity Check

This bit indicates invalid parity in the UCSB or FCB. The error is considered permanent.

#### Bit 6: Load Check

This bit is given for a load UCSB or load FCB command when the load was invalid. The error is considered permanent.

Bit 7: A channel 9 code was sensed in the FCB during a carriage motion.

#### Sense Byte 1 Meanings

- Bit 0: Command Retry—This indicates a parity error in the print line buffer. The error is considered permanent. In a system with MCS the error is retried 5 times before it is considered permanent.
- Bit 1: Print Check—Indicates the line in process may contain one or more print errors.
- Bit 2: Print Quality—Indicates a machine failure that could affect print quality.
- Bit 3: Line Position—Indicates that the previous line or next line to be printed may be in the wrong place.

The last three conditions will result in an 'Intervention Required' message to the operator. When the condition is corrected the last operation is repeated. The operator

will have the option to cause a permanent error by pressing the Cancel button on the 3211.

Bit 6: Mechanical Motion—Signifies that the command in process cannot be completed and the results are unpredictable due to hardware failure. The error is considered permanent.

If bit 3 of byte 0 is set and no bits in byte 1 are set, a sync check or train overload exists. These errors are considered permanent.

### 3505 and 3525 Error Routines

The error routine for the IBM 3505 Card Reader and IBM 3525 Card Punch with Read and Punch features attempts recovery from I/O errors that cause an interruption. The condition causing the interruption is indicated in the channel status word (CSW). If the unit check (bit 38) is present in the CSW, a sense command is performed to obtain further information about the error interrupt. The status byte and sense byte 0 provide information and reasons for a unit check detected in the last operation. Sense byte 1 defines the ERP actions required for the unit check.

The error analysis sequence is shown in Figure 91. The meanings of the sense bits, IOB flags, and IOB error counts are shown in Figure 92. More information can be obtained from IBM 3505 Card Read and IBM 3525 Card Punch Subsystem, GA21-9124.

| Priority | Status<br>Bit | Sense<br>Byte |   | Condition               | Applicable to:<br>Read Punch Printer |   |   | Control | Pointer |
|----------|---------------|---------------|---|-------------------------|--------------------------------------|---|---|---------|---------|
| 1        | 45            |               |   | Channel Control Check   | x                                    | x | x | x       | ERR001  |
| 2        | 46            |               |   | Interface Control Check | x                                    | х | х | х       | ERR011  |
| 3        | 44            |               |   | Channel Data Check      |                                      | х | x | х       | ERR012  |
| 4        | 32            |               |   | Should Not Occur        | х                                    | х | х | х       | EXIT12  |
| 5        | 33            |               |   | Should Not Occur        | х                                    | x | x | х       | EXIT12  |
| 6        | 34            |               |   | Should Not Occur        | х                                    | х | x | х       | EXIT12  |
| 7        | 38            |               |   | Unit Check              | x                                    | x | х | х       | SENSE0  |
| 8        |               | 0             | 5 | Should Not Occur        | х                                    | х | х | x       | EXIT12  |
| 9        |               | 0             | 7 | Permanent Error (Key)   | х                                    | x | х | х       | EXIT22  |
| 10       |               | 0             | 3 | Equipment Check         | x                                    | х | х |         | ERR002  |
| 11       |               | 0             | 6 | Abnormal Format Reset   | х                                    |   |   |         | SENSE1  |
| 12       |               | 0             | 1 | Intervention Required   | х                                    | х | х | х       | ERR003  |
| 13       |               | 0             | 2 | Bus-Out Check           | x                                    | х | х | x       | SENSE1  |
| 14       |               | 0             | 4 | Data Check              | Х                                    |   |   |         | SENSE1  |
| 15       |               | 0             | 0 | Command Reject          | X                                    | х | х | х       | SENSE1  |
| 16       | 47            |               |   | Chaining Check          | X                                    |   |   |         | EXIT12  |
| 17       | 42            |               |   | Program Check           | x                                    | х | х |         | ERR004  |
| 18       | 43            |               |   | Protection Check        | Х                                    | х | х | х       | ERR004  |
| 19       | 39            |               |   | Unit Exception          | Х                                    |   |   |         | ERR004  |
| 20       | 41            |               |   | Incorrect Length        | х                                    | x |   |         | ERR004  |

Sense Byte 0 Meanings and Actions Taken

#### Bit 0: Command Reject

This bit is set on for invalid commands such as read backwards and for commands for as the set of t

#### Bit 1: Intervention Required

This bit is set on for a hopper misfeed, hopper jam, cornering station misfeed, Read station check, transport jam, and normal user occurrences such as hopper empty, joggler open, stacker full, stop key depressed, or covers open.

Recovery from this error is possible as defined by recovery indicators on the machine.

CENTER A DECEMBER OF THE CONTRACT OF THE REPORT OF THE ADDRESS OF

| aa poliger<br>Saas                       |                                                                    |                                 |                                   | in the c                      | 10 × 10 ×      | in the second                                                                                                                                                                                                                                          |                             |                                                           |
|------------------------------------------|--------------------------------------------------------------------|---------------------------------|-----------------------------------|-------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------------------------------|
|                                          |                                                                    | Bir 1                           | Bit 2                             | Bit '3                        | Bit 4          | Bii 5                                                                                                                                                                                                                                                  | Bit 6                       | Bit 7                                                     |
| Sense Byte O                             | Reject                                                             | Intervention<br>Required        | Bus-Out<br>Check                  | Equipment<br>Check            | Data<br>TCheck | ی ایر ایر کرد.<br>(۱۹۹۵ میلی ۱۹۹۵ میلی<br>(۱۹۹۹ میلی ۱۹۹۵ میلی<br>(۱۹۹۵ میلی ۱۹۹۵ میلی | Abnormal<br>Format<br>Reset | Permanent<br>Error<br>Key                                 |
| i an | 00 No Chair<br>01 Command<br>10 Data Cha<br>11 Command<br>Data Cha | ing<br>Chaining<br>ining<br>and | Error<br>Routine<br>in<br>Control | 6 - 55 - 77<br>               | ·····          | Exceptional<br>Condition                                                                                                                                                                                                                               |                             | 0 Start<br>1 Restart                                      |
| IOBFL 2                                  |                                                                    |                                 |                                   |                               |                |                                                                                                                                                                                                                                                        |                             | QSAM<br>Access<br>Method                                  |
| IOBFL 3                                  | Retry<br>Flag<br>Command                                           | Entry<br>Flag                   | Channel<br>Control<br>Check       | Interface<br>Control<br>Check | Punch<br>Retry | Message<br>Type                                                                                                                                                                                                                                        | ی میں<br>Market<br>Count    | Logout<br>Flag                                            |
| Error Counts<br>IOBECT<br>Byte 2         |                                                                    |                                 | ·<br>·                            |                               |                | · .                                                                                                                                                                                                                                                    |                             | Channel Con-<br>trol Check,<br>Interface<br>Control Check |

#### Figure 92. 3505//3525 Sense Bits, IOB Flags, and IOB Error Counts

|                               | ,            | provide the second s | *          |
|-------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------|------------|
| Bit 2: Bus-Out Check          |              | 1 N - 1 C - 16-800-1                                                                                            |            |
| This results in a bad parity  | on bus-      | out during initial selection. The error is o                                                                    | considered |
| a permanent condition only    |              |                                                                                                                 |            |
| Bit 3: Equipment Check        | , <b>′</b> • |                                                                                                                 |            |
| This bit is turned on for err | ors due      | to data compare check, emitter check, a                                                                         | nd CU      |
| internal parity check detect  | ed betw      | een IS and CE.                                                                                                  |            |
| A recovery can be made as     | defined      | by the recovery indicators on the mach                                                                          | ine.       |
|                               |              | IC card code is found when Data Mode                                                                            | 1 is read. |
| Recovery can be made as d     | efined b     | by recovery indicators on the machine.                                                                          |            |
| Bit 5: Not Used               | 3            | and the second second                                                                                           | •          |
| Bit 6: Abnormal Format Rese   | +            | Charles and the                                                                                                 |            |
| Bit 0. Abnormal Pormat Rese   | ι            | 1542 1 357 Car                                                                                                  |            |
| (XM)(44)                      | t alphad     | ST HOMBERD AND A STATE                                                                                          | ۰.<br>بر ۲ |
|                               |              |                                                                                                                 |            |

#### Bit 7: Permanent Error (Error Bypass Key)

This results when the operator presses the Error Bypass Key rather than performing recovery assistance. The error is considered a permanent condition. Sense Byte 1 Meanings

#### Bit 0: Permanent Error

This bit directs the ERP to post a permanent error condition and proceed with appropriate disposition of the condition. It is set only with sense byte 0, bit 0 or bit 1.

#### Bit 1: Automatic Retry

This results in retrying the failing CCW once. If successful, normal program execution continues. If unsuccessful, a permanent error condition is posted and the procedure is continued with the appropriate disposition of the condition. This occurs only with sense byte 0, bits 2 and 3.

#### Bit 2: Motion Malfunction

This bit is turned on with Intervention Required when the cause is other than a normal user occurrence. It is set only with sense byte 0, bit 1. This bit is not required by the ERP to effect recovery but is included to facilitate the measurement of SSIs.

#### Bit 3: Retry After Intervention Required Complete

After a normal not-ready to ready Device End, the failing CCW is reissued. This occurs only with sense byte 0, bits 1, 3, 4, and 6.

#### Bits 4-7: Not Used.

#### Sense Byte 2 Meanings

This sense byte is for diagnostic purposes only. It defines the first error in the 3505 or 3525 and also serves as a pointer to the appropriate maintenance documentation.

#### Sense Byte 3 Meanings

This sense byte is for diagnostic purposes only. It serves to further resolve a limited group of errors.

#### **Channel Checks**

Recovery from channel errors (channel control check, interface control check, and channel data check) is as follows:

If Selective Reset or Interface Disconnect was given between Initial Selection and Channel End, reissue the command to the 3505 or 3525.

# GLOSSARY OF TERMS, ACRONYMS, AND ABBREVIATIONS

The following list of terms are defined as they are used in this publication. Acronyms and abbreviations with their meanings are also listed in alphabetical sequence with the list of terms. If you do not find the term you are looking for, refer to the index or to the *IBM Data Processing Glossary*, GC20-1699.

**access method:** Any of the data management techniques available to the user for transferring data between real storage and an input/output device.

**address translation:** The process of changing the address of a data item or an instruction from its virtual address to its real storage address. See also dynamic address translation.

**allocate:** To assign a resource for use in performing a specific task.

alternate path retry (APR): A facility that allows an I/O operation that has developed an error to be retried on another channel assigned to the device performing the I/O operation. APR also provides the capability to establish other paths to an online or offline device.

**alternate track:** For direct-access devices, a track designated to contain data in place of a defective primary track.

**APR:** Alternate path retry.

**ASCII:** American National Standard Code for Information Interchange.

**asynchronous:** Without regular time relationship; unexpected or unpredictable with respect to the execution of a program's instructions.

**automatic priority group:** A group of tasks at a single priority level that are dispatched according to a special algorithm that attempts to provide optimum use of CPU and I/O resources by these tasks. See also dynamic dispatching.

**available page queue:** A queue of the pages whose real storage is currently available for allocation to any task.

**AVT:** Appendage vector table.

**BEBLK:** Beginning-end block.

**BSAM:** Basic sequential access method.

**BTAM:** Basic teleprocessing access method.

**buffer:** An area of storage that is temporarily reserved for use in performing an input/output operation, into which data is read or from which data is written. Synonymous with I/O area.

**burst mode:** A means of transferring data to or from a particular 1/O device on either the multiplexer or selector channel. All channel controls are monopolized for the duration of data transfer.

byte mode: See multiplex mode.

CAW: Channel address word.

CC: Condition code; chain command.

CCC: Channel control check.

**CCH:** Channel check handler.

**CCW:** Channel command word.

**CCW translation:** See channel program translation.

CD: Chain data.

CE: Channel end.

CEB: Channel error block.

**channel:** A hardware device that connects the CPU and real storage with the I/O control units.

**channel address word (CAW):** A word in real storage that specifies the location in real storage where a channel program begins.

**channel check handler (CCH):** A feature that, when a channel error occurs, records information about the error and issues a message to the operator.

**channel command:** An instruction that directs a channel, control unit, or device to perform an operation or set of operations.

**channel command word (CCW):** A doubleword at the location in real storage specified by the channel address word. One or more CCWs make up the channel program that directs channel operations.

**channel program:** One or more channel command words that control a specific sequence of channel operations. Execution of the specific sequence is initiated by a single start I/O instruction.

**channel program translation:** In a channel program, replacement by software of virtual addresses with real addresses.

**channel status word (CSW):** A doubleword in real storage that provides information about the termination of I/O operations.

**control block:** A storage area used by an operating system to hold control information.

**control program:** A program that is designed to schedule and supervise the performance of data processing work by a computing system.

**CPU:** Central processing unit.

**CRC:** Cyclic redundancy check.

CSW: Channel status word.

CUA: Channel and unit address.

**CVT:** Communications vector table.

**DASD:** Direct-access storage device.

DAT: Dynamic address translation.

**data set:** The major unit of data storage and retrieval in an operating system, consisting of a collection of data in one of several prescribed arrangements and described by control information to which the system has access.

**DAVV:** Direct-access volume verification.

DCB: Data control block.

**DDR:** Dynamic device reconfiguration.

DEB: Data extent block.

#### **DEC:** Decimal.

**demand paging:** Transfer of a page from external page storage to real storage at the time it is needed for execution.

**device number:** A part of an external page address that refers to a particular paging device; together with a group number and a slot number, it identifies the location of a page in external page storage.

**DIDOCS:** Device independent display operator's console support.

**direct access:** Retrieval or storage of data by a reference to its location on a volume, rather than relative to the previously retrieved or stored data.

**direct-access storage device (DASD):** A device in which the access time is effectively independent of the location of the data.

**disabled page fault:** A page fault that occurs when I/O and external interruptions are disallowed by the CPU.

**disk storage:** Storage on direct-access devices that record data magnetically on rotating disks.

**drum storage:** A direct-access storage device which records data magnetically on a rotating cylinder.

**DSCB:** Data set control.block.

DSS: Dynamic support system.

**dynamic address translation (DAT):** The change of a virtual storage address to a real storage address during execution of an instruction. See also address translation.

**dynamic dispatching:** A facility that assigns priorities to tasks within an automatic priority group to provide optimum use of CPU and 1/O resources.

dynamic support system (DSS): An interactive debugging facility that allows authorized maintenance personnel to monitor and analyze events and alter data.

**EBCDIC:** Extended binary-coded-decimal interchange code.

ECB: Event control block and the second seco

**ECF:** Error correction function.

enabled page fault: A page fault that occurs when I/O and external interruptions are allowed by the CPU.

| EOD: End-of-day.       | ÷., | 1. 11 |              | , |    |
|------------------------|-----|-------|--------------|---|----|
| EOF: End-of-file.      |     |       | 3            |   | đ, |
| EOV: End-of-volume.    |     |       | e transfra i |   |    |
| ERG: Error record gap. |     | 1     | ti çe        |   |    |

**ERP:** Error recovery procedure.

ERPIB: Error recovery procedure interface block.

ESV: Error statistics by volume.

EVA: Error volume analysis.

EXCP: Execute channel program.

**EXCPVR:** Execute channel program virtual equal real. An I/O request issued from a virtual region whose channel program contains real addresses. This channel program does not require translation by IOS.

external page address: An address that identifies the

location of a page in a page data set. The address consists of a relative device number, a relative group number, and a relative slot number.

**external page storage:** The portion of auxiliary storage that is used to contain pages.

**external page table (XPT):** An extension of a page table that identifies the location on external page storage of each page in the page table.

**external storage:** Data storage other than real storage; for example, storage on magnetic tape or direct-access devices.

à

FIFO: First-in, first-out.

fixed: Not capable of being paged out.

fixed page: A page in real storage that is not to be paged out.

FLIH: First level interuption handler.

frame: See page frame.

frame number: The part of a real storage address needed to refer to a frame. See also page number and segment number.

frame table: See page frame table.

frame table entry (FTE): An entry in the page frame table that describes how a frame is being used.

FREELIST: A chain of unassigned RQEs.

FTE: Frame table entry.

group: See slot group.

**group number:** A part of an external page address that refers to a slot group; together with a device number and a slot number, it identifies the location of a page in external page storage.

GTF: Generalized trace facility.

HA: Home address.

HEX: Hexadecimal.

HIO: Halt input/output.

**HIPO:** Hierarchy input-process-output.

**hold page queue:** A queue to which pages in real storage are initially assigned through operations such as page-in or page reclamation. See also available page queue.

IAL: Indirect address list.

**ICC:** Interface control check.

**ILC:** Instruction length code.

**input/output:** A general term for the equipment used to communicate with a computer, commonly called I/O. The data involved in such communication.

**input-output error:** A general term used to denote any of the conditions that would preclude normal (or successful) completion of an I/O operation. Input-output errors are generally a result of malfunctioning input/output devices.

**intercepted I/O request:** A request for I/O activity on which processing has been suspended so that an I/O error routine could be used to process an error that occurred after channel end for the last activity on the needed device.

**invalid page:** A page that cannot be directly addressed by the dynamic address translation feature of the central processing unit.

I/O: Input/output.

**IOB:** Input/output block.

**IOS:** Input/output supervisor.

**IPL:** Initial program loading.

**IRB:** Interruption request block.

job pack area (JPA): See region job pack area.

JPA: Job pack area.

LCH: Logical channel.

**link pack area (LPA):** An area of virtual storage containing selected reenterable and serially reusable routines that are loaded at IPL time and can be used concurrently by all tasks in the system.

**link pack area directory:** A directory that contains an entry for each entry point in link pack area modules.

**link pack area library:** A partitioned data set that contains the modules specified to be in the link pack area.

**link pack area queue:** A queue that contains a contents directory entry for each link pack area module currently in use, for each module in the link pack update area, and for each module in the fixed link pack area.

**link pack update area:** An area in virtual storage containing modules that are additions to replacements for link pack area modules for the current IPL.

**local system queue area (LSQA):** One or more segments associated with each virtual storage region that contains job-related system control blocks.

**lock/unlock facility:** A supervisor facility that controls the execution of instruction strings when a disabled page fault occurs.

**logical channel:** The set of all physical channels by which a device may be reached.

LPA: Link pack area.

LSQA: Local system queue area.

MCH: Machine check handler.

NIP: Nucleus initialization program.

**nondynamic area:** The area of virtual storage occupied by the resident portion of the control program (the nucleus and the link pack area). Contrast with dynamic area.

**nonpageable dynamic area:** An area of virtual storage whose virtual addresses are identical to real addresses; it is used for programs or parts of programs that are not to be paged during execution.

**nonpageable region:** A subdivision of the nonpageable dynamic area that is allocated to a job step or system task that is not to be paged during execution. In a nonpageable region, each virtual address is identical to its real address.

NRZI: Non-return-to-zero-inverse encoding.

**OBR:** Outboard recorder; outboard recording.

**OLTEP:** Online Test Executive Program.

**page:** A fixed-length block of instructions, data, or both, that can be transferred between real storage and external page storage.

page fault: A program interruption that occurs when a page

marked "not in real storage" is referred to by an active page. Synonymous with page translation exception.

**page fixing:** Marking a page as nonpageable so that it remains in real storage.

page frame: A block of real storage that can contain a page.

**page frame table:** A table that contains an entry for each frame. Each frame table entry describes how the frame is being used.

**page-in:** The process of transferring a page from external page storage to real storage.

**page-out:** The process of transferring a page from real storage to external page storage.

**paging:** The process of transferring pages between real storage and external page storage.

**paging device:** A direct-access storage device on which a page data set (and possibly other data sets) are stored.

**paging supervisor:** A part of the supervisor that allocates and releases real storage space (page frames) for pages, and initiated page-in and page-out operations.

**PCI:** Program controlled interruption.

**PCRS:** Program check recovery subroutine.

PCU: Primary control unit.

**permanent error:** An I/O error that either cannot be corrected or remains uncorrected after error recovery procedures have been used.

PGFX: Page fix.

PL/I: Programming Language I.

**primary paging device:** An auxiliary storage device that is used in preference to secondary paging devices for paging operations. Portions of a primary paging device can be used for purposes other than paging operations.

**processing program:** Any program capable of operating in the problem program mode. This included IBM-distributed language processors, application programs, service and utility programs, and user-written programs.

**PSA:** Prefixed storage area.

**PSW:** Program status word.

**QSAM:** Queued sequential access method.

**quick cell:** A reserved space in the system queue area or a local system queue area that can be used to reduce that time required to allocate space for a control block.

**real storage:** The storage from which the central processing unit can directly obtain instructions and data, and to which it can directly return results.

**reference bit:** A bit associated with a page in real storage; the reference bit is turned "ON" by hardware whenever the associated page in real storage is referred to (read or stored into). There is a reference bit in each of two storage key areas associated with each page frame.

region: See virtual storage region.

**region job pack area (JPA):** An area in a virtual storage region that contains modules that are not in the link pack area but are needed for the execution of jobs.

relocate hardware: See dynamic address translation.

#### **RQE:** Request queue element.

**R0:** Record zero.

SAVECCW: Pointer to an address of the user's channel program.

SCU: Secondary control unit.

SER: System environment recording.

**secondary paging device:** An auxiliary storage device that is not used for paging operations until the available space on primary paging devices falls below a specified minimum. Portions of a secondary paging device can be used for purposes other than paging operations.

**segment:** A continuous 64K area of virtual storage, which is allocated to a job or system task.

**segment table entry (STE):** An entry in the segment table that indicates the length, location, and availability of a corresponding page table.

#### segment translation exception: A program

interruption that occurs when a virtual address cannot be translated by the hardware because the invalid bit in the segment table entry for that address is set. See also page translation exception, translation specification exception.

SIO: Start input/output.

SIRB: System interruption request block.

SLI: Suppress length indication.

**slot:** A continuous area on a paging device in which a page can be stored.

**slot group:** A set of slots on one or more tracks within a cylinder on a paging device.

**slot number:** A part of an external page address that refers to a slot; together with a device number and a group number, it identifies the location of a page in external page storage.

SMF: System management facilities.

SQA: System queue area.

**STE:** System table entry.

**supervisor call (SVC):** An instruction which causes an SVC interruption in the hardware to give control to a control program routine (called an SVC routine) for some specific action, such as reassigning parts of real storage or retrieving data from an I/O device.

**supervisor lock:** An indicator used to inhibit entry to disabled code while a disabled page fault is being resolved.

SVC: Supervisor call.

TCB: Task control block.

TCH: Test channel.

TIC: Transfer in channel.

TIE: Track in error.

**TIOT:** Task input/output table.

**TP:** Teleprocessing.

**track address:** In direct-access devices, an address made up of a cylinder number and a read-write head number. Every track of a direct-access device has a unique track address.

#### translation specification exception: A

program interruption that occurs when a page table entry, segment table entry, or the control register pointing to the segment table contains information in an invalid format. See also page translation exception, segment translation exception.

UCS: Universal character set.

UR: Unit record.

virtual address: An address that refers to virtual storage and must, therefore, be translated into a real storage address when it is used.

virtual equals real (V=R) storage: An area of virtual storage that has the same range of addresses as real storage and is used for a program or part of a program that cannot be paged during execution.

3

virtual storage: Addressable space that appears to the user as real storage, from which instructions and data are mapped into real storage locations. The size of virtual storage is limited by the addressing scheme of the computing system and by the amount of auxiliary storage available, rather than by the actual number of real storage locations.

virtual storage region: A subdivision of the dynamic area that is allocated (in segment-size blocks) to a job step or a system task.

VS: Virtual storage.

WTO: Write-to-operator.

**XPT:** External page table.

### INDEX

Indexes to program logic manuals are consolidated in the publication *OS/VS Master Index of Logic*, GY28-0603. For additional information about any subject listed below, refer to other publications listed for the same subject in the master index.

# Α

ABEND routine 17, 45 abnormal end appendage described 47 in method of operation diagram 23, 26, 39 ABTERM interface routine 63 alternate path retry in module directory 61 in routine directory 63 selective retry 105 vary path 105 VARY PATH command 105 alternate path table data area layout 67 in data area directory 54 AMDPRDMP 94 appendage vector table (AVT) 68 appendages abnormal end described 47 in method of operation diagram 26 channel end 47 end-of-extent 47 page fix in method of operation diagram 18,28 in routine directory 63 user's 28 program controlled interrupt described 51 in method of operation diagram 32 start I/O described 51 in method of operation diagram 24 user's 1 vector table 68 attention routine interface described 47 in functional organization chart 49 in module directory 61 in routine directory 63 AVT (appendage vector table) 68

# В

BEBLK (beginning-end block) CCW translation header BEBLK 71-73 data area layout 68-69 header BEBLK 71-73 in data area directory 54 translation header BEBLK 71-73 beginning-end block (see BEBLK)

# С

CAW (channel address word) data area layout 69-70 defined in glossary 157 in data area directory 54 in module directory 58 initialization 24 CCH (channel check handler) defined in glossary 157 described 47 in functional organization chart 49 in method of organization diagram 32 in module directory 61,62 in routine directory 63 interface 63 CCW (channel command word) chains 3.4 initialized 41 when built 22 data area layout 70 defined in glossary 157 described 47 in data area directory 54 translation 22,30,32 translation header BEBLK data area layout 71-73 in data area directory 56 in method of operation diagram 30 translator in functional organization chart 48 in method of operation diagram 25,30-35 in routine directory 63 channel availability (see also alternate path) alternate path retry, described 105 alternate path table 67 channel search routine, described 47 test channel routine described 51 in routine directory 64 channel check handler (see CCH) channel command word (see CCW) channel end appendage described 47 in method of operation diagram 34,45 channel error block table data area layout 73-74 in data area directory 54 channel program defined in glossary 157 translation defined in glossary 157 in method of operation diagram 24 channel restart routine defined 47 in functional organization chart 49 in method of operation diagram 32,36-37 in module directory 61 in routine directory 63 channel search routines defined 47 in functional organization chart 49

channel search routines (Continued) in method of operation diagram 37-39 in module directory 61 in routine directory 63 channel status word (see CSW) channel table data area layout 75-76 in data area directory 54 in module directory 58 channels defined in glossary 157 logical 8-9 multiplexor 8-9 physical 8 relationship to I/O activity, diagram 8 switching 8-9 completion codes system 91-92 table 92 concept of logical channels 8-9 control blocks communication between 66 used by I/O supervisor 2,12,66 control flow 6 control program 3-6 CSW (channel status word) data area layout 74-75 defined in glossary 157 in data area directory 54 in module directory 58 in routine directory 63 translate routine 47,63

# D

DASD (direct-access storage device) shared (see also I/O devices, direct-access devices) option 113 explanation of 113 PURGE routine 113 starting I/O 113 data areas 65-89 directory 53-56 data control block (DCB) in data area directory 54 data extent block (see DEB) DAVV (direct-access volume verification) 107 attention routine 63 DCB in data area directory 54 DDR (dynamic device reconfiguration) 109 appendage support interface routine 63 DEB (data extent block) in data area directory 54 in data area relationships 66 in method of operation diagram 16 validity check routine in method of operation diagram 16 in routine directory 63 dequeue subroutine described 47 in method of operation diagram 27 in module directory 62 in routine directory 63 descriptions of routines 47,51-52 device characteristics table 102

device-dependent error routines for 1052 119-121 1053 133-135 1275 126-129 1287 121-123 1288 121-123 1403 124-126 1419 126-129 1443 124-126 2250 131-133 2260 133-135 2305 135-140 2314 135-140 2319 135-140 2400 140-145 2495 146-148 2501 129-131 2520 129-131 2540 148-150 3211 150-153 3330 135-140 3333 135-140 3400 140-145 3505 153-155 3525 153-155 device entry table 80 device statistics table data area layout 76-79 in data area directory 54 table entries 78-79 device table data area layout 79-80 in data area directory 55 in module directory 58 table entry 80 devices, I/O DEVTYPE routine 102-103 direct-access devices supported 118-119 error routines 118-155 magnetic-tape devices supported 119 **DEVTYPE** 102-103 macro 102-103 parameter 102-103 routine described 102-103 in module directory 59 diagnostics aids 91-95 direct-access devices defined in glossary 158 in device table 118-119 shared 113 start I/O routines described 51 in method of operation diagram 22-23 volume verification 107 direct-access extent test routine 63 trap routine 63 volume verification 107 dynamic device reconfiguration (see DDR) dynamic support system (DSS) defined in glossary 158

### Е

1

ECB 2 in data area directory 55 end-of-extent appendage 47 enqueue routine described 47 in functional organization chart 48 subroutine described 47 in functional organization chart 50 in module directory 62 in routine directory 63 error analysis sequence for 1052 120 1053 134 1275 127 1287 122 1288 122 1403 124 1419 127 1443 124 2250 132 2260 134 2305 138 2314 137 2319 137 2400 141 2495 147 2501 130 2520 130 2540 149 3211 151 3330 138 3333 138 3400 141 3505 153 3525 153 error EXCP routine 8 in functional organization chart 50 in method of operation diagram 13,17 in module directory 59 in routine directory 63 error interpreter routine in module directory 58 error recovery procedure module names for 1052 58,59 1053 60 1275 60 1287 60 1288 60 1403 58,59 1419 60 1443 58,59 2250 60 **2260 6**0 2305 58,59 2314 58 2319 58 2400 59,60,61 2495 60 2501 58,59 2520 58,59

2540 58,60 3210 58,59 3211 59.60 3215 58,59 3330 58,59 3333 58,59 3400 59,60,61 error recovery routine described 51 in functional organization chart 50 in routine directory 63 error retry for 1052 120 1053 135 1275 128 1287 123 1288 123 1403 125 1419 128 1443 125 2250 133 2260 135 2305 139 2314 139 2319 139 2400 142 2495 147 2501 131 2520 131 2540 150 3211 151 3330 139 3333 139 3400 142 3505 154 3525 154 error routine interface description 51 in functional organization chart 49 in method of operation diagram 42-43 in module directory 61 in routine directory 63 error routines description of 117-155 for devices 1052 119-121 1053 133-135 1275 126-129 1287 121-123 1288 121-123 1403 124-126 1419 126-129 1443 124-126 2250 131-133 2260 133-135 2305 135-139 2314 135-139 2319 135-139 2400 140-145 2495 146-147 2501 129-131 2520 129-131 2540 148-150 3211 150-153 3330 135-139 3333 135-139

error routines (Continued) 3400 140-145 3505 153-155 3525 153-155 event control block (ECB) 2 in data area directory 55 EXCP macro 1-3 used by I/O supervisor 2 used by user 1 routine for I/O supervisor 1-8 supervisor described 3-5 I/O supervisor interaction 1-8 in functional organization chart 48 in method of operation diagram 14-15 in module directory 59 in routine directory 63 validity check routine described 51 in module directory 62 EXCPVR macro 3 extended SVC routine described 104 in module directory 61 extent test routine in method of operation diagram 23 in routine directory 63

### F

first-in, first-out (FIFO) enqueue routine 63 first level interruption handler (FLIH) 3-6 FLIH (first level interruption handler) 3-6 functional organization error EXCP supervisor 6,50 EXCP supervisor 48 I/O interruption supervisor 49 functions of the I/O supervisor 7

### G

generalized trace facility (GTF) 94-95 general register assignments 91 get request element routine described 51 in functional organization chart 48 in method of operation diagram 17,23 in module directory 62 in routine directory 63 graphics device entry in device table 79 GTF (generalized trace facility) 94-95

# H

header BEBLK 71 in data area directory 56 when initialized 30 HIO routine 63

# 

IAL (indirect address list) data area layout 80-81 in data area directory 55 in method of operation diagram 31 IECINT patch area 94 IECIOLTS 115-116 addressing scheme 116 bit settings 116 indirect address list (IAL) 80-81 inline fix and unfix subroutine 63 input/output block (see IOB) intercepted I/O request, defined in glossary 158 interruption supervisor (see I/O interruption supervisor) I/O appendages abnormal end 47 channel end 47 end-of-extent 47 program controlled interrupt 51 start I/O 51 vector table 68 I/O devices direct-access devices 118-119 failure of and actions taken 117-155 magnetic tape devices 119 starting I/O 20-21 starting I/O 22-23 volume verification 107 I/O error routines for 1052 119-121 1053 133-135 1275 126-129 1287 121-123 1288 121-123 1403 124-126 1419 126-129 1443 124-126 2250 131-133 2260 133-135 2305 135-140 2314 135-140 2319 135-140 2400 140-145 2495 146-148 2501 129-131 2520 129-131 2540 148-150 3211 150-153 3330 135-140 3333 135-140 3400 140-145 3505 153-155 3525 153-155 I/O FLIH (first level interruption handler) 3-6 I/O interruption supervisor described 4-6 I/O supervisor interaction 6-8 in functional organization chart 49 in method of operation diagram 13,32-35

in module directory 58 in routine directory 63 SIO instruction 6 I/O new PSW 61 I/O old PSW 61 I/O operations restarting 6,12 scheduling 4,7 starting 4,6-7,12 terminating 6-7,12 I/O purge routine 97 (see also SVC, SVC 16) in module directory 60 I/O requesters, characteristics of 4 I/O supervisor control blocks provided by user 1 definition of routines and subroutines 47-52 error EXCP supervisor 44-45,50 EXCP supervisor 14,15,48 EXCP validity check 51 functions of 6-8 I/O interrupt volume verification 107 I/O purge routine 97 OLTEP synchronizing module 115-116 system completion codes 91-92 user interaction with I/O supervisor 1-3 IOB (input/output block) chain 100 in data area directory 55 in data area relationships 66 in method of operation diagram 25 when completion code entered 42 when updated 24,34 IOB, error counts for 1052 120 1053 135 1275 128 1287 123 1288 123 1403 125 1419 128 1443 125 2250 133 2260 135 2305 139 2314 139 2319 139 2400 142 2495 147 2501 131 2520 131 2540 150 3211 151 3330 139 3333 139 3400 142 3505 154 3525 154 IOB flags for 1052 120 1053 135 1275 128 1287 123 1288 123 1403 125

ï

1419 128

# L

LCH (logical channel word) data area layout 81-82 in data area directory 55 in data area relationships 66 local GETMAIN subroutine 63 logical channel concept of 8-9 defined in glossary 159 in method of operation diagram 36-39 physical channel relationship 8-9 queues 82 table 81 in data area directory 55 in module directory 58,61 word (see LCH) logical channel word (see LCH)

# Μ

machine check handler routine 63 interface routine 63 magnetic tape devices 119 for start I/O 20-21 in device table 78-79 volume statistics table 88-89 MCH routine 49,62 messages write-to-operator 117-118 method of operation 11-45 CCW translator 30-31 channel restart routine 36-37 channel search routine 38-39 error EXCP routine 44-45 error routine interface 42-43 EXCP supervisor 14-15 get request element routine 18-19 I/O interruption supervisor 32-35 I/O supervisor 12-13 page fix routine 28-29 post start I/O routine 26-27

method of operation (Continued) sense subroutine 40-41 SIO subroutine 24-25 start I/O routine for DASD 22-23 start I/O routine for tape 20-21 validity check routine 16-17 miscellaneous data recording routine 50 module directory 57-62 multiplexor channel 8-9

# Ν

noise bit 140-141 NRZI (non-return-to-zero-inverse) encoding defined in glossary 159 when used 140

### 0

object module names 58-62 objectives of I/O supervisor 6-8 OLTEP (online test executive program) 115-116 online test executive program (OLTEP) 115-116 operator response to error 117-118 write-to-operator messages 117-118 ordered seek enqueue routine 63 outboard recording routine 50

### Ρ

page exception handler routine 63 page fault, when set invalid 32 page fix appendage in method of operation diagram 18,28 in routine directory 63 interface routine 63 user's 28 page fix list (PGFX) data area layout 83 in data area directory 55 page fix routine described 51 in functional organization chart 48 in method of operation diagram 28-29 in routine directory 63 when executed 19 page supervisor 3 in method of operation diagram 19,29 patch area 94 PCI (program controlled interrupt) modify parameter list 32,84 PCRS (program check recovery subroutine) described 111-112 in routine directory 63 permanent errors defined in glossary 159 of devices 1052 119-121 1053 133-135 1275 126-129 1287 121-123 1288 121-123

1403 124-126 1419 126-129 1443 124-126 2250 131-133 2260 133-135 2305 135-140 2314 135-140 2319 135-140 2400 140-145 2495 146-148 2501 129-131 2520 129-131 2540 148-150 3211 150-153 3330 135-140 3333 135-140 3400 140-145 3505 153-155 3525 153-155 PGFX (page fix list) data area layout 83 in data area directory 55 when initialized 28 physical channel relationships to logical channel 8-9 table 54.76 post routine interface described 51 in functional organization chart 49 in module directory 62 in routine directory 63 post start I/O routine described 51 in functional organization chart 49 in method of operation diagram 15 in module directory 62 in routine directory 63 priority enqueue routine 63 problem determination area 93 program check recovery subroutine (PCRS) 63,111 program controlled interrupt appendage 51 program controlled interruption (PCI) modify parameter list 84 program organization error EXCP supervisor 50 **EXCP** supervisor 48 I/O interruption supervisor 49 program status word (see PSW) PSW (program status word) data area layout 84-85 I/O new PSW 55,61 I/O old PSW 55,61 in data area directory 55 SVC old PSW 55,61 purge routine described 96-102 in method of operation diagram 42 in module directory 58,59 IOB chain 100 parameter list 97 quiesce option 101 removing elements from logical channel queues 97 supervisor's asynchronous exit queues 99 supervisor's request block queues 99 RESTORE macro 100,102

ĩ

use of IOB 100 use of IRB 99 use of SIRB 99 virtual I/O request 102 purging a virtual request 102

# Q

r

queuing scheduling I/O 6 terminating I/O 6 queuing methods FIFO 63 ordered seek 63 priority 63 quiesce complete subroutine described 51 in functional organization chart 49 in module directory 61 in routine directory 64 quiesce I/O parameter list 99 quiesce option 101

# R

register assignments 91 request queue element (see RQE) RESTORE macro 100,102 restore routine described 102 in module directory 59,62 routine descriptions 47-52 routine directory 63-64 RQE (request queue element) building 14 data area layout 86-87 in data area directory 56 in data area relationships 66 in module directory 58,62 initialization of 18,86 locating 18 scheduling I/O 86 table 87 when dequeued 26

# S

2314 139 2319 139 2400 142 2495 147 2501 131 2520 131 2540 150 3211 151 3330 139 3333 139 3400 142 3505 154 3525 154 sense subroutine described 51 in functional organization chart 49 in method of operation diagram 40-41 in module directory 61 in routine directory 64 SER (system environment recording) routine interface described 51 in functional organization chart 49 in module directory 62 in routine directory 64 message routine in module directory 61 service interface routine 64 shared DASD option 113 SIO (see start I/O) statistics table in module directory 58 statistics update routine 50 start I/O appendage described 51 in method of operation diagram 24 **CAW 24** CCW 20-23 channel restart routine 63 command 24 described 51 extend parameter list 88 for direct-access devices 64 described 51 in method of operation diagram 22,23,38 in module directory 62 in routine directory 64 for tape devices described 51 in method of operation diagram 20-21 in module directory 62 in routine directory 64 for TP devices 64 for unit record devices described 51 in module directory 62 in routine directory 64 for 2305 64 post start I/O routine 26-27 register usage 91 RESTORE macro 100,102 restore routine (see also SVC, SVC 17) described 102 routine in functional organization chart 48 in method of operation diagram 14

1

subroutine described 51 in functional organization chart 48 in method of operation diagram 15,20-23 in module directory 62 in routine directory 64 volume verification routine 107 when issued 24 supporting SVC routines 97-104 SVC FLIH (first level interruption handler) 3-6 SVC interruption 3,97 SVC old PSW 62 SVC routines 97-104 SVC 0 3,12 SVC 15 6,8,12 SVC 16 97 SVC 17 102 SVC 24 102-103 SVC 33 103 SVC 91 103 SVC 92 104 SVC 109 104 SVC 114 3,12 synchronizing module, OLTEP 115-116 system completion codes 91-92 system environment recording (see SER) supervisor (see also I/O supervisor and page supervisor) I/O 3

#### page 3



task control block (see TCB) TCB (task control block) in data area directory 56 **EXCP** 104 in module directory 59 test channel routine described 51 in functional organization chart 48 in method of operation diagram 26 in module directory 62 in routine directory 64 time sharing option (see TSO) trace facility, generalized 94-95 translation header BEBLK data area layout 71-73 in data area directory 56 in method of operation diagram 30 translator CCW 30-32,63 trap routines described 51 in method of operation diagram 30-31 in module directory 61 in routine directory 64 TSO (time sharing option) TCB EXCP 104 TCB EXCP interface routine 64

### U

UCB (unit control block) in data area directory 56 in data area relationships 66 in module directory 58 lookup table 56 when updated 24 unfix/FREEMAIN routine in method of operation diagram 35 in routine directory 64 unit control block (see UCB) unit record start I/O 64 trap routine 64 user interaction with I/O supervisor 1-3

# ۷

validating input data 14,16-17 validity check routine described 52 in functional organization chart 48 in method of operation diagram 16-17,45 in routine directory 64 validity check subroutine described 52 in module directory 62 validation of data in method of operation diagram 16-17 virtual I/O request, purging 102 virtual request 102 VOLSTAT routine described 103 in module directory 59 volume statistics table data area layout 88-89 in data area directory 56 volume verification for direct access 107 in module directory 60 VS subsystems 3

# W

write-to-operator error messages 117-118 WTO (write-to-operator) routine described 117-118 in module directory 58,60,61



SY26-3823-1

1

J



International Business Machines Corporation Data Processing Division 1133 Westchester Avenue, White Plains, New York 10604 (U.S.A. only)

IBM World Trade Corporation 821 United Nations Plaza, New York, New York 10017 (International) OS/VS2 I/O Supervisor Logic SY26-3823-1

1

Reader's Comment Form

Your comments about this publication will help us to improve it for you. Comment in the space below, giving specific page and paragraph references whenever possible. All comments become the property of IBM.

Please do not use this form to ask technical questions about IBM systems and programs or to request copies of publications. Rather, direct such questions or requests to your local IBM representative.

If you would like a reply, please provide your name, job title, and business address (including ZIP code).

### Fold and Staple

First Class Permit Number 2078 San Jose, California

Business Reply Mail No postage necessary if mailed in the U.S.A.

Postage will be paid by:

IBM Corporation Programming Center – Publishing Department D58 Monterey and Cottle Roads San Jose, California 95193

.....

Fold and Staple



International Business Machines Corporation Data Processing Division 1133 Westchester Avenue, White Plains, New York 10604 (U.S.A. only)

IBM World Trade Corporation 821 United Nations Plaza, New York, New York 10017 (International) OS/VS2 I/O Supervisor Logic (File No. S370-30) Printed in U.S.A. SY26-3823-1

ĭ

OS/VS2 I/O Supervisor Logic SY26-3823-1 Reader's Comment Form

Your comments about this publication will help us to improve it for you. Comment in the space below, giving specific page and paragraph references whenever possible. All comments become the property of IBM.

Please do not use this form to ask technical questions about IBM systems and programs or to request copies of publications. Rather, direct such questions or requests to your local IBM representative.

If you would like a reply, please provide your name, job title, and business address (including ZIP code).

#### Fold and Staple

First Class Permit Number 2078 San Jose, California

### Business Reply Mail

No postage necessary if mailed in the U.S.A.

Postage will be paid by:

IBM Corporation Programming Center – Publishing Department D58 Monterey and Cottle Roads San Jose, California 95193

Fold and Staple

IBM

International Business Machines Corporation Data Processing Division 1133 Westchester Avenue, White Plains, New York 10604 (U.S.A. only)

IBM World Trade Corporation 821 United Nations Plaza, New York, New York 10017 (International) OS/VS2 I/O Supervisor Logic (File No. S370-30) Printed in U.S.A. SY26-3823-1

......