GA22-7072-0 File No. S370-01

## Systems

# IBM System/370 Extended Facility



## Preface

This publication describes the IBM System/370 extended facility or feature, which is available on all processor complexes and some models of System/370.

This manual is intended for system programmers and IBM Field Engineering personnel. The reader should be familiar with the general machine functions of System/370, as described in the *IBM System/370 Principles of Operation*, GA22-7000, and with the MVS system.

The following reading is considered corequisite:

IBM Virtual Machine Facility/370 System Extensions General Information Manual, GC20-1827

MVS/System Extensions: Debugging Handbook (Volume 2), SD23-0002

- OS/VS2 Data Areas, SYB8-0606. (This document is on microfiche)
- OS/VS2 MVS/System Extensions General Information Manual, GC28-0872

OS/VS2 System Logic Library, Volumes 1-7, SBOF-8210

#### First Edition (January 1978)

Changes are continually made to the specifications herein; before using this publication in connection with operation of IBM equipment, refer to the *IBM* System/370 Bibliography, GC20-0001, for editions that are applicable and current.

Publications are not stocked at the address given below; requests for IBM publications should be made to your IBM representative or to the IBM branch office serving your locality.

A form for reader's comments is provided at the back of this publication. If the form has been removed, comments may be addressed to IBM Corporation, Product Publications, Department B98, PO Box 390, Poughkeepsie, N.Y., U.S.A., 12602. Comments become the property of IBM.

© Copyright International Business Machines Corporation 1978

## Contents

|  |  |  |  | - |  |
|--|--|--|--|---|--|

| IBM System/370 Extende       | d F   | acil | ity   |      |       |     |      |    |   |  | 5  |
|------------------------------|-------|------|-------|------|-------|-----|------|----|---|--|----|
| Common-Segment Bit           | ••    |      |       |      |       |     |      |    |   |  | 5  |
| Low-Address Protection .     |       |      |       |      |       |     |      |    | • |  | 5  |
| Attributes of System/370 Ext | tend  | ed-I | Faci  | lity | Ins   | tru | ctic | ns |   |  | 6  |
| Operand Addressing .         |       |      |       |      |       |     |      |    |   |  | 6  |
| MAPL Control Block .         |       | •    |       |      |       |     |      |    |   |  | 6  |
| Lock-Interface Table .       |       |      |       |      |       |     |      |    |   |  | б  |
| Program Interruptions .      |       |      |       |      |       |     |      |    |   |  | 7  |
| PER Events                   |       |      |       |      |       |     |      |    |   |  | 7  |
| Privileged-Operation Exce    | ptio  | ns   |       |      |       |     |      |    |   |  | 7  |
| Instructions                 | •     |      |       |      |       |     |      |    |   |  | 7  |
| INVALIDATE PAGE TAI          | BLE   | EN   | TR    | Y    |       |     |      |    |   |  | 7  |
| TEST PROTECTION .            |       |      |       |      | ۰     |     |      |    |   |  | 8  |
| OBTAIN LOCAL LOCK            |       |      |       |      |       |     |      |    |   |  | 8  |
| RELEASE LOCAL LOCK           |       |      |       |      |       |     |      |    |   |  | 8  |
| OBTAIN CMS LOCK .            |       |      |       |      |       |     |      |    |   |  | 9  |
| RELEASE CMS LOCK             |       |      |       |      |       |     |      |    |   |  | 9  |
| TRACE INSTRUCTIONS           |       |      |       |      |       |     |      |    |   |  | 9  |
| FIX PAGE                     |       |      |       |      |       |     |      |    |   |  | 10 |
| SVC ASSIST                   |       |      |       |      |       |     |      |    |   |  | 11 |
| Virtual-Machine Extended-Fa  | cilit | уA   | ssist | :    |       |     | •    |    |   |  | 12 |
| Direct Control and System/37 | 70 E  | xte  | nde   | d Fa | acili | ity |      |    |   |  | 12 |
|                              |       |      |       |      |       |     |      |    |   |  |    |
| Index                        | •     |      | •     | •    | •     | •   | •    | •  | • |  | 13 |

.

## IBM System/370 Extended Facility

The IBM System/370 extended facility or feature is available on all processor complexes and some models of System/370. Developed to support the internal structure of the MVS control program, this facility enhances the capabilities and performance of the MVS system when it is used with the MVS/System Extensions program product (Program No. 5740-XE1). It contains:

Common-segment bit Low-address protection INVALIDATE PAGE TABLE ENTRY instruction TEST PROTECTION instruction Four lock-handling instructions Six tracing instructions FIX PAGE instruction SVC ASSIST instruction Virtual-machine extended-facility assist

The common-segment-bit function permits a single segment-table entry in the translation-lookaside buffer (TLB) to serve for a segment shared by all segment tables. Thus, separate TLB entries are not required for each segment table sharing that common segment. Use of the common-segment-bit function increases the effective size of the TLB and thus improves CPU performance.

Low-address protection can be used to prevent system programs, which are executed with a PSW key of zero, from modifying the contents of the first 512 bytes of main storage. Since these locations contain information critical to proper operation of the entire system, the use of low-address protection can prevent system failures caused by inadvertent modifications in this area by the CPU program.

Use of the instruction INVALIDATE PAGE TABLE ENTRY permits the invalidation of a single page-table entry in the translation-lookaside buffers of all configured CPUs. It is therefore not necessary, when a page is stolen, to purge the entire TLB in order to eliminate a single entry. For configurations containing more than one CPU sharing main storage, it is also not necessary to use programmed inter-CPU communication via the SIGNAL PROCESSOR instruction when a page-table entry is invalidated. Use of INVALIDATE PAGE TABLE ENTRY in a demand-paging environment improves CPU performance.

Supervisor services test for potential protection violations before performing services on behalf of application programs. TEST PROTECTION can be used to perform such tests without causing program interruptions for protection exceptions. When TEST PROTECTION is used, it is not necessary to establish and release functional recovery routines before and after such testing. The elimination of the overhead associated with such recovery routines, when testing for user protection errors, improves CPU performance. Twelve instructions are provided that depend on the particular conventions, fields, and control-block formats of the MVS system. Use of these 12 instructions in the MVS/ System Extensions program product improves CPU performance.

The virtual-machine extended-facility assist permits the 12 MVS-dependent instructions to be executed directly by a virtual machine without program interruptions to invoke routines for their simulation. Use of the virtual-machine extended-facility assist for these instructions thus eliminates the CPU performance degradation that would otherwise arise from the use of simulation techniques. This assist is used by the VM/370 System Extensions program product (Program No. 5748-XE1).

#### COMMON-SEGMENT BIT

Bit 30 of the segment-table entry is defined as the common-segment bit. When this bit is a one, it indicates that the associated segment is common to all segment tables. The entry in the translation-lookaside buffer (TLB) formed from a segment-table entry with the common bit on may be used for the segment index and segment size for which it was fetched, regardless of the value of the segment-table origin in control register 1.

When bit 30 of the segment-table entry is zero, the rules for the use of the TLB entry are those that apply when the System/370 extended facility is not installed.

## LOW-ADDRESS PROTECTION

Low-address protection, when active, prohibits instructions from storing into locations 0 through 511. The range test is applied before any dynamic address translation or prefixing is performed. Low-address protection is active whenever bit 3 of control register 0 is one.

Low-address protection is not applied to accesses made by the CPU or channel for interruptions, updating the interval timer, logout, storing the CSW by an I/O instruction or interruption, storing channel identification during execution of STORE CHANNEL ID (STIDC), and the initial-program-loading and store-status functions, nor is it applied to data stores by a channel during I/O data transfer.

If storing is attempted to a location protected by low-address protection, the protected area is unchanged, and a program interruption for protection occurs, with suppression or termination of the operation.

## ATTRIBUTES OF SYSTEM/370 EXTENDED-FACILITY INSTRUCTIONS

The System/370 extended facility provides 14 instructions. The two instructions INVALIDATE PAGE TABLE ENTRY and TEST PROTECTION are not dependent on specific conventions and control-block formats of the MVS control program. The other 12 instructions depend on the conventions and control-block formats of the MVS control program. Although these 12 MVS-dependent instructions will operate in any environment, they may not be useful when used outside MVS. These 12 MVS-dependent instructions include four lock-handling instructions, six trace instructions, the FIX PAGE instruction, and the SVC ASSIST instruction.

The INVALIDATE PAGE TABLE ENTRY instruction uses the RRE format:

| Op Code |    | R, | R,    |  |
|---------|----|----|-------|--|
| 0       | 16 | 24 | 27 31 |  |

This format permits two general registers to be specified, as for RR-format instructions. However, the RRE format uses a 16-bit operation code.

The 12 MVS-dependent instructions and TEST PRO-TECTION use the SSE instruction format of the form;



This format provides for addressing a first and second operand in a manner identical to that used for SS instructions. It differs from the SS format in that the operation code consists of 16 bits.

#### **Operand Addressing**

In addition to the two operands explicitly designated by the  $D_1(B_1)$  and  $D_2(B_2)$  fields, many System/370 extendedfacility instructions use operands at specific, fixed mainstorage locations or pointed to by general registers. Furthermore, many operands fetched from main storage are in turn used for addressing still other operands.

In EC mode, the translation-mode bit of the PSW controls address translation for all main-storage operand references of all System/370 extended-facility instructions, except for INVALIDATE PAGE TABLE ENTRY.

#### **MAPL Control Block**

The two System/370 extended-facility instructions FIX PAGE and SVC ASSIST use a special 16-word parameter list (MAPL) as an implicit operand. The first eight words are used by SVC ASSIST, and the remainder of the MAPL is used for FIX PAGE. This parameter list must be aligned on a doubleword boundary, and the last three bytes of the word at location A4 hex contain the address of the MAPL.

The MAPL layout is:

| Off     | set     |          |                                                   |
|---------|---------|----------|---------------------------------------------------|
| Decimal | (Hex)   | Name     | Content                                           |
| 0-3     | (0-3)   | MPLSVTA  | SVC-table address                                 |
| 4-7     | (4-7)   | MPLSVRBP | Prefix length in bytes of an SVRB                 |
| 8-11    | (8-B)   | MPLESVC1 | Entry address for SVCs of type 1                  |
| 12-15   | (C-F)   | MPLRSVC1 | Exit address for SVCs of type 1                   |
| 16-19   | (10-13) | MPLESVC2 | Entry address for SVCs of types 2, 3, and 4       |
| 20-23   | (14-17) | MPLRSVC2 | Exit address for SVCs of types 2, 3, and 4        |
| 24-27   | (18-1B) | MPLESVC6 | Entry address for SVCs of type 6                  |
| 28-31   | (1C-1F) | MPLRSVC6 | Exit address for SVCs of type 6                   |
| 32-33   | (20-21) | MPLLCSA  | 16 times lowest virtual common page-frame number  |
| 34-35   | (22-23) | MPLLPRIV | 16 times lowest virtual private page-frame number |
| 36-39   | (24-27) | MPLPF TP | Page-frame-table origin                           |
| 40-41   | (28-29) | -        | Reserved                                          |
| 42-43   | (2A-2B) | MPLMAXFX | Maximum number of pages to be fixed               |
| 44-47   | (2C-2F) | MPLCNTRS | Address of PVT + X'720'                           |
| 48-51   | (30-33) | -        | Reserved                                          |
| 52-55   | (34-37) | MPLPFAL  | Entry address to move a page to a preferred frame |
| 56-59   | (38-3B) | MPLPFCM  | Entry address if MPLMAXFX is reached              |
| 60-63   | (3C-3F) | -        | Reserved                                          |

## Lock-Interface Table

A .....

The four lock-handling instructions may access the lockinterface-table prefix. This table is located by an address contained in the word in main storage following the second-operand word. The prefix of the lock-interface table consists of four words, arranged as follows:

| 0)]3    | et.   |            |
|---------|-------|------------|
| Decimal | (Hex) | Field Name |
| -16     | (-10) | LITOLOC    |
| -12     | ( –C) | LITRLOC    |
| -8      | ( -8) | LITOCMS    |
| 4       | ( -4) | LITRCMS    |
|         |       |            |

## PROGRAM INTERRUPTIONS

#### PER Events

The System/370 extended-facility instructions are subject to PER interruption controls, except that branch events are not recognized when these instructions cause branching.

#### **Privileged-Operation Exceptions**

All System/370 extended-facility instructions are privileged.

#### INSTRUCTIONS

The instructions described in this section are listed in the table "Instruction Summary" together with their operation codes and the program-interruption conditions that can be recognized when they are executed.

In the format shown in the instruction description, the op code is given in hex, which is signified by enclosing its value in single quotation marks ('XXXX').

| Name                                                                                                                                                                                                                                                                                                                                                | Characteristics                                                       | Code |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|------|
| INVALIDATE PAGE TABLE ENTRY                                                                                                                                                                                                                                                                                                                         | RREXFMA                                                               | 8221 |
| TEST PROTECTION                                                                                                                                                                                                                                                                                                                                     | SSEXFMA                                                               | E501 |
| OBTAIN LOCAL LOCK                                                                                                                                                                                                                                                                                                                                   | SSEXFMA <sup>2</sup> SPR ST                                           | E504 |
| RELEASE LOCAL LOCK                                                                                                                                                                                                                                                                                                                                  | SSE XFM A SPR ST                                                      | E505 |
| OBTAIN CMS LOCK                                                                                                                                                                                                                                                                                                                                     | SSE XFM A SPR ST                                                      | E506 |
| RELEASE CMS LOCK                                                                                                                                                                                                                                                                                                                                    | SSE XFMA SPR ST                                                       | E507 |
| TRACE SVC INTERRUPTION                                                                                                                                                                                                                                                                                                                              | SSE XFMA SP ST                                                        | E508 |
| TRACE PROGRAM INTERRUPTION                                                                                                                                                                                                                                                                                                                          | SSE XFMA SP ST                                                        | E509 |
| TRACE INITIAL SRB DISPATCH                                                                                                                                                                                                                                                                                                                          | SSE XFMA SP ST                                                        | E50A |
| TRACE I/O INTERRUPTION                                                                                                                                                                                                                                                                                                                              | SSE XFMA SP ST                                                        | E50B |
| TRACE TASK DISPATCH                                                                                                                                                                                                                                                                                                                                 | SSE XFMA SPST                                                         | E50C |
| TRACE SVC RETURN                                                                                                                                                                                                                                                                                                                                    | SSE XFMA SPST                                                         | E50D |
| FIX PAGE                                                                                                                                                                                                                                                                                                                                            | SSE XFMA SPRST                                                        | E502 |
| SVC ASSIST                                                                                                                                                                                                                                                                                                                                          | SSE XFMA SPRST                                                        | E503 |
| Legend:<br>A Access exceptions<br>A Addressing, protection, and tran<br>A Addressing and translation-speci<br>M Privileged-operation exception<br>R PER general-register-altration e<br>RRE RRE instruction format<br>SP Specification exception<br>SSE SSE instruction format<br>ST PER storage-altration event<br>XF System/320 extended facility | Islation-specification exceptions<br>fication exceptions only<br>vent |      |

Instruction Summary

## INVALIDATE PAGE TABLE ENTRY

| IPTE | R <sub>1</sub> ,R | 2  |    | 1     | [RRE] |
|------|-------------------|----|----|-------|-------|
| 8    | 221'              |    | R, | R,    |       |
| 0    |                   | 16 | 24 | 28 31 |       |

The register designated by the  $R_1$  field contains a segment-table entry, of which only the page-table origin is used. The register designated by the  $R_2$  field contains a virtual address, of which only the page index is used. A program interruption for translation specification occurs if the format of bits 8-12 of control register 0 is invalid. Otherwise, the real address of a page-table entry is computed using the two operands. This entry is accessed, using the PSW key, to fetch a page address and to store a one in the page-invalid bit.

The translation-lookaside buffers (TLBs) of all configured CPUs are purged of copies of page-table entries for which all of the following conditions hold:

- 1. At the time the copy was formed, the value of bits 8-12 of control register 0 in the CPU containing the TLB copy was the same as the current value of bits 8-12 of control register 0 of the CPU executing IPTE.
- 2. The page-table origin and page-index values used to compute the address of the page-table entry from which the TLB copy was made are the same as the page-table origin and page-index values of the operands of the IPTE instruction being executed.
- 3. The page address in the TLB copy is the same as that in the page-table entry invalidated by the IPTE instruction being executed.

Each receiving CPU purges its TLB between units of operation after having completed all stores that use TLB entries to be purged.

Condition Code: The code is unchanged.

#### Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Protection Addressing Translation specification

#### **TEST PROTECTION**



Using bits 24-27 of the second-operand address as a test key, the first-operand location is tested for protectionexception conditions, including low-address protection if it is active. The condition code is set to reflect the test result.

## Condition Code:

- 0 Both fetching and storing are permitted with the test key
- 1 Fetching but not storing is permitted with the test key
- 2 Neither fetching nor storing is permitted with the test key
- 3 A page- or segment-translation exception was encountered in attempting to translate the first-operand address.

### Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Addressing Translation specification

## **OBTAIN LOCAL LOCK**

#### General Form



Form Used in MVS/System Extensions Program Product



If the local lock in the ASCB addressed by the first-operand word is not held, it is replaced, using an interlocked update with the value from PSALCPUA; the local-lock bit of the highest lock-held-indicator word fetched from the secondoperand location is set to one; and zeros are placed in general register 13. Otherwise, the updated instruction address, prefixed by eight zeros, is placed in general register 12; the contents of LITOLOC are placed in general register 13; and bits 8-31 of the contents of LITOLOC are placed in the instructionaddress portion of the PSW.

Serialization occurs before fetching the local lock and, if the lock is obtained, again after the lock is updated.

Condition Code: The code remains unchanged.

#### Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

#### RELEASE LOCAL LOCK

General Form



Form Used in MVS/System Extensions Program Product



If the highest lock-held-indicator word fetched from the second-operand location shows that the executing CPU holds the local lock and does not hold a CMS lock, and if the word after the local lock word in the ASCB addressed by the first-operand word is zero, then the doubleword containing the lock is set to zero using interlocked update. Also, the local-lock bit of the highest lock-held-indicator word is set to zero, and zeros are placed in general register 13.

Otherwise, the updated instruction address, prefixed by eight zeros, is placed in general register 12; the contents of LITRLOC are loaded into general register 13; and bits 8-31 of the contents of LITRLOC are placed in the instruction address portion of the PSW.

Condition Code: The code remains unchanged.

#### **Program Exceptions:**

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

#### OBTAIN CMS LOCK

#### General Form



Form Used in MVS/System Extensions Program Product

| 'E506' | ·0' | '224' | .0, | '2F8' |   |
|--------|-----|-------|-----|-------|---|
| 0      | 16  | 20    | 32  | 36 47 | ŗ |

If the highest lock-held-indicator word fetched from the second-operand location shows that the executing CPU holds the local lock and does not hold a CMS lock, and if the CMS lock addressed by bits 8-31 of general register 11 is not held, the lock is replaced, using an interlocked update, with the first-operand word. Also, the highest lock-held indicator is set to show that a CMS lock is held, and zeros are placed in general register 13.

Otherwise, the updated instruction address, prefixed by eight zeros, is placed in general register 12; the contents of LITOCMS are loaded into general register 13; and bits 8-31 of the contents of LITOCMS are placed in the instructionaddress portion of the PSW.

Serialization occurs before fetching the lock and, if the lock is obtained, again after the lock is updated.

Condition Code: The code remains unchanged.

#### Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

## **RELEASE CMS LOCK**

General Form



Form Used in MVS/System Extensions Program Product

|   | 'E507' | .0. |    | 224 <sup>.</sup> | ۰ <b>۵</b> , | '2F | 8" |
|---|--------|-----|----|------------------|--------------|-----|----|
| 1 | 0      | 16  | 20 |                  | 32           | 36  | 47 |

If the contents of the CMS lockword addressed by bits 8-31 of general register 11 equal the contents of the firstoperand word and if the word after the CMS lockword is zero, then the doubleword containing the lockword is set to zero using interlocked update. Also, the highest lock-heldindicator word fetched from the second-operand location is set to show that no CMS lock is held, and zeros are placed in general register 13.

Otherwise, the updated instruction address, prefixed by eight zeros, is placed in general register 12; the contents of LITRCMS are loaded into general register 13; and bits 8-31 of the contents of LITRCMS are placed in the instruction address portion of the PSW.

Condition Code: The code remains unchanged.

#### Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

## TRACE INSTRUCTIONS

General Form



Specific Forms Used in MVS/System Extensions Program Product

## TRACE SVC INTERRUPTION

| 'E508' | 8, | D, | °0° | '02 <b>0</b> ' |    |
|--------|----|----|-----|----------------|----|
|        | 16 | 20 | 32  | 36             | 47 |

#### TRACE PROGRAM INTERRUPTION

| 'E509' | 8, | D, | ʻ0ʻ | '028' |    |
|--------|----|----|-----|-------|----|
| 0      | 16 | 20 | 32  | 36    | 47 |

#### TRACE INITIAL SRB DISPATCH

| 'E50A' | 8, | D, | <b>.</b> 0, | '420° | 7  |
|--------|----|----|-------------|-------|----|
| )      | 16 | 20 | 32          | 36    | 47 |

#### TRACE I/O INTERRUPTION

| 'E508' | В, | D, | .Q. | '038' |   |
|--------|----|----|-----|-------|---|
| )      | 16 | 20 | 32  | 36 4  | 7 |

## TRACE TASK DISPATCH

| 'E50C' | в, | D, | в, | D, |    |
|--------|----|----|----|----|----|
| 0      | 16 | 20 | 32 | 36 | 47 |

9





All six TRACE instructions use implicit logical addresses less than 4,095. TRACE INITIAL SRB DISPATCH uses the contents of bit positions 8-31 of general register 0 as the address of an SRB to access fields in that SRB. TRACE TASK DISPATCH uses the contents of bit positions 8-31 of general register 3 as the address of an RB plus 16 (10 hex) to access fields in that RB. The first operand of all TRACE instructions is a halfword field. The second operand of all TRACE instructions is the PSW to be traced.

The word at location 84 (54 hex) contains the address of the trace-table-entry (TTE) header. The trace-table-entry header has doubleword alignment and consists of three words. Each TRACE instruction performs an interlocked update of the first word of the header. The updated value contains the address of a trace-table entry (TTE). Each TRACE instruction stores 32 bytes in a TTE, which must be on a 32-byte boundary. Condition code 0 is set, and the updated word in the TTE header is the old value plus 32 (20 hex) unless that value is logically greater than or equal to the value of the third word in the TTE header. In the latter case, condition code 1 is set, and the updated TTE header word contains the value from the second word of the TTE header. The accompanying TTE diagram contains a row for each field of a 32-byte TTE and a column for each TRACE instruction. For a particular row and column, the entry shows from which register, operand, PSA field, or other source a value is copied into the TTE at that offset (row) for that TRACE instruction (column).

## Condition Code:

- 0 TTE placed at next sequential location.
- 1 TTE placed at table start because table wrapped.
- 2 –
- 3 –

## Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Access

Specification

## FIX PAGE

General Form



Form Used in MVS/System Extensions Program Product



| Decimal (Hex)<br>Byte Offsets<br>widhin Trace-<br>Table Entry |                 | Instruction                             |                                  |                          |                              |                           |                                          |  |  |
|---------------------------------------------------------------|-----------------|-----------------------------------------|----------------------------------|--------------------------|------------------------------|---------------------------|------------------------------------------|--|--|
|                                                               |                 | TRACE<br>SVC<br>INTERRUPTION            | TRACE<br>PROGRAM<br>INTERRUPTION | TRACE                    | TRACE<br>I/O<br>INTERRUPTION | TRACE<br>TASK<br>DISPATCH | TRACE<br>SVC<br>RETURN                   |  |  |
| Bytes                                                         | 0-1             | 2nd Operand<br>Bytes 0-1                | 2nd Operand<br>Bytes 0-1         | 2nd Operand<br>Bytes 0-1 | 2nd Operand<br>Bytes 0-1     | 2nd Operand<br>Bytes 0-1  | 2nd Operand<br>Bytes 0-1                 |  |  |
| Buta 2                                                        | Bits 0-3        | 27                                      | .3.                              | '4'                      | '5'                          | .7'                       | .8,                                      |  |  |
| Bits 4-7                                                      |                 | .0.                                     | 0, .0,                           |                          | FLCIOAA                      | .0.                       | <del>.</del> ۵                           |  |  |
| Byt                                                           | • 3             | FLCSVCN<br>Byte 1                       | FLCPICOD<br>Byte 1               | .0.                      | Bits 12-23                   | RBINTCOD<br>Byte 1        | 2nd Operand<br>Byte Minus 17             |  |  |
| Byte                                                          | 4-7             | 2nd Operand<br>Bytes 4-7                | 2nd Operand<br>Bytes 4-7         | 2nd Operand<br>Bytes 4-7 | 2nd Operand<br>Bytes 4-7     | 2nd Operand<br>Bytes 4-7  | 2nd Operand<br>Bytes 4-7                 |  |  |
| Bytes                                                         | 8-9             | General                                 | General                          | .0.                      |                              | General                   | General                                  |  |  |
| Bytes 10-11 (A-B)                                             |                 | Register 15                             | Register 15                      | SRBPASID                 |                              | Register 15               | Register 15                              |  |  |
| Bytes 12-                                                     | 15 (C-F)        | General<br>Register 0                   | FLCTEA                           | General<br>Register 0    | FLCCSW                       | General<br>Register 0     | General<br>Register 0                    |  |  |
| Bytes 1<br>(1                                                 | 6-19<br>0-13)   | General<br>Register 1                   | General<br>Register 1            | General<br>Register 1    | .0.                          | General<br>Register 1     | General<br>Register 1                    |  |  |
| Byte                                                          | 8its 0-1        | FLCSILC<br>Bits 5-6                     | FLCPIILC<br>Bits 5-6             | .04                      | 2nd Operand<br>Byte 2        | RBINLNTH<br>Bits 5-6      | 2nd Operand<br>Byte Minus 19<br>Bits 5-6 |  |  |
| (14)                                                          | Bits 2-7        | 2nd Operand<br>Bits 18-23               | 2nd Operand<br>Bits 18-23        |                          |                              | 2nd Operand<br>Bits 18-23 | 2nd Operand<br>Bits 18-23                |  |  |
| Byte 21 (15)                                                  |                 | Second byte of the two-byte CPU address |                                  |                          |                              |                           |                                          |  |  |
| Bytes (                                                       | 22-23<br>16-17) | 1st Operand<br>Bytes 0-1                | 1st Operand<br>Bytes 0-1         | 1st Operand<br>Bytes 0-1 | 1st Operand<br>Bytes 0-1     | 1st Operand<br>Bytes 0-1  | 1st Operand<br>Bytes 0-1                 |  |  |
| Bytes 24-2                                                    | 7 (18-18)       | PSATOLD                                 | PSATOLD                          | SRBPTCB                  | PSATOLD                      | PSATOLD                   | PSATOLD                                  |  |  |
| Bytes 28-3                                                    | 1 (1C-1F)       | 8                                       | ytes 3-6 of doublewo             | rd that would be         | tored by the instruction     | on STORE CLOCK            | ζ.                                       |  |  |

Trace-Table-Entry Diagram

The contents of general register 1 are used as the virtual address of a location in a page to be fixed. The contents of general register 2 are used as the virtual address of a location in the last of a group of consecutive pages to be fixed. The contents of general register 0 are used as the real address of a location in the page frame containing the page to be fixed. The second operand is a word containing the address of the MAPL control block.

If the page to be fixed is a nucleus page, an LSQA/SQA page, or a V=R page, then the fix count for the page frame containing that page is not examined or incremented. If the fix count for the page frame containing the page to be fixed is zero, if the page frame is not in the preferred area, and if the page is either a private page of a second-level preferred user or a common page, then execution is completed by loading the next instruction address prefixed by eight zeros in general register 14; by loading the contents of MPLPFAL in general register 15; and by placing the contents of bits 8-31 of the contents of the MPLPFAL in the instructionaddress part of the PSW. Otherwise, the fix count for the page frame containing the page to be fixed is incremented by one. If the incremented fix count is one, then the total system count of fixed frames is incremented by one, and either the number of private pages fixed in the current address space or the number of frames allocated to fixed common pages is incremented by one, depending on whether the page being fixed is a private or common page, respectively.

If the virtual address of the page fixed is less than the virtual address of the last page of the consecutive group of pages to be fixed, then general register 1 is incremented by 4,096, and execution is completed by placing the first-operand address in the instruction-address part of the PSW. Otherwise, the total system count of fixed frames is compared with the maximum fix-count threshold. If the threshold has been reached, instruction address prefixed by eight zeros in general register 14; by loading the contents of MPLPFCM in general register 15; and by placing bits 8-31 of the contents of MPLPFCM in the instruction-address part of the PSW. Otherwise, general register 15 is set to zero, and normal instruction sequencing proceeds with the updated instruction address.

Condition Code: The code remains unchanged.

**Program Exceptions:** 

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

#### SVC ASSIST

General Form

| 'E503' | в, | D, | 8, | D,    |     |
|--------|----|----|----|-------|-----|
|        | 16 | 20 | 32 | 36 47 | ř., |

Form Used in MVS/System Extensions Program Product

| 'E503' | ʻ0ʻ ʻ224' |    | .Ο. | '21C' |
|--------|-----------|----|-----|-------|
| 0      | 16        | 20 | 32  | 36 47 |

The first and second operands are words containing the addresses of the current ASCB and TCB, respectively.

Main-storage locations, which contain the MVS system status for the last SVC interruption, are tested to determine whether SVC-ASSIST action is to be taken. If SVC-ASSIST action is not taken, instruction execution is completed with normal instruction sequencing. No assist action is taken unless the CPU was enabled prior to the last SVC interruption, and a task is currently dispatched that holds no locks and for which SVC screening is not activated.

A type-1 SVC request is assisted only if the request is for an assistable type-1 function, if the only lock needed for the requested SVC function is the local lock, and if an attempt to obtain the local lock is successful.

A type-2, type-3, or type-4 SVC request is assisted only if the request is for an assistable function of type 2, 3, or 4, and if an attempt to dequeue an SVRB from the SVRB pool of the current address space is successful.

A type-6 SVC request is assisted only if the request is for an assistable type-6 function for which no locks are needed.

Assist action consists in copying the information stored at the last SVC interruption into the current request block, saving all 16 general registers, loading the general registers as shown below, and then loading the instruction address portion of the PSW from bit positions 8-31 of general register 9.

- GR No. Contents Loaded on Assist Action
- 3 Address of CVT
- 4 Second operand
- 5 Address of current RB for type 1 or type 6; address of the acquired SVRB for type 2, 3, or 4
- 6 SVC entry-point address
- 7 First operand
- 8 Address of the RB for the program that was being executed at SVC interruption
- 9 Entry address from that MAPL field that is appropriate to the SVC type
- 11 Address of the MBCB part of the SVRB acquired; for type 2, 3, or 4 only
- 12 Address of requested SVCTABLE entry
- 13 Exit address from that MAPL field that is appropriate to the SVC type

Condition Code: The code remains unchanged.

Program Exceptions:

Operation (if System/370 extended feature not installed) Privileged operation Access Specification

## VIRTUAL-MACHINE EXTENDED-FACILITY ASSIST

The virtual-machine extended-facility assist is a part of the System/370 extended facility. This assist improves the performance of virtual machines when they execute any of the 12 MVS-dependent instructions for the System/370 extended facility.

This assist is active when bit positions 1 and 29 of control register 6 contain zero and one, respectively. Bit position 1 of control register 6 serves as the virtual-machine problemstate bit (zero indicates the supervisor state, and one indicates the problem state). The following table summarizes how bit position 15 of the PSW and bit positions 1 and 29 affect the actions that result when an MVSdependent instruction is encountered.

| PSW<br>Bit 15 | CR<br>Bit 1 | CR<br>Bit 29 | Action                             |
|---------------|-------------|--------------|------------------------------------|
| 0             | 0 or 1      | 0 or 1       | Execute per instruction definition |
| 1             | 0 or 1      | 0            | Privileged-operation exception     |
| 1             | 1           | 1            | Privileged-operation exception     |
| 1             | 0           | 1            | Execution assisted                 |
|               |             |              |                                    |

Assist action for the MVS-dependent instructions consists in their being executed exactly as if the PSW had contained a zero in the problem state bit. INVALIDATE PAGE TABLE ENTRY and TEST PROTECTION are not assisted, and all attempts to execute either instruction by virtual machines result in program interruptions for privilegedoperation exceptions.

Note: The virtual-machine extended-facility assist is separate from the virtual-machine assist (VMA). Either facility or both facilities may be active simultaneously. Both assists use bit 1 of control register 6 as the problem-state bit of the virtual machine; hence, these facilities are mutually compatible.

# DIRECT CONTROL AND SYSTEM/370 EXTENDED FACILITY

On CPUs with both the direct-control facility and the System/370 extended facility installed, the first-operand address of READ DIRECT and WRITE DIRECT is a real address. Also, storage-alteration events of the programevent-recording (PER) facility are not recognized when READ DIRECT is executed. This differs from the definition of direct control when the System/370 extended facility is not installed, where the first-operand address of READ DIRECT and WRITE DIRECT is subject to dynamic address translation and the execution of READ DIRECT is subject to PER monitoring for storage alteration. Where more than one page reference is given, the major reference is first.

common-segment bit 5

direct-control facility, effect on when extended facility also installed 12

extended-facility assist, virtual machine 12, 5 extended facility installed, effect on direct-control facility when 12

FIX PAGE instruction 5

instructions FIX PAGE 5 INVALIDATE PAGE TABLE ENTRY 7 OBTAIN CMS LOCK 9 OBTAIN LOCAL LOCK 8 RELEASE CMS LOCK 9 RELEASE LOCAL LOCK 8 SVC ASSIST 11 **TEST PROTECTION** 8 TRACE I/O INTERRUPTION 9 TRACE INITIAL SRB DISPATCH TRACE PROGRAM INTERRUPTION 9 TRACE SVC INTERRUPTION 9 TRACE SVC RETURN 9 TRACE TASK DISPATCH 9 instructions, summary table for 7 interruptions, program 7 (see also the program exceptions listed in the individual instruction descriptions) INVALIDATE PAGE TABLE ENTRY instruction 7, 5

lock-handling instructions OBTAIN CMS LOCK 9 OBTAIN LOCAL LOCK 8 RELEASE CMS LOCK 9 RELEASE LOCAL LOCK 8 lock-interface table 6 low-address protection 5

MAPL control block (operand for FIX PAGE and SVC ASSIST) 6 MVS control program, extended facility supports the 5 MVS-dependent instructions 6, 5

OBTAIN CMS LOCK instruction 9 OBTAIN LOCAL LOCK instruction 8 operand addressing 6

program interruptions 7 (see also program exceptions listed in the individual instruction descriptions)

READ DIRECT instruction, effect on when both direct-control facility and extended facility installed 12 RELEASE CMS LOCK instruction 9 RELEASE LOCAL LOCK instruction 8 RRE instruction format 6

segment-table entry, common-segment bit in 5 SVC ASSIST instruction 11 SSE instruction format 6

TEST PROTECTION instruction 8, 5 tracing instructions TRACE I/O INTERRUPTION 9 TRACE INITIAL SRB DISPATCH 9 TRACE PROGRAM INTERRUPTION 9 TRACE SVC INTERRUPTION 9 TRACE SVC RETURN 10 TRACE TASK DISPATCH 9

virtual-machine extended-facility assist 12, 5

WRITE DIRECT instruction, effect on when both direct-control facility and extended facility installed 12



International Business Machines Corporation Data Processing Division 1133 Westchester Avenue, White Plains, N.Y. 10604

IBM World Trade Americas/Far East Corporation Town of Mount Pleasant, Route 9, North Tarrytown, N.Y., U.S.A. 10591

IBM World Trade Europe/Middle East/Africa Corporation 360 Hamilton Avenue, White Plains, N.Y., U.S.A. 10601 IBM System/370 Extended Facility

Order No. GA22-7072-0

This manual is part of a library that serves as a reference source for systems analysts, programmers, and operators of IBM systems. This form may be used to communicate your views about this publication. They will be sent to the author's department for whatever review and action, if any, is deemed appropriate. Comments may be written in your own language; use of English is not required.

IBM shall have the nonexclusive right, in its discretion, to use and distribute all submitted information, in any form, for any and all purposes, without obligation of any kind to the submitter. Your interest is appreciated.

Note: Copies of IBM publications are not stocked at the location to which this form is addressed. Please direct any requests for copies of publications, or for assistance in using your IBM system, to your IBM representative or to the IBM branch office serving your locality.

Possible topics for comment are:

Clarity Accuracy Completeness Organization Coding Retrieval Legibility If you wish a reply, give your name and mailing address:

*Note:* Staples can cause problems with automated mail sorting equipment. Please use pressure-sensitive or other gummed tape to seal this form.

What is your occupation?

Number of latest Newsletter associated with this publication:

Thank you for your cooperation. No postage stamp necessary if mailed in the U.S.A. (Elsewhere, an IBM office or representative will be happy to forward your comments or you may mail directly to the address in the Edition Notice on the back of the front cover or title page.)

## **Reader's Comment Form**

