Trailing-Edge
-
PDP-10 Archives
-
tops10_703a_sys_atpch16_bb-fr67f-bb
-
moncal.mem
There are 7 other files named moncal.mem in the archive. Click here to see a list.
TOPS-10 Monitor Calls Manual
Volume 2
|
| Electronic distribution with Autopatch Tape 16
|
|
| May 1987
This manual describes the
monitor calls used by TOPS-10
MACRO programmers to request
services that are controlled
by the TOPS-10 monitor. The
TOPS-10 Monitor Calls Manual
consists of two volumes.
Volume 1 is an overview of the
services available to the
programmer. Volume 2 is a
detailed list of the calls and
coding sequences that are used
to invoke those services.
|
| This manual updates the
| TOPS-10 Monitor Calls Manual
| printed for TOPS-10 7.03.
| This version of the manual is
| not printed, and is not
| available from DIGITAL. It is
| distributed on the Autopatch
| Tape #16 for TOPS-10 7.03A in
| file form only.
|
| Operating System: TOPS-10 Version 7.03A(31735)
Software: GALAXY Version 5.1
digital equipment corporation marlboro, massachusetts
First Printing, August 1980
Updated, December 1981
Revised, February 1984
Revised, April 1986
| Autopatch Revision, May 1987
The information in this document is subject to change without notice
and should not be construed as a commitment by Digital Equipment
Corporation. Digital Equipment Corporation assumes no responsibility
for any errors that may appear in this document.
The software described in this document is furnished under a license
and may only be used or copied in accordance with the terms of such
license.
No responsibility is assumed for the use or reliability of software on
equipment that is not supplied by DIGITAL or its affiliated companies.
| Copyright C , 1971, 1980, 1981, 1984, 1986, 1987 Digital Equipment
| Corporation.
All Rights Reserved.
The postage-prepaid READER'S COMMENTS form on the last page of this
document requests the user's critical evaluation to assist us in
preparing future documentation.
The following are trademarks of Digital Equipment Corporation:
DEC DECnet IAS
DECUS DECsystem-10 MASSBUS
Digital Logo DECSYSTEM-20 PDT
PDP DECwriter RSTS
UNIBUS DIBOL RSX
VAX EduSystem VMS
VT
CONTENTS
PREFACE
CHAPTER 22 MONITOR CALL DESCRIPTIONS
CHAPTER 23 GETTAB TABLES
23.1 HOW TO USE GETTAB TABLES . . . . . . . . . . . . 23-1
23.2 HOW TO USE GETTAB SUBTABLES . . . . . . . . . . 23-2
23.3 ADDING ITEMS TO THE MONITOR'S GETTAB TABLES . . 23-4
23.4 ADDING NEW GETTAB TABLES TO THE MONITOR . . . . 23-5
23.5 ALPHABETIC LISTING . . . . . . . . . . . . . . . 23-6
23.6 TOPS-10 GETTAB TABLES . . . . . . . . . . . . . 23-8
TABLES
22-1 PATH. Functions and Flags . . . . . . . . . . 22-344
PREFACE
This is the second volume of the 2-volume TOPS-10 Monitor Calls
Manual. Volume 1 describes the facilities offered by the monitor for
assembly language programs. You can use the information in Volume 1
to learn how to implement these facilities in your programs.
Volume 2 contains a detailed description of each monitor call, its
calling sequence, functions, and error codes, if any. It is the
definitive list of the monitor call functions. For information on
using these calls, you should you read Volume 1 before attempting to
use Volume 2.
Not all devices are supported under current versions of TOPS-10. In
the interest of providing useful information, this manual includes
references to unsupported and obsolete hardware. For support status
of hardware and software, please refer to the current TOPS-10 Software
Product Description.
Obsolete monitor calls are marked, either in the CALLI UUO, or in the
chapter in which they were previously described. Appropriate
substitutes, (if any), for obsolete calls are also indicated. Section
23.5 lists the GETTAB Tables, and notes any obsolete tables.
|
| CONVENTIONS
|
| This electronic distribution of the Monitor Calls Manual, Vol. 2
| contains special notation to identify the following:
|
| Notation Meaning
|
| bolding bolding within an argument description
| defines a type of data that you must supply
| in your program.
|
| / \ / \
| | | or \ /
| \ / braces define a choice of argument types that
| you can supply for the same word.
|
| If you find any errors or have any suggestions for improving this
| manual, please fill out the Reader's Reply Form at the end of this
| manual and mail it to the address shown on the back of the form.
|
| All reported errors will be corrected as soon as possible and
| distributed with the next revision of the manual. Changes to this
| manual will be announced in the Software Dispatch newsletter.
xii
CHAPTER 22
MONITOR CALL DESCRIPTIONS
This chapter describes each of the TOPS-10 monitor calls. For each
description the following information is included, if applicable:
o Function: briefly describes the general use of the call.
|
|
| o Calling Sequence: shows the format for the call. Cases
| where a word may contain one of a number of types of
| information are indicated by the presence of braces
| containing the options. Braces are included as:
|
| / \ / \
| | | or \ /
| \ /
o Restrictions: describes any unusual conditions that might
affect the operation of the call or its effect on the calling
program.
o Normal Return: describes the result of a normal return from
the call and any operational aspects with which you should be
concerned.
o Error Return: describes the result of an error on return.
o Example: shows one or more examples of the call.
o Related Calls: lists other, related monitor calls.
o Common Errors: describes common user errors.
22-1
MONITOR CALL DESCRIPTIONS
In the calling sequences shown, the following definitions apply
throughout this section:
o ac: an arbitrary accumulator; often used for passing
arguments to the call and to store an error code returned
from a call.
o return: the statement to which control passes on return from
a call.
o normal return: the statement to which control passes if no
error occurs in executing a call.
o error return: the statement to which control passes if an
error occurs in executing a call.
The monitor call names are defined in the file UUOSYM.MAC; the CALLI,
MTAPE, and TTCALL monitor calls offer extensions through parameters
passed to the monitor.
22-2
ACCLG. [CALLI 204]
ACCLG. [CALLI 204]
Function
Used by the LOGIN system program to increment LOGNUM and ensure
that LOGIN does not exceed the maximum number of logged-in jobs.
The monitor performs the following functions for the ACCLG.
call:
1. Increments LOGNUM (a word containing the number of logged-in
jobs).
2. Checks the LOGNUM against the appropriate access maximum
(LOGMAX for timesharing jobs or BATMAX for batch jobs).
Calling Sequence
MOVSI ac,(flags)
ACCLG. ac
error return
normal return
where: flags are:
Bit Symbol Meaning
0 AC.MAX Check LOGMAX.
1 AC.BMX Check BATMAX.
2 AC.DCR Decrement LOGNUM count.
Normal Return
On a normal return, LOGNUM has been incremented and the maximum
is not exceeded. If the LOGIN program is halted before the LOGIN
UUO has successfully completed, however, the program should trap
the CTRL/C exit and perform another ACCLG. call, setting the
AC.DCR flag to decrement the LOGNUM count before allowing the
program to exit.
22-3
ACCLG. [CALLI 204]
Error Return
When this call takes the error return, one of the following error
codes will be returned in the ac.
Error Codes
Code Symbol Error
1 ACLMX% LOGMAX check failed. That is, to log in this
job would exceed LOGMAX.
2 ACLBM% BATMAX check failed.
3 ACLIL% Invalid argument to ACCLG. call.
4 ACLJL% ACCLG. with AC.DCR set produced an invalid
value after decrementing.
5 ACLDC% An ACCLG. with AC.DCR had been attempted when
the LOGNUM had not been incremented.
22-4
ACCT. [CALLI 167]
ACCT. [CALLI 167]
Function
Reads or changes the account string for a job.
Calling Sequence
MOVE ac,[XWD fcn-code,addr]
ACCT. ac,
error return
normal return
. . .
addr: EXP len
. . .
last argument
where: fcn-code is one of the function codes described below.
addr is the address of the argument block.
len is the length of the argument block (not including
this word), and the words up through last argument are
arguments for the given function.
The function codes and their meanings are:
Code Symbol Function
0 .ACTCH Changes the account string for the specified
job. The first word of the argument block must
contain a 1 for the number of arguments; the
second word must contain either a byte pointer
to the ASCIZ account string or the word
[-1,,address], where address is the location of
the account string. In the latter case, account
strings must be left-justified on a word
boundary.
You must have JACCT privileges to use function
code 0. Note that [1,2] privileges alone do not
provide ability to perform this function.
1 .ACTRD Reads the account string for the specified job.
The first word of the argument block must
contain a 2 for the number of arguments; the
second word must contain the job number for the
desired account string (-1 for the calling job);
the third word must contain the address of where
to return the account string.
22-5
ACCT. [CALLI 167]
NOTE
The maximum length for account strings is set by
the system administrator when the monitor is
generated by MONGEN (symbol name MLACTS). This
default can be changed if your installation uses
fewer than 39 characters in its account strings.
Normal Return
If the function was .ACTCH, the account string is changed. If
the function was .ACTRD, the account string for the job is in the
location pointed to by addr+2, and addr+1 contains the job
number.
Error Return
An error code is returned in the ac. The error codes and their
meanings are:
Code Symbol Error
1 ACTTL% Account string too long for your buffer; the
leftmost characters have been stored.
2 ACTAC% Address check error.
3 ACTIL% Illegal argument.
4 ACTNJ% Nonexistent job number.
5 ACTPS% JACCT privileges required.
Example
MOVE T1,[XWD .ACTRD,ARGLST]
ACCT. T1,
JRST ERROR
JRST CONTIN
ARGLST: EXP 2
JOBNO: EXP -1
ACCADR: EXP ACCSTR
ACCSTR: BLOCK ^D8
. . .
ERROR: error routine
CONTIN: success routine
This code sequence places the ASCIZ account string for the
calling job into the locations starting at ACCSTR.
Related Calls
GETPPN, PJOB
22-6
APRENB [CALLI 16]
APRENB [CALLI 16]
Function
Enables trap servicing for a program. When a condition enabled
for trap servicing occurs, control is transferred to the address
given by .JBAPR in the job data area. See Chapter 6 for more
information about handling traps.
Calling Sequence
MOVEI ac,flags
APRENB ac,
return
where: flags is a halfword containing flag bits as follows:
Bit Symbol Trap Condition
18 AP.REN Repetitive enable.
19 AP.POV Pushdown list overflow.
21 AP.ABK Reserved.
22 AP.ILM Memory protection violation.
23 AP.NXM Nonexistent memory.
24 AP.PAR Memory parity error.
26 AP.CLK Clock tick. The clock ticked while your program
was actively running; this trap does not occur
for every clock tick.
29 AP.FOV Floating-point overflow.
32 AP.AOV Arithmetic overflow.
When one of these conditions occurs while the processor is in
user mode, the monitor:
1. Stores the PC in location .JBTPC in the Job Data Area. If
the PC is equal to the first or second location in your trap
servicing routine, the program is terminated.
2. Clears the arithmetic and floating-point overflow flags.
3. Transfers control to your trap-servicing routine; the
location is given by the right half of location .JBAPR in the
Job Data Area.
22-7
APRENB [CALLI 16]
Your program must place the address of the trap-servicing routine
into .JBAPR before executing the APRENB monitor call.
NOTES
o If your trap-servicing routine contains the
instruction
JRSTF @.JBTPC
the processor bits are cleared and the state
of the CPU is restored; control resumes where
the interrupt occurred.
o The APRENB monitor call clears the trap after
an occurrence of any selected condition;
therefore your program must call APRENB after
each trap occurs.
o To enable repeated trap interceptions, your
program should set AP.REN (bit 18) when
executing the APRENB call; however, clock
interrupts must be reenabled after each trap
occurs.
o If your program does not enable for traps,
overflow conditions and clock ticks are
ignored, but the other conditions listed
above produce fatal errors.
Example
MOVEI T1,OVERFL ;Get routine address
; to handle overflow
MOVEM T1,.JBAPR ;Put into .JBAPR
MOVEI T1,AP.AOV ;Arithmetic overflow flag
APRENB T1, ;To .JBAPR on arith ovflw
JRST CONTIN ;On to something else
OVERFL: OUTSTR [ASCIZ /ARITHMETIC OVERFLOW ERROR/]
JRSTF @.JBTPC ;Resume execution
. . .
CONTIN: ;Something else
This code sequence sets up an overflow message for the first
arithmetic overflow; note that this example will not handle more
than one arithmetic overflow.
22-8
APRENB [CALLI 16]
Common Errors
Not reenabling the interrupt after each trap has occurred.
Failing to set up .JBAPR prior to the APRENB call.
Related Calls
UTRP., PISYS.
22-9
ATTACH [CALLI 104]
ATTACH [CALLI 104]
Function
Attaches a terminal line to a job. For example, this call is
used by the BATCON program to attach and detach jobs from their
terminals at system shutdown. This call is more powerful than
the ATTACH monitor command.
An unprivileged job can use the ATTACH monitor call only if its
terminal is in user mode, and it can only detach from its own
controlling terminal.
Calling Sequence
MOVE ac,[EXP <flag>+<lineno>B17+<jobno>B35]
ATTACH ac,
error return
normal return
where: flag is one of the bits described below.
lineno is a line number (restricted to 16 bits).
jobno is the number of a logged-in job (use -1 for the
current job).
If jobno is -1, your job is detached from the current line and
attached to the specified line; if jobno is 0, the job attached
to the line specified by lineno is detached; if jobno is positive
(requires JACCT or [1,2] privileges), the monitor detaches the
specified job from its current line and attaches it to the
specified line.
The flags and their meanings are:
Bit Symbol Terminal Mode
0 AT.UMM Puts terminal in monitor (command) mode.
However, .STPGR of the SETUUO may force the
terminal into user mode.
1 AT.UUM Puts terminal in user mode.
If neither flag is set, the terminal mode is not changed. Note
that this is the terminal mode, not the job mode.
22-10
ATTACH [CALLI 104]
To attach an arbitrary job to a terminal:
jobno should be the number of the job to be attached.
lineno should be the number of the terminal to which the
job is to be attached.
flag is the mode to which the new terminal will be set.
The previous terminal will be left in monitor mode.
To attach your current job to a terminal, follow the above
definitions, with the following exception:
jobno should be less than 0 (-1 is recommended).
To detach an arbitrary terminal:
jobno must be zero.
lineno should be the number of the terminal to be
detached.
flags will be ignored. The terminal will be left in
monitor mode.
To detach your job's controlling terminal:
jobno must be zero.
lineno should be -1 or 777777. If you explicitly include
777777, the first two bits of the value are
ignored, producing 177777 (both flag bits are
off).
flags are ignored. The terminal is placed in monitor
mode.
Normal Return
The job is attached or detached as specified, and the terminal is
in the specified mode.
Error Return
The ac is cleared. An error return occurs only if you use an
illegal line or job number, or if you do not have the required
privileges for the call.
22-11
ATTACH [CALLI 104]
Example
MOVSI T1,-1
ATTACH T1,
JRST ATTERR
JRST CONTIN
. . .
ATTERR: error routine
CONTIN: success routine
This example detaches the current job from its terminal line; the
mode is not changed.
22-12
CALLI [OPCODE 047]
CALLI [OPCODE 047]
Function
Passes the monitor a code for an extended set of monitor calls,
called CALLIs. The negative CALLI codes, except CALLI -1, are
reserved for customer-defined monitor calls. All non-negative
codes and -1 are reserved for use by DIGITAL. Any CALLIs not
listed in the following table are not supported or not
implemented. Obsolete CALLIs. are marked as such, and some
indicate an appropriate, supported monitor call to substitute for
the obsolete call. Obsolete calls are not described in this
manual.
The defined CALLIs also have symbolic names; in this chapter they
are listed in alphabetical order by symbol name. For example,
CALLI -1 is named LIGHTS, and is described in this chapter under
LIGHTS.
The CALLIs and their symbolic names are listed in numerical order
on the following pages.
22-13
CALLI [OPCODE 047]
Symbol CALLI Function Symbol CALLI Function
LIGHTS (Obsolete) SYSPHY [CALLI 51]
RESET [CALLI 0] DEVTYP [CALLI 53]
DDTIN (Obsolete; use TTCALL) DEVSTS [CALLI 54]
SETDDT [CALLI 2] DEVPPN [CALLI 55]
DDTOUT (Obsolete; use OUTSTR) SEEK (Obsolete)
DEVCHR [CALLI 4] RTTRP [CALLI 57]
GETCHR (Obsolete; use DEVCHR) LOCK [CALLI 60]
WAIT [CALLI 10] JOBSTS [CALLI 61]
CORE [CALLI 11] LOCATE [CALLI 62]
EXIT [CALLI 12] WHERE [CALLI 63]
MONRT. [CALLI 1,12] DEVNAM [CALLI 64]
UTPCLR [CALLI 13] CTLJOB [CALLI 65]
DATE [CALLI 14] GOBSTR [CALLI 66]
LOGIN [CALLI 15] HPQ [CALLI 71]
APRENB [CALLI 16] HIBER [CALLI 72]
LOGOUT [CALLI 17] WAKE [CALLI 73]
SWITCH (Obsolete) CHGPPN [CALLI 74]
REASSI [CALLI 21] SETUUO [CALLI 75]
TIMER [CALLI 22] OTHUSR [CALLI 77]
MSTIME [CALLI 23] CHKACC [CALLI 100]
GETPPN [CALLI 24] DEVSIZ [CALLI 101]
TRPSET [CALLI 25] DAEMON [CALLI 102]
TRPJEN [CALLI 26] JOBPEK [CALLI 103]
RUNTIM [CALLI 27] ATTACH [CALLI 104]
PJOB [CALLI 30] DAEFIN [CALLI 105]
SLEEP [CALLI 31] FRCUUO [CALLI 106]
SETPOV (Obsolete; use APRNEB) DEVLNM [CALLI 107]
PEEK [CALLI 33] PATH. [CALLI 110]
GETLIN [CALLI 34] METER. (Obsolete; use SNOOP.)
RUN [CALLI 35] MTCHR. [CALLI 112]
SETUWP [CALLI 36] JBSET. [CALLI 113]
REMAP [CALLI 37] POKE. [CALLI 114]
GETSEG [CALLI 40] TRMNO. [CALLI 115]
GETTAB [CALLI 41] TRMOP. [CALLI 116]
SPY [CALLI 42] RESDV. [CALLI 117]
SETNAM [CALLI 43] UNLOK. [CALLI 120]
TMPCOR [CALLI 44] DISK. [CALLI 121]
DSKCHR [CALLI 45] DVRST. [CALLI 122]
SYSSTR [CALLI 46] DVURS. [CALLI 123]
JOBSTR [CALLI 47] XTTSK. [CALLI 124]
STRUUO [CALLI 50] CAL11. [CALLI 125]
22-14
CALLI [OPCODE 047]
Symbol CALLI Function Symbol CALLI Function
MTAID. [CALLI 126] QUEUE. [CALLI 201]
IONDX. [CALLI 127] RECON. [CALLI 202]
CNECT. [CALLI 130] PITMR. [CALLI 203]
MVHDR. [CALLI 131] ACCLG. [CALLI 204]
ERLST. [CALLI 132] NSP. [CALLI 205]
SENSE. [CALLI 133] NTMAN. [CALLI 206]
CLRST. [CALLI 134] DNET. [CALLI 207]
PIINI. [CALLI 135] SAVE. [CALLI 210]
PISYS. [CALLI 136] CMAND. [CALLI 211]
DEBRK. [CALLI 137] PIBLK. [CALLI 212]
PISAV. [CALLI 140] SCS. [CALLI 213]
PIRST. [CALLI 141] SEBLK. [CALLI 214]
IPCFR. [CALLI 142] CTX. [CALLI 215]
IPCFS. [CALLI 143] PIFLG. [CALLI 216]
IPCFQ. [CALLI 144] IPCFM. [CALLI 217]
PAGE. [CALLI 145] LLMOP. [CALLI 220]
SUSET. [CALLI 146] LATOP. [CALLI 221]
SCHED. [CALLI 150] KNIBT. [CALLI 222]
ENQ. [CALLI 151] CHTRN. [CALLI 223]
DEQ. [CALLI 152] ETHNT. [CALLI 224]
ENQC. [CALLI 153] ENTVC. [CALLI 225]
TAPOP. [CALLI 154] NETOP. [CALLI 226]
FILOP. [CALLI 155]
NODE. [CALLI 157]
ERRPT. [CALLI 160]
ALLOC. [CALLI 161]
PERF. [CALLI 162]
DIAG. [CALLI 163]
DVPHY. [CALLI 164]
GTNTN. [CALLI 165]
GTXTN. [CALLI 166]
ACCT. [CALLI 167]
DTE. [CALLI 170]
DEVOP. [CALLI 171]
SPPRM. [CALLI 172]
MERGE. [CALLI 173]
UTRP. [CALLI 174]
PIJBI. [CALLI 175]
SNOOP. [CALLI 176]
TSK. [CALLI 177]
KDP. [CALLI 200]
22-15
CAL11. [CALLI 125]
CAL11. [CALLI 125]
Function
Performs front-end testing and debugging functions. Using this
call, you can obtain information about PDP-11 based front end
nodes, send and receive front-end messages, and examine and
deposit into the front-end software.
Calling Sequence
MOVE ac,[XWD len,addr]
CAL11. ac,
error return
normal return
. . .
addr: XWD port,fcn-code ;.C11FC
address ;.C11AD
value ;.C11CN
qstart ;.C11EN
where: len is the length of the argument block.
addr is the address of the argument block. Starting at
this address, the call accepts up to four words,
depending on the function code.
The argument block for CAL11. UUOs depends on the function
specified in the right half of the function word (.C11FC) at
addr. The function word contains a port specification in the
left half, and the function code in the right half.
Therefore, the format of the argument list for CAL11. is:
Offset Symbol Meaning
0 .C11FC Function word, containing the port
specification and the function code. The
left half of this word contains the type of
port, in either of the following formats.
The first format is old, and may be used by
existing programs. However, the new format
is recommended for new programs.
22-16
CAL11. [CALLI 125]
The old format for the left half is:
Bits Symbol Meaning
9-17 C1.CNO Type of PDP-11
(see .C11TY below).
9-14 C1.1NT Type of port
(see .C11TY below).
14-17 C1.1NN CPU number.
The new format for the left half of addr is
as follows. Note that this format is
signified by the setting of bit 0, the sign
bit.
Bits Symbol Meaning
0 C1.1NF New format for port
specification.
1-8 C1.1XX Reserved for use by
DIGITAL.
9-11 C1.1TY Type code, one of the
following:
Code Symbol Meaning
0 .C11DL DL-10
1 .C11DT DTE-20
2 .C11KD KMC/DUP
3 .C11DR DMR-11
11-14 C1.1CN CPU number.
15-17 C1.1PN Port number.
The right half of .C11FC (C1.1FC) contains
the function code. The arguments following
.C11FC depend on the function, so the
argument lists are described for each
function code listed below.
22-17
CAL11. [CALLI 125]
The function codes and their meanings are:
Code Symbol Function
0 .C11DP Deposits the specified data in the specified
location. The argument block for this function
is:
addr: XWD port,.C11DP ;.C11FC
EXP dpaddr ;.C11AD
EXP value ;.C11CN
where: dpaddr is the address to receive the
value.
value is the data to be deposited.
This function requires the JP.POK privilege.
This function works for DN60 and DN8x front ends
only.
1 .C11EX Examines the specified location. The argument
list for this function is:
addr: XWD port,.C11EX ;.C11FC
EXP exaddr ;.C11AD
where: exaddr is the address to be examined.
The data at the specified location is returned
in the ac.
This function requires the JP.POK privilege.
.C11EX works for DN60 and DN8x front ends only.
2 .C11QU Queues a request to the front end. The argument
list for this function is:
addr: XWD port,.C11QU ;.C11FC
BLOCK 2
EXP qstart ;.C11EN
where: qstart is the first word of a data block
containing information regarding the
front end function.
This function requires the JP.POK privilege.
.C11QU works only for DN60 front ends.
22-18
CAL11. [CALLI 125]
Code Symbol Function
3 .C11NM For DL10 based ANF-10 front ends, returns the
name of the program running on the PDP-11. The
SIXBIT program name is returned in ac. For all
other front ends, .C11NM returns the name of the
protocol enabled by the monitor for a given DTE.
The argument list for this function is:
addr: XWD port,.C11NM ;.C11FC
4 .C11UP Returns the status of the PDP-11 (0 for down, 1
for up). The status is returned in the ac. The
argument list for this function is:
addr: XWD port,.C11UP ;.C11FC
5 .C11SM Sends a message. The argument list for this
function is:
addr: XWD port,.C11SM ;.C11FC
This function works only for a DN8x front end.
6 .C11RM Receives a message. The argument list for this
function is:
addr: XWD port,.C11RM ;.C11FC
This function works only for a DN8x front end.
7 .C11TY Returns the node type and node number. The
argument list for this function is:
addr: XWD port,.C11TY ;.C11FC
The node number is returned in the left half of
the ac, and the node type is returned in the
right half, as one of the following type codes:
Code Symbol Meaning
1 .C1D76 DC76.
2 .C1D75 DC75/DN87.
3 .C1D60 DN60.
4 .C1D8S DN87S.
5 .C1CFE Console front end.
6 .C1MCB DECnet-10 MCB front end.
22-19
CAL11. [CALLI 125]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 C11NP% Job not privileged.
2 C11UF% Unknown function.
3 C11ND% Wrong type of PDP-11 specified.
4 C11IU% Examine/deposit function already in use.
5 C11NA% No answer to examine/deposit.
6 C11TS% Queue entry too short.
7 C11NE% Not enough arguments.
10 C11IA% Invalid address specified for examine/deposit.
11 C11IQ% Invalid argument for queue request function.
12 C11IC% Insufficient core.
13 C11RP% DTE-reload bit is set, or primary protocol is
not running.
14 C11IE% Insufficient exec virtual memory.
15 C11IL% Illegal packet length.
16 C11NC% CPU is not running.
17 C11IT% Illegal type code specified.
20 C11IP% Illegal port number specified.
21 C11DL% No DL10 support in this monitor.
22 C11DT% No DTE support in this monitor.
23 C11KD% No KDP support in this monitor.
24 C11DR% No DMR support in this monitor.
22-20
CHGPPN [CALLI 74]
CHGPPN [CALLI 74]
Function
Changes the project-programmer number (PPN) for the current job.
This call is reserved for the exclusive use of the LOGIN and
INITIA programs.
Calling Sequence
MOVE ac,[XWD projno,progno]
CHGPPN ac,
error return
normal return
where: projno,progno is the new project-programmer number (PPN).
Normal Return
The PPN for the current job is changed to the given number.
Error Return
Occurs if the calling job is already logged in, or if either the
project or programmer number is zero. The ac is unchanged.
Example
MOVE T1,[XWD 27,5031]
CHGPPN T1,
JRST ERROR
This code sequence changes the PPN for the current job to
27,5031.
Related Calls
GETPPN, LOGIN
22-21
CHKACC [CALLI 100]
CHKACC [CALLI 100]
Function
Determines whether a file may be accessed, based on your job's
current PPN and the file access protection code. Your programs
should not make assumptions concerning the access codes
associated with a file; they should use the CHKACC monitor call
to determine if access is permitted to that file. This is
especially true for privileged programs that are constrained by
the access privileges of a non-privileged project-programmer
number for which they are performing a task.
The CHKACC call does not function correctly on systems that are
running a file daemon program, such as FILDAE. So, if your
system is running a FILDAE type program, use the FILOP. call.
The FILOP. monitor call allows a privileged program to specify
that an operation is to be performed only when the operation
would be legal if performed by a specified project-programmer
number. In most cases, the FILOP. function eliminates the need
for the CHKACC monitor call. New programs should be written
using the FILOP. "in your behalf" capability (.FOPPN).
Calling Sequence
MOVEI ac,addr
CHKACC ac,
error return
normal return
. . .
addr: XWD fcn-code,<ufdprot>B26+<filprot>B35
XWD projno,progno ;For file
XWD projno,progno ;For accessing program
where: addr is the address of the argument block.
fcn-code is one of the function codes described below.
ufdprot is a directory protection code.
filprot is a file protection code.
projno,progno is a project-programmer number (PPN).
NOTE
When your program specifies function codes 0
through 6, the monitor ignores the directory
protection. When your program specifies function
codes 7 and 10, the monitor ignores the file
protection.
22-22
CHKACC [CALLI 100]
The function codes and their meanings are:
Code Symbol Access
0 .ACCPR Checks whether your job can change the
protection for the file.
1 .ACREN Checks whether your job can rename the file.
2 .ACWRI Checks whether your job can write the file.
3 .ACUPD Checks whether your job can update the file (in
old update mode).
4 .ACAPP Checks whether your job can append to the file.
5 .ACRED Checks whether your job can read the file.
6 .ACEXO Checks whether your job can execute the file.
7 .ACCRE Checks whether your job can create the file in
the user's UFD.
10 .ACSRC Checks whether your job can read the directory
as a file.
The right to access a file is determined by:
o The type of access desired.
o The project-programmer number of the user desiring access to
the file.
o The project-programmer number of the directory containing the
file.
o The protection field of the file or the protection field of
the directory.
Note that access to a file is not dependent on the file name.
However, the file name is needed if your program is going to
perform a LOOKUP.
The owner of a UFD or an SFD can always read the UFD or SFD as a
directory.
22-23
CHKACC [CALLI 100]
Normal Return
The monitor returns 0 in the ac if access to the file is allowed,
or -1 if access is not allowed.
Error Return
The ac is unchanged; this occurs only if you gave an invalid
function code or CHKACC is not implemented on your system.
Example
The following code checks to see if the user logged in as
[11,315] can change a file with protection <055> in the directory
area [27,5031].
MOVEI T1,ARGLST
CHKACC T1,
JRST ERROR
JRST CONTIN
ARGLST: XWD .ACCPR,<775>B26+<055>B35
XWD 27,5031 ;For files
XWD 11,315 ;For accessing program
Related Calls
FILOP.
Common Errors
Assuming that the CHKACC call grants access to a file. Remember
that it only tests the accessibility of the file. FILDAE can
still deny access to the file on a LOOKUP, ENTER, RENAME, or
FILOP. call. The File Daemon program is described in Appendix C.
22-24
CHTRN. [CALLI 223]
CHTRN. [CALLI 223]
Function
CHTRN. is used to translate characters from one representation
to another. For instance, CHTRN. may be used to convert 8-bit
characters to 7-bit characters.
Calling Sequence
XMOVEI ac,addr
CHTRN. ac,
error return
normal return
addr: XWD flags, source count
EXP source byte pointer (word one)
EXP source byte pointer (word two)
XWD reserved, destination count
EXP destination byte pointer (word one)
EXP destination byte pointer (word two)
where: flags are one or more of the flags listed below.
source count is the number of bytes stored where the
source byte pointer indicates.
destination count is the number of bytes available at the
location the destination byte pointer indicates.
The flag bits are:
Flag Symbol Meaning
0 CH.FBR Fallback representation (translates 8-bit to
7-bit).
1 CH.OVR Includes overprinting in the fallback
representation.
2 CH.RAI Changes lower case to upper case.
3 CH.6BT Converts ASCII characters to SIXBIT.
4 CH.IGN Ignores extra bits; does not range-check
characters.
5 CH.ESC Maps 7-bits ESCape sequences to 8-bit wherever
possible.
6 CH.X6B Expands SIXBIT source to ASCII destination.
22-25
CHTRN. [CALLI 223]
Normal Return
The ac is unchanged. The byte pointers returned will have any
indirection and indexing resolved. If you specify a one-word
global byte pointer, the pointers will be expanded from one-word
global format to two-word global format.
Error Return
One of the following codes is returned in the ac:
Code Symbol Error
1 CHADC% Address check while reading or writing
arguments.
2 CHBYP% Illegal byte pointer.
3 CHINV% Unknown or reserved flag bit specified.
4 CHILC% Illegal character encountered during
translation.
5 CHDCE% Destination count exhausted prematurely.
6 CHIBC% Invalid bit combination specified.
22-26
CLOSE [OPCODE 070]
CLOSE [OPCODE 070]
Function
Terminates transmission of data to or from a file. Closes the
file for both input and output. The default functions of the
CLOSE call for unbuffered data modes are:
o The output side of the channel is closed. In unbuffered data
modes, the effect is to execute a device-dependent function.
o The input side of the channel is closed. The end-of-file
flag is cleared. Further actions depend on the data mode.
The effect is to execute a device-dependent function.
In buffered data modes, the following operations are performed on
the output side of the channel:
o All data in the buffers that have not been transmitted to the
the device is written to the device.
o Device-dependent functions are performed.
o The ring use bit is set to 1, indicating that the ring is not
in use.
o The buffer byte count, the third word of the buffer header,
is set to 0.
o Control returns to the user program when transmission is
complete.
In buffered data modes, if a ring buffer exists, the following
operations are performed to close the input side of the channel:
o The monitor waits until the device is inactive.
o The use bit of each buffer is cleared, to indicate that the
buffer is empty.
o The use bit of the buffer ring is set to 1, to indicate that
the ring is not in use.
o The buffer byte count is set to 0.
o Control returns to the user program.
22-27
CLOSE [OPCODE 070]
If a file is being written to disk at the time of the output
CLOSE, the unwritten blocks at the end of the disk file are
deallocated. On input CLOSE, the access date of a disk file is
updated if any data was actually read. (LOOKUP followed by CLOSE
does not change the access date.)
If the file is being output to the card punch, the last card is
punched, followed by an end-of-file card. This end-of-file card
and the header card contain the file identification punch in
column 1, which is ignored by the card reader service routine.
If a file is being output to magtape, two EOF marks are written
and the tape position is backspaced over one EOF.
If a file is being output to the line printer, a form-feed
character is appended to the last block of data.
Calling Sequence
CLOSE channel,flags
return
where: channel is the channel number for the file.
flags are one or more of the function flags described
below.
The function flags and their meanings are:
Bits Symbol Function
29 CL.DAT Deletes the name block and access tables from
the disk data base and the space is returned to
monitor free core. For example, this function
is used by BACKUP on a RESTORE operation.
30 CL.RST Inhibits deletion of the original file, if any,
for an ENTER call that creates or supersedes the
file. The new copy of the file is discarded.
31 CL.NMB Inhibits deletion of the name block and access
tables in monitor memory; this function is
effective only if a LOOKUP call was executed for
the channel, but no subsequent INPUT call for
the channel was executed.
32 CL.ACS Prevents updating of the file access date. For
example, this feature is used by BACKUP, to save
files on magtape without changing their access
dates.
22-28
CLOSE [OPCODE 070]
Bits Symbol Function
33 CL.DLL Inhibits deallocation of any unwritten blocks at
the end of a disk file.
34 CL.IN Inhibits closing of the input side of the
channel.
35 CL.OUT Inhibits closing of the output side of the
channel.
Return
The function is performed.
Example
See Chapter 11, Monitor Calls Manual Vol. 1.
Related Calls
LOOKUP, ENTER, RENAME
22-29
CLRBFI [TTCALL 11,]
CLRBFI [TTCALL 11,]
Function
Clears text from the terminal input buffer. This call is often
used to clear any further user commands when an error occurs;
otherwise, incorrect processing (due to user-type ahead) could
follow the error.
Calling Sequence
CLRBFI
return
Return
All text is cleared from the input buffer.
Related Calls
TTCALLs, TRMOP.
22-30
CLRBFO [TTCALL 12,]
CLRBFO [TTCALL 12,]
Function
Clears the terminal output buffer. This monitor call is normally
equivalent to typing CTRL/O.
Calling Sequence
CLRBFO
return
Return
The terminal output buffer is cleared.
Related Calls
CLRBFI, TTCALLs, TRMOP.
22-31
CLRST. [CALLI 134]
CLRST. [CALLI 134]
Function
Clears or sets the I/O status bits for a device. This enables
your program to continue after an I/O error has occurred. The
CLRST. UUO functions like SETSTS, taking the list of devices and
I/O status bits for each device, with the additional ability to
specify devices not explicitly OPENed on an I/O channel.
You can examine the current setting of the I/O status bits by
using the SENSE. monitor call.
Calling Sequence
|
| MOVE ac,[XWD len,addr]
| CLRST. ac,
| error return
| normal return
| . . .
| addr: / SIXBIT/device/ \
| | EXP channo | ;.CLRSX
| \ EXP udx /
| XWD 0,setsts-value ;.CLRST
| / SIXBIT/device/ \
| | EXP channo | ;.CLRSX
| \ EXP udx /
| XWD 0,setsts-value ;.CLRST
| . . .
where: len is the length of the argument list.
addr is the address of the argument list, containing one
or more 2-word entries.
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the universal device index for a device.
setsts-value is the halfword value of the I/O status bits
for the given device, channel, or udx; and it specifies
the new settings for the I/O status bits.
Your program can clear the I/O status bits for more than one
device. The argument block contains a 2-word entry for each
device.
22-32
CLRST. [CALLI 134]
For a complete list of I/O status bits, see Chapter 11. Each
type of device has a unique set of I/O status bits, which are
described in the chapter about the appropriate device.
Normal Return
The I/O status bits for each specified device are cleared.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 CLRID% Illegal device specified.
2 CLRNO% Specified device does not belong to your job.
Example
MOVE T1,[XWD <CONTIN-ARGLST>,ARGLST]
CLRST. T1,
JRST ERROR
JRST CONTIN
ARGLST: SIXBIT /DTA0/
EXP 0
EXP CHANNO
EXP 0
. . .
CONTIN:
This code sequence clears the I/O status bits for DTA0 and the
device associated with the channel whose number is the value of
CHANNO.
Related Calls
ERLST., GETSTS, SENSE., SETSTS
22-33
CMAND. [CALLI 211]
CMAND. [CALLI 211]
Function
Defines commands that run specified programs, and manipulates the
job's user-defined command list. In the argument list to this
call, your program defines a command name that, when typed as a
monitor command, will run the program specified by the file
specification that is also included in the command list. The
CMAND. UUO allows you to define multiple command names in the
argument list, and allows you to read the command list that is
already defined for your job.
Calling Sequence
MOVE ac,[XWD fcn-code,addr]
CMAND. ac,
error return
normal return
where: fcn-code is the function code. The function codes are
listed below.
addr is the address of the argument list. The argument
list for each function code is described in the following
list of function codes.
The function codes and their meanings are:
Code Symbol Meaning
0 .CMINT Initializes (clears) any current command
definitions and creates a new command list as
specified at addr. The argument list stored at
addr is formatted as follows:
addr: flag,,length ;.CMFLA
command name ;.CMNAM
device name ;.CMDVC
file name ;.CMFLE
file extension ;.CMEXT
PPN ;.CMPPN
first SFD ;.CMSFD
second SFD
. . .
0 ;end of command list
22-34
CMAND. [CALLI 211]
Code Symbol Meaning
Where the flags to be stored in the left half of
.CMFLG indicates the number of characters in the
command that must be input to define the command
uniquely. The flags are:
Mask Symbol Meaning
10B17 CM.UN1 Command is uniquely
identified by the first
character of its name.
4B17 CM.UN2 Command is uniquely
identified by the first two
characters.
2B17 CM.UN3 Command is uniquely
identified by the first
three characters.
1B17 CM.UN4 Command is uniquely
identified by the first
four characters.
1B12 CM.AUT Command is defined as
automatically saving the
job's current context. The
command will create a new
context, in which the
called program will run.
The original context is
restored when the program
terminates.
And where the length is the number of words in
the command block, stored in the right half of
.CMFLA, and symbolized by CM.COU.
The rest of the command block contains the
command name (in SIXBIT), and the file
specification of the program to be run when the
command is used. Note that the command block is
of variable length, depending on the SFD level
of the directory where the file is stored.
You can define more than one command by
including a command block for each command, and
storing them in contiguous blocks. The last
word, where the next .CMFLA might be expected,
must be set to zero.
22-35
CMAND. [CALLI 211]
Code Symbol Meaning
1 .CMADD Adds one or more command definitions to the
current command list. The argument block for
this function is identical to that used by
function 0 (.CMINT).
2 .CMDEL Deletes one or more commands from the current
list of defined commands. The argument list for
this function is:
addr: length ;.CMSIZ
first command ;.CMCMN
.
.
.
The length of the argument list is equal to the
entire length of the argument list, including
.CMSIZ. The commands to be deleted are listed
in the following words, and each must be
equivalent to the .CMNAM word where the command
was defined (see .CMINT argument list). Note
that commands in the command list that are not
listed in the .CMDEL argument list are not
affected by this function.
3 .CMLST Lists all the currently defined command names.
The argument list for this function is:
addr: length
BLOCK length-1
where length is the length of the argument
block, and length-1 is the number of commands to
return. On a successful return, the argument
block appears as:
addr: length ;.CMSIZ
first command ;.CMNAM
.
.
.
Where .CMSIZ contains the total number of
defined commands. The command names are
returned starting at .CMNAM. If the reserved
block is not long enough, the list of command
names is limited to the reserved space.
22-36
CMAND. [CALLI 211]
Code Symbol Meaning
4 .CMRET Returns information about a command. You must
include the argument list as:
addr: length ;.CMSIZ
command name ;.CMCNM
In this argument list, specify the length of the
block to be returned in .CMSIZ, and the name of
the defined command for which information is
desired, in .CMCNM. The information is returned
in the form of a command block (same as argument
list for .CMINT), for the command name.
5 .CMDMP Dumps the command data base. This function uses
the following argument list:
addr: length
BLOCK length-1
After the call returns successfully, a list of
all the command blocks for defined commands will
be returned at addr. See function 0 (.CMINT)
for the format of the returned command blocks.
Note that the last command block will be
followed by a zero word to indicate the end of
the command list.
Normal Return
The state of a return from CMAND. UUO is described for each
function listed above.
Error Return
On an error return, the CMAND. UUO takes the non-skip return and
returns the appropriate code from the following list of error
codes:
Code Symbol Error
1 CMIAL% Your program specified an illegal argument list.
The argument list length was either too long or
too short.
2 CMADC% Address check occurred.
3 CMNER% Not enough room to define commands in your job's
per-process space.
22-37
CMAND. [CALLI 211]
Code Symbol Error
4 CMDNF% Your program did not finish reading the command
list. The buffer size you allowed at addr was
not enough to contain all the information to be
returned.
5 CMNSN% No such command name. On a .CMRET or .CMDEL
function, you specified a command that is not
defined.
Example
MOVE AC,[XWD .CMADD,CMBLK]
CMAND. AC,
error return
success ;Command has been defined
CMBLK: CM.UN3!6 ;/UNIQUE:3, and 6 words in block
SIXBIT /XDDT/ ;Command name
SIXBIT /DSKA/ ;Device name
SIXBIT /DDT/ ;File name
EXP 0 ;Extension. Might as well leave zero
XWD 1,4 ;PPN
This will define the XDDT command to run DSKA:DDT[1,4].
Common Errors
Assuming that .CMFLA in .CMINT or .CMADD specifies the length of
the entire argument list.
22-38
CNECT. [CALLI 130]
CNECT. [CALLI 130]
Function
Connects or disconnects a device associated with an MPX channel.
You can use CNECT. only with devices that are MPX-controllable
(specifically, terminals, pseudo-terminals, line printers, card
readers, paper tape punches, and remote data terminals).
Calling Sequence
|
| MOVEI ac,addr
| CNECT. ac,
| error return
| normal return
| . . .
| addr: XWD fcn-code,channel
| / SIXBIT/device/ \
| \ EXP udx /
where: addr is the address of the argument block.
fcn-code is one of the function codes described below.
channel is the number of an initialized MPX channel.
device is the SIXBIT physical, generic, or logical name
of a device.
udx is the Universal Device Index for the device.
Your program must initialize an MPX channel for the device using
an OPEN call, before using the CNECT. call to connect the device
to an MPX channel. The device must be initialized and connected
to the MPX channel before it can be used for any I/O.
The function codes and their meanings are:
Code Symbol Function
1 .CNCCN Connects the device to an MPX channel.
2 .CNCDC Equivalent to CLOSE and disconnect from MPX
channel.
3 .CNCDR Equivalent to RESET and disconnect from MPX
channel.
4 .CNOFE Determines output feasibility.
22-39
CNECT. [CALLI 130]
Normal Return
The specified device is connected, disconnected, reset, and/or
closed, as appropriate for the given function code. For the
.CNCCN function, the Universal Device Index for the device is
returned in the ac.
For the .CNOFE function, two values are returned in the ac. The
left half of the ac contains the user address of the current
output buffer, or 0 if none. The right half of the ac contains
the number of data requests for a network device (except
terminals, which return a 1 if output is possible), 0 if there
are no data requests for the network device, or -1 if the device
is local. The number of data requests indicates the number of
buffers that the remote device can accept before your job will
block in output wait state.
Your program can perform an output UUO to the device if the left
half of the ac contains 0 and the right half is non-zero.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 CNCNM% MPX channel not initialized.
2 CNCUD% Nonexistent device.
3 CNCCM% Illegal device for MPX.
4 CNCNF% Not enough memory for control blocks.
5 CNCNC% Device not connected.
6 CNCNO% Device illegal or not initialized.
7 CNCII% Invalid Universal Device Index.
10 CNCUF% Invalid function code.
11 CNCDU% Device is not available to your job.
12 CNCSD% Device is spooled; not MPX-controllable.
Example
MOVEI T1,ARGLST
CNECT. T1,
JRST ERROR
JRST CONTIN
ARGLST: XWD .CNCDC,CHANNO
SIXBIT /TTY111/
This code sequence disconnects the device TTY111, which is
associated with the MPX channel given by CHANNO, from an MPX
channel.
22-40
CORE [CALLI 11]
CORE [CALLI 11]
Function
Allows your program to dynamically expand or contract its core
allocation in either or both segments. Note that neither of the
segments may be locked in core.
Calling Sequence
MOVE ac,[XWD hiseg,lowseg]
CORE ac,flag
error return
normal return
where: hiseg is the highest relative address to be used in the
program high segment.
lowseg is the highest relative address to be used in the
program low segment.
flag is a flag bit (UU.PHY) to indicate that the core
assignment applies to physical memory. To set this flag,
set bit 19. When bit 19=0, virtual memory references are
allowed. When bit 19=1, all memory references are
accepted as physical addresses.
Note that if the CORE UUO is executed in a non-zero section, all
core address arguments will be interpreted as section-relative
values. That is, all references are assumed to be relative to
the current section.
If hiseg = 0, the core assignment for the high segment is left
unchanged; if lowseg = 0, the core assignment for the low segment
is left unchanged.
If you give a non-zero hiseg that is less than 400000 or the
length of the low segment (whichever is greater), the high
segment is eliminated. Doing this from the high segment causes
an illegal memory reference.
If your program has no high segment, or if you give a CORE call
that eliminates the high segment, you can create a new,
non-sharable high segment by giving hiseg greater than 400000.
You can make the new high segment sharable by doing the
following:
o Giving it a .EXE extension.
o Writing it onto a storage device.
22-41
CORE [CALLI 11]
o Closing the file.
o Using the SSAVE monitor command, or the SAVE. UUO with the
SS%SSH flag, to save the entire core image.
o Initializing the program with a GET, R, or RUN monitor
command, or with a RUN, MERGE., or GETSEG monitor call.
If you use the CORE monitor call giving a value for lowseg that
is less than or equal to .JBREL, the monitor removes any
noncontiguous pages from your address space; these pages may
include the page fault handler (PFH) or VMDDT. To avoid this,
use the PAGE. monitor call to choose only the needed pages.
Before expanding core, you should compare the highest required
address with the highest legal address (stored in .JBREL). The
example below shows how to expand core only if necessary.
You can specify the beginning of your program's high segment by
using the REMAP monitor call, the /NEWPAGE or /SET switches to
LINK, or the TWOSEG pseudo-op to MACRO.
Normal Return
The ac contains the current virtual memory limit in 1K blocks.
However, if the CORE monitor call is issued from a non-zero
section, the virtual memory limit is not returned in the ac.
Error Return
The error return occurs if any of the following conditions
occurs:
o You give hiseg < 400001, but you do not have write-access
privileges.
o You give both hiseg and lowseg as zero. In this case, the
number of free 1K blocks is returned in the ac.
o The sum of the requested new low segment and the previously
existing high segment exceeds your allowed program size.
Core assignment is not changed; the maximum allowed program
size (in 1K blocks) is returned in the ac.
o The sum of the requested new low and high segments exceeds
your allowed program size. Core assignment is not changed;
the maximum allowed program size (in 1K blocks) is returned
in the ac.
22-42
CORE [CALLI 11]
o You give a lowseg argument that would extend the low segment
into the high segment.
o One or both segments are locked.
Example
MOVE T1,NEWSIZ ;Set up for call
PUSHJ P,CHKCOR ;Call for core
JRST CONTIN
;Subroutine to get core only if needed
CHKCOR: CAMG T1,.JBREL## ;Core size OK?
POPJ P, ;Yes
CORE T1, ;Get more core
JRST ERROR ;To error routine
POPJ P, ;Core increase OK
Related Calls
PAGE.
22-43
CTLJOB [CALLI 65]
CTLJOB [CALLI 65]
Function
Obtains the number of the job that is controlling a specified
subjob. The subjob must be attached to a pseudo-terminal.
Calling Sequence
MOVEI ac,jobno
CTLJOB ac,
error return
normal return
where: jobno is the number of the controlled job, or -1 to
specify your current job.
Normal Return
The number of the controlling job is returned in the ac. If the
job given by jobno is not controlled by a pseudo-terminal (PTY),
the number returned in the ac is -1.
Error Return
Occurs if the job number is illegal.
Example
MOVNI T1,1
CTLJOB T1,
JRST ERROR
This code sequence returns the number of the controlling job in
T1.
Related Calls
PJOB
22-44
CTX. [CALLI 215]
CTX. [CALLI 215]
Function
CTX. allows you to manipulate contexts. (For a discussion of
contexts, see Volume 1.) Since the argument block of CTX. is
never written by the monitor, it may reside in a write-protected
page or in a literal.
Calling Sequence
XMOVEI ac,argblk
CTX. ac
error return
normal return
where: argblk is the following argument block whose maximum
length is .CTMAX:
17 35
|=======================================================|
| P | RESERVED | LENGTH | FUNCTION CODE |
|-------------------------------------------------------|
| DATA BUFFER LENGTH |
|-------------------------------------------------------|
| DATA BUFFER ADDRESS |
|-------------------------------------------------------|
| SIXBIT CONTEXT NAME |
|-------------------------------------------------------|
| RESERVED | RUN UUO OFFSET |
|-------------------------------------------------------|
| RUN UUO BLOCK ADDRESS |
|-------------------------------------------------------|
| TMPCOR LENGTH | SIXBIT NAME |
|-------------------------------------------------------|
| TMPCOR BUFFER ADDRESS |
|=======================================================|
The format of the argument block is:
Offset Symbol Contents
0 .CTFNC The function code word. It also contains one of
the following flags, and the length of the
argument block, in the following format:
Bits Symbol Meaning
0 CT.PHY Physical-only RUN UUO.
2-8 Reserved for DIGITAL.
22-45
CTX. [CALLI 215]
Offset Symbol Contents
Bits Symbol Meaning
9-17 CT.LEN Length of the argument block,
including .CTFNC.
18-35 CT.FNC One of the function codes
listed below.
1 .CTDBL Holds the data buffer length in words. 510
decimal words is the maximum.
2 .CTDBA Contains the full 30-bit address of the data
buffer. If the IFIW (sign bit) is on, a section
local address, relative to the section CTX. is
executed in, is referenced.
3 .CTNAM Used to hold a context name when creating a new
context. When manipulating contexts, this word
may contain a context name or context number.
4 .CTRNO RUN UUO word. This holds the offset that would
normally go into the left half of the RUN UUO ac
(0 for terminal input, or 1 for indirect command
file input).
5 .CTRNB Holds the 30-bit block address that would
ordinarily go into the right half of the RUN UUO
ac.
6 .CTTMN Contains the TMPCOR length in the left half
(bits 0-17), and its SIXBIT name in the right
half (bits 18-35).
7 .CTTMB The 30-bit TMPCOR buffer address.
Valid function codes you can specify for .CTFNC are:
Code Symbol Function
0 .CTSVH Saves the current context and halts the job.
This has the effect of a PUSH command (see
Operating System Commands Manual, Chapter 1).
The context created is inferior. The inferior
context is deleted as soon as you switch from it
back to the superior one.
1 .CTSVR Saves the current context, and runs a program.
This is the equivalent of doing an auto-save,
then a restore, at monitor level.
22-46
CTX. [CALLI 215]
Code Symbol Function
2 .CTSVT Creates a parallel context by saving the current
one, and creating a new top level context. The
new context is different from one formed by a
PUSH chain, as it is not inferior, nor is it
associated with a chain of PUSHed contexts.
3 .CTSVS Saves the current context, and switches to
another, (already existing) one. For instance,
you could use .CTSVR to create a new context
running a program, and switch back to the
previous context using .CTSVS. You could later
return to the context created by .CTSVR, and
restart the program in that context, without
waiting for it to re-initialize.
4 .CTSVD Switches to the specified context, deletes it,
and returns to the previous (saved) context. A
specific deletion is required for parallel
contexts only.
5 .CTRDB Reads the data buffer without changing the
information. An inferior context uses this to
read data when a superior context passes to it.
6 .CTWDB Writes the data buffer. An inferior context
writes data to its superior using this. Once
data has been written, the old data in the
superior context is lost.
7 .CTRQT Reads the context quota and saved-page quota for
a job. The following offsets in the data buffer
are required:
Offset Symbol Contents
0 .CTJOB Job number, supplied by
program.
1 .CTCTQ Returned context quota.
2 .CTPGQ Returned saved-pages quota.
10 CTSQT Sets the context quota and saved-pages quota.
The data buffer offsets are the same as for
.CTRQT.
22-47
CTX. [CALLI 215]
Code Symbol Function
11 .CTDIR Returns a directory map of all contexts.
(GETTAB %CTBDM contains the byte pointer to the
directory byte-stream.) The data buffer offsets
returned are:
Offset Symbol Contents
0 .CTJOB Target job number.
1 .CTWCT Word count of byte-stream data.
2 .CTFDW First data word of the
directory byte-stream.
12 .CTINF Returns information about a particular context.
The data buffer offsets returned are:
Offset Symbol Contents
0 .CTJOB Target job number.
1 .CTCNO Number of target context.
2 .CTCNM Name of target context.
3 .CTSNO Superior context's number.
4 .CTSNM Superior context's name.
5 .CTPGM Program running or saved in
target context, if any.
6 .CTITM Idle time (in clock ticks).
On any return, the ac contains:
Bits Symbol Meaning
0 CT.DAT Set if data returned to the buffer.
1 CT.DBT Returned if the buffer is truncated.
2 CT.ETX Set if UUO error text in the buffer.
3 CT.RUN Set for a RUN UUO error.
18-27 CT.RDL Count of words returned in the buffer.
28-35 CT.ERR CTX. or RUN UUO error code. Returned
regardless of whether or not the data buffer
contains error text.
Normal Return
No errors will be flagged in CT.ETX, CT.RUN, or CT.ERR. Offsets
(if any) from requested functions are returned in the data
buffer.
22-48
CTX. [CALLI 215]
Error Return
One of the following error codes is returned in bits 28 through
35 of the ac. If a data buffer is specified, error text is also
returned.
Code Symbol Error
0 CXIFC% Illegal function code.
1 CXACR% Address check performed while reading arguments.
2 CXACS% Address check performed while storing answers.
3 CXNEA% Insufficient number of arguments.
4 CXNLI% User not logged in.
5 CXLOK% Program locked in core.
6 CXDET% Job detached.
7 CXSCE% System context quota exceeded.
10 CXSPE% System page quota exceeded.
11 CXJCE% Job context quota exceeded.
12 CXJPE% Job page quota exceeded.
13 CXNCS% Insufficient core to save context.
14 CXNCD% Not enough core to return data block.
15 CXICN% Illegal context number.
16 CXNSC% No superior context.
17 CXNPV% No privileges to set quotas.
20 CXIJN% Illegal job number.
21 CXCSI% Users cannot switch to an intermediate context.
22 CXCDI% Users cannot delete an intermediate context.
23 CXCDC% Users cannot delete the current context.
24 CXCNP% Context not privileged.
25 CXNDA% No data block is available.
22-49
DAEFIN [CALLI 105]
DAEFIN [CALLI 105]
Function
Indicates that a request to the DAEMON program has been
completed. This monitor call is reserved for the exclusive use
of the DAEMON program.
If the specified job was in the DAEMON wait state, the monitor
requeues the specified job to the run queue.
Calling Sequence
MOVE ac,[XWD length,addr]
DAEFIN ac,
error return
normal return
. . .
addr: jobno
where: length is the length of the argument block.
addr is the address of the argument block.
jobno is the number of the logged-in job to be restarted.
Normal Return
The monitor leaves the ac unchanged, requeues the specified job,
and clears the JDC bit in the job status word .GTSTS.
Error Return
The monitor clears the ac. This occurs if you are not
privileged, if the job number is illegal or zero, or if the
request could not be completed.
Example
MOVE T1, [XWD 1,ARGLST]
DAEFIN T1,
JRST ERROR
JRST CONTIN
ARGLST: EXP JOBNO
Related Calls
DAEMON
22-50
DAEMON [CALLI 102]
DAEMON [CALLI 102]
Function
Invokes the system program DAEMON. When a job executes the
DAEMON monitor call, the monitor puts the job into JD wait (sets
the JDC bit in the GETTAB table .GTSTS) and wakes DAEMON. DAEMON
examines the status word .GTSTS for each job in the system; for
each job in the JD wait state, DAEMON performs the requested
function. When the specified function has been completed, DAEMON
issues a DAEFIN monitor call to make the job runnable.
Calling Sequence
MOVE ac,[XWD length,addr]
DAEMON ac,
error return
normal return
. . .
addr: EXP fcn-code
. . .
last argument
where: length is the length of the argument block.
addr is the address of the argument block, which contains
fcn-code in the first word, followed by an argument list
which differs for each function code. The argument lists
are described below.
The function codes and their meanings are:
Code Symbol Function
1 .DCORE Obsolete
2 .CLOCK Enters a request in the clock queue to wake your
job after a specified number of seconds has
elapsed. As soon as the request has been
entered in the queue, you should issue a call to
HIBER with no time argument. An argument of
zero clears the job's entry in the clock queue
and wakes the job.
22-51
DAEMON [CALLI 102]
Code Symbol Function
The argument list for the .CLOCK function is:
addr: .CLOCK
EXP seconds
where: seconds is the number of seconds before
the job DAEMON should wake. The
preferred method for awakening the
program after a short amount of time is
by using the HIBER. call.
3 .FACT Makes an entry in the system accounting file
FACT.SYS. Your job must have the JACCT
privilege, or be logged in under [1,2]. Note
that the USAGE accounting system should be used
instead of the FACT file accounting system, as
FACT is no longer supported. Refer to the
QUEUE. UUO and the TOPS-10/20 Usage Accounting
Manual for information about writing USAGE
accounting entries. The system accounting file
entry must require fewer than 24 words of
memory. This entry may be stored (by DAEMON)
for as long as 10 minutes before being written.
DAEMON closes the current FACT file when its
length reaches 2048 blocks, and opens a new FACT
file.
The argument list for the .FACT function is:
addr: .FACT
first word of entry
. . .
last word of entry
Your job must have the JACCT privilege, or be
logged in under [1,2]. Note that the USAGE
accounting system should be used instead of the
FACT file accounting system, as FACT is no
longer supported. Refer to the QUEUE. UUO and
the TOPS-10/20 Usage Accounting Manual for
information about writing USAGE accounting
entries.
4 .DMQUE Reserved for use by DIGITAL.
22-52
DAEMON [CALLI 102]
Code Symbol Function
5 .DMERR Makes an entry in the error file; the third and
following words of the argument block are
written into the error file. Your job must have
JACCT or [1,2] privileges.
The argument block for the .DMERR function is:
addr: .DMERR
EXP ercode
first word of message
. . .
last word of message
where: ercode is a code to be entered in the
error file.
first word of message ... last word of message
are words of data to be entered in the error
file SYS:ERROR.SYS. The codes are:
Ercode Symbol Meaning
1 .ESWHY Answer to ONCE's Why Reload
question, and comment, if any.
2 .ESMSE Continuable stopcode.
3 .ESMPE KI memory parity error.
4 .ESNXM KI non-existent memory error.
5 .ESCIN Information extracted from a
crash.
6 .ESCPE Channel-detected memory parity
error or non-existent memory.
7 .ESDRE DAEMON restarted.
10 .ESHDE Hardware-detected device error.
11 .ESMDE Massbus device error.
12 .ESDXE DX20 device error.
14 .ESSWE Software event. The events are:
Code Symbol Event
1 .SWEPK POKE. function.
2 .SWESN SNOOP. function.
3 .SWETP TRPSET function.
4 .SWERT RTTRP. function.
5 .SWMS1 Miscellaneous debugging
event number 1.
6 .SWMS2 Miscellaneous debugging
event number 2.
22-53
DAEMON [CALLI 102]
Code Symbol Function
Ercode Symbol Meaning
15 .ESCSE Configuration status change.
The condition change codes are
listed below:
Code Symbol Status Change
0 .CSCAT Attach function
1 .CSCDT Detach function.
2 .CSCXC Exchange function.
3 .CSCTC Date/time change.
4 .CSCCF DETACH CPU function.
5 .CSCCO ATTACH CPU function.
6 .CSCNF Node off-line.
7 .CSCNO Node on-line.
10 .CSCMO Set memory on-line.
11 .CSCMF Set memory off-line.
16 .ESSLM System log message.
17 .ESDEB Software requests data.
21 .ESTAP Magnetic tape errors (see
TAPSER).
30 .ESKLE KL processor error data from
RSX-20F front end.
31 .ESFER Front end reload.
33 .ESHSB KS processor halt status block.
42 .ESTPS Magnetic tape performance
statistics code (see TAPSER).
43 .ESCFG Maximum configuration in
AVAIL.SYS.
44 .ESMRV Monitor run values in AVAIL.SYS.
45 .ESDSC Disk statistics (usually from a
crash).
46 .ESBAV Beginning of AVAIL.SYS time
stamp.
47 .ESEAV End of AVAIL.SYS time stamp.
50 .ESDLE DL10 hardware error.
51 .ESKIP KI parity/non-existent memory
interrupt.
52 .ESKLP KL parity/non-existent memory
interrupt.
54 .ESKSN KS non-existent memory trap.
55 .ESKPT KL/KS parity trap.
56 .ESSNX Non-existent memory scan.
57 .ESSPR Parity memory scan.
61 .ESKDT KL data parity trap.
22-54
DAEMON [CALLI 102]
Code Symbol Function
Ercode Symbol Meaning
62 .ESMOT KL data parity interrupt.
63 .ESCSB CPU status block.
64 .ESDSB Device status block.
67 .ESKAE KL addressing failure.
71 .ESLPT Line printer error.
72 .ESHCC Hard copy controller entry.
73 .ESULD Microcode load.
100 .ESDTC Date/time change (obsolete).
201 .ESNUS Network utility started.
202 .ESNDL Network down-line load.
203 .ESNUD Network up-line dump.
210 .ESNHE Network hardware error.
211 .ESNSE Network software error.
220 .ESNOE Network operator entry.
221 .ESNTC Network topology change.
230 .ESNLC Network line counter.
231 .ESNNS Network node statistic entry.
377 .ESHIA Hiatus in ERROR.SYS.
775 .ESOFF Marker for first word of block
as pointer to start of first
entry.
777 .ESEOF End-of-file flag.
.DMERR is a privileged function; to use it you
must have the JACCT privilege, or be logged in
under [1,2].
NOTE
For a complete description of the format
of the error file, refer to the SPEAR
Reference Manual.
6 .DMCTL Reserved for use by DIGITAL.
Normal Return
The monitor performs the specified function and issues a DAEFIN
monitor call to make the job runnable. The ac is cleared.
22-55
DAEMON [CALLI 102]
Error Return
If DAEMON is not running, control returns to the error return,
but the ac is unchanged.
If DAEMON is running, an error code is returned in the ac, and
control returns to the error return. The error codes and their
meanings are:
Code Symbol Error
1 DMILF% Illegal function code.
2 DMACK% Address check.
3 DMWNA% Incorrect number of arguments.
4 DMSNH% Impossible error. If this occurs, please report
it to your Software Support Specialist.
5 DMCWF% File cannot be written.
6 DMNPV% Not enough privileges.
7 DMFFB% Incorrect format for FACT file entry.
10 DMPTH% Invalid path.
Example
MOVE T1,[2,,ADDR]
DAEMON T1,
JRST ERROR
JRST CONTIN
. . .
ADDR: .CLOCK
EXP 5
This code puts the program to sleep for 5 seconds.
Related Calls
DAEFIN
22-56
DATE [CALLI 14]
DATE [CALLI 14]
Function
Returns a code giving the system date. The code is an integer
given by the formula:
code = 31[12(year-1964)+(month-1)]+(day-1)
You can obtain the current day, month, and year using the
formulas:
day = mod(code,31)+1
month = mod(code/31,12)+1
year = (code/372)+1964
The DATE call is equivalent to using GETTAB to obtain item
%CNDAT. The day, month, and year are stored in GETTAB items
%CNDAY, %CNMON, and %CNYER, respectively. Your program can avoid
the computations needed to interpret the data returned from the
DATE call by GETTABing the specific items, but the efficient
program will avoid performing three separate GETTAB calls by
GETTABing %CNDAT and then dividing the data into its appropriate
components.
Calling Sequence
DATE ac,
return
Example
The following macro computes the current day, month, and year.
DEFINE CURDAT(DAY,MONTH,YEAR)<
DATE T1,
IDIVI T1,^D31
ADDI T2,1
MOVEM T2,DAY
IDIVI T1,^D12
ADDI T2,1
MOVEM T2,MONTH
ADDI T1,^D1964
MOVEM T1,YEAR
>
Related Calls
TIMER
22-57
DEBRK. [CALLI 137]
DEBRK. [CALLI 137]
Function
Dismisses a PSI software interrupt, reenabling any conditions
disabled by the interrupt. See Chapter 6 for a discussion of the
software interrupt system.
On a DEBRK. monitor call, the monitor scans the queue of pending
interrupts, looking for conditions requiring service by an
interrupt routine. If one is found, the interrupt occurs and
control passes to the interrupt routine. If no such condition is
found, DEBRK. restarts the interrupted process beginning at the
point within your job where the interrupt occurred (usually the
instruction after the last instruction that was executed).
Calling Sequence
DEBRK.
return 1
return 2
Return
The DEBRK. call normally returns to old PC (see Chapter 6).
Return 1 is taken if DEBRK. is not implemented; return 2 is taken
if there is no interrupt in progress.
Related Calls
PIBLK., PIINI., PIRST., PISAV., PISYS.
22-58
DEQ. [CALLI 152]
DEQ. [CALLI 152]
Function
Dequeues one or more requests for enqueued resources, or
relinquishes ownership of one or more enqueued resources. See
Chapter 8 for a discussion of the ENQ/DEQ facility.
Calling Sequence
|
| / MOVE ac,[XWD .DEQDR,addr] \
| | MOVE ac,[XWD .DEQDA,0] |
| \ MOVE ac,[XWD .DEQID,request-id] /
| DEQ. ac,
| error return
| normal return
where: function is one of the function codes listed below.
addr is the address of an argument block, which is the
same as the one used for the ENQ. call.
request-id is a request identifier that you specified in
the ENQ. argument block.
For a discussion of these parameters and the format of each
request block, refer to the ENQ. call.
The function codes and their meanings are:
Code Symbol Function
0 .DEQDR This function dequeues a specific request.
After a normal return, the monitor has removed
the specified request from the specified queue,
or the monitor has dissolved the lock between
the job and the specified resource. The error
return is taken if you set up the call in an
incorrect format, or if you have no pending
requests and you are not the owner of the
specified resource. On an error return, the
monitor returns an error code in the ac.
22-59
DEQ. [CALLI 152]
Code Symbol Function
1 .DEQDA This function removes all of your requests for
ownership and dissolves all of your resource
locks. The error return is taken if you write
the call in an incorrect format, or if you do
not have any pending requests or locks. On an
error return, the monitor returns an error code
in the ac. You should perform this function
before EXITing; otherwise, when you perform a
CLOSE, the function will fail but the nature of
the failure will be difficult to determine. The
monitor automatically performs the .DEQDA
function when you issue a LOGOUT monitor call.
2 .DEQID This function requires the request-id in the
right half of the ac. The monitor removes all
requests of yours with the specified request-id
from resource queues, and it dissolves all locks
of yours with the specified request-id. You
should specify this function when you are
dequeueing requests that were made in the same
ENQ. argument block. The error return is taken
if you have set up the call incorrectly, if you
have no pending requests, or if you are not the
owner of a resource.
Normal Return
The specified requests are dequeued and the specified locks are
dissolved.
Error Return
If an error is found in one of the requests in a multiple request
DEQ. monitor call, the error return is taken and the monitor
returns an error code in the ac. However, the ENQ/DEQ facility
continues processing until all of the dequeue requests have been
performed. Therefore, the monitor will have dequeued all valid
requests whether or not an error resulted from another request in
the same monitor call. If errors are found in several requests
of the same monitor call, the error code returned in the ac
reflects the last error found.
If you specify that you want to dequeue a request or dissolve a
lock associated with a pooled resource, the monitor will return
an error code if you attempt to dequeue more resources than you
own within the pool. However, you can dequeue a subset of those
resources that you own within a pool, still retaining ownership
of those you did not dequeue. Therefore, you cannot dequeue more
resources than you own, but you do not have to dequeue all that
you own in one request.
22-60
DEQ. [CALLI 152]
The error codes for the DEQ. call are identical to those of the
ENQ. call. They are listed in the description of the ENQ.
call.
Example
DEQ. monitor calls that specify multiple requests are treated as
multiple DEQ. monitor calls, each specifying a single request.
This is not true for the ENQ. monitor call. For example:
MOVE T1 [XWD .DEQDR,DEQBLK]
DEQ. T1,
JRST ERROR
JRST SUBR
DEQBLK: 2,,^D8
0,,400000
0,,2
POINT 7,[ASCIZ/TEST/]
^D10,,1
0,,4
POINT 7,[ASCIZ/TESER/]
^D10,,1
The above code is, in effect, identical to the following, but the
following is less efficient:
MOVE T1,[XWD .DEQDR,DEQ1]
DEQ. T1,
JRST ERROR
DEQ: MOVE T1,[XWD .DEQDR,DEQ2]
DEQ. T1,
JRST ERROR
JRST SUBR
DEQ1: 1,,^D5
0,,400000
0,,2
POINT 7,[ASCIZ/TEST/]
^D10,,1
DEQ2: 1,,^D5
0,,400000
0,,4
POINT 7,[ASCIZ/TESER/]
^D10,,1
Related Calls
ENQ., ENQC.
22-61
DEVCHR [CALLI 4]
DEVCHR [CALLI 4]
Function
Returns the physical characteristics of a specified device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DEVCHR ac,
| return
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Return
If the device is not found, or if your program has not
initialized the device, the monitor clears the ac. Otherwise,
the ac contains flags giving the physical characteristics of the
device. The flags and their meanings are:
Bits Symbol Device or Mode
0 DV.DRI DECtape whose directory is in memory; you can
clear this bit by using the REASSI monitor call
for the device.
1 DV.DSK Disk.
2 DV.CDR Card device. If DV.IN is set, it is a card
reader; if DV.OUT is set, it is a card punch.
3 DV.LPT Line printer.
4 DV.TTA Terminal that is currently controlling a job.
5 DV.TTU Terminal that is in use.
6 DV.2IO Device can do input and output at the same time.
7 DV.DIS Special display device. Note that this does not
indicate the "display" terminal characteristic.
22-62
DEVCHR [CALLI 4]
Bits Symbol Device or Mode
8 DV.LNG Device with long dispatch table; this means that
monitor calls other than INPUT, OUTPUT, CLOSE,
and RELEAS can perform real functions.
9 DV.PTP Papertape punch.
10 DV.PTR Papertape reader.
11 DV.DTA DECtape.
12 DV.AVL The device is available or is assigned to your
job.
13 DV.MTA Magnetic tape.
14 DV.TTY Terminal.
15 DV.DIR The device is a directory device. You can test
this bit to determine whether ENTER/LOOKUP must
be done before you can start I/O to the device.
16 DV.IN Input device.
17 DV.OUT Output device.
18 DV.ASC The device has been initialized by the ASSIGN
monitor command.
19 DV.ASP The device has been assigned by the INIT, OPEN,
or FILOP. monitor call.
Bits 20-35 specify the modes that are legal for the device.
20 DV.M17 Mode 17, dump. This is the same as IO.MOD =
.IODMP returned from a GETSTS monitor call.
21 DV.M16 Mode 16, dump records. This is the same as
IO.MOD = .IODPR returned from a GETSTS monitor
call.
22 DV.M15 Mode 15, image dump. This is the same as IO.MOD
= .IOIDP returned from a GETSTS monitor call.
23 DV.M14 Mode 14, binary. This is the same as IO.MOD =
.IOBIN returned from a GETSTS monitor call.
24 DV.M13 Mode 13, image binary. This is the same as
IO.MOD = .IOIBN returned from a GETSTS monitor
call.
22-63
DEVCHR [CALLI 4]
Bits Symbol Device or Mode
25 DV.M12 Mode 12, reserved for use by DIGITAL.
26 DV.M11 Mode 11, reserved for use by DIGITAL.
27 DV.M10 Mode 10, image. This is the same as IO.MOD =
.IOIMG returned from a GETSTS monitor call.
28 DV.M7 Mode 7, reserved for use by customers.
29 DV.M6 Mode 6, reserved for use by customers.
30 DV.M5 Mode 5, reserved for use by DIGITAL.
31 DV.M4 Mode 4, reserved for use by DIGITAL.
32 DV.M3 Mode 3, byte. This is the same as IO.MOD =
.IOBYT returned from a GETSTS monitor call.
33 DV.M2 Mode 2, packed image. This is the same as
IO.MOD = .IOPIM returned from a GETSTS monitor
call.
34 DV.M1 Mode 1, ASCII line. This is the same as IO.MOD
= .IOASL returned from a GETSTS monitor call.
35 DV.M0 Mode 0, ASCII. This is the same as IO.MOD =
.IOASC returned from a GETSTS monitor call.
NOTE
To check for the NUL device, use DEVCHR to see if both
DV.DSK and DV.TTY are set.
Example
MOVE T1,[SIXBIT/DEV/]
DEVCHR T1,
TLNN T1,(DV.DSK)
JRST NOTDSK
JRST ISDSK
This example checks to see if device DEV (assumed to be a logical
name) is a disk. The call returns to NOTDSK if it is not and
returns to ISDSK if it is.
Related Calls
DEVLNM
22-64
DEVLNM [CALLI 107]
DEVLNM [CALLI 107]
Function
Assigns (or clears) a logical device name to a device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| MOVE ac+1,[SIXBIT/name/]
| DEVLNM ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a device
to which you wish to assign a logical name.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
name is the logical name to be assigned to the device.
If name is binary zero, any existing logical name
assignment will be cleared.
Normal Return
The logical name is assigned to the device; the ac and ac+1 are
unchanged.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-3 DVLNA% Device not assigned to your job.
-2 DVLIU% Logical name already in use.
-1 DVLNX% No such device or channel.
Related Calls
DEVCHR, DEVNAM, DEVOP., DEVPPN, DEVSIZ, DEVSTS, DEVTYP, REASSI
Common Errors
Assuming that DEVLNM also causes the device to become associated
with your job. Use the REASSI call to actually obtain the
device.
22-65
DEVNAM [CALLI 64]
DEVNAM [CALLI 64]
Function
Returns the physical name of a device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DEVNAM ac,
| error return
| normal return
where: device is the logical device name whose physical name is
desired.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Normal Return
The SIXBIT physical name of the device is returned in the ac.
|
| The normal return is also taken if a device has been partially
| deassigned. For example, if the user halts the program before
| the deassignment operation is complete. In this case, the ac is
| returned clear.
Error Return
If the specified device does not exist or if the specified
channel is not initialized, the ac is cleared.
Related Calls
DEVCHR, DEVLNM, DEVOP., DEVPPN, DEVSIZ, DEVSTS, DEVTYP
22-66
DEVOP. [CALLI 171]
DEVOP. [CALLI 171]
Function
Performs miscellaneous device functions for devices other than
terminals, tapes, disks, or TSKs. Use TRMOP. for terminal
functions, TAPOP. for tape functions, DISK. for disk functions,
or TSK. for TSK functions.
Calling Sequence
|
| MOVE ac,[XWD length,addr]
| DEVOP. ac,
| error return
| normal return
| . . .
| addr: EXP fcn-code
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| addr+2: arglst
where: length is the length of the argument block.
addr is the address of the argument block.
fcn-code is one of the function codes described below.
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
arglst begins the list of arguments for the given
function.
All function codes listed below use the 2-word argument list
shown above. Additionally, some function codes accept a longer
argument list. For those codes that accept an argument list
longer than 2 words, the argument list format is shown with the
description of the function code.
The function codes are defined within the following four ranges:
0000-0777 Performs a specific action.
1000-1777 Reads a parameter.
2000-2777 Sets a parameter.
3000-3777 Reserved for customer definition.
22-67
DEVOP. [CALLI 171]
The Read/Set function codes are parallel (for example, function
code 1002 reads a parameter and code 2002 sets the same
parameter). The symbol .DFSET is equal to 1000, and can be added
to the read parameter to establish the offset for the set
parameter. Therefore, to read the page counter, use function
.DFPCT. To set the page counter, use .DFPCT+.DFSET.
The monitor returns values in the ac for the Read functions.
The function codes and their meanings are:
Code Symbol Function
1 .DFLLV Loads the standard vertical forms control unit.
2 .DFENV Enables the system to load a non-standard
vertical forms control unit.
3 .DFDVL Disables loading non-standard vertical forms
control unit.
4-10 Reserved for use by Digital.
11 .DFLR2 Loads a translation RAM into LP20. This
function takes a 4-word argument list of the
form:
|
| addr: .DFLR2
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| 8-bit byte count for RAM
| address of RAM buffer
12 .DFLV2 Loads a VFU through LP20. This function takes a
4-word argument list of the form:
|
| addr: .DFLV2
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| 7-bit byte count of VFU
| address of VFU data
13 .DFMDC Clears DVCMDA. This is the flag indicating
whether the device is controlled by MDA (in
GALAXY Version 4.1 and later). This function
requires privileges.
14 .DFMDS Sets DVCMDA. This is the flag indicating
whether the device is controlled by MDA (in
GALAXY Version 4.1 and later). This function
requires privileges.
22-68
DEVOP. [CALLI 171]
Code Symbol Function
15-777 Reserved for use by Digital.
1000 .DFPCT Returns the line printer's page counter in the
ac.
2000 Sets the page counter value in addr+2. The page
counter is limited to 12 bits. The argument
list for .DFPCT is:
|
| addr: .DFPCT
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| EXP counter
1002 .DFHCW Reads the line printer characteristics. The
printer characteristics are returned in the ac
in the form:
Bits Symbol Meaning
0 DF.LCP Lowercase capability.
1 DF.PGC Has page counter.
2 Reserved.
3-5 DF.VFT Code for type of vertical forms
control unit (VFU). The type
codes are:
Code Symbol Type
0 .DFVTO Papertape VFU.
1 .DFVTD DAVFU.
2 .DFVTN No VFU.
6-8 DF.TYP Code for character set codes.
The set codes are:
Code Symbol Character set
0 .DFC64 Set of 64
characters.
1 .DFC95 Set of 95
characters.
2 .DFC28 Set of 128
characters.
3 .DFVAR Variable size
set.
22-69
DEVOP. [CALLI 171]
Code Symbol Function
Bits Symbol Meaning
9-11 DF.CLS Code for line printer class.
The class codes are:
Code Symbol Class
0 .DFSUK Unknown.
1 .DFSBX BA10.
2 .DFSLC LP100.
3 .DFS20 LP20 (20F).
4 .DFSA1 LP11.
5 .DFSA2 LP20 (ANF
DN8X).
12-14 DF.CLU Line printer class, as the type
of unit. The unit codes are:
Code Symbol Type
0 .DFUUK Unknown.
1 .DFUFG LP05-type.
2 .DFULN LN01-type.
18-35 DF.CSN Character set name, in SIXBIT.
2002 Sets the line printer characteristics. The
argument list for .DFHCW is:
|
| addr: .DFHCW
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| EXP characteristics
Defines the characteristics using the
definitions listed above for the Read function.
1003 .DFRES The extended I/O error status for the given
device is returned in the ac.
The error status is returned as a code. The
error codes are:
Code Symbol Error
1 IOPLE% Page limit exceeded (LPT).
2 IOVFE% VFU format error (LPT).
3 IOLTE% Label type error (MTA).
4 IOHLE% Header label error (MTA).
22-70
DEVOP. [CALLI 171]
Code Symbol Function
Code Symbol Error
5 IOTLE% Trailer label error (MTA).
6 IOVLE% Volume label error (MTA).
7 IODER% Hard device error.
10 IOPAR% Parity error.
11 IOWLE% Write-lock error.
12 IOIPO% Illegal positioning operation
(MTA).
13 IOBOT% Beginning of tape (MTA).
14 IOIOP% Illegal operation (MTA).
15 IOFNF% File not found (MTA).
16 IOCAN% Operator cancelled volume
switch request (MTA).
17 IOTMV% Too many volumes in volume set
(MTA).
20 IONND% Network node down.
21 IOUNC% Undefined character interrupt
(LP20).
22 IORPE% RAM parity error (LP20).
23 IOLRA% Tape labelling request was
aborted by a RESET UUO (MTA).
24 IOVPF% Volume protection failure
(MTA).
25 IOFPF% File protection failure (MTA).
26 IOUEF% Unexpired file (MTA).
27 IONDD% Network device disconnected.
1004 .DFRDS A status code for the specified device is
returned in the ac.
The status codes and their meanings are:
Bit Symbol Status
0 DF.OFL Device off-line.
34 DF.LLE DAVFU load-enabled.
35 DF.LVE A VFU error occurred.
The bits returned in the left half of the ac are
device-independent; the bits returned in the
right half are device-specific.
Normal Return
The specified function is executed.
22-71
DEVOP. [CALLI 171]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-1 DFACS% Address check.
0 DFIFC% Illegal function code.
1 DFPRV% Not enough privileges.
2 DFIFD% Function invalid for device.
3 DFNLR% Value out of range.
4 DFNXD% Nonexistent device.
5 DFNDV% No DAVFU (LPT only).
6 DFNIA% Device not initialized.
7 DFDOL% Device off-line.
10 DFCNS% Page counter not set (LPT only).
11 DFNPC% No page counter (LPT only).
12 DFENI% Extended error recovery not implemented.
13 DFNVC% Non-variable character set.
If the monitor call has not been implemented on your system, the
error return is taken and the monitor leaves the ac unchanged.
Related Calls
DEVCHR, DEVLNM, DEVNAM, DEVPPN, DEVSIZ, DEVSTS, DEVTYP
22-72
DEVPPN [CALLI 55]
DEVPPN [CALLI 55]
Function
Returns the project-programmer number (PPN) associated with a
disk device or an ersatz device. Note that the DEVPPN UUO does
not return SFD names. It is recommended that programs use the
PATH. call to return complete directory names.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DEVPPN ac,
| error return
| normal return
where: device is the SIXBIT physical, logical, or ersatz name of
a disk device.
channo is a channel number for a disk device.
udx is the Universal Device Index for a disk device.
Normal Return
The PPN for the specified device is returned in the ac. Note
that if you have enabled /NEW in your search list, the returned
PPN for SYS will be [1,5] instead of [1,4].
Error Return
The error return occurs in two cases. The cause of the error is
indicated by the value returned:
o If zero is returned in the ac; the device does not exist, or
you have not initialized it.
o If your own PPN is returned; the device is not a disk device.
Related Calls
DEVCHR, DEVLNM, DEVNAM, DEVOP, DEVSIZ, DEVSTS, DEVTYP, PATH.
22-73
DEVSIZ [CALLI 101]
DEVSIZ [CALLI 101]
Function
Returns the buffer size and standard number of buffers for a
device.
Calling Sequence
MOVEI ac,addr
DEVSIZ ac,
error return
normal return
. . .
| addr: EXP status
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
where: addr is the address of the argument block. Normally, the
address points to the OPEN block used to initialize the
device.
status is the I/O status word, which must match the
information given when the channel was initialized with
INIT, OPEN, or FILOP.
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Note that the format for the argument block is identical to the
format used for the OPEN monitor call and that the OPEN block is
ordinarily used as the DEVSIZ block. The number and sizes of
buffers differ among different data modes, and depending on mode
modifier bits.
Normal Return
The ac contains the default number of buffers in its left half,
and the default buffer size (including a 3-word header) in its
right half. If you specify a device that was initialized in dump
mode, the monitor clears the ac and takes the normal return.
22-74
DEVSIZ [CALLI 101]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-2 DVSIM% Illegal data mode.
-1 DVSNX% Nonexistent device.
0 DVSDM% Dump mode specified; therefore, buffer size is
not applicable.
Related Calls
DEVCHR, DEVLNM, DEVNAM, DEVOP., DEVPPN, DEVSTS, DEVTYP
22-75
DEVSTS [CALLI 54]
DEVSTS [CALLI 54]
Function
Returns the device status word from the device data block (DDB).
This call returns the last CONI performed for the device, which
is different for each device type and model. To interpret the
device status word, refer to the hardware manual for the specific
device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DEVSTS ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of a channel.
udx is the Universal Device Index for a device.
You can specify any device on an I/O bus. Where multiple units
are on a single controller, the status of the controller is
returned.
Normal Return
The device status word is returned in the ac. If the service
routine for the device does not store a CONI, the returned word
may be useless. Devices having both a controller and data
interrupt store the controller CONI.
Error Return
If the device does not exist or is not initialized, the ac is
cleared.
Related Calls
DEVCHR, DEVLNM, DEVNAM, DEVOP., DEVPPN, DEVSIZ, DEVTYP
22-76
DEVSTS [CALLI 54]
Common Errors
o Confusing "device status" (DEVSTS) with "I/O status"
(GETSTS). GETSTS returns the file (I/O) status bits, which
are documented in Volume 1. DEVSTS returns the hardware
device status.
o Confusing the "device status" returned by DEVSTS with the I/O
error status that is returned by the DEVOP. UUO.
22-77
DEVTYP [CALLI 53]
DEVTYP [CALLI 53]
Function
Returns the physical properties for a device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DEVTYP ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Normal Return
If the ac is 0, there was no such device; otherwise, the device
type bits are returned in the ac as follows:
Bits Symbol Characteristic
0 TY.MAN Directory device; a LOOKUP/ENTER is mandatory.
1-7 Reserved.
8 TY.GEN If the argument is a SIXBIT name, this bit is
set if the device is generic.
9 TY.MDA Controlled by MDA (mountable device allocator).
10 TY.EHF Extended hardware features; for example, this
bit is set for a line printer with lowercase
capability.
11 TY.MPX MPX-controllable.
12 TY.AVL Available to your job.
13 TY.SPL Spooled.
14 TY.INT Interactive; there is output after each break
character.
22-78
DEVTYP [CALLI 53]
Bits Symbol Characteristic
15 TY.VAR Capable of variable buffer size.
16 TY.IN Input capability.
17 TY.OUT Output capability.
18-26 TY.JOB Job number to which the device is currently
assigned.
27-28 Reserved.
29 TY.RAS Restricted; assigned only to privileged job or
by MOUNT command.
30-35 TY.DEV One of the following device type codes:
Code Symbol Device Type
0 .TYDSK Disk.
1 .TYDTA DECtape.
2 .TYMTA Magnetic tape.
3 .TYTTY Terminal.
4 .TYPTR Papertape reader.
5 .TYPTP Papertape punch.
6 .TYDIS Display unit.
7 .TYLPT Line printer.
10 .TYCDR Card reader.
11 .TYCDP Card punch.
12 .TYPTY Pseudo-terminal.
13 .TYPLT Plotter.
14 .TYEXT External task.
15 .TYMPX MPX-controlled.
16 .TYPAR PA611R on a DC44.
17 .TYPCR PC11(R) on a DC44.
20 .TYPAP PA611P on a DC44.
21 .TYLPC LPC-11 on a DC44.
22 .TYPCP PC-11(P) on a DC11.
23 .TYWTY WTY device on a DC11.
24 .TYTSK Network task.
25 .TYD78 DAS78 device.
26 .TYRDA Remote data entry device.
27 .TYMCR Monitor command interpreter
(MCR) device.
30 .TYDRA DTR01/DR01 device.
31 .TYKDP KMC/DUP interface.
32 .TYDTE DTE interface.
33 .TYDDP DDP device.
34 .TYDMR DMR device.
35 .TYRX2 RX02 floppy disk controller.
36-57 Reserved for use by DIGITAL.
60-77 Reserved for use by customers.
22-79
DEVTYP [CALLI 53]
Error Return
The DEVTYP monitor call should never take the error return.
Related Calls
DEVCHR, DEVLNM, DEVNAM, DEVOP., DEVPPN, DEVSIZ, DEVSTS
Common Errors
Assuming that a normal return indicates that the device exists.
22-80
DIAG. [CALLI 163]
DIAG. [CALLI 163]
Function
Provides diagnostic functions for devices and CPUs.
Calling Sequence
MOVE ac,[-len,,addr]
DIAG. ac,
error return
normal return
. . .
addr: fcn-code
argument
where: len is the length of the argument list.
addr is the address of the argument list.
fcn-code is one of the function codes listed below.
argument is different for each function code; each type
of argument is described with its function code below.
Code Symbol Meaning
0-6 Reserved for use by DIGITAL.
7 .DIAKU Returns the controller and unit numbers for a
device. The format of the argument list is:
addr: EXP .DIAKU
SIXBIT/device/
On a normal return, Bits 0-8 contain 0, Bits
9-17 contain the controller device code, Bits
29-32 contain the unit number, and Bits 33-35
contain the slave unit number.
10 .DIACS Forces a CPU status block read on a CPU and
forces DAEMON to make an error entry (code 63)
in ERROR.SYS. (The error codes and entry types
are listed with the DAEMON call.) This function
requires that you have JP.POK, [1,2], or JACCT
privileges. The format of the argument list is:
addr: EXP .DIACS
EXP CPU-number
22-81
DIAG. [CALLI 163]
Code Symbol Meaning
11 .DIADS Reads the device status for all devices on the
specified CPU into a GETTAB table in the monitor
and forces DAEMON to make an error entry (code
64) in ERROR.SYS. (The error codes and entry
types are listed with the DAEMON call.) This
function requires that you have JP.POK, [1,2],
or JACCT privileges. The format for the
argument list is:
addr: EXP .DIADS
EXP CPU-number
13 .DIANL Enables and disables automatic reload of
microcode in DX20 when the DX20 fails.
addr: EXP .DIANL
EXP flag,CPUn
where the flag specifies the action and CPUn is
the CPU number. If flag=0, automatic reloading
of the DX20 is enabled. A non-zero value for
the flag disables auto-reload. The CPU number
can be -1 to indicate all CPUs.
15 .DIASM Seizes the specified magnetic tape
controller(s). The argument list is formatted
as:
addr: EXP .DIASM
SIXBIT/device/
device may be either a device name, or zero to
indicate all units.
16 .DIARM Releases the specified magnetic tape
controllers. The argument list is formatted as:
addr: EXP .DIARM
SIXBIT/device/
device may be either a device name, or zero to
indicate all units.
17 .DIELD Enables microcode loading. The argument list is
formatted as:
addr: XWD CPUno, .DIELD
22-82
DIAG. [CALLI 163]
Code Symbol Meaning
20 .DIDLD Disables microcode loading. The format of the
argument list is:
addr: XWD CPUno, .DIDLD
21 .DILOD Loads the microcode. The format of the argument
block is:
addr: XWD CPUno, .DILOD
22 .DIISM Sets IPA channel (CI20 or NTA20) maintenance
mode. The format of the argument block is:
addr: XWD CPUno, .DIISM
23 .DIICM Clears IPA channel maintenance mode. The format
of the argument block is:
addr: XWD CPUno, .DIICM
107 .DIACC Manipulates the CI port counters. The format of
the argument list is:
addr: XWD CPUno, .DIACC
XWD channo,sub-ftn
The only valid channel number is 7. The
counters are manipulated in the manner indicated
in the sub-function. Valid sub-functions are:
Code Function
0 Gets counters.
1 Releases counters.
2 Point counters.
3 Reads counters.
Normal Return
The specified function has been performed.
22-83
DIAG. [CALLI 163]
Error Return
The ac is unchanged if the DIAG. monitor call is not implemented
on the system. Otherwise, one of the following error codes is
returned in the ac:
Code Symbol Meaning
1 DIANP% Not enough privileges.
2 DIAIA% Illegal number of arguments.
3 DIAIC% Illegal controller number.
4 DIAIU% Illegal unit number.
5 DIAAA% Some units already assigned.
6 DIADM% Unit not in diagnostic mode.
7 DIAAJ% Unit assigned to another job.
10 DIAFC% Not enough free core.
11 DIAAU% No assigned units.
12 DIACP% IOWD crosses page boundary.
13 DIAIF% Illegal function.
14 DIAVC% Job must not be virtual.
15 DIANC% No such CPU.
16 DIANR% CPU not running.
17 DIABA% Invalid argument list.
20 DIACI% No CI port on specified CPU.
21 DIATO% The Read Port Counters function timed out.
22 DIANK% No NI port on specified CPU.
23 DIARF% Microcode reload failed.
24 DIANM% No microcode available.
25 DIAPN% CI or NI port not running.
22-84
DISK. [CALLI 121]
DISK. [CALLI 121]
Function
Performs miscellaneous disk functions.
Calling Sequence
MOVE ac,[XWD fcn-code,addr]
DISK. ac,
error return
normal return
where: fcn-code is one of the function codes described below.
addr is the address of the argument list. Each function
code requires a different argument list. Therefore, the
argument lists are described below, with the appropriate
function codes.
Normal Return
On a successful return from the call, the function you specified
is accomplished, and neither the ac nor the argument list is
affected.
Error Return
Each function can produce its own set of error codes on an error
return from the DISK. call. The error code is returned in the
ac. A negative error code is one of the following,
general-purpose error codes:
Code Symbol Meaning
-2 DUINP% Not enough privileges to perform the function.
-1 DUILF% Illegal function requested.
A positive error code indicates an error that is specific to the
function code. The ac is unchanged if DISK. is not implemented
on your system. In the argument lists described below:
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
structure is the SIXBIT name of a file structure.
22-85
DISK. [CALLI 121]
The function codes, their meanings, argument lists, and error
codes are:
Code Symbol Function
0 .DUPRI Sets the disk priority level. The argument list
for .DUPRI is:
addr: XWD channo,priority
where: channo is an initialized channel number.
You can use -2 to indicate all channels
for the job, or -1 for all explicitly
initialized channels for this job.
priority is in the range -3 to +3 (0 is
normal priority and +3 is the highest
priority).
If you set the priority for a channel, the
setting overrides the setting for the job, and
remains in effect until you change it or release
the channel.
If you set the priority for the entire job, the
setting remains in effect until you change it
with another DISK. call or with a SET DSKPRI
monitor command.
The maximum priority level you can use for your
job is stored in bits 1 and 2 (JP.DPR) of the
job privilege table (GETTAB table 6, .GTPRV).
On an error return from this function, one of
the following error codes may be stored in the
ac:
Code Symbol Meaning
1 DUPIP% Priority higher than JP.DPR.
2 DUPNO% Channel not initialized.
3 DUPIA% Illegal channel number or code.
1 .DUSEM Sets PDP-10/PDP-11 compatibility mode (22-sector
mode on the RP04/RP06) for the channel. .DUSEM
is a privileged function. The argument list for
.DUSEM is:
addr: EXP channo
22-86
DISK. [CALLI 121]
Code Symbol Function
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUSID% Illegal device.
2 DUSCM% The device does not support
22-sector mode.
2 .DUSTM Clears PDP-10/PDP-11 compatibility mode. .DUSTM
is a privileged function. The argument list for
.DUSTM is:
addr: EXP channo
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUSID% Illegal device.
2 DUSCM% The device does not support
22-sector mode.
3 .DUUNL Unloads an RP04 or RP06 drive. .DUUNL is a
privileged function. The argument list for
.DUUNL is:
addr: SIXBIT/device/
where device is the name of a specific unit,
such as RPA0.
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUUIU% Illegal unit name.
2 DUUNI% Structure is illegal or not
available.
3 DUUNU% Device cannot be unloaded.
22-87
DISK. [CALLI 121]
Code Symbol Function
4 .DUOLS Takes a controller/channel off-line soon. The
monitor will continue I/O that is in progress,
but will not use the controller for new I/O
requests. .DUOLS is a privileged function. The
argument list for .DUOLS is:
addr: SIXBIT/controller/
where: controller is the name of a disk
controller, such as RPA.
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUOIP% Specified controller/channel is
being put off-line.
2 DUOSK% Nonexistent controller.
3 DUOSS% If controller were set off-line,
there would not be enough
swapping space.
4 DUOIS% Unit in structure cannot be set
off-line.
5 DUOES% Not enough space for IOWDs.
6 DUOPI% Obsolete
5 .DUOLN Takes a controller/channel off-line now. The
monitor stops current I/O on that controller and
will not use the controller for new I/O
requests. .DUOLN is a privileged function. The
argument list for .DUOLN is:
addr: SIXBIT/controller/
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUOIP% Specified controller/channel is
being put off-line.
2 DUOSK% Nonexistent controller.
3 DUOSS% If controller were set off-line,
there would not be enough
swapping space.
22-88
DISK. [CALLI 121]
Code Symbol Function
Code Symbol Meaning
4 DUOIS% Unit in structure cannot be set
off-line.
5 DUOES% Not enough space for IOWDs.
6 DUOPI% Obsolete
6 .DUONL Puts a controller/channel on-line. This
function makes the controller available for I/O.
.DUONL is a privileged function. The argument
list for .DUONL is:
addr: SIXBIT/controller/
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUOIP% Specified controller/channel is
being put off-line.
2 DUOSK% Nonexistent controller.
3 DUOSS% If controller were set off-line,
there would not be enough
swapping space.
4 DUOIS% Unit in structure cannot be set
off-line.
5 DUOES% Not enough space for IOWDs.
6 DUOPI% Obsolete
7 .DUUFD Sets call for UFD compressor. The argument list
for .DUUFD is:
addr: EXP channo
where channo specifies a channel on which a file
is open. The UFD in which the file exists will
be compressed.
This function does not force the compression to
take place immediately, but sets the compression
to be performed on the next output CLOSE for a
file in this UFD. By default, the compression
is performed on an output CLOSE only if the
directory contains an empty block.
22-89
DISK. [CALLI 121]
Code Symbol Function
10 .DUSWP Removes a disk unit from the active swapping
list. .DUSWP is a privileged function. The
argument list for .DUSWP is:
addr: SIXBIT/device/
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUOIP% Specified controller/channel is
being put off-line.
2 DUOSK% Nonexistent controller.
3 DUOSS% If controller were set off-line,
there would not be enough
swapping space.
4 DUOIS% Unit in structure cannot be set
off-line.
5 DUOES% Not enough space for IOWDs.
6 DUOPI% Obsolete
11 .DUASW Adds a disk unit to the active swapping list.
.DUASW is a privileged function. The argument
list for .DUASW is:
addr: SIXBIT/device/
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUANU% No such unit.
2 DUAAI% Unit already in active swapping
list.
3 DUASF% SWPTAB is full.
4 DUAN4% This error code is obsolete.
5 DUANS% No swapping space (SWAP.SYS) on
pack.
22-90
DISK. [CALLI 121]
Code Symbol Function
12 .DUASD Adds a structure to the system dump list. The
argument list for .DUASD is:
addr: SIXBIT/structure/
On an error return from this function, one of
the following error codes may be returned in the
ac:
Code Symbol Meaning
1 DUDND% No such structure.
2 DUDNC% No crash space on structure.
3 DUDAD% Structure already on system dump
list.
4 DUDDF% System dump list full.
13 .DURSD Removes a structure from the system dump list.
The argument list for .DURSD is:
addr: SIXBIT/structure/
On an error return from this function, the
following error code may be returned in the ac:
Code Symbol Meaning
1 DUDNS% Structure not in system dump
list.
14 .DULEN Returns the number of written blocks in the file
in ac. The argument list for .DULEN is:
addr: EXP channo
15 .DUCLM Clears MDA wait for the specified unit. The
argument list for .DUCLM is:
addr: SIXBIT/device/
This function is used by the GALAXY batch and
spooling system and requires [1,2] or JACCT
privileges.
22-91
DISK. [CALLI 121]
Code Symbol Function
16 .DUFRE Returns the amount of free space in a given UFD
before the logged in quota is exhausted. The
argument list for .DUFRE is:
addr: SIXBIT/structure/
XWD p,pn
If there is no job logged in with the specified
PPN, the normal return is taken with bit 0 set.
This bit setting is returned by the DSKCHR call,
when DC.NPA is returned in .DCUFT (arg+1). This
signifies the fact that the quota is not
available.
On an error return from this function, the
following error code may be returned in the ac:
Code Symbol Meaning
1 DUFND% No such structure.
Related Calls
DSKCHR
22-92
DNET. [CALLI 207]
DNET. [CALLI 207]
Function
Obtains information about DECnet network nodes and environment in
your network area only. This monitor call is for use in system
programs associated with DECnet-10 Versions 3.0 and 4.0.
NOTE
In a multi-area DECnet environment, the DNET.UUO
only returns information about nodes in the same
area as the DECnet-10 host.
If DECnet-10 is running as an Ethernet endnode,
the DNET.UUO only returns information about the
DECnet-10 host node.
Calling Sequence
XMOVEI ac,addr
DNET. ac,
error return
normal return
addr: argument list
where: addr is the address of the argument list. Each function
code requires a different argument list. The first word
of every argument list (.DNFFL) contains the following
information in the following bit fields:
addr: flags+fcn-code,,len
where flags (DN.FLA) are:
Bit Symbol Meaning
0 DN.FLS Used with functions that return
information about single entities (a
node or link). Indicates that the
function should step through the list,
returning information about the next
entity in the list.
1 DN.FLK List information only about known
nodes.
22-93
DNET. [CALLI 207]
Bit Symbol Meaning
2 DN.FLR List information only about active
(reachable) nodes.
3 DN.FLE List information only about EXECUTOR
nodes. Refer to the DECnet-10 User's
Guide for more information.
The function codes and argument lists are described below:
Code Symbol Meaning
1 .DNLNN Lists node names. You specify the following at
addr:
addr: flag+<.DNLNN,,length>
BLOCK length-1
You must include one of the following flags:
Bit Symbol Meaning
1 DN.FLK List known nodes.
2 DN.FLR List active nodes.
3 DN.FLE List EXECUTOR nodes.
And length is the length of the block to
reserve.
The monitor returns the argument list in the
following form:
Offset Symbol Contents
1 .DNCNT Number of node names returned in
the list.
2 .DNNMS First node name
3 . . . Second node name
. . .
22-94
DNET. [CALLI 207]
Code Symbol Meaning
2 .DNNDI Returns information about a node. You specify
the following at addr:
addr: flag+<.DNNDI,,length>
node-name
BLOCK length-2
You must include one of the following flags:
Bit Symbol Meaning
0 DN.FLS Step through list of nodes. If
you set this flag, you must be
sure that addr+1 will contain 0
on the first call, to start at
the first node in the node list.
The nodes are listed in
numerical order, by address.
1 DN.FLK List only known nodes.
2 DN.FLR List only active nodes.
3 DN.FLE List only EXECUTOR nodes.
And length is the length of the argument block
returned. If you do not specify step mode by
setting DN.FLS, you must specify the node-name
in addr+1.
The monitor returns the argument list in the
following form:
Offset Symbol Contents
1 .DNNAM Node name.
2 .DNRTR Router information, in the
following format:
Bit 0 (DN.RCH) is set if the
node is reachable.
Bits 1-17 (DN.HOP) contain the
number of hops to the specified
node.
Bits 18-35 (DN.CST) contain the
cost of the path to the
specified node.
22-95
DNET. [CALLI 207]
Code Symbol Meaning
Offset Symbol Contents
3 .DNLLI Link information, in the
following format:
Bit 0 (DN.VLD) is on if the word
contains valid information.
Bits 1-17 (DN.LNK) contain the
number of active links to the
node.
Bits 18-35 (DN.DLY) contain the
message delay time to the node.
4 .DNADR Node address.
5-10 DNCKT Circuit name, up to 4 ASCIZ
words. This string may contain
up to 16 characters.
3 .DNSLS Shows link status. You must specify the
following at addr:
addr: DN.FLS+<.DNSLS,,length>
jobno,,channo
where the flag DN.FLS (step through node list)
is optional, and length is the number of words
reserved for the returned argument list. If you
set DN.FLS, be sure that addr+1 is 0 on the
first call, so that the information is returned
starting at the first node in the node list.
The monitor returns the argument list in the
following form:
Offset Symbol Contents
1 .DNJCN Currently displayed job number
and link number.
2 .DNNOD Remote node name, in SIXBIT.
3 .DNOBJ Object types, where the left
half (DN.DOB) contains the
destination object type, and the
right half (DN.SOB) contains the
source object type.
22-96
DNET. [CALLI 207]
Offset Symbol Contents
4 .DNSTA Status word. The left half of
this word (DN.LSW) contains the
status variable bits and the
link status code. The variable
bits are:
Bit Symbol Meaning
0 NS.IDA Interrupt data is
available.
1 NS.IDR Interrupt data
may be sent.
2 NS.NDA Normal data is
available.
3 NS.NDR Normal data may
be sent.
The remainder of the left half
contains a numeric code
associated with the symbol that
is stored in the right half.
The right half of this word
(DN.STA) contains a SIXBIT
symbol representing the status
of the link. The status codes
and associated SIXBIT symbols
are:
Code Symbol State
1 CW Connect wait.
2 CR Connect message
received.
3 CS Connect message
sent.
4 RJ Remote task
rejected connect
initiation
message.
5 RN Link is up and
running.
6 DR Disconnect
message received.
7 DS Disconnect
message sent.
22-97
DNET. [CALLI 207]
Offset Symbol Contents
Code Symbol State
10 DC Disconnect
message has been
confirmed.
11 CF No confidence in
link.
12 LK No link exists.
13 CM No communication
has taken place.
14 NR No resources
exist.
5 .DNQUO Quota word, where the left half
(DN.IQT) contains the input
quota, and the right half
(DN.OQT) contains the output
quota.
6 .DNSEG Segment size.
7 .DNFLO Flow control option, where the
left half (DN.XMF) contains the
flow control option used for
transmission, and the right half
(DN.RCF) contains the flow
control option used for
receiving messages.
10 .DNMSG Message count word, where the
left half (DN.MRC) contains the
number of messages received, and
the right half (DN.MXM) contains
the number of messages
transmitted.
11 .DNMPR Monitor process word. If the
job number at .DNJCN is -1, this
is the terminal number that
NRTSER has been given for this
particular link. This word is 0
for any job number other than
-1.
22-98
DNET. [CALLI 207]
Error Return
On an error, one of the following error codes is returned in the
ac:
Code Symbol Error
1 DNADE% Address error.
2 DNWNA% Wrong number of arguments.
3 DNIDN% Illegal job number.
4 DNFNE% Illegal function number.
5 DNILF% Illegal flag set.
6 DNNSN% No such node name.
7 DNNSC% No such channel.
10 DNNDA% Node is in a different DECnet area.
Normal Return
If DECnet-10 Version 3 or 4 is included in your monitor, the
normal return is taken for every DNET. call except when it
reaches the end of the node list while returning information
about nodes in the list.
Example
The following example shows the programming sequence used to list
known nodes, up to the specified length, starting at location
DNARG.
MOVE T1,[DN.FLK+<.DNLNN,,100>]
MOVEM T1,DNARG
MOVEI T1,DNARG
DNET. T1,
HALT ;Error return
DNARG: BLOCK 100
On a normal return, the argument block is filled with the
following information:
DNARG: DN.FLK!<.DNLNN,,100> ;Fcn-code+flags
20 ;Number of nodes
SIXBIT/ONE/ ;Node names
SIXBIT/TWO/
SIXBIT/THREE/
SIXBIT/KL1026/
SIXBIT/JINX/
SIXBIT/GNOME/
.
.
.
22-99
DSKCHR [CALLI 45]
DSKCHR [CALLI 45]
Function
Returns the characteristics of a disk device. These
characteristics are needed to allocate storage efficiently on the
disk.
Calling Sequence
MOVE ac,[XWD len,addr]
DSKCHR ac,
error return
normal return
. . .
addr: SIXBIT/name/
BLOCK len-1
where: name is the SIXBIT name of a file structure, a controller
type, a controller, a logical unit, a physical unit, a
physical device, or a channel number. The value of len
is the number of words in the argument list.
If more than one unit was specified, the monitor returns
values in the ac and the argument block, pertinent to the
first unit specified. If more than one file structure
was specified, the monitor returns values in the ac and
argument block, pertinent to the first unit on the first
file structure.
Normal Return
On a successful return, the disk characteristics are returned in
addr+1 through addr+<length-1>, and disk status flags are
returned in the ac. For a complete list of I/O status bits,
refer to Chapter 11.
The contents of the returned argument block are:
Offset Symbol Contents
0 .DCNAM The argument supplied for the call. This is the
only word in the argument block that the user
program supplies. The .DCNAM argument may be a
channel number.
22-100
DSKCHR [CALLI 45]
Offset Symbol Contents
1 .DCUFT The number of blocks left in your job's quota
before the UFD is exhausted. If this value is
negative (DC.NPA==1B0), the UFD has not been
accessed since the job logged in, and the quota
is not available. To obtain this information
for jobs other than your own, use the .DUFRE
function of the DISK. UUO.
2 .DCFCT The number of first-come, first-served blocks
available to all users.
3 .DCUNT The number of blocks available to all users on
this file structure.
4 .DCSNM SIXBIT name of the structure to which this unit
belongs.
5 .DCUCH The size characteristics:
Bits Symbol Meaning
0-8 DC.UCC Number of blocks per cluster.
9-17 DC.UCT Number of blocks per track.
18-35 DC.UCY Number of blocks per cylinder.
6 .DCUSZ Number of 128-word blocks on the unit.
7 .DCSMT Mount count for the structure. This count is
the number of jobs that performed a MOUNT
command for this file structure without
executing a DISMOUNT command. Note that LOGIN
performs an implied MOUNT of all structures in
DSK, the default job search list.
10 .DCWPS Number of words per SAT block.
11 .DCSPU Number of SAT blocks for each unit.
12 .DCK4S Space (in K) allocated for swapping.
22-101
DSKCHR [CALLI 45]
Offset Symbol Contents
13 .DCSAJ Mount word for the structure:
Value Meaning
0,,0 No job or more than one job has the
structure mounted.
-1,,n One job (number n) has the structure
mounted and the structure is not
single-access.
0,,n One job (number n) has the structure
mounted and the structure is
single-access.
14 .DCULN SIXBIT logical name of the unit.
15 .DCUPN SIXBIT physical name of the unit.
16 .DCUID SIXBIT identification of the unit.
17 .DCUFS First logical block to be used for swapping.
20 .DCBUM Number of blocks per unit (including maintenance
cylinders).
21 .DCCYL Current cylinder number.
22 .DCBUC Number of blocks per unit in PDP-11
compatibility mode.
23 .DCLPQ Length of the position wait queue.
24 .DCLTQ Length of the transfer wait queue.
25 .DCALT Unit name for alternate port.
26 .DCOWN Owner PPN of structure.
27 .DCPAS Position in active swapping list if argument was
a physical unit; -1 if not in list.
30 .DCPSD Position in system dump list if argument was a
structure; -1 if not in list.
31 .DCBSC Blocks per super-cluster.
22-102
DSKCHR [CALLI 45]
Offset Symbol Contents
32 .DCXCH The extended unit characteristics:
Bits Symbol Meaning
0-8 DC.XCC Data channel number
9-17 DC.XCK Unit controller number
18-26 DC.XCU Physical unit number
27-35 DC.XCA Bit mask of accessible CPUs
(1B35=CPU0, 1B34=CPU1, etc.)
33 .DCDET Name of the alternate port. The port does not
have to be attached.
34 .DCNUS The name of the next unit in the specified file
structure.
35 .DCBRC Count of blocks read by buffered I/O.
36 .DCBWC Count of blocks written by buffered I/O.
37 .DCDRC Count of blocks read by dump I/O.
40 .DCDWC Count of blocks written by dump I/O.
41 .DCMRC Count of blocks read by monitor I/O.
42 .DCMWC Count of blocks written by monitor I/O.
43 .DCSRC Count of blocks read by swap I/O.
44 .DCSWC Count of blocks written by swap I/O.
45 .DCPRC Count of blocks read by paging I/O.
46 .DCPWC Count of blocks written by paging I/O.
47 .DCFKS Remaining swap space.
50 .DCCBK Count of disk cache blocks in use.
51 .DCCRC Count of disk cache read calls.
52 .DCCRH Count of disk cache read hits.
53 .DCCWC Count of disk cache write calls.
54 .DCCWH Count of disk cache write hits.
55 .DCSDV Count of soft device/search errors.
22-103
DSKCHR [CALLI 45]
Offset Symbol Contents
56 .DCSDT Count of soft data errors.
57 .DCHDV Count of hard device/search errors.
60 .DCHDT Count of hard data errors.
61 .DCECT Count of retries on last error.
62 .DCSER Count of SAT errors.
63 .DCRER Count of RIB errors.
64 .DCCER Count of software checksum/consistency errors.
65 .DCHBN Logical block number of last error (within
unit).
66 .DCERR Last error status.
67 .DCSDF Last error status.
70 .DCHDI Last error status.
71 .DCSDI Last error status.
72 .DCNHG Count of non-recoverable transfer-hung errors.
73 .DCTHG Count of transfer-hung errors.
74 .DCPHG Count of position-hung errors.
75 .DCSHG Count of software-hung errors.
76 .DCMAX Length of DSKCHR argument block. The value of
this symbol may change as words are added to the
DSKCHR block.
The flags returned in the ac are as follows:
Bits Symbol Meaning
0 DC.RHB Disk pack off-line; the monitor must reread the
home block before the next operation to verify
the pack identification.
1 DC.OFL Unit is off-line.
2 DC.HWP Hardware write-protected.
3 DC.SWP Belongs to write-protected file structure.
22-104
DSKCHR [CALLI 45]
Bits Symbol Meaning
4 DC.SAF Belongs to single-access file structure.
5 DC.ZMT Mount count is zero.
6 DC.PRV Belongs to private file structure.
7-8 DC.STS Status code for unit:
Code Symbol Status
0 .DCSTP Has pack mounted.
2 .DCSTN No pack mounted.
3 .DCSTD Unit down.
9 DC.MSB Unit has more than one SAT block.
10 DC.NNA Belongs to a structure that has a lock to
prevent further INIT, LOOKUP, ENTER, OPEN, and
FILOP. calls (NNA - "no new access"). This lock
is set by a privileged STRUUO function.
11 DC.AWL Write-locked for all jobs.
12-13 DC.CPU CPU number of the CPU to which the device is
connected. DC.XCC in word .DCXCH supersedes
DC.CPU.
14 DC.ALT Dual-ported device.
15-17 DC.TYP Type of argument passed with the DSKCHR call:
Code Symbol Meaning
0 .DCTDS Generic name, such as DSK.
1 .DCTAB File structure subset, because
of abbreviation, such as D.
2 .DCTFS File structure name, such as
DSKA.
3 .DCTUF Unit within file structure, such
as DSKA0.
4 .DCTCN Controller class name, such as
FH.
5 .DCTCC Controller name, such as RPA.
6 .DCTPU Physical unit, such as RPA0.
18-20 DC.DCN Data channel number that software lists as
connected to hardware; first data channel is 0.
22-105
DSKCHR [CALLI 45]
Bits Symbol Meaning
21-26 DC.CNT Controller type:
Code Symbol Controller Type
1 .DCCFH RC10 for RD10 and RM10-B.
2 .DCCDP RP10 for RP02 and RP03.
4 .DCCFS RH10 for fixed head disk.
5 .DCCRP RH10/RH20/RH11 for moving head
disk (RP04, RP06, RP07, and
RM03).
6 .DCCRN RH20 for RP20.
7 .DCCRA HSC50 for CI disks.
27-29 DC.CNN Controller number; first one of each type is 0.
30-32 DC.UNT Unit type:
Code Symbol Meaning When
0 .DCUFD RD10 (DC.CNT=1)
0 .DCUS4 RS04 (DC.CNT=4)
0 .DCUR4 RP04 (DC.CNT=5)
0 .DCUN0 RP20 (DC.CNT=6)
0 .DCU80 RA80 (DC.CNT=7)
1 .DCUFM RM10-B (DC.CNT=1)
1 .DCUD2 RP02 (DC.CNT=2)
1 .DCUR6 RP06 (DC.CNT=5)
1 .DCU81 RA81 (DC.CNT=7)
2 .DCUD3 RP03 (DC.CNT=2)
2 .DCUR3 RM03 (DC.CNT=5)
2 .DCU60 RA60 (DC.CNT=7)
3 .DCUR7 RP07 (DC.CNT=5)
33-35 DC.UNN Physical unit number within the controller;
first one is 0.
Error Return
The error return occurs if any of the following conditions is
found:
o The argument at addr is 0.
o The device does not exist or channel is not initialized.
o The argument is illegal.
22-106
DSKCHR [CALLI 45]
Example
The following example checks a user's logged-in quota on
structure DSKB:
MOVE T1,[2,,ADDR]
DSKCHR T1,
JRST NOQTA
SKIPGE ADDR+.DCUFT
JRST NOQTA
. . .
ADDR: SIXBIT /DSKB/
BLOCK 1
This code tests the value returned from the DSKCHR call. When
DSKCHR fails, or when no quota is returned at ADDR+1, the program
jumps to NOQTA, where it must act on the possibility that the
structure is not mounted or there is no quota on the structure.
22-107
DTE. [CALLI 170]
DTE. [CALLI 170]
Function
Performs functions for the DTE (KL systems only), and is not
recommended for customer programs. To use the DTE. monitor call,
you must have the JP.POK or JACCT privilege, or be logged in
under [1,2].
Calling Sequence
MOVE ac,[fcn-code,addr]
DTE. ac,
error return
normal return
. . .
addr: argument list
where: fcn-code is one of the function codes described below.
addr is the address of the argument list. Each function
requires a different argument list. These are described
below.
In the following discussion of the DTE. functions,
o cpuno is the number of a CPU.
o dteno is the number of a DTE.
o fedno is the unit number of a front-end device.
The function codes and their meanings are:
Code Symbol Function
0 .DTECL Clears a PDP-11 on a DTE. The argument list for
the .DTECL function is:
addr: XWD cpuno,dteno
1 .DTEST Starts primary protocol on a DTE. The argument
list for the .DTEST function is:
addr: XWD cpuno,dteno
22-108
DTE. [CALLI 170]
Code Symbol Function
2 .DTETB Sets the byte pointer for messages being
transferred to the DECsystem-10. The argument
list for the .DTETB function is:
addr: XWD cpuno,dteno
EXP <byte pointer to DECsystem-10>
3 .DTEEB Sets the byte pointer for messages transmitted
to the PDP-11. The argument list for the .DTEEB
function is:
addr: XWD cpuno,dteno
EXP <byte pointer to PDP-11>
4 .DTERW Returns the PDP-11 reload ROM word in the ac.
The argument list for the .DTERW function is:
addr: XWD cpuno,dteno
If bit 4 (DT.RP4) is set on return, the PDP-11
got code from the disk.
5 .DTEMN Return (in ac) the master DTE number for the
CPU. The argument list for the .DTEMN function
is:
addr: XWD cpuno,dteno
6 .DTEPR Presses the PDP-11 reload button. The argument
list for the .DTEPR function is:
addr: XWD cpuno,dteno
7 .DTEGS Returns the status word for the DTE. The status
word for the specified DTE is returned in ac.
The argument list for the .DTEGS function is:
addr: XWD cpuno,dteno
The status flags that can be returned are:
Flag Symbol Meaning
6 DT.DTX DTE exists.
7 DT.DTM DTE is master DTE.
8 DT.PPC DTE is running primary
protocol.
9 DT.SPC DTE is running secondary
protocol.
10 DT.RLD DTE needs reloading.
22-109
DTE. [CALLI 170]
Code Symbol Function
10 .DTERJ Sets reload job number. The argument list for
the .DTERJ function is:
addr: EXP jobno
where: jobno is the job number for the reload.
|
| 11 .DTEGF Assigns the specified Front End Device (FED) to
| the current job in its current job context. The
| FED can then be operated using the DTE.
| functions for FEDs (.DTEIF, .DTEOF, .DTEFG.,
| .DTEFS, and .DTEFR). Privileged programs can
| use the FED functions to communicate with the
| software running on PDP-11 devices connected to
| the system with a DTE. That software includes
| GALAXY, DDT11, and the FE program.
|
| To assign a FED, use the following argument
| block:
|
| addr: XWD cpuno,dteno
| EXP fedno
|
| Where cpuno is the CPU number and dteno is the
| number of the DTE to which the FED is connected.
| In addr+1, specify the unit number of the FED.
| On a successful return from the DTE. function,
| the contents of the ac are indeterminate
|
| You can use this function to assign the first
| free FED unit on the specified CPU and DTE by
| specifying -1 for fedno. In this case, the FED
| unit number will be returned in the ac.
12 .DTEIF Front-end device input. The argument list for
the .DTEIF function is:
addr: XWD cpuno,dteno
EXP fedno
XWD byte-count, addr-of-input-buffer
13 .DTEOF Front-end device output. The argument list for
the .DTEOF function is:
addr: XWD cpuno,dteno
EXP fedno
XWD byte-count,addr-of-output-buffer
22-110
DTE. [CALLI 170]
Code Symbol Function
14 .DTEFG Returns (in ac) the front-end device status.
The argument list for the .DTEFG function is:
addr: XWD cpuno,dteno
EXP fedno
The returned device status flags are:
Flag Symbol Meaning
28 DT.FER Fatal error.
29 Reserved.
30 DT.EOF End of file.
31 DT.IOP I/O in progress.
32 DT.SER Soft error.
33 DT.HER Hard error.
34 DT.OFL Off-line.
35 DT.NXD Nonexistent device.
15 .DTEFS Sets front-end device status. The argument list
for the .DTEFS function is:
addr: XWD cpuno,dteno
EXP fedno
EXP status
where: status is the status word for the
front-end device.
16 .DTEFR Releases a front-end device. The argument list
for the .DTEFR function is:
addr: XWD cpuno,dteno
EXP fedno
17 .DTERC Releases KL error chunks. The argument list for
the .DTERC function is:
addr: XWD cpuno,0
20 .DTERT Releases the KL error timer. The argument list
for the .DTERT function is:
addr: XWD cpuno,0
22-111
DTE. [CALLI 170]
Code Symbol Function
21 .DTEDT Returns Universal Device Indexes for terminal
lines leading to the DL11s on the specified DTE.
The argument list for this function is:
addr: XWD cpuno,dteno
On a successful return, the UDX is returned in
the ac. However, for DTE 0, which is dedicated
to the console front end (RSX-20F), the ac
contains the KLINIK line's UDX in the left half,
and the CTY's UDX in the right half.
22 .DTESU Specifies the type of protocol that will run on
the DTE. The argument list for this function
is:
addr: XWD cpuno,dteno
SIXBIT/user-name/
where the user-name is one of the following
protocol types:
DECNET for DECnet-10.
ANF for ANF-10.
IBM for IBM communications.
NOBODY if the DTE is not running a
protocol.
PROGRA if the DTE is dedicated to a job.
23 .DTERU Reads the protocol type of the protocol that is
running on the DTE. The argument list is:
addr: XWD cpuno,dteno
BLOCK 2
The information is returned in the following
format:
addr: XWD cpuno,dteno
SIXBIT/user-name/
EXP jobn
where user-name is the name of the protocol
running on the DTE (refer to .DTESU above). The
job number (jobn) is returned in addr+2 only if
user-name is PROGRA.
22-112
DTE. [CALLI 170]
Code Symbol Function
24 .DTELS Loads a secondary bootstrap from your job's
memory area, using the PDP-11 bootstrap ROM.
This function must be preceded by the .DTECL
(clear) and .DTEPR (press reload) functions.
You must also use function .DTEDM (dump) before
you can load any bootstrap. The argument list
for this function is:
addr: XWD cpuno,dteno
POINT 16,addr1
EXP length
where addr+1 contains a byte pointer indicating
the location of the secondary loader, and length
is the length of the loader, in 16-bit bytes.
25 .DTEDM Dumps PDP-11 memory, using the PDP-11 bootstrap
ROM. Before you use this function, be sure to
use functions .DTECL (clear) and .DTEPR (press
reload). You must always dump the PDP-11 memory
before you can load a program into its memory.
The argument list for this function is:
addr: XWD cpuno,dteno
POINT 16,addr1
EXP count
where addr+1 contains a byte-pointer to the
memory that must be dumped, and where count is
the number of 16-bit bytes to dump from the
PDP-11.
26 .DTKPS Not intended for customer use.
27 .DTKPR Not intended for customer use.
Normal Return
The function is performed, and any requested value is stored in
the ac.
22-113
DTE. [CALLI 170]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 DTENP% Not enough privileges.
2 DTEUF% Illegal function code.
3 DTEDC% Illegal CPU or DTE number.
4 DTEAP% Primary protocol already running.
5 DTEPT% Power fail did not come up.
6 DTEDE% Doorbell did not clear.
7 DTTTE% To TOPS-10 error during BOOT sequence.
10 DTEDD% No response from PDP-11 after BOOT sequence.
11 DTEIJ% Illegal job number.
12 DTEIB% Illegal byte count.
13 DTENI% Front-end device not initialized.
14 DTEFB% Front-end device in use by another job.
15 DTENF% Nonexistent front-end device.
16 DTEFE% Fatal error on front-end device.
17 DTESE% Error starting primary protocol.
20 DTENC% No free core for front-end device buffers.
21 DTETE% KL error data timer expired.
22 DTECM% The FEDSER monitor module was told not to send
messages to the PDP-11.
23 DTEIU% Tried to set line to illegal user value.
24 DTEWU% Wrong line user for function.
25 DTEEV% No exec virtual memory to perform function.
26 DTEIP% Illegal byte pointer.
22-114
DVPHY. [CALLI 164]
DVPHY. [CALLI 164]
Function
Returns the physical names of all devices of a given type, or of
all devices supported by the system (except pseudo-terminals,
terminals, MPX devices, and disks).
Calling Sequence
|
| MOVE ac,[XWD len,addr]
| DVPHY. ac,
| error return
| normal return
| . . .
| addr: / EXP device-type \
| \ EXP -1 /
| BLOCK 1
where: len is the length of the argument block (must be 2).
addr is the address of the argument block.
device-type is one of the device type codes returned from
the DEVTYP monitor call, such as .TYLPT for a line
printer. A value of -1 means all devices supported by
the system.
On the first DVPHY. call, addr+1 should contain 0; the monitor
returns the name of the first device. If you leave this name in
addr+1, the next DVPHY. call returns the name of the next device,
and so forth. When all devices have been returned (by several
calls), the monitor returns 0 in addr+1.
Normal Return
For 0 in addr+1, the monitor returns the name of the first
device; for a device name in addr+1, the monitor returns the name
of the next device, or, if no more, 0. The ac is unchanged.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 DVPIA% Illegal argument length.
2 DVPIT% Illegal device type.
3 DVPNP% Nonexistent physical device.
4 DVPNT% Nonexistent device type.
22-115
DVPHY. [CALLI 164]
Example
The following example shows how to obtain the physical names of
all line printers on the system:
SETZB T1,ADDR+1 ;Initialize counter and device name
TAG1: MOVE T2,[XWD 2,ADDR] ;Set up call
DVPHY. T2, ;Get name
JRST ERROR ;Error
SKIPN T3,ADDR+1 ;Get name, skip if not at end
JRST TAG2 ;0 means we're done
MOVEM T3,LPTNAM(T1) ;Save in next block-slot
AOJA T1,TAG1 ;Increment count and loop
TAG2: MOVEM T1,NLPT ;Save count
JRST CONTIN
NLPT: BLOCK 1
LPTNAM: BLOCK 10
ADDR: EXP .TYLPT ;Type is LPT
EXP 0 ;Start with first device
CONTIN:
Related Calls
SYSPHY, SYSSTR
Common Errors
Using a SIXBIT name for device type.
22-116
DVRST. [CALLI 122]
DVRST. [CALLI 122]
Function
Restricts the use of a device. Once restricted, the device is
then assignable only by the operator; unprivileged users must
request assignment through the MOUNT monitor command before using
the OPEN/INIT monitor call. (See the Commands Manual.)
Privileged users (JACCT or [1,2]) can still use the OPEN or INIT
monitor call, or the ASSIGN command, if the device is not
controlled by MDA.
The DVRST. monitor call requires the JACCT privilege or that you
be logged in under [1,2].
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DVRST. ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a device
to be designated as being restricted.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Normal Return
The device is restricted.
Error Return
The error return occurs if any of the following conditions is
found (the ac is unchanged):
o You do not have the JACCT privilege or are not logged in
under [1,2].
o The specified device does not exist.
o The device is a disk.
Related Calls
DVURS.
22-117
DVURS. [CALLI 123]
DVURS. [CALLI 123]
Function
Removes the restriction created by a DVRST. monitor call.
DVURS. requires the JACCT privilege or that you be logged in
under [1,2].
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| DVURS. ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a device
that is to be returned to unrestricted status.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Normal Return
The restriction is removed. The device is available for public
use and returned to the monitor's pool of available devices.
Error Return
The error return occurs if any of the following conditions is
found (the ac is unchanged):
o You do not have the JACCT privilege or are not logged in
under [1,2].
o The given device does not exist.
Related Calls
DVRST.
22-118
ENQ. [CALLI 151]
ENQ. [CALLI 151]
Function
Requests access to resources that are defined by cooperating user
programs. The ENQ. call is one of three monitor calls that
provide control over the ENQ/DEQ facility, which provides
resource definition, control over access to resources, and
deadlock detection for the resources. The ENQ/DEQ facility is
described in Chapter 8.
Calling Sequence
MOVE ac,[XWD fcn-code,addr]
ENQ. ac,
error return
normal return
. . .
addr: EXP <size>B5+<number>B17+<len>B35 ;header block
XWD 0,request-id
XWD time-limit
<lock block>
<lock block>
.
.
.
where: fcn-code is one of the function codes listed below.
addr is the address of the argument block, which consists
of a header block followed by one or more lock blocks.
The header block contains 1 to 3 words, in the following order:
Offset Symbol Contents
0 .ENQLL The header size, the number of lock requests, and
the total length of the argument, including the
header and all the words in all the lock blocks.
Specifically, the .ENQLL word is formatted as
follows:
Bits Symbol Value
0-5 EQ.BHS Size of the header block. This
value is between 1 and 3,
because the second and third
words are optional. If you omit
this value, the default is 2.
22-119
ENQ. [CALLI 151]
Offset Symbol Contents
Bits Symbol Value
6-17 EQ.LNL Number of lock blocks following
the header block. Include one
lock block for each resource
requested.
18-35 EQ.LLB Total length (in words) of the
argument block. All the lock
blocks in a single request must
be the same length. Thus, the
value of EQ.LLB is the header
block length (EQ.BHS) plus the
length of each lock block times
the number of resources
requested (EQ.LNL).
1 .ENQRI An 18-bit request-id identifying this request.
This optional value identifies the ENQ.
request, enabling you to identify it when it
causes a software interrupt. This is useful
when you use the ENQ/DEQ facility in conjunction
with the software interrupt (PSI) system. After
an interrupt is generated, the request-ids of
the granted requests are inclusively ORed into
the status word of the interrupt block. To
receive a software interrupt, use function code
2 (.ENQSI) when you issue the ENQ. monitor call.
The request-id can also be used with the DEQ.
call to dequeue a specific request.
2 .ENQTL Time limit specifying the number of seconds to
wait for each request in the call to be granted.
If any resource is not available within that
time limit, the call takes the error return with
the ENQTL% error code in the ac. This word is
optional. If you include the time limit in the
header block, specify 3 for size in word 0.
Each lock block represents a separate ENQ. request. There is no
limit to the number of locks that can be requested, but multiple
requests in the same ENQ. call must be given level numbers. The
locks will be granted in the order of the level numbers.
22-120
ENQ. [CALLI 151]
The format of a lock block is:
|
| / EXP <flags+level>B17+<channo>B35 \
| | EXP flags+user-code |
| \ EXP user-code /
| / XWD pool-size,number \
| \ XWD 0,sharer-group /
| XWD mask-len,mask-addr
| XWD block-len,block-addr
where a lock block is two to five words long, identifying the
resource to be locked and describing the characteristics of the
lock. The first requestor of a resource defines lock
characteristics. Subsequent requests for the same resource must
conform to those characteristics or wait until the resource is
released by the first requestor.
In the case of multiple-lock requests, all the lock blocks in a
single ENQ. request must be the same length. Specifically, a
lock block can contain the following words:
Offset Symbol Contents
0 .ENQFL Contains the flag bits, level number, and
channel number. The flags are:
Bit Symbol Meaning
0 EQ.FSR The lock request allows sharers.
If you do not set this bit, the
monitor assumes that you require
exclusive access to the
resource. Unless the first
requestor for the resource sets
this flag, no requests for the
same resource (specified in the
next word, .ENQBP) can be
granted until the first
requestor dequeues it (using
DEQ. or RESET). If the first
requestor sets this bit, other
programs with the same sharer
group number as that specified
in .ENQPS can obtain access to
the resource while it is locked
for your job.
22-121
ENQ. [CALLI 151]
Bit Symbol Meaning
1 EQ.FLB Bypass level checking. When
multiple request blocks are made
in a single ENQ. call, you must
assign a level number to each
request. When EQ.FLB is not
set, lower-level resources will
be granted before higher-level
resources are considered. The
EQ.FLB flag prevents this
level-checking, allowing
resources to be granted
regardless of their order by
level number.
2 EQ.FLT Grant a long-term lock. That
is, after the resource is
dequeued by all users, the lock
data is preserved for about 5
minutes.
3 EQ.FEL Grant an eternal lock. This
prevents the resources from
being dequeued automatically
when your program performs a
RESET function.
4 EQ.FAB Abort the resource. This
prevents the resource from being
accessible to any other user. A
request for an aborted lock
causes error code ENQAB% to be
returned in the ac. The
resource cannot be granted to
another user until it is
dequeued.
5 EQ.FDD Set deadlock detection. This
flag prevents your request from
causing a deadlock among
resource users. If this flag is
set, and granting your request
would cause a deadlock, the ENQ.
call takes the error return with
error code ENQDD% in the ac.
6 EQ.FCW Specifies that a 36-bit user
code is included in the next
word (.ENQBP). This is the
preferred method of specifying a
user code in the lock block.
22-122
ENQ. [CALLI 151]
Bit Symbol Meaning
7-8 Reserved for use by DIGITAL.
9-17 EQ.FLV 9-bit level-number that you
assign to each request in a
multiple-lock request. In a
multiple-lock request (a single
ENQ. call containing multiple
lock blocks), each lock block
must be assigned a level number;
the locks will be granted in
ascending numerical order
according to level number,
unless you set EQ.FLB (bypass
level checking) in the flag
word.
18-35 EQ.FCC The number of the channel on
which the resource is being
accessed (positive integer), to
associate the lock with the file
that is open on that channel.
Alternatively, you can specify a
negative number indicating one
of the following conditions:
Code Symbol Meaning
-3 .EQFPL The lock
requested is a
privileged
global lock and
the resource is
available only
to [1,2] or
JACCT jobs.
This code allows
privileged jobs
to define locks
on resources to
prevent access
from
unprivileged
jobs.
22-123
ENQ. [CALLI 151]
Offset Symbol Contents
Code Symbol Meaning
-2 .EQFGL The lock you are requesting is a
global lock. Specifying this
code prevents access to the
resource from any other job. To
use this code, your job must
have JP.ENQ set in its privilege
word.
-1 .EQFJB The lock is a job-wide lock,
preventing access to the
resource from any other requests
by your job.
1 .ENQBP Specifies the resource to be locked. You can
use a pointer to an ASCIZ string, or a user-code
in this word (more on this later). You must
include this word in every lock block because it
defines the resource you are requesting.
When the first program to request the resource
is granted a lock, it is said to have ownership
of the resource. When a second program makes an
ENQ. call with the same value in this word (if
a user-code is specified) or the same ASCIZ
string (if a byte pointer is used), the request
is for the same resource that was granted to the
first job. The contents of the word to which
the byte pointer refers, or the user code
itself, are purely arbitrary values to the
monitor. The monitor only checks lock requests
for matches, granting or preventing locks on the
basis of matching strings. This is the key to
the ENQ/DEQ access-checking mechanism.
If the flag EQ.FCW is set in the previous word
(.ENQFL), .ENQBP must contain a 36-bit value as
a user-code.
If EQ.FCW is not set, and the flag EQ.BUC is set
in .ENQBP (that is, a value of 5 is placed in
bits 0-2), the rest of the word must contain a
33-bit user-code.
22-124
ENQ. [CALLI 151]
Offset Symbol Contents
If neither flag is set, this word (.ENQBP) must
contain a pointer to an ASCIZ text string. This
may be either a standard byte pointer in the
form:
POINT 7,address,bit-location
Or, if the ASCIZ string is stored in 7-bit
bytes, starting at the first byte of the
location being referenced, the pointer can take
the form:
XWD -1,address
The ASCIZ string at address can be up to 30
(decimal) words. The maximum string length for
your system is stored in %EQMSS in GETTAB table
.GTENQ.
Cooperating programs (those requesting the same
resources) must specify exactly the same user
code or ASCIZ string.
2 .ENQPS Specifies either a pool number for a pooled
resource, or a sharer group number for a
sharable resource. This word is optional and
defaults to 0.
For a pooled resource, the word contains the
pool-size in the left half and the number of
resources requested from the pool in the right
half. For a sharable resource, the left half is
zero, and the right half contains the
sharer-group number. Thus, a resource cannot be
pooled and also be accessible to a sharer group.
A pooled resource is defined by the first
requestor of the resource. By specifying the
number of resources in the pool, the requestor
is defining the number of "copies" of the
resource to be made available. Each copy of the
resource can be requested for exclusive access
by specifying the same resource identifier in
word .ENQBP and the same pool-size in word
.ENQPS. The requestor must also specify, in the
right half of .ENQPS (EQ.PPR), the number of
copies of the resource to lock.
22-125
ENQ. [CALLI 151]
Offset Symbol Contents
If the left half of .ENQPS (EQ.PPS) is 0, the
right half (EQ.PPR) specifies the sharer-group
number, thus defining a group of jobs that can
simultaneously share the resource. Any program
that sets the flag EQ.FSR and specifies the same
resource and the same sharer group number will
be granted its request. Therefore, when you
share the ownership of a resource, only other
jobs in the same sharer group are allowed
ownership of the resource. The sharer group
number defaults to 0. Therefore, if the first
requestor specifies a sharable resource but
omits the sharer group number, all subsequent
sharable requests for the resource that also
omit the sharer group number, or that set it to
0, will be granted immediately.
3 .ENQMS Contains a pointer to the bit mask representing
the portions of a resource to be locked. The
pointer consists of the mask-len stored in the
left half, and the mask-addr in the right half.
The bit mask, describing fields of bits to be
locked, is stored at the location specified in
mask-addr, and the length of the bit mask (in
words) is stored in the mask-len. This provides
a facility for partitioning the resource,
allowing locks on portions of a resource. This
word is optional and defaults to 0.
4 .ENQTB Contains the block-length and block-addr of a
lock-associated data block. This data block can
be used to pass information to subsequent users
of a resource. To use this facility, you should
set EQ.FLT, thus preserving all lock request
data for the resource for at least 5 minutes
after you dequeue the resource. This word is
optional and defaults to 0.
22-126
ENQ. [CALLI 151]
The function codes and their meanings are:
Code Symbol Function
0 .ENQBL Requests ownership of a resource. Your job will
block if the resource is not available. Your
request is placed in a queue associated with the
specified resource. If more than one request
was included in your ENQ. call, your job will
block until all the requests have been granted.
After all requests have been granted, the normal
return is taken and the monitor clears the ac.
If you set the flag EQ.FBL in .ENQFL of the
request block (to bypass level checking), the
monitor could return a nonzero value. A nonzero
value indicates that a level number sequencing
error occurred, but it was ignored because you
specified that level numbers were to be
bypassed.
1 .ENQAA Requests ownership of a resource and returns
immediately if the resource is unavailable. If
all requests specified in this argument cannot
be granted immediately, the system will not
enter any requests in the queues associated with
those resources and the error return is taken
with error code 1 (ENQRU%) in the ac. However,
if the system can grant all of your requests
immediately, the normal return is taken and the
monitor leaves the ac unchanged.
2 .ENQSI Requests ownership of a resource and, if the
resource is not immediately available, causes a
software interrupt when the resource becomes
available. You can use this function when the
Programmable Software Interrupt (PSI) system is
enabled, to prevent your job from blocking while
waiting for the requests to be granted.
If all the requests in the call can be granted
immediately, this function is equivalent to
function code 0 (.ENQBL). If any of the
requests are not available, the call takes the
error return with error code 1 (ENQRU%) in the
ac. In this case, your job can continue
processing until it receives a .PCQUE software
interrupt. The interrupt control block will
contain the request-ids of the requests that are
granted, inclusively ORed into the status word.
The PSI system is described in Chapter 6.
22-127
ENQ. [CALLI 151]
Code Symbol Function
3 .ENQMA Modifies an existing request made by your job.
If the modification you specify in this request
is identical to the request you made earlier, no
action is taken and the normal return is taken
from the call. If you do not have a request in
any queue, the error return is taken and the
monitor returns error code 24 (ENQNE%) in the
ac. If you specify more than one request with
this function code and the error return is
taken, you must issue the ENQC. monitor call to
determine which (if any) modification request
was granted. The error code that the monitor
returns in the ac reflects only the last error
that occurred as the result of this call.
You can modify a request from exclusive
ownership to shared ownership, but you will
receive an error code if you attempt to modify a
request from shared to exclusive ownership if
other jobs are also sharing the resource. To
modify a request from shared to exclusive
ownership when other jobs are sharing the
resource, you must first DEQ. the request.
Then, enqueue it again as an exclusive ownership
request.
Normal Return
All requests in the call are granted, and the resources are
locked for your program.
Error Return
One of the following error codes is returned in the ac on an
error return. These error codes are also returned on an error
from a DEQ. or ENQC. call. They are described in more detail
in Chapter 8.
Code Symbol Error
1 ENQRU% At least one of the requested resources is not
available.
2 ENQBP% You requested an illegal number of pooled
resources.
3 ENQBJ% You specified an illegal job number.
4 ENQBB% You specified an illegal byte size for the byte
pointer. The byte size must be between 1 and
36, inclusive.
22-128
ENQ. [CALLI 151]
Code Symbol Error
5 ENQST% The ASCIZ string is too long. It must be less
than 30 (decimal) words. (Refer to GETTAB table
.GTENQ, item %EQMSS for current maximum message
length.)
6 ENQBF% You specified an illegal function code.
7 ENQBL% You specified an illegal argument list length.
The total argument list for the call must be
header-block-size plus (request-block-size times
number-of-requests).
10 ENQIC% You specified an illegal number of requests.
11 ENQBC% You specified an illegal channel number.
12 ENQPI% Your program does not have enough privileges for
the given function.
13 ENQNC% Not enough core available, or the maximum number
of active locks (item %EQMAQ in GETTAB table
.GTENQ) has been exceeded.
14 ENQFN% Device is not initialized or is not a disk.
15 ENQIN% The address for the byte pointer is indirect or
indexed; this is not allowed.
16 ENQNO% Your program cannot dequeue resources it does
not own.
17 ENQLS% Levels are not specified in ascending order.
20 ENQCC% Illegal modification of ownership; you cannot
change a request from shared to exclusive
ownership. You must DEQ. the request, then
ENQ. it with EQ.FSR set.
21 ENQQE% Your ENQ quota has been exceeded; your quota is
set by the system administrator.
22 ENQPD% The number of resources in the pool disagrees
with the number in your request.
23 ENQDR% Duplicate request; identical to a request
already in the queue.
24 ENQNE% Not enqueued on this lock.
25 ENQLD% Level in request does not match lock.
26 ENQED% Insufficient privileges for this function; you
must have JP.ENQ set.
27 ENQME% Mask too long or lengths do not match.
30 ENQTE% Lock-associated table is too long.
31 ENQAB% A resource that was requested has been marked as
aborted.
32 ENQGF% Attempt to ENQ. with EQ.FEL option on a ghost
file.
33 ENQDD% Deadlock detected.
34 ENQTL% Time limit exceeded.
22-129
ENQ. [CALLI 151]
Example
.
.
.
MOVE T2,[XWD 10,ADDR] ;Initialize channel
FILOP. T2,
JRST ERROR1 ;Error return
JRST ENQ ;Normal return
ADDR: XWD CHAN,1 ;Channel and LOOKUP
EXP MODE ;Data mode
SIXBIT/DSK/ ;Device
0,,0 ;Buffer addresses
0,,0
0,,ADDR1 ;LOOKUP block
0,,0
0,,0
ADDR1: SIXBIT/FILE/ ;File name
SIXBIT/EXT/ ;Extension
XWD 0,0
XWD 27,4072 ;Project-programmer
;Number
ENQ: MOVE T3,[XWD 0,ADDR3] ;Function and address
ENQ. T3,
JRST ERROR3 ;Error return
JRST NORM ;Normal return
ADDR3: XWD 1,5 ;Number of locks, length of block
XWD 0,1 ;Request identifier
XWD 0,CHAN ;Resource on chan
POINT 7,[ASCIZ/NAME/] ;Pointer to resource
0,,0 ;Not a pooled resource
.
.
.
ERROR1: OUTSTR ERROR2
JRST DONE
ERROR3: OUTSTR ERROR4
JRST DONE
22-130
ENQ. [CALLI 151]
ERROR2: ASCIZ/ERROR WITH FILOP./
ERROR4: ASCIZ/ERROR WITH ENQ./
.
.
.
DONE: EXIT
Related Calls
DEQ., ENQC.
22-131
ENQC. [CALLI 153]
ENQC. [CALLI 153]
Function
Returns information about the current state of ENQ/DEQ requests
and sets access rights for the ENQ/DEQ facility (privileged).
Refer to Volume 1 for more information about using the ENQ/DEQ
calls. For more information about the contents of the argument
block, refer to the ENQ. call.
Calling Sequence
Each function of the ENQC. call requires a different calling
sequence. The calling sequence for each ENQC. function is
described below, for the appropriate function.
The ENQC. function codes and their meanings are:
Code Symbol Function
0 .ENQCS Returns a 3-word status block for each specified
lock. The calling sequence for the .ENQCS
function is:
MOVE ac,[XWD .ENQCS,addr]
MOVEI ac+1,buffer
ENQC. ac,
error return
normal return
. . .
addr: EXP parameters
XWD 0,request-id
EXP time limit
first word of first lock block
. . .
last word of last lock block
buffer: BLOCK <locks>*3
. . .
where: addr is the address of the argument
list.
buffer is the address of a buffer (of
length locks*3) for storing the returned
three-word status blocks.
parameters is a word of the form:
<size>B5+<locks>B17+<length>B35
22-132
ENQC. [CALLI 153]
Code Symbol Function
where: size is the size of the header block (1
to 3).
locks is the number of lock blocks in
the argument list.
length is the length of each lock block
(size plus number of locks times the
length of each lock block).
The right half of addr+1 may contain
request-id, an optional request
identifier.
time limit is an optional time limit for
the request to be granted.
On a normal return, the monitor returns a
three-word status block for each request, at
buffer. The format of each block is:
Offset Symbol Meaning
0 .ENQCF Flags:
Bits Symbol Meaning
0 EQ.CFI Invalid lock.
1 EQ.CFO This user is
owner.
2 EQ.CFQ This user is
in queue for
specified
resource.
3 EQ.CFX Owner's access
is exclusive.
4-8 Reserved.
9-17 EQ.CFL Level number.
18-26 EQ.CFC The owner's
context
number.
27-35 EQ.CFJ The owner's
job number or
an error code.
1 .ENQCT A time stamp, in universal
date-time format, indicating
the time that the lock was
granted; or 0, indicating that
the resource is available.
22-133
ENQC. [CALLI 153]
Code Symbol Function
Offset Symbol Meaning
2 .ENQCI The left half (EQ.CIQ) contains
the number of users sharing the
resource. The right half
(EQ.CID) contains the
request-id of the owner of the
lock.
1 .ENQCG Returns user's quota in ac. The calling
sequence for the .ENQCG function is:
MOVE ac,[XWD .ENQCG,addr]
ENQC. ac,
error return
normal return
. . .
addr: XWD 0,jobno
where: jobno is the number of the job whose ENQ
quota is required. If jobno is -1, your
own job is assumed.
2 .ENQCC Changes user's quota. The calling sequence for
the .ENQCC function is:
MOVE ac,[XWD .ENQCC,addr]
ENQC. ac,
error return
normal return
. . .
addr: XWD quota,jobno
where: quota is the new ENQ/DEQ quota.
jobno is the number of the job whose
quota is to be changed. If jobno is -1,
your own job is assumed.
This function sets the lock quota for a specific
job. To perform this function, you must have
POKE privileges, be a [1,2] job, or be running
with the JACCT bit set. The ENQ/DEQ quota for
the specified job will be set to the value you
specify in the left half of the argument word on
a normal return. On a normal return, the ac is
cleared. If you attempt to use this function
without the required privileges, the error
return is taken and the monitor returns an error
code in the ac.
22-134
ENQC. [CALLI 153]
Code Symbol Function
3 .ENQCD Dumps the data base. The calling sequence for
the .ENQCD function is:
MOVE ac,[XWD .ENQCD,addr]
ENQC. ac,
error return
normal return
. . .
addr: XWD 0,len
where: addr is the address of a buffer to
receive the returned data.
len is the length of the data block to
be returned, minus one word.
This function dumps the data base (all lock and
queue entries). The entire data base is placed
in your area, beginning with addr+1. If this
length is not large enough to accommodate the
entire data base, the monitor returns as much as
possible of the data base. The end of the data
base is indicated by a word containing -1. You
must have SPY privileges to specify this
function code. The format of the returned data
is described in Chapter 8.
Normal Return
The requested function is performed.
Error Return
The error codes that can be returned in the ac on an error return
are identical to those that can be returned from the ENQ. and
DEQ. calls. The error codes are listed in the description of
the ENQ. call.
Related Calls
DEQ., ENQ.
22-135
ENTER [OPCODE 077]
ENTER [OPCODE 077]
Function
Specifies an output file to create, supersede, or update a file.
Use FILOP. to perform an ENTER for an extended I/O channel.
Calling Sequence
The ENTER monitor call has two types of argument lists: one
using a four-word argument list and one using an extended
argument list. The extended argument list offers many additional
options for ENTERing a file. For complete information about the
argument lists, refer to Section 11.13.
The calling sequence for the ENTER UUO is:
ENTER channo,addr
error return
normal return
where: addr is the address of the argument list. Refer to
Section 11.13 for more information about the argument
list.
Normal Return
When you use the short form of the argument block, the monitor
returns a four-word argument block at addr.
Refer to Section 11.13.1 for information about the argument block
that is returned.
When you use the extended argument list, the monitor returns the
information that is listed on Section 11.13.2.
Error Return
On an error return from ENTER, the monitor returns an error code
in either of the following:
o For the short-form argument block, the error code is stored
in the right half of addr+1 of the 4-word argument block
o For the extended-form argument block, the error code is
returned in the right half of addr+3.
22-136
ENTER [OPCODE 077]
It is possible to LOOKUP/RENAME a file after using an ENTER to
specify the argument list, referring to the same argument list
with subsequent calls. Note, however, that on an error return
from the ENTER, the error code overwrites the high-order three
bits of the creation date and the entire access date. Because
most programs recover from these errors by either aborting or by
reinitializing the entire argument block, this overwriting of
data normally does not cause any problems. However, a program
may attempt to recover from an error by fixing only the incorrect
portion of the argument block and then reexecuting the monitor
call. These programs should always initialize the contents of
these locations before reexecuting the ENTER monitor call.
Error codes are restricted to a maximum of 15 bits to eliminate
problems when recovering from an error in a file with a zero
creation date. The error codes are described in Section 11.14.
Examples
See Chapter 11.
Related Calls
ENTER, FILOP., INIT, LOOKUP, OPEN, RENAME
22-137
ENTVC. [CALLI 225]
ENTVC. [CALLI 225]
Function
Reads or sets an entry vector. An entry vector indicates the
entry point for a program. (Refer to the TOPS-10 LINK Reference
Manual and the TOPS-10 MACRO Assembler Manual for more
information on entry vectors.)
Calling Sequence
XMOVEI ac,addr
ENTVC. ac,
error return
normal return
addr: flag,,function
length
exec-addr
where: addr is the address of the argument list.
flag indicates whether the vector is read (0) or set
(EN.SET).
function is the function code described below.
length is a value returned by the monitor on a read, and
supplied by you on a set. A (JRST) in the right half
indicates that you are supplying a start address only in
exec-addr (if setting), or that the monitor is returning
the start address in exec-addr (if reading). Otherwise,
you supply a length for the entry vector (0-37 words,
octal), or the monitor returns the length of the entry
vector.
exec-addr contains the 30-bit address of the entry vector
or the start address, returned on a read, or to be set
for the set function. exec-addr is a user address.
The function code for ENTVC. is:
Code Symbol Meaning
0 .ENVRS Reads or sets the entry vector. Set the EN.SET
flag in the left half of the first word of the
argument block to perform a set. 0 in the left
half indicates a read should be performed.
22-138
ENTVC. [CALLI 225]
Normal Return
The specified function is performed.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 EVIAL% Illegal argument list.
2 EVIFC% Illegal function code.
3 EVADR% An address check was encountered.
22-139
ERLST. [CALLI 132]
ERLST. [CALLI 132]
Function
Returns data giving the status of each device on an MPX channel
that has errors.
Calling Sequence
MOVEI ac,addr
ERLST. ac,
error return
normal return
. . .
addr: XWD length,channo
BLOCK length-1
where: addr is the address of the argument block.
length is the length of the argument block; the length
should be the number of devices connected to the channel
plus two.
channo is the number of an initialized channel.
Normal Return
The monitor returns data at addr+1 for devices on the channel
that have errors. The data at addr is in the format:
addr: XWD length,channo
EXP number of devices
XWD udx,status
. . .
XWD udx,status
where: length and channo were given in the call.
number of devices is the number of devices on the channel
that have encountered errors.
udx is the Universal Device Index of a device having
errors.
status is a halfword containing I/O status bits for the
device. These bits are identical to those returned for a
GETSTS monitor call.
22-140
ERLST. [CALLI 132]
The monitor continues to return device error information in the
argument block until all space allocated by your program has been
filled. Your program should check the value of addr+1. If
addr+1 is greater than the length of the argument block minus
two, the device error list is incomplete because of lack of
space.
For a list of I/O status bits, see the appropriate device in
Volume 1.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 ERLBC% Illegal channel number.
2 ERLNM% Not an MPX-channel.
Related Calls
CLRST., GETSTS, SENSE.
22-141
ERRPT. [CALLI 160]
ERRPT. [CALLI 160]
Function
ERRPT. is a privileged monitor call used only by the DAEMON
program to ask the monitor for the next error condition to be
logged in the error file.
Calling Sequence
MOVE ac,[XWD len,addr]
ERRPT. ac,
error return
normal return
. . .
addr: BLOCK 4
where: len is the length and addr is the address of the argument
list that is filled in by the monitor on a normal return.
Normal Return
If an error condition (such as a stopcode or a hardware error) is
found, the monitor places values in the locations at addr as
follows:
Offset Symbol Contents
0 .ERPT0 Address, job number, and error code:
Bits Symbol Meaning
0-17 ER.PAD Address used by DAEMON.
18-26 ER.PJN Job number.
27-35 ER.PCD Error code for the error file.
1 .ERPT1 Two monitor internal addresses:
Bits Symbol Meaning
0-17 ER.PDA Address of DDB for device with
error condition.
18-35 ER.PUA Address of UDB for device with
error.
22-142
ERRPT. [CALLI 160]
Offset Symbol Contents
2 .ERPT2 CPU number.
Bits Symbol Meaning
0-14 Reserved for use by DIGITAL.
15-17 ER.CPU CPU number on which error was
detected.
18-35 Reserved for use by DIGITAL.
3 .ERPT3 Reserved for use by Digital.
Error Return
One of the following conditions occurred:
o The ERRPT. call is not implemented.
o The calling sequence was improper.
o No appropriate error condition was found. In this case, the
values of the words at addr are unchanged.
22-143
ETHNT. [CALLI 223]
ETHNT. [CALLI 223]
Function
The ETHNT. monitor call accesses the Ethernet. ETHNT. allows you
to read the Ethernet configuration, enable and disable protocols,
enable and disable multicast addresses, and send and receive
datagrams. For an overview of Ethernet, as well as a full
description of datagram buffers (addressed using .ETUBL) and
function buffers (addressed using .ETBFL and .ETBFA), refer to
Chapter 5, Volume 1.
Calling Sequence
XMOVEI ac,addr
ETHNT. ac,
error return
normal return
where: addr is the address of the ETHNT. argument block.
The argument block is:
|=======================================================|
| Flags | Function | Argument Block Length |
|=======================================================|
| |
| Function-Specific Arguments |
| |
|=======================================================|
22-144
ETHNT. [CALLI 223]
The format of the argument block is:
Offset Symbol Contents
0 .ETFCN Function code word for the argument block. This
word contains the length of the argument block,
and may also contain a flag. Its format is:
Bits Symbol Meaning
0-8 ET.FFL Function-specific flags.
Bit Symbol Meaning
1 ET.FZC Zero counters
after they
have been
read. Use
this flag
with
functions
.ETRCC,
.ETRPC, and
.ETRKC.
9-17 ET.FFN One of the function codes
listed at the end of the
argument block description.
18-35 ET.FLN Length of the argument
block.
1 .ETPSW Contains the portal status and the assigned
portal ID. ET.PST (Bits 0-8) may contain one or
more of the following flags:
Bit Symbol Meaning
0 ET.PON Portal is online.
1 ET.PXB Transmit buffers available.
2 ET.PRB Receive buffers available.
The rest of .ETPSW contains the portal ID,
.ETPID, assigned by the monitor.
1 .ETCSW Contains the channel status and channel ID.
ET.CST (Bits 0-8) contains the channel status.
If the ET.CON flag in ET.CST is on, the channel
is online. ET.CID (Bits 9-35) contains the
channel ID.
22-145
ETHNT. [CALLI 223]
Offset Symbol Contents
1 .ETKSW Contains the status and ID of a controller.
ET.KST (Bits 0-8) contains the controller
status. If the ET.KON flag in ET.KST is on, the
controller is online. ET.KID (Bits 9-35)
contains the controller ID.
2 .ETAR1 Contains the first function-specific argument.
Function-specific arguments are described in
each of the function codes below.
3 .ETAR2 Contains the second function-specific argument.
Valid function codes for .ETFCN are:
Code Symbol Meaning
1 .ETOPN Opens a user portal. This function requires
JP.POK privileges. This function specifies the
protocol type to be enabled, and protocol
specific flags. The argument block is:
Word Symbol Contents
0 .ETFCN Contains the function code .ETOPN
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETCIW Identifies the Ethernet channel
on which the protocol should be
enabled.
3 .ETPIW Identifies the protocol type to
be enabled on the Ethernet
channel. Set the ET.PAD flag in
the left half of .ETPIW to enable
padding for the protocol.
22-146
ETHNT. [CALLI 223]
Code Symbol Meaning
2 .ETCLS Closes a user portal and releases all resources
associated with it. The argument block
contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETCLS
in Bits 9-17, and the length of
the argument block, 2, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
3 .ETQRB Queues receive datagram buffers. The argument
block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETQRB
in Bits 9-17, and the length of
the argument block, 3, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETUBL Contains the address of the user
buffer descriptor list. Refer to
Chapter 5, Volume 1 for the
format of the user buffer
descriptor list.
4 .ETRRQ Reads receive queue. This function fills each
block in the buffer descriptor list with data
appropriate to a received datagram. The
argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRRQ
in Bits 9-17 and the length of
the argument block, 3, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
22-147
ETHNT. [CALLI 223]
Code Symbol Meaning
Word Symbol Contents
2 .ETUBL Contains the address of the user
buffer descriptor list. Refer to
Chapter 5, Volume 1 for the
format of the user buffer
descriptor list. The status
field in .UBSTS of the buffer
descriptor contains zero if the
datagram was received
successfully.
5 .ETQXB Transmits datagram buffer to the destination
Ethernet address specified in the buffer
descriptor block. The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETQXB
in Bits 9-17, and the length of
the argument block, 3, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETUBL Contains the address of the user
buffer descriptor list. Refer to
Chapter 5, Volume 1 for the
format of the user buffer
descriptor list.
6 .ETRXQ Returns data associated with transmitted
datagrams. The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRXQ
in Bits 9-17, and the length of
the argument block, 3, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
22-148
ETHNT. [CALLI 223]
Code Symbol Meaning
Word Symbol Contents
2 .ETUBL Contains the address of the user
buffer descriptor list. Refer to
Chapter 5, Volume 1 for the
format of the user buffer
descriptor list. On a successful
transmission, the returned status
is zero.
7 .ETEMA Enables a portal to receive datagrams destined
for an Ethernet multicast address. .ETEMA may
not be used while a promiscuous receiver is
active. The argument block for .ETEMA contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETEMA
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETMCA Contains the two word Ethernet
multicast address.
10 .ETDMA Disables a portal from receiving datagrams bound
for a multicast address. The multicast address
you disable must have been previously enabled
using the .ETEMA function. The argument block
contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETDMA
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETMCA Contains the two word Ethernet
multicast address.
22-149
ETHNT. [CALLI 223]
Code Symbol Meaning
11 .ETRCL Returns a list of all known channels. The
argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRCL
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETCSW Reserved.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
12 .ETRCI Returns information about a specific channel.
The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRCI
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETCSW Contains the channel-id in Bits
9-35. Returns an updated channel
status in Bits 0-8. Flag ET.CON
indicates whether the channel is
on- or off-line.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
22-150
ETHNT. [CALLI 223]
Code Symbol Meaning
13 .ETRCC Returns a list of the counters associated with a
channel, and (optionally) zeroes them. Zeroing
the counters requires JP.POK privileges. The
argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRCC
in Bits 9-17, and the length of
the argument block, 4, in the
right half. Set the ET.FZC flag
of .ETFCN if you want the
counters zeroed after information
is returned.
1 .ETCSW Contains the channel-id in Bits
9-35. Returns an updated channel
status in Bits 0-8. Flag ET.CON
indicates whether the channel is
on- or off-line.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
14 .ETSCA Sets the physical address associated with a
channel. The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETSCA
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETCSW Contains the channel-id in Bits
9-35. Returns an updated channel
status in Bits 0-8. Flag ET.CON
indicates whether the channel is
on- or off-line.
2 .ETEAD Specifies the physical address.
.ETEAD is two words long. It may
not be a multicast address.
22-151
ETHNT. [CALLI 223]
Code Symbol Meaning
15 .ETRPL Returns a list of all portals on a channel. The
argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRPL
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETCSW Contains the channel-id in Bits
9-35. Returns an updated channel
status in Bits 0-8. Flag ET.CON
indicates whether the channel is
on- or off-line.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
The list is returned in the specified buffer,
with each portal ID occupying a full word, right
justified (.ETPSW format).
16 .ETRPI Returns all information (except counters) about
a specific portal. The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRPI
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
The information is returned in the specified
buffer.
22-152
ETHNT. [CALLI 223]
Code Symbol Meaning
17 .ETRPC Returns a list of the counters associated with a
portal, and (optionally) zeroes them. Zeroing
the counters requires JP.POK privileges. The
argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRPC
in Bits 9-17, and the length of
the argument block, 4, in the
right half. Set the ET.FZC flag
if you want the counters zeroed
after the information is
returned.
1 .ETPSW Contains the portal-id in Bits
9-35. Returns an updated portal
status in Bits 0-8.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
20 .ETRKL Returns a list of all controllers on a channel.
The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRKL
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETCSW Contains the channel-id in Bits
9-35. Returns an updated channel
status in Bits 0-8. Flag ET.CON
indicates whether the channel is
on- or off-line.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
The list is returned in the specified buffer,
with each portal ID occupying a full word, right
justified (.ETKSW format).
22-153
ETHNT. [CALLI 223]
Code Symbol Meaning
21 .ETRKI Returns all information (except counters) about
a specific controller. The argument block
contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRKI
in Bits 9-17, and the length of
the argument block, 4, in the
right half.
1 .ETKSW Contains the controller-id in
Bits 9-35. Returns an updated
controller status in Bits 0-8.
Flag ET.KON indicates whether the
controller is on- or off-line.
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
The information is returned in the specified
buffer.
22 .ETRKC Returns a list of the counters associated with a
controller, and (optionally) zeroes them.
Zeroing the counters requires JP.POK privileges.
The argument block contains:
Word Symbol Contents
0 .ETFCN Contains the function code .ETRKC
in Bits 9-17, and the length of
the argument block, 4, in the
right half. Set the ET.FZC flag
if you want the counters zeroed
after the information is
returned.
1 .ETKSW Contains the controller-id in
Bits 9-35. Returns an updated
controller status in Bits 0-8.
Flag ET.KON indicates whether the
controller is on- or off-line.
22-154
ETHNT. [CALLI 223]
Word Symbol Contents
2 .ETBFL Contains the length of the
destination buffer.
3 .ETBFA Contains the address of the
destination buffer.
Normal Return
The requested function is performed, and information is returned
as specified in the description of the function.
Error Return
One of the following codes is returned in the ac:
Code Symbol Error
1 ETPRV% Program has insufficient privileges.
2 ETADC% Address check attempting to read argument block.
3 ETIAL% Illegal argument list length.
4 ETILF% Illegal function code specified.
5 ETUEE% Unexpected Ethernet error.
6 ETRES% Insufficient resources.
7 ETIPI% Invalid portal ID.
10 ETICI% Invalid channel ID.
11 ETIPT% Invalid protocol type.
12 ETPIU% Protocol type already in use.
13 ETPRA% Promiscuous receiver active.
14 ETBAC% Buffer address check.
15 ETIBS% Invalid buffer size.
16 ETIBP% Invalid byte pointer.
17 ETIEA% Invalid Ethernet address.
20 ETPQE% Portal quota exceeded.
21 ETBQE% Buffer quota exceeded.
22 ETPWS% Protocol in wrong state.
23 ETIKI% Invalid controller ID.
22-155
EXIT [CALLI 12]
EXIT [CALLI 12]
Function
Stops job execution and optionally resets the job.
Calling Sequence
EXIT fcn-code,
continue return
where: fcn-code is one of the function codes described below.
For either code, when you EXIT from a job in an
auto-pushed context, you are returned to the superior
context and the inferior one is deleted.
continue return is the instruction to be executed if the
user issues a valid CONTINUE monitor command.
The function codes and their meanings are:
Code Function
0 Performs the following:
o Releases all I/O devices, closing files if necessary.
o Unlocks the job from core.
o Sets the user-mode write-protect bit for the high
segment.
o Resets APR traps to zero.
o Clears PC flags.
o Performs a RESET and stops the job.
If timesharing was stopped by a TRPSET monitor call, the
monitor resumes timesharing. A RESET monitor call is
executed, and the word EXIT is typed on your terminal, and
the terminal is left in monitor mode. You cannot continue
with the CONT or CCONT monitor command.
22-156
EXIT [CALLI 12]
Code Function
1 Performs the following:
o Clears PC flags.
o Stops the job.
EXIT is not printed on your terminal, and you can continue
program execution with the CONT or CCONT monitor command.
If you use function code 1, you should first RELEASE all
devices and channels; a convenient way to do this is to
use the RESET monitor call. The symbol for EXIT 1, is
MONRT.
2-17 Reserved for use by DIGITAL.
Related Calls
LOGOUT, MONRT.
22-157
FILOP. [CALLI 155]
FILOP. [CALLI 155]
Function
Performs various file operations, including initializing channels
and creating, deleting, writing, reading, renaming, appending to,
and superseding files.
Calling Sequence
MOVE ac,[XWD len,addr]
FILOP. ac,
error return
normal return
. . .
addr: arglst
where: len is the length of the argument list.
addr is the address of the argument list.
The argument block for FILOP. functions 1 through 6 and 13
through 15 looks like this:
0 9 17 18 35
!===============================================================!
! Flags ! FO.CHN ! Function Code !
!---------------------------------------------------------------!
! I/O mode !
!---------------------------------------------------------------!
! Device name or UDX !
!---------------------------------------------------------------!
! Output buffer header ! Input buffer header !
!---------------------------------------------------------------!
! Number of output buffers ! Number of input buffers !
!---------------------------------------------------------------!
! Ptr to RENAME block ! Ptr to LOOKUP block !
!---------------------------------------------------------------!
! Length of PATH block ! Ptr to PATH block !
!---------------------------------------------------------------!
! Project number ! Programmer number !
!---------------------------------------------------------------!
! Length of filespec block ! Ptr to filespec block !
!---------------------------------------------------------------!
! Output buffer starting addr ! Input buffer starting addr !
!---------------------------------------------------------------!
! Output buffer size ! Input buffer size !
!===============================================================!
22-158
FILOP. [CALLI 155]
The format of the argument list (for functions 1-6 and 13-15) is:
Offset Symbol Contents
0 .FOFNC Flags, channel number, and function code:
Bits Symbol Meaning
0 FO.PRV Indicates that the program with
appropriate privileges ([1,2]
or JACCT) will perform
privileged FILOP. functions.
You must set this bit to use
privileged FILOP. functions.
1 FO.ASC Assigns an extended channel
number, one that is greater
than 17. When you set this bit
for an OPEN function (function
codes 1 through 6) the monitor
assigns the next available
channel number. It then
performs the requested
function. On return, the
monitor returns the assigned
channel number in FO.CHN in the
argument block or, if FO.CFW is
set, in the address pointed to
by the left half of the word at
the location specified in
FO.FNC. The number will be
equal to or greater than 20 so
that existing channel number
allocations will not be
affected.
2 FO.UOC Specifies the file that is open
on the channel that is
indicated in the right half of
this word (.FOFNC). Normally,
a RENAME function is performed
on the file specified in the
right half of .FOLEB. When you
set this bit, however, the
right half of .FOLEB is
ignored, and the function is
performed on the file that is
open on the specified channel.
22-159
FILOP. [CALLI 155]
Offset Symbol Contents
Bits Symbol Meaning
3 FO.CFW Indicates that the right half
of this function word contains
an address. At that address,
you must store:
channel-addr,,function-code
where the channel-addr is the
address where the channel
number is stored. For this
format, the field FO.CHN is
ignored.
4-8 Reserved for use by DIGITAL.
9-17 FO.CHN Channel number.
18-35 FO.FNC Function code (see below).
1 .FOIOS I/O status (open mode). Note that any bits
appearing here may also be set by OPEN call (see
.OPMOD in OPEN call).
2 .FODEV SIXBIT device name or Universal Device Index.
3 .FOBRH Buffer ring header pointers:
Bits Meaning
0-17 Address of output buffer ring header.
18-35 Address of input buffer ring header.
If the value of this word is 0, there is no
corresponding buffer ring header.
4 .FONBF Number of buffers needed. The left half is the
number of output buffers needed. The right half
is the number of input buffers needed. If zero
buffers are requested in a FILOP. monitor call,
the monitor does not set up any buffers. It
also does not clear any buffer ring that is
already set up, and does not clear the first
word of the buffer ring header. Thus, a FILOP.
causing an OPEN allows an old buffer ring to be
recycled.
22-160
FILOP. [CALLI 155]
Offset Symbol Contents
This word allows a user program to set up its
own buffer ring. If you specify 777777 octal,
the monitor sets up a ring of 2 buffers for
non-disk devices. If no default has been set
for this job, the monitor uses the system
default for non-disk devices, or a ring of n
buffers for disk devices, where n is specified
by the SET DEFAULT BUFFERS monitor command or
SETUUO. This argument to FILOP. performs the
same action as the INBUF and OUTBUF monitor
calls and is needed only for buffered I/O.
5 .FOLEB Pointers to RENAME and LOOKUP/ENTER blocks:
Bits Meaning
0-17 Address of RENAME block (see RENAME
monitor call).
18-35 Address of LOOKUP/ENTER block (see
LOOKUP/ENTER monitor call).
6 .FOPAT Length of, and pointer to PATH. block (see PATH.
monitor call). The actual path of the file
found or created is returned in this block. A
specific path for finding or creating the file
must still be specified in the LOOKUP, ENTER, or
RENAME argument block.
7 .FOPPN Project-programmer number. Set the FO.PRV flag
if you include this word and want it to take
effect. The monitor then performs the file
operation as if the current job were logged in
under the given PPN. If FO.PRV is set in Word 0
(.FOFNC), and a PPN is supplied in this word,
your program acquires the file access rights and
restrictions of that PPN. This allows you to do
file operations in behalf of the user whose PPN
you include here. If you specify [1,2] in this
word, you lose full file access. This word is
ignored if the job is not logged in under [1,2]
or does not have JACCT privileges.
10 .FOFSP Length of and pointer to a block in which the
full file specification of the new file should
be stored. If you include this word, the file
specification is returned automatically.
Alternatively, you can specify function 33
(.FOFIL) to only return the file specification.
Refer to .FOFIL for the format of the returned
block.
22-161
FILOP. [CALLI 155]
Offset Symbol Contents
11 .FOBSA Buffer starting address. The left half contains
the starting address of the output buffer ring,
(FO.OSA) the right half holds the starting
address of the input buffer ring, (FO.ISA).
12 .FOBSZ Size of the input and output buffers. The left
half, FO.OSZ, contains the output buffer size.
FO.ISZ, the right half, holds the size of the
input buffer.
13 .FOMAX Length of the FILOP. argument block.
The function codes and their meanings are:
Code Symbol Function
1 .FORED Opens the file described by the LOOKUP/ENTER
block for reading (duplicates LOOKUP call). You
must include the LOOKUP/ENTER block pointer for
directory devices when you are using this
function.
2 .FOCRE Creates the file described by the LOOKUP/ENTER
block. This function strictly requires creation
of the file; if a matching file is found in the
directory, the error return is taken. The
LOOKUP/ENTER block pointer is required for the
.FOCRE function.
3 .FOWRT Writes the file described by the LOOKUP/ENTER
block. This function supersedes any matching
file in the directory, or creates a new file.
The LOOKUP/ENTER block pointer is required for
the .FOWRT function.
4 .FOSAU Updates the file described by the LOOKUP/ENTER
block in exclusive access mode. No other user
can write to this file until it is closed. The
LOOKUP/ENTER block pointer is required for the
.FOSAU function. If the specified file does not
exist, it will be created automatically for this
function.
5 .FOMAU Updates the file described by the LOOKUP/ENTER
block, in multi-access mode. This allows other
users to read and write the file. The
LOOKUP/ENTER block pointer is required for the
.FOMAU function.
22-162
FILOP. [CALLI 155]
Code Symbol Function
6 .FOAPP Appends to the file described in the
LOOKUP/ENTER block. Note that if the buffers
were built by this FILOP. call, the last block
of the file will be read into the first buffer.
The byte count and byte pointer are set to write
data immediately after the last word of the
file. The LOOKUP/ENTER block pointer is
required for the .FOAPP function.
7 .FOCLS Closes the file associated with the channel
specified in the word at addr. This function
does not accept the standard FILOP. argument
list. Instead, you include the CLOSE flags
(refer to the CLOSE UUO) in addr+1. The monitor
executes a GETSTS call for the file. The I/O
status bits are returned in the ac. For a list
of I/O status bits, refer to the appropriate
device chapter in Volume 1. If the argument
block is two or more words long, then the right
half of .FOIOS is taken to be the optional CLOSE
status bits (for example, CL.DAT or CL.NMB). If
there are errors, the monitor takes the error
return and returns an error code in the ac.
10 .FOURB Checkpoints the file associated with the channel
specified in the word at addr. Only the
function word of the FILOP. argument block is
required. The monitor writes all output buffers
to disk, updates directories, updates checksums
in RIB pointers, and updates the end-of-file
pointer. The file remains open for further I/O.
The .FOURB function is meaningful only for files
that are being written.
NOTE
If output is not complete, the monitor
writes the last partially filled word;
this may leave null bytes in the word.
22-163
FILOP. [CALLI 155]
Code Symbol Function
11 .FOUSI Performs a USETI monitor call (specifies next
block number to be input) for a specified block
of the file associated with the channel
specified at addr, setting that block for next
input. The format of the argument list for the
.FOUSI function is:
addr: XWD channo,.FOUSI
EXP blockno
where: channo and blockno give the channel
number and block number of the file. Refer to
the USETI call for more information.
On a normal return, the I/O status bits are
returned in the ac. The monitor takes the error
return if the block number is larger than the
specified file or no previous LOOKUP was
executed. .FOUSI returns error code %ERILU if
the argument block is not exactly two words
long.
12 .FOUSO Performs a USETO monitor call for a specified
block of the file associated with the channel
specified at addr, setting that block for next
output. The format of the argument list for the
.FOUSO function is:
addr: XWD channo,.FOUSO
EXP blockno
where: channo and blockno give the channel
number and block number of the file. Refer to
the USETO call for more information.
The monitor takes the error return if not enough
space is available or no previous ENTER was
executed. The I/O status word is returned in
the ac for a successful return. .FOUSO returns
error code %ERILU if the argument block is not
exactly two words long.
13 .FORNM Renames the file described by the RENAME block.
The LOOKUP/ENTER block pointer and the RENAME
block pointer are required for the .FORNM
function, unless the file is already open on the
specified channel. However, if a file is open
on the channel specified in .FOFNC, and if you
set the flag FO.UOC in the same word, then the
right half of .FOLEB is ignored, and the
function is performed on the open file.
22-164
FILOP. [CALLI 155]
Code Symbol Function
14 .FODLT Deletes the file described by the LOOKUP block.
Pointers to both LOOKUP and RENAME blocks are
required for this function, unless you set the
flag FO.UOC, and a file is open on the channel
specified in .FOFNC. In this case, the right
half of .FOLEB is ignored and the function is
performed on the open file.
15 .FOPRE Preallocates space for the file described by the
LOOKUP/ENTER block. This function is most
useful for batch jobs. If a preallocated file
is entered but not written, the space is still
allocated; a CLOSE for the file will not
deallocate the space.
If the file is entered immediately after being
preallocated, it is not superseded; any
subsequent ENTER to the file will supersede it.
The LOOKUP/ENTER block pointer is required for
the .FOPRE function.
16 .FOSIO Opens a device for super-I/O (refer to the
SUSET. UUO). The first four words of the
argument list are required for this function.
This function does not require .FOLEB.
17 .FOINP Performs INPUT monitor call. Reads data from
the file opened on the specified channel. The
argument list is:
addr: XWD channo,.FOINP
addr1
addr2
where: addr1 is the address of the next buffer
to be used in non-dump I/O, or the address of
the dump mode command list if using dump I/O.
This word is optional for non-dump I/O. addr2
is the optional address of a word containing the
block number of the file to perform a USETI to
before writing. The I/O status bits are
returned in the ac.
22-165
FILOP. [CALLI 155]
Code Symbol Function
20 .FOOUT Performs OUTPUT monitor call. Writes data to
the file opened on the specified channel. The
argument list is:
addr: XWD channo,.FOOUT
addr1
addr2
where: addr1 is the address of the next buffer
to be used in non-dump I/O, or the address of
the dump mode command list. addr2 is the
optional address of a word that contains the
block number of the file to perform a USETO to
before reading. .FOIOS is optional for buffered
I/O modes. The I/O status bits are returned in
the ac.
21 .FOSET Performs SETSTS monitor call. The format of the
argument list is:
addr: XWD channo,.FOSET
EXP setsts-bits
This function returns error code %ERILU if the
argument block is not exactly two words long.
22 .FOGET Performs GETSTS monitor call. The I/O status
bits are returned in the ac. The format of the
argument list is:
addr: XWD channo,.FOGET
23 .FOREL Performs RELEAS monitor call. The format of the
argument list is:
addr: XWD channo,.FOREL
24 .FOWAT Waits for I/O to finish. The format of the
argument list is:
addr: XWD channo,.FOWAT
25 .FOSEK Obsolete.
26 .FORRC Rewrites the RIB of a file if it has changed.
This function is ignored and the normal return
is taken if the channel is not a disk or if the
RIB has not changed. The argument list for this
function is:
addr: XWD channo,.FORRC
22-166
FILOP. [CALLI 155]
Code Symbol Function
27 .FOGTF Returns the block number of the first file on a
DECtape. If the device on the channel is not a
DECtape, the ac is not changed. This duplicates
the UGETF call, but allows you to use extended
channel numbers. The argument list for this
function is:
addr: XWD channo, .FOGTF
30 .FOMTP Performs the function of an MTAPE. call, but
allows you to use extended channel numbers. The
MTAPE. code is included in the FILOP. argument
list as shown:
addr: XWD channo,.FOMTP
EXP n
In the argument list shown here, the value of n
is equivalent to the MTAPE. code for the
function to be employed. For example, EXP 1
would perform the MTREW. function.
This function returns error code %ERILU if the
argument block is not two or more words long.
31 .FOUTP Clears a DECtape directory. Duplicates the
UTPCLR call. The argument list for this
function is:
addr: XWD channo, .FOUTP
This function returns the ac unchanged if
successful.
32 .FORAW Renames the file with the specified number of
words for allocation. Same function as .FORNM,
but allocation in words is specified in .RBSIZ
of extended RENAME argument block.
33 .FOFIL Returns the file specification of the file that
is open on this channel. To return the file
specification as well as to perform another
function, include Word 10 (.FOFSP) in the
argument block instead of using the .FOFIL
function. The argument list for this function
is:
addr: XWD channo,.FOFIL
XWD len,addr2
22-167
FILOP. [CALLI 155]
Code Symbol Function
where the second word contains the length (len)
and address (addr2) of the block where the file
specification should be stored.
34 .FOFXI Performs an IN monitor call, using extended
addressing and dump mode I/O. The argument list
is:
addr: XWD channo, .FOFXI
addr1
addr2
where: channo is the channel number from which
data is read from the opened file. addr1 is the
address of the command list, which has a
two-word format. The first word of each command
word pair contains the length of the command
list. The second word of each command word pair
holds the address where I/O should be performed.
If the length is zero, the address in the second
word is the location of the next command list.
When both the length and the address are zero,
the end of the list has been encountered. addr2
is the (optional) address of a word containing
the block number of the file to perform a USETI
to before reading. The I/O status bits are
returned in the ac.
35 .FOFXO Performs an OUT monitor call, using extended
addressing and dump-mode I/O. The argument list
is:
addr: XWD channo, .FOFXO
addr1
addr2
where: channo is the channel number on which
data is written to the opened file. addr1 is
the address of the command list. Command list
format is described above in .FOFXI. addr2 is
the (optional) address of a word containing the
block number of the file to perform a USETO to
before writing. The I/O status bits are
returned in the ac.
The file specification is returned when you use function .FOFIL
or when you specify an address in .FOFSP (offset 10 into the
argument block). For .FOFSP, the following data block is
returned at the address you specify in the right half of the
word. For .FOFIL, this data is returned in the argument block at
addr2.
22-168
FILOP. [CALLI 155]
Offset Symbol Contents
0 .FOFND Reserved for use by DIGITAL.
1 .FOFDV Device name.
2 .FOFFN File name.
3 .FOFEX File extension.
4 .FOFPP PPN.
5 .FOFSF First SFD.
6-10 Subsequent levels of SFDs.
Note that words 5 through 10 are returned only where appropriate,
and that the entire block is ended by a zero word. When you
reserve the block for the file specification, be sure to include
space for this zero word.
Multiple channels of a single job and/or multiple jobs can update
a file simultaneously using FILOP. The monitor imposes no
restrictions or interlocks when a file is being simultaneously
updated. Therefore, users must ensure that separate jobs do not
update the same block of the same file at the same time. The
ENQ/DEQ Facility (refer to Chapter 8) may be used to ensure that
such interference does not occur, but the monitor does not
require its use when simultaneously updating a file.
To update a file simultaneously, your program performs a
FILOP. monitor call using function code 5 (.FOMAU). A file can
be updated in this manner when the file is idle, when it is being
read, or when it is being updated by other jobs. A file cannot
be simultaneously updated if the file is in single-access update
mode; that is, when a LOOKUP and an ENTER have been performed or
a FILOP. has been performed with function code 4 (.FOSAU) or 6
(.FOAPP).
Note that even though an extended LOOKUP/ENTER/RENAME block can
be specified by the FILOP. monitor call, your program cannot
change the file attributes of a simultaneously updated file. The
current file attributes will be returned in the extended argument
block on a LOOKUP, and those same values will be used for the
ENTER. In other words, FILOP. uses the LOOKUP values on the
ENTER.
In order to prevent excessive monitor overhead, files that are to
be simultaneously updated should be pre-allocated into contiguous
blocks, if possible. This will prevent the creation of
inefficient retrieval pointers, and will lessen the chance that
extended RIBs will be created.
Normal Return
The requested function has been performed.
22-169
FILOP. [CALLI 155]
Error Return
Error codes are returned in the ac for the FILOP. call. If -1 is
returned in the ac, an invalid argument list was supplied. Other
error codes are identical to those used by LOOKUP/ENTER. These
are listed in Section 11.14, in Volume 1. Note that several
functions return the I/O status word in the ac.
Examples
See Chapter 11, Monitor Calls Manual, Volume 1.
Related Calls
CLOSE, ENTER, GETSTS, IN/INPUT, LOOKUP, MTAPE, OPEN, OUT/OUTPUT,
PATH., RELEAS, RENAME, SETSTS, SUSET., UGETF, USETI/USETO,
UTPCLR, WAIT
22-170
FRCUUO [CALLI 106]
FRCUUO [CALLI 106]
Function
Forces a monitor command for a job or a terminal. This monitor
call requires JP.POK, JACCT, or [1,2] privileges.
Calling Sequence
MOVE ac,[XWD len,addr]
FRCUUO ac,
error return
normal return
. . .
addr: SIXBIT /command/
/ XWD 0,jobno \ ;optional arguments
\ XWD 0,udx /
where: len is the length of the argument list. If you give a
zero len, the default is 1.
addr is the address of the argument list.
command is the name of a command (from the list below).
jobno is the number of a logged-in job. If you omit the
jobno, or specify it as zero, the current job is assumed.
udx is the Universal Device Index for the terminal.
The names of the commands that can be forced are:
Command Meaning
.BPT Forces a DDT breakpoint trap, simulating
<CTRL/D>.
.BYE Detaches the job, this command is forced when a
dataset disconnects.
.FCONT Continues the job; this command is forced when a
job is continued after it was halted by "Waiting
for operator action." (Refer to JCONTINUE monitor
command in the Commands Manual.)
.HALT Stops the job; this command is forced when you
type CTRL/C.
22-171
FRCUUO [CALLI 106]
Command Meaning
.HELLO Connects (greets) the job; this command is forced
when a dataset or network connect occurs, and
runs INITIA.
.NETLD Invokes execution of the program which does
automatic down-line loading for ANF-10 series
remote software.
.RESTA Greets the job but does not run INITIA.
.TYPE Types the current input buffer; this is
equivalent to typing CTRL/R.
HALT Stops the job (regardless of CTRL/C trapping).
INITIA This command is forced when the system is
initialized and is used to run INITIA for certain
terminals (this is controlled by MONGEN).
KJOB Kills the job; this command is used to force a
job to terminate.
USESTA Types status information; this is equivalent to
typing either CTRL/T or the USESTAT command.
Normal Return
The command is executed; the ac is unchanged.
Error Return
The ac is cleared.
Examples
MOVE T1,[XWD 2,ADDR]
FRCUUO T1,
JRST FRCERR
JRST CONTIN
ADDR: SIXBIT /.TYPE/
XWD 0,0
This code sequence displays the contents of the terminal input
buffer for the current job, as though the user had typed
<CTRL/R>.
22-172
GETLCH [TTCALL 6,]
GETLCH [TTCALL 6,]
Function
Returns the line characteristics for a terminal line.
Calling Sequence
GETLCH addr
return
. . .
addr: XWD 0,lineno
where: addr is the address of the argument list.
lineno is the line number for the terminal whose
characteristics are required. If you use -1 for addr,
the monitor returns characteristics for your job's
controlling terminal.
Normal Return
If the job is detached and addr contained -1, the monitor returns
a 0 word. On a normal return, the monitor returns the terminal's
UDX in the right half of addr (.UXTRM + lineno).
The following line characteristics are returned in the left half
of the word at addr:
Bit Symbol Characteristic
0 GL.ITY Pseudo-terminal (PTY).
1 GL.CTY Operator's terminal (CTY).
2 GL.DSP Display console (DIS).
3 GL.DSL Dataset line.
4 GL.CNE No characters are echoed.
5 GL.HDP Half-duplex line.
6 GL.REM Remote terminal.
7 GL.RBS Remote batch terminal.
8-9 Reserved for use by DIGITAL.
10 GL.8BM Terminal is open in 8-bit I/O mode.
22-173
GETLCH [TTCALL 6,]
Bit Symbol Characteristic
11 GL.LIN User has typed some input.
12 GL.SLV TTY SLAVE is in effect.
13 GL.LCM Terminal in lowercase mode.
14 GL.TAB Terminal has tab capability.
15 GL.LCP Local copy only (no echo).
16 GL.PTM Papertape mode is on (CTRL/Q, CTRL/S, and so
forth, control papertape motion instead of
terminal output).
17 GL.NEC Terminal is in no-echo mode. This
characteristic is set by setting IO.SUP in the
OPEN call, or by SETSTS, or by TRMOP
function .TOCOB. This setting is overridden
when the job goes to monitor level, and echoing
resumes. You can clear this bit using a RESET
call.
If you use an invalid line number, the monitor returns 0 in the
left half of the word at addr.
Related Calls
GETLIN, SETLCH, SETSTS, TRMOP., TTCALL
Common Errors
Typing a comma after addr.
22-174
GETLIN [CALLI 34]
GETLIN [CALLI 34]
Function
Returns the SIXBIT monitor-assigned name of the terminal attached
to your job.
Calling Sequence
GETLIN ac,
return
Return
The SIXBIT name of the terminal is in the ac, left-justified, in
the form TTYnnn, where nnn is the dynamic terminal number
associated with your job's terminal.
If your job is not attached to any terminal, the ac contains:
XWD 0,'nam'
Where: nam is the right half of the name of the terminal to
which your job was last attached (that is, nnn in
TTYnnn).
Examples
GETLIN T1, ;Get terminal name
TLNN T1,-1 ;Job detached?
JRST NOTTY ;Yes
. . . ;No
This sequence gets the name of the terminal for the job and
checks whether the job is currently detached.
22-175
GETPPN [CALLI 24]
GETPPN [CALLI 24]
Function
Returns the project-programmer number (PPN) for your job.
Calling Sequence
GETPPN ac,
normal return
alternate return
Where: alternate return is taken if your program has the JACCT
bit set and another job is logged in under the same PPN.
The GETPPN monitor call returns the project number in the left
half of the ac, and the programmer number in the right half of
the ac.
Examples
GETPPN T1,
JFCL
MOVEM T1,MYPPN
This code gets the PPN regardless of whether the program is
JACCTed.
Related Calls
OTHUSR
Common Errors
Forgetting the sequence of normal return followed by alternate
return.
22-176
GETSEG [CALLI 40]
GETSEG [CALLI 40]
Function
Replaces the current program high segment with a given high
segment. Refer to Chapter 2 for specific information about the
implementation of this call and the state of memory during the
GETSEG operation.
Calling Sequence
|
| MOVEI ac,addr
| GETSEG ac,
| error return
| normal return
| . . .
| addr: SIXBIT/device/
| SIXBIT/filename/
| SIXBIT/extension/
| EXP 0
| XWD proj,prog ;or PATH. pointer
| / XWD 0,addr2 \ ;core argument
| \ XWD -1,addr3 /
where: addr is the address of the 6-word argument block.
addr2 is the address of a PATH block.
device is the name of the device on which the high
segment resides.
filename specifies the name of the file containing the
new high segment.
extension specifies the extension of the file containing
the new high segment.
proj,prog is the project-programmer number for the
directory in which the high segment file resides. If you
specify this word to be zero, your default directory path
is assumed. If you specify this word as [XWD 0,addr3],
addr3 points to a PATH. block containing the full path
specification for the file. Refer to the description of
the PATH. monitor call for the format of a PATH. block.
The core argument word is optional. If it is zero, the
high segment is placed into the current PC section.
Otherwise, addr3 is the address containing the section
number where the high segment will be placed.
22-177
GETSEG [CALLI 40]
The GETSEG monitor call allows your program to initialize a high
segment from a file or from a currently-loaded sharable segment
without affecting your program's low segment. This facility can
be used for shared data segments, shared program overlays, and
runtime routines (such as FORTRAN and COBOL object-time systems).
On KL processors, if the high segment obtained by the GETSEG
monitor call is an execute-only segment, it is a concealed high
segment. You can give zeros for any argument except the file
name or device. The defaults are:
extension .EXE
PPN default directory path
Normal Return
The monitor replaces the current high segment with the given high
segment.
NOTES
If the given file contains both a high and a low
segment, the monitor brings in only the high
segment.
The contents of the accumulators are not
preserved (this aspect varies from monitor
version to monitor version).
The left half of .JBHRL is cleared.
The right half of .JBHRL is set to the new
highest legal user address in the high segment.
.JBSA and .JBREN are cleared if they contain
addresses in the new high segment. This removes
the program's start address, so that an error
will occur on a START or REENTER command.
Channel 0 is released by the GETSEG call. Other
channels are not released. Refer to the RELEAS
UUO.
A GETSEG call made from the current program's high segment can
succeed only if the start of the new high segment coincides with
the normal return for the call. Program execution returns to the
user program at the PC corresponding to the normal return from
the GETSEG UUO in the previous segment. It is the user's
responsibility to ensure that this PC contains instructions he
wishes to be executed.
22-178
GETSEG [CALLI 40]
Error Return
See Section 11.14 a list of GETSEG errors.
Related Calls
MERGE., RELEAS, RUN
Common Errors
o Forgetting to save the acs over the GETSEG.
o Forgetting that channel 0 is destroyed.
o Forgetting that a GETSEG from a high segment returns control
to the PC in the new high segment.
22-179
GETSTS [OPCODE 062]
GETSTS [OPCODE 062]
Function
Returns the I/O status bits for a device. Use FILOP. to perform
GETSTS on an extended I/O channel. The specific I/O status bits
for each device are listed in Volume 1 in the chapter specific to
the device.
Calling Sequence
GETSTS channo,addr
return
...
addr: BLOCK 1
where: channo is the channel number of the channel for which the
I/O status word is desired.
addr is the address of the word to receive the I/O status
word.
Return
The monitor returns the I/O status bits in the right half of the
word at addr, and the data mode for I/O in the left half of the
word at addr. The I/O status bits that are possible are:
Bits Symbol Meaning
18-21 IO.ERR Bit mask for device-independent I/O error flags.
18 IO.IMP Software detected improper data mode, or checksum
error occurred.
19 IO.DER Device error. Refer to specific device for cause
of this error.
20 IO.DTE Data error.
21 IO.BKT Block too large, quota exceeded, or file
structure is full.
22 IO.EOF End of file was reached.
23 IO.ACT Device is active.
24-29 Device-dependant error flags. These are listed
for each device in the appropriate chapter in
Volume 1.
22-180
GETSTS [OPCODE 062]
Bits Symbol Meaning
30 IO.SYN Synchronous mode I/O.
31 IO.UWC Use user's word count.
32-35 Data mode of the I/O, indicated by one of the
codes that are listed in Table 11-2 in Volume 1.
Related Calls
CLRST., ERLST., FILOP., SENSE., SETSTS, STATO, STATZ
Common Errors
o Forgetting that there is only one return from the call.
o If you give a nonexistent or uninitialized channel number,
the monitor stops your job and prints the following message
on your terminal:
?I/O to unassigned channel at user PC address
where address gives the program counter for your job at the
time of the failure.
|
| o Forgetting to clear the error status bits before retrying the
| GETSTS function. An INPUT function followed by GETSTS will
| not clear previously set bits. You should use SETSTS to
| clear the I/O error bits before attempting to read the new
| I/O error status.
22-181
GETTAB [CALLI 41]
GETTAB [CALLI 41]
Function
Returns a word from one of the monitor's GETTAB tables, allowing
your program to read many types of job and system information.
The GETTAB tables are listed in Chapter 23.
Calling Sequence
MOVE ac,[XWD index,table]
GETTAB ac,
error return
normal return
where: index is an index into the specified table. If the table
is indexed by job number, you can use -1 to obtain
information about your own job.
If the table is indexed by job number or segment number,
you can use -2 to return information about your own high
segment.
table gives the number of the GETTAB table.
Normal Return
The requested word from the table is returned in the ac.
Error Return
The index or the table number was invalid.
Examples
See Chapter 23 for examples.
22-182
GOBSTR [CALLI 66]
GOBSTR [CALLI 66]
Function
Returns file structure names from the search list for a job or
for the system.
To use the GOBSTR call for a job other than your own, you must
have either the JP.SPA privilege or the JP.SPM privilege set in
your .GTPRV word, or you must have JACCT privileges, or the job
must be logged into [1,2].
For a discussion of file structures in a search list, see the
SETSRC program in the TOPS-10 User Utilities Manual.
Calling Sequence
|
| MOVE ac,[XWD len,addr]
| GOBSTR ac,
| error return
| normal return
| . . .
| addr: EXP jobno ;.DFGJN
| XWD projno,progno ;.DFGPP
| / EXP -1 \ ;.DFGNM for first in list
| | EXP 0 | ;.DFGNM for first after FENCE
| \ SIXBIT/structure/ / ;.DFGNM for next in list
| EXP 0 ;.DFGDR
| BLOCK 1
where: len is the length of the argument list.
addr is the address of the argument list.
addr+2 contains the structure name, or 0, or -1.
Therefore you can begin with the first name in the list
by using -1 at addr+2; then when the monitor returns the
first name in the list, you can leave the name in addr+2
to call for the second name, and so forth. If the next
item in the list is FENCE, the monitor returns 0. If
there are no more items in the list, the monitor returns
-1.
22-183
GOBSTR [CALLI 66]
jobno is the number of a logged-in job (use -1 for the
current job; use 0 for the system search list).
projno,progno is a project-programmer number (PPN).
structure is the SIXBIT name of a file structure.
I/O status bits are returned at addr+4 as follows:
Bits Symbol Meaning
0 DF.SWL If on, software write-protect is set.
1 DF.SNC If on, creation of files is not allowed on this
structure, unless the structure name is
explicitly included in the file specification.
Refer to Chapter 12 for more information.
Normal Return
The monitor returns the required SIXBIT structure name (or 0 or
-1) at addr+2, and the I/O status word at addr+4.
Error Return
The monitor returns one of the following error codes in the ac:
Code Symbol Meaning
3 DFGIF% File structure name is not 0, -1, or a
file structure name in SIXBIT.
6 DFGPP% The specified job number and
project-programmer number do not
correspond.
10 DFGNP% Your job is not privileged.
12 DFGLN% The specified length of the argument
block is invalid.
22-184
GOBSTR [CALLI 66]
Examples
The following code reads all the structures in the job search
list.
MOVEI T1,0 ;Initialize counter
LOOP: MOVE T2,[.DFGST+1,,ADDR]
GOBSTR T2, ;Get next structure
JRST ERROR
MOVE T2,ADDR+.DFGNM ;Get structure name
MOVEM T2,STRTAB(T1) ;Save in table
AOJE T2,CONTIN ;Last one if -1
AOJA T1,LOOP ;Bump table pointer and loop
ADDR: EXP JOBNO ;Job number
XWD PROJ,PROG ;PPN
EXP -1 ;Get first one in list
EXP 0
EXP 0
STRTAB: BLOCK 30 ;Space to store search list
Related Calls
DSKCHR, JOBSTR, STRUUO, SYSSTR
22-185
GTNTN. [CALLI 165]
GTNTN. [CALLI 165]
Function
Returns the node number and line number for a terminal. This
call is applicable to network systems only.
Calling Sequence
|
| / MOVE ac,[SIXBIT/terminal-name/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| GTNTN. ac,
| error return
| normal return
|
| where: terminal-name is the monitor-assigned name of the
| terminal, returned when you use the GETLIN monitor call.
|
| udx is the Universal Device Index for the terminal.
|
| channo is the channel number of the channel to which the
| terminal is connected.
Normal Return
The monitor returns the node number and the line number in the ac
in the form:
node-number,,line-number
The node-number is the number of the node at which the specified
terminal is located. The line-number on non-network systems is
equivalent to the terminal number. On a network system,
line-number is the physical line number of the terminal on the
node to which the terminal is connected.
Networked terminals are assigned logical line numbers from a pool
of network terminal numbers when they connect to a host.
Therefore, the logical line number will change as the particular
node to which the terminal is attached comes on-line, and as the
terminal connects to, and disconnects from a host.
22-186
GTNTN. [CALLI 165]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 NTNSD% Nonexistent device.
1 NTNAT% Device is not a terminal.
2 NTTNC% Terminal is not connected.
Related Calls
GTXTN., NETOP.
22-187
GTXTN. [CALLI 166]
GTXTN. [CALLI 166]
Function
Returns the physical name of the terminal for a given node and
line number. This call applies to network systems only.
Calling Sequence
MOVE ac,[XWD nodeno,lineno]
GTXTN. ac,
error return
normal return
Where: nodeno is the node number for a terminal.
lineno is the physical line number for the terminal at
the node.
Normal Return
The physical name of the terminal is returned in ac in the form:
SIXBIT/name/
Where: name is the physical name of the terminal (such as
TTY427).
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 XTUNT% Unknown terminal (node number or the line number
specified is not known or node or line is not
connected to the DECsystem-10).
1 XTNLT% Not a legal terminal.
Related Calls
GTNTN., NODE.
22-188
HIBER [CALLI 72]
HIBER [CALLI 72]
Function
Suspends execution of the job until a specified event occurs.
Calling Sequence
MOVE ac,[flags+sleeptime]
HIBER ac,
error return
normal return
Where: flags specify conditions described below.
sleeptime gives the amount of time for the job to sleep.
If HB.SEC is set in flags, the sleeptime is specified in
seconds; otherwise, it is specified in milliseconds.
The sleeptime is rounded upward to the next larger jiffy, with a
maximum of 262 seconds. If you set HB.SEC, the maximum sleeptime
is about 72 minutes (at 60 Hz) or 87 minutes (at 50 Hz). If you
need a longer sleeptime, use the PITMR. UUO, or the .CLOCK
function of the DAEMON UUO. If you give the sleeptime as 0, the
job sleeps until awakened by one of the specified events, or by a
WAKE monitor call.
If your job is hibernating, it can be woken by another job if
that job has sufficient privileges. Refer to the WAKE UUO.
To prevent your job from oversleeping and missing an event, the
monitor sets the wakeup bit even if the job is already awake.
You can use another HIBER call to clear the bit. You cannot
assume that any of the specified events actually occurred to WAKE
your job; therefore you should test for all the events that may
have caused your job to awaken, and explicitly execute another
HIBER call if you were WAKEd unexpectedly.
You can also clear the wake-enable bit for your job by using the
RESET monitor call. Note that until the first HIBER call is
executed, there is no protection against wakeup commands from
other jobs. To guarantee your job's protection, you should
execute a WAKE monitor call for your job, followed by a HIBER
call giving the protection you want. The HIBER will return
immediately, having set the protection codes as desired.
22-189
HIBER [CALLI 72]
The bits and their meanings are:
Bits Symbol Meaning
0 HB.SWP Clear the in-core protect time, making the job
available for swapping out.
1 HB.SEC The sleeptime is specified in seconds.
9 HB.DIN When set in conjunction with HB.RTL and/or
HB.RTC, enables the JB.UHI bit in JOBSTS, which
allows terminal input from programs such as
BATCON and OPR. The job is awakened on input to
the terminal.
10 HB.IPC Wake the job when an IPCF packet is placed in
its input queue.
11 HB.RIO Wake the job when asynchronous I/O is completed.
12 HB.RPT Wake the job for PTY activity.
13 HB.RTL Wake the job when a line of terminal input is
typed on any terminal assigned to your job, or
if there is a rescanable line available on the
job's controlling terminal.
14 HB.RTC Wake the job when a character of terminal input
is ready.
15 HB.RWJ Wake the job only on a WAKE monitor call from
the job itself. Setting this bit prevents other
jobs from waking your job, unless the other job
is privileged.
16 HB.RWP Wake the job only on a WAKE monitor call from a
job having the same programmer number.
17 HB.RWT Wake the job only on a WAKE monitor call from a
job having the same project number.
Normal Return
When an enabled HIBER condition occurs, execution resumes at the
normal return.
22-190
HIBER [CALLI 72]
Error Return
The HIBER call takes the error return only if it is not
implemented on your system.
Examples
MOVSI T1,(HB.RWP+HB.RWT)
HIBER T1,
JRST ERROR
This code sequence causes the job to sleep until awakened by a
WAKE monitor call from another job having the same
project-programmer number. See also RTTRP call.
Related Calls
SLEEP, WAKE
Common Errors
o Forgetting to protect against WAKEs from other jobs.
o Assuming a particular event woke your job, without actually
checking.
22-191
HPQ [CALLI 71]
HPQ [CALLI 71]
Function
Places your job in, or removes your job from a high-priority
scheduler queue.
You cannot use HPQ unless your system administrator has set the
privilege value JP.HPQ to a nonzero value. This value is the
highest priority queue you can request. This monitor call is
primarily intended for real-time programs where fast response
time is critical. Refer to Chapter 9 of the Monitor Calls
Manual, Volume 1, for more information.
Calling Sequence
MOVEI ac,queue
HPQ ac,
error return
normal return
Where: queue is the number of the required high priority queue.
The lowest queue number is 1; the highest is a system
parameter. If you give queue as 0, your job returns to
the normal scheduler queue.
Normal Return
The monitor places your job in the given queue.
Error Return
The ac contains -1; you gave an illegal value for queue or you
are not a privileged user.
Related Calls
RTTRP, TRPSET, UJEN
22-192
IN [OPCODE 056]
IN [OPCODE 056]
Function
Reads data from an initialized channel into memory. Use
FILOP. to perform an IN for an extended I/O channel.
Calling Sequence
IN channo,addr
normal return
error return
where: channo is the number of an initialized I/O channel.
addr is one of the following:
o If the channel was initialized for dump mode, then
addr gives the address of an I/O command list.
o If the channel was initialized for buffered mode,
then addr gives the address of the second word of the
next buffer to be used; if you give 0 (the normal
case), the next buffer in the ring is used.
Note that the return locations for this call are in the
reverse order from the convention for other calls,
because the normal return follows the calling instruction
and the error return follows the normal return.
Normal Return
Data is input from the channel.
Error Return
The monitor found an end-of-file mark or errors in the data
(reflected in the I/O status word). If using non-blocking I/O
mode, the error return could indicate no available data. This is
indicated by no error bits set in the I/O status word. Use the
GETSTS call to read the I/O status bits.
Examples
See LOOKUP call.
Related Calls
FILOP., INPUT, OUT, OUTPUT
22-193
IN [OPCODE 056]
Common Errors
o If the channel was not initialized, the monitor stops the job
and prints:
?I/O to unassigned channel at user PC xxxxx
o If the specified address is illegal, the monitor stops the
job and prints:
?Address check for device yyyyyy:UUO at user PC xxxxx
o If the monitor cannot allocate buffers in your address space,
the monitor stops the job and prints (see INBUF):
?Address check for device yyyyyy:UUO at user PC xxxxx
22-194
INBUF [OPCODE 064]
INBUF [OPCODE 064]
Function
Sets up an input buffer ring with the specified number of buffers
for a given initialized channel. Use FILOP. to perform an INBUF
on an extended I/O channel.
NOTE
Buffers are allocated by the monitor in the
user's address space starting at the location
pointed to by the contents of .JBFF. This symbol
represents a word in the Job Data Area. As the
JDA exists only in Section 0, you cannot
initialize a buffer in a non-zero section, unless
that section is mapped to section 0. Use the
FILOP. monitor call to specify buffer starting
addresses in a non-zero section.
Calling Sequence
INBUF channo,buffers
return
where: channo is the number of an initialized channel.
buffers is the number of buffers to set up in the ring.
For disk devices, if you give buffers as 0, the monitor
uses the value given in the SET DEFAULT BUFFERS monitor
command or SETUUO. If no value has been set, the system
default (a MONGEN parameter) is used. For non-disk
devices, 2 buffers are assumed.
Normal Return
The buffer ring is set up.
Related Calls
FILOP., OUTBUF
22-195
INBUF [OPCODE 064]
Common Errors
o If the channel was not initialized, the monitor stops the job
and prints:
?I/O to unassigned channel at user PC xxxxx
o If the monitor cannot allocate buffers in your address space,
the monitor stops the job and prints:
?Address check for device yyyyyy:UUO at user PC xxxxx
o If your program tries to use INBUF or OUTBUF to create
buffers outside the job's core image, the job cannot expand
because the system runs out of virtual memory and the monitor
stops the job and prints:
?Illegal address in UUO at user PC xxxxx
o If you use INBUF or OUTBUF to set up a buffer ring in a
non-zero section, the monitor stops the job and displays the
following error message:
?Illegal INBUF/OUTBUF for device yyyyyy;UUO at user PC
xxxxx
22-196
INCHRS [TTCALL 2,]
INCHRS [TTCALL 2,]
Function
Reads an ASCII character from the job's controlling terminal's
input buffer, skipping on return if a character was available.
INCHRS also sets "character mode," in which the program will not
wait for the end of the line of input from the terminal.
Therefore, CTRL/U, DELETE, and other line-editing characters will
not function as they do for the monitor. See Chapter 15 for more
specific information.
Calling Sequence
INCHRS addr
return 1 ;no character in buffer
return 2 ;character read from buffer
...
addr: BLOCK 1
where: addr is the address of a word to contain the input
character (in bits 29 to 35); the rest of the word is
cleared.
Return
If a character has been input, the monitor copies it to bits 29
to 35 of the word at addr.
Related Calls
TRMOP., TTCALL
Common Errors
Typing a comma after addr.
22-197
INCHRW [TTCALL 0,]
INCHRW [TTCALL 0,]
Function
Inputs an ASCII character from the terminal's input buffer. The
monitor waits for a character if none is available. INCHRW
inputs the character regardless of whether a complete line has
been typed. If the program is not prepared to handle every
possible control character, you should consider using the INCHWL
call instead of INCHRW.
Calling Sequence
INCHRW addr
return
where: addr is the address of the word to receive the ASCII
input character. The character is placed in bits 29-35
of the word; the rest of the word is cleared.
If no character has been input, the monitor waits for a
character.
Return
If a character has been input, the monitor places the character
in bits 29-35 of the word at addr.
Related Calls
TRMOP., TTCALL
Common Errors
Typing a comma after addr.
22-198
INCHSL [TTCALL ,]
INCHSL [TTCALL 5,]
Function
Inputs a character in line mode from the terminal's input buffer,
skipping on return if the input was terminated by a line break
character such as carriage-return/line-feed.
Calling Sequence
INCHSL addr
return 1
return 2
where: addr is the address of the word to receive the character
(in bits 29 to 35); the rest of the word is cleared.
return 1 is the return instruction when a line break has
not been input from the terminal
return 2 is the return instruction when a line break
character has been input from the terminal.
Return
If a line break has been input from the terminal, the monitor
returns at return 2 with the next character of the line in bits
29-35 of addr; if not, it returns at return 1.
Related Calls
TRMOP., TTCALL
Common Errors
Typing a comma after addr.
22-199
INCHWL [TTCALL 4,]
INCHWL [TTCALL 4,]
Function
Inputs a character from the terminal input buffer, waiting until
a break character is encountered. With this type of input, the
monitor handles line-editing characters like DELETE, CTRL/R, and
so forth.
See Chapter 15, Monitor Calls Manual, Vol. 1 for a discussion of
break characters.
Calling Sequence
INCHWL addr
return
where: addr gives the address of the word to contain the input
character; the rest of the word is cleared.
Return
The character is right-justified in the word at addr. The rest
of the word is cleared.
Related Calls
TRMOP., TTCALL
Common Errors
Typing a comma after addr.
22-200
INIT [OPCODE 041]
INIT [OPCODE 041]
Obsolete; use OPEN or FILOP..
22-201
INPUT [OPCODE 066]
INPUT [OPCODE 066]
Function
Inputs data from an initialized channel to memory. Use FILOP. to
perform an INPUT on an extended I/O channel. INPUT is the same
as IN, except INPUT does not give an error return if an error or
EOF condition occurs. The user must check for such conditions
with GETSTS, STATZ, or STATO.
NOTE
Programs doing non-blocking I/O should use the IN
monitor call or FILOP. function .FOINP.
Calling Sequence
INPUT channo,addr
return
where: channo is the number of an initialized channel.
addr is one of the following:
o If the channel is initialized for dump mode, then addr gives
the address of an I/O command list.
o If the channel is initialized for buffered mode, then addr
gives the address of the second word of the next buffer to be
used; if you give 0 (the default), the next buffer in the
ring is used.
Return
Data is input from the channel.
Related Calls
FILOP., IN, OUT, OUTPUT
22-202
INPUT [OPCODE 066]
Common Errors
o If the channel was not initialized, the monitor stops the job
and prints:
?I/O to unassigned channel at user PC xxxxx
o If the specified address is illegal, the monitor stops the
job and prints:
?Address check for device yyyyyy:UUO at user PC xxxxx
o If the monitor cannot allocate buffers in your address space,
the monitor stops the job and prints:
?Address check for device yyyyyy:UUO at user PC xxxxx
22-203
IONDX. [CALLI 127]
IONDX. [CALLI 127]
Function
Returns the Universal Device Index (UDX) for a device or channel.
For information about terminal names and their UDXs, refer to the
TRMNO. UUO.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| \ MOVEI ac,channo /
| IONDX. ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a device
for which its UDX is desired.
channo is the number of an initialized channel.
Normal Return
The Universal Device Index for the specified device or current
device on the specified channel is returned in the ac.
Error Return
If the ac is cleared, you gave a nonexistent device or
SIXBIT/MPX/ as a device name.
22-204
IONEOU [TTCALL 15,]
IONEOU [TTCALL 15,]
Function
Sends an 8-bit image character to the terminal's output buffer.
Calling Sequence
IONEOU addr
return
where: addr contains the 8-bit character in bits 28 to 35.
Return
The 8-bit character is output to the terminal.
Related Calls
OUTCHR
Common Errors
Typing a comma after addr.
22-205
IPCFM. [CALLI 217]
IPCFM. [CALLI 217]
Function
Communicates with [SYSTEM]INFO and [SYSTEM]IPCC, replacing a
message exchange.
Calling Sequence
XMOVEI ac,addr
IPCFM. ac,
error return
normal return
addr: flags dest,,len
addr1
optional in-your-behalf process ID (PID)
addr1: message block
where: addr is the address of the packet header block.
flags are one or both of the flags in the packet header
block.
dest is the destination PID. len is the length of the
packet header block.
The argument block at addr is:
Offset Symbol Contents
0 .IPCMF Flags, destination, and length fields, in the
following format:
Bits Symbol Meaning
0 IP.CMP Invoking privileges. The job
must have IPCF privileges to
use this bit.
1 IP.CMI Indirect sender's PID.
2-14 Reserved for DIGITAL.
22-206
IPCFM. [CALLI 217]
Offset Symbol Contents
Bits Symbol Meaning
15-17 IP.CMD Destination process code, one
of the following:
Code Symbol Meaning
1 .IPCCC [SYSTEM]IPCC
2 .IPCCF System-wide [SYSTEM]INFO
3 .IPCCP Receiver's [SYSTEM]INFO
18-26 Reserved for DIGITAL.
|
| 27-35 IP.CML Total length of argument block,
| including .IPCMF.
1 .IPCMP Pointer to [SYSTEM]IPCC or [SYSTEM]INFO message
block detailed below. The pointer may be a
30-bit address or a section address (if an IFIW
is given), relative to the section the message
block is in. No indexing or indirection is
allowed.
2 .IPCMI In-your-behalf word; the PID on whose behalf to
perform this operation, 0 for your own job. If
this word is non-zero, IPCF privileges must be
enabled or the given PID must belong to your
current JCH. If .IPCMI is on, it contains the
address (30-bit or IFIW) of the PID.
The message block at addr 1 for [SYSTEM]IPCC is:
Offset Symbol Contents
0 .IPCS0 Holds the message length identifier in the left
half, and one of the following function codes in
the right half:
Code Symbol Meaning
1 .IPCSE Enables IPCF privileges.
2 .IPCSD Disables IPCF privileges.
3 .IPCSI Obtains PID of [SYSTEM]INFO for
user of PID.
4 .IPCSF Sets the program specified
in .IPCS1 to act as
[SYSTEM]INFO for the program
specified in .IPCS2. If you do
not specify .IPCS2, the system
is assumed as the default.
22-207
IPCFM. [CALLI 217]
Offset Symbol Contents
Code Symbol Meaning
5 .IPCSZ Deletes PID.
6 .IPCSC Creates PID for job.
7 .IPCSQ Sets PID quota.
10 .IPCSO Changes owner of PID, assign
new job number.
11 .IPCSJ Supplies job number of PID.
12 .IPCSP Gives PID list for job.
13 .IPCSR Reads job quota.
16 .IPCQS Sets PID quota.
17 .IPCQR Reads PID quota.
23 .IPCLP Locates PID in system PID table
and returns index.
24 .IPCWP Writes system PID table.
(Refer to GETTAB table .GTSID)
25 .IPCRP Reads system PID table.
1 .IPCS1 First argument.
2 .IPCS2 Second argument.
3 .IPCS3 Third argument.
The message block for [SYSTEM]INFO is:
Offset Symbol Contents
0 .IPCI0 The left half holds the message block length;
the right half contains one of the following
function codes:
Code Symbol Meaning
1 .IPCIW What is PID (ASCIZ).
2 .IPCIG Gets PID name.
3 .IPCII Assigns PID name until reset.
4 .IPCIJ Assigns PID name until logout.
5 .IPCID Drops specific PID.
6 .IPCIR Drops names set in .IPCII.
7 .IPCIL Drops names set in .IPCIJ.
10 .IPCIN Notifies when the PID is
dropped.
1 .IPCI1 First argument.
2 .IPCI2 Second argument.
22-208
IPCFM. [CALLI 217]
Normal Return
The system process returns data in a packet to the user's message
block.
Error Return
The ac will contain one of the error messages documented under
IPCFR. UUO.
Related Calls
.IPCFQ, .IPCFR, .IPCFS
22-209
IPCFQ. [CALLI 144]
IPCFQ. [CALLI 144]
Function
Returns information about a job's IPCF input queue. The
information returned is the packet header block for the next (if
any) packet in the queue of packets sent by the inter-process
communication facility. The IPCF calls are described in Chapter
7 of Monitor Calls Manual, Volume I.
Calling Sequence
MOVE ac,[XWD len,addr]
IPCFQ. ac,
error return
normal return
. . .
addr: BLOCK len
where: len is the length of the block (4 to 6 words) at addr to
receive returned data.
addr is the address of the block to receive the data.
Normal Return
The ac is not changed. The packet header block for the next
packet in the queue is returned at addr. The format of the
information returned is described in Chapter 7.
Offset Symbol Contents
0 .IPCFL Flag word of the next packet in the queue.
1 .IPCFS Sender's PID.
2 .IPCFR Receiver's PID.
3 .IPCFP Length of next message and number of packets:
Bits Meaning
0-17 Length of next message.
18-35 Number of packets in your input
queue.
4 .IPCFU Sender's PPN.
22-210
IPCFQ. [CALLI 144]
Offset Symbol Contents
5 .IPCFC Sender's capability word:
Bits Symbol Meaning
0 IP.JAC Sender has JACCT privileges
set.
1 IP.JLG Sender is logged in.
2 IP.SXO Sender is execute-only.
3 IP.POK Sender has POKE. privilege
(JP.POK).
4 IP.IPC Sender has IPCF privilege
(JP.IPC).
5-17 Reserved.
18-26 IP.SCN Sender's context number.
27-35 IP.SJN Sender's job number.
Error Return
If there is no packet in the input queue, IPCFQ. takes the error
return and returns an error code in the ac. The error codes for
all IPCF calls are listed under the IPCFR. call.
Related Calls
IPCFM., IPCFR., IPCFS.
22-211
IPCFR. [CALLI 142]
IPCFR. [CALLI 142]
Function
Retrieves a packet from the IPCF input queue for the calling
process. The IPCF facility and the format of the argument blocks
are described in Chapter 7 of Monitor Calls Manual, Volume I.
Calling Sequence
MOVE ac,[XWD len,addr]
IPCFR. ac,
error return
normal return
. . .
addr: EXP flags
BLOCK 2
XWD len2,addr2
. . .
addr: BLOCK len2
where: len is the length of the packet header block.
addr is the address of the packet header block.
flags is the flag word (.IPCFL) in the packet header
block.
len2 is the length of the packet to be retrieved. If the
packet is going to be a page of data, this field must
contain 512 or an error code is returned in the ac and
the IPCFR. monitor call takes the error return.
addr2 is the address of the packet message block.
The retrieving process should check the contents of the flag word
(word 0, .IPCFL). If there is an error condition associated with
the packet, it will be indicated in bits 24-29. Error codes
received in the ac indicate an error with the monitor call (for
example, if the packet was not received).
If the IPCFR. monitor call is issued but there are no packets in
the input queue, the job cannot continue executing until a packet
is placed in the input queue. To prevent the job from blocking,
bit 0 (IP.CFB) should be set in the flag word. When IP.CFB is
set and there are no packets in the input queue when the IPCFR.
call is issued, the call will take the error return and the
monitor will return error code 3 (IPCNT%) in the ac.
22-212
IPCFR. [CALLI 142]
When a process is retrieving a page of data, bit 19 (IP.CFV) in
the flag word must be set and the length of the data message
block (left half of .IPCFP) must contain 1000 or the IPCFR.
monitor call fails and the monitor returns error code 21 (IPCPR%)
in the ac.
If the retrieved packet is shorter than the number of reserved
words (that is, len2), the packet is retrieved and the extra
words are left unchanged. If, however, the number of reserved
words is not long enough to store the packet, the IPCFR. monitor
call takes the error return and the monitor returns error code 5
(IPCTL%) in the ac. To prevent this error, the receiver can set
bit 4 (IP.CFT) in the flag word indicating that, if the packet is
too long for the reserved space, the message should be truncated.
Normal Return
On a normal return, the monitor returns the associated variable
(see Chapter 7) in the ac indicating that there is another packet
waiting in the queue. If there are no more packets in the queue,
the monitor clears the ac. The packet retrieved from the
process' input queue is returned to the address specified in the
IPCFR. monitor call (beginning with addr). The packet header
block is filled in as follows:
Offset Symbol Contents
0 .IPCFL The left half remains the same, the right half
contains flags (see Chapter 7).
1 .IPCFS Sender's PID.
2 .IPCFR Receiver's PID.
3 .IPCFP Length and location of data:
Bits Contents
0-17 Message length.
18-35 Address of message, for short-form
messages (default), or page number of
long-form messages. If the page number
refers to a non-existent page, error code
IPCAC% is returned.
4 .IPCFU Sender's PPN. If the argument block length is
less than 5, this word is not returned.
22-213
IPCFR. [CALLI 142]
Offset Symbol Contents
5 .IPCFC Sender's capability word:
Bits Symbol Meaning
0 IP.JAC Sending program has JACCT
privileges.
1 IP.JLG Sender is logged in.
2 IP.SXO Sender is execute-only.
3 IP.POK Sender has POKE. privilege
(JP.POK).
4 IP.IPC Sender has IPCF privilege
(JP.IPC).
5-17 Reserved.
18-26 IP.SCN Sender's context number.
27-35 IP.SJN Sender's job number.
If the argument block length is less than 6,
this word is not returned.
Error Return
The packet is not retrieved and one of the following error codes
is returned in the ac:
Code Symbol Error
1 IPCAC% Address check.
2 IPCNL% Packet header not long enough.
3 IPCNP% No packet in receiving queue.
4 IPCIU% Page is in use (locked in core).
5 IPCTL% Data too long for user's buffer.
6 IPCDU% Receiver's PID unknown.
7 IPCDD% Receiver disabled.
10 IPCRS% No room in sender's quota.
11 IPCRR% No room in receiver's quota.
12 IPCRY% No room in system storage.
13 IPCUP% Unknown page (send) or duplicate page (receive).
14 IPCIS% Invalid sender PID.
15 IPCPI% Not enough privileges.
16 IPCUF% Unknown function code.
17 IPCBJ% Illegal job number.
20 IPCPF% PID table full.
21 IPCPR% Page requested, normal text.
22 IPCIE% Paging I/O error.
23 IPCBI% Bad index for system PID table.
24 IPCUI% Undefined PID in system table.
25 IPCRU% Receiver PID unknown or does not match job.
| 26 IPCRP% Insufficient physical memory space available.
| 27 IPCRV% Insufficient virtual memory space available to
| receive page.
22-214
IPCFR. [CALLI 142]
Code Symbol Error
70 IPCFU% [SYSTEM]INFO has unknown internal error.
71 IPCCF% [SYSTEM]IPCC request from [SYSTEM]INFO failed.
72 IPCFF% [SYSTEM]INFO failed to complete an ASSIGN.
73 IPCQP% PID quota exceeded.
74 IPCBP% Unknown PID.
75 IPCDN% Duplicate name.
76 IPCNN% No such name.
77 IPCBN% Name has illegal characters.
Examples
An example of the IPCFR. monitor call is shown below.
MOVE T2,[XWD 6,PHB] ;Length and address of packet
IPCFR. T2, ; To be retrieved.
JRST ERR
JRST NORM
PHB: EXP 0 ;No flags
EXP 0 ;Sender's PID
EXP 0 ;Receiver's PID
10,,PMB1 ;Length and address of packet
;Message block to be retrieved
EXP 0 ;PPN of sender
EXP 0 ;Capabilities of sender
PMB1: EXP 0
EXP 0
EXP 0
.
.
.
EXP 0
On a normal return from the IPCFR. monitor call, the packet has
been retrieved from the input queue. If no packet was in the
input queue, the call takes the error return, and error code 3 is
returned in the ac. Below is an example of what a response from
[SYSTEM]INFO could be after a request for a PID.
PHB 20 ;The packet was sent by [SYSTEM]INFO
PHB+1 2001 ;[SYSTEM]INFO's PID
PHB+2 31 ;Job number of receiver
PHB+3 4,,PMB1 ;Length and address of packet message
; block
PHB+4 1,,2 ;PPN of sender
PHB+5 260000,,1014 ;Capabilities of sender
PMB1 32,,3 ;User code and function code
22-215
IPCFR. [CALLI 142]
PMB1+1 400004,,1001 ;The requested PID
PMB1+2 ASCIZ/CORP/ ;The symbolic name
PMB1+3 0
22-216
IPCFR. [CALLI 142]
The IPCFR. monitor call can take the normal return and return an
error code in the flag word of the packet header block. For
example, word 0 of the packet header block could contain the
following:
PHB/ 0520
This means that the length of the packet message block specified
in the IPCFR. monitor call was not long enough, so the monitor
returned error code 5 in the flag word. The 20 in the flag word
indicates that the message in the receiver's input queue is from
[SYSTEM]INFO.
If a process sends a request to [SYSTEM]INFO to obtain the PID
associated with the symbolic name "FRED," the following could
result:
Location Contents
AC 0 ;indicating a normal return and no
;errors set in the AC; no more packets
;in queue.
PHB 7620 ;the flag word
PHB+1 2,,1003 ;the sender's PID
PHB+2 164,,1011 ;the receiver's PID
PHB+3 10,,PMB ;length and addr of message block
PMB 11,,1 ;user code and function code
PMB+1 0 ;no response
PMB+2 ASCIZ/FRED/ ;symbolic name
The first word of the packet, PHB, contains 7620. This value
indicates the following:
o 76 is the error code indicating that the symbolic
name "FRED" is not associated with any currently assigned
PID.
o 2 indicates that the call to [SYSTEM]INFO succeeded, and a
normal
return was taken. The number of packets still in the queue
is stored in
the ac.
o 0 indicates that the packet is not a "returned to sender"
packet.
The call to
Error code 76 in the flag word indicates that the symbolic name
"FRED" is not associated with any currently assigned PID.
22-217
IPCFR. [CALLI 142]
Related Calls
IPCFM., IPCFQ., IPCFS.
22-218
IPCFS. [CALLI 143]
IPCFS. [CALLI 143]
Function
Sends an IPCF packet to the specified process.
By giving the receiver's PID as the PID of [SYSTEM]INFO or
[SYSTEM]IPCC, you can obtain information from the IPCF facility
itself (see Chapter 7).
Calling Sequence
MOVE ac,[XWD len,addr]
IPCFS. ac,
error return
normal return
. . .
addr: flags
sender's PID
receiver's PID
XWD len,addr2
. . .
addr2: message-word-0
.
.
.
message-word-(len-1)
where: len is the length of the packet header block. The length
of this block must be equal to or greater than 4 or the
monitor returns error code 2 (IPCNL%) in the ac.
addr is the address of the packet header block.
flags is the flag word in the packet header block.
sender's PID is Word 1 of the packet header block.
receiver's PID is Word 2 in the packet header block.
len2 is the length of the packet message block. When
sending a short-form message, this value should not
exceed 12 octal. The limit may be GETTABed in %IPCML.
addr2 is the address of the packet message block.
message-word-0 through message-word-n are the words
making up the packet message block. Refer to Chapter 7
for more information.
22-219
IPCFS. [CALLI 143]
Normal Return
On a normal return, the ac is unchanged and the packet described
by the packet header block at addr has been placed in the
intended receiver's queue.
Offset Symbol Contents
0 .IPCFL Flags are the same as those described in Chapter
7.
1 .IPCFS Sender's PID.
2 .IPCFR Receiver's PID. If you use the PID for
[SYSTEM]INFO or for [SYSTEM]IPCC, you can
retrieve information from the IPCF facility
itself (see Chapter 7).
3 .IPCFP Length and location of data:
Bits Contents
0-17 Message length.
18-35 Address of message.
Error Return
On an error return, an error code is returned in the ac and the
packet is not sent. The error codes are listed under the
IPCFR. call.
Examples
This code fragment sends a packet to [SYSTEM]INFO, asking that a
PID be assigned with the symbolic name LJC.
MOVE T1,[XWD 4,PHB] ;Length and address of packet
IPCFS. T1, ; header block
JRST ERROR
JRST NORMAL
PHB: 0 ;This is a packet header
0 ;Sender's PID
0 ;Receiver's PID (your [SYSTEM]INFO)
XWD 3,PMB ;Length and addr of message block
PMB: XWD 234,.IPCII ;Ack code and function (assigns PID)
0 ;No duplicate PID
ASCIZ/LJC/ ;Symbolic name
Related Calls
IPCFM., IPCFQ., IPCFR.
22-220
JBSET. [CALLI 113]
JBSET. [CALLI 113]
Function
Sets system or job parameters for another job. Your job must
have the JACCT bit set, or must be logged in under [1,2]. You
can use the SETUUO monitor call to set parameters for your
current job.
Calling Sequence
MOVE ac,[XWD len,addr]
JBSET. ac,
error return
normal return
. . .
addr: XWD 0,jobno
XWD fcn-code,argument
where: len is the length of the argument list.
addr is the address of the argument list.
jobno is the number of the job for which the SETUUO
function is to be performed.
fcn-code is one of the function codes described under
SETUUO.
argument is an argument for the given function code.
Refer to the SETUUO description for a list of all function codes
and their meanings.
Normal Return
The function has been performed and the ac is left unchanged.
Error Return
The error return is taken if the calling job is not privileged,
the specified job number is illegal, or the SETUUO function
failed.
22-221
JOBPEK [CALLI 103]
JOBPEK [CALLI 103]
Function
Reads or writes another job's core.
To use the JOBPEK call, you must have POKE privileges (JP.POK),
your program must have JACCT set, or you must be logged in under
[1,2].
Use the Format 1 calling sequence with 18-bit addresses. Use the
Format 2 calling sequence if the core being read or written is
either in a non-zero section or in a context other than the
current one.
Calling Sequences
Format 1: MOVEI ac,addr
JOBPEK ac,
error return
normal return
. . .
addr: EXP <flags>+jobnoB17+countB35
XWD readaddr,writeaddr
where: addr is the address of the argument list.
flags are one or more of the flags listed below.
jobno (JK.JOB) is the number of the logged-in job whose
core is to be read or written, stored in Bits 9-17.
count (JK.WCT) is the number of words to be read or
written (the maximum can be obtained using GETTAB to read
item %CNJPK from table .GTCNF), stored in Bits 18-35.
readaddr is the location of the first word to be read.
writeaddr is the location of the first word to be
written.
Format 2: MOVE ac,[length,,addr]
JOBPEK ac,
error return
normal return
. . .
addr: EXP <flags>+countB17+JCHB35
EXP 0
XWD readaddr
XWD writeaddr
22-222
JOBPEK [CALLI 103]
where: addr is the address of the argument list.
flags are one or more of the flags listed below.
count (JK.EWC) is the number of words to be read or
written (refer to GETTAB table .GTCNF, item %CNJPK),
stored in Bits 8-17.
JCH (JK.JCH) is the job/context handle of the job whose
core is to be read or written, stored in Bits 18-35.
readaddr is the 30-bit address giving the location of the
first word to be read.
writeaddr is the 30-bit address giving the location of
the first word to be written.
The flags and their meanings are:
Bit Symbol Meaning
0 JK.WRT Write the other job's core; if not set, read the
other job's core.
1 JK.UPM Read the other job's UPMP (user page map page or
user page table). JK.WRT must not be set.
2 JK.EVA Source address is between .MCFV and .UUPMP;
treat it as if it were an executive virtual
address mapped through the specified job's UPMP.
Both JK.WRT and JK.UPM must be off.
3 JK.AIO Do not block if data is inaccessible (due to the
state of cache on SMP systems); set this bit
only if you set either JK.UPM or JK.EVA.
Notice that if the other job's core is to be read (JK.WRT is
cleared), then readaddr is a location in the other job and
writeaddr is a location in the current program. If the other
job's core is to be written (JK.WRT is set), then readaddr is a
location in the current program and writeaddr is a location in
the other job.
Normal Return
The specified words are transferred between the other job and the
current job.
22-223
JOBPEK [CALLI 103]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Meaning
1 JKNPV% Job not privileged.
2 JKIJN% Illegal job number.
3 JKSWP% Job swapped out or in transit.
4 JKIAD% Illegal address (source or destination).
5 JKDNA% Data not addressable (if JK.AIO is set).
6 JKPNC% Page not in core.
7 JKIOE% I/O error occurred.
10 JKABZ% Target address is in an "allocated but zero"
page.
Examples
MOVEI T1,ADDR
JOBPEK T1,
JRST ERROR
JRST CONTIN
. . .
ADDR: EXP 14B17+1000B35
XWD 10000,12000
This example reads 1000 (octal) words from the core of job 14
into the current job's core. Reading begins at location 10000 in
the other job; writing begins at location 12000 in the current
job.
22-224
JOBSTR [CALLI 47]
JOBSTR [CALLI 47]
Function
Returns names of file structures in your job's search list. For
a discussion of file structures in a search list, see Chapter 11.
Calling Sequence
MOVE ac,[XWD len,addr]
JOBSTR ac,
error return
normal return
. . .
addr: SIXBIT/str/ ;.DFJNM
EXP 0 ;reserved
EXP 0 ;.DFJST
where: len is the length of the argument list (.DFJBL).
addr is the address of the argument list. You can
include a structure name (str) at addr to obtain the name
of the next structure in your job search list, or 0 to
obtain the first structure in your active search list, or
-1 to obtain the first structure in your job's passive
search list (after FENCE in search list returned by
SETSRC program).
addr+1 (.DFJDR) is reserved.
At addr+2 (.DFJST), the monitor returns the write-protect
flag for the structure. The flags are:
Bits Symbol Meaning
0 DF.SWL Software write-protect.
1 DF.SNC Do not create files on this structure;
create only if specified as file
structure or a physical device name.
Normal Return
If you give 0 at addr, the monitor returns the first structure in
the search list after the FENCE.
If you give -1, the monitor returns the first structure in the
list.
22-225
JOBSTR [CALLI 47]
If you give a SIXBIT structure name (or leave the one the monitor
last entered), the monitor returns the next structure name in the
search list. When there are no more structures in the list, the
monitor returns -1 at addr. If the next item in the list is
FENCE, the monitor returns 0.
Therefore you can begin with the first name in the list by using
-1 at addr. When the monitor returns the first name in the list,
you can leave the name in addr to call for the second name, and
so forth.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
3 DFGIF% Illegal file structure name.
12 DFGLN% Illegal argument length.
Examples
The following example reads all structures in the job's search
list:
MOVEI T1,0 ;Initialize counter
LOOP: MOVE T2,[.DFJBL,,ADDR] ;Pointer to argument block
JOBSTR T2, ;Get next structure (on 0 or -1)
JRST ERROR
MOVE T2,ADDR+.DFJNM ;Get structure
MOVEM T2,STRTAB(T1) ;Save in table
AOJE T2,CONTIN ;All done if -1
AOJA T1,LOOP ;Bump table pointer and loop
ADDR: EXP -1 ;Start with the first one
EXP 0
EXP 0
STRTAB: BLOCK 30 ;Where to store search list
CONTIN: .
.
.
Related Calls
DVPHY., GOBSTR, SYSPHY, SYSTR
22-226
JOBSTS [CALLI 61]
JOBSTS [CALLI 61]
Function
Provides information (including checking statistics) about
terminal devices, pseudo-terminals, and software states
associated with terminals. For more information about terminals
and pseudo-terminals, refer to Chapter 15.
Calling Sequence
|
| / MOVNI ac,jobno \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| JOBSTS ac,
| error return
| normal return
where: udx is the Universal Device Index of the terminal for
which information is desired.
channo is the number of an I/O channel on which a
terminal device has been opened.
jobno is the number of a logged-in job associated with
the terminal. To obtain status of a pseudo-terminal,
provide the job number of the controlled job. Note that
the negative of the job number is used because positive
values are interpreted as channels or UDXs.
Normal Return
The monitor returns a status word for the job, with the
appropriate flags set from the following list.
Bits Symbol Meaning
0 JB.UJA The given job number is assigned.
1 JB.ULI The job is logged in.
2 JB.UML Terminal is at monitor level.
3 JB.UOA Terminal output is available.
4 JB.UDI The terminal is at user level and is in the
input wait state, or the terminal is at monitor
level and can accept a command. There is no
command waiting to be decoded, the job is not
running, and the job is not stopped waiting for
operator intervention.
22-227
JOBSTS [CALLI 61]
Bits Symbol Meaning
5 JB.UJC JACCT is set for the job. Note that this means
that two CTRL/Cs will not stop the job.
6 JB.URN The job is running. This bit is zero if the job
is in a wait state.
7 JB.UFC The terminal device is in "full character set"
mode. This characteristic can be set using the
TRMOP. UUO.
8 JB.UBK The terminal device is in "break on all
characters" mode. This characteristic can be
set using the TRMOP., OPEN, or FILOP. UUOs.
9-10 Reserved for use by DIGITAL.
11 JB.UNE The terminal device is in "no echo" mode. This
characteristic can be set using the TRMOP.,
OPEN, or FILOP. UUOs.
12 JB.UTO The terminal is in terminal output state. In
other words, the job is blocked waiting for
terminal output.
13 JB.UCC The terminal characteristics have changed since
last JOBSTS.
14 JB.UNT The terminal connected to the pseudo-terminal
has used SET HOST to connect to another system.
15 JB.UHI The terminal is HIBERing for input. If a
program such as OPR or BATCON is running under
batch, and JB.UHI is set, the job will awaken on
input to the terminal. (Refer to the HB.DIN bit
in the HIBER monitor call.)
16-26 Reserved for use by DIGITAL.
777B35 JB.UJN Bit mask to contain job number (0 if none
assigned).
Since JB.UOA will be set if any output is pending, but JB.UTO will be
set if the output buffer for the terminal is full, you can make each
INPUT UUO transfer more data, by testing for JB.UTO before JB.UOA,
then doing on INPUT for a PTY.
22-228
JOBSTS [CALLI 61]
Error Return
One of the following occurred:
o The specified job number or channel number is invalid.
o There was no terminal on the specified channel.
22-229
KDP. [CALLI 200]
KDP. [CALLI 200]
Function:
Loads, dumps, and starts the KMC-11 (KS systems only).
Calling Sequence:
MOVE ac,[XWD len,addr]
KDP. ac,
error return
normal return
...
addr: EXP fcn-code
argument 1
argument 2
argument 3
where: len is the length of the argument block.
addr is location of the argument block. At addr, store
the function code (fcn-code). The remainder of the
argument block depends on the function to be performed.
The function codes are:
Code Symbol Meaning
1 .KDPKN Returns in argument 1 the number of KMC-11s on
the system.
2 .KDPDN Returns in argument 2 the count of DUP-11s on
the KMC that you specify in argument 1.
3 .KDPSS Returns in argument 2 the status of KMC
specified in argument 1.
4 .KDPHA Halts the KMC-11 specified in argument 1.
5 .KDPMC Master-clears the KMC specified in argument 1.
6 .KDPST Starts the KMC specified in argument 1.
7 .KDPRE Reads the CRAM location from the KMC specified
in argument 1 and pointed to by the address in
argument 2. The CRAM location is stored in
argument 3.
22-230
KDP. [CALLI 200]
Code Symbol Meaning
10 .KDPWR Writes in CRAM location from the KMC specified
in argument 1, at the address specified in
argument 2, from the value stored in argument 3.
101 .KDLRS Reads line status of KMC specified in argument
1, on line of DUP specified in argument 2. The
line status is returned in the address pointed
to by argument 3. Argument 3 must be specified
as [len,,addr], where len is the length and addr
is the address of the block where status is to
be stored.
102 .KDLHA Stops DDCMP on a line specified by the KMC in
argument 1 and the DUP in argument 2.
103 .KDLST Starts DDCMP on a line specified by the KMC in
argument 1 and the DUP in argument 2.
104 .KDLSU Sets the line's user. Specify the KMC in
argument 1, the DUP in argument 2, and the
SIXBIT/user/ in argument 3. Refer to the
DTE. call for more information about line users.
105 .KDLRU Returns the line's user in argument 3. You must
specify the KMC in argument 1 and the DUP in
argument 2.
Error Return
One of the following error codes may be returned:
Code Symbol Meaning
1 KDILF% Illegal function code.
2 KDILK% Illegal KMC-11 number.
3 KDALS% Argument list too short.
4 KDIWR% Function is illegal when KMC-11 is running.
5 KDICA% Illegal CRAM address (.KDPRE or .KDPWR).
6 KDILL% Illegal line (DUP-11) number.
7 KDKNR% Function is illegal when KMC-11 is not running.
10 KDLNS% DDCMP was not started on the line.
11 KDLAS% DDCMP was already started on the line.
13 KDUNP% User not privileged to perform this function.
22-231
KNIBT. [CALLI 222]
KNIBT. [CALLI 222]
Function
Provides functions for starting and stopping the NIA20
microprocessor, and reading and writing its control RAM (CRAM).
This call requires POKE privileges.
Calling Sequence
XMOVEI ac,addr
KNIBT. ac
error return
normal return
addr: fcncode,,len
CPUno,,channo
args
where: addr is the address of the argument list.
fcncode is one of the function codes described below.
len is the length of the argument block.
CPUno is the number of the CPU to which the NIA20 is
attached.
channo is the RH20 channel number of the NIA20
microprocessor.
args are arguments specific to the functions you want to
perform on the NIA20.
The format of the argument block is:
Offset Symbol Contents
0 .KBFCN This word holds the function code and the length
of the KNIBT. argument block. The left half,
KB.FCN, holds one of the function codes listed
below. KB.ALN, the right half, holds the
length.
1 .KBKID This is the NIA20 identification word. The left
half, KB.CPU, holds the CPU number. The right
half, KB.RH2, holds the RH20 channel number of
the NIA20. The only currently valid value of
KB.RH2 is 5.
22-232
KNIBT. [CALLI 222]
Offset Symbol Contents
2 .KBCRA CRAM address, the third word in the argument
block for functions .KBSTA, .KBRED, and .KBWRT
(see below).
3 .KBCCH Contains the high order bits (0-29) of the CRAM
for the NIA-20. This word is used in the .KBRED
and .KBWRT argument blocks.
4 .KBCCL Holds the low order bits (30-59) of the NIA-20
CRAM. .KBRED and .KBWRT also use this word.
The function codes for .KBFCN are as follows:
Code Symbol Meaning
1 .KBSTS Returns the status of the NIA20 in the user's
ac. Status information is returned in the
following format:
Bits Symbol Meaning
0 KS.RUN NIA20 is running.
1 KS.MAI NIA20 is in maintenance mode.
2 KS.RLD The NIA20 needs to be reloaded.
3 KS.ARD Auto-reload is disabled.
4 KS.RRQ The system requested an NIA20
reload.
5 KS.DRQ The system requested an NIA20
dump.
6-17 Reserved for DIGITAL.
18-35 KS.RJB Job number of job reloading
NIA20.
2 .KBSRJ Sets the current job as the job to reload the
NIA20.
3 .KBSTP Stops the NIA20. This must be done before
.KBSTA, .KBRED, or .KBWRT are performed.
4 .KBSTA Starts the NIA20 microprocessor at a specific
CRAM address given in .KBCRA.
5 .KBRED Reads the contents of the CRAM location given in
.KBCRA, placing the CRAM words into .KBCCH, and
.KBCCL.
6 .KBWRT Writes the contents of a specific CRAM location.
.KBCRA, .KBCCH, and .KBCCL are the argument
words for .KBWRT.
22-233
KNIBT. [CALLI 222]
Normal Return
The specified function is performed; status bits are returned in
the ac for function .KBSTS.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 KBPRV% Insufficient privileges.
2 KBADC% An address check has been performed.
3 KBIAL% Invalid argument list.
4 KBILF% Illegal function.
5 KBICS% Illegal CPU specified.
6 KBCNA% CPU not available.
7 KBKDE% NIA20 doesn't exist.
10 KBKMM% NIA20 is in maintenance mode.
11 KBDNS% NIA20 microprocessor didn't start.
12 KBDNI% NIA20 microprocessor didn't initialize.
Code Symbol Error
13 KBICA% Invalid CRAM address.
14 KBCRE% CRAM read error.
15 KBCWE% CRAM write error.
16 KBNRJ% Not the reload job.
Related Call
DIAG.
22-234
LATOP. [CALLI 221]
LATOP. [CALLI 221]
Function
Performs Local Area Terminal (LAT) functions. This function is
not intended for customer use.
Calling Sequence
MOVEI ac,addr
LATOP. ac,
error return
normal return
addr: EXP len
function code
argument list
. . .
where addr is the address of the argument list, len is the total
length of the argument list including this word, and function
code is the function code or symbol listed below. The remainder
of the argument list differs depending on the function code. The
appropriate argument list is described below for each function.
The functions are:
Code Symbol Meaning
0 .LASET Sets LAT parameters for the local node. The
parameters you set using this function are
dynamic parameters stored only in the host
software. Your program must have JACCT or [1,2]
privileges to set LAT parameters.
The parameters you can set with .LASET are:
Code Symbol Meaning
1 .LPMAC Maximum number of active circuits.
2 .LPMCO Maximum number of simultaneous connects.
3 .LPNUM Host number.
4 .LPLAS LAT access state.
5 .LPRLI Circuit retransmit limit.
6 .LPTIM Retransmit initial value.
7 .LPMTI Multicast timer initial value.
10 .LPCOD Group codes.
11 .LPNNM Host node name.
12 .LPNID Host node identification string.
13 .LPSRV Service rating and description.
22-235
LATOP. [CALLI 221]
To set parameters with codes 1 through 12, use the following
argument list to .LASET:
Word Symbol Contents
0 .LAACT Argument list length.
1 .LAFCN EXP .LASET.
2 .LAPRM Parameter code identifying the parameter to be
set.
3 .LAVAL Contents depend on the parameter code:
For Codes .LAVAL Contains
1 through 7 new parameter value
10 address of a bit mask
11 through 13 ASCIZ string pointer
4 .LAQUA Qualifier (required for parameter code 13 only)
contains the following:
Bit Symbol Meaning
0 LA%RAT Rating
1 LA%DSC Service description
5 .LADSC ASCIZ string pointer to service description
string (LA%DSC=1).
Argument Lists for .LASET
The .LASET function accepts the argument list that is appropriate
to the parameter code you specify in addr+2, .LAPRM. Parameter
codes 1 through 7 accept an argument directly from .LAVAL. On a
successful return, the parameter you specify will be set to the
value you include in .LAVAL.
Parameter code 10 (group codes) requires the address of a bit
mask in .LAVAL. The bit mask is 8 words long, representing the
group codes of terminals that can access the host. The bit mask
is numbered decimally from 0 to 255, signified by bits 0 through
31 of each word. Each bit you set represents a group number that
is allowed to access the system.
Each word in the group code bit mask is formatted as:
0 1 2 3 4................................31 32-----35
---------------------------------------------------------
| Each bit represents a group number | Ignored |
---------------------------------------------------------
22-236
LATOP. [CALLI 221]
The group numbers that are represented by each word, starting at
ADDR:, are:
Word Group Numbers
ADDR: 0 through 31
ADDR+1: 32 through 63
ADDR+2: 64 through 95
ADDR+3: 96 through 127
ADDR+4: 128 through 159
ADDR+5: 160 through 191
ADDR+6: 192 through 223
ADDR+7: 224 through 255
To specify a group code number, set the corresponding bit in the
bit mask. For example, to set group 64, set bit 0 in the second
word of the bit mask.
Parameter codes 11 and 12 require an ASCIZ string pointer in
.LAVAL. The pointer may be specified as a byte pointer, or in
the form -1,,addr, where addr is the address of the ASCIZ string.
Parameter code 13 allows you to set service rating and
description. The contents of .LAVAL include flags and service
rating. Depending on the flags you set, you may include a
pointer in the following word, .LADSC.
The flags you can set in .LAVAL for parameter code 13 are:
Bit Symbol Meaning
0 LA%RAT Sets the rating as specified in the right half
of this word. If this bit is not set, and no
previous rating has been set, then the rating is
automatically set to the default value.
1 LA%DSC Sets the service description as specified by the
next word.
If bit 1 is set, then .LADSC must contain an ASCIZ pointer to a
service description string. If LA%DSC is set but .LADSC contains
0, the service description string is cleared.
22-237
LATOP. [CALLI 221]
Code Symbol Meaning
1 .LACLR Clear specified LAT node parameters. This
function requires JACCT or [1,2] privileges.
The argument list for .LACLR consists of the
following words:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LACLR
2 .LAPRM Parameter code (see function
code 0).
3 .LAVAL Depends on parameter code in
.LAPRM.
For parameter code 10, contains
the address of the group code
bit mask. For parameter 13,
contains the ASCIZ pointer to
service name to clear. This
word is ignored for all other
parameters.
2 .LASCH Shows the LAT characteristics. You can use this
function to obtain the values of both permanent
and dynamic parameters.
The argument block for this function is:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LASCH
2 .LABCT EXP len1
3 .LABFA addr1
where len is the length of the argument block.
The value of len1 is the number of words you
have reserved to contain the returned
information. On the return, the left half of
len1 contains the actual number of words
returned. The value of addr1 is the location
where the information will be stored on the
return.
22-238
LATOP. [CALLI 221]
Code Symbol Meaning
3 .LASTC Shows connects. This function returns
information about the active LAT connections at
the local node.
The argument list is:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LASTC
2 .LABCT EXP len1
3 .LABFN addr1
where the value of len is the length of the
argument block. The value of len1 is the number
of words reserved for the information that will
be returned. On the return, the left half of
this word contains the actual number of words
returned. The value of addr1 is the address
where the information will be returned.
4 .LASAS Shows adjacent servers. This function returns
information about LAT servers that are able to
access the local node.
The argument block for this function is:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LASAS
2 .LABCT EXP len1
3 .LABFA addr1
4 .LAQUA pointer
where len is the length of the argument list.
The value of len1 is the number of words
reserved for the information. On the return,
the left half of this word contains the actual
number of words used. The value of addr1 is the
location where the information will be returned.
.LAQUA contains an ASCIZ string pointer to a
location containing the server name. You may
specify .LAQUA to receive information about a
specific LAT server. This returns a Full Format
Server Block. The default action, if this word
is zero, is to return a summary of all servers
(Short Format Server Block).
22-239
LATOP. [CALLI 221]
Code Symbol Meaning
5 .LASCO Shows counters. The argument list is:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LASCO
2 .LABCT EXP len1
3 .LABFA addr1
4 .LAQUA pointer
where len is the length of the argument block.
The value of len1 is the number of words
reserved for information that will be returned.
On the return, the left half of this word
contains the actual number of words returned.
The value of addr1 is the location where the
information will be returned.
The last word, .LAQUA, is optional and may
contain an ASCIZ string pointer (addr2) to a
word containing the server name, to obtain
counter information about the specific server.
To obtain totals information, leave .LAQUA zero.
6 .LAZRO Zeroes counters. This function requires JACCT
or [1,2] privileges. The argument list is:
Word Symbol Contents
0 .LAACT EXP len
1 .LAFCN EXP .LAZCO
2 .LABCT EXP len1
3 .LABFA addr1
4 .LAQUA pointer
where len is the length of the argument block.
The value of len1 is the number of words
reserved for information that will be returned.
On the return, the left half of this word will
contain the actual number of words returned.
The value of addr1 is the location where the
information will be returned.
The last word, .LAQUA, is optional and may
contain an ASCIZ string pointer to a word
containing the server name, to obtain counter
information about the specific server. To zero
all totals, zero the contents of .LAQUA.
22-240
LATOP. [CALLI 221]
Normal Return
On a successful completion of the monitor call, the skip return
is taken, the requested information is stored in the specified
locations, and the ac contains the address of the argument list.
Several LATOP. functions return information in a buffer starting
at the address stored in Word 3 of the argument block, .LABFA.
The functions and the format of the information returned are
listed below.
Function .LASCH (Show Characteristics)
Show Buffer Format
0-----------------------------17 18------------------------35
-----------------------------------------------------------------
| MAX-ALLOC-CIRCUITS | N-ALLOC-CIRCUITS |
-----------------------------------------------------------------
| MAX-ACTIVE-CIRCUITS | N-ACTIVE-CIRCUITS |
-----------------------------------------------------------------
| MAX-CONNECTS | N-CONNECTS |
-----------------------------------------------------------------
| HOST-NUMBER | LAT-TERMINAL-ACCESS-STA |
-----------------------------------------------------------------
| HOST-RETRANSMIT-LIMIT | HOST-CIRCUIT-TIMER |
-----------------------------------------------------------------
| HOST-MULTICAST-TIMER | Reserved |
-----------------------------------------------------------------
| HIGH-PROTOCOL-VERSION | LOW-PROTOCOL-VERSION |
-----------------------------------------------------------------
| PROTOCOL-ECO | CURRENT-PROTOCOL-VERSION|
-----------------------------------------------------------------
| MAX-SLOT-SIZE | MAX-SLOTS |
-----------------------------------------------------------------
| FRAME-SIZE | MAX-SERVICES |
-----------------------------------------------------------------
| HOST GROUP CODES (8 words) |
-----------------------------------------------------------------
| HOST-NAME count | HOST-ID count |
-----------------------------------------------------------------
| HOST NAME (2 words) |
-----------------------------------------------------------------
| HOST ID (13 words) |
-----------------------------------------------------------------
| Service Blocks (19 words per service) |
-----------------------------------------------------------------
22-241
LATOP. [CALLI 221]
Service Block Format
-----------------------------------------------------------------
| HOST-SERVICE-NAME-RATING |
-----------------------------------------------------------------
| SERVICE-NAME count | SERVICE-DESCRIPTION count |
-----------------------------------------------------------------
| SERVICE-NAME (4 words) |
-----------------------------------------------------------------
| SERVICE-DESCRIPTION (13 words) |
-----------------------------------------------------------------
Function .LASTC (Show Connects)
Connect Block Format
-----------------------------------------------------------------
| Terminal Number |
-----------------------------------------------------------------
| Server Name count | Indeterminate |
-----------------------------------------------------------------
| Server Name (4 words) |
-----------------------------------------------------------------
Function .LASAS (Show Adjacent Servers)
Full Format Block
-----------------------------------------------------------------
| Server Ethernet Address (2 words) |
-----------------------------------------------------------------
| FRAME-SIZE | SERVER-VERSION |
-----------------------------------------------------------------
| MAX-SLOTS | Indeterminate |
-----------------------------------------------------------------
| CIRCUIT-TIMER | KEEP-ALIVE-TIMER |
-----------------------------------------------------------------
| PRODUCT-TYPE | STATE |
-----------------------------------------------------------------
| SERVER-NUMBER | SERVER-NAME count |
-----------------------------------------------------------------
| SERVER-LOCATION count | Unused |
-----------------------------------------------------------------
| SERVER-NAME (4 words) |
-----------------------------------------------------------------
| SERVER-LOCATION (4 words) |
-----------------------------------------------------------------
22-242
LATOP. [CALLI 221]
Short Format Block
-----------------------------------------------------------------
| SERVER-NUMBER | SERVER-NAME count |
-----------------------------------------------------------------
| SERVER-NAME (4 words) |
-----------------------------------------------------------------
| ETHERNET-ADDRESS (2 words) |
-----------------------------------------------------------------
Functions .LASCO (Show Counters) and .LAZCO (Zero Counters)
Counter Block Format
-----------------------------------------------------------------
| Messages Received |
-----------------------------------------------------------------
| Messages Sent |
-----------------------------------------------------------------
| Messages Retransmitted |
-----------------------------------------------------------------
| Receive Sequence Errors |
|---------------------------------------------------------------|
| Illegal Messages Received |
-----------------------------------------------------------------
| Resource Failures |
-----------------------------------------------------------------
Error Return
On an error return, the non-skip return is taken, and the ac
contains an error code. The error codes are:
Code Symbol Meaning
0 LABTS% The buffer size you allocated was too small
for the amount of information available.
The actual number of words that are required
is stored in the left half of .LABCT.
1 LAVOR% Value of a parameter is outside the allowed
range.
2 LALNO% LAT is not operational.
3 LASVR% Invalid or unknown LAT server name.
4 LAIPN% Invalid LAT parameter.
5 LAIPV% Invalid LAT parameter value.
6 LASVC% Invalid or unknown LAT service name.
7 LAILR% Insufficient LAT resources.
10 LAHAS% LAT host name already set.
11 LAIVF% Invalid function code.
12 LAABS% Argument list too small.
13 LAADC% Address check for argument list (specified
address not in memory)
14 LAPRV% Not enough privileges.
22-243
LLMOP. [CALLI 220]
LLMOP. [CALLI 220]
Function
Performs functions for the network management layer of DECnet.
This call is used only by the NML program and is not intended for
use in customer programs. The LLMOP. UUO may change at any time
without notice. This call requires [1,2], JP.POK, or JACCT
privileges.
Calling Sequence
MOVE ac1, fcncode
XMOVEI ac2, addr
LLMOP. ac2,
error return
normal return
where: fcncode is the function code. The argument block found
at addr is specific to the function code contained in
ac1.
addr is the address of the argument block.
Function codes for LLMOP. are:
Code Symbol Function
0 .ELDIR Builds an Ethernet loopback message from data
supplied in the argument block, and transmits it
to the destination address. The argument block
is:
Offset Symbol Contents
0 .LMCID Channel ID. Bits 34 and 35
(LM.CID) contain the value of
the Ethernet port to use.
1-2 .LMDST Destination address.
3 .LMREQ Request number, containing:
Bits Symbol Meaning
0 LM.AIC Assigns
interrupt
channel
specified in
LM.ICH.
22-244
LLMOP. [CALLI 220]
Code Symbol Function
Bits Symbol Meaning
12-17 LM.ICH Contains PSI
channel to
interrupt when
the message
arrives.
18-35 LM.REQ Contains the
request number
returned by
LLMOP. This
value is used
in function
.ELRPY.
Offset Symbol Contents
4 .LMRBL Length of the loopback request
data buffer. The right half
(LM.MBL) contains the length
of the data portion of the
loopback message.
5 .LMRBP Pointer to loopback request
data buffer.
1 .ELAST Builds an Ethernet loopback message, and
transmits it according to the type of assistance
required. The first words in the argument
block, .LMCID, .LMDST, .LMREQ, .LMRBL, and
.LMRBP, are described in function .ELDIR. The
remainder of the argument block is:
Offset Symbol Contents
6-7 .LMAST Address of the node used as
the assistant in the loopback
request. This may not be a
multicast address.
10 .LMHLP Assistance level. Level 1,
.LMXMT, forwards the loopback
message to both the
destination and local nodes.
Level 2, .LMRCV, forwards the
loopback message to assistant
and local nodes. Level 3,
.LMFUL, forwards the message
to destination, assistant, and
local nodes.
22-245
LLMOP. [CALLI 220]
Code Symbol Function
2 .ELRPY Reads the loopback reply message. The argument
block is:
Offset Symbol Contents
0 .LMCID Channel ID. Bits 34 and 35
(LM.CID) contain the value of
the Ethernet port to use.
1-2 .LMSRC Address of the remote system
that satisfied a loop assisted
operation.
3 .LMREQ Request number. The right
half (LM.REQ) contains the
request number of the reply to
be read. The caller is
blocked until the reply
arrives.
4 .LMRBL Length of the loop response
buffer. The left half
(LM.RML) contains on return
the length of the received
loop reply message data. The
right half (LM.MBL) holds the
maximum length of the loop
response message buffer that
you supply.
5 .LMRBP Pointer to loop reply buffer.
3 .ELAIC Assigns interrupt channel for Ethernet loopback
reply. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, where Bits 34 and
35 (LM.CID) contain the value
of the Ethernet port to use.
22-246
LLMOP. [CALLI 220]
Code Symbol Function
Offset Symbol Contents
1 .LMICF Interrupt channel flags, in
the form:
Bits Symbol Meaning
0 LM.AIC Assigns the
interrupt
channel given
in LM.ICH when
lit.
12-17 LM.ICH Contains the
PSI channel to
interrupt when
the loopback
message
arrives.
4 .ELABT Aborts the loop request. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, where bits 34 and
35 contain the value of the
Ethernet port to use.
3 .LMREQ Request number. The right
half, LM.REQ, contains the
number of the request to be
aborted.
5 .ELSTS Obtains status of Ethernet loopback requests.
The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, where bits 34 and
35 contain the value of the
Ethernet port to use.
22-247
LLMOP. [CALLI 220]
Code Symbol Function
Offset Symbol Contents
1 .LMSTF Status code for the request.
The right half, LM.RTC,
contains one of the following
status codes:
Code Symbol Status
0 .LMPND Request
pending,
incomplete.
1 .LMSUC Request
completed
successfully.
2 .LMABT Request
aborted.
3 .LMTXF Transmit
failed.
4 .LMCCE Channel
communication
error.
2 .LMCST Status returned from the KLNI
port driver.
3 .LMREQ Request number. The right
half, LM.REQ, contains the
number of the request to be
aborted.
6 .RCRID Transmits a Read Identify protocol message to
the destination address node on the Ethernet.
Use the .RCRPY function to read the System ID
reply message. The argument block is identical
to that of function .ELDIR. The value returned
in LM.REQ of .LMREQ must be used in any
subsequent .RCRPY, .RCABT, or .RCSTS calls.
7 .RCRCT Transmits a Read Counters protocol message to
the destination address node on the Ethernet.
Use the .RCRPY function to read the System ID
reply message. The argument block is identical
to that of function .ELDIR.
22-248
LLMOP. [CALLI 220]
Code Symbol Function
10 .RCIDS Transmits a System ID protocol message to the
destination address node on the Ethernet. This
function blocks the program until the transmit
is completed. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, where bits 34 and
35 (LM.CID) contain the value
of the Ethernet port to use.
1-2 .LMDST Destination address.
11 .RCRBT Transmits a Boot protocol message to the
destination address node on the Ethernet.
.RCRBT blocks the issuing process until the
transmit is completed. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, where bits 34 and
35 (LM.CID) contain the value
of the Ethernet port to use.
1-2 .LMDST Destination node address.
3-4 .LMPWD 8-byte verification code. The
code is transmitted to the
remote system, which uses it
in deciding whether to allow
the boot request. The 8-bit
bytes are packed four to a
word.
5 .LMCIF Control information, in the
form:
Bits Symbol Meaning
26 LM.BDV Specifies the
boot device,
where 0
indicates the
system
default, and 1
represents a
specified
device.
22-249
LLMOP. [CALLI 220]
Code Symbol Function
Bits Symbol Meaning
27 LM.BSV Specifies the
boot server,
where 0 is the
system
default, and 1
indicates
requesting a
system.
28-35 LM.PRO Specifies the
processor to
boot. 0
indicates the
system
processor, and
1 represents
the
communication
processor.
Offset Symbol Contents
6 .LMDID Device ID in an 8-bit byte
string.
7 .LMSID Software ID in an 8-bit byte
string.
12 .RCRPY Reads the response to a request ID or Read
Counters function. The format of the argument
block is the same as for .ELRPY. .LMSRC
contains the address of the responding node.
.LMRBL contains the returned message length, and
.LMRBP contains a pointer to the response
buffer.
13 .RCRSV Transmits a reserve remote console MOP message.
The argument block contains .LMCID, .LMDST, and
.LMPWD, as described in function .RCRBT.
14 .RCREL Transmits a release remote console MOP message.
The argument block contains .LMCID and .LMDST.
22-250
LLMOP. [CALLI 220]
Code Symbol Function
15 .RCSND Sends ASCII console command data to a remote
console and polls for response data. If no
command data is included, the function only
polls for response data. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID, in the form:
Bits Symbol Meaning
16 LM.CBF Command break
flag. If this
bit is set, a
break
condition in
the serial
byte stream
precedes the
command data
buffer.
17 LM.MNO Message
number, which
is a one-bit
sequence
number,
indicating the
current
Console
Requestor
command
message.
34-35 LM.CID Channel ID.
Offset Symbol Contents
1-2 .LMDST Destination address.
3 .LMREQ Request number, as described
in .ELDIR.
4 .LMRBL Length of console request
buffer. The right half,
LM.MBL, contains the maximum
buffer length.
5 .LMRBP Pointer to the remote console
data buffer.
22-251
LLMOP. [CALLI 220]
Code Symbol Function
16 .RCPOL Polls for completion of the Send Console Command
function. The argument block is:
Offset Symbol Contents
0 .LMCID Channel ID and returned flags,
in the form:
Bits Symbol Meaning
7 LM.RDL Indicates that
received data
was lost. The
flag is set by
the local
requestor if
the response
data buffer
was too small
to receive the
data from the
remote node.
15 LM.RDO Indicates that
response data
was lost, due
to a buffer
overrun or
error
condition.
16 LM.CDL Indicates that
command data
was lost.
This flag is
set if command
data in the
Console
Command
message was
lost. The
remote server
sets this bit.
22-252
LLMOP. [CALLI 220]
Code Symbol Function
Bits Symbol Meaning
17 LM.MNO Message
number, which
is a one-bit
sequence
number,
indicating the
current
Console
Requestor
command
message.
34-35 LM.CID Channel ID.
Offset Symbol Contents
1-2 .LMSRC Source node and physical
address of the node that sent
this reply.
3 .LMREQ Request ID, assigned by
.RCSND.
4 .LMRBL Length of console response
buffer. The format of the
buffer is described in .ELRPY
5 .LMRBP Pointer to the remote console
data buffer.
20 .RCABT Aborts an outstanding remote console request.
The argument block is identical to that of
.ELABT.
21 .RCSTS Obtains status of a remote console request. The
argument block is identical to that of .ELSTS.
22-253
LLMOP. [CALLI 220]
Code Symbol Function
22 .RCADR Obtains a channel address. The argument block
is:
Offset Symbol Contents
0 .LMCID Channel ID, where bits 34 and
35 contain the value of the
Ethernet port to use.
1-2 .LMHWA Hardware address.
3-4 .LMPYA Physical address.
Normal Return
On a successful completion, the requested functions are
performed, and any returns are made as specified in the
description of the function code.
Error Return
One of the following codes is returned in the ac:
Code Symbol Error
1 LMPRV% Program has insufficient privileges.
2 LMIIF% Program specified an illegal function.
3 LMICN% Program specified an illegal channel number.
4 LMOFF% LLMOP. is off.
5 LMADC% An address check was performed.
22-254
LOCATE [CALLI 62]
LOCATE [CALLI 62]
Function
Changes the logical node number for the current job. This call
functions in the ANF-10 network to allow you to route device I/O
to devices at other nodes. Subsequent references to output
devices (such as line printers) and input devices (such as card
readers), when implicitly requested or generically referenced,
will be assumed to refer to devices on the node you specify with
this call.
Calling Sequence
/ MOVE ac,[SIXBIT/nodename/] \
\ MOVEI ac,nodenumber /
LOCATE ac,
error return
normal return
where: nodename is the SIXBIT physical name of a node.
nodenumber is one of the following:
-1 Changes your job's location to the physical node
of your terminal.
0 Changes your job's location to that of the host
computer.
n Changes your job's location to node number n,
where n is a positive integer.
Normal Return
The location of your job is changed as specified. Any subsequent
generic device specifications are associated with the new node
number and node name.
Error Return
The error return occurs if the LOCATE monitor call is not
implemented on your system, or if you specified an invalid node
number or node name.
22-255
LOCATE [CALLI 62]
Examples
MOVEI T1,3
LOCATE T1,
JRST ERROR
Locates your job at node number 3.
Related Calls
WHERE
22-256
LOCK [CALLI 60]
LOCK [CALLI 60]
Function
Locks the current job into user memory. Note that there are two
calling sequences for LOCK. The standard calling sequence is
described under Calling Sequence 1 and the extended calling
sequence is described under Calling Sequence 2. The extended
calling sequence locks a segment starting at a specified page in
physical memory.
The default function of this call locks the segments of the
program as set by bits 17 and 35 in the accumulator. Bit 17 must
be set to lock the high segment; bit 35 must be set to lock the
low segment. The specified segment(s) is locked into physically
contiguous memory in contiguous executive virtual memory space,
unless you set flags in the accumulator to specify otherwise.
NOTE
Programs using user mode extended addressing
cannot use the LOCK monitor call.
Calling Sequence 1
MOVE ac,[flags]
LOCK ac,
error return
normal return
where: flags include one or more of the following bits:
Bit Symbol Function
14 LK.HLC Locks the high segment in user core and sets its
cache bit. If this bit is off, the high segment
is locked with its cache bit off. KL10
processors will run your program faster if you
use LK.HLC; however, for a real-time program
that has direct access to memory, you should not
set LK.HLC.
15 LK.HNP Locks the high segment without forcing the job
to be locked into physically contiguous
locations. If this bit is not set, physical
contiguity for the locked high segment is
required.
22-257
LOCK [CALLI 60]
16 LK.HNE Locks the high segment without forcing it to
reside in executive virtual memory. If this bit
is not set, the locked high segment must reside
in executive virtual memory.
NOTE
For executive-mode, real-time trapping,
your high segment must be locked into
contiguous executive virtual memory.
17 LK.HLS Locks the high segment. Without this bit set,
the high segment will not be locked, and bits
14-16 will be ignored.
32 LK.LLC Locks the low segment in user core and sets its
cache bit. If this bit is off, the low segment
is locked with its cache bit off. Processors
will run your program faster if you use LK.LLC;
however, for a real-time program that has direct
access to memory, you should not set LK.LLC.
33 LK.LNP Locks the low segment without requiring
physically contiguous locations for the low
segment. If this bit is not set, the low
segment must be locked into physically
contiguous locations.
34 LK.LNE Locks the low segment without requiring the low
segment to reside in executive virtual memory.
If this bit is not set, the low segment must be
locked into executive virtual memory.
NOTE
For executive-mode, real-time trapping,
your low segment must be locked into
contiguous executive virtual memory.
35 LK.LLS Locks the low segment. If this bit is clear,
the lowseg will not be locked, and bits 32-35
will be ignored.
22-258
LOCK [CALLI 60]
Calling Sequence 2
MOVE ac,[XWD -n,addr]
LOCK ac,
error return
normal return
. . .
addr: fcn-code
hiseg,,lowseg
where: n is the number of arguments plus one, expressed as a
negative value.
addr is the address of the argument block.
fcn-code is the function code described below.
hiseg is set if the high segment is to be locked. lowseg
is set if the low segment is to be locked.
Code Symbol Meaning
0 .LKPPN Locks the high and/or the low segment into
contiguous physical pages, starting at the
physical page number specified in the argument.
The left half of addr+1 contains the starting
page number of the high segment; if this
halfword is 0, the high segment is not locked.
The right half of addr+1 contains the starting
page number of the low segment; if this halfword
is 0, the low segment is not locked.
If you use Calling Sequence 2 when the system is running with
KL-paging the low segment is locked into the second higher
physical page.
Normal Return
When using Calling Sequence 1, the monitor has locked the program
into core. If physical or executive virtual contiguity is
required, the following information is stored in the ac:
XWD hiseg,lowseg
where: hiseg is the address of the high segment (0 if no high
segment exists).
lowseg is the address of the low segment.
If no contiguity is required, the ac is cleared.
22-259
LOCK [CALLI 60]
The monitor will lock your program into memory and take the
normal return if all of the following conditions are met:
o The lock privilege bit (JP.LCK) is set for your job.
o The locked job would not prevent any other job from expanding
to its guaranteed minimum (CORMIN).
o The locked job would not prevent any other current job from
running. (Note that unlocked jobs can exceed CORMIN.)
o For executive virtual mapping, the locked job would not
exceed the maximum amount of executive virtual memory
available for locking.
o The job either has no high segment, or has a sharable high
segment.
o The job is not virtual and has a contiguous core image.
When using Calling Sequence 2, the monitor locks the specified
segment (contiguously and physically) starting at the page in
physical memory specified in your program. If you specify that
the low segment is to be locked, the monitor locks your job into
the next higher physical page location than the one you specified
in the right half of your argument.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 LKNIS% The LOCK call, or a feature you requested, is
not implemented on your system; or you attempted
to lock a nonsharable high segment.
1 LKNLP% No locking privilege.
2 LKNCA% Not enough core available; your locked job would
prevent running an unlocked job.
3 LKNCM% Not enough core for CORMIN; your job would
prevent maintaining CORMIN for unlocked jobs.
4 LKNEM% Not enough core for executive virtual memory;
your locked job would exceed the maximum
allowable executive virtual memory. You can
obtain the executive virtual memory maximum and
in-use values from the GETTAB table .GTCnV,
where n is the CPU number. The maximum is in
word 43 (%CVEVM) of the table and the in-use
value is in word 44 (%CVEVU).
22-260
LOCK [CALLI 60]
Code Symbol Error
5 LKNIA% Illegal flags specified.
6 LKNPU% Specified page not available. You would receive
this error on an extended LOCK call if the two
segments would overlap, one or both segments
would overlap another locked job or the monitor,
or one or both segments would be outside the
range of on-line memory.
7 LKNAL% Illegal movement specified. You tried to move a
locked segment or place a segment into executive
virtual memory.
Examples
See Chapter 9.
22-261
LOGIN [CALLI 15]
LOGIN [CALLI 15]
Function
Informs the monitor that a job has successfully logged in, and
passes certain parameters to the monitor (including the
project-programmer number). The calling job must not be logged
in.
The LOGIN monitor call is used by the LOGIN and INITIA programs
and is not intended for customer use.
Calling Sequence
MOVE ac,[XWD -len,addr]
LOGIN ac,
return
...
addr: proj,,prog ;JBTPPN (.GTPPN)
privilege bits ;JBTPRV (.GTPRV)
user-name ;first half, .PDNM1 (.GTNM1)
user-name ;second half, .PDNM2 (.GTNM2)
charge # ;.PDCN0 (.GTCNO)
where: len is the length of the argument list.
addr is the address of the argument list. The data in
the argument list is to be passed to the monitor.
Return
The job is logged in, if it is not already logged in.
Related Calls
ACCLG., CHGPPN, LOGOUT
22-262
LOGOUT [CALLI 17]
LOGOUT [CALLI 17]
Function
Releases all I/O devices associated with the calling job and
returns them to the monitor's pool of available devices, along
with the job's allocated core and its job number.
To perform this call, the user program should use the RUN UUO to
call SYS:LOGOUT.EXE, where SYS is the [1,4] area.
The LOGOUT UUO has no error return. If the calling program has
JACCT privileges and is named LOGOUT.EXE, this call logs out the
job. Otherwise, the call functions like an EXIT UUO.
Calling Sequence
LOGOUT
return
Related Calls
EXIT
22-263
LOOKUP [OPCODE 076]
LOOKUP [OPCODE 076]
Function
Selects a file for input. Use FILOP. to perform a LOOKUP for an
extended I/O channel. The LOOKUP call is meaningful only for
directory devices (disk, DECtape, labelled magnetic tape), and
for TSK devices (initiated for task-to-task communication). It
is a no-op for other devices, always taking the normal return for
these.
Calling Sequence
The LOOKUP monitor call, like the ENTER call, has two calling
sequences: one using a 4-word argument list and one using an
extended argument list. The argument lists for LOOKUP, ENTER,
and RENAME UUOs are identical. These are described in Section
11.13. The four-word argument list is detailed in Section
11.13.1. The extended argument list is described in Section
11.13.2.
Normal Return
For DECtape, the monitor returns a 4-word block at addr in the
following form:
Offset Contents
0 The SIXBIT file name.
1 The extension, creation date, and first block number:
Bits Contents
0-17 The SIXBIT file extension.
18-20 The high-order three bits of the file
creation date.
21-25 Reserved.
26-35 The first physical (data) block number.
2 Remainder of creation date:
Bits Contents
0-23 Reserved.
24-35 The low-order 12 bits of the file
creation date.
22-264
LOOKUP [OPCODE 076]
Offset Contents
3 Length and address of file:
Bits Contents
0-17 Negative of number of words in
zero-compressed file.
18-35 Address of word preceding the first word
of the file.
For disk files, and labelled magtape files, refer to Sections
11.13.1 and 11.13.2 for the argument blocks returned by LOOKUP,
ENTER, and RENAME UUOs.
Error Return
The error codes for LOOKUP are the same as those for ENTER, and
are documented in Section 11.14.
Examples
For more information about doing I/O and examples using the
LOOKUP call, refer to Chapter 11.
22-265
MERGE. [CALLI 173]
MERGE. [CALLI 173]
Function
Merges an .EXE file or a portion of an .EXE file into the
currently loaded low segment in memory, ignoring page 0 from the
.EXE file.
Calling Sequence
|
| MOVEI ac,addr
| MERGE. ac,
| error return
| normal return
| ...
| addr: SIXBIT/device/
| SIXBIT/filename/
| SIXBIT/extension/
| EXP 0
| XWD / proj,prog \
| \ 0,addr2 /
| XWD / low-page,hi-page \
| | -n,,addr3 |
| \ 0 /
where: addr is the address of the 6-word argument block.
device is the name of the device on which the .EXE file
resides.
filename specifies the name of the .EXE file.
extension specifies the extension of the .EXE file.
proj,prog is the project-programmer number representing
the directory in which the .EXE file resides. If you
specify this word as zero, your directory path is
assumed. If this word is [XWD 0,addr], addr points to a
PATH. block containing the full path specification for
the file. Refer to the description of the PATH. monitor
call for information pertaining to the format of the
PATH. block.
22-266
MERGE. [CALLI 173]
The last word of the argument block has three possible
forms: low-page and hi-page specify the lower-bound
virtual page number and the upper-bound virtual page
number of the .EXE file to be loaded into your low
segment. Specifying -n,,addr3 indicates that each of the
n ranges of pages given in addr3 (in low-page, hi-page
form) are to be MERGEd. This format saves you from
performing multiple MERGEs. Finally, placing zero in the
last word causes the low-segment pages in the .EXE file
to be merged.
Normal Return
The .EXE file pages are merged into the current low segment in
memory. The accumulators are destroyed and channel 0 is
released.
Error Return
The error return is taken if any errors are detected; the monitor
returns an error code in the ac. The possible error codes are
listed in Chapter 11.
Related Calls
GETSEG, RUN
Common Errors
o Forgetting to save the acs over the MERGE.
o Forgetting that channel 0 is destroyed.
o Attempting to MERGE high segment data.
22-267
MONRT. [CALL 1,12]
MONRT. [CALL 1,12]
Function
Identical to the call:
EXIT 1,
See the EXIT monitor call. Note that this function does not
perform a RESET for your job.
22-268
MSTIME [CALLI 23]
MSTIME [CALLI 23]
Function
Returns the current time of day.
Calling Sequence
MSTIME ac,
return
Return
The time elapsed (in milliseconds) since midnight is returned in
the ac.
Related Calls
DATE, RUNTIM, TIMER
22-269
MTAID [CALLI 126]
MTAID. [CALLI 126]
Function
Associates a SIXBIT reel identifier with a specified magnetic
tape drive. This call requires JACCT or [1,2] privileges.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| MOVE ac+1,[SIXBIT/reelid/]
| MTAID. ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
reelid is the SIXBIT tape reel identifier, or 0 to clear
the current reelid.
Note that your program can also clear the reel identifier by
using function code 11 (MTUNL.) to the MTAPE monitor call; or by
deassigning the drive, using the REASSI UUO. All reel-specific
error counts are cleared by the MTAID. call in order that all
accumulated data for the specific reel is accurate.
Normal Return
The monitor has associated the tape reel identifier with the
specified magtape device; the reel identifier is included in all
media reports.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-2 MTINA% Specified device is not available to your job or
your job is not privileged.
-1 MTINX% Specified device is nonexistent or not a magtape
device.
22-270
MTAID [CALLI 126]
Examples
MOVE T1,[SIXBIT/MTA0/]
MOVE T1+1,[SIXBIT/REEL1/]
MTAID. T1,
JRST ERROR
Related Calls
MTAPE, MTCHR., TAPOP.
22-271
MTAPE [OPCODE 072]
MTAPE [OPCODE 072]
Function
Passes the monitor a code for an extended set of calls; these
calls perform functions for magnetic tapes and are usually called
MTAPEs. Use FILOP. or TAPOP. to perform magnetic tape or DECtape
functions on extended I/O channels.
Each defined MTAPE code also has a symbolic name; in this chapter
the MTAPEs are discussed in alphabetical order by their names.
For example, MTAPE 3 has the name MTEOF.; its function is
discussed under the name MTEOF.
Magtape I/O is described in Volume 1, Chapter 14.
The MTAPEs are:
MTWAT. [MTAPE 0]
MTREW. [MTAPE 1]
MTEOF. [MTAPE 3]
MTSKR. [MTAPE 6]
MTBSR. [MTAPE 7]
MTEOT. [MTAPE 10]
MTUNL. [MTAPE 11]
MTBLK. [MTAPE 13]
MTSKF. [MTAPE 16]
MTBSF. [MTAPE 17]
MTDEC. [MTAPE 100]
MTIND. [MTAPE 101]
MTLTH. [MTAPE 200]
After your program issues the MTAPE monitor call, the monitor
waits for the magnetic tape to complete any action in progress.
The monitor then clears bits 18-25 of the file status word,
initiates the indicated MTAPE function, and returns control
immediately to your program.
22-272
MTAPE [OPCODE 072]
The I/O service routine may be reading several blocks ahead of
your program when performing I/O in buffered mode. The execution
of the MTAPE monitor call affects only the physical position of
the magnetic tape and does not change the data that has already
been read into the buffer. Therefore, when your program issues
either an IN, INPUT, OUT, or OUTPUT call after the MTAPE monitor
call, the monitor may not retrieve the buffer containing the
block requested. To guarantee that the requested block will be
in the buffer, your program can set up a single buffer ring.
With a single buffer ring the monitor is prohibited from reading
ahead, and it stops the device after every IN, INPUT, OUT, or
OUTPUT monitor call. Alternatively, your program can set bit 30
(IO.SYN) in the I/O status word. Setting this bit causes the
monitor to stop the device after each buffer is filled on an IN,
INPUT, OUT, OUTPUT, or FILOP. monitor call. Note that the
FILOP. monitor call provides the functions of the MTAPE calls.
22-273
MTBLK. [MTAPE 13]
MTBLK. [MTAPE 13]
Function
Writes three inches of blank tape. Use FILOP. to perform an
MTBLR. on an extended I/O channel.
Calling Sequence
MTBLK. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
Three inches of blank tape are written on the device associated
with the given channel.
Examples
MTBLK. 5,
Three inches of blank tape is written to the magtape on the unit
associated with channel 5.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return where none exists.
Forgetting to include a comma after the channel number.
22-274
MTBSF. [MTAPE 17]
MTBSF. [MTAPE 17]
Function
Backspaces one file on a magtape. Use FILOP. to perform an
MTBSF. on an extended I/O channel.
Calling Sequence
MTBSF. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor backspaces over one file on the device associated
with the given channel. The monitor moves the tape in the
reverse direction until the tape has passed a tape mark or
reached the beginning of the tape. The backspace operation
positions the tape heads either immediately in front of a tape
mark or at the beginning of the tape.
In most cases, your program should skip forward over the file
mark to the beginning of the file. However, when you have
backspaced to the beginning of the tape and when your program
issues the MTSKF. call, the monitor skips the entire first file
on the tape, stopping at the beginning of the second file rather
than leaving the tape positioned at the beginning of the first
file. Therefore, a correct sequence for backspacing a file is:
1. MTBSF. to backspace the file.
2. MTWAT. to wait for completion
3. STATO MT,IO.BOT to determine whether this is the beginning of
the tape.
4. MTSKF. to skip over the file mark if it is not the beginning
of the tape.
It is necessary to wait after the MTBSF. instruction to ensure
that the move is complete before testing to see whether or not
this is the beginning of the tape, but your program can use the
MTWAT. call to wait for the spacing operation to be completed.
22-275
MTBSF. [MTAPE 17]
Examples
MTBSF. 5,
Backspaces over 1 file on the tape associated with channel 5.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-276
MTBSR. [MTAPE 7]
MTBSR. [MTAPE 7]
Function
Backspaces one record on a magtape device. Use FILOP. to perform
an MTBSR. on an extended I/O channel.
Calling Sequence
MTBSR. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor backspaces over one record on the device associated
with the given channel.
Examples
MTBSR. 7,
This call backspaces over a record on the magtape associated with
channel 7.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return where none exists.
Forgetting to include a comma after the channel number.
22-277
MTCHR. [CALLI 112]
MTCHR. [CALLI 112]
Function
Returns information about the state of a magtape drive.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| | MOVEI ac,udx |
| \ MOVE ac,[XWD len,addr] /
| MTCHR. ac,
| error return
| normal return
| . . .
| addr: device-identifier ;applicable only if ac contains
| BLOCK 20 ; len,,addr
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Optionally, you can specify the length and location of
the argument list:
len is the length of the argument list.
addr is the address of the argument list, and the words
at addr+1 will be filled in by the monitor on return.
The argument list is used only if the length and address
are given in the ac instead of a device identifier
(device, channel number, or UDX).
device-identifier is set by the user program and contains
the device name, UDX, or channel number.
Normal Return
The monitor returns a value in the ac, and, if you used the
optional argument list, the monitor returns values beginning at
addr+1.
22-278
MTCHR. [CALLI 112]
The word returned in the ac is in the format:
Bits Symbol Meaning
0-17 MT.AWC The word count of the last record read or
written.
18-26 MT.CRC If a 9-track NRZI tape, this field contains the
last cyclic redundancy character (CRC);
otherwise, this field contains 0.
27-29 MT.NCR The number of characters not accounted for in
MT.AWC, read from the tape into the last
addressed location during the last read.
30 Reserved for use by DIGITAL. Should contain 0.
31 MT.7TR The unit is a 7-track unit.
32 MT.WLK The tape transport is write-locked.
33-35 MT.DEN The tape density code:
Code Symbol Density
1 .MTDN2 200 bits per inch (8.1 rows per
mm).
2 .MTDN5 556 bits per inch (22.5 rows
per mm).
3 .MTDN8 800 bits per inch (32.2 rows
per mm).
4 .MTD16 1600 bits per inch (65.3 rows
per mm).
5 .MTD62 6250 bits per inch (255.5 rows
per mm).
When the monitor determines the value of the density indicator to
be returned, it examines the I/O status bits you set in the OPEN
call. The monitor returns the density identifier you set in the
OPEN call. If you did not use OPEN to specify a density
indicator, the monitor determines whether or not you issued the
SET DENSITY monitor command. If you did, the monitor returns, in
the ac, the same value you specified in the monitor command. If
neither, the monitor returns the system-default density. (Note
that when you issue a GETSTS, the monitor examines only the I/O
status bits set by the OPEN. If you did not specify a density
indicator with OPEN, the monitor returns a 0 when you issue a
GETSTS. Therefore, when you issue a GETSTS, the monitor does not
further investigate the density indentifier or supply the
system-default density indicator.)
22-279
MTCHR. [CALLI 112]
If you use the optional argument list, the monitor returns data
at addr+1 and the subsequent locations. The information,
starting addr+1, is returned as:
Offset Symbol Contents
0 .MTCHN Channel number.
1 .MTRID SIXBIT reel identifier of the tape.
2 .MTWRD Number of files read since the beginning of the
tape.
3 .MTREC Number of records since last end-of-file.
4 .MTCRD Number of characters read since last tape
unload.
5 .MTCWR Number of characters written since last tape
unload.
6 .MTSRE Number of soft read errors since last unload.
7 .MTHRE Number of hard read errors since last unload.
10 .MTSWE Number of soft write errors since last unload.
11 .MTHWE Number of hard write errors since last unload.
12 .MTTME Total number of read and write errors since last
tape unload.
13 .MTTDE Number of device errors since system startup.
14 .MTTUN Number of unloads since system reload.
15 .MTRTY Number of retries to resolve last error; if bit
1 is set, the error is a hard error.
16 .MTCCR Character count of the last record read or
written.
17 .MTPBE Position before error. The file number before
last error (right half), and record number
before last error (left half).
20 .MTFES Final error state. Refer to the TOPS-10/TOPS-20
SPEAR Manual.
22-280
MTCHR. [CALLI 112]
Error Return
The error return is taken and -1 returned in the ac if the device
you specified was not a magnetic tape unit or was nonexistent.
Related Calls
TAPOP.
22-281
MTDEC. [MTAPE 100]
MTDEC. [MTAPE 100]
Function
Initializes a channel for DIGITAL-compatible mode tape handling.
Use FILOP. to perform an MTDEC. on an extended I/O channel.
In DIGITAL compatible mode, the monitor writes or reads 36 bits
in 5 frames of a 9-track magnetic tape. The tape can be any
density or parity and is not industry-compatible. DIGITAL
compatible mode is the default mode that is set when the channel
is opened.
The DIGITAL-compatible mode remains in effect until the channel
is released, or until you issue the MTIND. monitor call for the
channel.
Calling Sequence
MTDEC. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The device associated with the given channel is initialized for
DIGITAL-compatible mode handling.
Examples
MTDEC. 11,
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return where none exists.
Forgetting to include a comma after the channel number.
22-282
MTEOF. [MTAPE 3]
MTEOF. [MTAPE 3]
Function
Writes an end-of-file mark on a magtape. Use FILOP. to perform
an MTEOF. on an extended I/O channel.
Calling Sequence
MTEOF. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor writes an end-of-file mark on the specified device.
Examples
MTEOF. 10,
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-283
MTEOT. [MTAPE 10]
MTEOT. [MTAPE 10]
Function
Advances a magtape device to the logical or physical end-of-tape.
Use FILOP. to perform an MTEOT on an extended I/O channel.
The logical end-of-tape is indicated by two consecutive
end-of-file marks. The MTEOT. call positions the tape between
these two marks, allowing files to be appended to the tape.
Calling Sequence
MTEOT. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor positions the tape between the two end-of-file marks
that indicate the end-of-tape.
Examples
MTEOT. 6,
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-284
MTIND. [MTAPE 101]
MTIND. [MTAPE 101]
Function
Initializes a channel for industry-compatible mode tape handling.
Use FILOP. to perform an MTIND. on an extended I/O channel.
In industry-compatible mode, the monitor writes or reads 32 bits
in 4 frames of a 9-track magnetic tape, ignoring the low-order 4
bits of each PDP-10 word. MTIND. will set a default density to
1600 BPI, or the highest density allowed on the drive.
The industry-compatible mode remains in effect until the channel
is released, or until you issue the MTDEC. monitor call for the
channel.
Calling Sequence
MTIND. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The device associated with the given channel is initialized for
industry-compatible mode handling.
Examples
MTIND. 10,
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-285
MTLTH. [MTAPE 200]
MTLTH. [MTAPE 200]
Function
Sets a flag to read the next record on the given device at low
threshold (TM10 only). Use FILOP. to perform MTLTH. on an
extended I/O channel.
Calling Sequence
MTLTH. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor sets a flag to read the next record from the given
device at low threshold.
Examples
MTLTH. 5,
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-286
MTREW. [MTAPE 1]
MTREW. [MTAPE 1]
Function
Rewinds a magtape. Use FILOP. to perform MTREW. on an extended
I/O channel.
Calling Sequence
MTREW. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor rewinds the tape on the specified device.
Examples
MTREW. 5,
Rewind the magtape associated with channel 5.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-287
MTSKF. [MTAPE 16]
MTSKF. [MTAPE 16]
Function
Skips forward one file on a magtape device. Use FILOP. to
perform MTSKF on an extended I/O channel.
Calling Sequence
MTSKF. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor skips forward one file on the specified device, using
a series of skip record operations.
Examples
MTSKF. 7,
This call skips over a file on the magtape associated with
channel 7.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-288
MTSKR. [MTAPE 6]
MTSKR. [MTAPE 6]
Function
Skips forward one record on a magtape device. Use FILOP. to
perform MTSKR. on an extended I/O channel.
Calling Sequence
MTSKR. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor skips forward one record on the specified device.
Examples
MTSKR. 7,
This call skips a record on the magtape associated with channel
7.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-289
MTUNL. [MTAPE 11]
MTUNL. [MTAPE 11]
Function
Unloads a magnetic tape. Use FILOP. to perform MTUNL. on an
extended I/O channel. If the drive is under the control of MDA
(under GALAXY Version 4.1 and later), this call only rewinds the
tape.
Calling Sequence
MTUNL. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
The MTUNL. call initializes all automatic error reporting.
Therefore, reel-specific errors can be summarized regardless of
the method used to change reels. An entry into the system error
log file (refer to the TOPS-10/TOPS-20 SPEAR Manual) is written
in the following format:
Drive number (in the form MTxn)
SIXBIT/reelid/
Number of characters read since last MTUNL.
Number of characters written since the last MTUNL.
Number of soft-read errors since the last MTUNL.
Number of hard-read errors since the last MTUNL.
Number of soft-write errors since the last MTUNL.
Number of hard-write errors since the last MTUNL.
These numbers will be output on both the operator's terminal and
your terminal (if WATCH MTA is set) in the following format:
[MTxn:reelid READ (c/h/s)=a/b/c WRITE (c/h/s)=d/e/f]
where: x is an alphabetic representing the tape controller,
n is a number representing the drive number.
reelid is the reel identification.
a is the number of characters read.
b is the number of hard-read errors.
c is the number of soft-read errors.
d is the number of characters written.
22-290
MTUNL. [MTAPE 11]
e is the number of hard-write errors.
f is the number of soft-write errors.
When a, b, and c are 0, the information pertaining to READ will
not be printed.
When d, e, and f are 0, the information pertaining to WRITE will
not be printed.
To prevent this message from being printed, you can use SETUUO,
or type the .STWTC function of the following monitor command:
.SET WATCH NO MTA
Return
The monitor rewinds the tape on the specified device.
Examples
MTUNL. 7,
This call rewinds the tape associated with channel 7.
Related Calls
FILOP., TAPOP.
Common Errors
Including an error return when none exists.
Forgetting to include a comma after the channel number.
22-291
MTUNL. [MTAPE 11]
MTWAT. [MTAPE 0]
Function
Stops program execution until all spacing and I/O operations for
a magnetic tape device are completed. Use FILOP. to perform
MTWAT. on an extended I/O channel. Your program should execute
this call after all tape-positioning operations.
Calling Sequence
MTWAT. channo,
return
where: channo is the number of a channel initialized for a
magtape device.
Return
The monitor resumes execution at return after all spacing and I/O
operations for the specified device are completed.
Related Calls
TAPOP.
Common Errors
Including an error return.
22-292
MVHDR. [CALLI 131]
MVHDR. [CALLI 131]
Function
Allows you to move the buffer ring control block for an
initialized channel from one location to another. This move is
accomplished by changing the monitor's pointer to the ring
control block.
Calling Sequence
MOVEI ac,channo
MOVE ac+1,[XWD outring,inring]
MVHDR. ac,
error return
normal return
where: channo is the number of an initialized channel.
outring is the new address of the output buffer ring
control block, or 0.
inring is the new address of the input buffer ring
control block, or 0.
outring and inring must be in your current low segment.
If you give 0 as the address of either buffer ring control block,
the address is not changed.
Normal Return
The pointers to the specified control blocks are changed.
Error Return
The following error code is returned in the ac:
Code Symbol Error
1 MVHDR% Channel not initialized.
If you specify an illegal address, the monitor halts your job and
displays the following error message:
?Illegal address in UUO at user PC nnnnnn
22-293
NETOP. [CALLI 226]
NETOP. [CALLI 226]
Function
Indicates the node name and port name to which a terminal is
connected.
Calling Sequence
XMOVEI ac,arglst
NETOP. ac,
error return
normal return
where: arglst is the address of the argument list described
below:
Word Symbol Meaning
0 .NOFCN Contains the length of the argument block in the
left half, and a function code in the right
half. You supply this information. The only
valid code is .NOGDI, function 1. .NOGDI
obtains information about the specified
terminal's connection.
1 .NOFLG Returns flags that indicate how your terminal is
connected. If no flag is returned, the TTY is
on a local line. Flags are:
Flag Symbol Meaning
0 NO.ANF The TTY is on an ANF-10 node.
1 NO.DCN The TTY is hosted through
DECnet.
2 NO.LAT The TTY is on a LAT terminal
server.
2 .NODEV The SIXBIT device name, UDX, or open channel
number of the TTY. You supply this information.
3 .NODCH Returns the physical characteristics of the TTY,
in the same format as the return from a DEVCHR
monitor call. Refer to the DEVCHR description
for more information.
4 .NODTY Returns the physical properties of the TTY, in
the same format as the return from a DEVTYP
monitor call. Refer to the DEVTYP description
for more information.
22-294
NETOP. [CALLI 226]
Word Symbol Meaning
5 .NONOD The user-supplied address of a string block that
contains the node name string on return. The
left half of the string block's first word
contains the length of the returned string. The
block will contain up to 16 characters of node
name.
6 .NOPNM The user-supplied address of a string block
which contains the port name string on return.
The left half contains the length of the
returned block. ANF port names are returned as
TTYnnn, where nnn is the node-local line number
in octal. CTERM returns nnnnnn, which is a
left-justified (octal) line number. NRT does
not report a port name. LAT port names can be a
maximum of 16 characters.
Normal Return
Information about the TTY's connection is returned as indicated
in the argument block description.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 NOADC% An address check was encountered.
2 NOILF% An illegal function code was specified.
3 NOLTS% The argument list is too short.
4 NONSD% No such device.
5 NODNC% The specified device is not connected.
6 NONTY% Device is not a TTY.
22-295
NETOP. [CALLI 226]
Example
Example of the NETOP.UUO, which indicates where your own job's
TTY is connected.
SETO T1, ;Refers to your job
TRMNO. T1, ;Get the TTY's UDX
HALT ;
MOVEM T1,ARGBLK+.NODEV ;Put into arg block
MOVEI T1,ARGBLK ;Point to arg block
NETOP. T1, ; or CALLI AC,226
HALT ;
ARGBLK: XWD 7,.NOGDI ;Length,,function code
ARGFLG: BLOCK 1 ;Flags returned from NETOP.
ARGDEV: BLOCK 1 ;User supplies device specifier
; here
ARGDCH: BLOCK 1 ;NETOP. returns DEVCHR UUO info here
ARGDTY: BLOCK 1 ;NETOP. returns DEVTYP UUO info here
ARGNOD: EXP NODSPC ;Address of string block to receive
; node name
ARGPNM: EXP PORSPC ;Address of string block to receive
; port name
NODSPC: XWD 0,5 ;Left half will receive string
; length and 4 words (16 chars)
BLOCK 4 ; worth of node name
PORSPC: XWD 0,5 ;Left half will receive string length
BLOCK 4 ; and 4 words worth of port name
22-296
NODE. [CALLI 157]
NODE. [CALLI 157]
Function
Performs miscellaneous functions associated with ANF-10 network
nodes.
Calling Sequence
MOVE ac,[XWD fcncode,addr]
NODE. ac,
error return
normal return
. . .
addr: EXP len
first argument
. . .
last argument
Where: fcncode is one of the function codes described below.
addr is the address of the argument list.
len is the length of the argument list (including this
word); and the words up through last argument are
arguments for the specified function.
The function codes and their meanings are:
Code Symbol Function
1 .NDALN Reserved for use by DIGITAL.
2 .NDRNN Given either a node number or a node name,
returns the other in the ac. The argument list
for .NDRNN is:
addr: EXP 2
node-id
Where node-id is the SIXBIT name or the octal
node number of the node. If you specify a node
name, the node number is returned in the ac. If
you specify the node number, the node name is
returned in the ac.
22-297
NODE. [CALLI 157]
Code Symbol Function
3 .NDSSM Sends special network station control
(maintenance) messages. This function requires
that the calling job be logged-in under [1,2] or
have POKE. privileges. The argument list for
.NDSSM is:
addr: XWD seconds,4
node-id
XWD send-bytes,send-buffer
XWD receive-bytes,receive-buffer
where seconds is the number of seconds to wait
before a timeout error (NDTOE%) occurs. This
field is ignored if an input buffer is not
specified; the default is eight seconds if 0 is
specified.
node-id is the SIXBIT node name or octal node
number of the node.
send-bytes is the number of 8-bit bytes to be
sent.
send-buffer is the address of the first byte of
the message.
receive-bytes is the number of bytes in the
receive buffer. When the receive buffer is
filled, the monitor will set receive-bytes to
the number of bytes actually stored in the
buffer.
receive-buffer is the address of the buffer to
store the response.
If the value for both receive-bytes and
receive-buffer is 0, the monitor returns control
to your program without waiting for a response
from the node.
22-298
NODE. [CALLI 157]
Code Symbol Function
4 .NDRBM Receives bootstrap messages from a remote node.
This function requires that the calling job be
logged-in under [1,2] or have POKE. privileges.
The argument list for .NDRBM is:
addr: EXP 4
0 ;returned node number
0 ;not used
XWD count,addr
where count is the number of 8-bit bytes to be
received.
addr is the first address of the buffer. If
there is a boot message to be read, the
following occurs:
1. The second word of the argument block is
filled in with the number of the node that
sent the boot request station control
message.
2. The boot request message is copied into the
input buffer.
3. The count field is updated to reflect the
actual number of bytes stored.
5 .NDRCI Returns the number of devices at each node for a
list of device types. The argument list for
.NDRCI is:
addr: EXP len
node-id
EXP 0 ;reserved
BLOCK buflength
where len is the length of the argument list
(len-1 = number of following arguments).
node-id is the SIXBIT name of the node or the
octal node number.
The word following the node-id must be zero
because it is reserved for use by DIGITAL.
buflength is the number of words to reserve for
the returned data.
22-299
NODE. [CALLI 157]
Code Symbol Function
Your program must supply the device types in the
right half of each word starting at addr+3. The
device types are returned by the DEVTYP call and
are documented under that call. The monitor
returns, in the left halves of these words, the
count of devices whose type is given in the
right half. Each word returned will appear as:
XWD device-count,device-type
6 .NDOUT Obsolete.
7 .NDIN Obsolete.
10 .NDTCN Connects remote terminals to the local system.
The argument list for .NDTCN is:
addr: EXP 2
XWD node,line
where node is the octal number of the node to
which the terminal is connected.
line is the remote line number of the terminal
to be connected. On a normal return, the
monitor returns the SIXBIT terminal number in
the ac. The normal return is taken if the
terminal is connected to the system on which the
program is running. Therefore, a normal return
from this call does not mean that the terminal
is connected to your job.
11 .NDTDS Disconnects a remote terminal from the local
system and, optionally, reconnects it to another
host system. The argument list is:
addr: EXP m
SIXBIT/TTYnnu/
EXP node-number
where m is the length of the argument block
(either 2 or 3).
TTYnnu is the terminal name of the local
terminal to be reconnected or disconnected.
node-number is the number of the node to which
you wish the terminal to be reconnected. This
word is optional.
22-300
NODE. [CALLI 157]
Code Symbol Function
On a normal return, the terminal specified by
TTYnnu is disconnected from the local system.
If a node-number is specified, the terminal will
be connected to that host. In this case, the
action performed is the same as if you issued a
SET HOST monitor command.
12 .NDLND Returns the list of defined nodes. The argument
list is:
addr: EXP n
arg1
...
argn
where n is the length of the argument list.
On a normal return, the ac contains the number
of known nodes and arg1 through argn contain the
node numbers of the known nodes. If the
argument block is not long enough to return the
complete list of known nodes, the list is
truncated.
13 .NDNDB Returns the specified type of information about
a specified node. The argument list is:
addr: EXP n
node-id
EXP sub-fcn-code
arg1
...
argn
where n is the length of the argument block.
node-id is either an octal node number or a
SIXBIT node name.
sub-fcn-code is the sub-function code that
specifies the type of information to be
returned. arg1 through argn are words that your
program reserves for the information returned by
the monitor.
Code Symbol Meaning
1 ND.NNM Returns the number of the node.
2 ND.SNM Returns the SIXBIT name of the
node.
22-301
NODE. [CALLI 157]
Code Symbol Meaning
3 ND.SID Returns the software ID as an
ASCIZ string.
4 ND.DAT Returns the date the NODE
software was generated as an
ASCIZ string.
5 ND.LMA Returns the last NCL (Network
Command Language) message
assigned (on output).
6 ND.LMS Returns the last NCL message
sent (on output).
7 ND.LAR Returns the last NCL ACK
received (on output).
10 ND.LAP Returns the last NCL ACK
processed (on output).
11 ND.LMR Returns the last NCL message
processed (on input).
12 ND.LMP Returns the last NCL message
received (on input).
13 ND.LAS Returns the last NCL ACK
message sent.
14 ND.MOM Returns the counter for maximum
outstanding messages.
15 ND.TOP Returns a list of network link
descriptors of the form:
XWD cost,node
where: cost is the line cost
and node is the name of a node
that is connected to the node
specified in addr+1. One
descriptor is returned for each
neighboring node. A zero word
signifies the end of the list.
22-302
NODE. [CALLI 157]
Code Symbol Function
Code Symbol Meaning
16 ND.CNF Returns the device
configuration for a node in the
following format:
XWD obj-type,number
where: obj-type is the NCL
device type and number is the
count of devices. One such
descriptor is returned for each
type of device on the node.
17 ND.CTJ Returns the station control job
number.
20 ND.OPR Returns the terminal number of
the OPR terminal.
14 .NDGNF Sets or reads the "greeted" node flag. The
format of the argument list is:
addr: EXP 2
node-number
arg
where the node-number is the number of the node
for which the "greeted" node flag is to be set
and/or read. The flag may be specified in arg
and is returned in arg. If the node-number is
specified as 0, the node number of the first
"ungreeted" node is returned in addr+1. This
function is intended to be used by privileged
programs that perform a node-specific function
to a node when it comes on line.
Normal Return
The function is performed.
22-303
NODE. [CALLI 157]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 NDIAL% Illegal argument list.
2 NDINN% Illegal node name or node number.
3 NDPRV% Not enough privileges.
4 NDNNA% Node not available.
5 NDNLC% Job not locked in core.
6 NDTOE% Timeout error.
7 NDRNZ% Reserved word is not zero.
10 NDNND% Channel not initialized or not a network device.
11 NDIOE% I/O error occurred. The left half of ac
contains I/O status bits. For a list of I/O
status bits, see Volume 1.
12 NDNFC% No free core.
13 NDIAJ% In use by another job.
14 NDNMA% No message available.
15 NDTNA% Terminal not available.
16 NDNLT% Not a legal terminal.
17 NDISF% Illegal sub-function.
20 NDRBS% Receive buffer too small.
21 NDNUG% No ungreeted nodes.
22 NDILN% Illegal line number in station-control message.
23 NDADC% Address check performed while reading or writing
arguments.
22-304
NSP. [CALLI 205]
NSP. [CALLI 205]
Function
The NSP. monitor call enables task-to-task communication between
programs running on nodes in DECnet-10 networks. The
communicating programs may be on separate nodes or the same node.
For information on using this call, refer to Volume 1, Chapter 5.
Calling Sequence
MOVEI ac,addr
NSP. ac,
error return
normal return
. . .
addr: argument 1
argument 2
argument 3
Where addr is the address of an argument list appropriate to the
function code given in bits 9-17 of argument 1. The function
codes are:
Code Symbol Meaning
1 .NSFEA Enter active state.
2 .NSFEP Enter passive state.
3 .NSFRI Read connect information.
4 .NSFAC Accept connection.
5 .NSFRJ Reject connection.
6 .NSFRC Read connect confirm information.
7 .NSFSD Synchronous disconnect.
10 .NSFAB Abort connection.
11 .NSFRD Read disconnect data.
12 .NSFRL Release the channel.
13 .NSFRS Read the channel status.
22-305
NSP. [CALLI 205]
Code Symbol Meaning
14 .NSFIS Send interrupt data.
15 .NSFIR Receive interrupt data.
16 .NSFDS Send normal data.
17 .NSFDR Receive normal data.
20 .NSFSQ Set quotas.
21 .NSFRQ Read quotas.
22-23 Reserved for use by DIGITAL.
24 .NSFPI Set PSI reasons for software interrupts.
Normal Return
The specified function has been performed and the ac is not
changed.
Error Return
On an error return from NSP., one of the following error codes is
returned in the ac:
Code Symbol Error
1 NSABE% The argument block was formatted incorrectly.
2 NSALF% An allocation attempt failed.
3 NSBCN% An invalid channel number was specified.
4 NSBFT% An illegal format type was specified in the
process descriptor block.
5 NSCFE% The connect block was formatted incorrectly.
6 NSIDL% Interrupt data block pointed to a string block
that was too long.
7 NSIFM% Illegal flow control.
10 NSILF% Illegal function code specified.
11 NSJQX% Job quota exhausted.
12 NSLQX% Link quota exhausted.
13 NSNCD% No connect data to read.
14 NSPIO% Percentage input out of bounds.
15 NSPRV% Insufficient privileges to perform specified
function.
16 NSSTB% Segment size too big.
17 NSUKN% Unknown node name was specified.
20 NSUXS% Unexpected or unspecified state.
21 NSWNA% Wrong number of arguments.
22 NSWRS% Function call while connected in wrong state.
23 NSCBL% Wrong length for connect block.
22-306
NSP. [CALLI 205]
Code Symbol Error
24 NSPBL% Wrong length for process block.
25 NSSBL% Wrong length for string block.
26 NSUDS% Unexpected state: disconnect sent.
27 NSUDC% Unexpected state: disconnect confirmed.
30 NSUCF% Unexpected state: no confidence.
31 NSULK% Unexpected state: no link.
32 NSUCM% Unexpected state: no communication.
33 NSUNR% Unexpected state: no resources.
NSP. error codes 34 to 56 correspond to DECnet disconnect codes.
34 NSRBO% Rejected by object.
35 NSDBO% Disconnected by object when running.
36 NSRES% No resources.
37 NSUNN% Unrecognized node name.
40 NSRNS% Remote node shut down.
41 NSURO% Unrecognized object.
42 NSIOF% Invalid object name format.
43 NSOTB% Object too busy.
44 NSABM% Abort by management.
45 NSABO% Abort by object.
46 NSINF% Invalid node name format.
47 NSLNS% Local node shut down.
50 NSACR% Access control rejection.
51 NSNRO% No response from object.
52 NSNUR% Node unreachable.
53 NSNLK% No link.
54 NSDSC% Disconnect complete.
55 NSIMG% Image field too long.
56 NSREJ% Reason for rejection was not specified.
57 NSBCF% Invalid combination of NS.EOM and NS.WAI flags.
60 NSADE% Address error.
22-307
NTMAN. [CALLI 206]
NTMAN. [CALLI 206]
Function
Performs various functions for the network managment layer of the
DECnet-10 network product. This call is used only by the NML
program and is not intended for use by customer programs. The
NTMAN. call is common to both DECnet-10 and DECnet-20 products,
and therefore may change at any time without notice. This call
requires JACCT, [1,2], or JP.POK privileges.
Calling Sequence
MOVEI ac,addr
NTMAN. ac,
error return
normal return
. . .
addr: len
entity
ptr to entity-id
fcn-code
info-type
EXP 0
ptr to data
len of data
BLOCK 1
where addr is the address of the argument block, which is
formatted as:
Word Symbol Contents
0 .NTCNT The number of words in the argument block (len).
1 .NTENT The entity on which the action is to be
performed. The types of entities are:
Code Symbol Meaning
0 .NTNOD Network node.
1 .NTLIN Communications line.
2 .NTLOG Reserved for DIGITAL use.
3 .NTCKT Circuit.
2 .NTEID A byte pointer to an entity identification. The
byte pointer must point to a node number, line
number, or circuit number.
22-308
NTMAN. [CALLI 206]
Word Symbol Contents
3 .NTFCN Contains the function code. The function codes
are:
Code Symbol Function
-2 .NTMAP Returns node number for node
name, or node name for node
number.
-1 .NTREX Returns the node-id of the local
node.
0 .NTSET Sets a parameter.
1 .NTCLR Clears a parameter.
2 .NTZRO Zeroes counters.
3 .NTSHO Shows selected items.
4 .NTSZC Shows and zeroes counters.
5 .NTRET Returns a list of entities.
6 .NTEVQ Removes an item from the event
queue.
4 .NTSEL Selection criteria for function. The following
allow you to select the item on which the
function is to be performed:
Code Symbol Meaning
-3 to -1 Used by .NTRET:
-3 .NTLOP Loop.
-2 .NTACT Active items.
-1 .NTKNO Known items.
0 to 4 Used by .NTSHO:
0 .NTSUM Summary.
1 .NTSTA Status.
22-309
NTMAN. [CALLI 206]
Word Symbol Contents
Code Symbol Meaning
2 .NTCHA Characteristics.
3 .NTCOU Counters.
4 .NTEVT Reserved for DIGITAL use.
5 .NTQUA Reserved for DIGITAL use.
6 .NTBPT Byte pointer to data.
7 .NTBYT Byte count for data.
10 .NTERR Returned information or error code.
11 .NTMAX Quantity to place in .NTCNT.
Normal Return
The requested information is returned in the address pointed to
by .NTERR, or data is changed according to the function code. On
a successful return, error code 1 (NESUC%) is returned in .NTERR.
Error Return
The error code is returned in the ac and in the .NTERR offset
into the argument block. Note that a successful return from the
call places error code 1 (NESUC%) into the offset .NTERR into the
argument block, and error NEADC% is returned only in the ac. The
error codes for NTMAN. are defined with decimal values and are:
Code Symbol Error
1 NESUC% Successful call.
-1 NEUFO% Invalid function or option.
-2 NEIMF% Invalid message format.
-3 NEPRV% Insufficient privileges.
-4 Reserved for use by DIGITAL
-5 NEMPE% Management program error.
-6 NEUPT% Invalid parameter.
-7 Reserved for use by DIGITAL
-8 NEURC% Invalid entity.
-9 NTINI% Invalid entity identifier.
-10 NELCE% Line communication error.
-11 NECWS% Component in wrong state.
-12 to -14 Reserved for use by DIGITAL.
-15 NERES% Resource error.
-16 NEIPV% Invalid parameter value.
-17 to -19 Reserved for use by DIGITAL.
22-310
NTMAN. [CALLI 206]
Code Symbol Error
-20 NENRM% No room, or slot already taken.
-21 Reserved for use by DIGITAL.
-22 NEPNA% Parameter not applicable to entity.
-23 NEPVL% Parameter value too long.
-24 Reserved for use by DIGITAL.
-25 NEOPF% Operational failure.
-26 NEFNS% Function not supported.
-27 NEIPG% Invalid parameter grouping.
-28 Reserved for use by DIGITAL.
-29 NEPAM% Parameter missing from argument list.
-30 to -46 Reserved for use by DIGITAL.
-47 NEADC% Address check (returned in ac only).
22-311
OPEN [OPCODE 050]
OPEN [OPCODE 050]
Function
Initializes a channel for I/O operation. Use FILOP. to assign an
extended I/O channel.
Calling Sequence
OPEN channo,addr
error return
normal return
. . .
addr: argument list
Where: channo is the number of a channel.
addr is the address of the argument list. The argument
list is:
Word Symbol Contents
0 .OPMOD Flags and status bits. The I/O status bits are
a set of 18 bits (right halfword) that reflect
the current state of a file transmission. They
are initially set by your program with the OPEN
monitor call. Thereafter, the monitor sets the
bits, but your program can test and reset them
using any of several monitor calls.
Bits Symbol Meaning
0 UU.PHS Only physical device names will
be used in the search. All
logical names defined by the
job will be ignored.
1 UU.DEL Disables error logging; only
user-mode diagnostic programs
may set this bit.
1 UU.FSP Specifies a full SCNSER PTY
(pseudo-terminal). That is,
all terminal characteristics
that are normally ignored for
PTYs will be set and enforced.
Refer to Chapter 15.
2 UU.DER Disables error retry; only
user-mode diagnostic programs
may set this bit.
22-312
OPEN [OPCODE 050]
Bits Symbol Meaning
2 UU.BJP If the given device is a PTY,
and if the calling program is
privileged, this bit specifies
that jobs logging on this PTY
are to be treated as batch
jobs.
2 UU.DMR Disables message re-assembly.
This bit is used in ANF-10
intertask communication to
allow the receipt of messages
that do not have the EOM bit
set. This flag should be set
if UU.AIO is set for TSK
devices. (Refer to Chapter 5.)
3 UU.AIO I/O is nonblocking. This
prevents the monitor from
stopping your job to wait for
I/O to be completed.
4 UU.IBC Disables clearing of buffers
after each output. Your
program must also set BF.IBC in
the .BFADR word of the buffer
ring header. (This is
applicable to buffered I/O
only. Refer to Chapter 11.)
5 UU.SOE Enables synchronization on each
I/O error. The monitor does
not perform more I/O until your
program clears the error bits.
6 UU.RRC Enables automatic rewrite of
RIB on change. This bit
pertains only to disk devices,
causing the monitor to rewrite
the file's RIB whenever a
change to the file requires it.
This is used to ensure file
integrity in the event of
system failure.
7 UU.LBF Allows the use of large buffers
(multiples of one block) for
disk I/O on this channel.
8-14 UU.DEC Reserved for use by DIGITAL.
15-17 UU.CUS Reserved for use by customers.
22-313
OPEN [OPCODE 050]
Bits Symbol Meaning
18-21 IO.ERR Error flags:
Flag Symbol Error
18 IO.IMP Improper mode flag.
19 IO.DER Error detected by
device.
20 IO.DTE Hard data error.
21 IO.BKT Block too large.
22 IO.EOF End-of-file reached.
23 IO.ACT I/O active.
24-29 Device-dependent flags (some
flags are repeated for
different devices). Refer to
the appropriate device chapter
in Volume 1 for more
information.
Flag Symbol Meaning
24 IO.BOT Beginning of tape
encountered (magtape
only).
24 IO.PTI Subjob is in terminal
input wait state (PTY
only).
25 IO.EOT End of tape encountered
(magtape only).
25 IO.PTO Subjob is in terminal
output wait state (PTY
only).
25 IO.ABS Enable user break mask
(terminals only).
26 IO.PAR Parity of tape, where
IO.PAR=1 for even
parity. Odd parity
(IO.PAR=0) is used only
for EBCDIC labelled
tapes (magtape only).
26 IO.PTM Subjob is in monitor
mode (PTY only).
22-314
OPEN [OPCODE 050]
Flag Symbol Meaning
26 IO.BKA Break on all characters
(terminals only).
27 IO.TEC Truth in echoing mode
(terminals only).
27 IO.MAI Maintenance DMR mode
(KDP and DTE devices
only).
27-28 IO.DEN Bit mask for tape
density, where:
0 = standard
1 = 200
2 = 556
3 = 800
For densities of 1600
and 6250, IO.DEN=0
(magtape only). This
flag is obsolete. Use
TAPOP. to set tape
density.
28 IO.SSD Semi-standard data mode
(DECtape devices only).
28 IO.SUP Suppress echoing
(terminals only).
29 IO.D29 DEC029 mode (card punch
only).
29 IO.SIM Super-image mode (card
reader only).
29 IO.WHD Write disk-pack headers
(disk only).
29 IO.NSD Non-standard data mode
(DECtape devices only).
29 IO.SFF Suppress form feeds
(line printers only).
29 IO.NRC Read with no reread
check (magtape only).
29 IO.FCS Obsolete (terminals
only).
29 IO.LEM Line editor mode
(terminals only).
22-315
OPEN [OPCODE 050]
Bits Symbol Meaning
30 IO.SYN Synchronous input.
31 IO.UWC Uses user word count. By
default this bit is not set,
and the monitor computes the
amount of data to be
transmitted using the byte
pointer in the buffer header.
If this flag is set, however,
the monitor uses the byte
count. Meaningful for output
only.
32-35 IO.MOD Data mode. In general, modes
0-14 are considered "buffered
I/O modes" and modes 15-17 are
"dump I/O modes." The possible
values for the data mode
(IO.MOD) in .OPMOD are:
Value Symbol Meaning
0 .IOASC ASCII mode (for any
device except display).
1 .IOASL ASCII line mode (for any
device except display).
2 .IOPIM Packed image mode
(terminal only).
3 .IOBYT Byte mode (magtape
device only).
4 .IOAS8 8-bit ASCII mode
(terminal,
pseudo-terminal, and
line printers only).
5 Reserved for use by
DIGITAL.
6-7 Reserved for use by
customers.
10 .IOIMG Image mode (for any
except display device).
11-12 Reserved for use by
DIGITAL.
22-316
OPEN [OPCODE 050]
Word Symbol Contents
Value Symbol Meaning
13 .IOIBN Image binary mode (for
disk, DECtape, magtape,
plotter, card device, or
papertape device).
14 .IOBIN Binary mode (for same
devices as .IOIBN).
15 .IOIDP Image dump mode (for
display devices only).
16 .IODPR Dump record mode (for
disk, DECtape, or
magtape devices).
17 .IODMP Dump mode (for disk,
DECtape, or magtape
devices).
1 .OPDEV SIXBIT physical or logical name or UDX of the
device to be initialized on the channel or UDX.
2 .OPBUF Buffer addresses (used for buffered I/O only):
Bits Meaning
0-17 Address of the control block for the
output buffers for the given channel.
If buffered I/O is not to be used,
specify 0 for the buffer control block
address.
18-35 Address of the control block for the
input buffers for the given channel. If
buffered I/O is not to be used, specify
0 for the buffer control block address.
Normal Return
The specified channel is initialized.
Error Return
The monitor takes the error return if the specified device is in
use, if the device does not exist, or if the device is
restricted. To assign a restricted device, use the MOUNT monitor
command before running the program, or use the .QUMNT function of
the QUEUE. call.
22-317
OPEN [OPCODE 050]
Examples
;Subroutine to OPEN the disk in dump mode
;Call with:
; PUSHJ P,DMPINI
; RETURN HERE
DMPINI: OPEN DSK,OPNBLK ;OPEN the disk on channel "DSK"
JRST NOTAVL ;Device is busy
ENTER DSK,FILE ;Create a new file
JRST FILBAD ;Cannot ENTER file name in
; disk directory.
POPJ P, ;Return - file is now open for
; Dump mode output.
;Here if device DSK: cannot be OPENed
NOTAVL: OUTSTR [ASCIZ "?CANNOT OPEN DSK:
"] ;Print an error message
EXIT ;Return to the monitor
;Here if file cannot be created
FILBAD: OUTSTR [ASCIZ "?CANNOT CREATE DSK:DUMP.BIN
"] ;Print an error message
EXIT ;Return to the monitor
OPNBLK: EXP .IODMP ;Select dump mode
SIXBIT /DSK/ ;Device name
EXP 0 ;No buffers
FILE: SIXBIT /DUMP/ ;File name
SIXBIT /BIN/ ;File name extension
EXP 0 ;Default protection
EXP 0 ;Default directory
;Subroutine to write data in buffer
;Call with:
; FILL BUFFER WITH DATA
; PUSHJ P,DMPOUT
; RETURN HERE
DMPOUT: OUT DSK,OUTLST ;Write data
POPJ P, ;No errors - Return to caller
OUTSTR [ASCIZ "?OUTPUT ERROR FOR DSK:DUMP.BIN
"] ;Output error message
EXIT ;Return to monitor
;Command list for output
OUTLST: IOWD BUFSIZ,BUFFER ;Write BUFSIZ words from buffer
EXP 0 ;End of command list
22-318
OPEN [OPCODE 050]
BUFFER: BLOCK BUFSIZ ;Output buffer
;Subroutine to close out file
;Call with:
; PUSHJ P,DMPDON
; RETURN HERE
;
DMPDON: CLOSE DSK, ;Write the end of file
STATO DSK,IO.ERR ;Are there any errors?
POPJ P, ;No-return
OUTSTR [ASCIZ "?ERROR CLOSING DSK:DUMP.BIN
"] ;Print error message
EXIT ;Return to the monitor
Related Calls
FILOP., INIT
22-319
OTHUSR [CALLI 77]
OTHUSR [CALLI 77]
Function
Determines whether other jobs are logged in under your
project-programmer number (PPN).
Calling Sequence
OTHUSR ac,
alternate return
normal return
Normal Return
The ac contains your project-programmer number; the normal return
occurs only if there are other jobs logged in under your
project-programmer number.
Alternate Return
The alternate return is taken if no other jobs are logged in
under your project-programmer number.
Examples
OTHUSR T1,
JRST ONLY1
If other jobs are logged in under your project-programmer number,
execution continues. If not, control is passed to ONLY1.
22-320
OUT [OPCODE 057]
OUT [OPCODE 057]
Function
Transmits data from your job's physical memory area to the file
selected for the given channel. Use FILOP. to perform an OUT UUO
on an extended I/O channel.
Calling Sequence
OUT channo,addr
normal return
error return
Where: channo is the number of an initialized channel.
In buffered mode, addr contains the address of the .BFHDR
(header) word of the buffer to be used. If you give addr
as 0, the next buffer is used.
In dump mode, addr is the address of the first word of
the command list. See IN call.
Normal Return
The data in the buffer at addr+1 is transferred.
Error Return
If an error occurs, you should examine the I/O status bits to
determine the cause of the error. Use the GETSTS call to obtain
I/O status bits.
NOTE
If, while using non-blocking I/O, your program
takes the error return with no error bits set,
that indicates you have exhausted all of the
output buffers. You must wait until a buffer
becomes available. The program at this point
should not attempt to store any more data based
on the state of the use bit. Instead, keep
trying the OUT call until it succeeds.
Examples
See Chapter 11.
22-321
OUT [OPCODE 057]
Related Calls
FILOP., IN, INPUT, OUTPUT
Common Error
o If the specified address is illegal, the monitor stops the
job and prints:
?Address check for device YYYYYY:;UUO at user PC xxxxx
o Failure to supply a command list address in dump mode.
o Forgetting to initialize the channel.
22-322
OUTBUF [OPCODE 065]
OUTBUF [OPCODE 065]
Function
Sets up an output buffer ring with the specified number of
buffers for the specified initialized channel. Use FILOP. to
perform an OUTBUF for an extended I/O channel.
NOTE
The monitor allocates buffers in the user's
address space starting at the location pointed to
by the contents of .JBFF. This has no meaning in
a non-zero section, unless that section is mapped
to section 0. Use the FILOP. monitor call to
specify buffer starting addresses in a non-zero
section.
Calling Sequence
OUTBUF channo,bufcnt
return
Where: channo is the number of an initialized channel.
bufcnt is the number of buffers to set up in the ring.
If you give buffers as 0, the monitor uses its default
number of buffers for the ring. This default varies
according to the device. For disks, the number of
buffers is a MONGEN parameter that can also be set with
the SET DEFAULT BUFFERS monitor command.
Return
The buffer ring is set up.
Related Calls
FILOP., INBUF
Common Errors
See the INBUF call for some common errors and their explanations.
22-323
OUTCHR [TTCALL 1,]
OUTCHR [TTCALL 1,]
Function
Sends an ASCII character to the job's controlling terminal.
Calling Sequence
OUTCHR location
return
Where: location is the address of the word containing the output
character; the ASCII code for the character is taken from
bits 29-35 of location.
Return
The monitor takes an ASCII code from bits 29-35 of location and
displays the character on the user terminal.
Related Calls
OUTSTR, TRMOP.
Common Errors
o Typing a comma after location.
o Assuming OUTCHR takes an immediate value in the effective
address field.
22-324
OUTPUT [OPCODE 067]
OUTPUT [OPCODE 067]
Function
Sends data from memory to an initialized channel. Use FILOP. to
perform an OUTPUT for an extended I/O channel. The OUTPUT
monitor call is the same as the OUT monitor call, except that OUT
takes the error return if any error bits are set in the I/O
status word, and OUTPUT ignores the error bits and has only one
return location.
Calling Sequence
OUTPUT channo,addr
return
Where: channo is the number of an initialized channel.
addr is one of the following:
o If the channel was initialized for dump mode, then
addr is the address of an I/O command list.
o If the channel was initialized for buffered mode,
then addr is the address of the second word of the
next buffer to be used; if you give 0 (the normal
case), the next buffer in the ring is used.
Return
Data is output to the device on the channel.
Related Calls
FILOP., IN, INPUT, OUT
Common Errors
Same as IN call.
22-325
OUTSTR [TTCALL 3,]
OUTSTR [TTCALL 3,]
Function
Sends an ASCIZ string to the user terminal.
Calling Sequence
OUTSTR addr
return
. . .
addr: ASCIZ/string/
Where: addr is the address of the ASCIZ string to be displayed
on the terminal and string is the string to be sent.
Return
The string is displayed on the user terminal.
Examples
See OPEN call.
Related Calls
OUTCHR, TRMOP.
Common Errors
Typing a comma after addr.
22-326
PAGE. [CALLI 145]
PAGE. [CALLI 145]
Function
Manipulates pages and the data associated with those pages in
your job's address space.
Calling Sequence
MOVE ac,[XWD fcncode,addr]
PAGE. ac,
error return
normal return
. . .
addr: len
first argument
. . .
last argument
where: fcncode is one of the function codes described below.
addr is the address of the argument list.
len is the number of words that follow in the argument
list; and the words up through last argument are
arguments for the given function, usually page numbers of
memory pages being manipulated. The value of len must be
greater than 2 or the negative of a value greater than 2.
The len can be specified as a negative value. In this
case, only one argument follows. That argument is the
page number of the first page in a set, where the set
contains that page plus the number of consecutive pages
indicated by the value. For example, when len contains a
negative value (such as -3), the argument (for example,
page number 401), is the first of 3 consecutive pages
(for this example, pages 401, 402, and 403), to be
manipulated.
22-327
PAGE. [CALLI 145]
The pages you can specify are restricted by the following
attributes:
o Page zero cannot be paged out or destroyed.
|
| o Page numbers must be specified in numerically
| increasing order.
o If the high segment is sharable, it cannot be paged
out.
o If the page is a SPY page, it cannot be paged out.
o If a page is locked in core, it cannot be paged out.
The function codes and their meanings are:
Code Symbol Function
0 .PAGIO Swaps a page in or out. Pages swapped in are
added to the working set; pages swapped out are
moved to secondary storage.
Use one word in the argument list for each page
to be swapped, or specify a negative list length
to specify a set of consecutive pages. If you
use more than one argument word, the page
numbers must be in ascending order. Each
argument word is in the form:
XWD flags,pageno
where: pageno is the number of the page to be
swapped (in the range 0-511 on a KS, or 0-16383
on a KL) and flags is one or both of the
following:
Bit Symbol Meaning
0 PA.GAF Swap the page out if this bit
is set; swap it in if not set.
1 PA.GSL Swap to slow swapping space if
this bit is set; swap to fast
space if not set.
2 PA.GDC Suppresses error codes PAGCE%,
PAGME%, PAGSC%, and PAGSM%.
22-328
PAGE. [CALLI 145]
Code Symbol Function
1 .PAGCD Creates or destroys a specified page. Use one
argument word for each page to be created or
destroyed. If you use more than one word, the
specified pages must be in ascending order.
Each argument word is of the form:
XWD flags,pageno
where: pageno specifies the number of the page
(in the range 0-511 on a KS, or 0-16383 on a KL)
to be created or destroyed and flags is one or
both of the following:
Bit Symbol Meaning
0 PA.GAF Destroy the page if this bit is
set; create the page if this
bit is not set.
1 PA.GCD Create the page on disk if this
bit is set; create a page in
the working set if this bit is
not set.
2 .PAGEM Moves or exchanges a page. The page is moved
from one virtual address to another, or two
pages exchange locations. You cannot move a
page to a location that is allocated to another
page and you cannot exchange pages unless the
source pages are allocated.
Use one argument word for each page to be moved
or exchanged. If you use more than one argument
word, the specified pages must be in ascending
order. Each argument word is of the form:
<flag>+<source>B17+<destination>B35
where: source is the page number of the page to
be moved, destination is the page number of the
location to receive the page, and the following
flag can be set:
Flag Symbol Meaning
0 PA.GAF Exchange the pages if this bit
is set; move the source page if
this bit is not set.
22-329
PAGE. [CALLI 145]
Code Symbol Function
3 .PAGAA Sets or clears the access-allowed bit for a
page. The access-allowed bit may be changed for
any page in the working set. If a page is
accessed that has this bit off, a page fault
occurs.
Use one argument word for each page whose
access-allowed bit is to be changed. If you use
more than one argument, the specified pages must
be in ascending order. Each argument word is of
the form:
XWD flags,pageno
where: pageno is the page number of the page
whose bit is to be changed, and flag is one or
more of the following:
Flag Symbol Meaning
0 PA.GAF Clear access-allowed for the
page if this bit is set; set
access-allowed if this bit is
not set.
1 PA.GSA Automatically sets
access-allowed on page fault;
dispatch to page handler on
page fault if this bit is not
set.
2 PA.GDC Ignores fact that page does not
exist, suppressing error code
PAGME%.
4 .PAGWS This function returns a bit map of those pages
in the current working set. In the PAGE. call,
you specify the number of words that are to be
returned. There is one bit for each possible
page. If a bit is set, the page associated with
that bit is a part of the working set. For
example, Word 1 contains the bits associated
with pages 0 through 35; Word 2 contains the
bits associated with pages 36 through 71, and so
on. The end of the bit map does not end on an
integral word boundary, so the last word in the
map is padded with zeroes. The bit map for
another section begins on a new word.
22-330
PAGE. [CALLI 145]
Code Symbol Function
5 .PAGGA Returns a bit map indicating which pages have
their access-allowed bits set. This bit map has
the same format as the one returned for function
code 4 (.PAGWS). If a bit in the map is set,
the page associated with that bit is accessible.
In the PAGE. monitor call, you specify the
number of words in the bit map that are to be
returned.
6 .PAGCA Determines the type of access allowed for a
given page. There is no argument block;
instead, you specify the function code in the
left half of the ac (bits 0-17) and the page
number in the right half of the ac (bits 18-35):
[function,,page-number]. On a normal return,
the monitor will set one or more of the bits
listed below:
Bits Symbol Meaning
0 PA.GNE Page does not exist.
1 PA.GWR Writable page.
2 PA.GRD Readable page.
3 PA.GAA Access allowed.
4 PA.GAZ Allocated page, but zero.
5 PA.GCP Page cannot be paged out.
6 PA.GPO Page is paged out.
7 PA.GHI Page is in high segment.
8 PA.GSH Page is sharable.
9 PA.GSP Page is SPYing (mapped onto
running monitor).
10 PA.GLK Page is locked in memory.
11 PA.GNC Page is not cached (KL10 and
KS10 only).
12 PA.GSN Section does not exist.
13 PA.GVR Page is virtual (SPY page).
14 PA.GIN Page is in an indirect section,
that is, a section mapped onto
another section.
15 Reserved for use by DIGITAL.
16-20 PA.GSC Section is independent, that
is, a section that another
section is mapped onto. PA.GIN
must be set for PA.GSC to be
set.
21 Reserved for use by DIGITAL.
22-35 PA.GPN Page number of the SPY page
which the specified user page
is SPYing on.
22-331
PAGE. [CALLI 145]
Code Symbol Function
7 .PAGCH Changes the pages in a high segment, or creates
a high segment from a contiguous collection of
pages. The argument block is written in the
following format:
addr: Number of words following.
addr+1: Number of pages to be remapped.
addr+2: Start page number.
addr+3: Destination page number.
addr+3 is an optional word of the argument
block. If not specified, page 400 is assumed.
This function waits for all I/O to stop before
creating the high segment. On a normal return,
the specified pages are REMAPped into the high
segment, which begins at destination page
number. The error return is taken if all of the
pages specified by start page number and number
of pages to be remapped do not exist, or if a
page included in the list already exists in your
program's address space. If the number of pages
specified is negative, those pages are remapped
from the low segment to the high segment, and
appended to the existing hi-seg.
Note that a sharable high segment cannot be
created or affected with this function code. If
only one argument is given, the number of pages
specified is deleted from the end of the high
segment.
10 .PAGCB Sets or clears the cache bit for the page.
(This flag is automatically set if PA.GAF is
on.) This function sets or clears the cache bit
on a per-page basis (KL10 and KS10 only). The
argument word format is as follows:
Bit 0 If this bit, PA.GAF, is set, the
cache bit is set in the
corresponding entry in the job's
page map. If clear, the cache bit
is clear.
Bit 1 Reserved.
Bit 2 This bit, PA.GDC, ignores the fact
that a page doesn't exist,
suppressing error code PAGME%.
Bits 3-26 Reserved.
Bits 27-35 The page number.
If there is more than one argument word in the
argument block, the page numbers specified in
those words must be in ascending numeric order.
22-332
PAGE. [CALLI 145]
Code Symbol Function
The error return is taken if any of the
following are true:
o The function or call is not implemented.
o A high segment page is specified in the
argument list.
o The argument list is not set up properly.
o The job is not locked in core.
11 .PAGSP Allows your program to map an arbitrary set of
pages from memory or from the monitor's virtual
address space into the program's address space.
Use one argument word for each page to be
mapped. If you use more than one argument word,
you must specify the pages in ascending order.
The argument word is formatted as follows:
<flags>+<source>B17+<destination>B35
where flags are one or more of the following:
Bit Symbol Meaning
0 PA.GAF Remove the page from the user's
addressing space. If not set,
add the monitor page to the
user's addressing space at the
specified page number.
2 PA.GDC On a create, this bit will
overlay an already existing
page. On a delete, if the page
does not exist, it is ignored
and error code PAGME% is
suppressed.
source is the page number of the source page.
If UU.PHY is set in the PAGE. monitor call
itself, source is a physical page in memory. If
UU.PHY is not set, source is a monitor virtual
address mapped through the executive page map.
destination is the page number of the page to be
mapped into your address space.
This function requires that the calling job have
PEEK privileges on all of core.
22-333
PAGE. [CALLI 145]
Code Symbol Function
12 .PAGSC Creates or destroys a specified section. Use
one argument word for each section to be created
or destroyed. For more than one word, the
sections or arguments must be specified in
ascending order. Each argument word is of the
form:
XWD <flag>+<source>B17+<destination>B35
where flag is one of the following:
Bits Symbol Meaning
0 PA.GSF Delete the section if this bit
is on, create the section if
this bit is off.
1 PA.GMS On a create, map the sections
specified in PA.GSS and PA.GDS
together.
2 PA.GDC On a create, any existing
section is emptied. On a
delete, ignore a non-existant
section.
If PA.GMS is set, give the source and
destination sections using the following format:
Bits Symbol Meaning
4-17 PA.GSS The section number of the
source section.
18-22 Reserved for use by DIGITAL.
22-35 PA.GDS The section number of the
destination section.
22-334
PAGE. [CALLI 145]
Code Symbol Function
13 .PAGBM Returns a bit map that indicates whether
specified page accessibility attributes belong
to a certain page. If, in the return, the bit
map is set on, the page has the specified
attributes.
Each argument word is of the form:
EXP count
EXP attribute-settings
EXP care-mask
EXP starting-page-no
where:
count is the number of arguments.
attribute-settings is the word indicating the
desired state of the given attribute. The page
accessibility attribute bits are the same as
those given for .PAGCA.
care-mask is the word specifying which bits of
the attribute-settings word should be examined.
Note that PA.GSC, the independent section bit,
is checked only when PA.GIN is turned on in both
.PAGCA and in the care mask in .PAGBM.
Likewise, PA.GPN, the SPY page number, is
checked only when PA.GSP is on in .PAGCA and the
care mask in .PAGBM.
starting-page-no specifies the page number of
the page that is mapped to bit 0 of the mask.
14 .PAGAL Determines the type of access allowed for a
given page. The argument block is:
EXP count
EXP starting-page
where:
count is the number of arguments.
starting-page is the starting page of the area
in which information is to be returned. The
bits returned are the same as for .PAGCA.
22-335
PAGE. [CALLI 145]
Normal Return
The specified function has been performed; the ac is unchanged.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 PAGUF% Function not implemented.
1 PAGIA% Illegal argument.
2 PAGIP% Illegal page number.
3 PAGCE% Page should not exist, but does.
4 PAGME% Page should exist, but does not.
5 PAGMI% Page should be in core, but is not.
6 PAGCI% Page should not be in core, but is.
7 PAGSH% Page is in sharable high segment.
10 PAGIO% Paging I/O error.
11 PAGNS% No swapping space available.
12 PAGLE% Core limit exceeded.
13 PAGIL% Function illegal if page locked.
14 PAGNX% Cannot allocate zero page with virtual limit
zero.
15 PAGNP% Not enough privileges.
16 PAGSC% Section should not exist, but does.
17 PAGSM% Section should exist, but does not.
20 PAGIS% Illegal section.
22-336
PATH. [CALLI 110]
PATH. [CALLI 110]
Function
Sets or reads a user's default directory path, reads the default
directory path for a device or channel, or sets or reads
pathological device name definitions. A pathological device name
is a logical name defining a directory search path in the form:
dev:file.ext[UFD,SFD1,SFD2,...SFD5].
Refer to Section 12.6.5 for more information.
Calling Sequence
MOVE ac,[XWD len,addr]
PATH. ac,
error return
normal return
. . .
addr: argument list
where: len is the length of the argument list. The value in
this word must be at least 3. If you specify 0, the
length defaults to 3.
addr is the address of the argument list.
There are two types of argument blocks for the PATH. monitor
call. Type 1 is used for reading and setting default directory
paths for users, channels, or devices. Type 2 is used for
reading or defining pathological names.
Argument Block Type 1
Argument Block Type 1 is used for reading and setting default
directory paths for users, channels, or devices. This argument
type is used for all functions (specified in .PTFCN), except
functions -6 and -5 (.PTFRN and .PTFSN). The function codes are
listed below.
Offset Symbol Contents
0 .PTFCN A SIXBIT device name; or a job number in the
left half and a function code or channel number
in the right half.
If you specify a device name, the monitor
returns the default path for that device.
22-337
PATH. [CALLI 110]
Offset Symbol Contents
If you specify a job number and function code,
or a job number and channel number, the word is
formatted as follows:
Bits Symbol Contents
0-17 PT.JBN Job number. This job number
defaults to your job number if
not in the range of 1 to the
highest legal job number.
18-35 PT.FCN Function code or channel number.
The function codes and their
meanings are listed below.
If you specify a channel number
instead of a function code, the
monitor returns the default path
for the device currently open on
that channel. If accessing a
file that is open on the
specified channel, the monitor
returns the actual path for the
file.
The function codes are:
Code Symbol Function
-6 .PTFRN Reads a
pathological
name. Refer to
Argument Block
Type 2.
-5 .PTFSN Sets a
pathological
name. Refer to
Argument Block
Type 2.
22-338
PATH. [CALLI 110]
Code Symbol Function
-4 .PTFRL Returns an
additional path
to be searched
when a file is
not in your
directory path.
(For example,
the monitor
returns SYS,
NEW, or LIB, if
appropriate.
See word .PTSWT
below.)
-3 .PTFSL Sets an
additional path
to be searched
when a file is
not found in
your directory
path. (See
.PTFRL.) When
you specify this
function code,
you must supply
the following
words in the
argument block:
.PTFCN
.PTSWT
.PTPPN
-2 .PTFSD Sets the default
path to search
if no path is
specified.
-1 .PTFRD Reads the
default path
that is searched
if no path is
specified.
22-339
PATH. [CALLI 110]
Offset Symbol Contents
1 .PTSWT Flags. The flags are only applicable to
specific functions. All flags apply if you
specify a device name or channel number in the
previous word (.PTFCN).
Bits Symbol Meaning
|
| 25 PT.EDA Returned to indicate that the
| device or channel number was
| both a pathological name and an
| ersatz device name. This flag
| is ignored for all functions
| that set the path.
26 PT.DLN Returned to indicate that the
device or channel specified in
.PTFCN is a pathological name.
Therefore, this flag is
applicable only when a device or
channel number is specified in
.PTFCN.
29 PT.SLT Returned to indicate the type of
search list associated with a
device or channel. The search
list types are:
Code Symbol Type
0 .PTSLN No search list
has been
associated with
the specified
device or
channel.
1 .PTSLJ Job search list.
2 .PTSLA ALL search list.
3 .PTSLS SYS search list.
.PTSLS is
applicable only
when a device
name or channel
number is
specified in
.PTFCN.
22-340
PATH. [CALLI 110]
Bits Symbol Meaning
30 PT.IPP Returned to indicate that the
device specified in .PTFCN has
an implied PPN, as in the case
of an ersatz device name. The
implied PPN is returned in the
following word, .PTPPN.
30 PT.DTL Set to prevent any change to the
status of LIB, allowing changes
to NEW and SYS without changing
LIB. This flag is useful only
for function code .PTFSL.
31 PT.LIB Returned to indicate that LIB
(if defined for your job) will
be searched on each structure in
your job search list, after your
default path for each structure
in the job search list has been
exhausted in the attempt to find
a file. The LIB ersatz device
name can be defined using
function .PTFSL, or by setting
flag PT.SEA in the LIB
pathological name definition
using function .PTFRN.
32 PT.NEW Returned to indicate that, when
SYS is specified or implied, the
NEW area [1,5] will be searched
before the SYS area [1,4].
33 PT.SYS Returned to indicate that SYS
(ersatz device name for [1,4])
will be searched on each
structure in your job search
list after your default path to
each structure in the search
list has been exhausted in the
attempt to find a file.
22-341
PATH. [CALLI 110]
Bits Symbol Meaning
34-35 PT.SCN Controls searching of
higher-level directories.
(Similar to /SCAN switch to
SETSRC program, but overrides
the setting of /SCAN.) The
values of this field can be 0
(use same scanning status as
before the PATH. call), or one
of the following:
Value Symbol Switch Setting
0 Use default
setting.
1 .PTSCN Turns scanning
off.
2 .PTSCY Turns scanning
on.
The scanning status is returned
if you specify a device or
channel number in .PTFCN, or if
you use function .PTFRD. The
status is set using function
.PTFSD. These bits are checked
when the path block is given for
LOOKUP, GETSEG, RUN, MERGE., and
FILOP. calls.
34 PT.SNW Set to indicate that NEW (ersatz
device name for [1,5]) will be
searched before [1,4] whenever
SYS is specified or implied.
35 PT.SSY Returned to indicate that SYS
(ersatz device name for [1,4])
will be searched on each
structure in your job search
list after your default path to
each structure in the search
list has been exhausted in the
attempt to find a file.
22-342
PATH. [CALLI 110]
Table 22-1 lists the information that can be stored in .PTFCN and
indicates the flags in .PTSWT that apply to each of the functions
.PTFRD, .PTFSD, .PTFSL, and .PTFRL:
Table 22-1: PATH. Functions and Flags
|
| +-----------------------------------------------------------+
| | | | Functions |
| | | Device |------------------------------------+
| |Flag | or Channel | .PTFRD | .PTFSD | .PTFSL | .PTFRL |
| +-----------------------------------------------------------+
| |PT.EDA | X | | | | |
| |-----------------------------------------------------------|
| |PT.DLN | X | | | | |
| |-----------------------------------------------------------|
| |PT.SLT | X | | | | |
| |-----------------------------------------------------------|
| |PI.IPP | X | | | | |
| |-----------------------------------------------------------|
| |PT.DTL | | | | X | |
| |-----------------------------------------------------------|
| |PT.LIB | X | X | | | |
| |-----------------------------------------------------------|
| |PT.NEW | X | X | | | |
| |-----------------------------------------------------------|
| |PT.SYS | X | X | | | |
| |-----------------------------------------------------------|
| |PT.SCN | X | X | X | | |
| |-----------------------------------------------------------|
| |PT.SNW | | | | X | X |
| |-----------------------------------------------------------|
| |PT.SSY | | | | X | X |
| +-----------------------------------------------------------+
22-343
PATH. [CALLI 110]
Offset Symbol Contents
2 .PTPPN The PPN (UFD) of the path. For function .PTFRL,
the library PPN, if any, is returned here. For
function .PTFSL, the library PPN is set from
this word unless PT.DTL is set in .PTSWT.
3 .PTSFD The first level of SFD, as the SFD name, stored
in SIXBIT. Subsequent words contain lower
levels of SFDs. TOPS-10 allows up to 5 nested
levels of SFDs, but MONGEN allows this value to
be set at less than 5. You can obtain the
maximum number of SFD levels allowed, from the
right half of the item %LDSFD in GETTAB table
.GTLVD.
4-10 . . . Name of the following SFD levels.
11 .PTMAX Maximum length. Contains a 0 to end the PATH.
block.
Argument Block Type 2
This argument block is used to read and define pathological names
(logical names for directory paths) using functions .PTFSN to set
the pathological name and .PTFRN to read the pathological name.
The offsets into the argument block are:
Offset Symbol Contents
0 .PTFCN Job number and function code in the following
format:
Bits Symbol Contents
0-17 PT.JBN Ignored for functions .PTFSN and
.PTFRN.
18-35 PT.FCN Function code. The function
codes and their meanings are:
Code Symbol Function
-6 .PTFRN Returns
information (in
.PTLNM) about
the current
pathological
name or returns
the next
pathological
name in the list
of defined
names.
22-344
PATH. [CALLI 110]
Code Symbol Function
-5 .PTFSN Defines or
deletes a
pathological
name. To delete
a name, you must
also set flag
PT.UDF in .PTLNF
and specify the
name to be
deleted in
.PTLNM.
Offset Symbol Contents
1 .PTLNF Pathological name flags:
Bits Symbol Meaning
0 PT.SEA The directories included in the
definition of this pathological
name will be searched when a
file is not found in the default
directory path when you issue a
LOOKUP monitor call. (This is
similar to .PTFSL, but allows
more flexibility.) PT.SEA can be
set for only one pathological
device. However, several
directories can be specified for
a single pathological name.
1 PT.UDF Deletes the definition of the
pathological name specified in
.PTLNM. You must also specify
function code -5 (.PTFSN) above.
2 PT.RCN Returns data about the
pathological name specified in
.PTLNM when you specify function
code -6 (.PTFRN). If this flag
is 0 for function .PTFRN, the
monitor returns, in .PTLNM, the
next pathological name defined
in the list.
3 Reserved for use by DIGITAL.
22-345
PATH. [CALLI 110]
Bits Symbol Meaning
4 PT.OVR Indicates that the file name and
extension specified in the
definition of the pathological
device should override those in
the argument block for
LOOKUP/ENTER calls. Used with
both .PTFRN and .PTFSN.
For example, when FOO/OVERRIDE
is defined as DSKA:FOO.DAT[1,2],
a LOOKUP of FOO:BAR.DAT will not
find BAR.DAT; it will find
FOO.DAT. When PT.OVR is not
set, the pathological name is
used to define defaults. For
example, when FOO is defined as
DSKA:FOO.DAT[1,2], a LOOKUP for
FOO:BAR would find BAR.DAT
Offset Symbol Contents
2 .PTLNM For function .PTFRN, set this word to 0 to
return the first pathological name in the list
of names defined for your job, or the next path
name in this word. For the .PTFSN function,
this word contains the path name (in SIXBIT)
that you wish to define or delete.
3 .PTLSB First word of the pathological name sub-block.
Each sub-block is in the format shown below.
Offsets are from the start of the sub-block.
The SFD list for the path begins at Word 5 and
is terminated with a zero word. The zero word
must not be past Word 12 (.PTLEL).
The entire list of sub-blocks must be terminated
by two zero words following the last sub-block.
These must be reserved in addition to .PTLEL.
Each path sub-block is formatted as:
Offset Symbol Contents
0 .PTNOD Reserved to DIGITAL for future
expansion.
1 .PTLSL SIXBIT device (such as DSKB,
DSK, ALL, or SSL).
2 .PTFIL File name.
3 .PTEXT File extension.
22-346
PATH. [CALLI 110]
Offset Symbol Contents
4 .PTLPP PPN.
5 .PTLSF Start of SFD list.
6-11 Subsequent SFD levels.
12 .PTLEL Zero word, to terminate SFD list.
13 .PTLZT First of the two-word zero terminator for the
entire list of path blocks.
You can include as many sub-blocks as you wish,
up to 77 (octal), except that the length of the
entire list of sub-blocks (including the header)
may not exceed 144 octal words.
Normal Return
For Read functions, the argument block is filled in; for Set
functions, the function is completed.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-1 PTNSS% No such SFD as that specified in search list.
0 PTNDD% Specified channel was not OPEN, or specified
device was not a disk device.
1 PTTME% Too many entries in PATH. block.
2 PTTMN% Too many pathological names defined.
3 PTNSN% Attempt to delete nonexistent name.
4 PTNFS% No per-process free core.
5 PTANE% Tried to define a pathological name that
already exists.
6 PTNEN% Non-existent pathological name used in argument
block for .PTFRN and .PTFSN.
7 PTNSJ% No such job as the job number you specified in
the argument block.
10 Reserved for use by DIGITAL.
11 PTNAI% Invalid number of arguments specified. You
must include 3 words in the block for calling
sequence 1; 5 words in the block for calling
sequence 2.
22-347
PATH. [CALLI 110]
Examples
This example defines the following pathological name:
FOO/SEARCH=DSKB:[10,10,MON,NEW],DSKC:[10,11,OLD]
The code to define the pathological name FOO is:
MOVE T1,[XWD ARGLEN,ARGLST]
PATH. T1,
JRST ERROR
JRST CONTIN
ARGLST: EXP .PTFSN ;Function code
EXP PT.SEA ;/SEARCH attribute
SIXBIT/FOO/ ;Logical path name to define
EXP 0 ;Start of first group
SIXBIT/DSKB/
0 ;File name
0 ;Extension
XWD 10,10
SIXBIT/MON/
SIXBIT/NEW/
EXP 0 ;Word terminating PATH spec
EXP 0 ;Start of second group
SIXBIT/DSKC/
0 ;File name
0 ;Extension
XWD 10,11
SIXBIT/OLD/
EXP 0 ;Word terminating PATH spec
EXP 0 ;Two words terminating PATH block
EXP 0
ARGLEN==.-ARGLST ;Length of arg list
22-348
PEEK [CALLI 33]
PEEK [CALLI 33]
Function
Returns the contents of any location in the monitor. The PEEK
monitor call requires that your program have bit 16 (JP.SPA) or
bit 17 (JP.SPM) set in the GETTAB table .GTPRV, or your program
must have JACCT privileges. If you do not have the proper
privileges, the ac is cleared.
Calling Sequence
MOVE ac,addr
PEEK ac,
return
where: addr is the 30 bit address of the word in the monitor
virtual address space to be returned.
If you set UU.PHY in this call, using the instruction:
PEEK ac,UU.PHY
the specified address is assumed to be a physical memory address
instead of a virtual address.
Return
On return, the contents of the monitor location given by addr is
returned in the ac. If the calling job does not have the
required privileges, the monitor clears the ac.
Related Calls
PAGE., POKE, SPY
22-349
PERF. [CALLI 162]
PERF. [CALLI 162]
Function
Allows privileged programs to perform system measurements over a
period of time. The PERF. call works only on the KL10 processor.
Note that only one job at a time may use the performance meter on
each CPU. The PERF. functions are discussed in Chapter 10.
Calling Sequence
MOVE ac,[XWD n,addr]
PERF. ac,
error return
normal return
. . .
addr: XWD fcncode,faddr
. . .
XWD fcncode,faddr
where: n is the number of function words specified in the
argument block, which begins at addr.
addr is the address of the argument block. The argument
block is a list of the functions to be enabled and the
address of the argument list that defines each function,
allowing you to specify multiple functions in a single
monitor call.
fcncode is one of the function codes described on the
following pages of this manual.
faddr is the address of the function code argument list.
Each function must have a corresponding argument list.
These argument lists are described with the function
codes.
The function codes and their meanings are:
Code Symbol Function
1 .PRSET Sets up the performance meter.
2 .PRSTR Starts the performance meter.
3 .PRRED Reads the performance meter.
4 .PRSTP Stops the performance meter.
5 .PRRES Releases the performance meter.
6 .PRBPF Turns background PERF analysis off.
7 .PRBPN Turns background PERF analysis on.
22-350
PERF. [CALLI 162]
The argument list at faddr for the .PRSET function is:
Offset Symbol Contents
0 .PMLEN Length of the argument list.
1 .PMCPU CPU type:
Bit Symbol CPU Type
0 PM.PD6 PDP-6.
1 PM.KA KA10.
2 PM.KI KI10.
3 PM.KL KL10.
4 PM.KS KS10.
2 .PMMOD CPU number and mode:
Bits Symbol Meaning
0-17 PM.CPN CPU number.
18 PM.MOD Interval mode. If this bit is
not set, a count of the enabled
events (specified in following
words) is kept. If on, the
duration of the enabled event
(in clock ticks) is kept.
19 PM.CLR Clears performance meter
counts. Resets the counters
when the call is issued. If
you clear this bit, the meter
will be set but any values
currently in the counters are
left unchanged.
3 .PMCSH Cache enable flags:
Flag Symbol Meaning
0 PM.CCR Count references.
1 PM.CCF Count fills.
2 PM.EWB Count EBOX writebacks.
3 PM.SWB Count sweep writebacks.
4 PM.SYN Synchronize performance and
accounting meters.
4 .PMPIE Priority interrupt enable flags:
Flag Symbol Meaning
0 PM.PI0 Enable for channel 0 (DTE).
1 PM.PI1 Enable for channel 1.
22-351
PERF. [CALLI 162]
Offset Symbol Contents
Flag Symbol Meaning
2 PM.PI2 Enable for channel 2.
3 PM.PI3 Enable for channel 3.
4 PM.PI4 Enable for channel 4.
5 PM.PI5 Enable for channel 5.
6 PM.PI6 Enable for channel 6.
7 PM.PI7 Enable for channel 7.
8 PM.NPI Enable for no interrupt in
progress.
5 .PMPCE Program counter enable flags:
Flag Symbol Meaning
0 PM.UPC User-mode enable.
1 PM.XPC Executive-mode enable.
6 .PMMPE Microcode probe enable flags:
Flag Symbol Meaning
0 PM.MPE Enable microcode probe.
7 .PMHPE Hardware probe enable flags:
Flag Symbol Meaning
0 PM.P0L Probe zero low.
1 PM.P0H Probe zero high.
10 .PMJOB Job enable flag:
Value Symbol Meaning
-2 .PMNUL Enable for null job.
-1 .PMSLF Enable for calling job.
11 .PMCHN Channel enable flags:
Flag Symbol Meaning
0 PM.EC0 Enable for channel 0.
1 PM.EC1 Enable for channel 1.
2 PM.EC2 Enable for channel 2.
3 PM.EC3 Enable for channel 3.
4 PM.EC4 Enable for channel 4.
5 PM.EC5 Enable for channel 5.
6 PM.EC6 Enable for channel 6.
7 PM.EC7 Enable for channel 7.
22-352
PERF. [CALLI 162]
The arguments at faddr and following for the .PRSTR, .PRRED,
.PRSTP, and .PRRES functions are:
Offset Symbol Contents
0 .PMLEN Length of the argument list.
1 .PMCPN CPU number.
2 .PMHTB High-order word of time-base.
3 .PMLTB Low-order word of time-base.
4 .PMHPM High-order word of performance counter.
5 .PMLPM Low-order word of performance counter.
6 .PMHMC High-order MBOX reference count.
7 .PMLMC Low-order MBOX reference count.
The argument offsets for the .PRBPF and .PRBPN functions are:
Offset Symbol Contents
0 .PMLEN Length of argument block.
1 .PMCPU CPU type (same as .PRSET).
2 .PMMOD CPU and flags (same as .PRSET).
3 .PMBPI Sample interval in ticks.
Normal Return
For the .PRSET function, the performance meter is set.
For the .PRSTR function, the monitor starts the performance
meter.
For the .PRRED function, the monitor has supplied the updated
values for faddr+2 through faddr+7.
For the .PRSTP and .PRRES functions, the monitor stops the
performance meter or releases the performance meter,
respectively.
22-353
PERF. [CALLI 162]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 PRCPU% Invalid CPU specified.
2 PRNXC% Nonexistent CPU specified.
3 PRMOD% Improper mode specified.
4 PRSET% Meter not set up.
5 PRUSE% Meter already in use.
6 PRRUN% Meter already running.
7 PRJOB% Invalid job number.
10 PRNRN% Meter not running.
11 PRNIM% Function not implemented.
12 PRFUN% Invalid function code.
13 PRPRV% Not enough privileges.
22-354
PIBLK. [CALLI 212]
PIBLK. [CALLI 212]
Function
Returns the address of the 4-word interrupt control block for the
current interrupt in progress on the Programmable Software
Interrupt (PSI) system. Refer to Chapter 6 for more information
about using the (PSI) system.
This call is used by generic interrupt processes that service
multiple interrupt conditions. Note that this call will not
generate an interrupt when UUO interrupts are enabled.
Calling Sequence
PIBLK. ac,
error return
normal return
Normal Return
On a successful return from this call, the address of the
interrupt control block is stored in the ac.
Error Return
The call can take the error return with one of the following
error codes stored in the ac:
Code Symbol Error
0 PSNIN% The PSI system has not been initialized for
this job.
1 PSNIP% No interrupt is in progress.
Related Calls
DEBRK., PIFLG., PIINI., PIJBI., PIRST., PISAV., PISYS., PITMR.
22-355
PIFLG. [CALLI 216]
PIFLG. [CALLI 216]
Function
The PIFLG. monitor call allows you to retrieve the PC flags of
the highest level pending interrupt that have been stored in the
monitor. Flags are stored in the monitor if you are using
extended addressing format, set by the PS.IEA bit of the PIINI.
monitor call.
Calling Sequence
/ MOVEI ac,.PSFRD \
\ MOVE ac,[flags,,.PSFWT] /
PIFLG. ac,
error return
normal return
where: flags are one or more of the interrupt PC flags. The
function codes are:
Code Symbol Function
0 .PSFRD Read interrupt flags.
1 .PSFWT Write interrupt flags.
Normal Return
The requested action is performed. Flags are returned in the ac.
Error Return
One of the following codes in returned in the ac:
Code Symbol Error
0 PSFNI% PSI system not initialized.
1 PSFNP% No interrupt in progress.
2 PSFEA% Extended addressing format for PI system not in
use.
3 PSFIF% Illegal function code.
Related Calls
PIBLK., PIINI., PIJBI., PISAV., PISYS., PITMR.
22-356
PIINI [CALLI 135]
PIINI. [CALLI 135]
Function
Initializes the programmable software interrupt (PSI) facility by
clearing any old interrupts and storing the base address of the
interrupt vector block. Refer to Chapter 6 for more information
about using the PSI system.
Calling Sequence
MOVE ac, [flag + addr]
PIINI. ac,
error return
normal return
. . .
addr:
where: flag is one or more of the following:
Bits Symbol Meaning
0 PS.UCS Use the current (PC) section for the vector
section. (IFIW) If PS.UCS is not set, addr is
treated as a 30-bit address.
1 PS.IEA Use extended addressing format. A 30-bit PC
word is stored in the old PC location in the
PSI block when an interrupt occurs. No flags
are stored in the PC. Flags are stored in the
monitor, and may be returned using the
PIFLG. UUO.
addr is the base address of the first interrupt vector
block. The interrupt vector block is a list of one or
more sub-blocks, each of which is formatted as follows:
Offset Symbol Contents
0 .PSVNP New program counter; this is the address of the
interrupt service routine.
1 .PSVOP Old program counter; this is the address of the
next instruction after the instruction that was
being executed when the interrupt occurred. If
the instruction was a monitor call, .PSVOP
contains the return address for the call;
however, if the monitor terminated the call,
.PSVOP contains the address of the call itself.
22-357
PIINI [CALLI 135]
Offset Symbol Contents
2 .PSVFL Control flags, and either device condition flags
or a non-I/O condition code.
The control flags are:
Bits Symbol Meaning
1 PS.VPO Disable all interrupts; they
can be reenabled by a
PISYS. monitor call.
2 PS.VTO Disable all interrupts of
higher priority until the
program gives a DEBRK. monitor
call.
3 PS.VAI Allow control block to accept
additional interrupts. Use
DEBRK. to dismiss interrupts.
4 PS.VDS Dismiss any additional
interrupt requests for this
condition or device until this
interrupt is dismissed (using
DEBRK.).
5 PS.VPM Print any standard message that
is relevant to this interrupt
condition.
6 PS.VIP Interrupts are in progress for
this interrupt control block.
This flag is used by the
monitor.
17-35 The right half of .PSVFL
contains the condition (reason)
for the interrupt. These are
divided into device I/O
conditions and non-I/O
conditions, and are described
under the PISYS. monitor call.
3 .PSVIS Interrupt status. When this auxiliary word is
returned by a device I/O interrupt, it contains:
udx,,file-status
22-358
PIINI [CALLI 135]
Normal Return
The program can use the PISYS. call to add or delete interrupt
conditions.
Error Return
The call can take the error return with one of the following
error codes stored in the ac:
Code Symbol Meaning
1 PIIBC% Illegal bit or section number given.
2 PIADC% Address check occurred.
3 PINFS% The monitor does not have sufficient free core.
Examples
See Chapter 6.
Related Calls
DEBRK., PIFLG., PIJBI., PIRST., PISAV., PISYS.
22-359
PIJBI [CALLI 175]
PIJBI. [CALLI 175]
Function
The PIJBI. monitor call allows one job to interrupt another with
a software interrupt. The interrupted job must be waiting for
the interrupt; it cannot be busy handling a previous interrupt.
The receiver enables cross-job interrupts by using the PISYS.
UUO (non-I/O condition .PCJBI).
Calling Sequence
MOVE ac,[XWD target,status]
PIJBI. ac,
error return
normal return
where: target is either the job context number of the job to
interrupt, or the job number of the job to interrupt.
Status is the status of the interrupt. The status word
is described in Volume 1.
A -1 for the job number will interrupt the job that is
executing the monitor call.
The job to be interrupted must be enabled for cross-job
interrupts or else the call will fail. Note that this
situation requires cooperation between two jobs, much
like ENQ/DEQ or IPCF. If the target job is processing an
interrupt, the sender must try again because requests are
not queued.
Normal Return
The interrupted job will receive a word of the following form:
[source,,status]
where source is the job context number of the job that performs
the PIJBI. call, and the status is the status that the job
included in the call.
22-360
PIJBI [CALLI 175]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Meaning
0 PSJNE% Job not enabled or the program specified an
invalid job number.
1 PSJOP% Job has an interrupt in progress. Try to
interrupt again.
Related Calls
DEBRK., PIFLG., PIINI., PISAV., PIRST., PISYS.
22-361
PIRST. [CALLI 141]
PIRST. [CALLI 141]
Function
Restores the saved state of the interrupt facility. This does
not restore any pending interrupts.
Calling Sequence
MOVEI ac,buffer
PIRST. ac,
error return
normal return
where: buffer is the address of the data saved by a PISAV.
monitor call.
Normal Return
The state of the interrupt facility as saved by PISAV. is
restored.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 PSNRS% Not restoring what was saved.
1 PSNME% Not enough monitor core to contain data base.
Related Calls
DEBRK., PIFLG., PIINI., PIJBI., PISAV., PISYS.
22-362
PISAV. [CALLI 140]
PISAV. [CALLI 140]
Function
Returns the monitor's data for the current state of the software
interrupt facility. Use PIRST. to restore this data to current
state.
Calling Sequence
MOVE ac,[XWD buflength,buffer]
PISAV. ac,
error return
normal return
. . .
buffer: BLOCK buflength
where: buflength is the length of the buffer for returned data
(buflength = 2 + (3 * blocks)). The data is returned in
a series of 3-word blocks, one block for each interrupt
vector.
buffer is the address of the buffer.
Normal Return
The interrupt data is returned at buffer in the format:
Offset Symbol Contents
0 .PSSFC Flags and count:
Bits Symbol Meaning
0 PS.SON The interrupt facility is on.
1 Reserved.
2 PS.SEA System using extended
addressing.
3-17 Reserved.
18-35 Count of words returned. If
error code PSBTS% (0) is
returned, this count is the
number of words required to
save the current interrupt
system.
1 .PSSIV Address of interrupt control block vector.
2 .PSSBL Address of first 3-word argument block.
22-363
PISAV. [CALLI 140]
Each 3-word argument block is in the form:
Offset Symbol Contents
0 .PSECN Condition or device.
1 .PSEOR Offset,,reasons.
2 .PSEPR Priority,,0.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 PSBTS% Block too small.
1 PSBSZ% Buffer size is 0 words.
Examples
See Chapter 6, Monitor Calls Manual, Volume 1.
Related Calls
DEBRK., PIFLG., PIINI., PIJBI., PIRST., PISYS.
22-364
PISYS. [CALLI 136]
PISYS. [CALLI 136]
Function
Controls the program interrupt facility during execution.
Calling Sequence
|
| MOVE ac,[EXP flags+addr]
| PISYS. ac,
| error return
| normal return
| . . .
| addr: / SIXBIT/device/ \
| | EXP channo |
| | EXP udx |
| \ EXP condition /
| XWD vectoroffset,reasons
| XWD priority, 0
where: flags are one or more of the function flags described
below.
addr is the address of the argument list.
device is the SIXBIT physical or logical name of an
initialized device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
condition is one of the non-I/O condition codes described
below.
vectoroffset is the relative address of the control block
for the interrupt (maximum value for this is stored in
GETTAB table .GTCNF, item %CNMVO).
reasons are flags (described below) specifying the device
conditions that can cause an interrupt.
priority is the priority level assigned to the interrupt.
Priority 0 is the lowest level. Higher values indicate
which events may interrupt other events. The maximum
priority level is available in GETTAB table .GTCNF, item
%CNMIP (normally 3).
22-365
PISYS. [CALLI 136]
The function flags and their meanings are:
Bits Symbol Meaning
1 PS.FOF Turns off the interrupt facility.
2 PS.FON Turns on the interrupt facility.
3 PS.FCP Clears all pending interrupts.
4 PS.FCS Clears all pending interrupts for a given device
or condition.
5 PS.FRC Removes the specified device or condition.
6 PS.FAC Adds the specified device or condition.
The non-I/O condition codes and their meanings are:
Code Symbol Meaning
-1 .PCTLE Time limit exceeded for batch job. The job run
time (in milliseconds) is returned in the status
word. You can change the job's time limit with
the SET TIME monitor command.
-2 .PCTMR Timer interrupt occurred. This condition is
enabled with the PITMR. call.
-3 .PCSTP CTRL/C received from user terminal. If the job
was in terminal input wait state, bit 0 of the
status word is set.
-4 .PCUUO A monitor call is about to be processed; the
status word contains the monitor call.
-5 .PCIUU An illegal monitor call has been processed; the
status word contains the monitor call.
-6 .PCIMR An illegal memory reference occurred; the status
word contains the effective address.
-7 .PCACK An address check occurred; the status word
contains the device name.
-10 .PCARI An exceptional arithmetic condition occurred.
-11 .PCPDL A pushdown list overflow occurred.
-12 .PCNSP The DECnet NSP. monitor call interrupt
occurred. Refer to the NSP. UUO.
22-366
PISYS. [CALLI 136]
Code Symbol Meaning
-13 .PCNXM A reference to nonexistent memory occurred.
-14 .PCAPC A line-frequency clock tick occurred while the
job was running. Note that this does not mean
an interrupt occurs on every clock tick, but
only on those that occur while the job is being
serviced by the CPU. The status word contains
the date and time in universal format.
-15 .PCUEJ A fatal error occurred for the job.
-16 .PCXEJ An external condition caused a fatal error for
the job.
-17 .PCKSY A KSYS (end of timesharing) warning occurred;
the status word contains the number of minutes
left until KSYS.
-20 .PCDSC The dataset status changed.
-21 .PCDAT An ATTACH or DETACH monitor call was executed.
For ATTACH the status word contains -1; for
DETACH the status word contains the Universal
Device Index for the terminal.
-22 .PCWAK A WAKE monitor call was executed; the status
word contains the job number of the waker.
-23 .PCABK An address break condition occurred.
-24 .PCIPC An IPCF packet is in your job's input queue; the
status word contains the associate variable.
-25 .PCDVT DECnet logging event occurred. Returns DR.xxx
conditions, indicating that an event occurred
that the DECnet management layer must handle.
-26 .PCQUE One or more resources requested by an
ENQ. monitor call is now available; the status
word contains the inclusive OR of the
request-ids of the granted requests.
-27 .PCNET The ANF-10 network topology changed. You can
obtain the state of the network using a
NODE. monitor call.
-30 .PCJBI Cross-job interrupt.
22-367
PISYS. [CALLI 136]
Code Symbol Meaning
-31 .PCDTC Date/time changed. The offset from the previous
UDT is returned in the status word. This offset
should be added to a previously stored UDT.
-32 .PCOOB An out-of-band character was received.
-33 .PCRC1 Reserved for customer use.
-34 .PCRC2 Reserved for customer use.
-35 .PCSCS SCS event.
-36 .PCETH ETHERNET event.
The device interrupt reason flags and their meanings are:
Flag Symbol Device Condition
19 PS.RID Input done.
20 PS.ROD Output done.
21 PS.REF End-of-file.
22 PS.RIE Input error.
23 PS.ROE Output error.
24 PS.RDO Device off-line.
25 PS.RDF Device full.
26 PS.RQE Quota exceeded.
27 PS.RWT I/O wait.
28 PS.ROL Device on-line.
29 PS.RRC RIB has changed.
30 PS.RDH Device hung.
31 PS.RSW Reel switch.
32 PS.RIA Input available.
22-368
PISYS. [CALLI 136]
Normal Return
The specified function is executed or the condition is enabled.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 PSTMA% Although no bits in the left half of the ac
require an argument list, the right half is
nonzero.
1 PSNFS% The left half of the ac is zero.
2 PSUKF% Unknown function flag.
3 PSOOF% Both the on and off function flags are set.
4 PSUKC% Address check for addr.
5 PSDNO% Device not initialized.
6 PSPRV% Privilege failure.
7 PSIVO% Invalid vector offset; not a multiple of 4, or
too large. This value may not be larger than
the limit given in the item %CNMVO in the GETTAB
table .GTCNF.
10 PSUKR% Nonzero value at addr+2.
11 PSPTL% Priority too large. Highest priority allowed
can be obtained from GETTAB table %CNMIP.
12 PSNRW% Nonzero right halfword in control block.
13 PSPND% Facility not initialized by PIINI.
14 PSARF% Function flags for both "add" and "remove" are
set.
Examples
See Chapter 6, Monitor Calls Manual, Volume 1.
Related Calls
DEBRK., PIFLG., PIINI., PIJBI., PIRST., PISAV.
22-369
PITMR. [CALLI 203]
PITMR. [CALLI 203]
Function
Enables the PSI system to interrupt after a duration of time.
The PSI system must be initialized with the PIINI. call.
Calling Sequence
MOVE ac,[XWD flag,interval]
PITMR. ac,
error return
normal return
where: flag is bit 0, which can be set to indicate that the
interval is specified in milliseconds. If bit 0 is off,
the interval is assumed to be the number of seconds.
interval is the number of seconds to wait, then interrupt
this job; if bit 0 is set, then the interval is taken as
the number of milliseconds. If interval is specified as
0, the default is 1 clock tick.
Restrictions
o The job must enable the timer condition (.PCTMR), using
PISYS.
o A second request will override the first, because the job can
have only one timer interrupt request pending at a time.
o Specified in milliseconds, the maximum interval is 262.143
seconds.
o In seconds, the maximum interval is 1 hour, 12 minutes, 49
seconds (at 60 Hz); or 1 hour, 27 minutes, and 22 seconds (at
50 Hz).
Normal Return
The program continues at the skip return and is interrupted with
the timer condition after the specified interval.
22-370
PITMR. [CALLI 203]
Error Return
The program receives one of the following error codes in the ac:
Code Symbol Error
0 PSTNE% Timer interrupts are not enabled for your job.
Use PISYS. call to enable for these types of
interrupts.
1 PSUFB% Unknown function bit. The only bit that may be
set in the left half of the ac is bit 0.
Related Calls
DEBRK., PIFLG., PIINI., PIJBI., PIRST., PISAV., PISYS.
22-371
PJOB [CALLI 30]
PJOB [CALLI 30]
Function
Returns the job number of your job.
Calling Sequence
PJOB ac,
only return
Return
Your job number is returned in the ac.
Related Calls
CTLJOB
22-372
POKE [CALLI 114]
POKE. [CALLI 114]
Function
Changes the value of a word in monitor core. Using the
POKE. call requires [1,2], JACCT, or JP.POK privileges.
Calling Sequence
MOVE ac,[XWD 3,addr]
POKE. ac,
error return
normal return
. . .
addr: monitor-addr
oldvalue
newvalue
where: addr is the address of the argument list.
monitor-addr is the address of the monitor word to be
changed.
oldvalue is the value of the word before the change.
newvalue is to be the value of the word after the change.
If you set UU.PHY using the instruction:
POKE. ac,UU.PHY
monitor-addr is assumed to be a physical memory address.
If you do not set UU.PHY, monitor-addr is assumed to be
an executive virtual address.
Normal Return
The value of the specified monitor word is changed.
22-373
POKE [CALLI 114]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 PKNPV% Your job is not properly privileged.
1 PKDIF% The value of the given word is different from
the value of oldvalue.
2 PKBAD% The value of monitor-addr is not a valid monitor
address.
Related Calls
PAGE., PEEK., SPY
22-374
QUEUE. [CALLI 201]
QUEUE. [CALLI 201]
Function
Allows your program to communicate with system components. The
actual communication is accomplished by QUEUE., using IPCF in
your behalf, but the QUEUE. call allows you to communicate with
system components using standard argument block formats. Some
functions provided by system components are not accessible
through QUEUE., and in these cases you must format your own
IPCF. messages. For example, QUEUE. allows you to send messages
to the GALAXY batch and spooling system, the accounting system,
and site-specific components.
Many of the implemented functions relate directly to monitor
commands. Therefore, information about these functions can be
obtained from the Commands Manual.
Calling Sequence
MOVE ac,[XWD len,addr]
QUEUE. ac,
error return
normal return
. . .
addr:
where: len is the length of the argument list, and must be 5 or
greater.
addr is the address of the argument list, which is
formatted as follows:
Argument |==============================================|
Block .QUFNC | QF.FLG | QF.HLN | QF.FNC |
Header |----------------------------------------------|
.QUNOD | Node-id |
|----------------------------------------------|
| Length of (QR.LEN) | Pointer to (QR.BLK) |
.QURSP | Response Block | Response Block |
|----------------------------------------------|
.QUTIM | | QT.TIM |
|==============================================|
Argument | | | |
Block | | | |
.QUARH | I | QA.LEN | QA.TYP |
|----------------------------------------------|
.QUARV | Value or Pointer |
|==============================================|
22-375
QUEUE. [CALLI 201]
Each word of the argument block header is described below:
Word Symbol Contents
0 .QUFNC Flags, header block length, and function code.
The flag field (QB.FLG) is in Bits 0-11 of the
left half of the word, in which you can set any
of the following flags:
Bit Symbol Meaning
0 QF.RSP User wants acknowledgement text
returned at the address
specified in Word 2 of this
block, .QURSP.
1 QF.PIP Your privileged job is invoking
privileges to perform privileged
QUEUE. call functions. You
must set this flag to use
privileged functions of QUEUE.
2 QF.NBR Non-blocking return. The call
will return automatically, and
the function will be performed
while your program runs. This
flag is useful with
function .QUWTO and requires
privileges.
The length of the header block is contained in
Bits 12-17, defined by the symbol QB.HLN.
The right half of word 0 contains the function
code. Function codes are listed at the end of
the argument header block description.
1 .QUNOD ANF-10 network node identifier. You must
specify whether the function is to be performed
at the central site (where the program is
running) or at a remote station. If this word
is 0, the central site is assumed. If you set
this word to -1, the located node (defined by a
LOCATE command or monitor call) is used.
2 .QURSP Pointer to the first word of a block reserved
for acknowlegement response from the system
component. Data is read from this word if
QF.RSP=1 in the function word. If non-zero, the
.QURSP word must contain the length of the
response block in the left half (QU.LEN) and the
address of the first word of the response block
in the right half (QU.BLK).
22-376
QUEUE. [CALLI 201]
Word Symbol Contents
3 .QUTIM This optional header word contains the maximum
number of seconds to wait for a response. If
the time is exceeded, the call returns error
code 11. If this word contains 0, or is
non-existent, there is no implied time limit on
the request.
The function codes that you can specify in Word 0 (.QUFNC) are:
Code Symbol Function
-n Reserved for use by customers.
1 .QUPRT Prints a file.
2 .QUCDP Punches a file on cards.
3 .QUPTP Punches a file on paper tape.
4 .QUPLT Plots a file.
5 .QUBAT Processes the file under BATCON, the batch
controller.
6 .QUALC Allocates a volume set.
7 .QUDAL Deallocates a volume set.
10 .QUMNT Mounts a volume set.
11 .QUDIS Dismounts a volume set.
12 .QUWTO Writes to operator.
13 .QUWTR Writes to operator with reply.
14 .QUVAL Validates an account.
15 .QUMAE Makes an accounting entry by sending a message
to the ACTDAE program. Refer to ACTSYM.MAC for
the format of accounting entries.
The argument header block is followed by the one or more argument
blocks. These argument blocks each consist of a header word and
one or more data words.
The header describes the data word. If Bit 0 of the header word
is set, the data words contain the value of the argument. If
however, Bit 0 in the header word is clear, the data word
contains the address of the data block. The remainder of the
header word provides the length and type code.
22-377
QUEUE. [CALLI 201]
The argument block, therefore, is formatted as follows:
Word Symbol Contents
0 .QUARH Contains information about the data word(s).
Specifically:
Bits Symbol Contents
0 QA.IMM If this bit is set, data for the
function starts at .QUARV.
If this bit is clear, the data
word contains the address of the
data block (IFIW or GFIW).
6-17 QA.LEN This field contains the number
of words in the data block. A
value of zero is interpreted as
one.
18-35 QA.TYP This field contains the code for
the type of data block that the
data word points to.
1 .QUARV Contains either the first word of the value of
an immediate argument for the function, or
contains the single-word address of a data block
that contains the argument.
Each function can be described by one or more types of data
blocks. The data blocks are listed below in the order of their
type codes. Include all the data block types that specify
information that is needed to perform the function you specified
in .QUFNC.
Use the value of QA.IMM to specify the location of the data. If
QA.IMM=1, the data words contain the data. If QA.IMM=0, the data
word points to a data block.
For the allocation, mounting, dismounting, and deallocation of
volume sets (functions 6-11), you must first specify Block Type
37 (.QBVSN) to specify the magtape volume set name or disk
structure name. Then list the data blocks that contain or point
to data about the request.
22-378
QUEUE. [CALLI 201]
The data block types are:
Type Symbol Contents
10 .QBFIL File specification block. You must include this
type of data block for any function on a file
(such as printing a file).
Offset Symbol Contents
0 .QBFSR SIXBIT structure name.
1 .QBFFL SIXBIT file name.
2 .QBFEX SIXBIT extension. The right
half of this word must be 0.
3 .QBFPP UFD number (PPN).
4 .QBFS1 First level of SFD in SIXBIT.
5 .QBFS2 Second level of SFD (SIXBIT).
6 .QBFS3 Third level of SFD (SIXBIT).
7 .QBFS4 Fourth level of SFD (SIXBIT).
10 .QBFS5 Fifth level of SFD (SIXBIT).
11 .QBCOP Number of copies block:
Offset Symbol Contents
0 .QBCNO Number of copies of the file to
be output.
12 .QBFRM Forms type block:
Offset Symbol Contents
0 .QBFTY Forms type in SIXBIT.
13 .QBPTP Print file type block (for function .QUPRT
only):
Offset Symbol Contents
0 .QBPCD File format code. Include one
of the following codes:
Code Symbol Meaning
1 .QBPAS ASCII.
2 .QBPFR FORTRAN.
3 .QBPCB COBOL.
4 .QBPAI Augmented image.
5 .QBPSA Stream ASCII.
6 .QBP11 Eleven.
7 .QBPIM Image.
10 .QBP8B 8-bit ASCII.
22-379
QUEUE. [CALLI 201]
Type Symbol Contents
14 .QBODP Output disposition block. Specifies the fate of
the file after the file is spooled.
Offset Symbol Contents
0 .QBODB Output file disposition, one of
the following:
Code Symbol Meaning
0 .QBODK Preserve the file after
processing it.
1 .QBODD Delete the file after processing
it.
2 .QBODR Rename the file into the
spooling area, effectively
deleting it from the original
area immediately.
15 .QBUNT Unit type:
Offset Symbol Contents
0 .QBUDA Device attributes in the left
half. If .QBUPH is specified in
the left half, you must specify
the unit number in the right
half of this word. The device
attribute codes are:
Code Symbol Meaning
1 .QBULC Lowercase printer.
2 .QBUUC Uppercase printer.
3 .QBUPH Physical device (specify unit
number in right half).
4 .QBUGN Generic device.
16 .QBAFT Specifies the date and time at which the request
should be processed.
Offset Symbol Meaning
0 .QBADT Time in universal date/time
format.
22-380
QUEUE. [CALLI 201]
Type Symbol Contents
17 .QBLIM Specifies the maximum number of units to which
the job is limited. For printer requests, this
is the number of pages. For batch processing,
this refers to number of seconds of processing
time, and so forth.
Offset Symbol Contents
0 .QBLNO Number of pages, seconds, or
appropriate limit.
20 .QBUNI Specifies whether a batch job can be processed
at the same time as others from the same PPN, or
if only one batch job from this PPN can run at a
time.
Offset Symbol Contents
0 .QBNVL Uniqueness code:
Code Symbol Meaning
1 .QBNNO Does not need to be unique.
2 .QBNYE Must be unique.
21 .QBRES Specifies whether a batch job should be
restarted by the operator if the job is
terminated unexpectedly (by a system failure,
for example).
Offset Symbol Contents
0 .QBRVL Restart code:
Code Symbol Meaning
1 .QBRNO Do not restart the job.
2 .QBRYE Restart the job.
22 .QBLOG Specifies the circumstances under which to print
a log file of the batch job.
Offset Symbol Contents
0 .QBLVL Output type code:
22-381
QUEUE. [CALLI 201]
Type Symbol Contents
Code Symbol Meaning
1 .QBLNL Never print a log file.
2 .QBLLG Always print a log file.
3 .QBLLE Print a log file only when the
batch job is terminated with an
error.
23 .QBACT Account string block. Specifies the ASCIZ
account string for a batch job. Argument words
.QBAC1 through .QBAC8 contain the ASCIZ string.
24 .QBFNC Reserved for use by DIGITAL.
25 .QBNOD Specifies the node at which the actual job
processing should be done (destination node).
Node number must be a remote non-host station in
an ANF-10 network.
Offset Symbol Contents
0 .QBNND Destination node number or
SIXBIT node name.
26 .QBNAM User's name block:
Offset Symbol Contents
0 .QBNM1 First word of SIXBIT user name.
1 .QBNM2 Second word of SIXBIT user name.
27 .QBOID Specifies the owner's PPN:
Offset Symbol Contents
0 .QBOPP Owner's PPN.
30 .QBNOT Specifies whether to notify the job when the
request is finished.
Offset Symbol Contents
0 .QBNTL Notify value:
Code Symbol Meaning
1 .QBNTY Notify job when request is
complete.
2 .QBNML Reserved for use by DIGITAL.
3 .QBNJB Reserved for use by DIGITAL.
22-382
QUEUE. [CALLI 201]
Type Symbol Contents
31 .QBBLT Specifies the action to take on the batch log
file:
Offset Symbol Contents
0 .QBBVL One of the following:
Code Symbol Meaning
1 .QBBND Append output log file to
existing log file.
2 .QBBDE Supersede existing log file.
3 .QBBSP Spool log file to printer
without preserving it in your
area.
32 .QBJBN Specifies the job name:
Offset Symbol Contents
0 .QBJNM SIXBIT job name.
33 .QBCDI Contains the batch job's default path block for
batch requests.
Offset Symbol Contents
0 .QBCPP PPN.
1 .QBCS1 First word of PATH block.
2 .QBCS2 Second word of PATH block.
3 .QBCS3 Third word of PATH block.
4 .QBCS4 Fourth word of PATH block.
5 .QBCS5 Fifth word of PATH block.
34 .QBNTE Specifies a note to include on output header
pages.
Offset Symbol Contents
0 .QBNM1 1 to 6 SIXBIT characters.
1 .QBNM2 1 to 6 SIXBIT characters
(maximum of 12 characters).
22-383
QUEUE. [CALLI 201]
Type Symbol Contents
35 .QBBGN Specifies the page number of the file to begin
printing, or the line number or tag in a batch
file where processing should begin.
Offset Symbol Contents
0 .QBBPN Beginning page number (for
printing), line number (for
batch jobs), or tag (in SIXBIT)
at which to begin processing a
batch job.
36 .QBPRI Specifies the relative priority of the request.
Unprivileged users can specify priorities
between 1 and 20, and privileged users can
specify a priority in the range of 1 to 62.
These limits can be changed by GALGEN, the
GALAXY generation program. If you specify
priority 0 or 63, the default priority is
assumed.
Offset Symbol Contents
0 .QBPVL Priority value (1 to 62).
37 .QBVSN Contains the ASCIZ volume set name. This block
must precede all other mount-specific blocks
when you perform a disk or tape mount.
Offset Symbol Contents
0 .QBVAS Beginning of ASCIZ volume set
name.
40 .QBMSG Contains the WTO/WTOR message block:
Offset Symbol Contents
0 .QBMAS Beginning of the ASCIZ message
for the operator.
41 .QBTYP Contains the privileged WTO/WTOR message type
block. WTO sends message to operator without
requiring response. WTOR requires response from
operator.
Offset Symbol Contents
0 .QBTAS Beginning of ASCIZ message for
the operator.
22-384
QUEUE. [CALLI 201]
Type Symbol Contents
42 .QBDEN Specifies the tape density:
Offset Symbol Contents
0 .QBTDN Tape density code. Refer to the
.TFDEN function of the TAPOP.
call.
43 .QBTRK Specified the tape track code:
Offset Symbol Contents
0 .QBDRV Tape track request code:
Code Symbol Meaning
1 .QBDR9 9-track tape.
2 .QBDR7 7-track tape.
44 .QBLTP Specifies the tape label type.
Offset Symbol Contents
0 .QBLAB Label type code. Refer to the
.TFLBL function of the TAPOP.
call.
45 .QBRMK Specifies the remark text:
Offset Symbol Meaning
0 .QBREM Start of ASCIZ remark to be sent
to operator with request.
46 .QBVOL Specifies the tape volume list:
Offset Symbol Meaning
0 .QBVLS Start of list of SIXBIT tape
volume identifiers. A maximum
of 63 volumes is allowed.
47 .QBLNM Specifies the volume set logical name:
Offset Symbol Meaning
0 .QBLGN SIXBIT logical name for this
volume set.
22-385
QUEUE. [CALLI 201]
Type Symbol Contents
50 .QBMFG Specifies MOUNT/DISMOUNT flags, indicated by
setting/clearing bits in the following word:
Offset Symbol Meaning
0 .QBMDF Flags to control the MOUNT or
DISMOUNT request:
Flag Symbol Meaning
0 QB.PAS Add the structure to the passive
search list (active search list
is default).
1 QB.EXC Exclusive/sharable access
(sharable is default for disk,
exclusive is default for tapes).
2 QB.NOC Prevent files from being created
on the volume set. (The default
is to allow file creation.)
3 QB.DSK This is a disk file structure
request.
4 QB.TAP This is a magtape request.
5 QB.WLK Write-lock the volume set
(default for magtapes).
6 QB.WEN Write-enable the volume set
(default for disk).
7 QB.REM Ask operator to remove the
structure when you dismount it.
8 QB.SCR Ask the operator to mount a
scratch tape.
9 QB.ARD Always recompute disk usage.
51 .QBAFN Specifies the accounting daemon (ACTDAE)
subfunction. .QBAFN is not intended for
customer use.
52 .QBAET Specifies the usage entry type. This type is
not intended for customer use.
53 .QBTTY Contains a SIXBIT terminal name. This block is
not intended for customer use. .QBTTY is
included in the IPCF message the monitor sends
to ORION for a 'SEND OPR' command.
54 .QBFNT Contains a six-word (maximum) argument block
that specifies a font name. LPTSPL uses this
ASCIZ string to locate the requested font file.
Argument words are .QBFN0 to .QBFN5.
22-386
QUEUE. [CALLI 201]
Type Symbol Contents
55 .QBEVT Specifies an event to take place at the interval
requested in .QBREP (Type 56). .QBEV0 is the
argument word containing one of the following
options:
Code Symbol Event
1 EV.KSY KSYS
4 EV.ATO Time-of-day
5 EV.USG Usage file closure
6 EV.BIL Billing file closure
7 EV.OPR ORION log file closure
56 .QBREP Repeats the event requested in .QBEVT at the
interval given in the .QBRP0 argument word.
.QBRP0 contains one of the following options:
Flag Symbol Meaning
0 QB.NOW Event happens now.
1 QB.DLY Event happens daily.
2 QB.WKY Event happens weekly.
3 QB.TIM Event happens at specified time
Or, you may specify .QBRP0 as day,,-1, where day
is the day of the week when the event occurs
(Wednesday=0, Thursday=1, and so on.)
57 .QBESW Contains the event switch block. This block
holds two words. .QBESD is the event-dependent
switch value word, and .QBESI is the
event-independent switch value word. You may
specify one of the following flags for .QBESI:
Flag Symbol Meaning
0 QB.FSF Failsoft option, which retains
the event in the queue after a
system reload.
1 QB.NFS No failsoft.
60 .QBAST Sets the OPR intervention bit to one of the
following:
Bit Symbol Meaning
1 .QBOIY Enable OPR intervention.
2 .QBOIN Disable OPR intervention.
22-387
QUEUE. [CALLI 201]
Type Symbol Contents
61 .QBPRC Sets the IBM /PROCESSING node.
62 .QBOPT Specifies a SIXBIT batch option name. .QBOP0 is
the offset to the option name.
63 .QBDIS Specifies text to be printed for a
DISTRIBUTION: header. .QBDI0 is the offset to
the first word of ASCIZ data.
64 .QBUSR Specifies text to be printed for a
USERNAME: header. .QBUS0 is the offset to the
first word of ASCIZ data.
65 .QBUTY Specifies a SIXBIT unit name, such as "LN01" to
queue to an LN01 laser printer.
Normal Return
On the return from QUEUE., the IPCF messages have been sent to
appropriate components. If you requested a response by setting
QF.RSP, the following information is returned in the ac:
Bits Symbol Meaning
18 QU.RBT Response from GALAXY was too long for reserved
space (as specified in .QURSP) and had to be
truncated.
19 QU.RBR Response from GALAXY was returned.
23-35 QU.RBL Contains the length of the returned response
from GALAXY.
Error Return
The error codes and their meanings are:
Code Symbol Meaning
1 QUIAL% Illegal argument list.
2 QUILF% Illegal function.
3 QUNFS% No monitor free core.
4 QUADC% Address check.
5 QUCNR% Component not running or has no system PID.
6 QUFER% Fatal error returned from ORION.
7 QUSOC% Invalid message from ORION.
10 QUNPV% Insufficient privileges.
11 QUTMO% Timeout limit exceeded.
22-388
REASSI [CALLI 21]
REASSI [CALLI 21]
Function
Reassigns or deassigns a device for a job. Your program can
reassign a device if the device is assigned to your job, or if it
is not assigned to any job. Restricted devices cannot be
reassigned by unprivileged jobs. The logical name assignment is
also cleared, unless the calling job has JACCT privileges or is
logged in under [1,2].
Calling Sequence
|
| MOVEI ac,jobno
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| REASSI ac,
| return
where: jobno is the number of a logged-in job to which the
device is to be reassigned. Use -1 to indicate the
current job or 0 to deassign the device.
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Return
If the ac is unchanged on the return from the call, the device is
reassigned as requested.
If the device is restricted and you specified 0 for jobno to
deassign the device, it is returned to the system's pool of
restricted devices.
A restricted device can be reassigned to an unprivileged job only
by a privileged job.
On the return from this call, the monitor performs an implicit
RELEAS monitor call for the device, unless you specified 0 or -1
for the jobno.
If the ac is cleared on the return, the jobno was not a valid job
number.
22-389
REASSI [CALLI 21]
If the ac contains -1 on the return, the device is not assigned
to the specified job. The device is your job's controlling
terminal, or the device name given is a duplicate of an existing
logical device name.
If ac+1 is cleared on a return from the call, the device is not
assigned to your job, or the device you specified was a disk or
your job's controlling terminal.
Common Errors
o Forgetting that there is only one return location from the
call.
o Attempting to assign a restricted device.
Related Calls
DEVLNM
22-390
RECON. [CALLI 202]
RECON. [CALLI 202]
Function
Performs tasks to aid system reconfiguration and diagnosis. This
call is not recommended for use by customer programs and requires
[1,2] or JACCT privileges. It is used by the CONFIG system
facility to take system snapshots, suspend the system, and other
system-wide functions. To perform the functions offered by the
RECON. call, use the CONFIG command level from the OPR program
(documented in the TOPS-10 Operator's Command Language Reference
Manual), because the functions must be performed in the correct
order or the system will fail to continue.
Calling Sequence
MOVE ac,[fcncode,,addr]
RECON. ac
error return
normal return
addr: argument-block
where: fcncode is one of the functions described below.
addr contains an argument block. The data in the
argument block depends on the function code. For
functions that do not require an argument, use 0 for
addr.
The function codes, their meanings, and argument blocks are:
Code Symbol Meaning
0 .RCROM Prevents execution of all jobs on the system
except the job number specified in addr+1. Use
-1 for current job. If the job number is 0, the
function is to resume normal timesharing. The
argument block for this call is:
MOVE ac,[.RCROM,,addr]
RECON. ac,
error return
normal return
. . .
addr: 2 ;length of argument block
jobno ;contains -1 for current job
22-391
RECON. [CALLI 202]
Code Symbol Meaning
1 .RCSPN Causes a suspension of the system. To
accomplish this, the monitor writes a copy of
memory to CRASH.EXE on disk, and the system is
halted. This last action is taken as the result
of the CONFIG command SUSPEND. This function
does not require an argument block, so the
calling sequence is:
MOVE ac,[.RCSPN,,0]
RECON. ac,
error return
normal return
2 .RCCI7 Causes the monitor to perform a continuable
stopcode (stopcode CI7), take a dump of memory,
and continue automatically. This dump is called
a "snapshot," and allows you to diagnose
problems by obtaining a dump without halting the
system. The .RCCI7 function does not require an
argument block, so the calling sequence looks
like:
MOVE ac,[.RCCI7,,0]
RECON. ac,
error return
normal return
3 .RCNAR Clears and sets the DF.NAR bit in the DEBUGF
word, which controls whether the system should
automatically reload on non-continuable
stopcodes. The DEBUGF word is defined in the
monitor symbol file S.MAC, and is manipulated
during analysis of system errors. By default,
DF.NAR is set, and automatic reload is enabled.
You can clear the bit to prevent auto-reload
when debugging the system, but this function
requires that you be logged in under [1,2].
22-392
RECON. [CALLI 202]
Code Symbol Meaning
The DF.NAR bit is set/cleared according to the
second word in the argument block. If Word 1 of
the argument is 0, the DF.NAR is cleared, and
automatic reload is enabled (default state). If
you place a non-zero value in Word 1, DF.NAR is
set, and the system will not automatically
reload on a non-continuable stopcode. The
calling sequence for this function is:
MOVE ac,[.RCNAR,,addr]
RECON. ac,
error return
normal return
. . .
addr: 2 ;length of argument block
-1 ;to disable auto-reload
4 .RCBTX Changes the BOOTXT command string to the command
string you specify in the argument. The calling
sequence for this function is:
MOVE ac,[.RCBTX,,addr]
RECON. ac,
error return
normal return
. . .
addr: n ;length of argument block
command-list ;first word
where n is the length of the command string (in
words) + 1. The command string cannot exceed 16
words, and cannot include line-feeds; therefore,
the maximum value for n is 17. For information
about the BOOTXT command string, refer to BTXLEN
in the COMMON monitor source file.
5 .RCRLD Causes the system to be reloaded. The monitor
will be reloaded from the file specified in
BOOTXT, and a crash dump will be taken. You
must be logged into [1,2] to use this function
(JACCT privileges alone are not sufficient).
This function causes an RLD stopcode and does
not require an argument list. The calling
sequence for this function is:
MOVE ac,[.RCRLD,,0]
RECON. ac,
error return
normal return
22-393
RECON. [CALLI 202]
Code Symbol Meaning
6 .RCRAC Causes auto-configuration (AUTCON) to run on the
specified CPU(s) to automatically configure
disks and tapes into the monitor's data base.
You must be logged in as [1,2] to use this
function. The calling sequence for this
function is:
MOVE ac,[.RCRAC,,n]
RECON. ac,
error return
normal return
where n specifies the CPU number. If n = -1,
AUTCON will run on all CPUs.
7 .RCDET Detaches a CPU or a device as specified in the
argument block. The calling sequence is as
follows:
MOVE ac,[.RCDET,,addr]
RECON. ac,
error return
normal return
addr: 2 ;length of argument block
SIXBIT CPU name
or
SIXBIT device name
10 .RCATT Attaches a CPU or device specified in the
argument block. The calling sequence for .RCATT
is:
MOVE ac,[.RCDET,,addr]
RECON. ac,
error return
normal return
addr: 2 ;length of argument block
SIXBIT CPU name
or
SIXBIT device name
22-394
RECON. [CALLI 202]
Code Symbol Meaning
11 .RCMON Sets a given range of memory on-line. The range
is given in two words of the argument block.
The first word specifies the first page of the
range, and the second word indicates the first
page beyond the range. The calling sequence is:
MOVE ac,[.RCMON,,addr]
RECON. ac,
error return
normal return
addr: 3 ;length of argument block
first page in range
last page in range +1
12 .RCMOF Sets a given range of memory off-line. You
specify the range the same way as for .RCMON.
The calling sequence is:
MOVE ac,[.RCMOF,,addr]
RECON. ac
error return
normal return
addr: 3 ;length of argument block
first page in range
last page in range +1
13 .RCCPU Returns the CPU accessibility mask. The mask
indicates which CPU is using the specified
device. The calling sequence for .RCCPU is:
MOVE ac,[.RCCPU,,addr]
RECON. ac,
error return
normal return
addr: 2 ;length of argument block
SIXBIT device name
The bit mask returned in the ac indicates which
CPU is associated with the device. For example,
Bit 35=CPU0, Bit 34=CPU1, and so forth.
22-395
RECON. [CALLI 202]
Code Symbol Meaning
14 .RCIOW Indicates when I/O on the system is complete.
The calling sequence is:
MOVSI ac,.RCIOW
RECON. ac,
error return
normal return
The return occurs after active I/O on the system
has finished.
15 .RCSDF Sets bits in DEBUGF that cause the monitor to
reload for a CPU, DEBUG, or JOB stopcode. This
function is used by ORION for the CONFIG
program. The calling sequence is:
MOVE ac,[.RCSDF,,addr]
RECON. ac,
error return
normal return
addr: 2 ;length of argument block
DEBUGF bits
16 .RCCDF Clears DEBUGF bits so that the monitor takes a
continuable dump on a CPU, DEBUG, or JOB
stopcode. This function is not intended for
customer use. The calling sequence is:
MOVE ac,[.RCCDF,,addr]
RECON. ac,
error return
normal return
addr: 2 ;length of argument block
DEBUGF bits
Normal Return
The specified function is performed.
22-396
RECON. [CALLI 202]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 RCIAL% Illegal argument list.
2 RCNPU% Not privileged.
3 RCNTS% Timesharing already stopped on some CPU.
4 RCNIJ% Illegal job number.
5 RCNCD% This function cannot be performed.
6 RCNAC% Address check.
7 RCNIS% Illegal command string for BOOTXT.
10 RCICN% Illegal CPU number.
11 RCNCR% CPU still running.
12 RCNCA% Can't attach disk.
13 RCNDS% Device is spooled.
14 RCNAA% Device is already attached.
15 RCNID% Illegal device.
16 RCNDU% Device is in use.
17 RCNND% Can't detach disk.
20 RCNNL% Can't set memory off-line.
21 RCNMM% Can't remove monitor memory.
22 RCNTB% Job or jobs too big.
23 RCNLJ% Can't move locked job(s).
22-397
RELEAS [OPCODE 071]
RELEAS [OPCODE 071]
Function
Releases an I/O channel. Use FILOP. to perform a RELEAS on an
extended I/O channel.
Calling Sequence
RELEAS channo,
return
Where: channo is the number of an initialized channel.
Return
The device is released, the channel is closed, any
device-dependent operations are performed, and any enqueue locks
are released.
If the given channel is not initialized, the monitor takes no
action.
Examples
See Chapter 11, Volume 1.
Common Errors
Forgetting the comma after the channel number.
Related Calls
FILOP.
22-398
REMAP [CALLI 37]
REMAP [CALLI 37]
Function
Moves the specified portion of a program's low segment into the
high segment, discarding the old high segment from the user
addressing space. The new low segment will be the previous low
segment minus the amount remapped. This monitor call is used by
the LINK program when you use the EXECUTE monitor command.
The .PAGCH function of the PAGE UUO has the same capability as
REMAP, but is more flexible.
Calling Sequence
MOVE ac,[XWD origin,addr]
REMAP ac,
error return
normal return
where: addr is the highest address in the low segment (that is,
the first address of the new high segment).
origin is the origin of the high segment.
The monitor waits until all I/O is completed in the low segment
before executing the REMAP monitor call. Then the monitor rounds
the address to the nearest core allocation unit (512 decimal
words).
Normal Return
o The monitor stores the value of addr in the location .JBREL
in the job data area.
o The monitor sets the left half of .JBHRL to zero (it deletes
the previous high segment).
o The monitor stores the highest legal user address for the
high segment in the right half of .JBHRL.
o The monitor changes the hardware mapping.
o The monitor sets the user-mode write-protect bit (the new
high segment is non-sharable).
o The contents of the ac are preserved.
22-399
REMAP [CALLI 37]
Error Return
The monitor takes the error return if any of the following
conditions is found:
o A negative argument is specified.
o The requested remapping would cause the high and the low
segments to overlap.
o The sum of the high segment origin plus its length would
cause the high segment to start (or end) at an address
outside the program's virtual address space (that is, greater
than or equal to 256K).
o The specified argument exceeds the length of the low segment.
Also, remapping will not occur, and the high segment will
remain unchanged in the user's address space.
o The segment is locked in memory.
Related Calls
CORE, GETSEG, MERGE., PAGE.
22-400
RENAME [OPCODE 055]
RENAME [OPCODE 055]
Function
Performs one or more of the following functions:
o Alters file attributes, including the file name, file
extension, and access privilege code of the file.
o Changes an SFD name.
o Deletes the specified file.
o Performs an implicit CLOSE.
Use FILOP. to perform a RENAME on an extended I/O channel.
Calling Sequence
RENAME channo,addr
error return
normal return
where: channo is the number of an initialized channel. If the
channel is an extended channel, use FILOP. function
.FORNM.
addr is the address of the argument list. The argument
list is equivalent to that of LOOKUP and ENTER calls and
is described in Section 11.13.
RENAME has two forms of argument block: the four-word block and
the extended argument block. The short-form (4-word) argument
list is described in Section 11.13.1. The extended argument list
is described in Section 11.13.2. For DECtape files, refer to
Chapter 13 for descriptions of the arguments.
The only way that your program can RENAME a file into or out of
an SFD is to refer to an explicit path using the PATH. argument
block (by including an [XWD 0,addr] instruction as the PPN
argument). If a RENAME is given that attempts to move a file
into or out of an SFD without specifying an explicit path, it
will take the normal return (assuming no other errors), but the
file will not change directories.
To delete a file after all read references have been made, your
program should specify the value of zero in the address of the
file name word in the RENAME block.
22-401
RENAME [OPCODE 055]
A delete function on a channel that is open for output, to
supersede a file, simply aborts the creation of the new file.
This is equivalent to a CLOSE with CL.RST set.
Although only a privileged job can delete a UFD, an unprivileged
job can delete an empty SFD. Note that you must set your path to
a different area before you can delete the current SFD. If the
directory is not empty or if a job is currently using the
directory, the monitor returns the DIRECTORY NOT EMPTY error
code.
A CLOSE is optional after a RENAME because a RENAME implicitly
performs a CLOSE. A CLOSE should not be issued between a LOOKUP
and a RENAME if the file is not in the default directory path,
because the CLOSE erases all memory of the path. If RENAME is
performed and the file is not in the default path, the monitor
returns the FILE NOT FOUND error in the right half of addr+1.
Restriction
If your program attempts to change the extension of an SFD, a
protection error results. An error also results if your program
attempts to alter the name, extension, or PPN associated with a
UFD or the PPN associated with an ersatz device name.
Normal Return
On a normal return, the monitor returns the same information on a
RENAME as on a LOOKUP and ENTER. Refer to Section 11.13.
Error Return
The error return is taken under the following conditions:
o No file has been opened on the specified channel.
o The specified file cannot be found.
o The specified file is currently in the process of being
written, superseded, or renamed.
o Your program does not have the appropriate privileges to
RENAME the file.
o The new file name already exists (occurs when changing file
names).
The monitor returns the error code for the RENAME monitor call in
the right half of addr+1 of the 4-word argument block, or in the
right half of addr+3 in the extended argument block. The error
code overwrites the high-order three bits of the creation date
and the entire access date.
22-402
RENAME [OPCODE 055]
This overwriting of data does not cause any problems for programs
that recover from RENAME errors by aborting or by re-initializing
the argument list. However, programs that attempt to recover
from an error by fixing only the incorrect portion of the
argument block and then reexecuting the monitor call should
restore the right half of addr+1 or addr+3 before reexecuting the
RENAME monitor call. Error codes are restricted to a maximum of
15 bits to allow programs to recover from an error in a file with
a zero creation date. See Section 11.14 for a list of error
codes.
22-403
RESCAN [TTCALL 10,]
RESCAN [TTCALL 10,]
Function
Resets the input buffer pointer to point to the beginning of the
previous command. Note that if the RESCAN UUO is issued after
the first terminal input or output instruction, the command is no
longer in the buffer.
Calling Sequence
RESCAN flag
return 1
return 2
where: flag controls the action of returning from the call. The
flag is bit 35 of the word. If the flag is not set, the
call always returns at return 1. If the flag is set, the
call returns at return 2 when no command is in the input
buffer, otherwise, the call takes return 1.
Example
RESCAN 1 ;Read TTY input
SKPINL ;Is anything there?
JRST PROMPT ;No, must be typeahead
;Read command line
. . .
Common Errors
Placing a comma after the flag.
22-404
RESDV. [CALLI 117]
RESDV. [CALLI 117]
Function
Resets a specified channel. RESDV. is similar to RESET, except
that only one channel is reset and any outstanding data is
discarded. If RESDV. is performed on a disk device, the file is
discarded (refer to the CLOSE function CL.RST).
Calling Sequence
MOVEI ac,channo
RESDV. ac,
error return
normal return
where: channo is the number of an initialized channel.
Normal Return
The channel is reset. Files that were being created on the
channel are deleted; any older files with the same name remain.
All I/O for the channel is stopped, and device allocations made
on the channel by INIT, OPEN, or FILOP. are closed. If the
device was not assigned by ASSIGN, ALLOCATE, REASSI, or MOUNT, it
is returned to the monitor's pool of available devices. (See the
Commands Manual for descriptions of these three commands.)
Error Return
If the ac contains -1, no device was associated with the channel.
Related Calls
CLOSE, RELEASE, RESET
Common Errors
Placing the channel number in the ac field.
22-405
RESET [CALLI 0]
RESET [CALLI 0]
Function
Initializes a program. Resets the program's runtime environment
to its initial state.
Calling Sequence
RESET
return
Return
The monitor initializes the program. This includes the following
functions:
o Clears all device allocations except those for devices
assigned by ASSIGN, REASSI, or MOUNT.
o Sets the job's first free location (right half of .JBFF) to
its starting value (left half of .JBSA). This allows buffer
space to be reclaimed when the program is restarted.
o Clears the left half of .JBFF (the job's first free
location).
o Aborts processing of any files that have not been closed to
release the associated I/O channels.
o Sets the user-mode write-protect bit for the high segment.
This prevents inadvertent data storage in the high segment,
and is done even if the segment is nonsharable.
o Unlocks your program, if it is locked in core.
o Releases any realtime devices.
o Resets any high-priority queue values to the value given in
the last HPQ command.
o Resumes timesharing if it was stopped by a TRPSET monitor
call.
o Resets any actions taken by APRENB, HIBER, or UTRP. monitor
calls in your program.
o Clears all program counter flags for your program (except
USRMODE and PUBLIC) that may be set.
22-406
RESET [CALLI 0]
o Clears any process identifications (PIDs) for your job,
except job-wide PIDs.
o Clears the software interrupt facility for your job.
o Releases and dequeues any enqueue locks or requests for your
job.
o Clears all of the data mode bits and the noecho bit for a
terminal. However, if the RESET is executed for a
not-logged-in job, whose program name is LOGIN, the noecho
bit will not be cleared. This allows noecho to be set by the
LOGIN command.
o Removes and undefines all SNOOP. breakpoints.
o Releases the performance meter.
o Clears any large disk buffers set by a UUO.
o Clears any address breaks set by a UUO.
22-407
RTTRP [CALLI 57]
RTTRP [CALLI 57]
Function
Connects a device to or releases it from the realtime interrupt
facility. For a discussion of realtime devices, interrupt modes,
and traps, refer to Chapter 9, Volume 1.
To use the RTTRP call, your job must have the JP.RTT privilege.
To use an EPT-mode trap, your job must have the JP.TRP privilege.
Your job must also have the JP.LCK privilege in order to lock
itself in core on the correct CPU.
Calling Sequence
MOVEI ac,addr
RTTRP ac,
error return
normal return
. . .
addr: argument list
where: addr is the address of the argument list.
The contents of the argument list depend on the interrupt mode
your program is setting up.
Normal Return
The device is connected to or released from the realtime
interrupt facility.
Error Return
The monitor returns one or more of the following error flags in
the ac. Before returning, the monitor scans the entire argument
list to discover as many errors as possible.
Bit Symbol Error
23 RTNEC% Nonexistent CPU.
24 RTJNP% Not enough privileges.
25 RTNC0% Not runnable on CPU0.
26 RTDIU% Device in use by another job.
27 RTIAU% Illegal accumulator used during RTTRP at
interrupt.
28 RTJNL% Job not locked (or not privileged).
29 RTSLE% System limit for realtime devices exceeded.
30 RTILF% Illegal format for I/O instruction.
22-408
RTTRP [CALLI 57]
Bit Symbol Error
31 RTPWI% Pointer word illegal.
32 RTEAB% Error address out of bounds.
33 RTTAB% Trap address bad.
34 RTPNB% PI channel not currently available for
BLKI/BLKO.
35 RTPNA% PI channel not available.
Related Calls
HPQ, TRPSET, UJEN
22-409
RUN [CALLI 35]
RUN [CALLI 35]
Function
Transfers execution control from the current program to another
program. The monitor replaces both the high and low segments of
your address space with the segments of the called program. The
function of the RUN UUO is described in more detail in Chapter 2
Volume 1.
Calling Sequence
|
| MOVSI ac,start-addr-increment
| HRRI ac,addr
| RUN ac,
| error return
| . . .
| addr: SIXBIT/device/
| SIXBIT/filename/
| SIXBIT/extension/ ;or zero
| EXP 0
| / XWD proj,prog \
| | XWD 0,addr1 |
| | XWD 0,core | ;or zero
| \ XWD -1,,addr2 / ;optional
where: start-addr-increment is an increment to the starting
address of the called program. This increment is used to
call indirect command files and should be 0 or 1. If any
other value is used, the meddling bit is set for the job,
unless the program is execute-only. For an execute-only
program, this value can be only 0 or 1.
addr is the address of the 6- or 7-word argument block.
device is the logical or physical name of the device
where the program being called resides.
filename is the name of the file being called (containing
either or both high and low segments).
extension is the file extension of the low segment file
(normally .EXE or blank).
22-410
RUN [CALLI 35]
proj,prog specifies the owner of the called program. If
this word is zero, the monitor assumes that the called
program is in your directory (that is, your PPN is
assumed), or the PPN is determined from the directory
name (for example, SYS=[1,4]). If this word is
[XWD 0,addr1], addr1 points to a PATH. block containing
the complete path for the file. Refer to the description
of the PATH. monitor call for information pertaining to
the format of the PATH. block.
core is the total amount of core to be reserved for the
called program. This word must be included, but may be
zero. For a program that contains both low and high
segments, the amount of core required to load the high
segment is subtracted from the core assignment first.
The amount reserved for the low segment is the remainder.
addr2 contains a section number indicating where the image
should be loaded. Using this argument results in an
error if the .EXE file is not a single section program in
Section 0.
Normally your program sets up only the first two words of the
argument block, leaving the rest of the words in the argument
block zero.
You can omit values and accept defaults for all parameters in the
argument list except device and filename. The defaults are:
extension defaults to .EXE.
PPN defaults to your PPN.
core defaults to the amount required by the new
program.
Normal Return
The new program is started at its new address plus
start-addr-increment. The contents of ac may be changed on the
return, and the new contents are unpredictable, because they vary
from one monitor release to the next. The RUN call also performs
an implicit RESET call.
Error Return
The error return is taken if any errors are detected; the monitor
returns an error code in the ac. Your program can attempt to
recover from an error and continue the program's execution. If
you set the left half of the error return location to a HALT, the
monitor will not return to the program but will print an error
message. Your terminal will be at monitor level.
22-411
RUN [CALLI 35]
If you do not include a HALT in the left half of the error return
location, your program can analyze the error code returned in the
ac. If the error code indicates an error from which you can
recover, your program can issue another RUN monitor call,
possibly including a HALT instruction in the error return
location.
If your program is using overlays, the monitor will not attempt
to return to your program. Therefore, you should place the RUN
monitor call in the low segment of your program, in case the
error is discovered after the high segment has been released. If
the call is issued from the low segment and an error occurs, the
high segment of the program is cleared and must be
re-initialized.
If the call is issued from the high segment and an error occurs,
the monitor may halt the job and print the following message:
?Illegal address in UUO at user PC xxxxxx
For this reason, the RUN call should be given from the low
segment.
See Section 11.14 for a list of error codes.
Related Calls
GETSEG, MERGE.
22-412
RUNTIM [CALLI 27]
RUNTIM [CALLI 27]
Function
Returns the cumulative runtime (in milliseconds or ten
microsecond units) for a specified job.
Calling Sequence
MOVEI ac,jobno
HRLI ac,(RN.PCN) ;optional for high precision
RUNTIM ac,
return
where: jobno is the number of a logged-in job (use 0 for your
own job). You may optionally set the sign bit 1B0
(RN.PCN), to return the runtime for the specified job in
ten microsecond units (high-precision runtime).
Return
The ac contains the cumulative runtime (in milliseconds) for the
specified job. If no such job exists, the ac contains 0.
Examples
MOVEI T1,0
RUNTIM T1,
This code returns the cumulative runtime for the current job in
T1.
22-413
SAVE. [CALLI 210]
SAVE. [CALLI 210]
Function
Saves the program in memory as an executable (.EXE) file on disk.
This call is similar to the SAVE monitor command.
Calling Sequence
|
| MOVE ac,[flag,,addr]
| SAVE. ac,
| error return
| normal return
| . . .
| addr: SIXBIT/device/
| SIXBIT/filename/
| SIXBIT/extension/ ;or zero
| EXP 0
| / XWD proj,prog \
| | XWD 0,,addr1 |
| | XWD 0,0 | ;core argument
| | -n,,addr2 |
| \ XWD 0,core /
where: the flag is bit 0 of the ac. When set, this bit (SS%SSH)
indicates that the program should be saved with a
sharable high segment (similar to SSAVE monitor command).
addr is the address of the argument block, which is
formatted like the argument blocks of GETSEG and RUN
calls. device is the disk name or logical name of the
disk device where the file should be written. filename
and extension contain the file name and file extension of
the new file. Note that extension is optional and
defaults to .EXE. The extension is optional because the
RUN monitor command will not accept file extensions other
than .EXE.
proj,prog specifies the owner of the called program. If
this word is zero, the monitor assumes that your
directory contains the called program (that is, your PPN
is assumed), or the PPN is determined from the device
name (for example, SYS=[1,4]). If this word is
[XWD 0,,addr1], addr1 points to a PATH. block containing
the complete path for the file. Refer to the
PATH. monitor call for information pertaining to the
format of the PATH. block.
22-414
SAVE. [CALLI 210]
Normal Return
The program in memory is written to disk in executable format.
The contents of all accumulators may be changed; the new contents
are not reliable and are subject to change from one monitor
release to the next. The SAVE. call releases channel 0
implicitly.
Error Return
If an error occurs in the process of executing the SAVE. call,
the non-skip return is taken and an error code is returned in the
ac. Refer to Section 11.14 for the list of error codes.
22-415
SCHED. [CALLI 150]
SCHED. [CALLI 150]
Function
Reads or sets system scheduling parameters. JACCT or [1,2]
privileges are required to issue the SCHED. monitor call.
However, the read functions may be used by a user with SPY
privileges, and the write functions are available to users with
POKE privileges.
Calling Sequence
MOVE ac,[XWD len,addr]
SCHED. ac,
error return
normal return
. . .
addr: XWD fcncode,fcnarg
. . .
XWD fcncode,fcnarg
where: len is the length of the argument list.
addr is the address of the argument list.
fcncode is one of the function codes described below.
fcnarg is the address of the argument list for the
corresponding function code.
The function codes, their meanings, and their arguments are:
Code Symbol Function
0 .SCRSI Reads the micro scheduling interval. The
monitor returns the scheduling interval at
fcnarg.
400000 .SCSSI Sets the micro scheduling interval. The word at
fcnarg should contain:
Word Symbol Contents
0 .SCBSI Scheduling interval.
1 .SCRMI Reads the minimum core usage function evaluation
interval. The monitor returns the interval at
fcnarg.
22-416
SCHED. [CALLI 150]
Code Symbol Function
400001 .SCSMI Sets the minimum core usage evaluation interval.
The word at fcnarg should contain:
Word Symbol Contents
0 .SCBMI Minimum core usage interval.
2 .SCRCQ Reads class quotas and flags. The monitor
returns the quotas and flags at fcnarg and
following in the form:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBCQ Class and quota:
Bits Symbol Meaning
0 SC.FCQ Set if quota
is fixed.
1-17 SC.CLN Class number.
18-35 SC.CLQ Class quota.
There is one word of the form of .SCBCQ for each
word specified by the word count.
400002 .SCSCQ Sets class quotas and flags. The data at fcnarg
is the same as that returned by the .SCRCQ
function.
3 .SCRTS Reads the base quantum runtime. The monitor
returns the time slices at fcnarg in the form:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBP1 Base quantum runtime for PQ1.
2 .SCBP2 Base quantum runtime for PQ2.
400003 .SCSTS Sets the base quantum runtime for one or both
queues. The data at fcnarg is the same as that
returned by the .SCRTS function.
22-417
SCHED. [CALLI 150]
Code Symbol Function
4 .SCRUF Reads the desired channel use fraction. This
fraction is the swapping channel utilization
percentage. The monitor returns the channel use
fractions at fcnarg in the form:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBUF Channel number in left half;
use fraction in right half.
There is one word of the form of .SCBUF for each
word specified by the word count.
400004 .SCSUF Sets the desired channel use fraction. The data
at fcnarg is the same as that returned by the
.SCRUF function.
5 .SCRJC Reads the scheduler class for a job. The
arguments at fcnarg are of the form:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBJC Job number in the left half;
class in the right half.
There is one word of the form of .SCBJC for each word specified
by the word count. The monitor returns the
class for each given job.
400005 .SCSJC Sets the scheduler class for a job. The
arguments at fcnarg are the same as those for
the .SCRJC function.
6 .SCRMC Reads the minimum core usage per job. The
monitor returns the minimum core usage at fcnarg
(.SCBMC).
400006 .SCSMC Sets the minimum core usage per job. The
monitor reads the core usage from fcnarg
(.SCBMC).
22-418
SCHED. [CALLI 150]
Code Symbol Function
7 .SCRCU Reads the class usage since startup. The
monitor returns the class runtimes at fcnarg in
the form:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBCU Runtime for class 0.
There is one word of the form of .SCBCU for each
word specified by the word count.
10 .SCREF Obsolete. The offset symbol .SCBEF is also
obsolete.
400010 .SCSEF Obsolete.
11 .SCRMM Reads the minimum core usage multiplier. The
monitor returns the multiplier at fcnarg
(.SCBMM).
400011 .SCSMM Sets the minimum core usage multiplier. The
monitor reads the multiplier from fcnarg
(.SCBMM).
12 .SCRDC Reads the default class for new jobs. The
monitor returns the default class at fcnarg
(.SCBDC).
400012 .SCSDC Sets the default class for new jobs. The
monitor reads the default class from fcnarg
(.SCBDC).
13 .SCRRC Reads the minimum core usage requeue constant.
The monitor returns the constant at fcnarg
(.SCBRC).
400013 .SCSRC Sets the minimum core usage requeue constant.
The monitor reads the constant from fcnarg
(.SCBRC).
14 .SCRPM Reads the minimum core usage maximum. The
monitor returns the maximum (in microseconds) at
fcnarg (.SCBPM).
400014 .SCSPM Sets the minimum core usage maximum. The
monitor reads the maximum (in microseconds) from
fcnarg (.SCBPM).
22-419
SCHED. [CALLI 150]
Code Symbol Function
15 .SCRML Reads quantum multipliers for PQ1, PQ2, and
scale factor. The monitor returns the values at
fcnarg in the format:
Word Symbol Contents
0 .SCBCT Count of the following words.
1 .SCBMP For PQ1, the queue number in
left half, quantum multiplier
in right half.
2 .SCBMQ For PQ2, the queue number in
left half, quantum multiplier
in right half.
3 .SCBMR 3 in left half, scale factor in
right half (SC.BMR==3,,0).
400015 .SCSML Sets quantum multipliers for PQ1, PQ2, and scale
factor. The data at fcnarg must the the same as
that returned by the .SCRML function.
16 .SCRMX Reads the maximum quantum run for PQ1 and/or
PQ2. The monitor returns the maximum quantum
run at fcnarg in the format:
Word Symbol Contents
0 .SCBCT Count of the following words.
1 .SCBMX Queue number in left half,
maximum time slice (in
milliseconds) in right half.
The returned block contains one
word of the form of .SCBMX for
each word specified in the word
count.
400016 .SCSMX Sets the maximum quantum run for PQ1 and/or PQ2.
The data at fcnarg must be in the same format as
that returned by the .SCRMX function.
17 .SCRSQ Reads secondary class quotas. The monitor
returns the quotas at fcnarg in the format:
Word Symbol Contents
0 .SCBCT Count of following words.
1 .SCBSQ Class in left half, quota in
right half.
The data at fcnarg contains one word of the form
of .SCBSQ for each word indicated by the word
count.
22-420
SCHED. [CALLI 150]
Code Symbol Function
400017 .SCSSQ Sets secondary class quotas. The data at fcnarg
must be in the same form as that returned by the
.SCRSQ function.
20 .SCRIQ Reads the time percentage to scan queue just
swapped in before subqueues. The monitor
returns the time percentage at fcnarg (.SCBIQ).
400020 .SCSIQ Sets the time percentage to scan queue just
swapped in before subqueues. The monitor reads
the time percentage from fcnarg (.SCBIQ).
21 .SCRSS Reads swap scan time. The monitor returns the
swap scan time at fcnarg (.SCBSS).
400021 .SCSSS Sets swap scan time. The monitor reads the swap
scan time from fcnarg (.SCBSS).
22 .SCRBB Reads number for background batch subqueue. The
monitor returns the number at fcnarg (.SCBBB).
400022 .SCSBB Sets number for background batch subqueue. The
monitor reads the number from fcnarg (.SCBBB).
23 .SCRBS Reads background batch swap time interval. The
monitor returns the interval at fcnarg (.SCBBS).
400023 .SCSBS Sets background batch swap time interval. The
monitor reads the interval from fcnarg (.SCBBS).
24 .SCRSF Reads scheduler fairness factor. The monitor
returns the fairness factor at fcnarg (.SCBSF).
400024 .SCSSF Sets scheduler fairness factor. The monitor
reads the fairness factor from fcnarg (.SCBSF).
25 .SCRSW Reads swapper fairness factor. The monitor
returns the fairness factor at fcnarg (.SCBSW).
400025 .SCSSW Sets swapper fairness factor. The monitor reads
the fairness factor from fcnarg (.SCBSW).
26 .SCRIO Reads in-core fairness. The monitor returns the
fairness at fcnarg (.SCBIO).
400026 .SCSIO Sets in-core fairness. The monitor reads the
fairness from fcnarg (.SCBIO).
22-421
SCHED. [CALLI 150]
Code Symbol Function
27 .SCRSC Reads SCDCOR. The monitor returns the value of
SCDCOR at fcnarg (.SCBSC).
400027 .SCSSC Sets SCDCOR. The monitor reads the value for
SCDCOR from fcnarg (.SCBSC).
30 .SCRSO Reads the CPU scan order. The monitor returns
the scan order for each CPU at fcnarg+1. The
argument block at fcnarg is the same as the
information you give to set the scan order in
function 400030 (.SCSSO).
400030 .SCSSO Sets the CPU scan order. The argument list at
fcnarg should appear as:
Word Symbol Contents
0 .SCBCT Word count.
1 .SCBSO Scan order for CPU0.
2 .SCBSO Scan order for CPU1.
. . .
Where .SCBSO is 0 if the scan order is
[HPQ,PQ1,PQ2] or 1 if the order is
[HPQ,PQ2,PQ1].
31 .SCRRT Reads dormant segment retention time (in
jiffies). The monitor returns retention time at
fcnarg (.SCBRT).
400031 .SCSST Sets dormant segment retention time. The
monitor reads retention time from fcnarg
(.SCBRT).
32 .SCRFG Reads the free core goal. The monitor returns
the free core goal at fcnarg in the following
format:
Word Symbol Meaning
0 .SCBFG Minimum free core size (goal).
1 .SCBFL Maximum free core size.
Both .SCBFG and .SCBFL are percentages of user
core as determined when the system was booted.
400032 .SCSFG Sets the free core goal. The monitor reads the
goal from fcnarg in the format given in function
.SCRFG.
22-422
SCHED. [CALLI 150]
Normal Return
The function has been performed.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 SCHAC% Address check.
2 SCHUF% Unknown function code.
3 SCHUJ% Unknown job.
4 SCHNP% Not enough privileges.
5 SCHUC% Unknown class.
6 SCHUQ% Unknown queue.
7 SCHNC% Nonexistent channel.
10 SCHEB% Bad exponential factor.
11 SCHMI% Cannot set protection if MCUINT is nonzero.
12 Reserved for use by DIGITAL.
13 SCHNH% Not 100%.
14 SCHFN% Fairness not positive.
15 SCHIC% Illegal CPU number specified in function .SCSSO.
16 SCHUO% Unknown scan order specified in function .SCSSO.
22-423
SCS. [CALLI 213]
SCS. [CALLI 213]
Function
Provides the diagnostic interface to the Systems Communications
Service layer of the System Communications Architecture, allowing
information to be exchanged between jobs on different systems
connected over a CI20.
This monitor call is used in DIGITAL-supplied hardware diagnostic
programs and is not intended to be used in customer programs.
The calling sequences and arguments of SCS. are subject to change
without notice. The program must be run under [1,2] or have
JACCT privileges to use the SCS. UUO.
Calling Sequence
MOVEI ac,addr
SCS. ac,
error return
normal return
addr: len,,function
where: addr is the starting address of the argument block, len
specifies the total length of the argument block, and
function is one of the function codes described below.
The function word is formatted as follows:
Word Field
Symbol Bits Symbol Contents
.SSFNC 1-8 SS.CPU CPU number.
9-17 SS.LEN Length of argument block, including
this word.
18-35 SS.FNC One of the function codes listed
below.
Function codes are:
Code Symbol Meaning
0 .SSCON Requests a connection.
1 .SSLIS Listens for a connection.
2 .SSREJ Rejects a connection request.
3 .SSDIS Disconnects and closes a connection.
4 .SSSDG Sends a datagram.
5 .SSQRD Queues buffer(s) to receive datagram.
6 .SSSMG Sends a message.
22-424
SCS. [CALLI 213]
Code Symbol Meaning
7 .SSQRM Queues buffer(s) to receive message.
10 .SSCSP Returns information about a status of a
connection.
11 .SSRCD Returns configuration data for a remote
system.
12 .SSSTS Returns information about status of a
connection.
13 .SSRMG Receives a message.
14 .SSMAP Maps a buffer for DMA transfer.
15 .SSUMP Unmaps a buffer for DMA transfer.
16 .SSSND Sends data to remove host.
17 .SSREQ Requests delivery of data.
20-21 Reserved.
22 .SSRDG Receives a datagram.
23 .SSACC Accepts a connection request.
24 .SSGDE Returns entry from data request complete
queue.
25 .SSEVT Returns entry from event queue.
26 .SSCRD Cancels datagram receive.
27 .SSCRM Cancels message receive.
30 .SSGLN Gets local node number.
31-34 Reserved.
35 .SSRBS Returns minimum buffer sizes.
36 .SSRPS Returns path status.
Normal Return
The function is performed successfully and the program continues
at the skip return.
Error Return
The function is not performed, and the error code is returned in
the ac. The error codes and their meanings are:
Code Symbol Error
0 SSNPV% Insufficient privileges.
1 SSIFC% Illegal function code.
2 SSARG% Bad argument list length.
3 SSACR% Address check reading argument block.
4 SSACS% Address check storing data.
5 SSCPN% CPU number is out of range.
6 SSNPC% No CI port on specified CPU.
7 SSNNK% CI node number on specified CPU is not known.
10 SSINN% Invalid CI node number.
11 SSNFC% No free core.
12 SSVNO% Virtual circuit is not open.
13 SSICI% Invalid connect identification.
14 SSRQE% Receive queue is empty.
22-425
SCS. [CALLI 213]
Code Symbol Error
15 SSNBQ% No buffer queued for packet reception.
16 SSRCF% Reject connection failed.
17 SSDCF% Disconnect connection failed.
20 SSNFB% No free buffers to send packet.
21 SSQBF% Queue buffers failed.
22 SSCBF% Cancel buffers failed.
23 SSPSF% Packet send failed.
24 SSDQE% Data entry queue empty.
25 SSEQE% Event queue empty.
26 SSCRB% Can't remove buffer from database.
27 SSCUB% Can't unmap buffer.
30 SSNSB% No such buffer name.
31 SSTMS% Too many buffer segment descriptions.
32 SSIDM% Illegal data mode.
33 SSSCP% Segment crosses page boundary.
34 SSSTL% Segment is greater than 1 page.
22-426
SEBLK. [CALLI 214]
SEBLK. [CALLI 214]
Function
SEBLK. is a privileged monitor call used only by DAEMON. It
returns system error block data.
Calling Sequence
MOVE ac,[arglen,,arglst]
SEBLK. ac
error return
normal return
where: arglen is length of the argument list stored at arglst.
Normal Return
The monitor returns information about system errors in the block
starting at arglst. The number of words stored in the monitor's
error block is returned in the ac. This tells you whether your
block was long enough to hold the information; if the block was
not long enough, the monitor truncated the information.
Error Return
One of the following codes is returned in the ac:
Code Symbol Error
0 SBNPV% Job not privileged.
1 SBNEQ% No error blocks on queue.
22-427
SENSE. [CALLI 133]
SENSE. [CALLI 133]
Function
Returns the I/O status bits for a device. I/O status bits can be
cleared individually using the CLRST. monitor call.
Calling Sequence
|
| MOVE ac,[XWD len,addr]
| SENSE. ac,
| error return
| normal return
| . . .
| addr: / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| XWD length,status
| . . .
| status: SIXBIT/name/
| status+1: XWD 0,GETSTS-bits
| status+2: DEVSTS-word
where: len is the length of the argument list, which must be 2.
addr is the address of the argument list.
device is the SIXBIT physical or logical name of an
initialized device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
Device, channo, and UDX are alternate ways of specifying
the device for which you desire the status bits.
length specifies the number of words in the status block.
This value should equal the number of devices multiplied
by 3.
status is the address of the status block.
22-428
SENSE. [CALLI 133]
The status block is returned in the form:
Offset Symbol Contents
0 .SNSDV The SIXBIT name of the device.
1 .SNSST The status bits for the device (GETSTS).
2 .SNSDS The device status (DEVSTS) bits for the device.
DEVSTS bits are from the device DDB, and are
different for each device.
Normal Return
The name and status bits for the device are returned at status.
Error Return
If the SENSE. monitor call is not implemented on your system, the
ac is unchanged; otherwise, the following error code is returned
in the ac:
Code Symbol Error
1 SNSBD% Illegal device specified.
Related Calls
CLRST.
22-429
SETDDT [CALLI 2]
SETDDT [CALLI 2]
Function
Sets the value of .JBDDT in the Job Data Area. Note that .JBDDT
is protected from a direct MOVEM because the monitor has its own
copy of .JBDDT and restores its value at every context switch.
Calling Sequence
MOVE ac,[last-addr,,start-addr]
SETDDT ac,
return
where: last-addr is the last address for DDT and start-addr is
the new start address.
Return
The start address and last address for DDT are set.
22-430
SETLCH [TTCALL 7,]
SETLCH [TTCALL 7,]
Function
Sets the line characteristics for your job's controlling
terminal. The line characteristics can be read using the GETLCH
call.
Calling Sequence
SETLCH [XWD flags,lineno]
return
where: flags are described below.
lineno is the line number for a terminal that can be a
terminal line number (such as 37 for TTY37) or a UDX
(such as UXTRM+37 for TTY37).
If you give a negative number for lineno, the current user
terminal is assumed. Flags can be changed only for the job's
controlling terminal.
The flags are:
Flag Symbol Characteristic
13 GL.LCM Terminal in lowercase mode.
14 GL.TAB Terminal has tab capability.
15 GL.LCP Local copy only (no echo).
16 GL.PTM The CTRL/Q papertape switch is on.
17 GL.NEC No echo from program.
Return
The line characteristics are set as requested. The argument
block is not changed.
Related Calls
GETLCH, TRMOP.
Common Errors
Using an ac in the calling sequence.
22-431
SETNAM [CALLI 43]
SETNAM [CALLI 43]
Function
Changes the name of the current program in the monitor's job
table. This name is used by some monitor commands, such as
USESTAT (CTRL/T) and SYSTAT.
The SETNAM monitor call also clears the SYS program bit (which is
used by GALAXY), clears the execute-only and JACCT bits, and
causes a version typeout if a version watch has been set with the
SET WATCH VERSION monitor command or with the .STWTC, ST.WVR
function of SETUUO.
Calling Sequence
MOVE ac,[SIXBIT/name/]
SETNAM ac,
return
where: name is the new program name for the job.
Return
The new program name is entered in the monitor's job table.
Examples
MOVE T1,[SIXBIT/NEWNAM/]
SETNAM T1,
This code changes the program name for the job to NEWNAM.
22-432
SETSTS [OPCODE 060]
SETSTS [OPCODE 060]
Function
Sets bits in the file status word for a device. Use FILOP. to
perform a SETSTS for an extended I/O channel.
Calling Sequence
SETSTS channo,bits
return
where: channo is the number of an initialized channel.
bits are I/O status bits. For a complete list of I/O
status bits, see the appropriate device chapter in Volume
1.
Return
The I/O status bits are set.
Examples
GETSTS CHN,T1 ;get status in T1
TRZ T1,IO.ERR ;keep mode and device-
; dependant bits
SETSTS CHN,(T1) ;clear errors
Related Calls
CLRST., GETSTS
Common Errors
1. If the SETSTS monitor call is done for a channel that has not
been initialized, the monitor stops the job and prints:
?IO to unassigned channel at user PC nnnnnn
2. If the data mode is illegal for the device, the monitor
prints:
?Illegal data mode for device xxxnnn; UUO at user PC
nnnnnn
22-433
SETUUO [CALLI 75]
SETUUO [CALLI 75]
Function
Sets system or job parameters. To set system parameters, your
job must have the JACCT bit set, or must be logged in under
[1,2], and may not be a batch job.
Calling Sequence
MOVE ac,[XWD fcncode,argument]
SETUUO ac,
error return
normal return
where: fcncode is one of the function codes described below.
argument is an argument for the given function code.
The function codes and their meanings are:
Code Symbol Function
0 .STCMX Sets the maximum core size that a user job may
use (the sum of the high and low segments,
CORMAX). The minimum value is set by MONGEN.
The maximum value is the size of user core in
words.
1 .STCMN Sets the guaranteed amount of contiguous core
that a single unlocked job can use (CORMIN).
The valid values are in the range 0 to CORMAX.
This argument is referred to as CORMIN.
2 .STDAY Obsolete.
3 .STSCH Sets parameters in the %CNSTS word in GETTAB
Table 11. The argument gives the flags. The
flags and their meanings are:
Bit Symbol Meaning
26 ST%NDL No automatic down-line load of
DC72, DC71, or DAS80-series
remote station.
27 ST%NOP No operator coverage.
28 ST%NSP Allow device unspooling.
29 ST%ASS Allow device assignment and
initialization.
32 ST%NRT No remote TTYs.
33 ST%BON LOGINs for batch jobs only.
22-434
SETUUO [CALLI 75]
Code Symbol Function
Bit Symbol Meaning
34 ST%NRL No remote LOGINs.
35 ST%NLG No LOGINs except CTY.
4 .STCDR Specifies the input name for the card reader
job, which is stored in the left half of
location .GTSPL. The argument is given in
single quotes that contain three SIXBIT
characters forming the job name. For example,
the MOVE statement in the calling sequence might
be:
MOVE AC1,[XWD .STCDR,'XYZ']
to specify the input name XYZ.
5 .STSPL Sets or clears the spooling state for the job's
devices. You specify the flag bits in the ac
and they are set in bits 31 to 35 of .GTSPL.
The flags and their meanings are:
Bit Symbol Meaning
31 JS.PCR Spool card reader.
32 JS.PCP Spool card punch.
33 JS.PPT Spool paper tape punch.
34 JS.PPL Spool plotter.
35 JS.PLP Spool line printer.
6 .STWTC Sets flags for SET WATCH routine (refer to
monitor command SET WATCH). The argument gives
one or more of the flags, which are:
Bit Symbol Meaning
9 ST.WCN /MESSAGE:CONTINUATION.
10 ST.WFL /MESSAGE:FIRST.
11 ST.WPR /MESSAGE:PREFIX.
11 ST.WMS /MESSAGE:ALL.
| 18 ST.WCX Watch contexts.
19 ST.WDY Watch daytime at start.
20 ST.WRN Watch runtime.
21 ST.WWT Watch wait time.
22 ST.WDR Watch disk reads.
23 ST.WDW Watch disk writes.
24 ST.WVR Watch versions.
25 ST.WMT Watch statistics for magtapes.
26 ST.WFI Watch file accessed.
19-26 ST.WAL Watch all.
22-435
SETUUO [CALLI 75]
Code Symbol Function
7 .STDAT Sets the system date as the number of days since
January 1, 1964, in 15-bit form. The argument
gives the number of days as:
((year-1964)12+(month-1))31+(day-1)
10 .STOPR Sets the SIXBIT name of the terminal to be used
as the operator terminal. The argument gives
the address of the word containing the name.
11 .STKSY Sets the decimal number of minutes until
timesharing ends; this value is stored in
SYSKTM. If SYSKTM is 0, timesharing is
continued indefinitely.
12 .STCLM Sets the maximum number of words of memory that
the job can use. This value is converted from
words to pages (at 512 words/page) and stored in
location JB.CLR in table .GTLIM. This value may
be set to zero, indicating that there is no
maximum limit.
13 .STTLM Sets the maximum number of seconds the job can
run. The argument is the number of seconds
permitted. This function cannot be used by
batch jobs that already have a time limit.
However, this function is allowed for non-batch
jobs, batch jobs with no time limit, and
privileged batch jobs with or without a time
limit.
14 .STCPU Specifies the CPU on which the job is to run.
The argument gives one of the following flags:
Bit Symbol Meaning
30 SP.CR5 Run on CPU5.
31 SP.CR4 Run on CPU4.
32 SP.CR3 Run on CPU3.
33 SP.CR2 Run on CPU2.
34 SP.CR1 Run on CPU1.
35 SP.CR0 Run on CPU0.
.STCPU is a privileged function, requiring
JP.CCC privileges. The error return is taken if
you attempt to change the CPU specification on a
single-CPU system.
22-436
SETUUO [CALLI 75]
Code Symbol Function
15 .STCRN Sets runnability for CPUs. The argument gives
one or more of the following flags:
Bit Symbol Meaning
30 SP.CR5 CPU5 is runnable.
31 SP.CR4 CPU4 is runnable.
32 SP.CR3 CPU3 is runnable.
33 SP.CR2 CPU2 is runnable.
34 SP.CR1 CPU1 is runnable.
35 SP.CR0 CPU0 is runnable.
The error return is taken if you attempt to
issue this function on a single-CPU system.
16 .STLMX Sets the maximum number of jobs that can be
logged in at any one time; this value is stored
in location LOGMAX. The argument gives the
maximum number of jobs; this number must be at
least 1, but no more than the system maximum,
which is defined by the symbol JOBN. JOBN is
the system limit defined when the monitor is
generated by MONGEN.
If you give a number smaller than the number of
jobs currently logged in, no new jobs can log in
until the number of jobs falls below LOGMAX.
You can obtain the number of jobs currently
logged in from the location %CNLNM in GETTAB
table .GTCNF.
17 .STBMX Sets the maximum number of batch jobs that can
be logged in at any one time; this value is
stored in location BATMAX. The argument gives
the maximum number of batch jobs; this number
must be less than the system maximum, which is
defined by the symbol JOBN.
You can obtain the number of batch jobs
currently logged in from the location %CNBNM in
GETTAB table .GTCNF.
20 .STBMN Sets the number of jobs reserved for batch
processing (BATMIN). The argument gives the
minimum number of jobs reserved. The value must
be in the range 1 to the value of BATMAX-1.
22-437
SETUUO [CALLI 75]
Code Symbol Function
21 .STDFL Sets the action to occur if the user disk space
is filled for the job. The argument is one of
the following codes:
Code Symbol Meaning
0 .DFPSE Pause when disk filled for job.
1 .DFERR Error when disk filled for job
or the user's quota has been
exceeded.
Any other value for argument returns the current
setting for .STDFL in the ac; the initial
default setting is .DFERR.
22 .STMVM Sets the system-wide virtual memory limit
(GVPL). The value returned in ac depends on the
given argument:
o If the given argument is less than the
current virtual memory page count, the value
returned is the total amount of virtual
memory in use by all virtual memory users.
o If the given argument is greater than the
current available swapping space, the value
returned is the total amount of available
swapping space.
o If the given argument is greater than the
total amount of virtual memory currently in
use, the value returned is the given
argument.
23 .STMVR Obsolete. This historical SETUUO function
always takes the error return and clears the ac.
24 .STUVM Sets the maximum virtual memory page limit and
the maximum physical memory page limit. The
argument gives the address of the word whose
format is:
LH = maximum virtual page limit (MVPL)
RH = maximum physical page limit (MPPL)
If the left half of the word (MVPL) is 0, the
user cannot use the virtual memory option. When
MVPL is set to 0, MPPL should also be set to 0.
If the right half (MPPL) is 0, the user can use
all of the system's physical memory.
22-438
SETUUO [CALLI 75]
Code Symbol Function
25 .STCVM Sets the current memory maximum. The argument
is the address of a word whose format is:
LH = current virtual page limit (CVPL)
RH = current physical guideline or limit
(CPPL)
The left half (CVPL) of the word at the
indicated address contains the current virtual
page limit.
If bit 18 (ST.VSG) is 0, the right half (CPPL)
contains the current physical page guideline; if
bit 18 is 1, bits 19 to 35 contain the current
physical page limit. A guideline is an
approximate physical page limit.
The guideline algorithm allows you to set a
memory limit that will not be strictly enforced.
The page fault handler will attempt to meet the
page limit within a window of approximation,
allowing slight over-allocation to accommodate
the program. If you set the ST.VSG bit, the
allocation is taken as a limit, and that limit
is strictly enforced.
26 .STTVM Sets the time interval between virtual time
traps in milliseconds. A virtual time trap
causes a Code 4 page fault to the page fault
handler each time the time interval has elapsed.
The argument gives the number of milliseconds
between traps.
27 .STABK Sets the address break condition. On a normal
return, the new address break condition and the
break address have been set. The address
conditions are specified in the word pointed to
by the argument. These conditions are:
Bits Symbol Contents
0 ST.AEX Set to break on EXECUTE.
1 ST.ARD Set to break on READ.
2 ST.AWR Set to break on WRITE.
3 ST.AUU Set to break on monitor
reference.
| 4-8 ST.ASN Specify the section number for
| the break address.
22-439
SETUUO [CALLI 75]
Code Symbol Function
Bits Symbol Contents
9-17 ST.ACT The number of times the break
address is to be referenced
before an interrupt occurs.
18-35 ST.ADR Sets the break address.
To clear the address break, clear bits 0 through
3.
If you have enabled for address break
interrupts, the PSI system will interrupt on an
address break. If the PSI system is not
enabled, the monitor will stop your job and
display the following message on your terminal:
%Address break at user PC xxxxxx
30 .STPGM Sets the name of a program that will run when
the current program session finishes executing.
You must run the program executing this SETUUO
from SYS:, under [1,2], or with JACCT privilege
set. The argument block is:
EXP flag ;Bits 2-35 reserved
SIXBIT /progra/ ;progra is program name
The monitor does an implied RUN UUO on
SYS:progra.EXE when the current program session
ends. Program session termination occurs under
one of the following conditions:
o When Bit 0 of the flag is set, the session
terminates whenever the job would otherwise
enter monitor mode (for instance, EXIT UUO,
^C, illegal memory reference, or swap read
error). If the job becomes detached,
issuing the unprivileged ATTACH command (or
the ATTACH UUO) does not attach you to the
job in monitor mode. You will attach in
user mode instead. The DETACH function of
the ATTACH UUO allows you to detach, leaving
your terminal in monitor mode.
22-440
SETUUO [CALLI 75]
Code Symbol Function
o When Bit 0 of the flag is clear, the session
terminates whenever you execute a command
that destroys the core image. The RUN UUO
executes SYS:progra.EXE instead of whatever
command you issued. You can still enter
monitor mode when your program terminates,
or when you issue an ATTACH command. You
may then execute any command that does not
change the core image, as well as the KJOB
command. Commands that automatically save
the current context and push to a new one do
not change the core image.
The status of .STPGM remains in effect until it
is explicitly cleared by a privileged program,
or the job logs out. Whenever .STPGM is in
effect, the program may execute RUN UUOs on any
file. Control may even transfer to a program
that is not privileged to execute this SETUUO.
If .STPGM specifies an inaccessible file,
SYS:LOGOUT will be run when the program session
terminates.
31 .STDFR Sets deferred spooling. If argument is
non-zero, spooled output will not be queued
until the job logs out. If argument is zero,
spooled output will be queued as each file is
closed.
32 .STHST Sets the host system. This function logically
attaches the controlling terminal to the
specified host system in an ANF-10 network. The
job on the previous system becomes detached.
The calling sequence is:
MOVE ac,[.STHST,,addr]
SETUUO ac,
error return
normal return
. . .
addr: node number or SIXBIT node name
22-441
SETUUO [CALLI 75]
Code Symbol Function
33 .STDEF Sets default values for job-wide parameters.
The calling sequence for the .STDEF function is:
MOVE ac,[XWD .STDEF,addr]
SETUUO ac,
error return
normal return
. . .
addr: XWD arglen,subfcncode
argument
where: arglen gives the number of arguments to
follow.
subfcncode is one of the following subfunction
codes:
Code Symbol Subfunction
0 .STDPC Set default protection code.
addr+1 contains the new default
protection code.
1 .STDNB Set default number of disk
buffers. addr+1 contains the
new default number of disk
buffers.
2 .STDAD Controls whether LOGIN will ask
you about attaching to this job
should you previously have
detached from it. JD.DAD in
.GTDFL contains the value of
the flag.
Argument JD.DFL Action
zero clear LOGIN will
ask about
this job.
non-zero set LOGIN does
not ask if
you want to
attach to
this job.
3 .STDSB Sets the default size of a disk
buffer. Refer to SET BIGBUF
monitor command. addr+1
contains the new disk buffer
size (value is number of blocks
per buffer).
22-442
SETUUO [CALLI 75]
Code Symbol Function
34 .STPRV Sets the privilege and capability words. The
calling sequence for the .STPRV function is:
MOVE ac,[XWD .STPRV,arglst]
SETUUO ac,
. . .
arglst: XWD 0,subfcncode
argument
subfcncode is one of the following subfunction
codes:
Code Symbol Subfunction
0 .STCPW Sets entire privilege word.
1 .STCPS Sets specified bits of
privilege word.
2 .STCPC Clears specified bits of
privilege word.
3 .STCCW Sets entire capability word.
4 .STCCS Sets specified bits of
capability word.
5 .STCCC Clears specified bits of
capability word.
NOTE
You can always clear bits in the privilege word.
However, you can set only those bits in the
privilege word that are set in the capability word,
unless you are a privileged job.
35 .STBSN Sets batch stream number (settable only once per
instance).
36 .STWTO Sets write-to-operator values. Refer to GETTAB
table .GTOBI.
37 .STCDN Sets CPU up/down status. To control the CPU
up/down status, set the appropriate bits in the
argument, from the following list:
Bit Function
18 Remove CPU from system.
19 Suspend the CPU.
20 Add the CPU to the system.
The CPU number must be stored in bits 33-35 of
the argument.
22-443
SETUUO [CALLI 75]
Code Symbol Function
40 .STCSB Sets or clears cache bits. The cache can be
enabled or disabled for the monitor's low
segment by setting the argument to 1 to enable
cache, or 0 to disable cache.
41 .STFPS Obsolete.
42 .STOPP Allows various levels of operators to run OPR
without [1,2] privileges and without having full
file access. This value may be read from GETTAB
table .GTOBI, and will be be used by LOGIN.
43 .STQST Sets queue structure. This sets the file
structure on which GALAXY queues will be stored.
44 .STCSZ Sets the size of the software disk cache in
blocks. This value can be set with MONGEN
symbol M.CBMX. The default value of M.CBMX is
the number of jobs on the system. The .STCSZ
function is illegal if M.CBMX=0. The argument
for this function specifies the number of disk
blocks for the cache.
45 .STEBP Sets the EDDT breakpoint facility. The argument
to this function is either 0 (to disable the
facility) or 1 (to enable the facility).
46 .STBPT Sets the DDT breakpoint facility. The argument
to this function is either 0 (to disable the
facility) or 1 (to enable the facility).
47 .STTMS Sets the system time of day. Specify the time
as the number of seconds past midnight.
|
| 50 .STCXP Sets the maximum core size that a user job may
| use (CORMAX). The maximum value is the size of
| the user core in pages. Set Bit 18 of this word
| to reduce the maximum core size gradually
| ("soft" CORMAX). Larger jobs will continue to
| run until they contract below the soft CORMAX
| limit, then will not grow beyond this size
| again.
51 .STCNP Sets the guaranteed amount of contiguous core
that a single unlocked job can use (CORMIN),
with the argument in pages.
Normal Return
The function is performed and the ac is unchanged.
22-444
SETUUO [CALLI 75]
Error Return
If the ac is cleared, you do not have sufficient privileges or
you gave an illegal job number, CPU number, or argument.
If the ac is not changed on an error return, the function you
requested is not implemented in the monitor.
Otherwise, one of the following error codes can be returned in
the ac:
Code Symbol Error
0 STNAR% Specified CPU(s) not running (functions .STCPU
and .STCRN).
1 STDHP% Insufficient privileges to perform specified
function.
2 STISN% Illegal structure name (function .STQST).
3 STITM% Illegal time (resulting time would be greater
than 23:59:59).
Related Calls
JBSET.
22-445
SETUWP [CALLI 36]
SETUWP [CALLI 36]
Function
Sets or clears user-mode write protection for the job's high
segment. You must use the SETUWP call to clear write protection
before your program can modify its high segment.
Because the previous setting of this bit is returned in ac, you
can write subroutines that preserve the previous setting and
restore them before returning.
Calling Sequence
MOVEI ac,fcncode
SETUWP ac,
error return
normal return
where: fcncode is one of the following function codes:
Code Function
0 Write-enables the high segment.
1 Write-protects the high segment.
Normal Return
The user-mode write protection bit is set as specified, and the
previous setting is returned in the ac.
Error Return
The error return is taken under the following conditions:
o If the high segment is a SPY segment.
o If the high segment has been meddled.
o If the user does not have the access privileges required to
access the specified high segment.
22-446
SKPINC [TTCALL 13,]
SKPINC [TTCALL 13,]
Function
Skips the next program instruction if at least one character can
be input from the job's controlling terminal. The SKPINC call
does not input a character. SKPINC clears the CTRL/O output
state and sets the terminal to "character mode", preventing the
monitor from processing control characters, such as DELETE and
CTRL/U, as input line editing commands.
This call is useful in a compute-bound program that should check
occasionally for user input.
Calling Sequence
SKPINC
return 1
return 2
where: the call returns to return 1 if there is no user input,
or to return 2 is there is user input.
Related Calls
SKPINL
22-447
SKPINL [TTCALL 14,]
SKPINL [TTCALL 14,]
Function
Skips the next instruction if at least one line can be input from
the job's controlling terminal. SKPINL sets the terminal to
"line mode" and clears the CTRL/O output state.
Calling Sequence
SKPINL
return 1
return 2
where: the call returns to return 1 if a complete line has not
been typed, or to return 2 if a complete line has been
typed.
Related Calls
SKPINC
22-448
SLEEP [CALLI 31]
SLEEP [CALLI 31]
Function
Causes your program to become dormant for a specified number of
real-time seconds.
Calling Sequence
MOVEI ac,seconds
SLEEP ac,
return
where: seconds gives the number of seconds that the job is to
sleep. If you give seconds as 0, the program will sleep
for one clock tick. The maximum sleep time is 68 seconds
(or 82 seconds for systems using 50 Hz frequency). If
you require a longer sleep period, use the HIBER monitor
call.
Return
Your job becomes dormant and the monitor sets the JBTST2 bit,
JS.SLP. The monitor will clear this bit when the specified time
has elapsed and your job becomes runnable again. All potential
job-wakers should check this bit and wake a job only if the bit
is cleared.
Examples
MOVEI T1,1
SLEEP T1,
This code puts your job to sleep for 1 second.
Related Calls
HIBER
22-449
SNOOP. [CALLI 176]
SNOOP. [CALLI 176]
Function
Allows privileged programs to insert breakpoints in the monitor
that trap to a user program. The user program must be locked in
core when the trap occurs (refer to LOCK monitor call). This
feature is used for fault insertion, performance analysis, and
trace functions. Only one job can use SNOOP. at any time.
CAUTION
Improper use of the SNOOP. call can cause the
system to fail in a number of ways. User
programs may require special code for
multiprocessor systems because the monitor may be
executing the same code simultaneously on several
systems and at different interrupt levels.
Refer to Chapter 10 for more information about the SNOOP.
monitor call. Do not attempt to use this call until you are
familiar with its operation.
Calling Sequence
MOVE ac,[XWD fcncode,addr]
SNOOP. ac,
error return
normal return
. . .
addr: argument list
where: fcncode is one of the function codes described below.
addr is the address of the argument list. The words at
addr depend on the given function.
22-450
SNOOP. [CALLI 176]
The function codes and their meanings are:
Code Symbol Function
0 .SODBP Defines breakpoints. This function is illegal
if breakpoints have been inserted.
The argument list for the .SODPB function is:
arglst: EXP arglength
EXP symbol checksum
EXP address
instruction
. . .
EXP address
instruction
where: arglength is the length of the argument
list. This must be 2 + the number of
address-instruction pairs in the
argument list times 2 .
symbol checksum is the checksum from the
current monitor's symbol table.
The checksum is required to ensure that the user
is setting breakpoints in the intended monitor.
Your program can obtain the version of the
monitor that is read in by BOOTS from GETTAB
table .GTCNF, where the relevant items are:
Offset Item Contents
137 %CNBCP Bootstrap CPU number.
140 %CNBCL Bootstrap line number.
141 %CNNCR Number of CPUs allowed to
run.
142 %CNMBS Bootstrap file structure.
143 %CNMBF Bootstrap file name.
144 %CNMBX Bootstrap file extension.
145 %CNMBD Bootstrap file directory.
155 %CNSF1 Bootstrap first SFD.
156 %CNSF2 Bootstrap second SFD.
157 %CNSF3 Bootstrap third SFD.
160 %CNSF4 Bootstrap fourth SFD.
161 %CNSF5 Bootstrap fifth SFD.
22-451
SNOOP. [CALLI 176]
Code Symbol Function
The checksum is followed by a series of word
pairs, each of which defines a breakpoint by
specifying, in the first word of each pair, the
monitor virtual address where the new
instruction is to be placed, and, in the second
word of the pair, the new instruction to be
inserted. Specifically, the argument list for
SNOOP. function 0 is:
Word Symbol Contents
0 .SOLEN The length of the argument list,
(the number of breakpoints being
defined times two, plus two).
1 .SOMSC The checksum of the monitor
symbol table.
2 .SOMVA Monitor virtual address where
new instruction is to be
inserted.
3 .SOBPI New instruction.
.SOMVA and .SOBPI are repeated for each replaced
instruction.
1 .SOIBP Inserts all breakpoints that have been defined
using function 0. Your program must be locked
in contiguous executive virtual memory to use
this function (see the LOCK monitor call).
2 .SORBP Removes inserted breakpoints from monitor code.
3 .SOUBP Undefines breakpoints that have been removed
using function 2.
4 .SONUL Null function. This function allows you to
execute code inserted at label BP$000, after
ensuring that your job owns the SNOOP resource.
This may be used by a program that must execute
code in monitor context and wants to ensure that
only this program can invoke the inserted code.
If you do not own the SNOOP resource, the
instruction at BP$000 is not executed, and the
error code SOSAS% is returned.
22-452
SNOOP. [CALLI 176]
Normal Return
The indicated function has been performed.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 SOIAL% Illegal argument list.
2 SONPV% Not enough privileges.
3 SOSAS% Another program already snooping.
4 SOMBX% Maximum number of breakpoints exceeded.
5 SOIBI% Breakpoints already inserted.
6 SONFS% No monitor free core available.
7 SOADC% Address check.
10 SOINL% Program not locked in contiguous executive
virtual memory.
11 SOWMS% Monitor symbol table checksum does not match.
Examples
The monitor computes the symbol table checksum in the following
manner:
MOVE T1,.JBSYM
SETZM CHKSUM
LOOP: MOVE T2,(T1)
EXCH T2,CHKSUM
ROT T2,1
ADD T2,CHKSUM
EXCH T2,CHKSUM
AOBJN T1,LOOP
.
.
.
MOVE T1,[XWD .SODBP,PUTEM]
SNOOP. T1,
JRST NOGOOD
MOVE T1,[XWD .SOIBP,0]
SNOOP. T1,
JRST NOBTTR
.
.
.
PUTEM: EXP 6
EXP MONITOR-CHECKSUM
EXP 12345
JRST HOOK1
EXP 12355
JRST HOOK2
22-453
SNOOP. [CALLI 176]
At this point the breakpoints have been inserted. To remove
them:
.
.
.
MOVE T1,[XWD .SORBP,0]
SNOOP. T1,
JRST BUMMER
MOVE T1,[XWD .SOUBP,0]
SNOOP. T1,
JRST LOSTIT
.
.
.
22-454
SPPRM. [CALLI 172]
SPPRM. [CALLI 172]
Function
Sets parameters for spooled files.
Calling Sequence
MOVE ac,[length,addr]
SPPRM. ac,
error return
normal return
. . .
addr: function code
device-id
parameters
.
.
.
where: length is the length of the argument list.
addr is the address of the argument list; and the data at
addr is listed below.
function code specifies the type of file.
device-id identifies the device.
parameters describes the characteristics of the file
processing to be performed. These parameters are
optional.
Specifically, the argument list is:
Word Symbol Contents
0 .SPPFN Function code, one of the following:
Code Symbol Function
1 .SPSFP Sets spooled file parameters.
2 .SPSPR Sets spooled parameters for
renamed files.
1 .SPPDN SIXBIT name of spooled device, channel number of
spooled file, or the UDX of the device. The
following words are optional
2 .SPPCP Number of copies.
22-455
SPPRM. [CALLI 172]
Word Symbol Contents
3 .SPPFM SIXBIT forms name.
4 .SPPLM Limit.
5 .SPPSF Spooling flags:
Bits Symbol Meaning
1-2 SP.DFR Deferred/immediate flag.
Value Symbol Setting
1 .SPDFD Deferred. The
spooler should
not start
processing the
file until the
user job logs
out.
2 .SPDFI Immediate.
Begin spooling
immediately.
30-35 SP.TYP Type of device, as reported by
DEVTYP monitor call.
6 .SPPDA Device attributes:
Bits Symbol Attribute
0 SP.UPC Uppercase (LPT).
1 SP.LWC Lowercase (LPT).
18 SP.PHY Physical unit is given in
SP.UNI.
28-35 SP.UNI Physical unit number (if SP.PHY
set).
7 .SPPND Node at which processing is to be done.
10 .SPPAF Time at which to begin processing (similar to
/AFTER switch).
11 .SPNM1 In-your-behalf user name (word 0 of word pair)
in SIXBIT.
12 .SPNM2 Second word of user name, in SIXBIT.
13 .SPMAX Maximum length of argument block.
22-456
SPPRM. [CALLI 172]
Normal Return
The specified parameters are set.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-1 SPPAC% Address check.
0 SPPIA% Illegal length for argument list.
1 SPPID% Illegal device.
2 SPPNA% Device not assigned or initialized.
3 SPPNS% Device not spooled.
4 SPPNC% No free core for spooled parameter block.
5 SPPIF% Illegal function code.
22-457
SPY [CALLI 42]
SPY [CALLI 42]
Function
Maps monitor section zero low-segment address space into your
program's high segment. Use of the SPY monitor call requires
that bit 16 (JP.SPA) or bit 17 (JP.SPM) in the privilege word
.GTPRV be set. The SPY segment cannot be write-enabled.
The SPY monitor call can be used to examine the monitor during
timesharing; it allows read-only access to monitor locations.
The SPY segment size cannot be changed by a CORE monitor call; if
you attempt to do this, the CORE call will take its error return.
Calling Sequence
MOVEI ac,monitoraddr
SPY ac,
error return
normal return
where: monitoraddr is the highest exec virtual (monitor) address
desired. Monitor low-segment core from 0 to monitoraddr
is mapped into user high-segment core from 400000 to
400000+monitoraddr. Therefore the value of monitoraddr
can be any value between 0 and 377777.
Note that you cannot save this portion of memory with the SAVE.
monitor call.
Normal Return
The desired monitor core is mapped into your program's high
segment.
Error Return
The error return occurs if you use an invalid value for
monitoraddr, or if your program does not have the required
privileges.
22-458
SPY [CALLI 42]
Examples
This code maps some of the monitor's section zero low segment.
MOVE T1,[%CNSIZ]
GETTAB T1,
HALT
SPY T1,
JRST ERROR
Related Calls
PAGE., PEEK, POKE.
22-459
STATO [OPCODE 061]
STATO [OPCODE 061]
Function
Tests the I/O status word for a device and skips if any of the
specified bits are set. Use FILOP. to perform a STATO for an
extended I/O channel. The I/O status bits are defined
differently for each device. Therefore, the bits appropriate to
each device are described in Volume 1 in the chapter on that
device.
Calling Sequence
STATO channo,mask
return 1
return 2
where: channo is the number of an initialized channel.
mask is a halfword of bits, where each bit sets a
corresponding bit in the I/O status word. The I/O status
word is described in Volume 1, in each chapter that
pertains to a specific device.
The I/O status bits are a set of 18 bits (right half) that
reflect the current state of a file transmission. They are
initially set by your program with the INIT/OPEN monitor call.
Thereafter, the monitor sets the bits, but your program can test
and reset them with any of several monitor calls.
Return
The call returns to return 1 if all of the specified bits are 0,
or to return 2 if any of the specified bits are set to 1.
Examples
See OPEN call.
Related Calls
STATZ
22-460
STATZ [OPCODE 063]
STATZ [OPCODE 063]
Function
Tests the I/O status (also called "file status") word for a
device and skips if all of the specified bits are cleared. Use
FILOP. to perform a STATZ on an extended I/O channel. For a
complete list of I/O status bits, refer to the appropriate device
chapter in Volume 1.
Calling Sequence
STATZ channo,mask
return 1
return 2
where: channo is the number of an initialized channel.
mask is a halfword in which each bit that you set
corresponds to a bit in the I/O status word.
The I/O status bits are a set of 18 bits (right half) that
reflect the current state of a file transmission. They are
initially set by your program with the INIT/OPEN monitor call.
Thereafter, the monitor sets the bits, but your program can test
and reset them with any of several monitor calls.
Return
The call returns to return 1 if one or more of the specified bits
is 1, or to return 2 if all of the specified bits are 0.
Related Calls
STATO
22-461
STRUUO [CALLI 50]
STRUUO [CALLI 50]
Function
Modifies the search list for a job or for the system. Except for
function 0, the functions and calling sequence for the STRUUO
monitor call are subject to change; therefore you should not use
anything but function 0 in user programs. All functions except 0
are privileged functions.
Calling Sequence
MOVE ac,[XWD len,addr]
STRUUO ac,
error return
normal return
. . .
addr: fcncode
first argument
. . .
last argument
where: len is the length of the argument list.
addr is the address of the argument list. The format of
the argument block is different depending on the function
code specified in the first word of the argument block.
fcncode is one of the function codes described below; the
words up through last argument are arguments for the
given function. The function codes and their meanings
are described below:
Code Symbol Function
0 .FSSRC Defines a new job search list.
The format of the argument block is shown below:
Word Symbol Contents
0 .FSFCN The function code. (.FSSRC)
1 .FSCSO Offset to first word of file
structure block, as used for
argument list to JOBSTR monitor
call.
22-462
STRUUO [CALLI 50]
Code Symbol Function
The first word of the argument block is followed
by blocks of three words each. Each three-word
block contains, in the first word, the structure
name; in the second word, zero; and in the third
word, flags that are described for the JOBSTR
monitor call.
Your program cannot create files on a file
structure unless it has access to the file
structure. However, by using the .FSSRC
function your program can add a file structure
to its search list. If your program attempts to
delete a file structure from its search list,
the monitor moves the file structure's name from
the job's active search list to its passive
search list. To remove the file structure from
the active or passive search list, issue the
DISMOUNT monitor command.
1 .FSDSL Defines a new search list for a job or for SYS.
MOUNT uses this function to complete the
mounting or dismounting procedures and to add or
delete file structures from another job's search
list. The argument block for the .FSDSL
function is shown below:
Word Symbol Contents
0 .FSFCN Function code. (.FSDSL)
1 .FSDJN The number of the job whose
search list is to be defined.
2 .FSDPP The project-programmer number of
the job.
3 .FSDFL The flag word. If bit 35 is
set, (DF.SRM), the monitor
removes all deleted file
structures from the job's search
list and decrements the file
structure's mount count. If bit
35 is not set, the monitor
places all deleted file
structures in the passive search
list. To delete a file
structure, it must have been
present in the current search
list and not listed in the
argument block.
22-463
STRUUO [CALLI 50]
Code Symbol Function
Word Symbol Contents
4 .FSDSO Offset to first word of JOBSTR
argument block.
The argument block contains as its first four
words: the function code, a job number, a
project-programmer number, and a flag word.
These four words are followed by one or more
three-word entries (each is an argument block
like that used by the JOBSTR call).The entries
specify the file structures to be in the search
list. The order in which the file structures
appear in the argument block is the order in
which they will appear in the search list.
If the job number and the project-programmer
number are both -1, the monitor assumes the
search list for your job is to be defined. If
the job number is 0, the monitor ignores the
project-programmer number and modifies the
system search list (SYS). If a value other than
-1 or 0 is specified, the monitor defines the
search list of the job with the specified job
number and project-programmer number. To
indicate the FENCE, your program must substitute
XWD 0,0 for SIXBIT/name/ in the first word of
the three-word entry. When your program
specifies the FENCE there will be three
consecutive zero words in the three-word entry.
2 .FSDEF Makes a new file structure available to users
(for example, defines a new file structure).
The file structure name, status, list of drives
and their associated units (packs), and
information for initializing components of the
monitor data base are specified in the argument
block. Specifically, the function does the
following:
o Builds a prototype structure data block.
o Links and initializes all necessary Unit
Data Blocks.
o Allocates core and initializes the SPT
tables and SAB rings.
o Sets the state of the units to PACK MOUNTED.
22-464
STRUUO [CALLI 50]
Code Symbol Function
o Creates a TABSTR entry (assigns a number to
the file structure).
The argument block for the .FSDEF function is
shown below:
Word Symbol Contents
0 .FSFCN Function code. (.FSDEF)
1 .FSNST Pointer to the structure
parameter block, in the form
(length,,address).
2 .FSNUN Pointer to the unit parameter
block for unit 0, in the form
(length,,address).
3 Pointer to the unit parameter
block for unit 1, in the form
(length,,address).
.
.
.
The structure parameter block is formatted as
follows:
Word Symbol Contents
0 .FSSNM File structure name in SIXBIT
(word HOMSNM in the HOME block).
1 .FSSNU Number of units in the
structure.
2 .FSSHL Highest logical block number
(that is, .FSSBU times .FSSNU
- 1).
3 .FSSSZ Size (in blocks) of the file
structure. (That is, the sum of
the values of UNIBPU for each
unit. The value of UNIBPU can
be found in word .DCUSZ returned
by the DSKCHR. call).
4 .FSSRQ Obsolete.
22-465
STRUUO [CALLI 50]
Word Symbol Contents
5 .FSSRF Obsolete.
6 .FSSTL Number of FCFS (first-come,
first-served) blocks left.
(That is, the sum of the values
of .FSUTL for each unit).
7 .FSSOD Number of blocks allowed for
overdraw (stored as a negative
number). See HOMOVR in the HOME
block.
10 .FSSMP First retrieval pointer to
Master File Directory. See
HOMPT1 in the HOME block.
11 .FSSML -1 if .FSSMP is the only
retrieval pointer to MFD. To
set this word, you must read the
RIB and test its contents. Do
not use COPIPT from HOMUN1 in
the HOME block.
12 .FSSUN Logical unit number within the
file structure where MFD begins.
(See HOMUN1 from the HOME
block.)
13 .FSSTR Number of retries on an error.
The suggested value for this
word is 10 (decimal).
14 .FSSBU Largest block on unit. (Largest
value of UNIBPU, returned in
.DCUSZ by DSKCHR.)
15 .FSSBC Number of blocks per
super-cluster (see HOMBSC in the
HOME block).
16 .FSSSU Number of super-clusters per
unit (see HOMSCU in the HOME
block).
17 .FSSIG Obsolete.
20 .FSSCC Byte pointer to cluster count
(see HOMCNP in the HOME block).
21 .FSSCK Byte pointer to retrieval
pointer checksum (see HOMCKP in
the HOME block).
22-466
STRUUO [CALLI 50]
Word Symbol Contents
22 .FSSCA Byte pointer to retrieval
pointer cluster address (see
HOMCLP in the HOME block).
23 .FSPVT -1 if this is a private
structure (see the HOPPVS bit in
HOMPVS in the HOME block).
24 .FSPPN PPN of file structure owner
(each half is -1 if wild) (see
HOMOPP in the HOME block).
25 .FSSCR Block in structure containing
RIB for CRASH.EXE (see HOMCRS in
the HOME block).
26 .FSK4C Number of K to reserve for
CRASH.EXE on disk (see HOMK4C in
the HOME block).
The format of the unit parameter block is:
Word Symbol Contents
0 .FSUNM Unit name in SIXBIT (such as
RPA0).
1 .FSUID Pack identifier (that is, the
pack serial number in SIXBIT;
see HOMHID in the HOME block).
2 .FSULN Logical name within file
structure (such as DSKB0,
DSKB1,...DSKB77; see HOMLOG in
the HOME block).
3 .FSULU Logical unit-number within file
structure (0,1,2,....FSSNU-1)
(see HOMLUN in the HOME block).
4 .FSUDS Status bits. These are:
Bit Symbol Meaning
0 FS.UWL Software
write-lock.
1 FS.USA Obsolete.
FS.UWL is meaningful only for
the first unit in the structure.
22-467
STRUUO [CALLI 50]
Word Symbol Contents
5 .FSUGP Number of sequential blocks to
try for on sequential output
(see HOMGRP in the HOME block).
6 .FSUTL Number of free blocks on unit,
minus a safety factor. The
suggested safety factor is one
block of safety for every 500
(decimal) blocks of disk. Do
not allocate safety blocks for
the swapping space. Thus, the
suggested safety factor is
(UNIBPU-HOMK4S*8)/500. This
value should be truncated to
less than 500 (decimal) blocks
per unit.
7 .FSUBC Number of blocks per cluster
(see HOMBPC in the HOME block).
10 .FSUCS Number of clusters per SAT (that
is, (UNIBPU/HOMBPC-1)/HOMSPU+1).
11 .FSUWS Number of words per SAT (that
is, (.FSUCS-1)/36 + 1).
12 .FSUSC Number of SATs in core (see
HOMSIC in the HOME block).
13 .FSUSU Number of SATs per unit (see
HOMSPU in the HOME block).
14 .FSUSP Pointer to SPT table
(length,,address).
15 .FSUSB First block for swapping (see
HOMSLB in the HOME block).
16 .FSUKS Number of K for SWAP.SYS. (See
HOMK4S in the HOME block.)
The format of the SPT table is:
Word Contents
0 Pointer to 1st SAT block.
1 Pointer to 2nd SAT block.
.
.
.
n Pointer to nth SAT block.
22-468
STRUUO [CALLI 50]
Code Symbol Function
Each word in the SPT table is in the form:
Bits Contain
0-12 Number of free clusters in this SAT.
13-35 Address of SAT (as a cluster number).
3 .FSRDF Allows your program to change the status of a
file structure if its mount count is 0 or 1. If
the mount count is 1, the job number and
project-programmer number arguments must be
those for the job that has the structure mounted
(in its search list). If the job number and
project-programmer number are both -1, the
search list for your job is assumed.
The argument block for the .FSRDF function is
listed below.
Word Symbol Contents
0 .FSFCN The function code (.FSRDF).
1 .FSRJN The job number or -1.
2 .FSRPP The project-programmer number or
-1.
3 .FSRNM The file structure name.
4 .FSRST The new status bits to be
assigned.
4 .FSLOK Allows your program to place a file structure in
a state where no new LOOKUPs or ENTERs are
allowed. The monitor will allow current reading
and writing to continue until a CLOSE is issued.
This function can be used to force a file
structure into a dormant state so that it can be
removed from the system with minimal damage to
its users. For example, this function could be
followed by .FSREM. The argument block for this
function is described below:
Word Symbol Contents
0 .FSFCN The function code (.FSRDF).
1 .FSLNM The file structure name in
SIXBIT.
22-469
STRUUO [CALLI 50]
Code Symbol Function
5 .FSREM Removes a file structure from the system. This
removal takes place immediately, with no regard
for the users of the file structure. Normally,
this function is preceded by the .FSLOK function
to prepare the structure for removal.
Specifically, the .FSREM function does the
following:
o Takes the non-error return if the file
structure does not exist.
o Removes the file structure name from the
search list of all jobs and from the system
search list.
o Unlinks and returns to the free core pool
any UFB or access blocks.
o For every unit, sets the state to NO PACK
MOUNTED and returns any core taken from the
free core pool.
o Clears KNOWLEDGE bits in the PPB and NMB
blocks.
o Unlinks STR data blocks and returns its core
if taken from the free core pool.
o Deletes (or marks for deletion) all sharable
high segments initialized from the file
structure.
o Clears the TABSTR entry.
o Takes the non-error return.
The argument block for the .FSREM function is
shown below:
Word Symbol Contents
0 .FSFCN The function code (.FSREM).
1 .FSMNM The file structure name in
SIXBIT.
22-470
STRUUO [CALLI 50]
Code Symbol Function
6 .FSULK Tests and sets the software write-lock bit
associated with each UFD. This function is
used, along with the .FSUCL function, to control
programs (such as LOGOUT and LOGIN) attempting
to modify a UFD at the same time. With the
interlock bit set, only one program can modify
the UFD at a time. Other programs should WAIT
for the interlock to be cleared.
The argument block for the .FSULK function is
shown below.
Word Symbol Contents
0 .FSFCN The function code (.FSULK).
1 .FSINM The file structure name in
SIXBIT.
2 .FSIPP The PPN of the UFD.
If the interlock bit is set for a program other
than your program, your program takes the error
return.
7 .FSUCL Clears the software interlock associated with a
UFD. Once a program has cleared the interlock,
another program may set the interlock (function
.FSULK) and modify the UFD. The argument block
for the .FSUCL function is shown below:
Word Symbol Contents
0 .FSFCN The function code (.FSUCL).
1 .FSGNM The file structure name in
SIXBIT.
2 .FSGPP The PPN of the UFD.
22-471
STRUUO [CALLI 50]
Code Symbol Function
10 .FSETS Tests error recovery procedures for the monitor
and your programs by causing hard and soft
errors to be simulated on the specified disk
unit of the system.
NOTE
This function is obsolete and applies
only to RP10 and RC10 controllers.
All error recovery and reporting procedures are
followed through by the monitor as if a real
error had occurred. This function causes the
monitor to enter the simulated hard errors in
the BAT block just as it would enter a real
error. Therefore, field service should be
notified of any error simulations that are being
done.
This function is implemented only for disk packs
and should not be attempted for the fixed-head
disk because the counts will not be decremented.
When a unit is removed from the system, the
error test sequence is terminated.
The argument block for the .FSETS function is
listed below.
Word Symbol Contents
0 .FSFCN The function code (.FSETS).
1 .FSEUN The disk pack name.
2 .FSEGT The number of good transfer
interrupts before simulation of
error.
3 .FSEDB The number of bad DATAI's before
the end of simulated error.
4 .FSEDO Error DATAI bits ORed with DATAI
bits received from the hardware.
5 .FSEDA Error DATAI bits ANDCMed with
DATAI bits received from the
hardware.
22-472
STRUUO [CALLI 50]
Code Symbol Function
Word Symbol Contents
6 .FSECB The number of bad CONIs before
terminating simulated error
sequence.
7 .FSECO Error CONI bits ORed with CONI
bits received from the hardware.
10 .FSECA Error CONI bits ANDCMed with
CONI bits received from the
hardware.
Note that the CONI mentioned above is executed
after a data transfer interrupt; the DATAI
mentioned above is executed before connecting to
the unit to initiate a position or transfer
operation.
11 .FSNMW Modifies the 'nocreate' and 'write-lock' status
of a file structure. The argument block for
this function is shown below.
Word Symbol Contents
0 .FSFCN The function code (.FSNMW).
1 .FSMFS The file structure name.
2 .FSMFL The flag word:
Bit Symbol Meaning
0 FS.MWL Write-lock bit.
1 FS.MNC No create bit.
12 .FSCLR Unlocks a file structure. The argument list is:
Word Symbol Contents
0 .FSFCN The function code (.FSCLR).
1 .FSCFS The file structure name in
SIXBIT.
Normal Return
The function is performed.
22-473
STRUUO [CALLI 50]
Error Return
Before the monitor accepts the newly-defined search list by
copying it in the PDB, it checks that the number of structures
defined is less than the system-defined maximum limit for the
job. This limit is stored in GETTAB table %LDMSS. If the number
exceeds the maximum, the error return is taken and the ac is
cleared.
Otherwise, one of the following error codes is returned in the
ac:
Code Symbol Error
0 FSILF% An illegal function code was specified.
1 FSSNF% One or more of the specified file
structures were not found.
2 FSSSA% One or more of the specified file
structures are in single-access mode.
3 FSILE% One or more illegal entries are in the
argument block.
4 FSTME% There are too many entries in the search
list.
5 FSUNA% One or more of the specified units are
not available.
6 FSPPN% The specified job number and
project-programmer number do not match.
7 FSMCN% The mount count is greater than 1.
10 FSNPV% Your job is not privileged but should
be.
11 FSFSA% The specified file structure already
exists.
12 FSILL% The argument block length has been
specified incorrectly.
13 FSUNC% Unable to complete the call.
14 FSNFS% The system has reached the maximum
number of file structures.
15 FSNCS% There is not enough free core for the
data block.
16 FSUNF% An illegal unit has been specified.
17 FSRSL% A file structure name is repeated in a
search list
20 FSASL% Structure contains units in active
search list.
21 FSISN% You specified an illegal structure name.
Related Calls
DSKCHR, GOBSTR, JOBSTR
22-474
SUSET. [CALLI 146]
SUSET. [CALLI 146]
Function
Selects a logical block number to be either read or written on
subsequent IN/INPUT or OUT/OUTPUT monitor calls relating to
either a file structure or a unit name. This call requires
your program to have [1,2] or JACCT privileges.
The block number is relative to a file structure if the channel
was initialized with a structure name (such as DSKB) and no
file is open on the channel (that is, no LOOKUP or ENTER was
performed).
The block number is relative to a unit number if the channel
was initialized with a physical or logical unit name (such as
RPA4 or DSKB) and no file is open on the channel (that is, no
LOOKUP or ENTER was performed).
Refer to Section 11.7.5 for more detailed discussion of SUSET.
Calling Sequence
MOVE ac,[EXP flags]
SUSET. ac,
error return
normal return
where: flags are as follows:
Bits Symbol Meaning
0 Reserved.
1 SU.SOT Output (input if not set).
2 SU.SMN Maintenance cylinder. You can set this bit
only if your job is logged in under [6,6].
SU.SBL (below) must contain the maintenance
cylinder.
3 Reserved.
4-12 SU.SCH Channel number. The channel number may be an
extended channel number obtained from the
FILOP. monitor call.
13-35 SU.SBL Block number or maintenance cylinder (if
SU.SMN is on).
22-475
SUSET. [CALLI 146]
Normal Return
The specified block will be the next one read/written on a
subsequent IN/OUT monitor call. The SUSET. monitor call
returns with the I/O status bit IO.BKT set if your job does not
have enough privileges, or if the given block number is too
large.
Error Return
The following error code is returned in the ac:
Code Symbol Error
-1 SUSNP% Not enough privileges.
Related Calls
FILOP., USETI, USETO
22-476
SYSPHY [CALLI 51]
SYSPHY [CALLI 51]
Function
Returns the name of a physical disk unit on the system.
Calling Sequence
|
| / MOVEI ac,0 \
| \ MOVE ac,[SIXBIT/device/] /
| SYSPHY ac,
| error return
| normal return
where: device is the physical unit name returned by a previous
call (such as SIXBIT/RPA0/).
Normal Return
If you set ac to 0, the monitor returns the first physical disk
name in ac. If you gave the name of a disk, the monitor
returns the next physical disk name, or, if there are no more
disks, the monitor returns 0 in the ac.
Error Return
The monitor takes the error return if the device you gave was
neither 0 nor the name of a disk unit.
Examples
Example to get all unit names in system
SETZB T1,T2 ;T1=Table pointer, T2=unit
; name
LOOP: SYSPHY T2, ;Get next one
JRST ERROR
JUMPE T2,CONTIN ;Done if zero
MOVEM T2,PHYTAB(T1) ;Save in table
AOJA T1,LOOP
PHYTAB: BLOCK ^D64
Related Calls
DVPHY., SYSSTR
22-477
SYSSTR [CALLI 46]
SYSSTR [CALLI 46]
Function
Returns the name of a file structure on the system.
Calling Sequence
|
| / MOVEI ac,0 \
| \ MOVE ac,[SIXBIT/device/] /
| SYSSTR ac,
| error return
| normal return
where: device is the structure name returned by a previous
call.
Normal Return
If you set ac to 0, the monitor returns the first structure
name in ac. If you gave the name of a structure, the monitor
returns the next structure name in ac, or if there are no more
structures, the monitor returns a 0 in the ac.
Error Return
The monitor takes the error return if the device you gave was
neither 0 nor the name of a structure.
Examples
Example to get all file structure names on system
SETZB T1,T2 ;Use T1 as table index, T2 as
; structure name
LOOP: SYSSTR T2, ;Get next structure
JRST ERROR
JUMPE T2,CONTIN ;Done if structure is zero
MOVEM T2,STRTAB(T1) ;Save in table
AOJA T1,LOOP ;Get next one
STRTAB: BLOCK ^D64 ;Where to put structures
Related Calls
DVPHY., SYSPHY.
22-478
TAPOP. [CALLI 154]
TAPOP. [CALLI 154]
Function
Performs various magnetic tape operations. Several TAPOP.
functions are identical to or extensions of other monitor calls
such as MTAPE and MTCHR. All TAPOP. functions assume that the
specified device has been assigned to your job by the ASSIGN
monitor command or the OPEN/INIT monitor call or that the
calling job has SPY privileges.
Calling Sequence
| MOVE ac,[XWD len,addr]
| TAPOP. ac,
| error return
| normal return
| . . .
| addr: EXP fncode
| / SIXBIT/device/ \
| | EXP channo |
| \ EXP udx /
| first argument
| . . .
| last argument
where: len is the length of the argument list.
addr is the address of the argument list.
fcncode is one of the function codes described below.
device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device and the
words up through last argument are arguments for the
given function.
The function codes fall into four groups:
Codes Functions
0 - 777 Perform specific actions.
1000 - 1777 Read parameters.
22-479
TAPOP. [CALLI 154]
Codes Functions
2000 - 2777 Set parameters. These function codes are not
explicitly listed in the descriptions below.
To set a parameter, use the corresponding read
function name plus the offset .TFSET (=1000).
For example, to set the density indicator, use
the read density indicator mnemonic plus
.TFSET:
.TFDEN+.TFSET
3000 - 3777 Reserved for customer-defined functions.
The function codes and their meanings are:
Code Symbol Function
1 .TFWAT Waits for I/O to be completed.
2 .TFREW Rewinds tape to load point.
3 .TFUNL Rewinds and unloads tape.
4 .TFFSB Skips forward one block.
5 .TFFSF Skips forward one file.
6 .TFSLE Skips to logical end-of-tape.
7 .TFBSB Skips backward one block.
10 .TFBSF Skips backward one file.
11 .TFWTM Writes a tape mark.
12 .TFWLG Writes 3 inches of blank tape.
13 .TFDSE Erases entire tape (data security, TX01/TX02
on DX10/DX20 only).
14 .TFWLE Writes logical end-of-tape (two tape marks for
unlabeled tapes).
15 .TFLBG Gets the tape label device data block.
Returns the name in ac. This is a privileged
function for use by the label processor.
16 .TFLRL Releases the tape label device data block.
This is a privileged function for use by the
label processor.
22-480
TAPOP. [CALLI 154]
Code Symbol Function
17 .TFLSU Swaps units. This is a privileged function
for use by the label processor.
20 .TFLDD Destroys the tape label data base. This is a
privileged function for use by the label
processor.
21 .TFFEV Forces end-of-volume processing. This allows
your program to write the end-of-volume label
before PULSAR finds the end-of-tape. The
monitor assumes a multivolume file and
automatically issues an operator MOUNT request
for the next volume.
22 .TFURQ Requests label processing. Set flag .TFCLE to
clear a tape labelling error.
23 .TFSMM Sets maintenance mode on the tape controller.
This is a privileged function.
24 .TFCMM Clears maintenance mode on the tape
controller. This is a privileged function.
25 .TFCEC Clears error counters. This privileged
function is restricted for use by the tape
label processor.
1000 .TFTRY Returns in the ac the number of retries on the
last error.
1001 .TFDEN Returns in ac the density code for the tape.
To set the density code, use .TFDEN+.TFSET;
the monitor reads the new density code from
addr+2. Note that in order to set the density
with this function code, IO.DEN must be zero.
The density codes and their meanings are:
Code Symbol Density
0 .TFD00 Unit default.
1 .TFD20 200 bits/inch (8.1 rows/mm).
2 .TFD55 556 bits/inch (22.5 rows/mm).
3 .TFD80 800 bits/inch (32.2 rows/mm).
4 .TFD16 1600 bits/inch (65.3 rows/mm).
5 .TFD62 6250 bits/inch (255.5
rows/mm).
6-17 Reserved for use by DIGITAL.
22-481
TAPOP. [CALLI 154]
Code Symbol Function
1002 .TFKTP Returns in the ac the controller type code for
the tape. To set the controller type code,
use .TFKTP+.TFSET; the monitor reads the new
controller type code from addr+2. The
controller type codes and their meanings are:
Code Symbol Controller Type
0 .TFKTA TM10A (TU10/20/30/40/41).
1 .TFKTB TM10B (TU10/20/30/40/41).
2 .TFKTC TM10C (TU43).
3 .TFKTX TX01/TX02 on DX10
(TU70,71,72).
4 .TFKTM TM02/TM03 on RH10/RH20
(TU16,TU45).
5 .TFKRH TM02/TM03 on RH11 (TU45).
6 .TFKD2 TX02 on DX20 (TU70,71,72).
7 .TFK78 TU78 on TM78.
1003 .TFRDB Returns in the ac the read-backwards bit
(TM02/TX01/TX02 only). The bit is on if the
tape is set for read-backwards, or off for
normal read. See Chapter 14. To set the
read-backwards bit, use .TFRDB+.TFSET; the
monitor reads the bit from addr+2.
1004 .TFLTH Returns in the ac the bit for read next record
at low threshold (TM10A/B/C only). The bit is
on if the tape is set for low threshold, or
off if not. To set the bit, use
.TFLTH+.TFSET; The monitor reads the bit from
addr+2.
1005 .TFPAR Returns in the ac the status of the even
parity bit (for 7-track tapes only). To set
the status of the even parity bit, use
.TFPAR+.TFSET; the monitor reads the status
from addr+2.
1006 .TFBSZ Returns in the ac the block size for the tape.
The returned value is one greater than the
number of data words per record. To set the
block size, use .TFBSZ+.TFSET; the monitor
reads the block size from addr+2.
22-482
TAPOP. [CALLI 154]
Code Symbol Function
1007 .TFMOD Returns in the ac the data mode code for the
tape. To set the data mode code, use
.TFMOD+.TFSET; the monitor reads the data mode
code from addr+2. The data mode codes and
their meanings are:
Code Symbol Data Mode
0 .TFMDD DIGITAL-compatible core dump
mode for 7-track and 9-track
tapes. The monitor uses the
default mode, either code 1
(.TFMID) or code 5 (.TFM7T).
1 .TFMID DIGITAL-compatible core dump
mode for 9-track tapes. The
monitor reads and writes
36-bit words in 5 frames.
This mode is also settable
with MTDEC. monitor call.
2 .TFM8B Industry-compatible 8-bit
mode, with 4 bytes per word.
This mode is also settable
with the .MTIND monitor call,
except that the default
density for this mode is 1600
BPI.
3 .TFM6B 6-bit mode, 6 bytes per word
(9-track, TU70 only).
4 .TFM7B ANSI/ASCII 7-bit mode, 5
bytes per word (TU70 only).
5 .TFM7T DIGITAL-compatible 7-track
core dump mode (SIXBIT).
1010 .TFTRK Returns in the ac the track status bit for the
tape (0 for 9-track, 1 for 7-track). To set
the track status bit, use .TFTRK+.TFSET; the
monitor reads the bit from addr+2.
1011 .TFWLK Returns in the ac the write-lock bit for the
tape (1 if write-locked, 0 if not).
1012 .TFCNT Returns in the ac the character count of the
last record (the actual record length).
1013 .TFRID Returns in the ac the SIXBIT reel
identification for the tape. To set the reel
identification, use .TFRID+.TFSET; the monitor
reads the SIXBIT reel identification from
addr+2.
22-483
TAPOP. [CALLI 154]
Code Symbol Function
1014 .TFCRC Returns in the ac the last cyclic redundancy
character (9-track NZRI only).
1015 .TFSTS Returns in the ac the unit status flags for
the tape. To set the flags, use
.TFSTS+.TFSET; the monitor reads the flags
from addr+2. The unit status flags and their
meanings are:
Bit Symbol Meaning
18 TF.UNS Unit is not schedulable.
19 TF.BOT Beginning-of-tape mark.
20 TF.WLK Write-lock.
21 TF.REW Unit is rewinding.
22-32 Reserved.
33 TF.STA Unit is started.
34 TF.SEL Unit is selected.
35 TF.OFL Unit is off-line.
1016 .TFSTA Returns unit statistics for the tape device.
Your program supplies the function code and
device at addr and addr+1. (These values are
identical to those returned for the MTCHR.
monitor call.) The monitor returns the device
statistics at addr in the format:
Offset Symbol Contents
0 .TSFUN Function code (user-supplied).
1 .TSDEV Device (user-supplied).
2 .TSRID SIXBIT reel identifier.
3 .TSFIL Number of files read since the
beginning of the tape.
4 .TSREC Number of records since last
tape unload.
5 .TSCRD Number of characters read
since last tape unload.
6 .TSCWR Number of characters written
since last tape unload.
7 .TSSRE Soft read errors since last
tape unload.
10 .TSHRE Hard read errors since last
tape unload.
11 .TSSWE Soft write errors since last
tape unload.
12 .TSHWE Hard write errors since last
tape unload.
13 .TSTME Total number of errors since
last tape unload.
22-484
TAPOP. [CALLI 154]
Code Symbol Function
Offset Symbol Contents
14 .TSTDE Total device errors since
system startup.
15 .TSTUN Total unloads since last
system reload.
16 .TSRTY Number of retries to resolve
last error.
17 .TSCCR Character count of last record
read or written.
20 .TSPBE Position before last error:
file number (in left half);
record number (in right half).
21 .TSFES Final error state. See the
TOPS-10/TOPS-20 SPEAR Manual.
1017 .TFIEP Returns in the ac the initial error pointer.
1020 .TFFEP Returns in the ac the final error pointer.
NOTE
Function codes 1021 and 1022 return the
blocks pointed to by 1017 and 1020.
These blocks are for communication of
errors to DAEMON and may change without
notice.
1021 .TFIER Returns in the ac the initial error status.
1022 .TFFER Returns in the ac the final error status.
1023 .TFFED Returns in the ac the final error disposition.
1024 .TFLBL Returns in the ac the label processing type
code. To set the label processing type code,
use .TFLBL+.TFSET; the monitor reads the new
code from addr+2. The label processing type
codes and their meanings are:
Code Symbol Label Processing Type
0 .TFLBP Bypass label processing. To
set this value, the job must be
privileged.
1 .TFLAL ANSI labels.
2 .TFLAU ANSI labels with user labels.
3 .TFLIL IBM labels.
4 .TFLIU IBM labels with user labels.
22-485
TAPOP. [CALLI 154]
Code Symbol Function
Code Symbol Label Processing Type
5 .TFLTM Leading tape mark.
6 .TFLNS Nonstandard labels.
7 .TFLNL No labels. When tapes are
processed with no labels, the
label processor is used only to
verify that the tape does not
contain a tape label.
Unlabeled tapes can be copied
to create a labeled tape.
10 .TFCBA DIGITAL COBOL ASCII labels.
11 .TFCBS DIGITAL COBOL SIXBIT labels.
12 .TFLNV Same as .TFLNL except that user
program is responsible for
dealing with an EOT. This type
is the default. To switch
reels after end-of-tape, use
TAPOP. function .TFFEV.
1025 .TFPLT Performs functions identical to the .TFLBL
function 1024 above, except that it allows
access to files and tape labels. Using this
function, you can examine and modify the
contents of a label. The .TFPLT function
requires the JP.POK, [1,2], or JACCT privilege.
1026 .TFLTC Returns the last tape label termination code
from the tape label processor. It is
recommended that you use DEVOP. function .DFRES,
because more information can be returned by that
function. The return codes are:
Code Symbol Error
1 .TFTCP Continue processing.
2 .TFTRE Returned EOF.
3 .TFTLT Label type error.
4 .TFTHL Header label error.
5 .TFTTL Trailer label error.
6 .TFTVL Volume label error.
7 .TFTDV Device error.
10 .TFTDE Data error.
11 .TFTWL Write lock error.
12 .TFPSE Positioning error.
13 .TFBOT Beginning of tape.
14 .TFIOP Illegal operation.
15 .TFFNF File not found.
16 .TFCAN Operator cancelled request.
17 .TFTMV Too many volumes requested.
22-486
TAPOP. [CALLI 154]
Code Symbol Function
1027 .TFDMS Returns in the ac the diagnostic mode set bit
(TX01/TX02 on DX10 only). This bit is 1 for
diagnostic mode, otherwise 0. To set this bit,
use .TFDMS+.TFSET; the monitor reads the new bit
from addr+2.
1030 .TFFSO Returns in the ac the bit showing whether a
forced SENSE command will be issued to the
controller (TX01/TX02 on DX10/DX20 only) after
the completion of every operation. To set the
bit, use .TFFSO+.TFSET; the monitor reads the
new bit from addr+2. This bit should be set by
diagnostic programs only, because it slows down
tape operations considerably.
1031 .TFMFC Returns in the ac the maximum frame count. To
set the count, use .TFMFC+.TFSET; the monitor
reads the new count from addr+2. Use this
function to speed tape throughput for a TU16, or
TU45, TU70, TU71, or TU72 that does not have an
integral number of bytes per word. The count
stays in effect until your program performs a
RESET with another TAPOP. monitor call or until
the tape is RELEASed (if the device was
ASSIGNed). This function allows a TU70 or a
TU16 to read and write tapes that do not have an
integral number of bytes per word. This
function provides tape compatibility with other
systems.
1032 .TFPDN Returns in the ac flags showing the possible
densities for a tape. The flags and their
meanings are:
Bit Symbol Density
31 TF.DN5 6250 bits/inch (255.5 rows/mm)
32 TF.DN4 1600 bits/inch (65.3 rows/mm).
33 TF.DN3 800 bits/inch (32.2 rows/mm).
34 TF.DN2 550 bits/inch (22.5 rows/mm).
35 TF.DN1 200 bits/inch (8.1 rows/mm).
22-487
TAPOP. [CALLI 154]
Code Symbol Function
1033 .TFLPR Returns at addr+2 the tape label parameters.
This function causes the first input label
processing if there is no file open for input.
To set the parameters, use .TFLPR+.TFSET; the
monitor reads the parameters beginning at
addr+2. This set function is legal only if
there is no file open for output on the given
channel. The parameters given apply to the next
file to be written. The format of the
parameters at addr is:
Offset Symbol Contents
0 .TPFUN Function code (user-supplied).
1 .TPDEV Device (user-supplied).
2 .TPREC Record format and form control:
Bits Symbol Meaning
0-17 TR.FCT Forms control
byte; one of
the following
codes:
Code Symbol Meaning
1 .TFCNO Records on tape
do not contain
form control
characters.
2 .TFCAS First character
of each record
is a form
control
character.
3 .TFCAM Records on tape
contain all
required form
control
characters.
Bits Symbol Meaning
18-35 TR.RFM Record format
byte; one of
the following
codes:
22-488
TAPOP. [CALLI 154]
Code Symbol Meaning
0 .TRFDF Default
(Fixed).
1 .TRFFX Fixed (F).
2 .TRFVR Variable (D).
3 .TRFSP Spanned (S).
4 .TRFUN Undefined (U).
Offset Symbol Contents
3 .TPRSZ Record size in characters.
4 .TPBSZ Block size in characters.
5 .TPEXP Expiration date in 15-bit
format.
Bits Symbol Meaning
18-35 TP.EEX Expiration
date.
0-17 TP.ECR Creation date.
6 .TPPRO Protection code.
7 .TPSEQ File sequence number.
10 .TPFNM File name (17 ASCII characters
maximum).
14 .TPGEN Generation and version numbers.
Bits Symbol Meaning
0-17 TP.GEN Generation
number.
18-35 TP.VER Generation
version number.
Function code 2033 (to set tape label
parameters) is legal only if there is no file
currently open for output on the specified
channel. The numbers you specify must apply
to the next file to be written.
Function code 1033 (to read label parameters)
always returns these numbers and causes the
first input label processing if there is no
file open for input.
Normal Return
The function is performed.
22-489
TAPOP. [CALLI 154]
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
-1 TPACS% Address check while storing answer.
0 TPIFC% Illegal function code.
1 TPPRV% Not enough privileges.
2 TPNMT% Not a magtape device.
3 TPVOR% Specified value out of range.
4 TPACR% Address check reading arguments.
5 TPCBS% Parameter cannot be set.
6 TPNIA% Tape not initialized or assigned.
7 TPNLP% No label processor.
10 TPETC% Termination code error.
11 TPIJN% Illegal job number.
12 TPLRF% Label release function required.
13 TPLSI% Set label parameter function illegal after first
output.
14 TPLOE% Attempted to read information from a label DDB
owned by someone else.
15 TPDNC% Drive not capable of specified density.
16 TPWWL% Write attempted to write-locked tape.
Examples
MOVE T1,[XWD 2,ARGLST] ;Pointer to arg list
TAPOP. T1, ;Get controller type
JRST ERROR ;Error
CAIE T1,.TFKTX ;If DX10
CAIN T1,.TFKD2 ;Or DX20
SKIPA ;Data security erase
; will work
JRST NODSE ;Otherwise don't try it
MOVE T1,[XWD 2,DSELSI] ;Pointer to arg list
TAPOP. T1, ;Erase the entire tape
JRST ERROR ;Error
JRST CONTIN ;Skip argument blocks
ARGLST: EXP .TFKTP ;Function to read
; controller types
SIXBIT /TAPE/ ;Device is "TAPE"
DSELST: EXP .TFDSE ;Function to do
; data security erase
SIXBIT /TAPE/ ;Device is "TAPE"
CONTIN: ;Continue
This example performs a data security erase on the logical device
"TAPE" if and only if the controller is capable of doing so.
(DX10/DX20).
Related Calls
MTAID., MTAPE, MTCHR.
22-490
TIMER [CALLI 22]
TIMER [CALLI 22]
Function
Returns the time of day since midnight (00:00) in jiffies. (A
jiffy is 1/60 second.)
NOTE
For systems using 50 Hz power, jiffy = 1/50
second. Therefore it is good programming
practice to use the MSTIME monitor call on any
system, because MTSIME call gives the time of day
in milliseconds and is independent of the type of
power used.
Calling Sequence
TIMER ac,
only return
Return
The number of jiffies since midnight is returned in the ac.
Related Calls
DATE, MSTIME
22-491
TMPCOR [CALLI 44]
TMPCOR [CALLI 44]
Function
Creates, reads, writes, or manipulates temporary files left in
core from the running of one program to another. Those files are
referenced by a three-character file name. All files are deleted
when the job is logged out. If the monitor call fails, your
program should write DSK:nnnNAM.TMP, where nnn is the job number.
This arrangement improves response time and minimizes the number
of disk reads.
Calling Sequence
MOVE ac,[XWD fcncode,addr]
TMPCOR ac,
error return
normal return
. . .
addr: XWD 'nam',0
IOWD buflength,buffer
where: fcncode is one of the function codes described below.
addr gives the address of the argument list.
nam is a 3-character SIXBIT string that is the file name.
buflength is the length of the buffer for the call.
buffer gives the address of the buffer for the call.
The function codes and their meanings are:
Code Symbol Function
0 .TCRFS Obtains free space. For this function, set the
ac to 0 before the call; no argument list is
required. On a normal return, the ac contains
the number of free words available to your
program (510 decimal).
22-492
TMPCOR [CALLI 44]
Code Symbol Function
1 .TCRRF Reads a file. The length of the file is
returned in the ac, and as much of the file as
possible is copied into the buffer for the call.
You can check for truncation by comparing the ac
to buflength.
The error return occurs if the specified file is
not found; in this case, the number of free
words available to your program is returned in
the ac.
2 .TCRDF Reads and deletes a file. Performs all the same
functions as .TCRRF and in addition deletes the
file. Note that the file is deleted even if it
is too long to fit in the buffer for the call.
3 .TCRWF Writes the contents of the buffer into a file.
The requested length of the file is the value of
buflength. If there is already a file of the
specified name, it is deleted and the space is
reclaimed.
The requested size of the file is specified by
buflength. If there is not enough space to
write the entire file, nothing is written, the
ac is set to the number of free words of space
available to the user, and the error return is
taken.
If there is enough space, the file is written.
The ac is set to the amount of space left after
the file has been written and the normal return
is taken.
If insufficient space is available, none of the
file is written, the error return occurs, and
the number of free words available to your
program is returned in the ac.
22-493
TMPCOR [CALLI 44]
Code Symbol Function
4 .TCRRD Reads a directory. The number of .TMP files in
your directory is returned in the ac, and their
file names are written into the buffer for the
call. You can check for truncation of the
directory list by comparing the ac to buflength.
Each entry in the buffer is of the form:
XWD 'nam',length
where: length is the length of the file in
words.
nam is the file name.
The error return occurs only if the call is not
implemented.
5 .TCRDD Reads and deletes from directory. This performs
all the same functions as .TCRRD and in addition
deletes all files from your directory.
Examples
MOVE T1,[XWD .TCRWF,ARGLST]
TMPCOR T1,
JRST TMCERR
JRST CONTIN
ARGLST: XWD 'XYZ',0
IOWD <BUFEND-BUFFER>,BUFFER
BUFFER: ASCIZ /THIS IS THE TEXT FOR THE FILE./
BUFEND:
CONTIN:
This example writes the text at BUFFER into the file XYZ if space
is available.
22-494
TRMNO. [CALLI 115]
TRMNO. [CALLI 115]
Function
Returns the number of the terminal controlling a specified job.
Calling Sequence
|
| / MOVEI ac,jobno \
| \ MOVNI ac,1 /
| TRMNO. ac,
| error return
| normal return
where: jobno is the number of a logged-in job (use -1 for the
current job).
Normal Return
Returns the UDX for the controlling terminal in the ac. The
format of Universal Device Index names is .UXxxx. The range of
values is 200000 through 200777 (octal). The symbol .UXTRM
(200000) is the offset for the terminal indexes.
Error Return
Zero is returned in the ac and indicates one of the errors listed
below:
o The job is currently detached (that is, there is no
controlling terminal).
o The job number specified is unassigned.
o The job number specified is illegal.
o The job number specified is a negative number other than -1.
22-495
TRMNO. [CALLI 115]
Examples
Your program can determine which of the above error conditions
occurred by using the JOBSTS monitor call. An example of a
program using this call for this purpose is shown below.
MOVE T1,JOBN
TRMNO. T1,
JRST .+2
JRST OK ;No error
MOVNI T1,JOBN
PJOB T1,
MOVNS T1,
JOBSTS T1,
JRST ILLNUM ;Job number illegal
JUMPL T1,DETJOB ;Job is detached
JRST NOJOB ;No such job
Related Calls
TRMOP.
Common Errors
Using .UXTRM as a mask instead of an offset.
22-496
TRMOP. [CALLI 116]
TRMOP. [CALLI 116]
Function
Performs various operations for terminals. Several
TRMOP. functions are identical to, or extensions of, TTCALL
monitor calls.
Calling Sequence
MOVE ac,[XWD len,addr]
TRMOP. ac,
error return
normal return
. . .
addr: EXP fcncode
EXP udx
first argument
. . .
last argument
where: len is the length of the argument list.
addr is the address of the argument list.
fcncode is one of the function codes described below.
udx is the Universal Device Index for a terminal, or -1
can be used to indicate the program's controlling
terminal. The words up through last argument are
arguments for the given function.
The argument list is formatted as follows:
Word Symbol Contents
0 .TOFNC Function code.
1 .TOUDX Universal Device Index or -1.
2 .TOAR2 Argument word.
3 .TOAR3 Argument word.
4 .TOAR4 Argument word.
5 .TOAR5 Argument word.
6 .TOAR6 Argument word.
22-497
TRMOP. [CALLI 116]
The argument words contain values that are read or set by the
function code, and they differ for each function. The function
codes fall into four groups:
Codes Symbol Actions
0-777 Perform a specific action.
1000-1777 Read parameters.
1000 .TOSET Add this value (symbol .TOSET) to the read
function, thus setting the specified
parameter(s).
2000 - 2777 Set parameters. These functions are not
explicitly listed in the descriptions below. To
set a parameter, use the corresponding Read
function plus the offset .TOSET (=1000). For
example, to set a terminal's receive speed, use
the receive speed function plus .TOSET:
.TORSP + .TOSET
3000 - 3777 Reserved for customer-defined functions.
The function codes and their meanings are:
Code Symbol Function
1 .TOSIP Takes the error (non-skip) return if the
terminal's input buffer is empty. The ac is
unchanged.
2 .TOSOP Takes the error (non-skip) return if the
terminal's output buffer is empty. The ac is
unchanged.
3 .TOCIB Clears the terminal's input buffer.
4 .TOCOB Clears the terminal's output buffer.
5 .TOOUC Outputs a character to the terminal; the
character is in bits 29 to 35 of .TOAR2.
6 .TOOIC Outputs an image-mode character to the terminal;
the character is in bits 28 to 35 of .TOAR2.
22-498
TRMOP. [CALLI 116]
Code Symbol Function
7 .TOOUS Outputs an ASCIZ string to the terminal; the
address of the string is in .TOAR2. If the job
number at the receiving terminal is different
from your job number, the character string is
limited to 128 characters. If you attempt to
send more than 128 characters to a job other
than your own, characters may be lost.
10 .TOINC Inputs a character from the terminal in line
mode; the character is stored in bits 29 to 35
of the ac.
11 .TOIIC Inputs an image-mode character from the
terminal; the character is stored in bits 28 to
35 of the ac. This function is not implemented
by the monitor.
12 .TODSE Enables a modem (dataset) for outgoing calls.
This function is not implemented by the monitor.
13 .TODSC Enables and places outgoing calls on a modem
with a dialer. A telephone number of up to 17
decimal digits is stored in 4-bit bytes in
.TOAR2 and .TOAR3 (terminated by a 17). If the
caller must wait for a second dial tone (for
example, after dialing 9), a 5-second wait is
indicated by a 16 byte.
14 .TODSF Disconnects a call (for example, hangs up a
modem).
15 .TORSC Rescans an input line.
16 .TOELE Sets the terminal element to the number stored
in .TOAR2.
17 .TOEAB Enables autobaud detection.
20 .TOISC Inputs a character from the terminal to the ac;
waiting in character mode if no input is
available.
21 .TOTYP Puts an ASCIZ string into the terminal's input
buffer; the address of the string is in .TOAR2.
A string of more than 300 characters results in
a range error.
22-499
TRMOP. [CALLI 116]
Code Symbol Function
22 .TOGMS Returns terminal's MIC status bits in addr+2.
If MIC is not controlling the job, addr+2
contains 0. The status bits are as follows:
Bits Symbol Meaning
0 TO.CHK Flag bit for word. If this bit
is set, there are other set
bits in the word.
1 TO.CCT A CTRL/C was typed.
2 TO.OCS An operator-sent character was
received.
3 TO.ECS An error character was
received.
4 TO.CPT A CTRL/P was typed.
5 TO.CBT A CTRL/B was typed.
6 TO.STL Silence this line.
7 TO.LMM Line is in monitor mode.
8 TO.LUM Line is in user mode.
9 TO.C1O Line is in column 1 on output.
10 TO.CAT A CTRL/A was typed.
11 TO.RSP Error response.
12 TO.RSY Response code sync.
13 TO.LOG MIC is logging.
14 TO.LUI Controlling job should do a
JOBSTS UUO for the controlled
job or terminal.
15-21 TO.AOC The received operator character
(ASCII).
22-28 TO.AEC The received error character
(ASCII).
29-35 TO.MMJ MIC master job number.
23 .TOSMS Sets the terminal's MIC status bits to the
contents of .TOAR2. The bits are the same as
those returned by the .TOGMS function above.
24 .TOCLR Clears the MIC status bits.
25 .TODSP Displays an ASCIZ string on the terminal. The
address of the string is in .TOAR2.
26 .TOGMR Returns the MIC response buffer. The address of
the 21-word buffer is in .TOAR2.
27 .TOLOG Returns the MIC log buffer. The address of the
21-word buffer is in .TOAR2.
22-500
TRMOP. [CALLI 116]
Code Symbol Function
30 .TODSS A modem is present if bit 0 of the ac is set on
return; bits 1 to 35 are reserved. If the line
is not a dataset line, the monitor takes the
error return and returns the TOIMP% error in ac.
31 .TOSBS Sets the terminal break character set. Using
this function, you can define the characters
that, when typed on the terminal, will be
interpreted by the monitor as break characters,
indicating the end of the input line. In the
argument block, you must specify the following:
addr: .TOSBS ;function code
udx ;terminal's UDX
field-width ;auto-break
break mask ;first word
. . . ; of break table
break mask ;last word
Where the field-width defines the number of
characters to be accepted on an input line.
After the specified number of characters are
typed, a break is automatically made. The field
width must be between 1 and 255.
The break mask is a 4-word block indicating the
mask of bits (in the left-hand 32 bits of each
word from .TOAR3 through .TOAR6) that indicate
the octal representation of characters to be
defined as break characters. You must enable
break set mode by setting flag IO.ABS in the I/O
status word. Refer to Volume 1 for more
information.
32 .TORBS Reads the terminal break character set. The
field width is returned in .TOAR2 of the
argument block, and the break mask is returned
in words .TOAR3 through .TOAR6. Refer to
.TOSBS.
22-501
TRMOP. [CALLI 116]
Code Symbol Function
33 .TOISO Sets counted image output string mode. This
function allows your program to output a
specified number of characters in a single
sequence. This function allows screen editors
and display-oriented programs to update the
terminal screen more efficiently. The argument
block for this function is:
addr: .TOISO ;function
udx ;terminal's UDX
byte-size,,byte-count
string-address
Where the size of each byte (7 or 8 bits) is
specified in byte-size, and the length of the
string is specified in byte-count. The string
address is a pointer to the location of the
output string.
34 .TOFLM Returns the carriage to the left margin.
35 .TOGCS Reads the special character status. The
conditions read are set in the TC.VAL
field. .TOSCS explains TC.VAL. The argument
block for .TOGCS is:
addr: .TOGCS
udx
len2,,addr2
addr2: character to read
The number of words given in len at addr2 have
the TC.VAL field filled in from the current
settings described in .TOSCS.
36 .TOSCS Sets the special character status. The .TOSCS
argument block is:
addr: .TOSCS
udx
len2,,addr2
addr2: mask + values + character
22-502
TRMOP. [CALLI 116]
Codes Symbol Function
The fields in addr2 are:
Bits Symbol Meaning
0-13 TC.MOD The mask of the fields to
change.
14-27 TC.VAL The conditions read or set.
See below for a list of
condition bits.
28-35 TC.CHR The character which the
condition(s) applies to.
Bits which may be selected for the character
are:
Bit Symbol Meaning
31 TC.CLR For control characters only,
clears the input buffer when
the character's interrupt is
posted.
32 TC.DFR Defer the character's interrupt
type.
33 TC.OOB An out-of-band character. This
character causes an interrupt
when received.
34 TC.NSA Disable special action.
35 TC.BRK Line break character.
37 .TOUNR Allows reading of only already echoed
characters. No further echoing occurs until an
empty buffer is returned, a no input available
return is taken, or a null character is
returned. The argument block is:
addr: .TOUNR
udx ;terminal UDX
40 .TOASO Sets counted ASCII output string mode. The
argument block is identical to .TOISO, function
33, except for the function code.
41 .TODNT Disconnects a network terminal, without hanging
up the dataset.
1000 .TOOIP Returns, in the ac, the output-in-progress bit
(1 in Bit 35 if output is in progress, otherwise
ac=0).
22-503
TRMOP. [CALLI 116]
Code Symbol Function
1001 .TOCOM Returns, in the ac, the monitor-mode bit (1 in
bit 35 if terminal is in monitor mode, otherwise
ac=0).
1002 .TOXON Returns, in the ac, the papertape bit (1 in bit
35 if terminal is in papertape mode, otherwise
ac=0). To set the bit, use .TOXON+.TOSET; the
monitor reads the bit from .TOAR2. When this
bit is set, the functions of CTRL/S and CTRL/Q
are defined to control the papertape. If CTRL/S
and CTRL/Q were defined previously for stopping
and continuing terminal output, these functions
are temporarily superseded by the papertape
function. When you clear .TOXON, the terminal
output function is restored.
1003 .TOLCT Returns, in the ac, the lowercase bit (1 in bit
35 if no lowercase capability, otherwise ac=0).
To set the bit, use .TOLCT+.TOSET; the monitor
reads the bit from .TOAR2.
1004 .TOSLV Returns, in the ac, the slave bit (1 in bit 35
if the terminal is slaved, otherwise ac=0). To
set the bit, use .TOSLV+.TOSET; the monitor
reads the bit from .TOAR2.
1005 .TOTAB Returns, in the ac, the tab-capability bit for
the terminal (1 in bit 35 if the terminal has
tab capability, otherwise ac=0). To set the
bit, use .TOTAB+.TOSET; the monitor reads the
bit from .TOAR2.
1006 .TOFRM Returns, in the ac, the formfeed-capability bit
for the terminal (1 in bit 35 if the terminal
performs formfeeds, otherwise ac=0). To set the
bit, use .TOFRM+.TOSET; the monitor reads the
bit from .TOAR2.
1007 .TOLCP Returns, in the ac, the local-copy bit for the
terminal (1 in bit 35 if characters are not
echoed, otherwise ac=0). To set the bit, use
.TOLCP+.TOSET; the monitor reads the bit from
.TOAR2.
22-504
TRMOP. [CALLI 116]
Code Symbol Function
1010 .TONFC Returns, in the ac, the free CRLF bit for the
terminal (1 in bit 35 if free CRLFs are not
performed, otherwise ac=0). To set the bit, use
.TONFC+.TOSET; the monitor reads the bit from
.TOAR2. The free CRLF
(carriage-return/line-feed) is placed in the
terminal output buffer when the maximum width of
the line is reached. Set the terminal line
width using .TOWID, SET TTY WIDTH monitor
command, or by setting the terminal type. The
free CRLF function is enabled by default.
1011 .TOHPS Returns, in the ac, the horizontal position of
the carriage or cursor (in the range 0 to octal
377).
1012 .TOWID Returns, in the ac, the carriage width for the
terminal (in the range 16 to 255 decimal). To
set this value, use .TOWID+.TOSET; the monitor
reads the width from .TOAR2.
1013 .TOSND Returns, in the ac, the GAG bit for the terminal
(1 in bit 35 if NOGAG, otherwise ac=0). To set
this bit, use .TOSND+.TOSET; the monitor reads
the bit from .TOAR2. Refer to the SET TTY
monitor command in the Commands Manual.
1014 .TOHLF Returns, in the ac, the half-duplex bit for the
terminal (1 in bit 35 if the terminal is in
half-duplex mode, otherwise ac=0). To set this
bit, use .TOHLF+.TOSET; the monitor reads the
bit from .TOAR2. Refer to the SET TTY monitor
command in the Commands Manual.
1015 .TORMT Returns, in the ac, the remote bit for the
terminal (1 in bit 35 if the terminal is remote,
otherwise ac=0). To set this bit, use
.TORMT+.TOSET; the monitor reads the bit from
.TOAR2. Refer to the SET TTY monitor command in
the Commands Manual.
22-505
TRMOP. [CALLI 116]
Code Symbol Function
1016 .TODIS Returns, in the ac, the display bit for the
terminal (1 in bit 35 if the terminal is a
display device, otherwise ac=0). To set this
bit, use .TODIS+.TOSET; the monitor reads the
bit from .TOAR2. You may set this bit to
indicate that the terminal is a display terminal
if any of the following is true:
o The terminal can backspace the cursor.
o A space character on the terminal erases the
character pointed to by the cursor.
Refer to the SET TTY monitor command in the
Commands Manual.
1017 .TOFLC Returns, in the ac, the filler class code (the
number of fillers used for padding) for the
terminal (in the range 0 to 3). To set the
code, use .TOFLC+.TOSET; the monitor reads the
code from .TOAR2. Refer to the SET TTY monitor
command in the Commands Manual.
1020 .TOTAP Returns, in the ac, the papertape-enable bit for
the terminal (1 in bit 35 if papertape is
enabled, otherwise ac=0). To set this bit, use
.TOTAP+.TOSET; the monitor reads the bit from
.TOAR2. Refer to the SET TTY monitor command in
the Commands Manual.
1021 .TOPAG Returns, in the ac, the bit setting for paged
display mode (1 in bit 35 if the terminal is in
paged display mode, otherwise ac=0). To set
this bit, use .TOPAG+.TOSET; the monitor reads
the bit from .TOAR2.
1022 .TOSTP Returns, in the ac, the output-stopped bit for
the terminal (1 in bit 35 if output has stopped,
otherwise ac=0). The output-stopped bit is set
when, for example, the terminal reaches its page
limit.
1023 .TOPSZ Returns, in the ac, the number of lines for the
current page setting (in the range 0 to 63). To
set the number of lines, use .TOPSZ+.TOSET; the
monitor reads the number of lines from .TOAR2.
1024 .TOPCT Returns, in the ac, the value of the page
counter (in the range 0 to 63).
22-506
TRMOP. [CALLI 116]
Code Symbol Function
1025 .TOBLK Returns, in the ac, the bit setting for blank
line handling (1 in bit 35 if multiple blank
lines are to be reduced to one blank line,
otherwise ac=0). To set the bit, use
.TOBLK+.TOSET; the monitor reads the bit setting
from .TOAR2.
1026 .TOALT Returns, in the ac, the bit setting for ESCape
(altmode) character handling (1 in bit 35 if no
conversion, 0 if the ASCII codes 175 and 176 are
converted to 033). To set the bit, use
.TOALT+.TOSET; the monitor reads the bit setting
from .TOAR2.
1027 .TOAPL Returns, in the ac, the bit setting for APL mode
(1 in bit 35 if in APL mode, otherwise ac=0).
To set the bit, use .TOAPL+.TOSET; the monitor
reads the bit setting from .TOAR2.
1030 .TORSP Returns, in the ac, the code for the terminal's
receive speed. To set the code, use
.TORSP+.TOSET; the monitor reads the code from
.TOAR2. (Note that the send and receive speeds
cannot both be 0.) The codes and their meanings
are:
Code Symbol Speed
1 .TO005 50 baud.
2 .TO007 75 baud.
3 .TO011 110 baud.
4 .TO013 134.5 baud.
5 .TO015 150 baud.
6 .TO020 200 baud.
7 .TO030 300 baud.
10 .TO060 600 baud.
11 .TO120 1200 baud.
12 .TO180 1800 baud.
13 .TO240 2400 baud.
14 .TO480 4800 baud.
15 .TO960 9600 baud.
16 .TOEXA External A.
17 .TOEXB External B.
1031 .TOTSP Returns, in the ac, the code for the terminal's
transmit speed. To set the code, use
.TORSP+.TOSET; the monitor reads the code from
.TOAR2. (Note that the send and receive speeds
cannot both be 0.) The codes and their meanings
are the same as those for the .TORSP function
above.
22-507
TRMOP. [CALLI 116]
Code Symbol Function
1032 .TODBK Returns, in the ac, the bit setting for the
terminal's debreak capability (1 in bit 35 if
debreak is enabled, otherwise ac=0). To set the
bit, use .TODBK+.TOSET; the monitor reads the
bit setting from .TOAR2. (Meaningful for model
2741 terminals only.)
1033 .TO274 Returns, in the ac, the bit to show whether the
terminal is a 2741 (1 in bit 35 if so, otherwise
ac=0). To set the bit, use .TO274+.TOSET; the
monitor reads the bit from .TOAR2. You must
have [1,2] or JACCT privileges to set this bit,
because the 2741 terminal is no longer
supported.
1034 .TOTDY Returns, in the ac, the terminal's TIDY setting
(1 in bit 35 if TIDY, 0 if NOTIDY). (Meaningful
for model 2741 terminals only.)
1035 .TOACR Returns, in the ac, the auto-CRLF column number.
If this value is not zero, the first space
character received from the terminal, after the
specified column, is converted to a
carriage-return/line-feed sequence. If the
value in the ac is zero, no automatic conversion
on input is performed. To set this value, use
.TOACR+.TOSET. Include the column number in
.TOAR2 as a decimal value from 0 to 255.
1036 .TORTC Returns, in the ac, the bit for CTRL/R and
CTRL/T compatibility (0 in bit 35 if
compatibility is enabled, otherwise ac=1). To
set the bit, use .TORTC; the monitor reads the
bit from .TOAR2.
1037 .TOPBS Returns, in the ac, the word containing the PIM
(packed image mode) break set (four 9-bit
bytes). To set this word, use .TOPBS+.TOSET;
the monitor reads the word from .TOAR2. If the
ninth bit of the argument is set, the bytes are
compared as 7-bit bytes. If the ninth bit is
clear, the bytes are compared as 8-bit bytes.
1040 .TODEM Returns, in the ac, the bit showing the
deferred-echo mode (1 in bit 35 if echo is
deferred until input is required, otherwise
ac=0). To set this bit, use .TODEM+.TOSET; the
monitor reads the bit from .TOAR2.
22-508
TRMOP. [CALLI 116]
Code Symbol Function
1041 .TOTRM Returns, in the ac, the SIXBIT terminal type.
To set the terminal type code, use
.TOTRM+.TOSET; the monitor reads the SIXBIT name
of the terminal type from .TOAR2. The valid
terminal types may be obtained from GETTAB table
.GTTNM.
1042 .TOBCT Returns, in the ac, number of commands processed
in the left half, and the number of break
characters received in the right half.
1043 .TOICT Returns, in the ac, number of input characters
received.
1044 .TOOCT Returns, in the ac, number of output characters
sent.
1045 .TOOSU Returns, in the ac, output suppression state
(CTRL/O).
1046 .TOFCS Returns, in the ac, full character set.
1047 .TOBKA "Break on all characters" mode. If this is off,
the break occurs on each line. If it is set,
breaks occur on each character.
1050 Reserved for use by DIGITAL.
1051 Reserved for use by DIGITAL.
1052 .TOTIC Returns number of characters in input buffer.
1053 Reserved for use by DIGITAL.
1054 .TOBKC Returns number of break characters in input
buffer.
1055 .TOECC Returns number of unprocessed (unechoed)
characters in input buffer.
1056 .TOTTC Returns total number of characters in monitor's
input buffer.
1057 .TOTOC Returns total number of characters in monitor's
output buffer.
1060 .TOLNB Returns length of terminal form/page.
1061 .TOLNC Returns number of lines remaining in page.
22-509
TRMOP. [CALLI 116]
Code Symbol Function
1062 .TOSSZ Returns stop size (number of lines to output)
for automatic CTRL/S.
1063 .TOSTC Returns page stop counter (number of lines
remaining on page).
1064-1066 Reserved for use by DIGITAL.
1067 .TOSTO Specifies that output will stop after the number
of lines specified for .TOSSZ.
1070 .TOSST Does not reset page stop counters after CTRL/S
and CTRL/Q.
1071 .TOSBL Sounds terminal bell on automatic page stop.
1072 .TOFSP Provides pseudo-terminals with the sceen-editing
facilities of a physical terminal. This is a
read-only function.
1073 .TOOFL Returns offline bit. If 0 is returned in the
ac, the terminal exists. This is a read-only
function.
1074 .TOECH Returns echo status. If set, echoing is
enabled.
1075 .TOAPC Returns asynchronous port characteristics. This
is a read-only function.
Code Symbol Meaning
0. .TOUNK Unknown.
1 .TOHWD Hard-wired.
2 .TODSD Dataset line.
3-4 Reserved
5 .TOADL Auto-dial.
6 Reserved.
7 .TONRT NRTSER line.
10 .TOLAT LAT line.
11 .TOCTM CTERM line.
1076 .TOUNP Enables unpause character; continues output
after CTRL/S. (The enabled character is
interpreted, on input, like CTRL/Q.)
1077 .TOESC Enables ESCape character (behaves like ESC key).
In other words, the enabled character is
interpreted, on input, as the ESCape character,
(ASCII character 033).
22-510
TRMOP. [CALLI 116]
Code Symbol Function
1100 .TOSWI Enables two-character switch sequence.
1101 .TO8BT Enables 8-bit terminal I/O.
1102 .TO8BI Enables 8-bit I/O mode on a terminal.
1103 .TOQOT Enables the terminal quote (^V)
character. .TTQOT, when combined with any
character, behaves as a single character. A
^V-character combination is deleted by a single
rubout, and echoes as one character. ^V
suppresses special action on the next character
you type. The character is echoed without being
processed.
1104 .TOMXT Returns maximum idle time before an automatic
disconnect.
1105 .TOADT Returns time remaining before automatic
disconnect.
1106 .TOCLE Enables command-level echoing.
Normal Return
The monitor performs the function.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
0 TOILF% Illegal function code.
1 TOPRC% Not privileged.
2 TORGB% Illegal range.
3 TOADB% Illegal argument list address or length.
4 TOIMP% Line is not a dataset line.
5 TODIL% Error in dialing routine.
6 TOTNA% Terminal not available.
7 TONBM% Terminal is not in break set mode. You must set
IO.ABS with the OPEN UUO before you can define
and enable break characters.
10 TONIB% Illegal byte size specified.
11 TONET% Not a network-based terminal.
22-511
TRPSET [CALLI 25]
TRPSET [CALLI 25]
Function
Prevents jobs other than the calling job from running. You can
(if you have the JP.TRP privilege) use this call to guarantee
fast response to realtime interrupts.
For a complete discussion of realtime traps and related
programming practices, see Chapter 9, Volume 1.
Calling Sequence
MOVE ac,[XWD len,addr]
TRPSET ac,
error return
normal return
. . .
addr: JSR address
BLKI address
where: len is the length of the argument list.
addr is the address of the argument list.
address is the address of a location to be patched to
trap directly to your program. This address must be in
the range 40 to 57 (octal).
Normal Return
The monitor has suspended execution of other jobs.
Error Return
The error return occurs if the TRPSET call is not implemented, or
if your job is not privileged.
Related Calls
HPQ, LOCK, RTTRP, UJEN
22-512
TSK. [CALLI 177]
TSK. [CALLI 177]
Function
Performs miscellaneous functions for network nodes. This monitor
call can be used by applications that wish to perform
non-blocking connects and disconnects. Also, it can be used by
applications translating ANF-10 protocol into another protocol.
These applications usually require more control over the connect
message than that provided by the standard LOOKUP/ENTER sequence.
The TSK. monitor call is an alternative to using the
LOOKUP/ENTER method for opening/defining network links. Once the
link enters the run state (.TKSOK), the normal OUT and IN monitor
calls can be used to send or receive data over the network link.
The TSK device cannot be designated as an MPX-controlled device,
but asynchronous I/O can be performed.
Refer to Chapter 5 for more information about using the TSK.
monitor call.
Calling Sequence
MOVE ac,[XWD length,addr]
TSK. ac,
error return
normal return
addr: EXP func-code ;.TKAFN
EXP channo ;.TKACH
EXP arg1 ;.TKAA1
EXP arg2 ;.TKAA2
EXP arg3 ;.TKAA3
where: function is one of the function codes listed below.
channo is the I/O channel number on which the device TSK
has been opened.
Each argument is an argument for the specified function
code.
Most arguments will be pointers to Network Process Descriptors
(NPDs), having the following format:
XWD length,addr
where: length is the length of the NPD (must be at least 3).
addr is the location of the NPD.
22-513
TSK. [CALLI 177]
Associated with each task link are two processes: the local
process and remote process. The processes are named by the NPD.
The format of the NPD is:
Offset Symbol Meaning
0 .TKNND Node number (-1 implies any node, but is not
valid when used in the remote passive NPD).
1 .TKNLN Length of ASCII process name that follows
(number of characters).
2 .TKNPN First word of the ASCII process name.
The following lists the function codes for TSK.:
Code Symbol Meaning
1 .TKFRS Returns the state of the link in arg1. The
possible states are:
Code State Meaning
0 .TKSID The link is idle. The call
destroys the contents of arg2
and stores the reason for the
disconnect. arg3 is unchanged.
1 .TKSCI The link is waiting for a
connect initiate message. It
returns the local NPD in the
area pointed to by arg2. It
returns the remote NPD in the
area pointed to by arg3.
2 .TKSCC The link is waiting for a
connect confirmation message.
It returns the local NPD at the
location specified in arg2 and
the remote NPD at the location
specified in arg3.
3 .TKSOK The link is operational. It
returns the local NPD at the
location specified in arg2 and
the remote NPD at the location
specified in arg3.
4 .TKSDC The link is waiting for a
disconnect confirmation
message. It returns the local
NPD at the location specified
in arg2 and the remote NPD at
the location specified in arg3.
22-514
TSK. [CALLI 177]
Code Symbol Meaning
You may include a pointer (len,,addr) to the
local NPD in arg2. You can include the pointer
to the remote NPD in arg3. These words,
however, are optional.
2 .TKFEP Enters the link into the passive state. The
link must be in the .TKSID state. The monitor
reads and stores the local and remote NPDs
pointed to by arg2 and arg3.
If, at a later time, the monitor receives a
Connect Initiate message that "matches" the
remote NPD, the following occurs:
o The monitor deletes the remote NPD.
o The monitor builds a new remote NPD from the
information given in the connect message.
The job can read the new NPD by using the
.TKFRS function to determine the process
that initiated the connection.
o The monitor enters the link into the .TKSOK
state.
o The monitor issues a device on-line
interrupt to the job if the job enabled this
condition using the PSI system.
3 .TKFEA Enters the link into the active state. Before
issuing this function the link must be in the
.TKSID state. All other states cause an error
code (TKILS%) to be returned. When this code is
issued, the monitor reads the local NPD pointed
to by arg1 and the remote NPD pointed to by
arg2. It then sends a Connect Initiate request
to the node/task specified in the remote NPD.
It puts the link into the TKSCC state and takes
the normal return. The link remains in the
TKSCC state until a Connect Confirm or
Disconnect function is issued.
If a Connect Confirm is issued, the monitor
discards the remote NPD pointed to by arg2. It
builds a new remote NPD using the information in
the Connect Confirm message (so that it can be
read by a .TKFRS function). The link is placed
in the .TKSOK state and the controlling job is
given a device on-line interrupt (if the
condition was enabled using the PSI system).
22-515
TSK. [CALLI 177]
Code Symbol Meaning
If a Disconnect function is issued, the monitor
discards both the local and remote NPD
specifications. It places the link into the
.TKSID (idle) state and gives the controlling
job a device off-line interrupt (if the job
enabled this condition using the PSI system).
4 .TKFEI Enters the link into the idle state. This
function is illegal for those tasks in .TKSDC or
.TKSCC states and is a no-op for those already
in the idle state (.TKSID). The monitor
performs the following for those links in .TKSCI
and .TKSOK states:
.TKSCI Both NPDs are released. The link
state is set to .TKSID.
.TKSOK A Disconnect Initiate is sent. The
link state is set to .TKSDC.
When Disconnect Confirmed message is issued at a
later time, the monitor frees both NPDs, sets
the link state to .TKSID, and issues a "device
off-line" interrupt.
5 .TKFWT Puts the link into the wait state. If the link
is in either the .TKSID or .TKSOK state, the
monitor takes the normal return immediately.
The monitor performs the following for those
links in the other states:
State Function
.TKSCI waits for a transition to the
.TKSOK state and then returns.
.TKSCC waits for a transition to either
the .TKSOK or .TKSID states, then
returns.
.TKSDC waits for a transition to .TKSID
and then returns.
22-516
TSK. [CALLI 177]
Code Symbol Meaning
6 .TKFOT Performs output with control of message
disassembly. This function is valid only for
links in the .TKSOK state. This function
performs an OUT monitor call on the specified
channel. If the OUT is successful, the contents
of the buffer will be sent without an EOF bit.
If unsuccessful, the monitor places error code
TKUDW% in the ac and returns the device status
word in arg1.
7 .TKFIN Performs input with message reassembly. This
function is valid only for those links in the
.TKSOK state. It performs an IN monitor call on
the specified channel. If the IN is successful
(non-skip return), and UU.DMR was not set on the
OPEN, the monitor reads the message as one
entire buffer and takes a skip return. If
UU.DMR was set, the message is read without
reassembly. If the IN fails, the monitor places
error code TKUDW% in the ac and stores the
device status word in ac+1.
10 .TKFRX Returns the status of the link in arg1 (see
.TKFRS for a list of codes) and the "segment
size," or the maximum message size, in arg2.
Note that the segment size is only returned if
the link is in "OK" state (.TKSOK).
Normal Return
The specified function has been performed.
22-517
TSK. [CALLI 177]
Error Return
One of the following error codes is returned in the ac.
Code Symbol Meaning
1 TKTNL% TSKSER not loaded (intertask communication is not
supported).
2 TKATS% Argument list was too short.
3 TKUNP% Insufficient privileges.
4 TKILF% Illegal function.
5 TKILC% Illegal channel (not a TSK device or channel not
open).
6 TKILN% Illegal NPD.
7 TKNTS% NPD too short.
10 TKILS% Function is illegal in this state.
11 TKNFC% Not enough monitor free-core to perform this
function.
12 TKNFL% No free links. (NETLAT is full.)
13 TKNXN% Attempt to connect to a non-existent node.
14 TKUDW% IN or OUT UUO (.TKFOT or .TKFIN) did not skip.
Related Calls
NODE.
22-518
TTCALL [OPCODE 051]
TTCALL [OPCODE 051]
Function
Passes the monitor a code for an extended set of calls; these
calls perform terminal functions and are usually called TTCALLs.
Each defined TTCALL code also has a symbolic name; the TTCALLs
are discussed in alphabetical order by their symbolic names in
this section. For example, TTCALL 1, has the symbolic name
OUTCHR; its function is discussed under the name OUTCHR in this
section.
The TTCALLs and their symbolic names are:
Symbol TTCALL Function
INCHRW [TTCALL 0,]
OUTCHR [TTCALL 1,]
INCHRS [TTCALL 2,]
OUTSTR [TTCALL 3,]
INCHWL [TTCALL 4,]
INCHSL [TTCALL 5,]
GETLCH [TTCALL 6,]
SETLCH [TTCALL 7,]
RESCAN [TTCALL 10,]
CLRBFI [TTCALL 11,]
CLRBFO [TTCALL 12,]
SKPINC [TTCALL 13,]
SKPINL [TTCALL 14,]
IONEOU [TTCALL 15,]
Note that TTCALL operations are performed only on physical
terminals, not on a device with the logical name TTY.
22-519
UGETF [OPCODE 073]
UGETF [OPCODE 073]
Function
Returns the block number of the next free block on a DECtape; the
UGETF call is a no-op for other devices. Use FILOP. to perform
UGETF for an extended I/O channel.
Calling Sequence
UGETF channo,addr
return
. . .
addr: BLOCK 1
where: channo is the channel number of an initialized device.
addr is the address of the location where the monitor
will return a block number at addr.
Return
The block number of the next free block is returned at addr. If
this call precedes an ENTER, the inter-block spacing factor used
for output is reduced to that used for .SAV files. This function
is used to reduce the number of times the tape must reverse
direction when reading a large file.
Related Calls
FILOP.
22-520
UJEN [OPCODE 100]
UJEN [OPCODE 100]
Function
Dismisses a realtime interrupt from a user-supplied service
routine, if such a routine is in progress.
Calling Sequence
UJEN
return
Return
The monitor restores all accumulators and executes the
instruction
JEN @counter
where: counter is the address of the program counter stored by a
JSR instruction when the interrupt occurred.
Note that you can dismiss a user-mode interrupt with a JRST 12,
instruction.
Related Calls
RTTRP, TRPSET
22-521
UNLOK. [CALLI 120]
UNLOK. [CALLI 120]
Function
Unlocks one or both segments for the current job. Your job can
also be unlocked when the monitor implicitly executes a RESET for
your program. This occurs in any of the following cases:
o Your program executes a RUN monitor call.
o You issue any of the monitor commands that invoke a program.
Calling Sequence
MOVE ac,[XWD high,low]
UNLOK. ac,
error return
normal return
where: high can be 0 or 1. If set, the high segment is
unlocked. If clear, the status of the high segment
remains the same.
low can be 0 or 1. If set, the low segment is unlocked.
If clear, the status of the low segment remains the same.
If you set both high and low, both segments will be
unlocked.
A high segment shared by several jobs cannot be unlocked unless
the SN%LOK bit is off for all those jobs. This bit is bit 5 in
GETTAB table 14, .GTSGN. This bit will be on for each job that
issued the LOCK monitor call for the high segment, but has not
issued a subsequent UNLOK. call for the high segment.
Normal Return
The specified segments are unlocked and become eligible for
swapping. Any existing meter points (set by the METER. monitor
call) are cleared, and any real-time devices are reset. CORMAX
is changed to show the newly available pages, if any.
Error Return
The error return occurs only if the UNLOK. monitor call is not
implemented on your system. You must use either a RESET or an
EXIT monitor call instead.
Related Calls
LOCK
22-522
USETI [OPCODE 074]
USETI [OPCODE 074]
Function
Specifies a block on disk or DECtape to be read, written, or
updated. This function can also be performed by SUSET. and FILOP
calls. (Use FILOP. to perform USETI on an extended I/O channel.)
The monitor call sequence for reading a file starting at a
specific block is listed below:
LOOKUP
USETI
INPUT
The monitor call sequence for writing a file starting at a
specific block is shown below:
ENTER
USETO
OUTPUT
The monitor call sequence for updating a file is:
LOOKUP
ENTER
USETO ;or USETI
OUTPUT ;or INPUT
If your job is privileged (that is, running with the JACCT bit
set or running under [1,2]) and your program does not perform an
ENTER before a USETO or a LOOKUP before a USETI, the monitor
performs super I/O. If your job is not privileged and your
program does not perform an ENTER before a USETO or a LOOKUP
before a USETI, the monitor sets IO.BKT in the I/O status word.
The OPEN-ENTER-USETI sequence does not perform super I/O. It
returns an IO.IMP error. Likewise, an IO.IMP error results from
OPEN-LOOKUP-USETO. Refer to Chapter 11, Volume 1, for more
information about using file positioning calls.
Calling Sequence
USETI channo,n
return
where: channo is the channel number for an initialized device.
n is the number of the block to be used for I/O.
22-523
USETI [OPCODE 074]
For DECtape, the block number is relative to the
beginning of the tape.
For disk, n is a block number, when the file is open.
When the call is not preceded by a LOOKUP, n is the
address of a word where the block number is stored. This
is a super-USETI call, because this method allows you to
specify a block number, greater than 18 bits, relative to
the beginning of the structure.
The action of the USETI call on disk devices is determined by the
value of n as follows:
Value Meaning
-n, n = 2 to 10 (octal) The nth extended RIB is read.
-1 IO.EOF is set in the I/O status
word, causing an end-of-file on
the next INPUT. On the next
OUTPUT, the data is appended to
the file.
0 The prime RIB is read on the
next INPUT.
1 to file size The block specified is read on
next INPUT. If the file size is
greater than or equal to 777770,
it is recommended that you use
FILOP. function .FOUSI.
file size to 777770 The IO.EOF bit is set in the I/O
status word, causing an
end-of-file on the next INPUT.
Related Calls
FILOP., SUSET., USETO
Common Errors
o Not synchronizing I/O with USETI or USETO.
o Not initializing a device on channo.
22-524
USETO [OPCODE 075]
USETO [OPCODE 075]
Function
Selects a block on disk or DECtape to be written by an OUT
monitor call. This function can be performed by SUSET. and
FILOP. (Use FILOP. to perform USETO on an extended I/O
channel.) Refer to the USETI UUO and Chapter 11, Volume 1, for
more information.
Calling Sequence
USETO channo,n
return
Where: channo is the channel number for an initialized device.
n is the number of the I/O block.
For DECtape, n is the block number relative to the
beginning of the tape.
For disk, n is a block number if a previous ENTER has
been used to open a file. Otherwise, n is the address of
a word that contains the block number relative to the
beginning of the structure or unit (super-USETO),
allowing you to specify a block number greater than 18
bits.
The action of the USETO call for disk is determined by the value
of n as follows:
Value Meaning
-n for n = 2 to 10 (octal) Equivalent To a USETO 777776 to
777770; you may not write to the
RIBs of a file.
-1 The most recently input or
output block is re-written on
the next OUTPUT.
0 The IO.BKT is set in the file
status word.
1 to file size The specified block is written
on the next OUTPUT. If the file
size is greater than or equal to
777777, it is recommended that
you use FILOP. function .FOUSO.
22-525
USETO [OPCODE 075]
Value Meaning
file size to 777776 The monitor allocates all blocks
from the block after file size
to the block before the one
specified. Each block allocated
is written with zeros. The
block specified is the next
block written in the next
OUTPUT.
Related Calls
FILOP., SUSET., USETI
Common Errors
o Not synchronizing I/O with USETI or USETO.
o Not initializing a device on channo.
22-526
UTPCLR [CALLI 13]
UTPCLR [CALLI 13]
Function
Clears a DECtape directory. Use FILOP. to perform UTPCLR on an
extended I/O channel. The UTPCLR monitor call is a no-op for
other devices.
Calling Sequence
UTPCLR channo,
return
where: channo is the channel number for an initialized device.
Normal Return
The monitor clears the directory by clearing the first 83 words
(except those 7-bit bytes describing blocks 0, 1, 2, 100, and
1102 through 1105 octal).
Common Errors
o I/O to unassigned channel at user PC xxxxxx.
o Forgetting to place the channel in the ac or forgetting the
comma after channo.
o Not initializing a DECtape on channo.
22-527
UTRP. [CALLI 174]
UTRP. [CALLI 174]
Function
Sets or reads user trap instructions. This UUO allows a user to
handle non-zero section LUUOs, arithmetic overflows, or pushdown
list overflows by depositing instructions in locations 420, 421
and 422 in the UPMP. Usually these instructions are calls to
user-supplied subroutines.
Calling Sequence
MOVE ac,[XWD fcncode,addr]
UTRP. ac,
error return
normal return
. . .
addr: length
trapno
trapinstr
. . .
trapno
trapinstr
where: fcncode is one of the function codes described below.
addr is the address of the argument list.
length is the number of words in the argument list.
trapno is the number of a trap. Trap numbers are listed
below.
trapinstr is the instruction to call the trap routine.
The function codes and their meanings are:
Code Symbol Meaning
0 .UTRED Reads the contents of the trap location. A zero
opcode cannot be used as a trap instruction, but
a zero fullword here will restore monitor
handling of the specific condition.
1 .UTSET Sets the contents of the trap location.
22-528
UTRP. [CALLI 174]
The trap numbers are:
Code Symbol Meaning
0 .UTLUU Stores the contents of the 4 word LUUO trap
block in the UPT.
1 .UTAOF Arithmetic overflow trap (location 421 in the
UPMP).
2 .UTPOV Pushdown list overflow trap (location 422 in the
UPMP).
Normal Return
The specified traps are cleared or set.
Error Return
One of the following error codes is returned in the ac:
Code Symbol Error
1 UTIAD% Illegal address.
2 UTUKF% Unknown function.
3 UTITN% Illegal trap number.
4 UTIUT% Illegal user trap instruction.
Related Calls
ABRENB, .JBINT trapping, PSI system
22-529
WAIT [CALLI 10]
WAIT [CALLI 10]
Function
Causes program execution to wait until all data transmissions on
a given channel are completed. Use FILOP. to perform WAIT on an
extended I/O channel.
Calling Sequence
WAIT channo,
return
where: channo is the channel number for an initialized device.
Normal Return
The monitor stops your program's execution until transmissions on
the channel are completed.
Common Errors
o Using WAIT on a tape which is spacing (see MTWAT.).
o Not initializing a device on channo.
o Omitting the comma after channo.
22-530
WAKE [CALLI 73]
WAKE [CALLI 73]
Function
Sets the wake bit for a specified job.
Calling Sequence
MOVEI ac,jobno
WAKE ac,
error return
normal return
Where: jobno is the number of a logged-in job (use -1 for the
current job).
You can design a real-time process control job to run other
process control jobs when specific alarm conditions occur. WAKE
can be called from an RTTRP job running at interrupt level; this
allows the real-time job to wake its background quickly when
necessary. See the RTTRP monitor call for restrictions on
accumulators when calling from the interrupt level.
If your job does not have the required privileges, the error
return occurs and the monitor clears the ac. A JACCT or [1,2]
job may WAKE any job. If any condition enabled in the last HIBER
call occurs, the wake bit for the job is set. At the next HIBER
call, the wake bit is cleared and the monitor returns at the
normal return immediately. The wake bit prevents the job from
oversleeping a wake condition.
Normal Return
The specified job is awake and resumes execution at the normal
return for the HIBER call that made the job dormant.
Error Return
Your job did not have the required privileges. The ac is
cleared.
Related Calls
Refer to the HIBER monitor call.
22-531
WHERE [CALLI 63]
WHERE [CALLI 63]
Function
Returns the node number for a device.
Calling Sequence
|
| / MOVE ac,[SIXBIT/device/] \
| | MOVEI ac,channo |
| \ MOVEI ac,udx /
| WHERE ac,
| error return
| normal return
where: device is the SIXBIT physical or logical name of a
device.
channo is the number of an initialized channel.
udx is the Universal Device Index for a device.
When your program specifies OPR as the device, the monitor
returns the node number at which your job is logically located.
Refer to the LOCATE command description in the Commands Manual.
When your program specifies CTY as the device, the monitor
returns the node number of your job's host system.
When your program specifies TTY as the device, the monitor
returns the node number to which your terminal is physically
located.
Normal Return
The monitor returns the status flags for the node and the node
number for the given device in the ac. The format of the
returned word is:
Bits Symbol Meaning
0-12 Reserved for use by DIGITAL.
13 RM.SDU Dial-up node.
22-532
WHERE [CALLI 63]
Bits Symbol Meaning
14-17 RM.SUP Status of the node:
Value Symbol Status
1 .RMSUN Not in contact with central
site.
2 .RMSUD Down.
4 .RMSUG Loading.
10 .RMSUL Loaded.
18-35 Node number for device.
Error Return
A nonexistent device was specified.
Related Calls
LOCATE, NODE., NETOP.
22-533
23-1
CHAPTER 23
GETTAB TABLES
The TOPS-10 monitor maintains tables that contain system and job
information. Values from some of these tables can be retrieved by a
program using the GETTAB monitor call.
23.1 HOW TO USE GETTAB TABLES
The calling sequence for GETTAB is:
MOVE ac,[XWD index,table]
GETTAB ac,
error return
normal return
where: ac is an accumulator.
index is the index into the table, which may be a job number,
a table item number, a high-segment number, or a class code,
depending on the table's organization.
table is the symbolic name of the desired table.
For those tables indexed by table item numbers, it is easier and more
reliable to use the calling sequence:
MOVE ac,[item]
GETTAB ac,
error return
normal return
where: item is the symbolic name of the desired item as defined in
UUOSYM. Using this calling sequence eliminates the need to
name both the table and the item desired. In the following
table descriptions, items marked by a * are described in more
detail at the end of the table.
23-1
GETTAB TABLES
For tables indexed by job numbers, use the index -1 to specify the
current job; use the index -2 to specify the job's current high
segment.
23.2 HOW TO USE GETTAB SUBTABLES
Some GETTAB tables have subtables. In this section, each subtable is
described after the description of the table containing it. Each
subtable description includes the calling sequence for accessing items
in the subtable.
Each subtable has a single entry in the GETTAB table. This entry
returns <length>B8+offset, where length is the length of the subtable
and offset is the first entry in the GETTAB table that corresponds to
the subtable.
Contents Offset GETTAB Table
0 entry 0
1 1
5B8+10 2 subtable 1 pointers
3 entry 3
4B8+15 4 subtable 2 pointers
5 entry 5
6 entry 6
7 entry 7
10 subtable 1 (entry 0)
11
23-2
GETTAB TABLES
Contents Offset GETTAB Table
subtable
1 12
13 s
14 c
15
16
subtable
2 17
20
An example of the use of GETTAB subtables follows below:
TITLE GTRSP - Example of CPU response sub-GETTAB
SUBTTL Hanley A. Strappman 13-June-80 /HAS
SEARCH UUOSYM ;Use standard symbols
T1=1 ;Accumulators
T2=T1+1
P1=5
P=17
PLN=100 ;Length of program stack
ARRAY PDL[PLN] ;The program stack
NCPUS==6 ;How many CPUs this program allows
GTRSP: JFCL ;In case of CCL RUN
RESET ;Reset the world
MOVE P,[IOWD PLN,PDL] ;Set up stack
MOVSI P1,-NCPUS ;For loop control
LOOP: HRRZ T1,P1 ;Get number of next CPU
PUSHJ P,GETIT ;Get the data
JRST NEXT ;No such table
23-3
GETTAB TABLES
;Insert here the code to process the data, then
NEXT: AOBJN P1,LOOP ;Go on to next CPU
EXIT ;Done
;Subroutine to return in T2 the number of TTY input-to-input
;UUO responses for the CPU specified by T1.
GETIT: LSH T1,1 ;Variables table numbers go up by twos
; (for example, .GTC1V=.GTC0V+2)
MOVE T2,[%CCRSP] ;CPU0's subtable pointer
ADD T2,T1 ;CPUn's subtable pointer
GETTAB T2, ;Get base index of subtable
POPJ P, ; ??? Must be an old monitor
JUMPE T2,CPOPJ ;No such subtable
ADDI T2,%CVRNI ;Add entry offset to subtable base
HRL T2,T2 ;This becomes the item number
HRRI T2,.GTCOV ;Right half is table number which
ADD T2,T1 ; equals <CPU0 index> + 2*<CPU number>
GETTAB T2, ;Finally get the subtable entry
POPJ P, ; ???Must be an old monitor
AOS (P) ;Skip return means good data in T2
CPOPJ: POPJ P, ;All done
END GTRSP
23.3 ADDING ITEMS TO THE MONITOR'S GETTAB TABLES
System programmers can add words (items) to the monitor's GETTAB
tables. The items added must have negative indexes, and must be added
at the top of the table in the order -n, -(n-1), -(n-2), ... -2, -1.
When the monitor is assembled, the range of valid indexes for each
table must begin with the lowest (most negative) index, and proceed to
the highest index.
It is good programming practice to use a .UNV file containing symbols
for these items for use in programs. This usage is similar to that of
searching UUOSYM.UNV.
23-4
GETTAB TABLES
23.4 ADDING NEW GETTAB TABLES TO THE MONITOR
System programmers can add completely new GETTAB tables to the
monitor. These tables must have negative table numbers, and must be
added at the beginning of COMMON.MAC in the order -n, -(n-1), -(n-2),
... -2, -1. When the monitor is assembled, the range of valid table
numbers must begin with the lowest (most negative) table number, and
proceed to the highest table number. Within these added tables, items
must be indexed sequentially.
For example, the system programmer can add a new table with the number
-1. This table must be added to the source code in the monitor module
UUOCON. The items in this table could begin and end with negative
indexes; for example, the indexes could begin with -14 and end with
-1. The items could begin with a negative index and end with a
positive index; for example, the indexes could begin with -10 and end
with 27. Or the items could begin and end with nonnegative indexes;
for example the indexes could begin with 0 and end with 15.
23-5
GETTAB TABLES
23.5 ALPHABETIC LISTING
Because GETTAB tables are often referred to by symbolic name, the
following list of GETTAB tables is provided in alphabetical order:
Symbol Table No. Description
.GTABS 111 Address Break Word
.GTADR 1 Job Relocation and Protection
.GTC0C 55 CPU0 CPU Data Block Constants
.GTC0V 56 CPU0 CPU Data Block Variables
.GTC1C 57 CPU1 CPU Data Block Constants
.GTC1V 60 CPU1 CPU Data Block Variables
.GTC2C 61 CPU2 CPU Data Block Constants
.GTC2V 62 CPU2 CPU Data Block Variables
.GTC3C 63 CPU3 CPU Data Block Constants
.GTC3V 64 CPU3 CPU Data Block Variables
.GTC4C 65 CPU4 CPU Data Block Constants
.GTC4V 66 CPU4 CPU Data Block Variables
.GTC5C 67 CPU5 CPU Data Block Constants
.GTC5V 70 CPU5 CPU Data Block Variables
.GTCAP 153 Job Capability Word
.GTCM2 43 SET Command Names
.GTCMP 112 Obsolete
.GTCMT 75 SET TTY Command Names
.GTCMW 101 SET WATCH Command Names
.GTCNF 11 System Configuration Table
.GTCNO 33 Charge Number
.GTCOJ 122 Obsolete
.GTCOM 30 Monitor Command Names
.GTCOR 27 Core Table (Obsolete)
.GTCQP 121 Scheduler Class Quota
.GTCRS 44 Hardware Status After Crash
.GTCRT 123 Class Runtime
.GTCTX 175 Context Table
.GTCVL 102 Current Page Limits
.GTDBS 21 Disk Block Seconds (Obsolete)
.GTDCD 160 CONI/DATAI To Device Status Block
.GTDCF 116 Obsolete
.GTDCN 164 SET DEFAULT Command Argument(s)
.GTDDB 200 I/O Wait DDB
.GTDEV 24 Segment Device or Structure
.GTDFL 140 User Defaults for Job
.GTDVL 110 Pointer to Logical Name Table
.GTEBR 132 EBOX Jiffy Remainder
.GTEBT 131 KL10 EBOX Time
.GTEDN 72 Ersatz Device Names
.GTENQ 127 ENQ/DEQ Statistics
.GTEQJ 163 ENQ/DEQ Queue Header
.GTETH 202 Ethernet Information
.GTFET 71 Feature Test Settings
.GTGTB 155 GETTAB Immediate
23-6
GETTAB TABLES
Symbol Table No. Description
.GTIDX 154 Range of GETTAB Tables
.GTIMI 176 Job Page Count
.GTIMO 177 Swapped-Out Page Count
.GTIPA 104 IPCF Statistics
.GTIPC 77 IPCF Miscellaneous Data
.GTIPI 106 PID for [SYSTEM]INFO
.GTIPP 105 IPCF Pointers and Counts
.GTIPQ 107 IPCF Flags and Quotas
.GTISC 45 Swap-In Scan Tables
.GTJLT 130 LOGIN Time for Job
.GTJTC 120 Job Type and Scheduler Class
.GTKCT 5 Job Kilo-Core Ticks
.GTLIM 40 Time Limit and Batch Status
.GTLOC 26 Remote Station Number
.GTLBS 165 Large Buffer Size
.GTLVD 16 Level D Disk Parameters
.GTMBR 134 MBOX Jiffy Remainder
.GTMBT 133 KL10 MBOX Time
.GTMVL 103 Maximum Page Limits
.GTNDB 161 Byte Pointers to Node Data Block
.GTNM1 31 User Name (first 6 characters)
.GTNM2 32 User Name (last 6 characters)
.GTNSW 12 Nonswapping Data Table
.GTNSP 172 DECnet session control (Obsolete)
.GTNTP 141 Network Performance Data
.GTOBI 157 WTO and Batch Data
.GTODP 15 ONCE-only Disk Parameters
.GTOSC 46 Swap-Out Scan Tables
.GTPC 152 Wait DDB and User PC
.GTPDB 162 Job PDB Word
.GTPID 76 Process Communication ID (IPCF)
.GTPPN 2 Job's PPN
.GTPRG 3 User Program Name
.GTPRV 6 Job Privilege Flags
.GTPTR 166 Program To Run
.GTQJB 42 Scheduling Queue Table (Obsolete)
.GTQQQ 41 Scheduling Queue Headers (Obsolete)
.GTRCT 17 Disk Blocks Read
.GTRDI 136 Program Run Directory
.GTRDV 135 Program Run Device
.GTRFN 137 Program Run File name
.GTRS0 145 First SFD in Run Path
.GTRS1 146 Second SFD in Run Path
.GTRS2 147 Third SFD in Run Path
.GTRS3 150 Fourth SFD in Run Path
.GTRS4 151 Fifth SFD in Run Path
.GTRSP 50 Response Counter Table
.GTRTD 37 Realtime Status Words
.GTSCN 73 Scanner Data
.GTSDT 13 Swapping Data Table
23-7
GETTAB TABLES
Symbol Table No. Description
.GTSGN 14 High Segment Parameters
.GTSG2 203 High Segment Section Number
.GTSID 126 Special PID Table
.GTSLF 23 GETTAB Table Data
.GTSNA 74 Last SEND ALL in 9-bit
.GTSPA 142 Scheduler Performance Data
.GTSPL 36 Spooling Control Flags
.GTSPS 54 Status of Subsequent Processors
.GTSQ 125 Obsolete
.GTSQH 124 Obsolete
.GTSSC 47 Scheduler Scan Tables
.GTSST 115 Scheduler Statistics
.GTST2 117 Second Job Status Word
.GTSTS 0 Job Status Word
.GTSWP 7 Job Swapping Parameters
.GTSYS 51 System-Wide Data
.GTTDB 22 Last Allocation (Obsolete)
.GTTIM 4 User Runtime
.GTTMP 34 TMPCOR Pointers (Obsolete)
.GTTNM 156 Terminal Type Names
.GTTRQ 53 Time in Run Queue
.GTTTY 10 Job's Controlling Terminal
.GTUPM 100 Physical Page Number of UPMP
.GTUUC 144 Monitor Calls Executed
.GTVIR 201 Job's Virtual Size
.GTVKS 143 Virtual Kilo-Core Ticks
.GTVM 113 Virtual Memory Data
.GTVRT 114 Paging Rage
.GTWCH 35 Watch Bits
.GTWCT 20 Disk Blocks Written
.GTWHY 52 Operator Reload Comments
.GTWSN 25 Names of Wait States
23.6 TOPS-10 GETTAB TABLES
The remainder of this chapter describes the TOPS-10 GETTAB tables.
For each table, the contents of the table, the indexing scheme, the
GETTAB calling sequence, and a word map for the table are described.
The description of each GETTAB table also includes the associated
monitor table. The monitor tables are described in the TOPS-10
Monitor Tables descriptions, available in the TOPS-10 Software
Notebook Set.
23-8
GETTAB TABLES
.GTSTS - Job Status Word
GETTAB Table 0
Contents One word for each job running on the system, giving
the status word for the job. (There is a second job
status word in GETTAB table .GTST2, Number 117.) The
bits in the job status word may vary from monitor to
monitor; therefore you should not reference .GTSTS in
a program that is monitor-independent.
Indexed by Job number or segment number.
Monitor table JBTSTS
Calling MOVE ac,[XWD jobno,.GTSTS]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job) or a high-segment number (use -2
for the current high segment).
|=======================================================|
| Job status |
|=======================================================|
The only documented bit in this word is JS.XO (bit 25), which
indicates a program that is execute-only. Refer to the Monitor Tables
descriptions for more information about the job status bits.
23-9
GETTAB TABLES
.GTADR - Job Relocation and Protection
GETTAB Table 1
Contents One word for each job running on the system, giving
the relocation addresses and protection for the job.
The bits in this word may vary from monitor to
monitor; therefore you should not reference .GTADR in
a program that is monitor-independent.
Indexed by Job number or segment number.
Monitor Table JBTADR
Calling MOVE ac,[XWD jobno,.GTADR]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job) or a high-segment number (use -2
for the current high segment).
|=======================================================|
| Job relocation and protection |
|=======================================================|
23-10
GETTAB TABLES
.GTPPN - Project-programmer Number
GETTAB Table 2
Contents One word for each job running on the system, giving
the project-programmer number (PPN) for the job.
Indexed by Job number or segment number.
Monitor Table JBTPPN
Calling MOVE ac,[XWD jobno,.GTPPN]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job) or a high-segment number (use -2
for the current high segment).
|=======================================================|
| Project-programmer number |
|=======================================================|
where project-programmer number is the job's PPN or
the segment owner's PPN.
If the high segment's file is in an SFD, this word is
returned as 0,,path-pointer, where path-pointer is a
pointer to a path block in monitor memory. PEEK
privileges are required to read the monitor's path
block.
23-11
GETTAB TABLES
.GTPRG - User Program Name
GETTAB Table 3
Contents One word for each job running on the system, giving
the SIXBIT name of the current user program.
Indexed by Job number or segment number.
Monitor Table JBTNAM
Calling MOVE ac,[XWD jobno,.GTPRG]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job) or a high-segment number (use -2
for the current high segment).
|=======================================================|
| SIXBIT program name |
|=======================================================|
For jobs, this is the program name that can be set by
SETNAM. The default is the file name of the runnable
program (.EXE file). For segments, this is the
segment name. If the segment is not sharable, 0 is
returned. If sharable, it is the file name of the
.EXE file.
23-12
GETTAB TABLES
.GTTIM - User Runtime
GETTAB Table 4
Contents One word for each job running on the system, giving
the total runtime (in jiffies) for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTTIM]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job).
|=======================================================|
| Total runtime in ticks |
|=======================================================|
23-13
GETTAB TABLES
.GTKCT - Job Kilo-Core Ticks
GETTAB Table 5
Contents One word for each job running on the system, giving
the total kilo-core ticks for the job. This value is
equivalent to the product of the number of clock
ticks in the job's runtime and the average number of
Ks of core used in each tick.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTKCT]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Kilo-core ticks |
|=======================================================|
23-14
GETTAB TABLES
.GTPRV - Job Privilege Flags
GETTAB Table 6
Contents One word for each job running on the system, giving
the privilege bits for the job.
Indexed by Job number.
Monitor Table JBTPRV
Calling MOVE ac,[XWD jobno,.GTPRV]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|==================================================|
| Job privilege bits |
|==================================================|
Privilege bits for each job are as follows:
Bits Symbol Privilege
0 JP.IPC IPCF privilege.
1-2 JP.DPR Highest disk priority for the job (a
value in the range 0 to 3).
3 JP.MET METER. privilege.
4 JP.POK POKE. privilege.
5 JP.CCC Privilege to change CPU
specification with either a command
or a monitor call.
6-9 JP.HPQ Highest high-priority queue
available to the job (a value in the
range 0 to 17 octal).
10 JP.NSP Device unspooling privilege.
11 JP.ENQ ENQ/DEQ privilege (allows you to use
-2 (.EQFGL) in the ENQ. block to set
global privileges).
12 JP.ADM System Administrator privilege.
13 JP.RTT RTTRP privilege.
14 JP.LCK LOCK privilege.
15 JP.TRP TRPSET privilege.
16 JP.SPA PEEK and SPY privilege for any core.
17 JP.SPM PEEK and SPY privilege for monitor
core.
Bits in the right half are reserved for customer
definition.
23-15
GETTAB TABLES
.GTSWP - Job Swapping Parameters
GETTAB Table 7
Contents One word for each job running on the system, giving
the swapping parameters for the job. The definitions
of the bits in this word may vary from monitor
release to monitor release; therefore you should not
reference .GTSWP in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table JBTSWP
Calling MOVE ac,[XWD jobno,.GTSWP]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Swapping parameters |
|=======================================================|
23-16
GETTAB TABLES
.GTTTY - Job's Controlling Terminal
GETTAB Table 10
Contents One word for each job running on the system, giving
the controlling terminal for the job. The
definitions of the bits in this word may vary from
monitor release to monitor release; therefore you
should not reference .GTTTY in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table TTYTAB
Calling MOVE ac,[XWD jobno,.GTTTY]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Controlling terminal |
|=======================================================|
The right half contains the address of the DDB for
the job's controlling TTY. This is always the
address of the DDB, even if the job is detached. If
0, there is no such job number.
23-17
GETTAB TABLES
.GTCNF - System Configuration Table
GETTAB Table 11
Contents Data describing the current configuration of the
system.
Indexed by Item number.
Monitor Table CNFTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below. When an item name is followed by a *,
that item is more fully described at the end of the
table.
Word Symbol Map
|=======================================================|
0,,11 %CNFG0 | System name (1st of 5 ASCIZ words) |
|-------------------------------------------------------|
1,,11 %CNFG1 | System name (2nd of 5 ASCIZ words) |
|-------------------------------------------------------|
2,,11 %CNFG2 | System name (3rd of 5 ASCIZ words) |
|-------------------------------------------------------|
3,,11 %CNFG3 | System name (4th of 5 ASCIZ words) |
|-------------------------------------------------------|
4,,11 %CNFG4 | System name (5th of 5 ASCIZ words) |
|=======================================================|
5,,11 %CNDT0 | System creation date (1st of 2 ASCIZ words) |
|-------------------------------------------------------|
6,,11 %CNDT1 | System creation date (2nd of 2 ASCIZ words) |
|=======================================================|
7,,11 %CNTAP | SIXBIT name of system device |
|=======================================================|
10,,11 %CNTIM | Encoded time of day in jiffies |
|=======================================================|
11,,11 %CNDAT | Encoded date (15-bit binary format) |
|=======================================================|
12,,11 %CNSIZ | System memory size (in words) |
|=======================================================|
13,,11 %CNOPR | SIXBIT name of operator TTY |
|=======================================================|
14,,11 %CNDEV | Start of DDB chain | Reserved |
|=======================================================|
15,,11 %CNSJN |-(Max number of high segs) |Max number of current jobs |
|=======================================================|
23-18
GETTAB TABLES
|=======================================================|
16,,11 %CNTWR | Two-register hardware and software flag |
|=======================================================|
17,,11 %CNSTS* | Feature test switches | Switch states |
|=======================================================|
20,,11 %CNSER | CPU0 serial number |
|=======================================================|
21,,11 %CNNSM | Number of nanoseconds per memory cycle |
|=======================================================|
22,,11 %CNPTY | Number of 1st PTY (CTY+1) | Number of PTYs in system |
|=======================================================|
23,,11 %CNFRE | Pointer to bit map of core blocks |
|=======================================================|
24,,11 %CNLOC | Address of low-segment core blocks |
|=======================================================|
25,,11 %CNSTB | Obsolete |
|=======================================================|
26,,11 %CNOPL | Pointer to line data block (LDB) of OPR TTY |
|=======================================================|
27,,11 %CNTTF | Pointer to TTY free chunks |
|=======================================================|
30,,11 %CNTTC | Number of TTY chunks | Address of 1st TTY chunk |
|=======================================================|
31,,11 %CNTTN | Number of free TTY chunks |
|=======================================================|
32,,11 %CNLNS | Pointer to current command TTY |
|=======================================================|
33,,11 %CNLNP | -Number of TTY+PTY+CTY lines,,addr of LINTAB |
|=======================================================|
34,,11 %CNVER | Monitor version number |
|=======================================================|
35,,11 %CNDSC | -Len of dataset ctrl tbl,,addr of ctrl tbl |
|=======================================================|
36,,11 %CNDLS | Obsolete |
|=======================================================|
37,,11 %CNCCI | Obsolete |
|=======================================================|
40,,11 %CNSGT | Ptr to last dormant seg deleted to free a seg number |
|=======================================================|
41,,11 %CNPOK | Last location changed by a POKE. monitor call |
|=======================================================|
42,,11 %CNPUC | Job that made last POKE. | Number of POKE.s made |
|=======================================================|
43,,11 %CNWHY | SIXBIT reason for last reload (operator input) |
|=======================================================|
44,,11 %CNTIC | Number of clock ticks per second |
|=======================================================|
45,,11 %CNPDB | Pointer to process data block (PDB) pointer tables |
|=======================================================|
46,,11 %CNRTC | Resolution of runtime clock (units/sec) |
|=======================================================|
47,,11 %CNCHN | Ptr to channel data block | Reserved |
|=======================================================|
23-19
GETTAB TABLES
|=======================================================|
50,,11 %CNLMX | Maximum number of logged-in jobs allowed |
|=======================================================|
51,,11 %CNBMX | Maximum number of batch jobs allowed |
|=======================================================|
52,,11 %CNBMN | Minimum number of jobs reserved to batch |
|=======================================================|
53,,11 %CNDTM | Date/time in universal date/time format |
|=======================================================|
54,,11 %CNLNM | Number of jobs logged in |
|=======================================================|
55,,11 %CNBNM | Number of batch jobs logged in |
|=======================================================|
56,,11 %CNYER | Current year |
|=======================================================|
57,,11 %CNMON | Current month |
|=======================================================|
60,,11 %CNDAY | Current day of the month |
|=======================================================|
61,,11 %CNHOR | Current hour (0-23) |
|=======================================================|
62,,11 %CNMIN | Current minute (0-59) |
|=======================================================|
63,,11 %CNSEC | Current second (0-59) |
|=======================================================|
64,,11 %CNGMT | Offset from Greenwich Mean Time |
| (such that %CNGMT +%CNDTM = GMT) |
|=======================================================|
65,,11 %CNDBG | Debug status |
|=======================================================|
66,,11 %CNFRU | Number of free core blocks in use by monitor |
|=======================================================|
67,,11 %CNTCM | Addr of last TTY chunk |
|=======================================================|
70,,11 %CNCVN | Customer version number |
|-------------------------------------------------------|
71,,11 %CNDVN | DIGITAL version number |
|=======================================================|
72,,11 %CNDFC | Number of data channels on the system |
|=======================================================|
73,,11 %CNRTD | Number of realtime devices |
|=======================================================|
74,,11 %CNHPQ | Number of high-priority queues |
|=======================================================|
75,,11 %CNLDB | TTY device data blk wrd pointing to line data blk |
|=======================================================|
76,,11 %CNMVO | Maximum vector offset for PISYS. |
|-------------------------------------------------------|
77,,11 %CNMIP | Maximum priority for PISYS. |
|=======================================================|
100,,11 %CNMER |Offset of MTA err rep word | Address of 1st MTA DDB |
|=======================================================|
23-20
GETTAB TABLES
|=======================================================|
101,,11 %CNET1 | User address of exec AC T1 (for DAEMON) |
|=======================================================|
102,,11 %CNLSD | Length of short device data block |
|-------------------------------------------------------|
103,,11 %CNLLD | Length of long device data block |
|-------------------------------------------------------|
104,,11 %CNLDD | Length of disk device data block |
|=======================================================|
105,,11 %CNEXM | Addr in JOBDAT of last Examine or Deposit command |
|=======================================================|
106,,11 %CNST2* | Software configuration flags |
|=======================================================|
107,,11 %CNPIM | Minumum condition in PISYS. |
|=======================================================|
110,,11 %CNPIL | Length of internal PITs |
|=======================================================|
111,,11 %CNPIA | Address of JBTPIA |
|=======================================================|
112,,11 %CNMNT* | Monitor type |
|=======================================================|
113,,11 %CNOCR | Addr of 1st CDR DDB | Offset to card count |
|-------------------------------------------------------|
114,,11 %CNOCP | Addr of 1st CDP DDB | Offset to card count |
|=======================================================|
115,,11 %CNPGS | Unit of core allocation (in words) |
|-------------------------------------------------------|
116,,11 %CNMMX |Maximum allowable CORMAX (total phys mem for all jobs |
|=======================================================|
117,,11 %CNNSC | Number of scheduler classes |
|=======================================================|
120,,11 %CNUTF | Exponential user time factor |
|=======================================================|
121,,11 %CNHSO | Address of start of monitor high segment |
|=======================================================|
122,,11 %CNHSL | Length of monitor high segment |
|=======================================================|
123,,11 %CNNWC | Number of words in core (highest addr of on-line mem) |
|=======================================================|
124,,11 %CNNXM | AOBJN pointer to NXMTAB used to scan for zeros |
|=======================================================|
125,,11 %CNNDB | Addr of 1st network node data block |
|=======================================================|
126,,11 %CNTKB | Offset in MTA KDB of addr of CDB |
|=======================================================|
127,,11 %CNDDC | Offset into TTY DDB of character counts |
|=======================================================|
130,,11 %CNHDL | Potentially hung device list |
|=======================================================|
131,,11 %CNBTX | Address of reload .CCL text for BOOTS |
|=======================================================|
23-21
GETTAB TABLES
|=======================================================|
132,,11 %CNTDB | Offset in MTA UDB of addr of DDBs |
|=======================================================|
133,,11 %CNMTK | Addr of 1st MTA KDB in system |
|=======================================================|
134,,11 %CNCPU | Number of CPUs monitor was built for |
|=======================================================|
135,,11 %CNDJB | Byte pointer to jobno in DDB |
|=======================================================|
136,,11 %CNSUP | System uptime |
|=======================================================|
137,,11 %CNBCP | Bootstrap CPU number |
|=======================================================|
140,,11 %CNBCL | Bootstrap CTY line number |
|=======================================================|
141,,11 %CNNCR | Number of CPUs allowed to run |
|=======================================================|
142,,11 %CNMBS | Monitor bootstrap file structure (from BOOTS) |
|-------------------------------------------------------|
143,,11 %CNMBF | Monitor bootstrap file name |
|-------------------------------------------------------|
144,,11 %CNMBX | Monitor bootstrap file extension |
|-------------------------------------------------------|
145,,11 %CNMBD | Monitor bootstrap file directory |
|=======================================================|
146,,11 %CNBPM | Maximum number of SNOOP. breakpoints allowed |
|=======================================================|
147,,11 %CNMXF | First free virtual address about the monitor |
|=======================================================|
150,,11 %CNLVO | Virtual address where LDBs start |
|=======================================================|
151,,11 %CNHXC | Maximum number of FILOP. extended channels |
|=======================================================|
152,,11 %CNVSH | Monitor virtual start address of high segment |
|=======================================================|
153,,11 %CNRST | Universal date/time of last role switch |
| on multiple CPU systems |
|=======================================================|
154,,11 %CNDCH | Offset into LDB of LDBDCH |
|=======================================================|
155,,11 %CNSF1 | Monitor bootstrap 1st SFD |
|=======================================================|
156,,11 %CNSF2 | Monitor bootstrap 2nd SFD |
|=======================================================|
157,,11 %CNSF3 | Monitor bootstrap 3rd SFD |
|=======================================================|
160,,11 %CNSF4 | Monitor bootstrap 4th SFD |
|=======================================================|
161,,11 %CNSF5 | Monitor bootstrap 5th SFD |
|=======================================================|
162,,11 %CNFLN | TTY number of FRCLIN |
|=======================================================|
23-22
GETTAB TABLES
|=======================================================|
163,,11 %CNPNP | Pointer to PTY table |
|=======================================================|
164,,11 %CNCAT | Pointer to network link address table |
|=======================================================|
165,,11 %CNLPD | Length of PDB |
|=======================================================|
166,,11 %CNJPK* | Max. size of JOBPEK transfers |
|=======================================================|
167,,11 %CNDAE* | Previous and current monitor versions |
|=======================================================|
170,,11 %CNHSH | AOBJN pointer to ENQ. HSHTAB |
|=======================================================|
171,,11 %CNACS | Offset to PDB for account string |
|=======================================================|
172,,11 %CNTOP | Pointer to TRMOP. dispatch table |
|=======================================================|
173,,11 %CNSFD | Pointer to JBTSFD |
|=======================================================|
174,,11 %CNCIP | Pointer to CIPWT |
|=======================================================|
175,,11 %CNPRV | Privilege word to be used by privileged jobs |
| (FRCLIN, INITIA) |
|=======================================================|
176,,11 %CNCV1 | First word of CTERM version string (8-bit) |
|=======================================================|
177,11 %CNCV2 | Second word of CTERM version string (8-bit) |
|=======================================================|
200,11 %CNLHN | Pointer to LAT host node data base |
|=======================================================|
201,,11 %CNIVM | "AND" mask for .GTIMI/.GTIMO/.GTVIR |
|=======================================================|
202,,11 %CNACB | Address of first Allocation Control Block |
|=======================================================|
203,,11 %CNAHB | Address of first Allocation Header Block |
|=======================================================|
The items in the configuration table are defined below:
Item Symbol Contains
17 %CNSTS Feature test switch flags and switch state flags
are as follows:
Bits Symbol Feature or State
0 ST%DSK Disk system.
1 ST%SWP Swapping system.
2 ST%LOG LOGIN system.
3 ST%FTT Full duplex TTY software.
4 ST%PRV Privileged features exist.
5 ST%TWR Software is two-segment
(reentrant).
23-23
GETTAB TABLES
Item Symbol Contains
Bits Symbol Feature or State
6 ST%CYC System clock runs at 50 Hz.
9 ST%TDS Type of disk system:
0 = 4-series
1 = 5-series
2 = spooled disk
10 ST%IND Independent PPNs on disk.
11 ST%IMG Image mode supported on TTYs.
12 ST%DUL Dual-processor system.
13 ST%MRB Multiple RIBs supported.
14 ST%HPT High-precision time accounting
supported.
15 ST%EMO Monitor overhead excluded from
accounting.
16 ST%RTC System has realtime clock (DK10).
17 ST%MBF System supports FOROTS.
18-25 Reserved.
26 ST%NDL No automatic down-line load of
DC72, DC71, and DAS80 series
remote stations.
27 ST%NOP No operator coverage.
28 ST%NSP Device unspooling allowed without
privilege.
29 ST%ASS System assigning/initializing
restricted devices allowed.
32 ST%NRT No remote TTYs.
33 ST%BON Batch jobs only.
34 ST%NRL No remote logging-in.
35 ST%NLG No logging-in except operator
CTY.
65 %CNDBG Debugging flags are as follows:
Bits Symbol Meaning
0 ST%DBG System debugging allowed.
1 ST%RDC Reload system on DEBUG stopcode.
2 ST%RJE Reload system on JOB stopcode.
3 ST%NAR No automatic reloading.
4 ST%CP1 Stop CPU0 on CPU1 halt.
18 ST%BP0 CPU0 can enter EDDT mode using
XCT .C0DDT.
19 ST%BP1 CPU1 can enter EDDT mode using
XCT .C1DDT.
20 ST%BP2 CPU2 can enter EDDT mode using
XCT .C2DDT.
21 ST%BP3 CPU3 can enter EDDT mode using
XCT .C3DDT.
22 ST%BP4 CPU4 can enter EDDT mode using
XCT .C4DDT.
23-24
GETTAB TABLES
Item Symbol Contains
Bits Symbol Meaning
23 ST%BP5 CPU5 can enter EDDT mode using
XCT .C5DDT.
77B23 ST%BPT Mask for all CPU breakpoint bits.
106 %CNST2 Configuration feature flags are as follows:
Bits Symbol Feature
6 ST%END DECnet is running as an Ethernet
end node.
7 ST%NPP Disabled starting primary
protocol on DTEs.
8 ST%RCM Restricted commands monitor.
9 ST%EXA Extended addressing in effect.
10 ST%D36 Monitor has DECnet Phase III
code.
11 ST%KLP Monitor uses KL-paging.
12 ST%MDA Mountable device allocation is in
effect.
13 ST%LSC Low segment of monitor is cached.
14 ST%ACV Account validation.
15 ST%NER Version 6.03 error reporting.
16 ST%NCS Scheduler is not a class system
scheduler.
17 ST%ITA Interval timer available.
18 ST%NDN Network devices have names of the
form gggnnu, where ggg is a
generic device name (such as
TTY), nn is the last two digits
of the node number, and u is the
unit number.
19 ST%XPI PI time excluded from runtime.
20 ST%ERT EBOX/MBOX runtime (KL10 only).
21 ST%EXE .EXE files written by SAVE and
SSAVE.
22 ST%NJN System uses 9-bit job numbers.
23 ST%EER Extended error reporting.
24 ST%TAP TAPSER included in monitor.
25 ST%MBE Massbus error reporting.
26 ST%GAL GALAXY supported.
27 ST%ENQ ENQ./DEQ. monitor calls included.
28 ST%SHC Scheduler is a class type
scheduler.
29 ST%NSE Nonsuperseding ENTER call.
30 ST%MSG MPX channels supported.
31 ST%PSI Software interrupt supported.
32 ST%IPC IPCF supported.
33 ST%VMS VMSER included in monitor.
34 ST%MER Magtape error reporting.
35 ST%SSP Swapping done in page units.
23-25
GETTAB TABLES
Item Symbol Contains
112 %CNMNT Monitor type flags are as follows:
Bits Symbol Monitor Type
0 CN%MNX Unknown monitor.
77B23 CN%MNT Monitor type:
Value Symbol Type
1 .CNT10 TOPS-10
2 .CNITS ITS
3 .CNTNX TENEX
4 .CNT20 TOPS-20
5 .CNTCX TYMCOM-X
24-29 CN%MNS DIGITAL monitor subtype.
30-35 CN%MNC Customer monitor subtype.
This word is used by operating systems that have
TOPS-20 UUO compatibility packages.
For example, a calling sequence to read this word
may be:
MOVE ac,[112,,11]
GETTAB ac,
MOVEI ac,0
LDB ac,[POINT ac,CN/MNT]
CAIN ac,1
JRST TOPS10
CAIN ac,4
JRST TOPS20
JRST UNKNOWN
166 %CNJPK Bit 0 of this word is a flag. If not set, this
flag indicates that JOBPEK transfers cannot cross
page boundaries.
167 %CNDAE In the left half is the previous version of the
monitor in SIXBIT. In the right half is the
current version of the monitor in binary.
23-26
GETTAB TABLES
.GTNSW - Nonswapping Data Table
GETTAB Table 12
Contents Data about nonswapping memory utilization.
Indexed by Item number.
Monitor Table NSWTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Some of this data is CPU-specific and exists in CDBs.
Word Symbol Map
|=======================================================|
10,,12 %NSCMX | System CORMAX (largest user job + 1) |
|=======================================================|
11,,12 %NSCLS | Byte pointer to last free core area |
|=======================================================|
12,,12 %NSCTL | Virtual core tally |
|=======================================================|
13,,12 %NSSHW | Obsolete |
|=======================================================|
14,,12 %NSHLF | Obsolete |
|=======================================================|
15,,12 %NSUPT | System uptime (in ticks) |
|=======================================================|
16,,12 %NSSHF | Obsolete |
|=======================================================|
17,,12 %NSSTU | Obsolete |
|=======================================================|
20,,12 %NSHJB | Highest job number in use |
|=======================================================|
21,,12 %NSCLW | Words cleared by system |
|=======================================================|
22,,12 %NSLST | Lost time |
|=======================================================|
23,,12 %NSMMS | Memory size in words |
|=======================================================|
23-27
GETTAB TABLES
|=======================================================|
24,,12 %NSTPE | Total memory parity errors |
|-------------------------------------------------------|
25,,12 %NSSPE | Spurious memory parity errors |
|-------------------------------------------------------|
26,,12 %NSMPC | Multiple memory parity errors |
|=======================================================|
27,,12 %NSMPA | Absolute addr of last memory parity error |
|-------------------------------------------------------|
30,,12 %NSMPW | Contents of 1st bad wd on parity sweep |
|-------------------------------------------------------|
31,,12 %NSMPP | PC where last MEM PAR error was detected |
|=======================================================|
32,,12 %NSEPO | Number of exec PDL overflows not recovered |
|-------------------------------------------------------|
33,,12 %NSEPR | Number of exec PDL overflows recovered |
|=======================================================|
34,,12 %NSMXM | Maximum value of CORMAX |
|=======================================================|
35,,12 %NSKTM | KSYS timer |
|=======================================================|
36,,12 %NSCMN | Amt of memory guaranteed to non-locked jobs (CORMIN) |
|=======================================================|
37,,12 %NSABC | Count of address breaks |
|-------------------------------------------------------|
40,,12 %NSABA | Address break addresses |
|=======================================================|
41,,12 %NSLJR | Last job run |
|=======================================================|
42,,12 %NSACR | Obsolete |
|-------------------------------------------------------|
43,,12 %NSNCR | Obsolete |
|-------------------------------------------------------|
44,,12 %NSSCR | Obsolete |
|=======================================================|
23-28
GETTAB TABLES
.GTSDT - Swapping Data Table
GETTAB Table 13
Contents Contains data pertinent to swapping.
Indexed by Item number.
Monitor Table SWPTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,13 %SWBGH | Size (in pages) of biggest hole in core |
|=======================================================|
1,,13 %SWFIN | Job number of job Being swapped |
| (Positive if swapping in, negative if swapping out) |
|=======================================================|
2,,13 %SWFRC | Job number of job being forced to swap out |
|=======================================================|
3,,13 %SWFIT | Job number of job waiting to swap in |
|=======================================================|
4,,13 %SWVRT | Number of 1P blocks of virtual core left in system |
|=======================================================|
5,,13 %SWERC* | Swap error count and flags |
|=======================================================|
6,,13 %SWPIN* | PDB swapping flag |
|=======================================================|
7,,13 %SWEUJ | Segment,,UDB-address |
|=======================================================|
%SWERC contains the count of swap read or write
errors in its left half; bits 18 to 21 of the right
half are the same as status bits returned by a GETSTS
monitor call for the disk; bits 22 to 35 contain the
count of bad 1K blocks.
%SWPIN is -1 if the monitor swaps Process Data Blocks
and a swap-in is in progress.
23-29
GETTAB TABLES
.GTSGN - High Segment Parameters
GETTAB Table 14
Contents One word for each job running on the system, giving
parameters for the job's high segment. The
definitions of these bits in this word may vary from
monitor release to monitor release; therefore you
should not reference .GTSGN in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table JBTSGN
Calling MOVE ac,[XWD jobno,.GTSGN]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
Word Symbol Map
|=======================================================|
0,,14 .GTSGN* | High segment parameters |
|=======================================================|
.GTSGN parameters are as follows:
Bits Symbol Meaning
0 SN%SPY Job is spying. See bits 18-35
below.
1 SN%SHR Job high segment is sharable.
2 SN%UWP Job high segment is write-enabled.
3 SN%MDL Job high segment has been meddled.
4 Reserved.
5 SN%LOK Job high segment is locked into
memory.
6 SN%NCS Job high segment is not cached.
7-9 Reserved.
10 SN%GTS Job high segment was obtained by
GETSEG.
18-35 Defined as described below:
23-30
GETTAB TABLES
The right half of .GTSGN contains one of the
following:
o If bit 0 = 0, then the right half contains the
job high segment index number.
o If bit 0 = 1, then the job is spying and the
right half contains the maximum exec virtual
address that can be spied upon.
23-31
GETTAB TABLES
.GTODP - ONCE-Only Disk Parameters
GETTAB Table 15
Contents Disk parameters that are established at monitor
generation time.
Indexed by Item number.
Monitor Table ODPTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
|=======================================================|
| Obsolete |
|=======================================================|
1,,15 %ODK4S | Number of K of disk words available for swapping |
|=======================================================|
2,,15 %ODPRT | In-core protect time multiplier |
|=======================================================|
3,,15 %ODPRA | In-core protect time offset |
|=======================================================|
4,,15 %ODPMN | Minimum ICPT after requeue to back of PQ2 |
|=======================================================|
5,,15 %ODPMX | Maximum value of ICPT |
|=======================================================|
23-32
GETTAB TABLES
.GTLVD - Level D Disk Parameters
GETTAB Table 16
Contents Project-programmer numbers for libraries, file data,
and other data. These PPNs are established at
monitor generation time.
Indexed by Item number.
Monitor Table LVDTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
|=======================================================|
0,,16 %LDMFD | MFD PPN [1,1] |
|=======================================================|
1,,16 %LDSYS | SYS PPN [1,4] |
|=======================================================|
2,,16 %LDFFA | Full file access PPN [1,2] |
|=======================================================|
3,,16 %LDHLP | Not-logged-in PPN [2,5] |
|=======================================================|
4,,16 %LDQUE | Queue area PPN [3,3] |
|=======================================================|
5,,16 %LDSPB | Addr of first PPB | Addr of next PPB to scan |
|=======================================================|
6,,16 %LDSTR |First structure data block |Offset to next str data blk|
|=======================================================|
7,,16 %LDUNI | First unit data block |Offset to nxt unit data blk|
|=======================================================|
10,,16 %LDSWP | First swap unit | Offset to next swap unit |
|=======================================================|
11,,16 %LDCRN | Number of 4-wd blks allocated at ONCE-only |
|=======================================================|
12,,16 %LDSTP | Standard file protection |
|=======================================================|
13,,16 %LDUFP | Standard UFD protection |
|=======================================================|
14,,16 %LDMBN | Obsolete |
|=======================================================|
15,,16 %LDQUS | SIXBIT queue structure name |
|=======================================================|
16,,16 %LDCRP | CRASH PPN [10,1] |
|=======================================================|
23-33
GETTAB TABLES
|=======================================================|
17,,16 %LDSFD | Maximum depth of SFDs to write |
|=======================================================|
20,,16 %LDSPP | Spooled file protection |
|=======================================================|
21,,16 %LDSYP | Standard SYS: protection |
|=======================================================|
22,,16 %LDSSP | Standard SYS:filename.SYS protection |
|=======================================================|
23,,16 %LDMNU | Maximum negative USETI that reads extended RIBs |
|=======================================================|
24,,16 %LDMXT | Maximum blocks to transfer with 1 I/O operation |
|=======================================================|
25,,16 %LDNEW | Experimental SYS PPN [1,5] |
|=======================================================|
26,,16 %LDOLD | Old SYS PPN [1,3] |
|=======================================================|
27,,16 %LDUMD | User-mode diagnostics PPN [6,10] |
|=======================================================|
30,,16 %LDNDB | Default disk buffers in ring |
|=======================================================|
31,,16 %LDMSL | Maximum units in active swapping list |
|=======================================================|
32,,16 %LDALG | ALGOL library PPN [5,4] |
|=======================================================|
33,,16 %LDBLI | BLISS library PPN [5,5] |
|=======================================================|
34,,16 %LDFOR | FORTRAN library PPN [5,6] |
|=======================================================|
35,,16 %LDMAC | MACRO source library PPN [5,7] |
|=======================================================|
36,,16 %LDUNV | UNIVERSAL file library PPN [5,17] |
|=======================================================|
37,,16 %LDPUB | Public user library PPN [1,6] |
|=======================================================|
40,,16 %LDTED | Text editor library PPN [5,10] |
|=======================================================|
41,,16 %LDREL | .REL file library PPN [5,11] |
|=======================================================|
42,,16 %LDRNO | RUNOFF library PPN [5,12] |
|=======================================================|
43,,16 %LDSNO | SNOBOL library PPN [5,13] |
|=======================================================|
44,,16 %LDDOC | .DOC file library PPN [5,14] |
|=======================================================|
45,,16 %LDFAI | FAIL library PPN [5,15] |
|=======================================================|
46,,16 %LDMUS | Music library PPN [5,16] |
|=======================================================|
47,,16 %LDDEC | Standard DIGITAL software [10,7] |
|=======================================================|
23-34
GETTAB TABLES
|=======================================================|
50,,16 %LDSLP | AOBJN pointer to active swap list |
|=======================================================|
51,,16 %LDBAS | BASIC library PPN [5,1] |
|=======================================================|
52,,16 %LDCOB | COBOL library PPN [5,2] |
|=======================================================|
53,,16 %LDMXI | PDP-11 library PPN [5,3] |
|=======================================================|
54,,16 %LDNEL | NELIAC library PPN [5,20] |
|=======================================================|
55,,16 %LDDMP | Dump PPN [5,21] |
|=======================================================|
56,,16 %LDPOP | POP2 library PPN [5,22] |
|=======================================================|
57,,16 %LDTST | TEST library PPN [5,23] |
|=======================================================|
60,,16 %LDLSO* | If nonzero, call DAEMON to log soft overruns |
|=======================================================|
61,,16 %LDMBR* | Massbus register pointers |
|=======================================================|
62,,16 %LDBBP* | Pointer to BAT pointer |Channel terminal fail count|
|=======================================================|
63,,16 %LDDBS | DBMS library PPN [5,24] |
|=======================================================|
64,,16 %LDEXP* | Offset of expected channel term word in CDB |
|=======================================================|
65,,16 %LDMIC | MIC macro library PPN [5,25] |
|=======================================================|
66,16 %LDTPS | Text processing system library PPN [5,26] |
|=======================================================|
67,,16 %LDCTL | .CTL file library PPN [5,27] |
|=======================================================|
70,,16 %LDGAM | Games library PPN [5,30] |
|=======================================================|
71,,16 %LDACT | System accounting PPN [1,7] |
|=======================================================|
72,,16 %LDAPL | APL library PPN [5,31] |
|=======================================================|
73,,16 %LDECT | RIB error threshold |
|=======================================================|
74,,16 %LDTOT | Total RIB errors |
|=======================================================|
75,,16 %LDDOR | Addr of first dormant acc table,,addr |
| of last dormant acc table |
|=======================================================|
76,,16 %LDCOR | Addr first free 4-wd core blk,,0 |
|=======================================================|
77,16 %LDINT | Disk interference count |
|=======================================================|
100,16 %LDD60 | D60 library PPN [5,32] |
|=======================================================|
23-35
GETTAB TABLES
|=======================================================|
101,,16 %LDERT | Address of queue table for DAEMON error reporting |
|-------------------------------------------------------|
102,,16 %LDPT1 | Pointer to extract entries for DAEMON queue table |
|-------------------------------------------------------|
103,,16 %LDPT2 | Pointer to insert entries for DAEMON queue table |
|-------------------------------------------------------|
104,,16 %LDLTH | Length of DAEMON queue table |
|=======================================================|
105,,16 %LDCDA | Offset of UNICDA in UDB |
|=======================================================|
106,,16 %LDDES | Offset of UNIDES in UDB |
|=======================================================|
107,,16 %LDPTR | Pointer to in-core copies of retrieval pointers |
|=======================================================|
110,,16 %LDMSS |Max strs in sys search list|Max strs in job search list|
|=======================================================|
111,,16 %LDSLB | Offset of UNISLB in UDB |
|=======================================================|
112,,16 %LDUTP | Define ersatz device UTP |
|=======================================================|
113,,16 %LDINI | INI PPN |
|=======================================================|
114,,16 %LDESZ | Size of 1 entry in ERPTBK |
|=======================================================|
115,,16 %LDKON | Pointer to first controller's data block |
|=======================================================|
116,,16 %LDLBF | Default number of disk buffers |
|=======================================================|
117,,16 %LDDVU | Offset to device unit number |
|=======================================================|
120,,16 %LDCSZ | Size of disk cache, in blocks |
|=======================================================|
121,,16 %LDRDC | Monitor cache block read calls |
|=======================================================|
122,,16 %LDRDH | Monitor cache block read hits |
|=======================================================|
123,,16 %LDWRC | Monitor cache block write calls |
|=======================================================|
124,,16 %LDWRH | Monitor cache block write hits |
|=======================================================|
125,,16 %LDHSF | CSHFND calls |
|=======================================================|
126,,16 %LDHSC | CSHFND collisions in hash table |
|=======================================================|
127,,16 %LDHSL | Length of cache hash table |
|=======================================================|
130,,16 %LDHST | Address of cache hash table |
|=======================================================|
131,,16 %LDCHD | Address of cache list header |
|=======================================================|
23-36
GETTAB TABLES
| |=======================================================|
| 132,,16 %LDSPN | DDB offset for spooled file name |
| |=======================================================|
| 133,,16 %LDSPM | DDB offset for spooled parameter block pointer |
| |=======================================================|
| 134,,16 %LDBLK | DDB offset for I/O block number |
| |=======================================================|
| 135,,16 %LDRSU | DDB offset to retrieval/acc blocks |
| |=======================================================|
| 136,,16 %LDNMB | DDB offset for NMB of father SFD |
| |=======================================================|
| 137,,16 %LDUPS | PPN for use by mail programs (UPS device) |
| |=======================================================|
| 140,,16 %LDSEB | Address of pointer to first system error block |
| |=======================================================|
| 141,,16 %LDROD |Number of times a Data Request Block was not available |
| |=======================================================|
| 142,,16 %LDFNT | Library PPN for printer fonts (FNT:) |
| |=======================================================|
| 143,,16 %LDSET | Bit mask of disk sets mounted on the system. |
| |=======================================================|
| 144,,16 %LDDET | First detached Unit Data Block,,offset to next |
| |=======================================================|
Item Contains
60 %LDLSO contains a flag for DAEMON. If %LDLSO is
nonzero, and if an overrun is recovered on the first
retry, then DAEMON is called.
61 %LDMBR contains massbus register pointers. The left
half contains the offset into KBD of the number of
registers. The right half contains the offset into
UBD of the number of registers.
62 %LDBBP contains pointers. The left half contains the
address of a byte pointer to the number remaining in
the block access table. The right half contains the
offset into the UDB of the channel terminal fail
count.
64 %LDEXP contains the offset of the expected channel
terminal word in the channel data block.
23-37
GETTAB TABLES
.GTRCT - Disk Blocks Read
GETTAB Table 17
Contents One word for each job running on the system, giving
the number of disk blocks read by the job.
Indexed by Job number.
Monitor Table JBTRCT
Calling MOVE ac,[XWD jobno,.GTRCT]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Disk blocks read |
|=======================================================|
The word contains the number of incremental disk
block reads in bits 0 to 11 (RC.INC==7777B11 in
UUOSYM), and the total number of disk block reads in
bits 12 to 35 (RC.TTL==77777777 in UUOSYM).
23-38
GETTAB TABLES
.GTWCT - Disk Blocks Written
GETTAB Table 20
Contents One word for each job running on the system, giving
the number of disk blocks written by the job.
Indexed by Job number.
Monitor Table JBTWCT
Calling MOVE ac,[XWD jobno,.GTWCT]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|===================================================|
| Disk blocks written |
|===================================================|
The word contains the number of incremental disk
block writes in bits 0 to 11 (WC.INC==7777B11 in
UUOSYM), and the total number of disk block writes in
bits 12 to 35 (WC.TTL==77777777 in UUOSYM).
23-39
GETTAB TABLES
.GTSLF - GETTAB Table Data
GETTAB Table 23
Contents Data for each GETTAB table.
Indexed by GETTAB table number.
Monitor Table NUMTAB
Calling MOVE ac,[XWD table,.GTSLF]
Sequence GETTAB ac,
error return
normal return
where table is the symbolic name of the table whose
data is required.
Word Symbol Map
|===================================================|
0,,23 .GTSLF | GETTAB table data |
|===================================================|
The word contains one word for each GETTAB table.
The word gives the following information:
Bits Symbol Meaning
0-8 SL.MAX If SL.TYP is 1, 2, 3, or 4, this
field is the largest item number in
the table. If SL.TYP is 5, this
field is the index into the range
table.
9-11 SL.TYP Type of table.
Value Symbol Type
0 .SLNIC Not included in
this system.
1 .SLIXI Indexed by item
number.
2 .SLIXJ Indexed by job
number.
3 .SLIXS Indexed by job
number or segment
number.
4 .SLIXP Indexed by job
number; data in
PDB.
23-40
GETTAB TABLES
Bits Symbol Meaning
Value Symbol Type
5 .SLIXR Indexed by item
number. Range may
not be 0 to length
-1.
12-13 Reserved for DIGITAL.
14-17 SL.MAC A monitor accumulator number.
18-35 SL.ADR If SL.TYP=1, 2, or 3, this halfword
contains the executive mode address
of the table. If SL.TYP=4, this
halfword contains the offset in
job's PDB. If SL.TYP is 5, this
halfword is the executive mode
address that would correspond to
index 0 in the table.
23-41
GETTAB TABLES
.GTDEV - Segment Device or Structure
GETTAB Table 24
Contents One word for each high segment running on the system,
giving the device or file structure for the sharable
high segment.
Indexed by Segment number.
Monitor Table JBTDEV
Calling MOVE ac,[XWD segno,.GTDEV]
Sequence GETTAB ac,
error return
normal return
where segno is a high-segment number. Use -2 for the
current high segment. For the high segment of a
different job, obtain the segment number using a
GETTAB to .GTSGN.
|=======================================================|
| Device or structure (segments only) |
|=======================================================|
This returns 0 if there is no such segment or if the
segment is not sharable.
23-42
GETTAB TABLES
.GTWSN - Names of Wait States
GETTAB Table 25
Contents Names of wait states used in job queues. The names
of wait states may vary from monitor release to
monitor release; therefore you should not reference
.GTWSN in a program that is monitor-independent.
Indexed by Item number.
Monitor Table STSTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
|=======================================================|
| SIXBIT name of wait state |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| SIXBIT name of wait state |
|=======================================================|
There are three 2-character SIXBIT names in each word
returned. These states are defined at label STSTBL:
in COMMON.
23-43
GETTAB TABLES
.GTLOC - Remote Station Number
GETTAB Table 26
Contents One word for each job running on the system, giving
the station (ANF-10 network node) number for the job.
This is the node at which the job is logically
located (LOCATE call and monitor command).
Indexed by Job number.
Monitor Tables JBTLOC
Calling MOVE ac,[XWD jobno,.GTLOC]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job or use 0 for the ANF-10 node
number of the central station.
|=======================================================|
| Network node number |
|=======================================================|
23-44
GETTAB TABLES
.GTCOM - Monitor Command Names
GETTAB Table 30
Contents Monitor command names as SIXBIT words.
Indexed by Command number.
Monitor Table COMTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the position in the table of the
required command name.
|=======================================================|
| SIXBIT monitor command name |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| SIXBIT monitor command name |
|=======================================================|
The HELP * command displays a list of these command
names.
23-45
GETTAB TABLES
.GTNM1 and .GTNM2 - User Name
GETTAB Tables 31 and 32
Contents Two words for each job running on the system, giving
the user's name in SIXBIT (up to 12 characters).
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTNM1]
Sequence GETTAB ac,
error return
MOVEM ac,uname1
MOVE ac,[XWD jobno,.GTNM2]
GETTAB ac,
error return
MOVEM ac,uname2
. . .
uname1: block 1
uname2: block 1
where jobno is the number of a logged-in job (use -1
for the current job); and uname1 and uname1 are
locations for storing the user name.
|=======================================================|
| First 6 SIXBIT chars of user name |
|-------------------------------------------------------|
| Last 6 SIXBIT chars of user name |
|=======================================================|
23-46
GETTAB TABLES
.GTCNO - Charge Number
GETTAB Table 33
Contents One word for each job running on the system, giving
the accounting charge number for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTCNO]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| User charge number |
|=======================================================|
23-47
GETTAB TABLES
.GTWCH - Watch Bits
GETTAB Table 35
Contents One word for each job running on the system, giving
the watch bits for the job. These bits are set by
defaults, by the SETUUO or JBSET. monitor call, or by
the SET WATCH monitor command.
Indexed by Job number.
Monitor Table JBTWCH
CALLING MOVE ac,[XWD jobno,.GTWCH]
SEQUENCE GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Watch flags |
|=======================================================|
Watch flags are as follows:
Flag Symbol Meaning
0 JW.WCX Watch context changes.
1 JW.WDY Watch daytime at start.
2 JW.WRN Watch runtime.
3 JW.WWT Watch wait time.
4 JW.WDR Watch disk reads.
5 JW.WDW Watch disk writes.
6 JW.WVR Watch versions.
7 JW.WMT Watch magtape statistics.
8 JW.WFI Watch file.
377B8 JW.WAL Watch all.
9 JW.WCN Message continuations.
10 JW.WFL First line of message.
11 JW.WPR Message prefixes.
23-48
GETTAB TABLES
Flag Symbol Meaning
7B11 JW.WMS Message level:
Value Symbol Message level
1 .JWWPR Prefix only.
2 .JWWOL One line.
3 .JWWPO Prefix and first
line.
6 .JWWLG Long without prefix.
7 .JWWPL Prefix and long.
12-35 Reserved.
23-49
GETTAB TABLES
.GTSPL - Spooling Control Flags
GETTAB Table 36
Contents One word for each job running on the system, giving
the file spooling flags for the job. These flags are
set by the SETUUO or JBSET. monitor call, or by the
SET SPOOL monitor command.
Indexed by Job number.
Monitor Table JBTSPL
Calling MOVE ac,[XWD jobno,.GTSPL]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Spooling control flags |
|=======================================================|
Spooling control flags are as follows:
Flag Symbol Meaning
26 JS.PRI Disk priority spooling.
27 JS.DFR Deferred spooling (old MPB style).
30 Reserved.
31 JS.PCR Spool card reader.
32 JS.PCP Spool card punch.
33 JS.PPT Spool papertape punch.
34 JS.PPL Spool plotter.
35 JS.PLP Spool line printer.
31-35 JS.PAL Spool all devices.
23-50
GETTAB TABLES
.GTRTD - Realtime Status Word
GETTAB Table 37
Contents One word for each job running on the system, giving
the realtime status word for the job. The
definitions of the bits in the realtime status word
may vary from monitor release to monitor release;
therefore you should not reference .GTRTD in a
program that is monitor-independent.
Indexed by Job number.
Monitor Table JBTRTD
Calling MOVE ac,[XWD jobno,.GTRTD]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Realtime status |
|=======================================================|
23-51
GETTAB TABLES
.GTLIM - Time Limit and Batch Status
GETTAB Table 40
Contents One word for each job running on the system, giving
the time limit and batch status for the job.
Indexed by Job number.
Monitor Table JBTLIM
Calling MOVE ac,[XWD jobno,.GTLIM]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Time and batch status |
|=======================================================|
Time and batch status flags are as follows:
Bits Symbol Meaning
0 JB.LTL Time limit set from forced DETACH
command.
7B9 JB.LCR Obsolete
10 JB.LBT Batch job.
11 JB.LSY Job using program from SYS.
12-35 JB.LTM Time to go, in jiffies
23-52
GETTAB TABLES
.GTCM2 - SET Command Names
GETTAB Table 43
Contents The SIXBIT names of all SET monitor commands. The
contents of the .GTCM2 table may vary from monitor
release to monitor release; therefore you should not
reference .GTCM2 in a program that is
monitor-independent.
Indexed by Command number.
Monitor Table COMTB2
Calling MOVE ac,[XWD index,.GTCM2]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| SET command name in SIXBIT |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| SET command name in SIXBIT |
|=======================================================|
These names are defined by the SNAMES macro in COMCON
and will be displayed if you type the monitor command
HELP *.
23-53
GETTAB TABLES
.GTCRS - Hardware Status After Crash
GETTAB Table 44
Contents Hardware status words after a crash. (See also
%CCCSB and %CCDSB.)
Monitor Table CPU Status Block
Indexed by Item number.
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
|=======================================================|
0,,44 CR.SAP | APR CONI |
|=======================================================|
1,,44 CR.SPI | PI CONI |
|=======================================================|
2,,44 CR.SSW | APR DATAI switches |
|=======================================================|
23-54
GETTAB TABLES
.GTISC - Swap In Scan Tables
GETTAB Table 45
Contents Swapper input scan list of queues. The definitions
of the bits in this table may vary from monitor
release to monitor release; therefore you should not
reference .GTISC in a program that is
monitor-independent.
Indexed by Queue number.
Monitor Table ISCAN
Calling MOVE ac,[XWD index,.GTISC]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Swap-in scan tables |
|=======================================================|
23-55
GETTAB TABLES
.GTOSC - Swap Out Scan Tables
GETTAB Table 46
Contents Swapper output scan list of queues. The definitions
of the bits in this table may vary from monitor
release to monitor release; therefore you should not
reference .GTOSC in a program that is
monitor-independent.
Indexed by Queue number.
Monitor Table OSCAN
Calling MOVE ac,[XWD index,.GTOSC]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Swap-out scan tables |
|=======================================================|
23-56
GETTAB TABLES
.GTSSC - Scheduler Scan Tables
GETTAB Table 47
Contents Scheduler scan list of queues. The definitions of
the bits in this table may vary from monitor release
to monitor release; therefore you should not
reference .GTSSC in a program that is
monitor-independent.
Indexed by Queue number.
Monitor Table SSCAN
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Scheduler scan tables |
|=======================================================|
23-57
GETTAB TABLES
.GTRSP - Response Counter Table
GETTAB Table 50
Contents One word for each job running on the system, giving
the time (in jiffies) when the job began its wait for
running. This time is cleared when the job is placed
in the run queue by the scheduler.
Indexed by Job number.
Monitor Table JBTRSP
Calling MOVE ac,[XWD jobno,.GTRSP]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Response counter table |
|=======================================================|
23-58
GETTAB TABLES
.GTSYS - System-Wide Data
GETTAB Table 51
Contents System-wide data concerning errors and stopcodes.
Indexed by Item number.
Monitor Table SYSTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
|=======================================================|
0,,51 %SYERR | System-wide hardware error count |
|=======================================================|
1,,51 %SYCCO | Number of times COMCNT was wrong |
|=======================================================|
2,,51 %SYDEL | Disabled hardware error count |
|=======================================================|
3,,51 %SYSPC | Last 3-char stopcode | Last stopcode addr+1 |
|=======================================================|
4,,51 %SYNDS | Number of DEBUG stopcodes |
|=======================================================|
5,,51 %SYNJS | Number of JOB stopcodes (+ DEBUGs if stopped) |
|=======================================================|
6,,51 %SYNCP | Number of commands processed |
|=======================================================|
7,,51 %SYSJN | Last stopcode job number |
|-------------------------------------------------------|
10,,51 %SYSTN | Last stopcode TTY name |
|-------------------------------------------------------|
11,,51 %SYSPN | Last stopcode program name |
|-------------------------------------------------------|
12,,51 %SYSUU | Last stopcode monitor call |
|-------------------------------------------------------|
13,,51 %SYSUP | Last stopcode user PC |
|-------------------------------------------------------|
14,,51 %SYSPP | Last stopcode user PPN |
|-------------------------------------------------------|
15,,51 %SYSCD | Last stopcode stopcode name |
|-------------------------------------------------------|
16,,51 %SYNCS | Total number of CPU stopcodes |
|-------------------------------------------------------|
17,,51 %SYNIS | Number of no dump stopcodes |
|-------------------------------------------------------|
23-59
GETTAB TABLES
|-------------------------------------------------------|
20,,51 %SYSTY | Type of last stopcode |
|-------------------------------------------------------|
21,,51 %SYSUD | UDT of last stopcode |
|-------------------------------------------------------|
22,,51 %SYSCP | CPU number of last stopcode |
|=======================================================|
23-60
GETTAB TABLES
.GTWHY - Operator Reload Comments
GETTAB Table 52
Contents ASCIZ string giving the operator's reason for
reloading.
Indexed by Word of ASCIZ string.
Monitor Table CRSHAC
Calling MOVE ac,[XWD word,.GTWHY]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Operator why comments in ASCIZ |
|=======================================================|
23-61
GETTAB TABLES
.GTTRQ - Time in Run Queues
GETTAB Table 53
Contents One word for each job running on the system, giving
the total time the job was in the run queues (even if
not running all the time).
NOTE
This table is usually set to 0, because it is
expensive for the CPU to maintain.
Indexed by Job number.
Monitor Table JBTRQT
Calling MOVE ac,[XWD jobno,.GTTRQ]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Total time in RUN queues (whether or not running) |
|=======================================================|
23-62
GETTAB TABLES
.GTSPS - Status Word for Subsequent Processors
GETTAB Table 54
Contents Status bits for processors other than CPU0. The
definitions of the bits in this word may vary from
monitor release to monitor release; therefore you
should not reference .GTSPS in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table JBTSPS
Calling MOVE ac,[XWD jobno,.GTSPS]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Second processor status |
|=======================================================|
Status flags are as follows:
Bits Symbol Meaning
29 SP.SC0 Can use SET CPU monitor command for
CPU0. Bits 28 through 24 are
similar for CPU1 through CPU5.
35 SP.CR0 Can use JBSET. or SETUUO monitor
call for CPU0. Bits 30 through 34
are similar for CPU1 through CPU5.
23-63
GETTAB TABLES
.GTCnC - CPUn CPU Data Block Constants
GETTAB Tables 55, 57, 61, 63, 65, 67
Contents CPU data block constants for CPUn, where n is a CPU
number from 0 to 5. For CPUs 0 to 5, respectively,
these tables are called .GTC0C, .GTC1C, .GTC2C,
.GTC3C, .GTC4C, and .GTC5C.
Indexed by Item number.
Monitor Table .CnCDB
|
| Calling MOVE ac,[item + <2 * n>]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below; and n is the number of a CPU (from 0 to
5).
Word Symbol Map
|=======================================================|
0,,55 %CCPTR | Pointer to next CDB | Reserved |
|=======================================================|
1,,55 %CCSER | APR serial number |
|=======================================================|
2,,55 %CCOKP | Jiffies CPU has been down (<=0 if OK) |
|=======================================================|
3,,55 %CCTOS | EPT address for this CPU |
|=======================================================|
4,,55 %CCLOG | Logical name (CPUn) |
|=======================================================|
5,,55 %CCPHY | Physical name (CPXn) (X,I,L, or S) |
|=======================================================|
6,,55 %CCTYP* | Customer processor code | DIGITAL processor code |
|=======================================================|
7,,55 %CCMPT* | Pointer to bad address subtable in variable area |
|=======================================================|
10,,55 %CCRTC | Addr of realtime clock (DK10) DDB |
|=======================================================|
11,,55 %CCRTD | Addr of realtime clock DDB (if precision accounting) |
|=======================================================|
12,,55 %CCPAR* | Pointer to parity subtable in variable area |
|=======================================================|
13,,55 %CCRSP* | Pointer to response subtable in variable area |
|=======================================================|
14,,55 %CCDKX | Number of DK10s on this CPU |
|=======================================================|
23-64
GETTAB TABLES
|=======================================================|
15,,55 %CCEBS | Number of EBOX ticks/second on KL10 |
|=======================================================|
16,,55 %CCMBS | Number of MBOX ticks/second on KL10 |
|=======================================================|
17,,55 %CCNXT* | Pointer to NXM subtable in variable area |
|=======================================================|
20,,55 %CCCSB* | Pointer to CPU status block subtable in variable area |
|=======================================================|
21,,55 %CCDSB* | Ptr to device status block subtable in variable area |
|=======================================================|
22,,55 %CCSDP* | Ptr to SBDIAG subtable in variable area |
|=======================================================|
23,,55 %CCBPA | Pointer to PERF. counts in variable subtable |
|=======================================================|
24,,55 %CCCIP | CI port control block |
|=======================================================|
25,,55 %CCNIP | NI port control block |
|=======================================================|
Word Contains
6 %CCTYP processor types are as follows:
Value Symbol Processor Type
1 .CC166 PDP-6
2 .CCKAX KA10
3 .CCKIX KI10
4 .CCKLX KL10
5 .CCKSX KS10
The pointers %CCMPT, %CCPAR, %CCRSP, %CCNXT, %CCCSB, and %CCDSB are
pointers to GETTAB subtables for CPUn; these subtables follow table
.GTCnV, and are described in the next few pages.
7 %CCMPT is of the form:
Bits Symbol Meaning
0-8 CC%BLN Length-1 of bad address subtable.
9-17 Reserved.
18-35 CC%BRA Offset into .GTCnV of bad address
subtable.
12 %CCPAR is of the form:
Bits Symbol Meaning
0-8 CC%PLN Length-1 of parity subtable.
9-17 Reserved.
18-35 CC%PRA Offset into .GTCnV of parity
subtable.
23-65
GETTAB TABLES
Word Contains
13 %CCRSP is of the form:
Bits Symbol Meaning
0-8 CC%RLN Length-1 of response subtable.
9-17 Reserved.
18-35 CC%RRA Offset into .GTCnV of response
subtable.
17 %CCNXT is of the form:
Bits Symbol Meaning
0-8 CC%NLN Length-1 of NXM subtable.
9-17 Reserved.
18-35 CC%NRA Offset into .GTCnV of NXM subtable.
20 %CCCSB is of the form:
Bits Symbol Meaning
0-8 CC%CLN Length-1 of CPU status block
subtable.
9-17 Reserved.
18-35 CC%CRA Offset into .GTCnV of CPU status
block subtable.
21 %CCDSB is of the form:
Bits Symbol Meaning
0-8 CC%DLN Length-1 of device status block
subtable.
9-17 Reserved.
18-35 CC%DRA Offset into .GTCnV of device status
block subtable.
22 %CCSDP is of the form:
Bits Symbol Meaning
0-8 CC%SLN Length-1 of SBDIAG subtable.
9-17 Reserved.
18-35 CC%SRA Offset into .GTCnV of SBDIAG
subtable.
23-66
GETTAB TABLES
.GTCnV - CPUn CPU Data Block Variables
GETTAB Tables 56, 60, 62, 64, 66, 70
Contents CPU data block variables for CPUn, where n is a CPU
number (from 0 to 5). For CPUs 0 to 5, respectively,
these tables are called .GTC0V, .GTC1V, .GTC2V,
.GTC3V, .GTC4V and .GTC5V.
Indexed by Item number.
Monitor Table .CnVBG
|
| Calling MOVE ac,[item + <2 * n>]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below and n is a CPU number (from 0 to 5).
Word Symbol Map
|=======================================================|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|=======================================================|
5,,56 %CVUPT | Uptime in jiffies |
|=======================================================|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|=======================================================|
12,,56 %CVLST | Lost time |
|=======================================================|
| Reserved |
|=======================================================|
23-67
GETTAB TABLES
|=======================================================|
14,,56 %CVTPE | Total memory parity errors |
|-------------------------------------------------------|
15,,56 %CVSPE | Spurious memory parity errors |
|-------------------------------------------------------|
16,,56 %CVMPC | Multiple memory parity errors |
|=======================================================|
17,,56 %CVMPA | Absolute addr of last MEM PAR error |
|-------------------------------------------------------|
20,,56 %CVMPW | Contents of 1st bad wd on parity sweep |
|=======================================================|
21,,56 %CVMPP | PC where last MEM PAR was found |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|=======================================================|
27,,56 %CVABC | Address break count |
|=======================================================|
30,,56 %CVABA | Address break address |
|=======================================================|
31,,56 %CVLJR | Last job run (obsolete) |
|=======================================================|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|=======================================================|
35,,56 %CVSTS | Number of job that stopped timesharing on this CPU |
|=======================================================|
36,,56 %CVRUN* | Operator controlled scheduling |
|=======================================================|
37,,56 %CVNUL | Null time |
|=======================================================|
40,,56 %CVEDI | PC |Exec don't care interrupts |
|=======================================================|
41,,56 %CVJOB | Current job |
|=======================================================|
42,,56 %CVOHT | Overhead time in jiffies (exec UUOs) |
|=======================================================|
43,,56 %CVEVM | Max exec virtual memory for LOCK mapping |
|-------------------------------------------------------|
44,,56 %CVEVU | Exec virtual memory used for LOCK mapping |
|=======================================================|
23-68
GETTAB TABLES
|=======================================================|
45,,56 %CVLLC | No. of times CPU has looped waiting for interlock |
|=======================================================|
46,,56 %CVTUC | Total monitor call count |
|=======================================================|
47,,56 %CVTJC | Total job context switch count |
|=======================================================|
50,,56 %CVTNE | Total nonexistent memory errors |
|-------------------------------------------------------|
51,,56 %CVSNE | Total nonreproducible NXM errors |
|-------------------------------------------------------|
52,,56 %CVNJA | Number of jobs affected by this NXM |
|-------------------------------------------------------|
53,,56 %CVMNA | First memory address with NXM |
|=======================================================|
54,,56 %CVETJ | EBOX ticks/jiffy (computed) |
|-------------------------------------------------------|
55,,56 %CVNTJ | MBOX ticks/jiffy (computed) |
|=======================================================|
56,,56 %CVBPA | Phys addr of bad parity word on last AR/ARX trap (KL) |
|=======================================================|
57,,56 %CVTBD | Bad data on last AR/ARX trap |
|-------------------------------------------------------|
60,,56 %CVTGD | Good data after recovery from AR/ARX trap |
|-------------------------------------------------------|
61,,56 %CVNPT | Number of AR/ARX traps since reload |
|=======================================================|
62,,56 %CVAER | RDERA results after unusual APR interrupt |
|=======================================================|
63,,56 %CVPCN | CONI APR after parity interrupt |
|=======================================================|
64,,56 %CVSB0 | SBUS diagnostic function 0, word 0 |
|-------------------------------------------------------|
65,,56 %CVS0A | SBUS diagnostic function 0, word 1 |
|=======================================================|
66,,56 %CVSB1 | SBUS diagnostic function 1, word 0 |
|-------------------------------------------------------|
67,,56 %CVS1A | SBUS diagnostic function 1, word 1 |
|=======================================================|
70,,56 %CVPPC | PC on AR/ARX trap |
|=======================================================|
71,,56 %CVPFW | Page fail word on last AR/ARX trap |
|-------------------------------------------------------|
72,,56 %CVHPT | Number of hard AR/ARX traps |
|-------------------------------------------------------|
73,,56 %CVSPT | Number of soft AR/ARX traps |
|=======================================================|
74,,56 %CVPTP | Number of page table parity errors |
|=======================================================|
75,,56 %CVCSN | Number of cache sweeps since reload |
| (cache sweep serial number) |
|=======================================================|
23-69
GETTAB TABLES
|=======================================================|
76,,56 %CVCLN | Number of times a job couldn't run due to cache state |
|=======================================================|
77,,56 %CVCLT | Lost time accrued due to cache state |
|=======================================================|
100,,56 %CVCSD | Incr on swapper wait for cache sweep by another CPU |
|=======================================================|
101,,56 %CVCRN | Cache sweep request sweep count (see COMMON.MAC) |
|=======================================================|
102,,56 %CVCEC | Count nonrecoverable AR/ARX prty errs involving cache |
|=======================================================|
103,,56 %CVPTR | Retry word for AR/ARX parity error trap routine |
|-------------------------------------------------------|
104,,56 %CVTSD | AR/ARX trap routine has saved APR ERA.SB Diags |
|-------------------------------------------------------|
105,,56 %CVREP | Used by NXM/parity recovery routines |
|=======================================================|
106,,56 %CVNDB | Number of times this CPU's doorbell was rung |
|=======================================================|
107,,56 %CVSBR | Status blocks read on this CPU |
|=======================================================|
110,,56 %CVBPF | 0 if performance counts being kept (%CCBPA) |
|=======================================================|
111,,56 %CVFBI | Number of file blocks input (read) |
|=======================================================|
112,,56 %CVFBO | Number of file blocks output (written) |
|=======================================================|
113,,56 %CVSBI | Number of swapping blocks input (read) |
|=======================================================|
114,,56 %CVSBO | Number of swapping blocks output (written) |
|=======================================================|
115,,56 %CVSNC | Number of CPU stopcodes on this CPU |
|=======================================================|
116,,56 %CVSND | Number of DEBUG stopcodes on this CPU |
|=======================================================|
117,,56 %CVSNJ | Number of job stopcodes on this CPU |
|=======================================================|
120,,56 %CVSJN | Last stopcode on this CPU - job number |
|=======================================================|
121,,56 %CVSNM | Stopcode name | Stopcode PC+1 |
|=======================================================|
122,,56 %CVSPN | Program running at last stopcode |
|=======================================================|
123,,56 %CVSPP | PPN of user running at last stopcode |
|=======================================================|
124,,56 %CVSTN | TTY name of user running at last stopcode |
|=======================================================|
125,,56 %CVSUP | User PC at last stopcode |
|=======================================================|
126,,56 %CVSUU | UUO at last stopcode |
|=======================================================|
23-70
GETTAB TABLES
|=======================================================|
127,,56 %CVEJN | Last parity/NXM error on this CPU - job number |
|=======================================================|
130,,56 %CVEPN | Last parity/NXM error on this CPU - job name |
|=======================================================|
131,,56 %CVPPI | CONI PI, at last parity/NXM interrupt |
|=======================================================|
132,,56 %CVTPI | CONI PI, at last error trap |
|=======================================================|
133,,56 %CVRQS | Requests for scheduler interlock |
|=======================================================|
134,,56 %CVTFI | Number of magnetic tape frames read |
|=======================================================|
135,,56 %CVTFO | Number of magnetic tape frames written |
|=======================================================|
136,,56 %CVSNI | Number of no dump stopcodes |
|=======================================================|
137,,56 %CVSTY | Type of last stopcode on this CPU |
|=======================================================|
140,,56 %CVSUD | UDT of last stopcode on this CPU |
|=======================================================|
23-71
GETTAB TABLES
Subtable: Bad Addresses
Subtable of .GTCnV
Contents Addresses generating parity errors on CPUn.
Indexed by Sequence of bad addresses found.
Calling MOVE ac,[%CCMPT+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is the item number of the required item
in the subtable.
Word Symbol Map
|=======================================================|
0 | First bad address found |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last bad address found |
|=======================================================|
where last is the sequence number of the last bad
address found. The value of last+1 is stored in
location %CVPTS in the parity subtable for the CPU.
The maximum length for the bad address subtable is
stored in bits 0-8 of %CCMPT in table .GTCnC.
23-72
GETTAB TABLES
Subtable: Parity
Subtable of .GTCnV
Contents Parity error data for CPUn, where n is a CPU number
(from 0 to 5).
Indexed by Item number.
Calling MOVE ac,[%CCPAR+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0 %CVPLA | Last (highest) address of parity error |
|=======================================================|
1 %CVPMR | Relative (not virtual) addr |
| in low or high segment of last PAR ERR |
|=======================================================|
2 %CVPTS | Number of PAR errors found on last sweep |
|=======================================================|
3 %CVPSC | Number of parity sweeps by monitor |
|=======================================================|
4 %CVPUE | Number of user-enabled parity errors |
|=======================================================|
5 %CVPAA | AND of bad address on last parity sweep |
|=======================================================|
6 %CVPAC | AND of bad contents last sweep |
|=======================================================|
7 %CVPOA | IOR of bad address on last parity sweep |
|=======================================================|
10 %CVPOC | IOR of bad contents last sweep |
|=======================================================|
11 %CVPCS | Number of spurious channel errors |
|=======================================================|
12 %CVMET | MOS errors this minute |
|=======================================================|
13 %CVMEC | MOS errors sent to TGHA |
|=======================================================|
14 %CVTME | Total MOS errors |
|=======================================================|
23-73
GETTAB TABLES
Subtable: Responses
Subtable of .GTCnV
Contents Response data.
Indexed by Item number.
Calling MOVE ac,[%CCRSP+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0 %CVRSO* | Sum of all terminal OUT UUO responses |
|=======================================================|
1 %CVRNO | Number of terminal OUT UUO responses |
|=======================================================|
2 %CVRHO | High-sum square of terminal OUT UUO responses |
|=======================================================|
3 %CVRLO | Low-sum square of terminal OUT UUO responses |
|=======================================================|
4 %CVRSI* | Sum of terminal IN UUO responses |
|=======================================================|
5 %CVRNI | Number of terminal IN UUO responses |
|=======================================================|
6 %CVRHI | High-sum square of terminal IN UUO responses |
|=======================================================|
7 %CVRLI | Low-sum square of terminal IN UUO responses |
|=======================================================|
10 %CVRSR | Sum of CPU quantum requeue responses |
|=======================================================|
11 %CVRNR | Number of quantum requeue responses |
|=======================================================|
12 %CVRHR | High-sum square of quantum requeue responses |
|=======================================================|
13 %CVRLR | Low-sum square of quantum requeue responses |
|=======================================================|
14 %CVRSX* | Sum of one of responses terminated by 1 of 3 above |
|=======================================================|
23-74
GETTAB TABLES
|=======================================================|
15 %CVRNX | Number of responses reflected in %CVRSX |
|=======================================================|
16 %CVRHX | High-sum square of responses in %CVRNX |
|=======================================================|
17 %CVRLX | Low-sum square of responses in %CVRNX |
|=======================================================|
20 %CVRSC* | Sum of CPU responses |
|=======================================================|
21 %CVRNC | Number of CPU responses |
|=======================================================|
22 %CVRHC | High-sum square of CPU responses |
|=======================================================|
23 %CVRLC | Low-Sum Square of CPU Responses |
|=======================================================|
32 %CVNRI | Number of characters received |
|=======================================================|
33 %CVNXI | Number of characters sent |
|=======================================================|
34 %CVNEI | Number of characters echoed |
|=======================================================|
The Responses Subtable contains information concerning the
response times calculated for user jobs, on a per-CPU basis.
The responses subtable is made up of blocks of four words
each. Each block contains information pertaining to a type
of response that is measured. The following format is used
for each block:
Word 1: Sum of responses, where response time is
measured in ticks
Word 2: Number of responses
Words 3 - 4: A double-word integer containing the sum
of squares of response times.
%CVRSI is the input response time. This value is increased
every time a job runs a program whose first event (of those
measured and stored in %CVRSI, %CVRSO, and %CVRSR) is a
terminal input operation. Note that the input response time
is calculated only once for this program, the first time it
does input from the terminal, and is measured from the time
that the monitor receives the command to run the program, to
the time the program does its first terminal input UUO.
%CVRSO is the output response time and is similar to the
input response time. Only the first terminal output done by
the program is calculated and added to this word.
23-75
GETTAB TABLES
%CVRSR is the quantum requeue response time. This time is
measured for compute-bound jobs (jobs that finish a CPU
quantum without performing a terminal input or output
operation), and measures the amount of time from the time
the monitor receives the command to run the program, to the
time the program must be rescheduled for more CPU time.
Again, this time is calculated only once for each program
execution.
%CVRSX is the response time for the first of the above three
events to occur for the job. If a program does an input
operation before an output and before a quantum expires, the
input response time (also calculated in %CVRSI) is stored in
%CVRSX. If a second job runs a program that does an output
operation first, the response time for the output is stored
in %CVRSO and added to %CVRSX.
Before the values in these locations can be used, however,
it is important to understand the way that response time is
calculated. The intention of counting response time is to
understand the amount of time it takes to reach one of the
three measured events (input operation, output operation, or
quantum expiration). The user may, for example, type a
command. The response time is the lag between the time the
monitor accepts the command and the time it takes to reach
one of the three events. Note that this does not include
the time the user spends typing the command. The response
time is counted in jiffies (ticks).
The Responses Subtable collects response times for the first
event for a job when it begins running a program. If the
first event for a program is to output a * as a command
prompt, the amount of time between the time the "RUN
program" command is accepted by the monitor and the time the
monitor sends the * to the user's terminal is measured as
the response time for that program. If a job runs a program
that immediately begins input from the terminal, the
response time for that action is the amount of time between
the time the "RUN program" command is accepted by the
monitor and the time the terminal input operation is
attempted. The response times are accumulated for all the
jobs as they are scheduled to run.
23-76
GETTAB TABLES
Subtable: Nonexistent Memory
Subtable of .GTCnV
Contents Nonexistent memory data.
Indexed by Item number.
Calling MOVE ac,[%CCNXT+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0 %CVNLA | Last NXM address |
|=======================================================|
1 %CVNMR | Last NXM relative address |
|=======================================================|
2 %CVNTS | Number of NXMs found this sweep |
|=======================================================|
3 %CVNSC | Number of NXM sweeps done |
|=======================================================|
4 %CVNUE | Number of user-enabled NXMs |
|=======================================================|
5 %CVNAA | AND of b1ad addresses |
|=======================================================|
6 %CVNOA | IOR of bad addresses |
|=======================================================|
7 %CVNCS | Number of spurious channel NXMs |
|=======================================================|
23-77
GETTAB TABLES
Subtable: CPU Status Block
Subtable of .GTCnV
Contents CPU status block data.
Indexed by Item number.
Calling MOVE ac,[%CCCSB+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0 %CVSAI | APRID |
|-------------------------------------------------------|
1 %CVSAP | CONI APR, |
|-------------------------------------------------------|
2 %CVSPI | CONI PI, |
|-------------------------------------------------------|
3 %CVSPD | DATAI PAG, |
|-------------------------------------------------------|
4 %CVSPC | CONI PAG, |
|=======================================================|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|-------------------------------------------------------|
| Reserved |
|=======================================================|
11 %CVSER | RDERA |
|=======================================================|
12 %CVSRD | CONI RH20 for First RH |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| CONI RH20 for eighth RH |
|=======================================================|
23-78
GETTAB TABLES
|=======================================================|
22 %CVSDT | Four words for |
|=======================================================|
| the 4 DTEs |
|-------------------------------------------------------|
| on a |
|-------------------------------------------------------|
| CPU |
|=======================================================|
26 %CVSE0 | EPT location 0 |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| EPT location 37 |
|=======================================================|
66 %CVSE1 | EPT location 140 |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| EPT location 177 |
|=======================================================|
126 %CVSU1 | UPT location 500 |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| UPT location 503 |
|=======================================================|
132 %CVSA6 | AC block 6, register 0 |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| AC block 6, register 3 |
|=======================================================|
136 %CVSA7 | AC block 7, register 0 |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| AC block 7, register 2 |
|=======================================================|
141 (1) %CVSSB | First word of SBDIAG data |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| 50th word of SBDIAG data |
|=======================================================|
23-79
GETTAB TABLES
Note (1) Each SBDIAG Block has the format:
Number of sub-block blocks,,offset to first
Each sub-block has the format:
Number of words,,logical
controller#
function 0 word 1
function 1 word 1
23-80
GETTAB TABLES
Subtable: Device Status Block
Subtable of .GTCnV
Contents Device status block data.
Indexed by Item number.
Calling MOVE ac,[%CCDSB+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
where n is the number of the required CPU (from 0 to
5); and item is the item number of the required item
in the subtable.
The table of device status for devices on this CPU
contains the results of executing the instructions in
the table obtained with the .GTDCD GETTAB. This
table and .GTDCD are parallel tables with a
one-for-one mapping of instructions in .GTDCD and
resumes here. Intentionally, there is no order
specified. It is intended that a program
(DAEMON/SPEAR) should get one instruction from
.GTDCD, print its symbol and device code in octal,
and then print the value from this table.
23-81
GETTAB TABLES
Subtable: Background Performance Analysis
Subtable of .GTCnV
Contents Disk/PI usage.
Indexed by Item number.
Calling MOVE ac,[%CCSDP+<2*n>]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
HRRI ac,.GTC0V+<2*n>
GETTAB ac,
error return
normal return
Word Symbol Map
|========================================================|
0 %CVCH0 | RH20 #0 usage |
|========================================================|
4 %CVCH1 | RH20 #1 usage |
|========================================================|
10 %CVCH2 | RH20 #2 usage |
|========================================================|
14 %CVCH3 | RH20 #3 usage |
|========================================================|
20 %CVCH4 | RH20 #4 usage |
|========================================================|
24 %CVCH5 | RH20 #5 usage |
|========================================================|
30 %CVCH6 | RH20 #6 usage |
|========================================================|
34 %CVCH7 | RH20 #7 usage |
|========================================================|
40 %CVPI0 | PI level 0 (DTE, KLIPA, and KLINI) usage |
|========================================================|
44 %CVPI1 | PI level 1 usage |
|========================================================|
50 %CVPI2 | PI level 2 usage |
|========================================================|
54 %CVPI3 | PI level 3 usage |
|========================================================|
60 %CVPI4 | PI level 4 usage |
|========================================================|
64 %CVPI5 | PI level 5 usage |
|========================================================|
70 %CVPI6 | PI level 6 usage |
|========================================================|
74 %CVPI7 | PI level 7 usage |
|========================================================|
23-82
GETTAB TABLES
.GTFET - Feature Test Settings
GETTAB Table 71
Contents Feature test settings that describe the features
included in the current monitor.
Indexed by Item number.
Monitor Table FETTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
TLNN ac,<bit+777777>
JRST not-available-address
TRNN ac,<bit+777777>
JRST feature-test-off-address
JRST feature-test-on-address
where item is one of the symbols given in the word
map below; bit is one of the feature test bits given
below the word map.
Word Symbol Map
|=======================================================|
0,,71 %FTUUO* | Monitor call features |
|=======================================================|
1,,71 %FTRTS* | Realtime and scheduler features |
|=======================================================|
2,,71 %FTCOM* | Command features |
|=======================================================|
3,,71 %FTACC* | Accounting features |
|=======================================================|
4,,71 %FTERR* | Error control and option features |
|=======================================================|
5,,71 %FTDEB* | Debugging features |
|=======================================================|
6,,71 %FTSTR* | File structure features and parameters |
|=======================================================|
7,,71 %FTDSK* | Internal disk features and parameters |
|=======================================================|
10,,71 %FTSCN* | Scanner option features |
|=======================================================|
11,,71 %FTPER* | I/O features and parameters |
|=======================================================|
12,,71 %FTPE2* | More I/O features and parameters |
|=======================================================|
13,,71 %FTDS2* | More internal disk features and parameters |
|=======================================================|
23-83
GETTAB TABLES
|=======================================================|
14,,71 %FTST2* | More file structure features and parameters |
|=======================================================|
15,,71 %FTUU2* | More monitor call features |
|=======================================================|
%FTUUO monitor call feature test flags (more at
%FTUU2 below) are as follows:
Bits Symbol Feature
19 F%MDA Mountable device allocator.
20 F%MLOG MIC log file support.
21 F%MIC MACRO command processor.
22 F%EQDQ ENQ./DEQ. monitor calls.
23 F%GALA GALAXY (always set).
24 F%PI Software PI system.
25 F%IPCF IPCF.
26 F%CCIN CTRL/C intercept.
27 F%PTYU JOBSTS and CTLJOB monitor calls.
28 F%PEEK PEEK monitor call.
29 F%POKE POKE. monitor call.
30 F%JCON Job continuation.
31 F%SPL Spooling.
32 F%PRV Job privileges.
33 F%DAEM DAEMON monitor call.
34 F%GETT GETTAB monitor call.
35 F%2REL 2-register relocation (obsolete).
%FTRTS realtime and scheduler feature test flags are
as follows:
Bits Symbol Feature
23 F%CMSR Communication measurement.
24 F%PSCD Scheduler performance gathering.
25 F%NSCH New scheduler.
26 F%VM Virtual memory (always on).
27 F%SWAP Swapper (defined in S, always on).
28 F%SHFL Shuffler (obsolete).
29 F%RTC DK10 service.
30 F%LOCK LOCK monitor call.
31 F%TRPS TRPSET monitor call.
32 F%RTTR RTTRP monitor call.
33 F%SLEE SLEEP monitor call.
34 F%HIBW HIBER and WAKE monitor calls.
35 F%HPQ HPQ monitor call.
23-84
GETTAB TABLES
%FTCOM command feature test flags are as follows:
Bits Symbol Feature
19 F%PJOB Extended PJOB command.
20 F%EXE .EXE file format.
21 F%MOFF Set memory off-line.
22 F%MONL Set memory on-line.
23 F%CCL COMPILE commands (defined in S,
always on).
24 F%CCLX COMPILE-class commands.
25 F%QCOM QUEUE and related commands.
26 F%SET SET command and SETUUO monitor call.
27 F%VERS Version.
28 F%BCOM Batch control files.
29 F%SEDA Set daytime and date.
30 F%WATC SET WATCH command and monitor call.
31 F%FINI FINISH and CLOSE commands.
32 F%REAS REASSIGN command and monitor call.
33 F%EXAM E and D commands.
34 F%TALK SEND command.
35 F%ATTA ATTACH command and monitor call.
%FTACC accounting feature test flags are as follows:
Bits Symbol Feature
28 F%ACCT Accounting support.
29 F%EMRT KL10 EBOX/MBOX user runtime
capability.
30 F%FDAE File DAEMON.
31 F%TLIM Limits for time, core, and so forth.
32 F%CNO Accounting charge numbers.
33 F%UNAM User names.
34 F%KCT Kilo-core ticks.
35 F%TIME Run time.
%FTERR error control and option feature test flags
are as follows:
Bits Symbol Feature
19 F%SCA Systems Communication Architecture
is supported.
20 F%KLP KL-paging is enabled.
21 F%KS10 KS10 processor.
22 F%MNXM Nonexistent memory error recovery.
23 F%KL10 KL10 processor.
24 F%KA10 KA10 processor (obsolete, always
off).
25 F%22BI 22-bit channel (DF10C).
23-85
GETTAB TABLES
Bits Symbol Feature
26 F%PDBS Swapping PDB (always off).
27 F%KI10 KI10 processor.
28 F%METR METER. monitor call.
29 F%EXON Execute-only files (always on since
6.01).
30 F%KII KI10 instruction check on KA10.
31 F%BOOT BOOTS bootstrap.
32 F%2SWP Multi-swapping devices.
33 F%EL DAEMON error logging.
34 F%MS Multi-processors.
35 F%MEMP Memory parity error recovery.
%FTDEB debugging feature test flags are as follows:
Bits Symbol Feature
27 F%2SEG 2-segment monitor (always on).
28 F%RSP Response time.
29 F%WHY Why reload logging.
30 F%PATT Patch space in tables.
31 F%TRAC Back-tracking features.
32 F%HALT Halts in monitor.
33 F%RCHK Internal redundancy checks.
34 F%MONP Monitor write-protected (always
off).
35 F%CHEC Monitor check-summed (always off).
%FTSTR file structure feature test flags (more at
%FTST2 below) are as follows:
Bits Symbol Feature
19 F%DHIA High availability features.
20 F%DSIM Simultaneous file update.
21 F%NUL Null.
22 F%LIB LIB/SYS/OLD/NEW, and other
structures.
23 F%DPRI Disk priority transfers.
Bits Symbol Meaning
24 F%APLB Append to last file block.
25 F%AIR Append implies read.
26 F%GSRC Generic device searching.
27 F%DRDR Rename across directories.
28 F%DSEK SEEK monitor call.
29 F%DSUP Super USETI/USETO monitor calls.
30 F%DQTA Disk quotas.
31 F%STR Multiple structures.
32 F%5UUO Miscellaneous 5-series monitor
calls.
23-86
GETTAB TABLES
Bits Symbol Meaning
33 F%PHYO Physical devices only.
34 F%SFD Subfile directories (SFDs).
35 F%MOUN STRUUO monitor call functions.
%FTDSK internal disk parameter flags (more at %FTDS2
below) are as follows:
Bits Symbol Feature
19 F%SLCK Debug search list code.
20 F%2ATB 2-part access blocks.
21 F%CBDB Debug CB interlock.
22 F%LOGI LOGIN (defined in S, always on).
23 F%DISK Disk system (defined in S, always
on).
24 F%FFRE Prevent races in FILFND.
25 F%SWPE Swap read error recovery.
26 F%DBBK Bad block marking.
27 F%DUFC UFD compressing.
28 F%DETS Disk error simulator.
29 F%DMRB Multi-RIBs.
30 F%DSMC Smaller allocation of disk core
blocks.
31 F%DALC Allocation optimization.
32 F%DSTT Disk-usage statistics.
33 F%DHNG Hung disk recovery.
34 F%DBAD Disk offline recovery.
35 F%DOPT Latency optimization.
%FTSCN scanner option feature test flags are as
follows:
Bits Symbol Feature
20 F%RP04 RP04 support.
21 F%RDX Remote data-entry service.
22 F%DCXH DC10-H (2741 on DC10) support.
23 F%TVP Fancy vertical positioning.
24 F%TYPE TYPESET-10 features on DC76.
25 F%2741 Support for 2741-like terminals.
26 F%CAFE DC76 support.
27 F%TBLK TTY blank command.
28 F%TPAG PAGE and display knowledge.
29 F%DIAL Auto-dialer.
30 F%SCLC Special line control.
31 F%SCNR Hardware scanner.
32 F%MODM Modem control.
33 F%630H Single-scanner 630.
34 F%GPO2 Modem support (Great Britain).
35 F%HDPX Truly half-duplex terminals.
23-87
GETTAB TABLES
%FTPER I/O parameter feature test flags (more at
%FTPE2 below) are as follows:
Bits Symbol Feature
19 F%RDBA Read backwards on TU70.
20 F%TAPO TAPOP. monitor call.
21 F%TLAB Tape label support.
22 F%TASK Task-to-task network support.
23 F%DAS7 DAS78 (remote 360/370/2780) support.
24 F%XTC DA28-C network support.
25 F%MSGS MSGSER (MPX device) monitor module.
26 F%HSLN High-speed logical device search.
27 F%CPTR CDP trouble intercept.
28 F%CRTR CDR trouble intercept.
29 F%CTY1 Support device CTY1 (always on).
30 F%NET Network software.
30 F%REM Remote-station software.
31 F%LPTR LPT-device error recovery.
32 F%OPRE Device errors to operator.
33 F%CDRS CDR superimage mode.
34 F%MTSE Magtape density/block commands.
35 F%TMP TMPCOR area (always on).
%FTPE2 I/O parameter feature test flags (more at
%FTPER above) are as follows:
Bits Symbol Feature
35 F%DX10 DX10 device-chaining (magtapes).
%FTDS2 internal disk parameter feature test flags
(more at %FTDSK above) are as follows:
Bits Symbol Feature
35 F%DUAL Dual-ported disks (RP04, RP06).
%FTST2 file structure parameter feature test flags
(more at %FTSTR above) are as follows:
Bits Symbol Feature
35 F%PSTR Private file structures.
%FTUU2 monitor call feature test flags (more at
%FTUUO above) are as follows:
Bits Symbol Feature
35 F%MPB MPB batch code.
23-88
GETTAB TABLES
.GTEDN - Ersatz Device Names
GETTAB Table 72
Contents SIXBIT names of ersatz devices. The first blank name
is the end of the table.
Indexed by Item number.
Monitor Table SDVTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the item number of the required name.
Word Symbol Map
|=======================================================|
0 | First ersatz device name |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last ersatz device name |
|=======================================================|
where the entry following last is blank (0).
The ersatz device names are defined in the EDEVS
macro in COMMOD.
23-89
GETTAB TABLES
.GTSCN - Scanner Data
GETTAB Table 73
Contents Scanner data.
Indexed by Item number.
Monitor Table .GTSCN
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,73 %SCNRI | Number of receive interrupts |
|=======================================================|
1,,73 %SCNXI | Number of transmit interrupts |
|=======================================================|
2,,73 %SCNEI | Number of echo interrupts (in %SCNXI) |
|=======================================================|
3,,73 %SCNMB | Maximum buffer size |
|=======================================================|
4,,73 %SCNAL | Number of active lines |
|=======================================================|
5,,73 %SCNPS | Size of buffer for PIM mode |
|=======================================================|
6,,73 %SCNRA | Address of receive interrupt routine |
|=======================================================|
7,,73 %SCNXA | Address of transmit interrupt routine |
|=======================================================|
10,,73 %SCNTA | Address of type |
|=======================================================|
11,,73 %SCTFT | Address of first TTY chunk on free list |
|=======================================================|
12,,73 %SCTFP | Address of last TTY chunk on free list |
|=======================================================|
13,,73 %SCRCQ | Number of characters queued or deferred |
|=======================================================|
14,,73 %SCRQF | Number of characters lost for queue overflow |
|=======================================================|
23-90
GETTAB TABLES
.GTSNA - Last SEND ALL in 9-Bit
GETTAB Table 74
Contents Data for last send-all message.
Indexed by Item number.
Monitor Table SNDTMP
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,74 %SCNAE | Byte pointer to end byte in message |
|=======================================================|
1,,74 %SCNAS | Byte pointer to first-1 byte in message |
|=======================================================|
2,,74 %SCNAM | First word of data in message |
|=======================================================|
.
.
.
|=======================================================|
| Last word of data in message |
|=======================================================|
23-91
GETTAB TABLES
.GTCMT - SET TTY Command Names
GETTAB Table 75
Contents The SIXBIT names of the SET TTY monitor commands.
The last name is followed by a blank word.
Indexed by Not indexed.
Monitor Table TTCWDT
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the number of the name to be returned.
Word Map
|=======================================================|
0 | First SET TTY command name |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last SET TTY command name |
|=======================================================|
where last is the number-1 of SET TTY commands in the
table.
The SET TTY command names are defined with the TTNAME
macro in COMCON and will be displayed if you type the
HELP * monitor command.
23-92
GETTAB TABLES
.GTPID - Process Communication ID (IPCF)
GETTAB Table 76
Contents All process communication identifiers (PIDs) that
have been assigned by the system. The default length
of the table is twice the number of jobs that can
run.
Indexed by Item number.
Monitor Table PIDTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the number of the desired item in the
table. The entry after the last PID in the table is
0.
Word Map
|=======================================================|
0 | First IPCF PID |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last IPCF PID |
|=======================================================|
where last is the number-1 of PIDs in the table.
23-93
GETTAB TABLES
.GTIPC - IPCF Miscellaneous Data
GETTAB Table 77
Contents Miscellaneous IPCF data.
Indexed by Item number.
Monitor Table IPCTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,77 %IPCML | Maximum IPCF packet length |
|=======================================================|
1,,77 %IPCSI | PID of system-wide [SYSTEM]INFO |
|=======================================================|
2,,77 %IPCDQ | Default data |
|=======================================================|
3,,77 %IPCTS | Total packets sent |
|=======================================================|
4,,77 %IPCTO | Total packets outstanding |
|=======================================================|
5,,77 %IPCCP | PID of [SYSTEM]IPCC |
|=======================================================|
6,,77 %IPCPM | PID mask |
|=======================================================|
7,,77 %IPCMP | Length of PID table |
|=======================================================|
10,,77 %IPCNP | Number of PIDs now defined |
|=======================================================|
11,,77 %IPCTP | Total PIDs defined since reload |
|=======================================================|
12,,77 %IPCIC | Number of IPCF pages currently in core |
|=======================================================|
13,,77 %IPCSP | PID of [SYSTEM]GOPHER |
|=======================================================|
23-94
GETTAB TABLES
.GTUPM - Physical Page of User Page Map
GETTAB Table 100
Contents One word for each job running on the system, giving
the physical page number of the job's page map.
Indexed by Job number or segment number.
Monitor Table JBTUPM
Calling MOVE ac,[XWD jobno,.GTUPM]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job) or a high-segment number (use -2
for the current high segment).
For high segment entries, this is the page number of
the start of the high segment. Note that only the
left half contains the page number. The right half
contains other data and should be ignored.
|=======================================================|
| User page map page number |
|=======================================================|
23-95
GETTAB TABLES
.GTCMW - SET WATCH Command Names
GETTAB Table 101
Contents The SIXBIT names of the SET WATCH monitor commands.
Indexed by Item number.
Monitor Table WATTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the number of the desired item in the
table.
Word Map
|=======================================================|
0 | First SET WATCH command name |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last SET WATCH command name |
|=======================================================|
where last is the number-1 of command names in the
table.
The SET WATCH command names are defined with the
WATTAB macro in COMCON and will be displayed if you
type the HELP * monitor command.
23-96
GETTAB TABLES
.GTCVL - Current Virtual and Physical Limits
GETTAB Table 102
Contents One word for each job running on the system, giving
the current virtual and physical page limits for the
job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTCVL]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Current virtual limit | Current physical limit |
|=======================================================|
23-97
GETTAB TABLES
.GTMVL - Maximum Virtual and Physical Limits
GETTAB Table 103
Contents One word for each job running on the system, giving
the maximum virtual and physical page limits for the
job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTMVL]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Maximum virtual limit | Maximum physical limit |
|=======================================================|
23-98
GETTAB TABLES
.GTIPA - IPCF Statistics for Job
GETTAB Table 104
Contents One word for each job running on the system, giving
the IPCF statistics for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTIPA]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| IPCF statistics for job |
|=======================================================|
IPCF statistics bits are as follows:
Bits Symbol Meaning
0-17 IP.CQD Count of sends since the job logged
in.
18-35 IP.CQC Count of receives since the job
logged in.
23-99
GETTAB TABLES
.GTIPP - IPCF Pointers and Counts
GETTAB Table 105
Contents IPCF pointers and counts for the system.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTIPP]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| IPCF pointers and counts |
|=======================================================|
IPCF pointer and count bits are as follows:
Bits Symbol Meaning
0-17 Reserved.
18-26 IP.CQP Outstanding sends.
27-35 IP.CQO Outstanding receives.
23-100
GETTAB TABLES
.GTIPI - PID for Job's [SYSTEM]INFO
GETTAB Table 106
Contents One word for each job running on the system, giving
the process communication identifier for the job's
[SYSTEM]INFO.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTIPI]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| PID for [SYSTEM]INFO for job |
|=======================================================|
23-101
GETTAB TABLES
.GTIPQ - IPCF Flags and Quotas for Job
GETTAB Table 107
Contents One word for each job running on the system, giving
the IPCF quotas and flags for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTIPQ]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| IPCF flags and quotas for job |
|=======================================================|
Quota and flag bits are as follows:
Bits Symbol Meaning
0 IP.CQX Disabled.
1 IP.CQQ Quota set.
777B17 PID quota.
777B26 IP.CQS Send quota.
777B35 IP.CQR Receive quota.
23-102
GETTAB TABLES
.GTDVL - Pointer to Job Logical Name Table
GETTAB Table 110
Contents One word for each job running on the system, giving a
pointer to the table of addresses of DDBs owned by
this job which have logical names.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTDVL]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Pointer to logical name table for job |
|=======================================================|
23-103
GETTAB TABLES
.GTABS - Address Break Word
GETTAB Table 111
Contents The address break word. The definitions of the bits
in this word may vary from monitor release to monitor
release and processor to processor; therefore you
should not reference .GTABS in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTABS]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use
-1 for the current job.
Word Map
|=======================================================|
| Address break word |
|=======================================================|
23-104
GETTAB TABLES
.GTVM - General Virtual Memory Data
GETTAB Table 113
Contents Data about virtual page handling.
Indexed by Item number.
Monitor Table .GTVM
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,113 %VMSWP | Swap count |
|=======================================================|
1,,113 %VMSCN | Scan count |
|=======================================================|
2,,113 %VMSIP | Swaps + page operations in progress |
|=======================================================|
3,,113 %VMSLE | Number of SWPLST entries |
|=======================================================|
4,,113 %VMTTL | Total virtual memory in use |
|=======================================================|
5,,113 %VMCMX | Maximum value of %VMTTL allowed |
|=======================================================|
6,,113 %VMRMX | Obsolete |
|=======================================================|
7,,113 %VMCON | Constant used in swap rate computation |
|=======================================================|
10,,113 %VMQJB | Obsolete |
|=======================================================|
11,,113 %VMRMJ | Obsolete |
|=======================================================|
12,,113 %VMTLF | Time of last fault |
|=======================================================|
13,,113 %VMSPF | System page fault counts |
|=======================================================|
14,,113 %VMSW1 | Address of SWPLST |
|=======================================================|
15,,113 %VMSW2 | Address of SW2LST |
|=======================================================|
16,,113 %VMSW3 | Address of SW3LST |
|=======================================================|
23-105
GETTAB TABLES
|=======================================================|
17,,113 %VMEXP | Time constant exponent |
|=======================================================|
20,,113 %VMDIF | %VMEXP - %VMCON |
|=======================================================|
21,,113 %VMMXI | Maximum interval for fault-rate computation |
|=======================================================|
22,,113 %VMIPC | Count of IPCF pages being swapped out |
|=======================================================|
23,,113 %VMUPJ | Offset of job number in UPMP |
|=======================================================|
24,,113 %VMUPR | Offset of end of low segment in UPMP |
|=======================================================|
25,,113 %VMLST | Offset of pointer to swappable DDBs in UPMP |
|=======================================================|
26,,113 %VMUPM | Virtual address of UPMP |
|=======================================================|
27,,113 %VMLNM | Offset of pointer to logical names in UPMP |
|=======================================================|
30,,113 %VMIC1 | Number of swap input requests in SWPLST |
|=======================================================|
31,,113 %VMHUA | Highest unmapped EXEC address |
|=======================================================|
32,,113 %VMPPB | Address of beginning of per-process space |
|=======================================================|
33,,113 %VMPPE | Address of end + 1 of per-process space |
|=======================================================|
34,,113 %VMPPJ | Address of per-process user JOBDAT |
|=======================================================|
35,,113 %VMFCC | Offset in UPMP for TMPCOR |
|=======================================================|
36,,113 %VMCTA | Offset in UPMP for extended channel table pointer |
|=======================================================|
37,,113 %VMJDA | EXEC virtual address of USRJDA |
|=======================================================|
40,,113 %VMRMC | Real maximum CORMAX |
|=======================================================|
23-106
GETTAB TABLES
.GTVRT - Paging Rate for Job
GETTAB Table 114
Contents One word for each job running on the system, giving
the page rate for the job.
Indexed by Job number.
Monitor Table JBTVRT
Calling MOVE ac,[XWD jobno,.GTVRT]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Paging rate for job | Reserved |
|=======================================================|
23-107
GETTAB TABLES
.GTSST - Scheduler Statistics
GETTAB Table 115
Contents Statistics kept by and for the job scheduler.
Indexed by Item number.
Monitor Table .GTSST
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,115 %SSOSO | Number of jobs run out-of-order to allow them |
| to give up resources for swap-out |
|=======================================================|
1,,115 %SSORJ | Number of jobs run out-of-order to allow them |
| to give up resources required to run a job |
|=======================================================|
2,,115 %SSNUL | Swapper null time |
|=======================================================|
3,,115 %SSLOS | Swapper lost time |
|=======================================================|
4,,115 %SSRQC | Total number of requeues |
|=======================================================|
5,,115 %SSICM | Obsolete |
|=======================================================|
6,,115 %SSMSI | Medium-term scheduling interval |
|=======================================================|
7,,115 %SSAJS | Average job size |
|=======================================================|
10,,115 %SSTQT | Total runtime given to all subclasses |
|=======================================================|
11,,115 %SSEAF | Obsolete |
|=======================================================|
12,,115 %SSEAT | Obsolete |
|=======================================================|
13,,115 %SSRSS | Total user time since SCHED. Set class parameters |
|=======================================================|
14,,115 %SSCLS | Default class for new jobs |
|=======================================================|
23-108
GETTAB TABLES
|=======================================================|
15,,115 %SSJIL | % of time scheduler scans just-swapped |
| in list before subqueues |
|=======================================================|
16,,115 %SSSWP | Min no. of ticks swapper scans same primary subqueue |
|=======================================================|
17,,115 %SSBBQ | Background batch subqueue |
|=======================================================|
20,,115 %SSBBS | No. of ticks between background batch swaps |
|=======================================================|
21,,115 %SSIOF |% of time swapper scans PQ2 incore chain before outcore|
|=======================================================|
22,,115 %SSSET | 0 If round-robin scheduling; |
| Date/time when class runtime scheduling initiated |
| if class scheduling |
|=======================================================|
23,,115 %SSFLG | 0 if round-robin scheduling; |
| Count of CPU classes with nonzero quota |
| if class scheduling |
|=======================================================|
24,,115 %SSCOR | Seconds to wait after swapping out a runnable |
| job before ignoring incore protect time |
|=======================================================|
23-109
GETTAB TABLES
.GTST2 - Second Job Status Word
GETTAB Table 117
Contents One word for each job running on the system, giving
the second job status word for the job. (The first
job status word is in GETTAB table 0 (.GTSTS).) The
definitions of the bits in the job status word may
vary from monitor release to monitor release;
therefore you should not reference .GTST2 in a
program that is monitor-independent.
Indexed by Job number.
Monitor Table JBTST2
Calling MOVE ac,[XWD jobno,.GTST2]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job (use -1
for the current job).
|=======================================================|
| Second job status word |
|=======================================================|
23-110
GETTAB TABLES
.GTJTC - Job Type and Scheduler Class
GETTAB Table 120
Contents One word for each job running on the system, giving
the job type and scheduler class for the job. The
bits in this word may vary from monitor to monitor;
therefore you should not reference .GTJTC in a
program that is monitor-independent.
Indexed by Job number.
Monitor Table JBTSCD
Calling MOVE ac,[XWD jobno,.GTJTC]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Job type and scheduler class |
|=======================================================|
23-111
GETTAB TABLES
.GTCQP - Scheduler Quota Percent for Class
GETTAB Table 121
Contents The scheduler class quota in percent for each class.
Indexed by Scheduler class.
Monitor Table CLSSTS
Calling MOVE ac,[XWD class,.GTCQP]
Sequence GETTAB ac,
error return
normal return
where class is the class number of the class whose
quota percentage is required.
|=======================================================|
| Class quota in percent for class |
|=======================================================|
23-112
GETTAB TABLES
.GTCRT - Class Runtime Since Quota Set
GETTAB Table 123
Contents The runtime for each class since the class quotas
were set.
Indexed by Scheduler class.
Monitor Table SIDOFS
Calling MOVE ac,[XWD class,.GTCRT]
Sequence GETTAB ac,
error return
normal return
where class is the class number of the class whose
runtime is required.
|=======================================================|
| Class runtime since quotas set for class |
|=======================================================|
23-113
GETTAB TABLES
.GTSID - Special PID Table
GETTAB Table 126
Contents A list of the defined system process identifiers
(PIDs) used by the IPCF facility.
Indexed by Item number.
Monitor Table .GTSID
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,126 %SIIPC | [SYSTEM]IPCC |
|=======================================================|
1,,126 %SIINF | [SYSTEM]INFO |
|=======================================================|
2,,126 %SIQSR | [SYSTEM]QUASAR |
|=======================================================|
3,,126 %SIMDA | Mountable device allocator |
|=======================================================|
4,,126 %SITLP | Magtape labeling process |
|=======================================================|
5,,126 %SIFDA | File Daemon |
|=======================================================|
6,,126 %SIMDC | Mountable device coordinator (historical) |
|=======================================================|
6,,126 %SITOL | Tape AVR process |
|=======================================================|
7,,126 %SIACT | [SYSTEM]ACCOUNTING |
|=======================================================|
10,,126 %SIOPR | Operator interface |
|=======================================================|
11,,126 %SISEL | System error logger |
|=======================================================|
12,,126 %SIDOL | Disk AVR process |
|=======================================================|
13,,126 %SITGH | [SYSTEM]TGHA |
|=======================================================|
14,,126 %SINML | DECnet NML listener |
|=======================================================|
23-114
GETTAB TABLES
|=======================================================|
15,,126 %SIGFR | [SYSTEM]GOPHER |
|=======================================================|
16,,126 %SICAT | [SYSTEM]CATALOG |
|=======================================================|
17,,126 %SIMAI | [SYSTEM]MAILER |
|=======================================================|
23-115
GETTAB TABLES
.GTENQ - ENQ./DEQ. Statistics
GETTAB Table 127
Contents Statistics and quotas for the ENQ. and DEQ. monitor
calls.
Indexed by Item number.
Monitor Table .EQTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,127 %EQMSS | Maximum string size |
|=======================================================|
1,,127 %EQNAQ | Number of active queues |
|=======================================================|
2,,127 %EQESR | Total ENQ. since reload |
|=======================================================|
3,,127 %EQDSR | Total DEQ. since reload |
|=======================================================|
4,,127 %EQAPR | Number of active pooled resources |
|=======================================================|
5,,127 %EQDEQ | Default ENQ. quota |
|=======================================================|
6,,127 %EQMMS | Maximum pie-slice lock mask block size |
|=======================================================|
7,,127 %EQMTS | Maximum lock-associated table size |
|=======================================================|
10,,127 %EQLTL | Minutes that unused lock data is kept |
|=======================================================|
11,,127 %EQNDD | Number of deadlocks detected |
|=======================================================|
12,,127 %EQNTO | Number of timeouts |
|=======================================================|
13,,127 %EQMAQ | Maximum number of active queues |
|=======================================================|
23-116
GETTAB TABLES
.GTJLT - LOGIN Time for Job
GETTAB Table 130
Contents One word for each job running on the system, giving
the date/time (in universal format) that the job
logged in.
Indexed by Job number.
Monitor Table JBTJLT
CALLING MOVE ac,[XWD jobno,.GTJLT]
SEQUENCE GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| LOGIN date/time in universal format |
|=======================================================|
NOTE
This table is adjusted retroactively whenever the
current system date/time is changed with the SET DATE
monitor command, the SET DAYTIME monitor command, or
the appropriate SETUUO function. Subtracting values
in this table from %CNDTM will result in the elapsed
time since the job logged in.
23-117
GETTAB TABLES
.GTEBT - KL10 EBOX Time in Jiffies
GETTAB Table 131
Contents The number of jiffies of KL10 EBOX time used. The
definitions of the bits in this word may vary from
monitor release to monitor release; therefore, you
should not reference .GTEBT in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTEBT]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Jiffies of KL10 EBOX time |
|=======================================================|
23-118
GETTAB TABLES
.GTEBR - Jiffy Remainder: Mod(.GTEBT,RTUPS)
GETTAB Table 132
Contents The remainder resulting from dividing the contents of
.GTEBT by RTUPS. The definitions of the bits in this
word may vary from monitor release to monitor
release; therefore, you should not reference .GTEBR
in a program that is monitor-independent.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTEBR]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Jiffy remainder - mod(.GTEBT,RTUPS) |
|=======================================================|
23-119
GETTAB TABLES
.GTMBT - KL10 MBOX Time in Jiffies
GETTAB Table 133
Contents The number of jiffies of KL10 MBOX time used. The
definitions of the bits in this word may vary from
monitor release to monitor release; therefore, you
should not reference .GTMBT in a program that is
monitor-independent.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTMBT]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
0,,133 .GTMBT | Jiffies of KL10 MBOX time |
|=======================================================|
23-120
GETTAB TABLES
.GTMBR - Jiffy Remainder: Mod(.GTMBT,RTUPS)
GETTAB Table 134
Contents The remainder resulting from dividing the Contents of
.GTMBT by RTUPS. The definitions of the bits in this
word may vary from monitor release to monitor
release; therefore, you should not reference .GTMBR
in a program that is monitor-independent.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTMBR]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
| Jiffy remainder - mod(.GTMBT,RTUPS) |
|=======================================================|
23-121
GETTAB TABLES
.GTRDV - Program Run Device
GETTAB Table 135
Contents One word for each job running on the system, giving
the device the program is run from.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRDV]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Device program is run from |
|=======================================================|
NOTE
GETTAB Tables 135, 136, and 137 store the file
specification of the last program run by the job.
Therefore, these words change when you issue a RUN,
GET, SAVE, or CORE 0 command.
23-122
GETTAB TABLES
.GTRDI - Program Run Directory
GETTAB Table 136
Contents One word for each job running on the system, giving
the project-programmer number (PPN) of the directory
from which the job's program is being run.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRDI]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Directory program is run from |
|=======================================================|
NOTE
GETTAB Tables 135, 136, and 137 store the file
specification of the last program run by the job.
Therefore, these words change when you issue a RUN,
GET, SAVE, or CORE 0 command.
23-123
GETTAB TABLES
.GTRFN - Program Run File name
GETTAB Table 137
Contents One word for each job running on the system, giving
the SIXBIT name of the file from which the job's
program is being run.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRFN]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| File program is run from |
|=======================================================|
NOTE
GETTAB Tables 135, 136, and 137 store the file
specification of the last program run by the job.
Therefore, these words are changed when you issue a
RUN, GET, SAVE or CORE 0 command.
23-124
GETTAB TABLES
.GTDFL - User Defaults for Job
GETTAB Table 140
Contents One word for each job running on the system, giving
the user defaults for the job as set by the SET
DEFAULT command or SETUUO call.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTDFL]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| User defaults |
|=======================================================|
User default bits are as follows:
Bits Symbol Meaning
777B8 JD.PRT Default file protection.
9 JD.SDP Set if user has set default
protection.
12 JD.DAD Set if LOGIN shouldn't ask
about detached jobs.
777B35 JD.BUF Number of default disk
buffers.
20077B26 JD.MSK Reserved for use by DIGITAL.
23-125
GETTAB TABLES
.GTNTP - Network Performance Data
GETTAB Table 141
Contents Data for network performance analysis.
Indexed by Item number.
Monitor Table NETGTT
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,141 %NTCOR | Number of words of free space now in use |
|=======================================================|
1,,141 %NTMAX | Maximum value %NTCOR has reached |
|=======================================================|
2,,141 %NTAVG | Exponential average of %NTCOR (in K words) |
|=======================================================|
3,,141 %NTBAD | Number of bad messages received and ignored |
|=======================================================|
4,,141 %NTRTP* | Ptr to received NCL message type subtable |
|=======================================================|
5,,141 %NTRMT* | Ptr to received NCL numbered message type subtable |
|=======================================================|
6,,141 %NTRDL* | Ptr to received NCL data message lengths subtable |
|=======================================================|
7,,141 %NTXTP* | Ptr to transmitted NCL message type subtable |
|=======================================================|
10,,141 %NTXMT* | Ptr to transmitted NCL numbered message type subtable |
|=======================================================|
11,,141 %NTXDL* | Ptr to transmitted NCL data message lengths subtable |
|=======================================================|
12,,141 %NTBLC | PC of detection |PCB adr of last bad message|
|=======================================================|
13,,141 %NTBYI | Number of input bytes processed |
|=======================================================|
14,,141 %NTBYO | Number of output bytes processed |
|=======================================================|
23-126
GETTAB TABLES
The pointers %NTRTP, %NTRMT, %NTRDL, %NTXTP, %NTXMT,
and %NTXDL are of the form:
<length-1>B8+<offset>B35
where length is the maximum length of the subtable;
and offset is the offset into .GTNTP of the start of
the subtable.
23-127
GETTAB TABLES
Subtable: Received NCL Message Types
Subtable of .GTNTP
Contents Received NCL message types.
Indexed by Item number.
Calling MOVE ac,[%NTRTP]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First received NCL message type |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last received NCL message type |
|=======================================================|
23-128
GETTAB TABLES
Subtable: Received NCL Numbered Message Types
Subtable of .GTNTP
Contents Received NCL numbered message types.
Indexed by Item number.
Calling MOVE ac,[%NTRMT]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First received NCL numbered message type |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last received NCL numbered message type |
|=======================================================|
23-129
GETTAB TABLES
Subtable: Received NCL Data Message Lengths
Subtable of .GTNTP
Contents Received NCL message lengths by powers of 2.
0 = 0 bytes, and message too long
1 = 1 byte
2 = 2 to 3 bytes
3 = 4 to 7 bytes
. . .
n = 2(n-1) to (2*n)-1 bytes
Indexed by Item number.
Calling MOVE ac,[%NTRDL]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First received NCL data message length |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last received NCL data message length |
|=======================================================|
23-130
GETTAB TABLES
Subtable: Transmitted NCL Message Types
Subtable of .GTNTP
Contents Transmitted NCL message types.
Indexed by Item number.
Calling MOVE ac,[%NTXTP]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First transmitted NCL message type |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last transmitted NCL message type |
|=======================================================|
23-131
GETTAB TABLES
Subtable: Transmitted NCL Numbered Message Types
Subtable of .GTNTP
Contents Transmitted NCL numbered message types.
Indexed by Item number.
Calling MOVE ac,[%NTXMT]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First transmitted NCL numbered message type |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last transmitted NCL numbered message type |
|=======================================================|
23-132
GETTAB TABLES
Subtable: Transmitted NCL Data Message Lengths
Subtable of .GTNTP
Contents Transmitted NCL message lengths by powers of 2.
0 = 0 bytes, and message too long
1 = 1 byte
2 = 2 to 3 bytes
3 = 4 to 7 bytes
. . .
n = 2**(n-1) to (2**n)-1 bytes
Indexed by Item number.
Calling MOVE ac,[%NTXDL]
Sequence GETTAB ac,
error return
ADDI ac,item
HRLZS ac
ADDI ac,.GTNTP
GETTAB ac,
error return
normal return
where item is the number (starting with 0) of the
required entry in the subtable.
Word Map
|=======================================================|
0 | First NCL data message length |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
last | Last NCL data message length |
|=======================================================|
23-133
GETTAB TABLES
.GTSPA - Scheduler Performance Data
GETTAB Table 142
Contents Data for analysis of scheduler performance.
Indexed by Item number.
Monitor Table SCDPER
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,142 %SPDGS | DECtape-generated sleeps |
|-------------------------------------------------------|
1,,142 %SPMGS | Magtape-generated sleeps |
|=======================================================|
2,,142 %SPEWS | Event-wait satisfied |
|=======================================================|
3,,142 %SPTIS | Terminal input satisfied |
|-------------------------------------------------------|
4,,142 %SPTOS | Terminal output satisfied |
|=======================================================|
5,,142 %SPPIS | Pseudo-terminal input satisfied |
|-------------------------------------------------------|
6,,142 %SPPOS | Pseudo-terminal output satisfied |
|=======================================================|
7,,142 %SPRS1 | Requeues from SS into PQ1 |
|-------------------------------------------------------|
10,,142 %SPRW1 | Requeues from wake into PQ1 |
|-------------------------------------------------------|
11,,142 %SPRD1 | Requeues from DAEMON-satisfied into PQ1 |
|-------------------------------------------------------|
12,,142 %SPRO1 | Other requeues into PQ1 |
|=======================================================|
13,,142 %SPQR1 | PQ1 jobs that expired quantum runtime |
|-------------------------------------------------------|
14,,142 %SPQR2 | PQ2 jobs that expired quantum runtime |
|-------------------------------------------------------|
15,,142 %SPQRH | HPQ jobs that expired quantum runtime |
|=======================================================|
23-134
GETTAB TABLES
|=======================================================|
16,,142 %SPIP1 | PQ1 jobs that expired in-core protect time |
|-------------------------------------------------------|
17,,142 %SPIP2 | PQ2 jobs that expired in-core protect time |
|-------------------------------------------------------|
20,,142 %SPIPH | HPQ jobs that expired in-core protect time |
|=======================================================|
21,,142 %SPKS1 | Number of swapped in for PQ1 jobs |
|-------------------------------------------------------|
22,,142 %SPKS2 | Number of swapped in for PQ2 jobs |
|-------------------------------------------------------|
23,,142 %SPKSH | Number of swapped in for HPQ jobs |
|=======================================================|
24,,142 %SPNJ1 | Number of PQ1 jobs swapped in |
|=======================================================|
25,,142 %SPNJ2 | Number of PQ2 jobs swapped in |
|=======================================================|
26,,142 %SPNJH | Number of HPQ jobs swapped in |
|=======================================================|
27,,142 %SPTC1 | Clock ticks charged to PQ1 |
|-------------------------------------------------------|
30,,142 %SPTC2 | Clock ticks charged to PQ2 |
|-------------------------------------------------------|
31,,142 %SPTCH | Clock ticks charged to HPQ |
|=======================================================|
32,,142 %SPNRS | Number of responses for PQ1/CMQ swap-in |
|-------------------------------------------------------|
33,,142 %SPNTS | Total ticks of response for PQ1/CMQ swap-in |
|-------------------------------------------------------|
34,,142 %SPSSS | Sum of squares of PQ1/PQ2 swap-in (2-Word integer) |
|=======================================================|
35,,142 | Reserved |
|=======================================================|
36,,142 %SPMWC | Number of measurements of wasted core |
|-------------------------------------------------------|
37,,142 %SPSWC | Sum of wasted core (pages) |
|-------------------------------------------------------|
40,,142 %SPSSC | Sum of squares of wasted core (2-word integer) |
|=======================================================|
23-135
GETTAB TABLES
.GTVKS - Virtual Kilo-Core Ticks for Job
GETTAB Table 143
Contents One word for each job running on the system, giving
the number of virtual kilo-core ticks for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTVKS]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Virtual kilo-core ticks |
|=======================================================|
23-136
GETTAB TABLES
.GTUUC - Monitor Calls Executed for Job
GETTAB Table 144
Contents One word for each job running on the system, giving
the number of monitor calls executed for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTUUC]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Count of monitor calls done for job |
|=======================================================|
23-137
GETTAB TABLES
.GTRS0 - First SFD in Job Run Path
GETTAB Table 145
Contents One word for each job running on the system, giving
the first SFD in the run path for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRS0]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| First SFD in path program was run from |
|=======================================================|
23-138
GETTAB TABLES
.GTRS1 - Second SFD in Job Run Path
GETTAB Table 146
Contents One word for each job running on the system, giving
the second SFD in the run path for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRS1]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Second SFD in path program was run from |
|=======================================================|
23-139
GETTAB TABLES
.GTRS2 - Third SFD in Job Run Path
GETTAB Table 147
Contents One word for each job running on the system, giving
the third SFD in the run path for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRS2]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Third SFD in path program was run from |
|=======================================================|
23-140
GETTAB TABLES
.GTRS3 - Fourth SFD in Job Run Path
GETTAB Table 150
Contents One word for each job running on the system, giving
the fourth SFD in the run path for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRS3]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Fourth SFD in path program was run from |
|=======================================================|
23-141
GETTAB TABLES
.GTRS4 - Fifth SFD in Job Run Path
GETTAB Table 151
Contents One word for each job running on the system, giving
the fifth SFD in the run path for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTRS4]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Fifth SFD in path program was run from |
|=======================================================|
23-142
GETTAB TABLES
.GTPC - User PC
GETTAB Table 152
Contents One word for each job running on the system, giving
its user program counter.
Indexed by Job number.
Monitor Table JBTPC
Calling MOVE ac,[XWD jobno,.GTPC]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| User PC |
|=======================================================|
23-143
GETTAB TABLES
.GTCAP - Job Capability Word
GETTAB Table 153
Contents One word for each job running on the system, giving
the maximum privileges that can be enabled for the
job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTCAP]
SEQUENCE GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Job capability word (maximum privileges) |
|=======================================================|
Capability bits are as follows:
Bits Symbol Privilege
0 JP.IPC IPCF privilege.
1-2 JP.DPR Highest disk priority for the job (n
is in the range 0 to 3).
3 JP.MET METER. privilege.
4 JP.POK POKE. privilege.
5 JP.CCC Privilege to change CPU
specification with a command or a
monitor call.
6-9 JP.HPQ Highest high-priority queue
available to the job (n is in the
range 0 to 17 octal).
10 JP.NSP Device unspooling privilege.
11 JP.ENQ ENQ/DEQ privilege.
12 JP.ADM System administrator privileges.
13 JP.RTT RTTRP privilege.
14 JP.LCK LOCK privilege.
15 JP.TRP TRPSET privilege.
16 JP.SPA PEEK and SPY privilege for any core.
17 JP.SPM PEEK and SPY privilege for monitor
core.
18-35 Reserved for users.
23-144
GETTAB TABLES
.GTIDX - Range of Each GETTAB Table
GETTAB Table 154
Contents The entry numbers of the minimum and maximum entries
for each GETTAB table.
Indexed by GETTAB table number.
Monitor Table RNGTAB
Calling MOVE ac,[XWD table,.GTIDX]
Sequence GETTAB ac,
error return
HLREM ac,minent
HRREM ac,maxent
where table is the symbol for the table whose range
is required; minent is a memory location for the
minimum entry number; and maxent is a memory location
for the maximum entry number.
|=======================================================|
| Min table index (ID.MIN) | Max table index (ID.MAX) |
|=======================================================|
.GTIDX contains one word for each GETTAB table. The
word gives the following information:
Bit Symbol Meaning
17 ID.MIN Minimum programs should do a HLRE in
case negative
35 ID.MAX Maximum programs should do a HRRE in
case negative.
23-145
GETTAB TABLES
.GTGTB - GETTAB Immediate Using Range Table
GETTAB table 155
Contents Data for each GETTAB table.
Indexed by GETTAB table number.
Monitor Table NUMTAB
Calling MOVE ac,[XWD table,.GTGTB]
Sequence GETTAB ac,
error return
normal return
where table is the mnemonic name of the table whose
data is required.
|=======================================================|
| GETTAB table data |
|=======================================================|
The word gives the following information for each
GETTAB table:
Bits Symbol Meaning
0-8 SL.MAX If SL.TYP is 1, 2, 3, or 4, this
field is the largest item number in
the table. If SL.TYP is 5, this
field is the index into the range
table.
9-11 SL.TYP Type of table:
Value Symbol Type
0 .SLNIC Not included in
this system.
1 .SLIXI Indexed by item
number.
2 .SLIXJ Indexed by job
number.
3 .SLIXS Indexed by job
number or segment
number.
4 .SLIXP Indexed by job
number; data in
PDB.
23-146
GETTAB TABLES
Bits Symbol Meaning
Value Symbol Type
5 .SLIXR Indexed by item
number. Range may
not be 0 to length
-1.
12-13 Reserved for use by DIGITAL.
14-17 SL.MAC A monitor accumulator number.
18-35 SL.ADR If SL.TYP=1,2,3,5, this halfword
contains the executive mode address
of the table; if SL.TYP=4, this
halfword contains the offset to PDB.
If SL.TYP is 5, this halfword is the
executive mode address of offset 0
into the table.
23-147
GETTAB TABLES
.GTTNM - Terminal Type Names
GETTAB Table 156
Contents The SIXBIT names of those terminals that may be
specifed in the SET TTY TYPE monitor command or in
TRMOP. monitor call functions .TOTRM + .TOSET.
Indexed by Terminal type number.
Monitor Table TTTWDT
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the number of the desired entry in the
table.
|=======================================================|
| First SIXBIT terminal name |
|-------------------------------------------------------|
. . .
|-------------------------------------------------------|
| Last SIXBIT terminal name |
|=======================================================|
The terminal names are defined with the TTTWDT macro
in COMCON.
23-148
GETTAB TABLES
.GTOBI - Write-to-Operator and Batch Data
GETTAB Table 157
Contents One word for each job running on the system, giving
flags defining the write-to-operator capabilities and
batch stream numbers and sets for the job.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTOBI]
Sequence GETTAB ac,
error return
normal return
where jobno is the number of a logged-in job. Use -1
for the current job.
|=======================================================|
| Operator batch data |
|=======================================================|
Operator and batch flags are as follows:
Flag Symbol Meaning
3B1 OB.WTO Write-to-operator capabilities:
Value Symbol Meaning
0 .OBALL WTO and WTOR
allowed.
1 .OBNWR No WTOR allowed;
WTO only.
2 .OBNOM No messages to
operator allowed.
23-149
GETTAB TABLES
Flag Symbol Meaning
7B4 OB.OPR Operator privileges:
Value Symbol Meaning
0 .OBNOP No operator
privileges
1 .OBSOP System-wide
privileges
2 .OBHOP Host system
privileges
3 .OBROP Remote operator
privileges
10 OB.BSS Batch stream number set.
177B17 OB.BSN Batch stream number.
23-150
GETTAB TABLES
.GTDCD - CONI/DATAI Corresponding to DSB
GETTAB Table 160
Contents Device status block subtable.
Indexed by Item number.
Monitor Table DVCSTS
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
|=======================================================|
|CONI/DATAI corresp to device status block (see %CCDSB) |
|=======================================================|
23-151
GETTAB TABLES
.GTNDB - Byte Pointers Into Node Data Block
GETTAB Table 161
Contents Pointers into an NDB to facilitate the retrieval of
data.
Indexed by Item number.
Monitor Table NDBTBL
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|=======================================================|
0,,161 %NDLEN | Length of NDB (not a byte pointer) |
|=======================================================|
1,,161 %NDNXT | Address of next NDB |
|=======================================================|
2,,161 %NDNNM | Node number |
|=======================================================|
3,,161 %NDSNM | Address of SIXBIT station name |
|=======================================================|
4,,161 %NDTIM | Timer |
|=======================================================|
5,,161 %NDNGH | First neighbor entry |
|-------------------------------------------------------|
6,,161 %NDNGL | Last neighbor entry |
|=======================================================|
7,,161 %NDNGN | Node number from %NDNGH (address = 0) |
|=======================================================|
10,,161 %NDOPR | Address of OPR LDB |
|=======================================================|
11,,161 %NDCTJ | Station control job number |
|=======================================================|
12,,161 %NDLAR | Last ACK received |
|-------------------------------------------------------|
13,,161 %NDLAP | Last output message acknowledged |
|-------------------------------------------------------|
14,,161 %NDLMS | Last message sent |
|-------------------------------------------------------|
15,,161 %NDLMA | Last message number assigned |
|-------------------------------------------------------|
23-152
GETTAB TABLES
|-------------------------------------------------------|
16,,161 %NDLAS | Last ACK sent |
|-------------------------------------------------------|
17,,161 %NDLMR | Last message received |
|-------------------------------------------------------|
20,,161 %NDLMP | Last message processed |
|=======================================================|
21,,161 %NDSDT | Address of system build date |
|=======================================================|
22,,161 %NDSID | Address of system identification |
|=======================================================|
23,,161 %NDMOM | Maximum number of outstanding messages allowed |
|=======================================================|
24,,161 %NDDEV | First device |
|=======================================================|
23-153
GETTAB TABLES
.GTPDB - Job PDB Word
GETTAB Table 162
Contents Number of monitor per process pages, and monitor
address of the job's PDB.
Indexed by Job number.
Monitor Table JBTPDB
Calling MOVE ac,[XWD jobno,.GTPDB]
Sequence GETTAB ac
error return
normal return
|======================================================|
| Number of monitor | Address (monitor) |
| "per process" pages | of job's PDB |
|======================================================|
Where the left half of this word is divided into
6-bit fields. Bits 0-5 are reserved for use by
DIGITAL. Bits 6-11 contain the number of per-process
pages to be swapped in, and bits 12-17 contain the
total number of per-process pages. This word does
not include section maps for non-zero sections.
23-154
GETTAB TABLES
.GTEQJ - ENQ./DEQ. Queue Header
GETTAB Table 163
Contents ENQ/DEQ queue header.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTEQJ]
Sequence GETTAB ac
error return
normal return
|======================================================|
| ENQ/DEQ queue header |
|======================================================|
23-155
GETTAB TABLES
.GTDCN - Default Command Arguments
GETTAB Table 164
Contents One word for each job running on the system, giving
the SET DEFAULT monitor command argument for the job.
Indexed by Item number.
Monitor Table DFLTTB
Calling MOVE ac,[item]
Sequence GETTAB ac
error return
normal return
Where item is the number of the command in the list
of SET DEFAULT commands. Use the HELP * monitor
command to obtain the list of SET DEFAULT commands
for your system.
|======================================================|
| Set default command arguments |
|======================================================|
23-156
GETTAB TABLES
.GTLBS - Large Buffer Size
GETTAB Table 165
Contents Size of disk buffers as adjusted by program and SET
BIGBUF monitor command. The program sets the buffer
size with the SETUUO; this setting overrides any that
might have been set with the monitor command. The
monitor command setting takes precedence when the
program is halted.
Indexed by Job number.
Monitor table PDB
Calling MOVE ac,[XWD jobno,.GTLBS]
Sequence GETTAB ac
error return
normal return
|======================================================|
| Set by program | Set by user command |
|======================================================|
Where the data in the left half is the buffer size as
set by the program. The right half contains the
buffer size as set by the monitor command SET BIGBUF.
23-157
GETTAB TABLES
.GTPTR - Program To Run
GETTAB Table 166
Contents The name of the program to run. Refer to the .STPGM
function of the SETUUO UUO.
Indexed by Job number.
Monitor Table
Calling MOVE ac,[XWD jobno,.GTPTR]
Sequence GETTAB ac
error return
normal return
|======================================================|
| SIXBIT program name |
|======================================================|
23-158
GETTAB TABLES
.GTSTM - Time of Last Reset
GETTAB Table 167
Contents Time the program was last RESET.
Indexed by Job number.
Monitor Table PDB
Calling MOVE ac,[XWD jobno,.GTSTM]
Sequence GETTAB ac
error return
normal return
|======================================================|
| Universal date/time of last RESET |
|======================================================|
23-159
GETTAB TABLES
.GTDNT - DECnet Queue Headers
GETTAB Table 170
Contents Pointers to tables and information about DECnet-10
Version 3.
Indexed by Item number.
Monitor table DCNGTB
Calling MOVE ac,[item]
Sequence GETTAB ac
error return
normal return
Word Symbol Map
|======================================================|
0,,170 %DNRCH* | Queue header for circuit blocks |
|======================================================|
1,,170 %DNNPH* | Queue header for port blocks |
|======================================================|
2,,170 %DNETH* | DTE control block table |
|======================================================|
3,,170 %DNNSJ* | Pointer to session control job block for NRTSER |
|======================================================|
4,,170 %DNNCH* | Pointer to NRTSER's internal channel table |
|======================================================|
5,,170 %DNNDQ* | Queue block header for LLINK's node blocks |
|======================================================|
6,,170 %DNLOC | Obsolete |
|======================================================|
7,,170 %DNPTR | Obsolete |
|======================================================|
10,,170 %DNCHB* | Pointer to start of blocks describing DECnet's |
| fixed-size freecore |
|======================================================|
11,,170 %DNKON* | Pointer to table of DECnet device names |
|======================================================|
12,,170 %DNNRV* | Pointer to current routing vector (indexed by |
| node number) |
|======================================================|
13,,170 %DNOFS* | Pointer to offset from routing vector to |
| secondary vector |
|======================================================|
14,,170 %DNRMX | Pointer to address of router maximum node number |
|======================================================|
15,,170 %DNCST | Address of byte pointer to cost |
|======================================================|
23-160
GETTAB TABLES
|======================================================|
16,,170 %DNHOP | Address of byte pointer to hops |
|======================================================|
17,,170 %DNLCL* | Address of byte pointer to LOCAL bit |
|======================================================|
20,,170 %DNACT | Address of byte pointer to ACTIVE bit |
|======================================================|
21,,170 %DNNDT | Obsolete |
|======================================================|
22,,170 %DNSMX | Obsolete |
|======================================================|
23,,170 %DNACB | Address of DECnet Allocation Control Block |
|======================================================|
For additional information (format of blocks pointed
to by this table), refer to code as follows:
Item Module Label
0 D36PAR BEGSTR RC
1 D36PAR BEGSTR EL
2 DTEPRM DTEGEN
3 Format returned is similar to that returned
by GETTAB .GTSJB.
4 NRTSER BEGSTR NR
5 D36PAR BEGSTR NN
10 D36COM BEGSTR CH
11 Device names are listed in ASCII.
12 ROUTER BEGSTR RN
13 Contains pointers to output adjacency block
for this node.
17 Set only for executor (local host) node.
23-161
GETTAB TABLES
.GTSJB - DECnet Session Control Block Pointer
GETTAB Table 171
Contents Pointer to DECnet session control job block.
Indexed by Job number.
Monitor table PDB
Calling MOVE ac,[XWD jobno,.GTSJB]
Sequence GETTAB ac
error return
normal return
|======================================================|
| Pointer |
|======================================================|
23-162
GETTAB TABLES
.GTNDA - NDB Address
GETTAB Table 173
Contents Pointers into the DECnet-10 node data block address
table. This table contains the address of the NDB
for each node.
Indexed by Node number.
Monitor table .GTNDA
Calling MOVE ac,[XWD nodeno,.GTNDA]
Sequence GETTAB ac
error return
normal return
|======================================================|
| Node data block address |
|======================================================|
23-163
GETTAB TABLES
.GTAOT - ANF-10 Object Translation Table
GETTAB Table 174
Contents The ANF-10 object translation table for each DECnet
object type.
Indexed by Item number: NCL object type.
Monitor table OBJTAB
Calling MOVE ac,[item]
Sequence GETTAB ac
error return
normal return
0 11 17 35
|======================================================|
| AO.XX | AO.TYP | AO.NAM |
|======================================================|
AO.XX, in bits 0 through 11, is reserved for use by
DIGITAL.
AO.TYPE contains the device type (refer to the DEVTYP
UUO).
AO.NAM contains the device name in SIXBIT.
23-164
GETTAB TABLES
.GTCTX - Context Table
GETTAB Table 175
Contents Information about contexts.
Indexed by Item number.
Monitor table
Calling MOVE ac,[item]
Sequence GETTAB ac
error return
normal return
where item is one of the symbols given in the word
map below.
Word Symbol Map
|===================================================|
0,,175 %CTJCQ | Default job context quota |
|===================================================|
1,,175 %CTJPQ | Default job saved-pages quota |
|===================================================|
2,,175 %CTSCQ | System-wide context quota |
|===================================================|
3,,175 %CTSPQ | System-wide saved-pages quota |
|===================================================|
4,,175 %CTSCU | System-wide count of contexts in use |
|===================================================|
5,,175 %CTSPU | System-wide count of currently saved pages |
|===================================================|
6,,175 %CTTCS | Total context saves done |
|===================================================|
7,,175 %CTACE | No. of times auto-push exceeded context quota |
|===================================================|
10,,175 %CTAPE | No. of times auto-push exceeded saved-pages quota |
|===================================================|
11,,175 %CTPCE | No. of times a privileged program exceeded |
| context quota |
|===================================================|
12,,175 %CTPPE | No. of times a privileged program exceeded |
| pages-saved quota |
|===================================================|
13,,175 %CPBDM | Byte pointer to returned context directory map |
|===================================================|
23-165
GETTAB TABLES
.GTIMI - Job Page Count
GETTAB Table 176
Contents Number of memory pages in use by each job.
Indexed by Job number.
Monitor Table JBTIMI
Calling MOVE ac,[XWD jobno,.GTIMI]
Sequence GETTAB ac,
error return
normal return
where jobno is the job number of a logged-in job, or
-1 for your current job.
0 2 3 8 9 14 15 35
|======================================================|
| | NZSICN | NZSSCN | Page Count |
|======================================================|
Bit definitions:
Bits Symbol Contents
0-2 Reserved
3-8 NZSICN Number of pages to allocate on
swap-in for non-zero section maps.
9-14 NZSSCN Number of pages currently allocated
to non-zero section maps.
15-35 IMGIN Number of physical pages in user
portion of job.
23-166
GETTAB TABLES
.GTIMO - Swapped-Out Page Count
GETTAB Table 177
Contents Number of physical pages in swapped-out job, on disk.
Indexed by Job number.
Monitor Table JBTIMO
Calling MOVE ac,[XWD jobno,.GTIMO]
Sequence GETTAB ac,
error return
normal return
where jobno is the job number of a logged-in job, or
-1 for the current job.
0 17 18 35
|======================================================|
| | Number of pages on disk |
|======================================================|
23-167
GETTAB TABLES
.GTDDB - I/O Wait DDB
GETTAB Table 200
Contents Device data block for devices in I/O wait state.
Indexed by Job number.
Monitor Table JBTDDB
Calling MOVE ac,[XWD jobno,.GTDDB]
Sequence GETTAB ac,
error return
normal return
|======================================================|
| Pointer to DDB |
|======================================================|
23-168
GETTAB TABLES
.GTVIR - Job's Virtual Size
GETTAB Table 201
Contents Virtual size of program.
Indexed by Job number.
Monitor Table
Calling MOVE ac,[XWD jobno,.GTVIR]
Sequence GETTAB ac,
error return
normal return
where jobno is the job number, or -1 for current job.
The virtual size is returned with bits 6-14
containing the high segment, and bits 15-35
containing the low segment.
23-169
GETTAB TABLES
.GTETH - Ethernet Information
GETTAB Table 202
Contents Data about Ethernet configuration.
Indexed by Item number.
Monitor Table
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the symbol representing one of the
words in the following word map.
Word Symbol Map
|===================================================|
0,,202 %EINEC | Number of Ethernet channels on system |
|===================================================|
1,,202 %EICHN | Address of first Ethernet channel block |
|===================================================|
2,,202 %EINEK | Number of Ethernet controllers on system |
|===================================================|
3,,202 %EIKON | Address of first Ethernet controller block |
|===================================================|
4,,202 %EISYS | Values of .ECBSYS,,.EKBSYS |
|===================================================|
5,,202 %EISTS | Values of .ECBSTS,,.EKBSTS |
|===================================================|
6,,202 %EIBYR | Total bytes received |
|===================================================|
7,,202 %EIBYX | Total bytes transmitted |
|===================================================|
10,,202 %EIDGR | Total datagrams received |
|===================================================|
11,,202 %EIDGX | Total datagrams transmitted |
|===================================================|
23-170
GETTAB TABLES
.GTSG2 - High Segment Section Number
GETTAB Table 203
Contents The section number of the job's high segment.
Indexed by Job number.
Monitor Table JBTSG2
Calling MOVE ac,[XWD jobno,.GTSG2]
Sequence GETTAB ac,
error return
normal return
where jobno is the job number, or -1 for the current
job.
|======================================================|
| S# | Reserved |
|======================================================|
Bits Symbol Contents
0-4 SG%SCN Section number where the high
segment for the job is stored.
5-35 Reserved.
23-171
GETTAB TABLES
| .GTCCM - Site-specific Commands
GETTAB Table 204
Contents Site-specific commands, defined using the MONGEN
dialog. (See the Software Installation Guide for
information on defining commands with MONGEN.)
Indexed by Command number.
Monitor Table CSTTAB
Calling MOVE ac,[item]
Sequence GETTAB ac,
error return
normal return
where item is the table position of the command name.
|======================================================|
| MONGEN-defined command name |
|======================================================|
. . .
|======================================================|
| MONGEN-defined command name |
|======================================================|
The table of commands defined using the DECLARE command is searched
first when you issue a command. If an exact match is not found, this
table is searched next. The HELP * command displays a list of these
command names.
23-172
APPENDIX A
GLOSSARY
Absolute virtual address
A fixed location in user virtual address space that cannot be
relocated by the software. However, it can be translated to a
physical address by the hardware. For example, locations 0 - 17
are mapped into the current AC block by the hardware. The
corresponding locations in physical memory are never referenced.
AC
Refer to accumulator.
ACCESS.USR
Each user can create his own ACCESS.USR file to specify who can
and cannot access his files. See Appendix C.
Access date
The date on which a file on disk was last read or written. If a
file has not been read or written since it was created, the
creation date and the access date are the same. The access date
is kept in the Retrieval Information Block (RIB) for the file.
Access privileges
Attributes of a file that specify the class of users allowed to
access the file and the type of access they are allowed.
Access table
A table stored in the monitor that reflects the status of a file.
There is one access table for each file that is open for reading
or writing, in addition to those files that were recently closed.
This information is kept in the monitor in order to decrease the
time needed to access the files.
A-1
GLOSSARY
Accumulator
One of the registers and associated equipment in the arithmetic
unit in which data can be placed while it is being examined or
manipulated (for example, the 16 high-speed registers at address
locations 0 through 17).
Active search list
An ordered list of file structures established for each job
running on the system. This list is used to translate references
to the generic device DSK into the actual file structures to be
used. This means if a user reads a file on device DSK, the
system will look for the file on structures contained in the
active search list. The active search list is separated from the
passive search list by the FENCE. The SETSRC program can be used
to alter the contents of the job's active search list.
Address
1. An identification represented by a name, label, or number for
a register, a location in storage, or any other data source
or destination in memory or on an addressable storage device.
2. The part of an instruction that specifies the location of an
operand of the instruction (also called "effective address").
?ADDRESS CHECK Error
This error can occur when a dump mode I/O command list or
LOOKUP/ENTER/RENAME block is not in your low segment. It can
also occur when an invalid address is encountered during any I/O
UUO processing.
Address mapping
The assignment of user virtual address space to the physical
address space in computer memory. This is automatically
performed by the TOPS-10 monitor and is transparent to user
programs.
ALL search list
The list of all structures currently known to the system and
physically mounted. This list is the output from the SYSSTR
monitor call.
Alphanumeric
The set of characters that includes the letters of the alphabet
(A through Z), and the numerals (0 through 9).
A-2
GLOSSARY
Arithmetic unit
The portion of the central processing unit in which arithmetic
and logical operations are performed.
ASCII code
American Standard Code for Information Interchange. A 7-bit code
in which textual information is recorded. The ASCII code can
represent 128 distinct characters. These characters are the
upper and lower case letters, numbers, common punctuation marks,
and special control characters.
Assembly language
The machine-oriented symbolic programming language specific to a
given computing system. The assembly language for TOPS-10 is
MACRO.
ASCIZ
A 7-bit ASCII string terminated by a zero byte. The string is
word aligned (left justified) unless specified by a byte pointer.
The zero byte is not included in the string length, but must be
present.
Assigning a device
Associating an I/O device to the user's job either for the
duration of the job or until the user relinquishes it.
Associated variable
Returned in the AC on a normal return for the IPCFR monitor call
and returned to the status word when a IPCF-related software
interrupt is generated.
Associative memory
High-speed, 32-word memory that is used by the KI10 processor to
provide address mapping information for the operating system and
user programs.
Asynchronous
1. Pertaining to the procedure by which the hardware can begin a
second operation before waiting for the first operation to be
completed.
2. Pertaining to the method of data transmission in which each
character is sent with its own synchronizing information and
no fixed time between consecutive characters.
A-3
GLOSSARY
Backspace
To move back the logical position in a file or on a line
according to a prescribed format. For example, magnetic tape
units can be backspaced over a file or a record. Some terminals
allow backspacing in order to permit over-printing.
Bad Allocation Table (BAT) block
A block written on every disk unit to enumerate the bad regions
of consecutive bad blocks on that unit so that they are not
reused. The BAT blocks appear in the HOME.SYS file.
BADBLK.SYS
The file that contains all bad blocks. It may be read but not
deleted and is useful for testing error recovery.
Baud
A unit of signalling speed equal to the number of discrete
conditions or signal events per second.
Binary code
A code that uses two distinct characters only; usually these
characters are 0 and 1.
Bit
A binary digit (that is, 0 or 1). Usually refers to the smallest
unit of information storage, which can be on or off. A word on
TOPS-10 has 36 bits.
Block
A set of records, words, characters, or digits handled as a unit.
On the TOPS-10, a 128-word unit of disk storage allocated by
hardware and software; 128 words are always written, adding
zeroes as necessary, although fewer than 128 words can be read.
Bootstrap
A routine designed to bring itself into a desired state by means
of its own action (for example, a machine routine whose first
instructions are sufficient to bring the rest of itself into the
computer from an input device).
A-4
GLOSSARY
Breakpoint
A location at which program operation is suspended in order to
examine partial results. Breakpoints are used in the debugging
process.
Break Set
The set of characters used by the monitor to determine the end of
a command line typed on the terminal. The default terminal break
set includes <ESC> and <RET>, but your program can be enabled to
recognize any set of characters as break characters.
Buffer
A device or area used to temporarily hold information being
transmitted between two processes, such as external and internal
storage devices or I/O devices and internal high-speed storage.
A buffer is often a special register or a designated area of
internal storage.
Buffer pointer
A position indicator that is located between two characters in a
buffer, before the first character in the buffer, or after the
last character in the buffer, to indicate the position at which
the next operation will begin.
Buffer Ring
A ring of buffers used to allow a program to perform I/O
efficiently. In a buffer ring, the program can execute
instructions while the monitor is filling buffers.
Bug
A deficiency in a program that causes it to execute incorrectly,
or a mistake made by a person when writing a program or designing
hardware.
Byte
Any contiguous set of bits within a word.
Call
(verb) To transfer control to a specified closed subroutine.
Call
(noun) An instruction used to pass control to another program,
such as a "monitor call."
A-5
GLOSSARY
Caller
The program or routine which calls another program or routine.
The person who invoked the caller is referred to as the user. As
an example, the user types commands to SCAN which stores them in
core. The caller then calls WILD to study this block and select
files. Thus the user has specified the request but the caller
actually invoked WILD.
Calling sequence
A specified arrangement of instructions, pointers, and data
necessary to pass parameters and control to, and return from, a
given subroutine.
Card
A punched card with 80 vertical columns, each containing 12
vertical rows. Also, a unit of computer circuitry.
Card column
One of the vertical lines of 12 punching positions on a punched
card.
Card field
A fixed number of consecutive card columns assigned to a unit of
information.
Card hopper
The tray on a card processing machine that holds the cards to be
processed and makes them available to the card feed mechanism.
Card row
One of the horizontal lines of punching positions on a punched
card. A row is 80 columns long.
Card stacker
The tray on a card processing machine that receives processed
cards.
Carriage return
1. The operation that prepares for the next character to be
printed or displayed at the first position on the same
(current) line on a terminal or line printer.
2. The ASCII character with the octal code 015.
A-6
GLOSSARY
CDP
The generic device name for the card punch device.
CDR
The generic device name for the card reader device.
Central processing unit (CPU)
The portion of the computer that contains the arithmetic and
logical facilities, control circuits, and basic I/O and memory
interfaces. There can be more than one CPU in a computing
system.
Central site
The location of the central computer in a computer network. This
term is used in conjunction with remote communications to mean
the location of the TOPS-10 central processor as distinguished
from the location of the remote station. Refer to "Host."
CFP
See Compressed File Pointer.
Channel
1. A path along which signals can be sent, such as an output
channel.
2. A portion of TOPS-10 that can overlap I/O transmission while
computations proceed simultaneously (such as a data channel).
Character
One symbol of a set of elementary symbols such as those
corresponding to the keys on a typewriter. The characters
usually include the decimal digits 0 through 9, the letters A
through Z, punctuation marks, operation symbols, and any other
special symbols which a computer may read, store, or write.
Clear
To erase the contents of a location, a block of memory, or a mass
storage device by replacing the contents with blanks or zeroes.
Cluster
A single- or multi-block unit of disk storage assignment. The
number of blocks per cluster is a parameter of each file
structure.
A-7
GLOSSARY
Command
The part of an instruction that causes the computer to execute a
specified operation.
Command List
Specifies the memory area to be read or written when performing
dump I/O.
Communication link
The physical means of connecting one device to another for the
purpose of transmitting and receiving data.
Compressed file pointer
An 18-bit pointer to the unit within the file structure and to
the first super-cluster of the file. This pointer is stored in
the UFD for each file in that UFD. It points to the retrieval
information block, which contains the information necessary to
access the desired file.
Computer operator
A person who manipulates the controls of a computer and performs
all functions that are required to maintain and operate the
system, such as adjusting parameters which affect the operation
of the system, loading tape and disk drives, placing cards in the
input hopper, and removing listings from the line printer.
Computer program
A series of instructions or statements prepared in order to
achieve a specific result and intended for execution by a
computer. A program can be in either the binary form in which it
can be directly executed by a computer or a symbolic form that
must be compiled and/or assembled before it can be executed.
Concatenation
The joining of two strings of characters to produce a longer
string, often used to create symbols in macro definitions, or
combining two or more files into one larger file.
Concealed mode
The user submode on the KI or KL processor that may contain
proprietary coding. Sections of proprietary code are
hardware-protected from access by public mode programs except
through predefined entry points (PORTAL instructions).
A-8
GLOSSARY
Console
The part of a computer used by the operator to determine the
status of, and to control the operation of, the computer (CTY).
Also informally used to refer to the user's terminal.
Context switching
The saving of sufficient hardware and software information for a
process so that it may be continued at a later time, and the
restoring of similar information relevant to another process. A
common use of context switching is the temporary suspension of a
user program so that the monitor can execute a function.
Continued directory
The collection of all directories with a particular name and path
on all file structures in the job's search list.
Continued MFD
The MFDs on all file structures in the job's search list.
Continued SFD
The SFDs on all file structures in the job's search list which
have the same name and path.
Continued UFD
The UFDs for the same project-programmer number on all file
structures in the job's search list.
Control character
A character whose purpose is to control an action, such as line
spacing on the line printer, rather than to pass data to a
program. An ASCII control character has an octal representation
of 0-37. It is typed by holding down the CTRL key on the
terminal while striking a character key. It can be punched on a
card using the multi-punch key.
Controller
The device or portion of a device which controls the operation of
connected units. Some controllers can initiate simultaneous
positioning commands to some of its units and can then perform a
transfer for one of its units.
Controller class name
All file structures residing on all controllers of a given type.
A-9
GLOSSARY
Controller name
All file structures residing on a specific controller.
Core
Physical memory.
Core storage
A storage device normally used for main memory in a computer.
CORMAX
The maximum amount of core memory that a single job can use at
one time. This value can range from MINMAX to total user core.
CORMIN
The amount of core guaranteed to unlocked jobs. Locked jobs are
limited to total user core minus CORMIN.
Counter
A device, such as a register or storage location, used to
represent the number of occurrences of a certain event. Refer to
program counter.
CPU
See central processing unit.
Create
To open, write, and close a file for the first time. Only one
user at a time can create a file with a given name and extension
in the same directory or subdirectory of a file structure.
CRLF
Carriage-return/line-feed sequence. A "free CRLF" can be enabled
for terminal output. An "automatic CRLF" can be enabled for
terminal input.
CTY
Console terminal used to load, control, and debug the system.
CUSP
A Commonly Used System Program, such as LOGIN, that works closely
with the monitor to perform system functions.
A-10
GLOSSARY
Customer
A customer of Digital Equipment Corporation who has purchased a
DECsystem-10 as distinguished from a user at a terminal who may
be purchasing time from a customer.
Cylinder
The hardware-defined region of consecutive logical disk blocks
which can be read or written without repositioning. A cylinder
usually consists of tracks in the same physical position on
different disk surfaces.
DAEMON
A program for writing all or parts of a job's core area and
associated monitor tables onto disk.
Data
A general term used to denote any or all information (facts,
numbers, letters, and symbols that refer to or describe an
object, idea, condition, or situation). It represents basic
elements of information which can be processed by a computer.
Data channel
The device which passes data between the memory system and a
controller.
DDB
A device data block.
DDT
The Dynamic Debugging Technique program used for on-line
checkout, testing, examination, modification, and program
composition of object programs. Various types of DDT programs
are available, such as DDT11 for debugging PDP-11 remote stations
and the RSX-20F front end, and EDDT for debugging the monitor.
Deadlock
The situation where two or more jobs are waiting for each other
to complete use of a resource, but neither of the jobs can obtain
a lock on the resource it needs for completion.
Debug
To detect, locate, and correct any mistakes in a computer
program.
A-11
GLOSSARY
DECtape
A convenient, pocket-sized reel of random access magnetic tape
developed by Digital Equipment Corporation. A standard reel
consists of 578 (decimal) blocks, each capable of storing 128
(decimal) words of data.
Default directory
The directory that monitor searches when a disk directory has not
been specified by the user. Typically, this is the UFD
(user-file directory) corresponding to the user's
project-programmer number but it may be another UFD or a SFD
(sub-file directory).
Demand paging
The operation in which all pages of a program are not resident in
core during execution. References to non-resident pages initiate
the actions of moving in additional pages or replacing inactive
pages.
Dequeue
The function of releasing or relinquishing ownership of a
resource. Refer to "Enqueue."
Device substitution
Your program can be written for one device, and, before your
program is executed, you can substitute another device by using
the ASSIGN command.
Device routines
Routines that perform I/O for specific hardware devices. They
usually translate logical block numbers to physical addresses for
those devices that associate addresses with data. These routines
also handle error recovery and ensure ease of programming through
device independence.
Diagnostic
Pertaining to the detection and isolation of a hardware
malfunction or bug. A program which tests the hardware and
isolates any faults.
Digit
A symbol that represents one of the nonnegative integers smaller
than the base of the system. For example, in the decimal system,
a digit is one of the characters from 0 to 9.
A-12
GLOSSARY
Direct address
An address that specifies the location of an operand. Contrast
with indirect address.
Directory
A file that contains the names and pointers to other files on the
device. The MFD, UFDs, and SFDs are directory files. The MFD is
the directory containing all the UFDs. The UFD is the directory
containing the files existing in a given project-programmer
number area. The SFD is a directory pointed to by a UFD or a
higher-level SFD. The SFDs exist as files under the UFD. The
DIRECT monitor command lists a directory.
Directory device
A storage retrieval device, such as disk, DECtape, or labelled
magnetic tape, that contains information describing the names of
files and the layout of stored data (programs and other files).
A directory device is randomly accessible.
Directory path
The ordered list of directory names, starting with a UFD name,
which uniquely specifies a directory without regard to a file
structure. A file structure name, a path, and a file name and
extension are needed to uniquely identify a file in the system.
Directory specification
The way that the user specifies the directory to the SCAN
program. It is always typed within square brackets. Fields are
separated by commas. The first two fields are the project and
programmer numbers which are octal. They specify the particular
UFD. Additional fields are SFDs in order from the UFD down. The
following notations are allowed:
[PPN] UFD
[PPN,sfd,...sfd] full path to directory
[-] default directory
[,] your UFD
DIS
Display light pen.
Disk
A form of mass storage device in which information is stored on
rotating magnetic platters. A disk is a directory device.
A-13
GLOSSARY
Disk address
All references to disk addresses refer to a logical or relative
address; they do not refer to any physical addressing scheme.
The basic addressable unit is a 200 (octal) 36-bit word block.
Dismounting a file structure
Deleting a file structure from a user's active search list by
using the DISMOUNT command. It does not necessarily imply
physical removal of the file structure from the system.
Dormant file structure
A file structure that is physically mounted but has no current
users; that is, when the mount count is zero.
Dormant segment
A sharable high segment kept on a swapping space, and possibly in
core, which is in no user's addressing space.
Double precision
The use of two computer words to represent a number.
DSK
The generic device name for disk-like devices. The generic
device DSK is translated by the system into actual file structure
names which are defined for each job by the file structure search
list.
DSKLST
A program that gives the status and statistics of all user disk
files at a given time.
DSKRAT
A damage assessment program that scans a file structure and
reports any inconsistencies detected.
DTA
The generic device name for DECtape.
Dump
A listing of variables and their values, or a listing of the
values of locations in core.
A-14
GLOSSARY
Echoing
A method of data transmission in which the received data is
returned to the sending end. Usually used in discussions of
terminal I/O.
Edit
To modify the content or format of a program or data file (as to
insert or delete characters).
Effective address
The actual address used; that is, the specified address as
modified by any indexing or indirect addressing rules.
ENQ/DEQ
A facility that ensures that resources such as files are shared
correctly.
Enqueue
The function of storing requests for ownership of some limited
resource in lists or queues until the requests can be granted.
Entry point
A point in a subroutine to which control is transferred when that
subroutine is called.
Error Interception
When an error occurs, the monitor intercepts control of the
program, examines location .JBINT, and transfers control to an
error intercepting routine.
Ersatz device name
A device name that may not refer to an actual device, but
represents a UFD. Ersatz device names are a specific set of such
logical names, recognized by the monitor.
Execute
To interpret an instruction or command and perform the indicated
operation(s).
Executive mode
A central processor mode characterized by the lack of memory
protection and relocation and by the normal execution of all
defined operation codes.
A-15
GLOSSARY
Extended file
A file that has more than one RIB in which to record the
retrieval pointers.
Extended argument block for LOOKUP, ENTER, and RENAME
A detailed argument block for each of these calls that describes
information from the file's RIB.
Extended RIBs
Additional retrieval information blocks (RIBs) required when the
retrieval pointers in a file overflow the prime RIB.
External symbol
A global symbol which is referenced in one module but defined in
another module. The EXTERN statement in MACRO-10 is used to
declare a symbol to be external. A subroutine name referenced in
a CALL statement in a FORTRAN module is automatically declared
external.
FENCE
The boundary between the active and passive search lists. This
distinction is maintained by the SETSRC program.
File
An ordered collection of characters or 36-bit words containing
computer instructions and/or data. A file is stored on a device,
such as disk or magnetic tape, and can be of any length, limited
only by the available space on the device and the user's maximum
space allotment on that device. A file is uniquely identified in
the system by a file structure name or directory name, a
directory path, and a file name and extension.
File Daemon
The monitor calls the File Daemon (if F%FDAE=1) every time that
someone tries to access a file that has a 4, 5, 6, or 7 code in
the owner's protection field and the access fails due to a
protection error. Refer to Appendix C.
File directory
See Directory.
A-16
GLOSSARY
File extension
One to three alphanumeric characters usually chosen by the
program to describe the class of information in a file. The
extension is separated from the file name by a period.
File name
One to six alphanumeric characters chosen by the user to identify
a file.
File specification
A list of identifiers which uniquely specifies a particular file.
A complete file specification consists of: the name of the
device on which the file is stored, the name of the file
including its extension, and the name of the directory in which
the file is contained. File specifications are ignored for
non-file-oriented devices, such as cards and paper tape. Your
program specifies a file name and directory name in a LOOKUP,
ENTER, RENAME, or FILOP. monitor call.
File specification area
The area of core in which SCAN stores the result of scanning the
user's file specification. This instructs WILD as to the files
to select.
File status word
See I/O status word.
File structure
The logical arrangement of blocks (which are normally 128 words
long) on one or more disk units of the same type to form a
collection of files and directories.
File structure abbreviation
An abbreviation of one or more file structures. This refers to
all those structures in the ALL search list whose names match the
abbreviation. For example, if there were structures "PRIV" and
"PACK," "P" would refer to both structures but "PR" would mean
just "PRIV."
File structure owner
The user whose project-programmer number is associated with the
file structure in the administrative file STRLST.SYS. The CATLOG
program is used to enter or delete this project-programmer number
or any of the other information that is contained in an
STRLST.SYS entry.
A-17
GLOSSARY
Flag
An indicator that signals the occurrence of some condition, such
as the end of a word.
Fragmentation
The state existing when swapped segments cannot be allocated in
one contiguous set of blocks on the swapping space and therefore
must be allocated in separate sections.
Full-SCNSER PTY
A pseudo-terminal (PTY) that contains the full terminal
characteristic set, allowing echoing to the controlled job and a
full break set. Refer to "PTY."
Fullword
A contiguous sequence of bits or characters that comprises a
single computer word, or describing a word that can be referred
to as a single unit. On TOPS-10, a word is 36 bits long.
Funny space
Refer to "Per-process space."
Generic device name
The name of a class of physical units. This abbreviation is
usually three characters. As an example, DTA is the generic name
for DECtapes, and DTA0, DTA1, and so forth, are specific unit
names.
Global symbol
A symbol that is accessible to modules other than the one in
which it is defined. The value of a global symbol is placed in
the loader's global symbol table when the module containing the
symbol definition is loaded.
Group
A contiguous set of disk clusters allocated as a single unit of
storage and described by a single retrieval pointer.
Halfword
A contiguous sequence of bits or characters which comprises half
of a computer word and may be addressed as a unit. On TOPS-10,
bits 0 through 17 comprise the left half word and bits 18 through
35, the right half word. Each half word is 18 bits long.
A-18
GLOSSARY
Hardware
Physical equipment of the computer (such as magnetic, mechanical,
and electronic devices), as contrasted with the computer program
(software) or method of use.
High segment
That portion of the user's addressing space, usually beginning at
virtual address 400000, which generally is used to contain pure
code that can be shared by other users. This segment is usually
write-protected in order to protect its contents. The user can
place information into a high segment with the TWOSEG pseudo-op
in MACRO-10. Higher-level languages, such as COBOL and FORTRAN,
also have provisions for loading code into the high segment.
HOME.SYS
The file that contains a number of special blocks for system use.
These blocks are the home blocks, the BAT blocks, the ISW blocks,
and block zero.
HOME block
The block written twice on every unit that identifies the file
structure the unit belongs to and its position on the file
structure. This block specifies all the parameters of the file
structure along with the location of the MFD. The home block
appears in the HOME.SYS file.
Host
A processor or system in a computer network that processes and
executes user commands and programs. For example, this term is
used to distinguish a DECsystem-10 from a PDP-11 remote station.
I/O
An abbreviation for input or output, or both. Pertaining to all
equipment and activity that transfers information into or out of
a computer.
I/O status word
Sometimes called "file status word," this word contains I/O error
bits and data modes for the device that is OPEN for I/O.
ICPT
In-core protect time. Minimum amount of time that a job is
guaranteed to reside in core.
A-19
GLOSSARY
Idle segment
A sharable segment that is referenced by one or more swapped-out
jobs, but not by any jobs currently in core.
Idle time
That part of uptime in which no job could run because all jobs
were HALTed or waiting for some external action such as I/O.
Immediate mode addressing
The interpretation of certain instructions in which the effective
address of the instruction is used as the value of an operand
(rather than the address of an operand).
Impure code
The code that is modified by a program.
Indexed address
An address that is formed by adding the content of an index
register to the content of an address field prior to or during
the execution of a computer instruction.
Index register
A register whose contents may be added to the operand address
prior to or during the execution of a computer instruction.
Accumulators 1 through 17 (octal) may be used as index registers.
(Accumulator 0 may not be used as an index register.)
Indirect address
An address which indicates a storage location where the address
of the referenced operand (or another indirect address) is to be
found. Contrast with direct address.
Initialize
To set counters, switches, or addresses to zero or other starting
values at prescribed points in the execution of a computer
routine, particularly in preparation for reexecution of a
sequence of code.
Initialize a device
A device must be initialized on a software I/O channel to do I/O.
A-20
GLOSSARY
Input
1. Pertaining to a device, process, or channel involved in the
acquisition of data.
2. Information that is read by a computer.
Instruction
A bit pattern which, when interpreted by the computer, directs
the computer to execute a specific operation. An instruction
generally contains the values or locations of its operands.
Interleaving
The process of configuring the memory addressing so that
consecutive addresses are not stored in the same memory module.
This allows the possibility of increasing memory speed by
overlapping part of the operation of different memory modules.
Internal date-time format
The format for storing a combined date and time internally. This
format is used by SCAN and other programs. It has the property
that it is one 35-bit ("integer") quantity such that the
difference between two points in time in internal format is
constant if they are a constant time apart. The format is:
In the left halfword, the number of days since November 17, 1858.
In the right half a fraction of the day since midnight.
This results in a resolution of approximately one third of a
second. The date field will not be exceeded until 2217 A.D.
(November 17, 1858, is the origin date used by the Smithsonian
calendar. This calendar is in use by several computer systems
and many astrophysics programs. Its origin was selected because
November 18, 1858 was the date of the first "Harvard Plates,"
which were the first accurate astronomical photographs. Hence,
this date standard minimizes the date field while leaving all
astrophysical measurements as positive dates).
Internal storage
Addressable high speed storage directly controlled by the central
processing unit.
A-21
GLOSSARY
Internal symbol
A global symbol located in the module in which it is defined. In
a MACRO-10 program, a symbol is declared internal with the INTERN
or ENTRY pseudo-op. These pseudo-ops generate a global
definition which is used to satisfy all global requests for the
symbol.
Interrupt
A signal which, when activated, causes a transfer of control to a
specific location in memory thereby breaking the normal flow of
control of the routine being executed. An interrupt is caused by
an external event such as a done condition in a peripheral. It
is distinguished from a trap which is caused by the execution of
a processor instruction.
IPCF
The Inter-Process Communications Facility, which allows
communication among jobs and system processes.
JACCT program
A program running with the JACCT privilege bit. This is set by
the monitor for special system programs such as LOGIN. This bit
gives the caller full file access; that is, it allows the caller
to LOOKUP and read any file in the system regardless of the
file's protection code.
Jiffy
A period of time equal to 1/60 of a second (for 60 Hz power) or
1/50 of a second (for 50 Hz power), used to count CPU cycles.
Synonym for "tick."
Job
The entire sequence of steps from beginning to end, that the user
initiates from his interactive terminal or batch control file or
that the operator initiates from his operator's console. Thus,
it is a specific group of steps presented as a unit of work for
the computer. A job usually includes all necessary computer
programs, files, linkages and instructions to the operating
system.
Job Data Area (JOBDAT)
The first 140 octal locations of a user's virtual address space.
This area provides storage for certain data items used by both
the monitor and the user's program.
A-22
GLOSSARY
Job search list
The ordered list of file structures for your job that are
searched automatically when the generic device name DSK is
specified or implied in the file specification.
K
A symbol used to represent 1024 (2000 octal); for example, 32K is
equivalent to 32,768.
Kernel mode
The executive submode in the processor under which I/O and
system-wide functions operate. Code executed in kernel mode can
access and alter all of memory.
KL-paging
The method of paging memory used by the hardware of the KL
processor to extend the virtual memory space of the program to a
multiple of 256K. Refer to the Processor Reference Manual.
Label
A symbolic name used to identify a statement or an item of data
in a program.
Leader
A blank section of tape at the beginning of a reel of magnetic
tape or the beginning or end of a stack of paper tape.
Library
A file containing one or more relocatable binary modules which
may be loaded in Library Search Mode. MAKLIB is a system utility
program which enables users to merge and edit a collection of
relocatable binary modules into a library file. PIP can also be
used to merge relocatable binary modules into a library, but it
has no facilities for editing libraries.
Library search mode
The mode in which a module (one of many in a library) is loaded
only if one or more of its declared entry points satisfy an
unresolved global request.
A-23
GLOSSARY
Library search symbol (entry symbol)
A list of symbols that are matched against unresolved symbols in
order to load the appropriate modules. This list is used only in
library search mode. A library search symbol is defined by an
ENTRY statement in MACRO-10.
Line
A string of characters terminated with a vertical tab, form feed,
or line feed. The terminator belongs to the line that it
terminates.
Line feed
1. The operation that prepares for the next character to be
printed or displayed at the same (current) position on the
next line on a terminal or line printer.
2. The ASCII character with the octal code 012.
Line printer
An electro-mechanical computer peripheral which accepts a line of
characters from the computer at a high speed and then prints the
entire line in one operation.
Line
To combine independently--translated modules into one module in
which all relocation of addresses has been performed relative to
that module and all external references to symbols have been
resolved based on the definition of internal symbols.
Load
To produce a core image and/or a saved file from one or more
relocatable binary files (REL files) by transforming relocatable
addresses to absolute addresses. This operation is not to be
confused with the GET operation, which initializes a core image
from a saved file (refer to GET).
Local peripherals
The I/O devices and other data processing equipment and memory,
excluding the central processor and memory, located at the
central site.
A-24
GLOSSARY
Local symbol
A symbol known only to the module in which it is defined.
Because it is not accessible to other modules, the same symbol
name with different values can appear in more than one module.
These modules can be loaded and executed together without
conflict. Local symbols are primarily used when debugging
modules; symbol conflicts between different modules are resolved
by mechanisms in the debugging program.
Lock
An association between a job and a resource.
Locked job
A job in core that is never a candidate for swapping or
shuffling.
Logged-in UFD
The UFD that corresponds to the project-programmer number under
which the user is logged in.
Logical device name
An alphanumeric name you choose to represent a physical device.
This name can be used synonymously with the physical device name
in all references to the device. Logical device names allow
device independence in that the most convenient physical device
can then be associated with the logical name at run time.
Logical names take precedence over physical names. With the
exception of disks, only one logical name can be associated with
a physical name.
Logical record
A collection of related items stored together. It is possible to
have:
1. Several logical records stored in a single physical record.
2. Each logical record stored in a single physical record.
3. Each logical record occupy one or more physical records.
4. Logical records span several physical records, and at the
same time, have more than one logical record in a single
physical record.
A-25
GLOSSARY
LOGIN
The system program by which the system users gain access to the
computing system.
Lost time
The time that the null job was running, while at least one other
job wanted to run (was not waiting for a device) but could not
because one of the following was true:
1. The job was being swapped out.
2. The job was being swapped in.
3. The job was on disk waiting to be swapped in.
4. The job was momentarily stopped so devices could become
inactive in order to shuffle jobs in core.
Low segment
The segment of user virtual address space beginning at zero. It
contains the Job Data Area and I/O buffers. The length of the
low segment is stored in location .JBREL of the Job Data Area.
When writing two-segment programs, it is advisable to place data
locations and impure code in the low segment.
LPT
The generic device name for line printers.
MACRO
The symbolic assembly program on the TOPS-10.
Macro
A portion of code that is substituted for its name whenever its
name is invoked.
Magnetic tape
A tape with a magnetic surface on which data can be stored by
magnetizing selective portions of the surface.
MAINT.SYS
The area of the disk reserved for maintenance use only.
A-26
GLOSSARY
Mask
1. A combination of bits that is used to control the retention
or elimination of portions of any word, character, or byte in
memory.
2. On half-duplex circuits, the characters typed on the terminal
to make the password unreadable.
Master/slave system
A specific type of multiprocessing system involving two
processors where one processor has a more important role than the
other.
Master file directory (MFD)
The file created when the disk is refreshed, which contains the
names of all user file directories including itself.
Meddling
The action of attempting to modify code in a sharable high
segment.
Memory cycle overlap
The hardware feature that allows a second memory reference to be
made before data from the first reference has been received by
the processor.
Memory protection
A scheme for preventing read and/or write access to certain areas
of storage.
Metering
A technique used to perform performance analysis.
MINMAX
The minimum value for CORMAX.
Mnemonic symbol
A symbolic representation for a computer instruction or other
numeric item. All defined monitor symbols are listed in
UUOSYM.MAC.
A-27
GLOSSARY
Modes
The data modes that can be used when performing I/O.
Module
The smallest entity that can be loaded by the loader. It is
composed of a collection of control sections. In MACRO-10, the
code between the TITLE and END statements represents a module.
In FORTRAN, the code between the first statement and the END
statement is a module. In COBOL, the code between the
IDENTIFICATION DIVISION statement and the last statement is a
module.
Module origin
The first location occupied by the module in user virtual address
space.
MONGEN
The monitor generator dialogue program that enables the system
programmer to define the hardware configuration of his individual
installation and the set of software options that he wishes to
select for his system.
Monitor
The collection of programs which schedules and controls the
operation of user and system programs, performs overlapped I/O,
provides context switching, and allocates resources so that the
computer's time is efficiently used. Also called the operating
system.
Monitor command
An instruction to the monitor to perform an operation.
Mount count
The count of the number of jobs that have a certain file
structure in their active or passive search lists (plus 1 if the
structure is in the system search list).
Mounting a device
To request both the system to assign an I/O unit and the operator
to physically place the specified medium (for example, magnetic
tape reel or disk pack) on that unit.
A-28
GLOSSARY
Mounting a file structure
The process of adding a file structure to a search list. If the
file structure is not already defined and mounted, this action is
requested of the operator.
MPX-controlled device
A device connected to a multiplexed channel.
MPXable Devices
The devices that can be connected to an MPX channel are line
printers, terminals, paper-tape punches, remote data entry
devices, and pseudo-TTYs.
MTA
The generic device name referring to a magnetic tape unit.
Multiprocessing
Simultaneous execution of two or more computer programs by two or
more processors.
Multiprogramming
A technique that allows scheduling in such a way that more than
one job is in an executable state at any one time. TOPS-10 is a
multiprogramming operating system in which there are two or more
independent instruction streams that are simultaneously active
but are not necessarily simultaneously executed.
Nesting
To include a loop, a macro definition, a routine, or a block of
data within a larger loop, macro definition, routine, or block of
data.
No-op
An instruction that specifically instructs the computer to do
nothing. The next instruction in sequence is then executed.
Non-blocking I/O
In buffered modes, the program does not block while waiting for a
buffer to be filled or emptied.
A-29
GLOSSARY
Non-directory device
A device, such as unlabelled magnetic tape or paper tape, that
does not contain a file describing the names and layout of data
files.
Non-sharable segment
A segment for which each user has his own copy. This segment can
be created by a CORE or REMAP UUO or initialized from a file.
Octal
1. Pertaining to a characteristic or property in which there are
eight possibilities.
2. Pertaining to the number system with a radix of eight.
Offset
The number of locations or bytes relative to the base of an
array, string, or block. For example, the number of locations
relative to zero that a Control Section must be moved before it
can be executed.
ONCE-only time
The time at which the operator can change a number of monitor
parameters when the monitor is started up. This is done prior to
scheduling any jobs, when the ONCE program is run at system
startup.
Operand
1. The data that is accessed when an operation (either a machine
instruction or a higher level operation) is executed.
2. The symbolic expression representing that data or the
location in which that data is stored, for example, the input
data or arguments of a pseudo-op or macro instruction.
Operating system
The collection of programs that administer the operation of the
computing system by scheduling and controlling the operation of
user and system programs, performing I/O and various utility
functions, and allocating resources for efficient use of the
hardware.
A-30
GLOSSARY
OPR
The operator's control program to monitor and maintain the GALAXY
batch and spooling system (Version 4.1 and later), and the DECnet
network environment (Version 3 or later).
OPSER
The OPerator SERvice program that allows multiple job control
from a single terminal.
Output
1. Pertaining to a device, process, or channel involved in an
output process (that is, the process of transferring data
from memory to a peripheral device).
2. The data that has been transferred from memory to a medium
readable by a person (such as line printer listings).
Pack
1. To compress data in memory or on a peripheral storage device
by taking advantage of known characteristics of the data so
that the original data can be recovered.
2. A disk pack (that is, a removable set of disks mounted on a
common shaft).
Packet
A group of words or block of data passed from one program to
anothers cooperating program. This is accomplished through use
of the IPCF facility or through task-to-task network
communication.
Pack-ID
A 6-character SIXBIT name or number used to uniquely identify a
disk pack.
A-31
GLOSSARY
Page
1. Any number of lines terminated with a form feed character.
2. The smallest mappable unit of core storage. On the KL10
processor, a page is 512 continuous words in core starting on
boundaries which are even multiples of 512. It is also the
smallest allocatable unit of memory. KL10 operations allow
programs to be composed of up to 512 pages scattered within
core.
3. To selectively remove parts of a user's program from core
memory.
Paper tape
A tape on which data is represented by specific patterns of
punched holes.
Parameter
A variable that is given a constant value for a specific purpose
or process, for example, an input argument to a subroutine or
command, or a value specifically assigned to a symbol in an
assembly in order to control exactly what code is assembled.
Parity bit
A binary digit attached to a group of bits to make the sum of all
the bits always odd (for odd parity) or always even (for even
parity).
Parity check
A check that tests whether the number of ones or zeros in an
array of binary digits is correct. This check helps ensure that
the data read has not been unintentionally altered.
Passive search list
An unordered list of the file structures that have been in the
job's active search list but have been removed without ever
having been dismounted. This list is maintained by the SETSRC
program and is use for accounting purposed when you log out.
Password
The character string assigned to a user; it is known only to the
user, the installation administration, and the monitor system.
The password is used to verify that a user is entitled to run a
job under a specific project-programmer number.
A-32
GLOSSARY
Path
See directory path.
Pathological name
The logical name associated with a directory path. The
pathological name refers to the list of structures and
directories (STR:[UFD,SFD1,SFD2,...,SFD5]) to be searched any
time the pathological name is specified as the device in the file
specification.
PC
See "program counter."
Peripheral equipment
Any unit of equipment, distinct from the central processing unit,
the console, and the memory, that can provide input to, or accept
output from, the computer.
Per-process space
The portion of monitor memory used to store data specific to user
jobs. Also called "funny space."
PHB
Packet Header Block used to store information when using IPCF.
Physical address space
A set of physical memory locations where information is actually
stored for the purpose of program execution. (As opposed to
virtual memory addresses, which may be mapped, relocated, or
translated to produce a physical memory address in the hardware
memory units. This physical address is 22 bits long on the
DECsystem-10.
Physical device name
The name of a specific peripheral unit. It is a SIXBIT name
consisting of 3 to 6 characters. Examples: FHA0, FHA1, DPA0,
DPA7, LPT0, DTA3.
PI
See "priority interrupt."
A-33
GLOSSARY
PID
A Process IDentifier is used to identify a system program that is
the target of communication using the IPCF facility.
PIT
PSI system's internal data base.
PLT
The generic device name for plotter.
PMB
The Packet Message Block where user data is stored to be sent to
another program, using IPCF.
Pointer
1. A location or register containing an address rather than
data. A pointer may be used in indirect addressing or in
indexing.
2. An instruction indicating the address, position, and length
of a byte of information (such as a byte pointer).
Policy CPU
In a symmetric multi-processing system, the CPU that provides
system initialization and other overhead functions for the rest
of the central processors.
Pool
One or more logically complete file structures that provide file
storage for the users and that require no special action on the
part of the user.
Pooled Resource
A pooled resource occurs when multiple copies of a resource
exist. You specify that a resource is to be a pooled resource
with the ENQ. monitor call.
Positioning operation
On the TOPS-10, the operation of moving the read-write heads of a
disk to the proper cylinder prior to a data transfer. This
operation requires the control for several micro-seconds to
initiate activity, but does not require the channel or memory
system.
A-34
GLOSSARY
Prime RIB
The first retrieval information block (RIB) of a file. This
block contains all file attributes and pointers to data blocks on
disk. Refer to RIB definition.
Priority interrupt
An interrupt that usurps control of the computer from the program
or monitor and jumps to an interrupt service routine if its
priority is higher than the interrupt currently being serviced.
Privileged program
1. Any program running under project number 1, programmer number
2.
2. A monitor support program executed by a monitor command which
has the JACCT (job status) bit set, for example, LOGOUT.
Process
A collection of segments that perform a particular task. Usually
synonymous with "job," "program," or "task."
Program
1. The complete plan for the solution of a problem, more
specifically the complete sequence of machine instructions
and routines necessary to solve a problem.
2. A collection of routines which have been linked and loaded to
produce a saved file or a core image. These routines
typically consist of a main program and a set of subroutines,
some of which may have come from a library.
Program counter (PC)
A register that contains the address from which the next
instruction to be executed is fetched. At the beginning of each
instruction on a PDP-10, the PC normally contains an address that
is one greater than the location of the previous instruction.
Programmed operators
Instructions which, instead of performing a hardware operation,
cause a jump into the monitor system or the user area at a
predetermined point and perform a software operation. The
monitor (or special user code) interprets these entries as
commands from the user program to perform specified operations.
A-35
GLOSSARY
Program origin
The location assigned by LINK to relocatable zero of a program.
Program trap
One of the software-defined operation codes which, when decoded
by the processor, causes the next instruction to be executed from
a specified address.
Project-programmer number
Two octal numbers, separated by commas, which, when considered as
a unit, identify the user and his file storage area on a file
structure.
Protected location
1. A storage location which cannot be accessed in a certain
context. For example, a write-protected location cannot be
written into.
2. A storage location reserved for special purposes in which
data cannot be stored without undergoing a screening
procedure to establish suitability for storage therein.
Protection address
The maximum relative address that the user can reference.
Protection code
Each file has a protection code that indicates who may or may not
access the file, in the form <opa>, where o is an octal digit
representing accessability to the owner of the file, p is the
digit for members of the same project (possessing the same
project number in their PPN), and a is the digit for all other
users. Each octal digit represents the level of access allowed
to the appropriate type of user, from 0, allowing any type of
access, to 7, allowing no access to other users. Note that the
owner can always change the protection code associated with the
file.
PSI System
Programmable software interrupt system.
Pseudo-op
An operation that is not part of the computer's operation
repertoire as realized by hardware; hence, an extension of the
set of machine operations. In MACRO, pseudo-ops are directions
for assembly operations.
A-36
GLOSSARY
Pseudo-terminal
A simulation of a terminal device generated by the software to
accept commands from a data base rather than a physical input
device.
PTP
The generic device name used to refer to the paper tape punch.
PTR
The generic device name used to refer to the paper tape reader.
PTY
The generic device name used to refer to a pseudo-terminal.
Public disk pack
A disk pack belonging to the storage pool and whose storage is
available to all users who have quotas on it.
Public mode
The user submode on the processor.
Pure code
Code which is never modified in the process of execution.
Therefore, it is possible to let many users share the same copy
of a program.
Pushdown list
A list that is constructed and maintained so that the next to be
retrieved is the most recently stored item in the list. Also
called "stack" and first-in/last-out (FILO) list.
Pushup list
A list that is constructed and maintained so that the next item
to be retrieved and removed is the oldest item in the list. Also
known as a first-in/first-out (FIFO) list.
Quantum time
The processor time given to each job when it is assigned to run.
A-37
GLOSSARY
Queue
A list of items waiting to be scheduled or processed according to
system, operator, or user-assigned priorities. Examples: batch
input queue, spooling queues, monitor scheduling queues.
QUOTA.SYS
The file that contains a list of users and their quotas for the
private file structure on which the file resides. Created using
PULSAR.
Random access
A process having the characteristic that the access time is
effectively independent of the location of the data.
RDA
The generic device name used to refer to a Remote Data terminal.
Read
Input data from a file.
Record
A collection of adjacent related items of data treated as a
logical unit.
Record gap
An area on a data medium between consecutive records. It is
sometimes used to indicate the end of a block or record.
Recursive
A repetitive process in which the result of each process is
dependent upon the result of the previous one.
Reentrant program
A program consisting of sharable code which can have several
simultaneously independent users.
Refresh
To remove all files from a file structure and to build the
initial set of files based on information in the HOME block.
A-38
GLOSSARY
Relative address
The address before hardware or software relocation is added.
REL file
A file containing one or more relocatable object modules.
Relocatable address
An address within a module which is specified as an offset from
the first location in that module.
Relocate
1. To move a routine from one portion of storage to another and
to adjust the necessary address references so that the
routine can be executed in its new location.
2. To convert a relocatable binary module to an absolute binary
module.
Relocation counter
1. The number assigned by LINK-10 as the beginning address of a
Control Section. This number is assigned in the process of
loading specific Control Sections into a saved file or a core
image and is transformed from a relocatable quantity to an
absolute quantity.
2. The address counter that is used during the assembly of
relocatable code.
Relocation factor
The contents of the relocation counter for a control section.
This number is added to every relocatable reference within the
Control Section. The relocation factor is determined from the
relocatable base address for the control section (usually 0 and
400000) and the actual address in user virtual address space at
which the module is being loaded.
Remote access
Pertaining to communication with a data processing facility by
one or more stations that are distant from that facility.
Remote peripherals
The I/O devices and other data processing equipment that are
located at the site of the remote station.
A-39
GLOSSARY
Removing a file structure
The process of physically removing a file structure from the
system. This is requested with the REMOVE switch in the DISMOUNT
command string and requires the operator's approval.
Resource
Any entity within the system. The actual definition of a
resource is defined by the job(s) using that resource. Refer to
ENQ/DEQ.
Response time
The time between the generation of an inquiry or request and the
receipt of the response or the accomplishment of the requested
action.
Restricted device
Your program can use a restricted device only if it is assigned
to you by a privileged job. You ask for this assignment by
issuing the MOUNT command.
Retrieval Information Block (RIB)
The block that contains pointers to all the groups in a specific
file. Each file has two copies of the RIB, one in the first
block of the first group and the second in the block following
the last data block in the last group of the file.
Return
1. The set of instructions at the end of a subroutine that
transfers control to the proper point in the calling program.
2. The point in the calling program to which control is
returned.
3. Informally, the carriage-return/line-feed sequence. Refer to
CRLF.
RIB
See Retrieval Information Block.
Routine
A set of instructions and data for performing one or more
specific functions.
A-40
GLOSSARY
Run
To transfer a save file from a device into core and to begin
execution.
SAT.SYS
The Storage Allocation Table file which contains a bit for each
cluster in the file structure. Clusters which are free are
indicated by zero and clusters which are bad, allocated, or
nonexistent are indicated by one.
Save
To produce a file from a core image of a program in memory. This
results in an executable file that can be loaded and run without
relocation.
Scan
The process of examining and parsing a text string. The SCAN
program parses commands for the monitor.
Search
1. The process of locating an object by examining each object in
the set to determine if it is the desired object or if the
desired object exists.
2. The process by which the disk controller reads sector heads
to find the correct sector. The second step in the transfer
operation.
Search List
A list of the file structures that may be searched when files are
referenced. (One of the ALL Search List, Job Search List, or SYS
Search List.)
Secondary storage
Low speed magnetic storage such as disks or drums.
Sector
A physical portion of a mass storage device.
A-41
GLOSSARY
Segment
An absolute Control Section. A logical collection of data,
either program data or code, that is the building block of a
program. The monitor keeps a segment in core and/or on the
swapping device.
Segment resident block
A block that contains all the information that the monitor
requires for a particular segment.
Service routine
A routine in general support of the operation of a computer.
SETSRC
A program that allows the user to list or change his search list.
SFD (sub-file directory)
A directory pointed to by a UFD or a higher-level SFD. Each user
has a UFD. Within that, he may have as many SFDs as he wishes.
Sharable segment
A high segment that can be used by several programs at a time.
Shared code
Pure code residing in a shared segment.
Sharer's Group
A subset of those jobs desiring shared ownership of a particular
resource.
Simultaneous Update
Allowing more than one cooperating job to update a file.
Single access
The status of a file structure that allows only one particular
job to access the file structure. This job is the one whose
project number matches the project number of the owner of the
file structure.
A-42
GLOSSARY
SIXBIT code
A 6-bit code in which textual information is recorded. It is a
compressed form of the ASCII character set, and thus not all of
the characters in ASCII are available in SIXBIT, notably the
nonprinting characters and the lower case letters are omitted.
The range of SIXBIT code is 00 to 77 (octal) which is equal to 40
through 137 (octal) in ASCII.
Skip
The process by which an instruction, macro or subroutine causes
control to bypass one instruction and proceed to the next
instruction.
Software Interrupt System
Interrupts the sequential flow of program execution under a
variety of conditions. Also called PSI system.
Spooling
The technique by which output to slow-speed devices is placed
into queues on faster devices (such as disk) to await
transmission to the slower devices; this allows more efficient
use of the computer.
Storage Allocation Table
A file reflecting the status of every addressable block on the
disk (SAT.SYS).
String
A set of contiguous items of a similar type. Generally strings
are sequences, of variable or arbitrary length; of bits, digits,
or characters.
STRLST.SYS
The administrative file that describes each file structure in the
system. This file is used by the MOUNT command.
Structure
A File Structure.
Sub-File Directory
An extension of the user-file directory that allows the user to
categorize his files into sub-groups.
A-43
GLOSSARY
Subroutine
A routine designed to be used by other routines to accomplish a
specific task.
Super-cluster
A contiguous set of one or more clusters introduced to compress
the file pointer for large units into 18 bits. Refer to
compressed file pointer.
Super-USETI
A style of reading a disk unit or file structure by giving
absolute addresses rather than locations within a file.
Supersede
To open a file for writing, write the file, and close the file
when an older copy of the same name already exists. Only one
user at a time may supersede a given file at any one time. The
older copy of the file is deleted when all users are finished
reading it.
Supervisor mode
The executive submode of the processor. Similar to public mode;
however, code executed in supervisor mode is able to access, but
not alter, concealed mode code.
SWAP.SYS
The file containing the swapping area on a file structure.
Swapping
1. The technique in multiprogramming of running more jobs than
there is physical memory for, by storing some of the jobs on
secondary storage when they are not executing.
2. The action of moving user programs between core and secondary
storage.
Swapping class
A category of swapping units distinguished from other categories
of swapping units according to speed. Class 0 contains the
fastest swapping units.
Swapping device
Secondary storage that is suitable for swapping, usually a
high-speed disk or drum.
A-44
GLOSSARY
Switch
1. The part of a file specification which is preceded by a
slash.
2. One of several physical controls on the operator's console.
3. A flag used to control the path of execution within programs.
Symbol
Any identifier used to represent a value that may or may not be
known at the time of its original use in a source language
program. Symbols appear in source language statements as lables,
addresses, operators, and operands.
Symbolic address
An address used to specify a storage location in the context of a
particular program. Symbolic addresses must then be translated
into relocatable (or absolute) addresses by the assembler.
Symbol table
A table containing entries and binary values for each symbol
defined or used within a module. This table generally contains
additional information about the way in which the symbol was
defined in the module.
SYS
A system-wide logical name for the system library. This is the
area where the standard programs of the system are maintained.
SYS search list
The file structure search list for device SYS. This is also used
for several of the ersatz devices because it is a constant,
well-ordered list.
SYSTAT
A program that outputs to the user's terminal status information
on the system as a whole, on selected aspects of the system, or
on a selected job or set of jobs.
A-45
GLOSSARY
Terminal
A device, normally consisting of both a keyboard and printing (or
display) mechanism, that is used to enter information into a
computer and to accept output from a computer. When it is used
as a timesharing terminal, the computer to which it is connected
can be very close or many miles away.
Tick
See Jiffy.
Total user core
The amount of physical core which can be used for locked and
unlocked jobs. This is all of the physical core minus the core
size of the monitor.
Track
The portion of a moving storage medium, such as disk, drum, or
tape, that is accessible to a given reading head position.
Transfer operation
The hardware operation of connecting a channel to a controller
and a controller to a unit for passing data between the memory
and the unit. The transfer operation involves verification,
search, and actual transfer.
Translate
To compile or assemble a source program into a machine language
program, usually in the form of a (relocatable) object module.
Trap
An unprogrammed conditional jump to a known location,
automatically activated by a side effect of executing a processor
instruction. The location from which the jump occurred is then
recorded. It is distinguished from an interrupt which is caused
by an external event.
Trap Servicing Routines
Allow programs to handle errors while a program is running. Some
of the errors that can be handled in this manner are illegal
memory references, and pushdown list overflows.
A-46
GLOSSARY
TSK
The generic device name for the device used to refer to one
program involved in inter-task communication with another
program.
Two's complement
A number used to represent the negative of a given value. This
number is obtained by substituting a zero for each one and a one
for each zero in the bit configuration of the binary number and
adding one to the result.
UFD
1. A file whose entries are the names of files existing in a
given project-programmer number area within a file structure.
2. The top-level directory for each user. Also, the top-level
directory for the ersatz devices which appear as one
directory.
Unconditional transfer
An instruction which transfers control to a specified location.
Unit
The smallest portion of a device that can be positioned
independently from all other units. Several examples of units
are: a disk, a disk pack, and a drum.
Universal Device Index (UDX)
A number used to identify any device on the system. The monitor
assigns the device a UDX when your program issues an IONDX.
monitor call.
Update
To open a file for reading and writing simultaneously on the same
software channel, rewrite one or more blocks in place, and close
the file.
User's program
All of the data and code running in a user virtual address space.
User file directory
See UFD.
A-47
GLOSSARY
User I/O mode
1. The central processor mode that allows a user program to be
run with automatic protection and relocation in effect, as
well as the normal execution of all defined operation codes
(including I/O instructions).
2. The monitor mode which allows a job to run with the I/O mode
hardware on.
User library
Any user file containing one or more relocatable binary modules
of which some or all can be loaded in library search mode.
User mode
A central processor mode during which instructions are executed
normally except for all I/O and HALT instructions, which return
control to the monitor. This makes it possible to prevent the
user from interfering with other users or with the operation of
the monitor. Memory protection and relocation are in effect so
that the user can modify only his area of core.
User virtual address space
A set of memory addresses within the range of 0 to 256K-1 words.
These addresses are mapped into physical core addresses by the
paging or relocation-protection hardware when a program is
executed.
UUO
Refer to programmed operators (Unimplemented User Operations).
Variable
Any entity that can assume any of a given set of values. When
stored in core, a variable can occupy part of a core location,
exactly one core location, or more than one core location.
Vestigial job data area
The first 10 (octal) locations of the high segment used to
contain data for initializing certain locations in the job data
area. These locations are usually 400000-400007 (octal)
inclusive.
A-48
GLOSSARY
Wildcard construction
A technique used to designate a group of files without
enumerating each file separately. The file name, extension, or
project-programmer number in a file specification can be replaced
totally with an asterisk or partially with a question mark to
represent the group of files desired.
Word
An ordered set of bits which occupies one storage location and is
treated by the computer circuits as a unit. The word length of
the DECsystem-10 is 36 bits. This means that it is possible to
store 36 bits of information at each memory address and to
transfer all 36 bits between memory and the CPU at the same time.
Working set
The collection of pages in physical core immediately accessible
to a job. Pages in core, but with the accessiblity bit off are
also included in the working set.
Zero compression
The technique of compressing a core image by eliminating
consecutive blocks of zeros and replacing them with an indication
of the number of words of zeros that were removed.
Zero length module
A module containing symbol definitions but no instruction or data
words (for example, JOBDAT). Note that the word "length" in this
context refers to the program length of the module after loading.
A-49
APPENDIX B
.EXE FILES
An .EXE file consists of a directory page followed by one or more
pages of data.
The data in the directory page consists of a variable number of
chunks. Each chunk starts with a word containing a code in the left
half and a count of the number of words in the chunk in the right
half. The following codes are defined:
1775 .SVSTA Entry vector block.
1776 .SVDIR Directory.
1777 .SVEND End of directory.
B.1 THE DIRECTORY
The directory for an .EXE file starts with a .SVDIR header word and
contains one or more 2-word entries that map the pages of the .EXE
file into a process' address space. This format is represented in the
following diagram.
|=======================================================|
| 1776 | Short Count |
|=======================================================|
.SVFPF |Flags | | Page Number |
|-------------------------------------------------------|
.SVPPC |Repeat Cnt | |Process Page |
|=======================================================|
\ \
. . .
\ \
|=======================================================|
.SVFPF |Flags | | Page Number |
|-------------------------------------------------------|
.SVPPC |Repeat Cnt | |Process Page |
|=======================================================|
B-1
.EXE FILES
The format of each .SVFPF word is as follows:
Bits Symbol Meaning
B0 SV%HIS Page is in high segment.
B1 SV%SHR Page is sharable.
B2 SV%WRT Page is writable.
B3 SV%CON Page is concealed.
B4 SV%SYM Page is part of symbol table.
5-22 Reserved.
23-35 The page number in the .EXE file at which the
page starts.
The format of each .SVPPC word is as follows:
Bits Symbol Meaning
0-8 SV%REP Repeat count (the number of contiguous pages
minus 1 that are described by this entry).
9-22 Reserved.
23-35 SV%PPN The process page number into which the page
should be loaded.
B-2
APPENDIX C
FILE DAEMON
The File Daemon provides extended file protection. The File Daemon
described in this appendix is a prototype that you may use to help you
in understanding the monitor support for this feature. The File
Daemon is supplied only to serve as a prototype for the File Daemon
you may desire at your installation.
Each installation will have varying types of accounting and file
security measures. Therefore, each installation's File Daemon may be
written to account for these differences and varying requirements.
The DIGITAL-supplied, prototype File Daemon supports access lists and
access logging that is performed on a user's or a system
administrator's request.
C.1 USER INTERFACE
The File Daemon allows any user to specify who can and who cannot
access his files. Each user may create a file named ACCESS.USR (which
is described in Section C.3). This file optionally lists the names of
some or all of that user's files and specifies, on an individual file
basis, the users who can and cannot access those files. Under
specific conditions, the File Daemon examines the user's ACCESS.USR
file and may record information, in a separate file called ACCESS.LOG,
regarding specific access requests to the listed files. Note that
ACCESS.USR can be created only by the owner of the particular
directory or by a job logged in under [1,2].
C.2 THE FILE DAEMON
The monitor calls the File Daemon (only if the monitor feature test
switch F%FDAE = -1) each time that someone tries to access a file that
has a 4, 5, 6, or 7 protection code in the owner's protection code
field and the access fails due to a file protection error or due to a
directory protection error.
C-1
FILE DAEMON
For example, if you protect a file against a specific user and that
user attempts to access your file (with a LOOKUP, ENTER, RENAME, or
FILOP. monitor call), the monitor suspends the execution of the
accessing user's program and it sends a message to the File Daemon.
This message includes the type of access the user is attempting and
that user's project-programmer number. The monitor gives control to
the File Daemon, which looks for your file called ACCESS.USR.
ACCESS.USR must be on the same file structure and in the same
directory area as the file being accessed.
After examining ACCESS.USR, the File Daemon returns to the monitor the
highest type of access you have specified that the user attempting
access to your file may have. Then, the File Daemon logs the access
request in ACCESS.LOG (if you set the /LOG switch in your ACCESS.USR
file; refer to Table C-1).
All of this occurs, even when you attempt to access your own files, if
a file has a 4, 5, 6, or 7 protection code in the owner's protection
code field. However, as the file's owner, you can read your file and
change the file's protection code without having the File Daemon
called. Depending on the information you specified in your ACCESS.USR
file, the File Daemon either grants or denies access to the accessing
user.
If the monitor attempts to pass control to the File Daemon, but the
File Daemon is not running, the monitor denies access to the file
unless the program attempting access has full file access rights
([1,2] or JACCT). The same result occurs when one of the following
conditions occurs:
1. The File Daemon cannot find ACCESS.USR in the same path as
the file being accessed.
2. The File Daemon cannot find ACCESS.USR in a higher-level
directory, when it scans up the directory structure.
If the File Daemon finds ACCESS.USR but cannot find the name of the
accessed file in ACCESS.USR, the File Daemon denies file access to the
accessing user. The File Daemon also denies access to the accessing
user if the File Daemon finds he specified filename in ACCESS.USR but
the project-programmer number does not match any of the
project-programmer numbers you have specified that may access your
file.
All files listed in your ACCESS.USR are assumed to be in the same User
File Directory (UFD) as the file named ACCESS.USR. However, if your
ACCESS.USR is in your UFD and it describes the type of accesses to be
allowed to files contained in the SFDs, the accessing user must
specify the full path to the file in the SFD before the File Daemon
will consider the file specification to match.
C-2
FILE DAEMON
The File Daemon treats all file accessors the same. All accesses to a
file having a 4, 5, 6, or 7 protection code in the owner's protection
code field cause the File Daemon to be called when a protection error
results. The File Daemon is always called when a protection error
occurs as a result of the directory protection code. Because of this
equal treatment, you should not do the following:
1. If a [1,2] job attempts to access a file that is protected
such that the File Daemon is called, that job may be denied
access to the file. This is a possible problem, for example,
if the [1,2] job is BACKUP and you have denied (either
implicitly or explicitly) these programs access to your
files. When you do this, your file will not be backed up on
magnetic tape. Therefore, you must accept the responsibility
of backing up your own files.
2. In general, full file access programs will not be allowed to
read your files. Therefore, under most circumstances, QUEUE
would not be allowed to queue a file that was protected such
that the File Daemon was called.
3. If the file's owner protection code field is such that the
File Daemon is called and the owner has neglected to include
his own project-programmer number in ACCESS.USR for this
file, the File Daemon grants the owner the same type of
access as if a 7 were in the owner's protection code field
(that is, the owner can only read the file or change the
file's protection code.)
4. ACCESS.USR files may be restored at arbitrary times.
Therefore, operators should not perform a full restore of the
disk using BACKUP when the File Daemon is running. If such a
full restore is done, the action may not allow BACKUP to
restore files that ACCESS.USR allows them to BACKUP.
5. The CHKACC monitor call tells a program what a user's file
access privileges are. Therefore, by using CHKACC, a program
can tell if the File Daemon will be called, but it will not
know the access privileges returned by the File Daemon.
C-3
FILE DAEMON
C.3 ACCESS.USR
Every user can create his own ACCESS.USR file. Note that ACCESS.USR
files can be created only by the owner of the specific directory or a
[1,2] job. ACCESS.USR is made up of one or more 'command lines'. You
must write each command line in the following format:
file-spec/switches=[ppn]/switches,...,[ppn]/switches
The file-spec is a full file specification (that is, device:
filename.extension [path]). The File Daemon scans each line in
ACCESS.USR until it matches a file specification on the left of the
equal sign and a project-programmer number on the right. All access
rights will then be determined by that line (there will be no
continued scan). The user should minimally specify one of the
switches synonymous with protection codes (such as, READ, EXECUTE,
ALL,...) for that file specification; refer to Table C-1. If you do
not specify a switch, a default of /NONE is provided. The possible
switches are listed in Table C-1.
C-4
FILE DAEMON
Table C-1: ACCESS.USR Switches
Switch Meaning
/LOG This switch causes the File Daemon to log any
/NOLOG access attempt in the file named ACCESS.LOG. If
you specify this switch, the File Daemon appends
a LOG entry to the end of ACCESS.LOG, which is
found in the same directory as your ACCESS.USR.
The log entry includes the following:
o the date of the access
o the time of the access
o the job number of the accessing job
o the project-programmer number and name
associated with the accessing job
o the name of the accessing program
o the type of access attempted
o the full file specification of the access
file
o the access permitted, detailing whether
access was permitted to the file
If you also specify the /EXIT or /CLOSE switch,
the File Daemon includes the following
information in the LOG entry (both the initial
entry and when the file is closed:
o the accessing job's run time
o kilo-core-seconds
o disk reads
o disk writes
If the File Daemon cannot find ACCESS.LOG in
your area, it creates one, giving it the same
protection code as your ACCESS.USR. Note that
the File Daemon can always access ACCESS.USR and
ACCESS.LOG.
C-5
FILE DAEMON
Table C-1: ACCESS.USR Switches (Cont.)
Switch Meaning
/LOG:n This switch allows the File Daemon to log access
attempts based on the switch value. The
following are the legal switch values:
ALL Log all accesses attempted
(same as /LOG).
NONE Do not log any accesses (same
as /NOLOG).
SUCCESSES Log only those accesses that
were permitted.
FAILURES Log only those accesses that
were not permitted.
/CLOSE If you specify the /LOG switch and the /CLOSE
/NOCLOSE switch, the File Daemon makes the log entry when
the file is closed.
/EXIT If the accessing program is executing and you
/NOEXIT have specified the /LOG and /EXIT switches, the
File Daemon makes the log entry when the program
has finished execution.
/CREATE This switch allows a user who would ordinarily
/NOCREATE not be allowed to create files in your directory
to do so. This switch is used in conjunction
with one of the ACCESS.USR switches that are
synonymous with protection codes (such as
/RENAME). This switch can appear on either side
of the equal sign. An example of a command line
with the /CREATE switch is as follows:
WONDER.TST=[10,3333]/CREATE/NONE
This command line allows any user to create a
file called WONDER.TST in your directory, but
none of these users may have any other access to
that file.
Another example is
WOND.TST=[10,10]/CREATE/READ,[*,*]/NONE
This command line prevents all users from
accessing the file WOND.TST, but allows user
[10,10] to create a file called WOND.TST.
C-6
FILE DAEMON
Table C-1: ACCESS.USR Switches (Cont.)
Switch Meaning
/PROT:nnn This switch specifies the protection code with
which a file will be created. This switch is
allowed only on the left side of the equal sign.
The value nnn must be an octal number in the
range 0-777. The file is created with the
specified protection code if the following
conditions occur:
1. You specify the /PROTECTION switch.
2. The File Daemon is called because a user
attempted to create a file in a directory
protected against that user.
3. The File Daemon allows the user to create
the file (determined by the contents of
ACCESS.USR).
/PROG:file This switch allows the specified program to have
the desired type of access to the file. This
switch can appear only on the right side of the
equal sign in the command line. For example:
ONE.TST/READ=[10,10],[10,65]/WRITE,[1,2]-
#/PROGRAM:SYS:BACKUP
This command line specifies that [10,10] jobs
can read ONE.TST, and [10,65] jobs can read and
write ONE.TST, a job logged in under [1,2]
running BACKUP can read the file. No one else
can access ONE.TST.
You may omit the device specification or you may
specify DSK: or ALL: in the filespec argument
to the /PROGRAM switch. However, this is not a
recommended procedure because there may be
potential security violations. The File Daemon
has no knowledge of your search list; therefore,
the File Daemon treats DSK: identically to
ALL:. It is recommended that the device name be
either a file structure name or an ersatz device
name (LIB: is not allowed, however).
C-7
FILE DAEMON
Table C-1: ACCESS.USR Switches (Cont.)
Switch Meaning
/XONLY This switch, when it appears in conjunction with
the PROGRAM switch, considers the specified
program to match the program doing the
accessing, only if the accessing program is
Execute-only.
/ALL This switch specifies that ALL access to the
file is allowed. Specified accessors of this
file can change the protection code for the
file, rename, write, execute, update, and append
to the file. (This is equal to protection code
0.)
/RENAME This switch specifies that rename access is
allowed. Specified accessors of this file can
rename, execute, write, read, update, or append
to the file. (This is equal to protection code
1.)
/WRITE This switch specifies that write access is
allowed. Desired accessors of this file can
write, read, execute, update, and append to the
file. (This is the same as protection code 2.)
/UPDATE This switch specifies that update access is
allowed. Specified accessors of the file can
update, append, read, and execute the file.
(This is equal to protection code 3.)
/APPEND This switch specifies that append access is
allowed. Specified accessors of this file can
append, read, or execute the file. (This is the
same as protection code 4.)
/READ This switch specifies that read access is
allowed. Specified accessors of this file can
read or execute the file. (This is the same as
protection code 5.)
/EXECUTE This switch specifies that execute access is
allowed. Specified accessors of this file can
only execute the file. (This is the same as
protection code 6.)
/NONE This switch specifies that no access is allowed
to the file. (This is the same as protection
code 7.)
C-8
FILE DAEMON
You create an ACCESS.USR file to specify for each file which
project-programmer numbers can access the file and what type of access
those accessors can have. The switches indicate the type of access
allowed.
Switches appearing on the left side of the equal sign affect all
project-programmer numbers appearing on the right side of the equal
sign. However, with the exception of the /PROTECTION switch, the
switch on the left side can be overridden for one or more
project-programmer numbers specified on the right side of the equal
sign. You can override the switches by explicitly specifying another
switch. For example, if the following line appeared in your
ACCESS.USR file:
TST.TST/ALL=[10,*],[11,*],[27,*],[17,*]/NONE
The File Daemon would allow all members of projects 10, 11, and 27
complete access to the file TST.TST. However, the File Daemon would
not allow members of project 17 to access TST.TST. For
project-programmer numbers other than 10, 11, 27, 17, the File Daemon
will search for a later TST.TST that contains the accessing job's
project-programmer number. If no match is found, the File Daemon
denies the accessing user's request.
Full wildcard specifications are allowed both on the left and right
sides of the equal sign. Comments and continuation lines are allowed
in ACCESS.USR. A comment must begin with a semicolon or an
exclamation point. A continuation line is indicated by inserting a
hyphen (minus sign) immediately proceeding the carriage return that
terminates a line. If there is a syntax error in a line in
ACCESS.USR, the File Daemon ignores that line. You should insure the
accuracy of your own ACCESS.USR files by proofing carefully. If the
following line were in your ACCESS.USR file:
FOO.BAR+[*,*]
The File Daemon would ignore the line because a + sign appears where
an = sign should appear. The File Daemon would deny access to all
users desiring access to FOO.BAR, since the File Daemon denies access
to all files whose names do not appear in ACCESS.USR. Since the File
Daemon ignores the line, it does not know that FOO.BAR is listed in
the file.
The following is an example of an ACCESS.USR file that uses most of
the features of the File Daemon.
Directory user = [13,675]
Directory protection = <700>
C-9
FILE DAEMON
File Protection
ACCESS.USR <777>
ACCESS.LOG <777>
F1.TST <077> File Daemon will not be called.
F2.TST <457> Project members may READ, otherwise
call File Daemon.
F3.TST <477> Only owner may access without File
Daemon.
F4.TST <777> Call File Daemon on all accesses.
ACCESS.USR
ACCESS.*/NONE=[*,*] ;No one can touch ACCESS.USR and
ACCESS.LOG including [1,2] and
JACCT users. Note that these files
cannot be backed up if the File
Daemon is running.
ALL:*.*/READ/LOG=[1,2]/PROGRAM:SYS:BACKUP/XONLY
;Allow access from BACKUP (from
SYS, execute only, and running
under [1,2] to read the file and to
make LOG entry.
F?.TST/LOG=[10,11]/NONE,[10,*]/EXECUTE/EXIT
;Log all access attempts. No
access allowed to [10,11], but
other project members [10,*] can
execute the file. Log entries are
made when the accessing program
exits.
*.*/CREATE/PROTECTION:055=[12,21]/ALL,[12,17]
;[12,21] has privileges for all
files (except ACCESS.*) and may
create files that have a protection
of 055. [12,17] cannot access any
file (/NONE is a default) but may
create files. No log entries will
be made.
*.*/CREATE/PROTECTION:777/LOG=[123,456]/NONE
;[123,456] may create files at will
but may not access them (such as a
student turning in homework).
C-10
FILE DAEMON
File Protection
*.*[13,675,A]/ALL/PROTECTION:057/CREATE=[1,2]/LOG
;[1/2] has all privileges in this
SFD and may create files with a
protection code of 057.
[13,675].UFD/LOG/READ=[*,*] ;Anyone may read this directory as
a file.
F3.TST/LOG=[12,3]/EXECUTE
*.*/LOG=[12,3]/NONE ;[12,3] can only execute F3.TST.
*.*=[*,*]/NONE ;No other access is granted and no
LOG entry is made.
Note that entries are scanned from left to right and top to bottom.
The scan stops on the first match of a file name on the left side of
the equal sign and a project-programmer number on the right side of
the equal sign.
When you create your ACCESS.USR file, you should take care to see that
a wild card specification will not match in a line earlier than a
specific specification in a later line. As a general rule, place
specific statements first in the ACCESS.USR file, followed by more
general "catch all" statements. If you want to log entries, you must
use the /LOG switch (and any of the other switches) on every line for
which that switch applies.
C.4 MONITOR INTERFACE TO A FILE DAEMON
A File Daemon is a privileged program that can be used for the
following purposes:
1. overseeing file accesses
2. aiding in proprietary billing
3. tracking program usage
The interface between the monitor and the File Daemon that is
described in this section is supplied and supported by Digital.
There is a privileged program called the File Daemon. Digital
supplies one unsupported version of a File Daemon, which is described
in the preceding sections of this appendix. But, each installation
should write its own File Daemon, because each installation will vary
on its requirements for such a program.
C-11
FILE DAEMON
When a File Daemon is running, the monitor calls it every time someone
tries to access a file or a directory that has a 4, 5, 6, or 7 code in
the owner's protection code field and the access fails due to a
protection error. So that the monitor knows there is a File Daemon,
the following must occur:
1. The feature test switch F%FDAE must be set to -1, to enable
the condition.
2. The program that will be the File Daemon must be privileged
(that is, it must be running under [1,2] or running with the
JACCT bit set).
3. This program must send an IPCF request to [SYSTEM] IPCC (code
6, .IPCSC) requesting a special PID.
4. This program must then send a request to [SYSTEM]IPCC
specifying code 24 (.IPCWP). This code requests that the
File Daemon's PID be entered in the Special PID table.
After each request to [SYSTEM]IPCC, the File Daemon receives
verification that the function occurred. After the verification
resulting from the File Daemon specifying code 24, the monitor sends
an IPCF packet to the File Daemon each time that a protection failure
occurs on a file or a directory.
The message portion of the IPCF packet that the monitor sends to the
File Daemon when a protection failure occurs has the following format:
| +---------------------------------------------------------------------+
| | Type of access | Code |
| |---------------------------------------------------------------------|
| | File structure name |
| |---------------------------------------------------------------------|
| | File name |
| |---------------------------------------------------------------------|
| | File name extension |
| |---------------------------------------------------------------------|
| | Project number | Programmer number |
| |---------------------------------------------------------------------|
| | Sub-file directory 1 or 0 |
| |---------------------------------------------------------------------|
| | Sub-file directory 2 or 0 |
| |---------------------------------------------------------------------|
| | Sub-file directory 3 or 0 |
| |---------------------------------------------------------------------|
| | Sub-file directory 4 or 0 |
| |---------------------------------------------------------------------|
| | Sub-file directory 5 or 0 |
| +---------------------------------------------------------------------+
C-12
FILE DAEMON
Where: type of access is the type of access being attempted to the
file. The Access Type Codes are listed in Table C-2.
code is a File Daemon Code, all of which are listed in Table
C-3.
The remaining words in the IPCF packet message are the full file
specification for the file being accessed.
Table C-2: Access Codes
| +------------------------------------------------+
| | Code | Symbol | Meaning |
| +-------+------------+---------------------------+
| | 0 | FNCNAA | No access is allowed. |
| |------------------------------------------------|
| | 1 | FNCEXE | Execute. |
| |------------------------------------------------|
| | 2 | FNCRED | Read. |
| |------------------------------------------------|
| | 3 | FNCALL | Allocate. |
| |------------------------------------------------|
| | 4 | FNCDLL | Deallocate. |
| |------------------------------------------------|
| | 5 | FNCAPP | Append. |
| |------------------------------------------------|
| | 6 | FNCUPD | Update. |
| |------------------------------------------------|
| | 7 | FNCCRE | Create. |
| |------------------------------------------------|
| | 10 | FNCSUP | Supersede. |
| |------------------------------------------------|
| | 11 | FNCTRN | Truncate. |
| |------------------------------------------------|
| | 12 | FNCCAT | Change attributes. |
| |------------------------------------------------|
| | 13 | FNCDEL | Delete. |
| |------------------------------------------------|
| | 14 | FNCCNM | Change name. |
| |------------------------------------------------|
| | 15 | FNCCPR | Change protection. |
| +------------------------------------------------+
C-13
FILE DAEMON
Table C-3: File Daemon Codes
Code Mnemonic Meaning
1 .FLDCA This code is set when the accessing program
has performed a LOOKUP, ENTER, RENAME, or
FILOP monitor call and a protection failure
occurred.
2 .FLDIC This code is set as a result of a previous
call to the File Daemon, the File Daemon
requested that it be called when the program
issues a CLOSE. This code is set as the
result of the program issuing an input
CLOSE. Refer to Table C-4, flag bit 1.
3 .FLDOC As a result of a previous call to the File
Daemon, the File Daemon requested that it be
called when the program issues a CLOSE.
This code is set as the result of the
program issuing an output CLOSE. Refer to
Table C-4, flag bit 1.
4 .FLDXT This code is set as a result of a previous
call to the File Daemon, which occurred
because a job tried to issue a R, RUN, or
GET command or a RUN monitor call and a
protection error resulted. The File Daemon
requested that the monitor call it when the
accessing program terminates execution. The
termination of a program's execution is
defined by the terminal user or by the batch
.CTL file, either of which may type
something that logically supersedes the core
image. The program may also terminate its
own execution by performing a RUN monitor
call. Refer to Table C-4, flag bit 2.
5 .FLDPG This code is set because a job tried to
execute a protected program by issuing a R,
RUN, or GET command or a RUN monitor call.
6 .FLDDA This code is set because a directory
protection failure occurred.
7 .FLDPS This code is set when a PUSH occurs from a
program that has /EXIT specified.
|
| 10 .FLDPR This code is set when a suspended program
| (with /EXIT) resumes with a POP.
C-14
FILE DAEMON
The File Daemon responds to the monitor by sending the monitor an IPCF
packet. The packet's message is in the following format:
|
| +---------------------------------------------------------+
| | reserved | reserved | job number |
| |---------------------------------------------------------|
| | flags | 0 | create | access |
| +---------------------------------------------------------+
| 0-----3 4---8 9-------17 18-------27 28----------35
Where:
job number is the number of the job attempting to access a file.
flags are bits 0 through 3 which are described in Table C-4.
create is the protection code at which the file will be created
if the specified job is creating a file.
access is the highest access this job is allowed to this file.
Refer to Table C-3.
The monitor grants or denies the job's access to the file based on the
access value and the type of access specified by the accessing job.
If the access value in the packet from the File Daemon to the monitor
is greater than or equal to the type of access the accessing job
desired, the monitor grants the job access to the file.
C-15
FILE DAEMON
Table C-4: File Daemon Flags
| +----------------------------------------------------------------+
| | Code | Symbol | Meaning |
| +-----------+----------+-----------------------------------------+
| | 0 | FL.DAA | The monitor is to call the File Daemon |
| | | | every time this file is accessed. |
| | | | For example, if this bit is not set |
| | | | and the program did a RENAME before a |
| | | | LOOKUP, the File Daemon would get |
| | | | called only on the LOOKUP. |
| |----------------------------------------------------------------|
| | 1 | FL.DCL | The File Daemon is called when the file |
| | | | is CLOSED. |
| |----------------------------------------------------------------|
| | 2 | FL.DXT | The File Daemon is called when this |
| | | | program terminates execution. |
| |----------------------------------------------------------------|
| | 3 | FL.DSP | If the program is attempting to create |
| | | | a file and this bit is set, the monitor |
| | | | assumes that the protection code for |
| | | | the file is in bits 9 through 17 of |
| | | | this word. |
| |----------------------------------------------------------------|
| | 777B17 | FL.DPT | Protection code supplied by File Daemon.|
| |----------------------------------------------------------------|
| | 777777B35 | FL.DHA | Highest access allowed. |
| +----------------------------------------------------------------+
C-16
INDEX
Access types, 22-331 Channels
Access-allowed bit, 22-330 closing, 22-27
Accessing files, 22-23 extended, 22-159
ACCLG. UUO, 22-3 initializing, 22-312
Account strings, 22-5 releasing, 22-398
ACCT. UUO, 22-5 resetting, 22-405
Accumulators, 22-2 Character mode, 22-447
Active swapping list, 22-90 input, 22-197
Address break condition, 22-439 Characteristics of disk devices,
ANF-10 22-100
intertask communication, 22-513 Checking
nodes, 22-297 file access, 22-22
Appending to files, 22-163 PPNs, 22-320
APRENB UUO, 22-7 Checkpointing files, 22-163
Assigning CHGPPN UUO, 22-21
logical names, 22-65 CHKACC UUO, 22-22
reel identifiers, 22-270 Clearing
ATTACH UUO, 22-10 DECtape directories, 22-167
Auto-CRLF, 22-508 DTEs, 22-108
Auto-reload DX20s, 22-82 DVCMDA, 22-68
I/O status bits, 22-32
Backspacing magtape logical names, 22-65
files, 22-275 terminal input buffer, 22-30
records, 22-277 terminal output buffer, 22-31
BATMAX, 22-3 CLOSE bits, 22-28
setting, 22-437 CLOSE UUO, 22-27
BATMIN, 22-437 Closing files, 22-163
Blank tape, 22-274 CLRBFI UUO, 22-30
Block pointer positioning, 22-475 CLRBFO UUO, 22-31
Break characters, 22-501 CLRST. UUO, 22-32
Breakpointing the monitor, 22-450 CMAND. UUO, 22-34
Buffer rings CNECT. UUO, 22-39
control block, 22-293 Command list creation, 22-34
for input, 22-195 Commands
for output, 22-323 defining, 22-34
recycling, 22-160 forcing, 22-171
Buffers, 22-74 Communicating with system
programs, 22-375
Cache bit, 22-332, 22-444 Completing magtape I/O, 22-292
CAL11. UUO, 22-16 Concealed high segment, 22-178
CALLI UUO, 22-13 Condition codes, 22-366
Cancelling enqueued requests, CONFIG. program, 22-391
22-59 Connecting MPX devices, 22-39
Capability bits, 22-443, 23-144 Contracting core, 22-41
Changing Controller numbers, 22-81
accounting strings, 22-5 Controller types
file attributes, 22-401 for disk, 22-106
high segments, 22-177 for magtape, 22-482
Index-1
memory space, 22-41 Controlling job number, 22-44
PPNs, 22-21 Controlling PSI interrupts,
search lists, 22-462 22-365
Index-2
CORE UUO, 22-41 UUO, 22-59
CORMAX, 22-434 Dequeuing enqueued requests,
CORMIN, 22-434 22-59
CPU diagnostics, 22-81 Destroying pages, 22-329
Creating Detaching terminals, 22-11
command lists, 22-34 DEVCHR UUO, 22-62
.EXE files, 22-414 Device
files, 22-136, 22-162 characteristics, 22-78
pages, 22-329 reading, 22-62
Cross-job interrupts, 22-360 diagnostics, 22-81
CTLJOB UUO, 22-44 error status, 22-70
CTX. UUO, 22-45 initialization, 22-312
node numbers, 22-532
DAEFIN UUO, 22-50 types, 22-79
DAEMON program, 22-142 Device interrupt codes, 22-368
invoking, 22-51 Device names
requesting, 22-50 physical, 22-115
DAEMON UUO, 22-51 reading, 22-66
DAP messages, 22-517 Device status, 22-76
Data base, 22-135 on MPX devices, 22-140
Data mode specification, 22-316 Devices
Data output, 22-321 realtime, 22-408
Dataset lines, 22-499 reassigning, 22-389
DATE UUO, 22-57 removing restrictions, 22-118
DDBs, 22-76 restricting, 22-117
DDT DEVLNM UUO, 22-65
addresses, 22-430 DEVNAM UUO, 22-66
breakpoints, 22-444 DEVOP. UUO, 22-67
Deassigning devices, 22-389 DEVPPN UUO, 22-73
DEBRK. UUO, 22-58 DEVSIZ UUO, 22-74
Debugging DEVSTS UUO, 22-76
flags, 23-24 DEVTYP UUO, 22-78
front ends, 22-16 DIAG. UUO, 22-81
DECnet, 22-93 Diagnostics, 22-81
link status, 22-96 Directory path, 22-337
DECnet-10 Disabling auto-reload of DX20s,
intertask communication, 22-305 22-82
network management, 22-308 Disconnecting MPX devices, 22-39
DECtape Disk
blocks, 22-520 cache, 22-444
LOOKUPs, 22-264 characteristics, 22-100
on extended channels, 22-167 compatibility, 22-86
DECtape directories controller types, 22-106
clearing, 22-527 I/O priority, 22-86
Deferred spooling, 22-441 mount count, 22-101
Defining names, 22-477
commands, 22-34 unit types, 22-106
symbols, 22-2 DISK. UUO, 22-85
Deleting Dismissing
commands, 22-36 interrupts, 22-58
files, 22-165 realtime interrupts, 22-521
Density codes for magtape, 22-481 DNET. UUO, 22-93
Index-3
Depositing to front ends, 22-18 Dormant programs, 22-449
DEQ. DSKCHR UUO, 22-100
error codes, 22-128 DTE
Index-4
protocol type, 22-112 File
status, 22-109 input, 22-264
DTE. UUO, 22-108 operations, 22-158
DVCMDA, 22-68 protection, C-1
DVPHY. UUO, 22-115 File access
DVRST. UUO, 22-117 checking, 22-22
DVURS. UUO, 22-118 simultaneous, 22-169
DX20 auto-reload, 22-82 File specifications, 22-167
File structures, 22-462
EDDT breakpoints, 22-444 Files
Enabling creating, 22-136, 22-162
auto-reload of DX20s, 22-82 merging, 22-266
dataset lines, 22-499 FILOP.
traps, 22-7 error codes (see Chapter 11)
Ending I/O, 22-27 UUO, 22-158
ENQ. Forcing commands, 22-171
data base, 22-135 FRCUUO, 22-171
error codes, 22-128 Free CRLF, 22-505
quotas, 22-134 Free space in UFDs, 22-92
UUO, 22-119 Front end
ENQC. testing, 22-16
error codes, 22-128 types, 22-19
UUO, 22-132
ENTER GALAXY requests, 22-375
error codes (see Chapter 11) GETLCH UUO, 22-173
UUO, 22-136 GETLIN UUO, 22-175
EOF mark, 22-283 GETPPN UUO, 22-176
EOT mark, 22-284 GETSEG
ERLST. UUO, 22-140 error codes (see Chapter 11)
Error file UUO, 22-177
entries, 22-53 GETSTS UUO, 22-180
logging, 22-142 GETTAB UUO, 22-182
ERRPT. UUO, 22-142 GOBSTR UUO, 22-183
Ersatz devices, 22-73 GTNTN. UUO, 22-186
Eternal locks, 22-122 GTXTN. UUO, 22-188
Ethernet protocols, 22-144 Guideline, 22-439
Examining GVPL, 22-438
front ends, 22-18
monitor, 22-458 Header block for ENQ., 22-119
Exchanging pages, 22-329 HIBER UUO, 22-189
Execute-only Hibernating jobs, 22-531
bit, 23-9 High priority scheduler queue,
segment, 22-178 22-192
Execution High segment origin, 22-399
suspending, 22-189 High segments
terminating, 22-156 changing, 22-177
EXIT UUO, 22-156 write protection, 22-446
Expanding core, 22-41 Host system, 22-441
Extended channels, 22-159 HPQ UUO, 22-192
for DECtape, 22-167
for magtape, 22-167
I/O
Index-5
FCFS blocks, 22-101 error status, 22-70
Feature test flags, 23-23 MPX status, 22-140
FILDAE, 22-22 terminating, 22-27
Index-6
I/O status bits, 22-180, 22-312, Kilo-core ticks, 23-14
22-428, 22-433 KL error
clearing, 22-32 chunks, 22-111
Implied PPNs, 22-341 timer, 22-111
IN UUO, 22-193 KMC-11, 22-230
In-behalf-of PPN, 22-161 KSYS, 22-436
In-your-behalf function, 22-22
INBUF UUO, 22-195 Limit, 22-439
INCHRS UUO, 22-197 Line characteristics, 22-173
INCHRW UUO, 22-198 Line mode input, 22-199
INCHSL UUO, 22-199 Line printer characteristics,
INCHWL UUO, 22-200 22-69
Incrementing LOGNUM, 22-3 Link status
Initializing ANF-10, 22-514
devices, 22-312 reading, 22-96
magtape channels, 22-282, Listing
22-285 ANF-10 nodes, 22-301
programs, 22-406 commands, 22-36
PSI system, 22-357 DECnet nodes, 22-94
Input buffer rings, 22-195 devices, 22-115
INPUT UUO, 22-202 Loading
Interrupt codes, 22-368 RAM, 22-68
Interrupt control block, 22-355 VFU, 22-68
Interrupting jobs, 22-360 LOCATE UUO, 22-255
Intertask communication Lock
ANF-10, 22-513 block, 22-121
DECnet-10, 22-305 status, 22-132
Invoking DAEMON, 22-51 LOCK UUO, 22-257
IONDX. UUO, 22-204 Lock-associated data block,
IONEOU UUO, 22-205 22-126
IPCFQ. Locking jobs, 22-257
error codes, 22-211, 22-214 Logging errors, 22-142
UUO, 22-210 Logical name assignment, 22-65
IPCFR. Logical node number, 22-255
error codes, 22-214 LOGIN UUO, 22-262
UUO, 22-212 LOGMAX, 22-3
IPCFS. setting, 22-437
error codes, 22-214 LOGNUM, 22-3
UUO, 22-219 LOGOUT UUO, 22-263
Long-term locks, 22-122
JBSET. UUO, 22-221 LOOKUP
Job error codes (see Chapter 11)
capability word, 23-144 UUO, 22-264
number, 22-372
privilege word, 23-15 Magtape
resetting, 22-156 controllers, 22-482
Job contexts, 22-45 densities, 22-481
Job search list, 22-225 drive status, 22-278
reading, 22-183 functions, 22-272
Job status word, 23-9 labels, 22-485
JOBPEK UUO, 22-222 operations, 22-479
JOBSTR UUO, 22-225 reel identifiers, 22-270
Index-7
JOBSTS UUO, 22-227 Magtapes on extended channels,
22-167
KDP. UUO, 22-230 Mapping
Index-8
pages, 22-333 Opening files, 22-162
segments, 22-399 OTHUSR UUO, 22-320
Master DTE number, 22-109 OUT UUO, 22-321
MDA OUTBUF UUO, 22-323
setting control, 22-68 OUTCHR UUO, 22-324
wait, 22-91 Output buffer rings, 22-323
Measuring performance, 22-350 OUTPUT UUO, 22-325
Memory space, 22-41 OUTSTR UUO, 22-326
MERGE. Owner PPN, 22-102
error codes (see Chapter 11)
UUO, 22-266 Packet header block, 22-213
MIC status bits, 22-500 PAGE. UUO, 22-327
Monitor Partitioned resources, 22-126
breakpoints, 22-450 PATH.
checksum, 22-451 block, 22-346
MONRT. UUO, 22-157, 22-268 UUO, 22-337
Mount count Pathological names, 22-337
for disk, 22-101 PC flags, 22-356
Moving pages, 22-329 PDB, 23-154
MPX devices PDP-11 compatibility
connecting, 22-39 for disks, 22-86
status, 22-140 PEEK UUO, 22-349
MSTIME UUO, 22-269 PERF. UUO, 22-350
MTAID. UUO, 22-270 Performing measurements, 22-350
MTAPE UUO, 22-272 Physical
MTBLK. UUO, 22-274 device names, 22-115
MTBSF. UUO, 22-275 unit names, 22-477
MTBSR. UUO, 22-277 PIBLK. UUO, 22-355
MTCHR. UUO, 22-278 PIFLG. UUO, 22-356
MTDEC. UUO, 22-282 PIINI. UUO, 22-357
MTEOF. UUO, 22-283 PIJBI. UUO, 22-360
MTEOT. UUO, 22-284 PIRST. UUO, 22-362
MTIND. UUO, 22-285 PISAV. UUO, 22-363
MTLTH. UUO, 22-286 PISYS. UUO, 22-365
MTREW. UUO, 22-287 PITMR. UUO, 22-370
MTSKF. UUO, 22-288 PJOB UUO, 22-372
MTSKR. UUO, 22-289 POKE. UUO, 22-373
MTUNL. UUO, 22-290 Pooled ENQ. resources, 22-125
MTWAT. UUO, 22-292 Positioning block pointers,
Multi-plexed devices, 22-39, 22-475
22-140 PPNs
MVHDR. UUO, 22-293 changing, 22-21
checking, 22-320
NDB, 23-152 for disk devices, 22-73
Network information, 22-93 implied, 22-341
/NEW searching, 22-73 owner, 22-102
NODE. UUO, 22-297 reading, 22-176
Non-blocking ENQ. requests, Preallocating space, 22-165
22-127 Primary protocol for DTEs, 22-108
Non-I/O interrupt codes, 22-366 Privilege bits, 23-15
NSP. UUO, 22-305 Privileges
NTMAN. UUO, 22-308 setting, 22-443
Index-9
NUL device, 22-64 Program execution, 22-530
Programs
OPEN UUO, 22-312 name, 22-432
Index-10
stopping, 22-156 error codes (see Chapter 11)
Protecting UUO, 22-401
files, C-1 Renaming files, 22-164
high segments, 22-446 Requesting
Pseudo-terminals, 22-44 ENQ. resources, 22-127
PSI interrupts controlling, resources, 22-119
22-365 RESCAN UUO, 22-404
PSI state RESDV. UUO, 22-405
restoring, 22-362 RESET UUO, 22-406
saving, 22-363 Resetting jobs, 22-156
PTYs, 22-44 Resources
releasing, 22-59
Quantum requeue response, 23-76 requesting, 22-119
Querying IPCF input queue, 22-210 Responses, 23-75
QUEUE. UUO, 22-375 Restoring PSI state, 22-362
Restricting devices, 22-117
RAM loading, 22-68 Rewinding magtape, 22-287
Reading Rewriting RIBs, 22-166
account strings, 22-5 ROM word, 22-109
data, 22-193 RTTRP UUO, 22-408
date, 22-57 RUN
device characteristics, 22-62 error codes (see Chapter 11)
device names, 22-66 UUO, 22-410
ENQ. quotas, 22-134 RUNTIM UUO, 22-413
file specifications, 22-167
files, 22-165, 22-264 SAVE. UUO, 22-414
GETTAB tables, 22-182 Saving PSI state, 22-363
I/O status, 22-428 SCHED. UUO, 22-416
I/O status bits, 22-180 Scheduler queue, 22-192
IPCF packets, 22-212 Search lists, 22-340
job search lists, 22-183, changing, 22-462
22-225 Secondary bootstrap, 22-113
lock status, 22-132 22-sector mode, 22-86
monitor locations, 22-349 Segments, 22-522
physical unit numbers, 22-81 Sending
PPNs, 22-73, 22-176 characters, 22-324
runtimes, 22-413 data, 22-325
terminal input, 22-197 IPCF packets, 22-219
terminal line characteristics, strings, 22-326
22-173 SENSE. UUO, 22-428
terminal names, 22-175 SET WATCH bits, 22-435
time, 22-269 SETDDT UUO, 22-430
Realtime SETLCH UUO, 22-431
interrupt facility, 22-408 SETNAM UUO, 22-432
interrupts, 22-521 SETSTS UUO, 22-433
traps, 22-512 Setting
REASSI UUO, 22-389 controllers off-line, 22-88
RECON. UUO, 22-391 controllers on-line, 22-89
Recycling buffer rings, 22-160 disk I/O priority, 22-86
Reel identifiers, 22-270 DVCMDA, 22-68
RELEAS UUO, 22-398 ENQ. quotas, 22-134
Relinquishing requests, 22-59 I/O status bits, 22-32
Index-11
Reload ROM word, 22-109 .JBDDT, 22-430
REMAP UUO, 22-399 job parameters, 22-221
RENAME terminal speed rate, 22-507
Index-12
SETUUO UUO, 22-434 Tasks, 22-513
SETUWP UUO, 22-446 Temporary files, 22-492
Sharable resources, 22-121 Terminal
Sharer group, 22-126 operations, 22-497
Simultaneous file access, 22-169 speeds, 22-507
Skipping status, 22-227
magtape files, 22-288 UDX, 22-495
magtape records, 22-289 Terminal break character sets,
on input, 22-447, 22-448 22-501
SKPINC UUO, 22-447 Terminal input
SKPINL UUO, 22-448 buffer, 22-30
SLEEP UUO, 22-449 rescanning, 22-404
Sleeping, 22-51 Terminal line
SNOOP. UUO, 22-450 characteristics, 22-173, 22-431
Software disk cache, 22-444 numbers, 22-186
Specifying Terminal names, 22-188
data mode, 22-316 reading, 22-175
ENQ. resources, 22-124 Terminal output buffer, 22-31
Spooled files, 22-455 Terminals, 22-10
Spooling Terminating
deferred, 22-441 data transmission, 22-27
Spooling bits, 22-435 execution, 22-156
SPPRM. UUO, 22-455 Testing
SPY UUO, 22-458 clear bits, 22-461
STATO UUO, 22-460 front ends, 22-16
Status set bits, 22-460
DECnet links, 22-96 Timed interrupts, 22-370
I/O, 22-312, 22-428, 22-433 TIMER UUO, 22-491
MIC, 22-500 TMPCOR UUO, 22-492
of DTEs, 22-109 Trap
STATZ UUO, 22-461 conditions, 22-7
Stopping programs, 22-156 instructions, 22-528
Structure parameter block, 22-465 Traps
STRUUO UUO, 22-462 enabling, 22-7
Subjobs, 22-44 virtual time, 22-439
Super-mode TRMNO. UUO, 22-495
input, 22-523 TRMOP. UUO, 22-497
output, 22-525 TRPSET UUO, 22-512
Super-USETI/USETO, 22-475 TSK. UUO, 22-513
Superseding files, 22-136 TTCALL UUO, 22-519
SUSET. UUO, 22-475 Types of devices, 22-79
Suspending execution, 22-189
Swapping pages, 22-328 UFD
Symbolic definition, 22-2 compression, 22-89
SYSPHY UUO, 22-477 quota, 22-101
SYSSTR UUO, 22-478 UGETF, 22-520
System UJEN UUO, 22-521
date, 22-436 Unit numbers, 22-81
dump list, 22-91 Unit parameter block, 22-467
file structures, 22-478 Unit types, 22-106
scheduling, 22-416 Universal Device Index, 22-204
time, 22-434 Unloading
Index-13
disk, 22-87
Tape labels, 22-485 magtapes, 22-290
TAPOP. UUO, 22-479 UNLOK. UUO, 22-522
Index-14
Unrestricting devices, 22-118 GETSEG, 22-177
Updating files, 22-136, 22-162 GETSTS, 22-180
USETI UUO, 22-523 GETTAB, 22-182
USETO UUO, 22-525 GOBSTR, 22-183
UTPCLR UUO, 22-527 GTNTN., 22-186
UTRP. UUO, 22-528 GTXTN., 22-188
UUOs HIBER, 22-189
ACCLG., 22-3 HPQ, 22-192
ACCT., 22-5 IN, 22-193
APRENB, 22-7 INBUF, 22-195
ATTACH, 22-10 INCHRS, 22-197
CAL11., 22-16 INCHRW, 22-198
CALLI, 22-13 INCHSL, 22-199
CHGPPN, 22-21 INCHWL, 22-200
CHKACC, 22-22 INPUT, 22-202
CLOSE, 22-27 IONDX., 22-204
CLRBFI, 22-30 IONEOU, 22-205
CLRBFO, 22-31 IPCFQ., 22-210
CLRST., 22-32 IPCFR., 22-212
CMAND., 22-34 IPCFS., 22-219
CNECT., 22-39 JBSET., 22-221
CORE, 22-41 JOBPEK, 22-222
CTLJOB, 22-44 JOBSTR, 22-225
DAEFIN, 22-50 JOBSTS, 22-227
DAEMON, 22-51 KDP., 22-230
DATE, 22-57 LOCATE, 22-255
DEBRK., 22-58 LOCK, 22-257
DEQ., 22-59 LOGIN, 22-262
DEVCHR, 22-62 LOGOUT, 22-263
DEVLNM, 22-65 LOOKUP, 22-264
DEVNAM, 22-66 MERGE., 22-266
DEVOP., 22-67 MONRT., 22-268
DEVPPN, 22-73 MSTIME, 22-269
DEVSIZ, 22-74 MTAID., 22-270
DEVSTS, 22-76 MTAPE, 22-272
DEVTYP, 22-78 MTBLK., 22-274
DIAG., 22-81 MTBSF., 22-275
DISK., 22-85 MTBSR., 22-277
DNET., 22-93 MTCHR., 22-278
DSKCHR, 22-100 MTDEC., 22-282
DTE., 22-108 MTEOF., 22-283
DVPHY., 22-115 MTEOT., 22-284
DVRST., 22-117 MTIND., 22-285
DVURS., 22-118 MTLTH., 22-286
ENQ., 22-119 MTREW., 22-287
ENQC., 22-132 MTSKF., 22-288
ENTER, 22-136 MTSKR., 22-289
ERLST., 22-140 MTUNL., 22-290
ERRPT., 22-142 MTWAT., 22-292
EXIT, 22-156 MVHDR., 22-293
FILOP., 22-158 NODE., 22-297
FRCUUO, 22-171 NSP., 22-305
Index-15
GETLCH, 22-173 NTMAN., 22-308
GETLIN, 22-175 OPEN, 22-312
GETPPN, 22-176 OTHUSR, 22-320
Index-16
OUT, 22-321 SLEEP, 22-449
OUTBUF, 22-323 SNOOP., 22-450
OUTCHR, 22-324 SPPRM., 22-455
OUTPUT, 22-325 SPY, 22-458
OUTSTR, 22-326 STATO, 22-460
PAGE., 22-327 STATZ, 22-461
PATH., 22-337 STRUUO, 22-462
PEEK, 22-349 SUSET., 22-475
PERF., 22-350 SYSPHY, 22-477
PIBLK., 22-355 SYSSTR, 22-478
PIINI., 22-357 TAPOP., 22-479
PIJBI., 22-360 TIMER, 22-491
PIRST., 22-362 TMPCOR, 22-492
PISAV., 22-363 TRMNO., 22-495
PISYS., 22-365 TRMOP., 22-497
PITMR., 22-370 TRPSET, 22-512
PJOB, 22-372 TSK., 22-513
POKE., 22-373 TTCALL, 22-519
QUEUE., 22-375 UGETF, 22-520
REASSI, 22-389 UJEN, 22-521
RECON., 22-391 UNLOK., 22-522
RELEAS, 22-398 USETI, 22-523
REMAP, 22-399 USETO, 22-525
RENAME, 22-401 UTPCLR, 22-527
RESCAN, 22-404 UTRP., 22-528
RESDV., 22-405 WAIT, 22-530
RESET, 22-406 WAKE, 22-531
RTTRP, 22-408 WHERE, 22-532
RUN, 22-410
RUNTIM, 22-413 Variable bits for DECnet links,
SAVE., 22-414 22-97
SCHED., 22-416 VFU loading, 22-68
SENSE., 22-428 Virtual time trap, 22-439
SETDDT, 22-430
SETLCH, 22-431
SETNAM, 22-432 WAIT UUO, 22-530
SETSTS, 22-433 WAKE UUO, 22-531
SETUUO, 22-434 WHERE UUO, 22-532
SETUWP, 22-446 Working set, 22-330
SKPINC, 22-447 Writing files, 22-162, 22-166
SKPINL, 22-448 Written blocks, 22-91
Index-17
Dear Customer,
Corporate User Publications, Marlboro, requests your opinion. As you may
know, it is a time-consuming and expensive task to prepare hardcopy, printed
manuals for printing, reproduction, and distribution. Completing this complex
task often prevents us from providing current information with every
distribution of software changes.
Therefore, we believe we can provide you with accurate information on
a more timely basis by distributing documentation files with the
software. This mechanism allows us to provide documentation with
autopatch releases and to distribute that documentation in an
electronic form with the software.
Autopatch Tape 16 for TOPS-10 7.03A contains a software documentation file
that reflects the software on the tape. DIGITAL authorizes you to
make up to two copies of the documentation for use at your site, as
long as you maintain DIGITAL's copyright page. We request that you
print the file and use one of the reply forms to send your opinions to us.
On Autopatch Tape 16, you will find the following documentation files:
1. MONCAL.MEM contains Volume 2 of the Monitor Calls Manual; it uses
approximately 2600 blocks of disk space. This version of the
manual contains changes that we have made since the manual was
printed for TOPS-10 Version 7.03, in May 1986.
2. MCINFO.MEM is a duplicate of this customer letter and the reply form.
MONCAL.MEM is about 775 line-printer pages long and contains change bars
to indicate the pages that have changed. The file contains non-printing
control characters for paging and bolding effect, making it unsuitable for
terminal display. We recommend that you print the file on any supported
line printer.
Please let us know what you think about this method of distributing software
documentation by filling out and returning the following reply form. Your
responses will be considered in future plans for the distribution of TOPS-10
documentation.
Sincerely,
Mary J. Marotta
Corporate User Publications
Digital Equipment Corporation
TOPS-10 MONITOR CALLS VOLUME 2
TOPS-10 V. 7.03A AUTOPATCH 16
READER'S COMMENTS
Your opinion is requested. Please read the customer letter on the previous
page, write your comments on this form, and mail the form to:
Corporate User Publications
Digital Equipment Corporation
200 Forest St.
Marlboro, MA 01752
Your name:______________________________________________
Company:________________________________________________
Address:________________________________________________
________________________________________________
Phone:__________________________________________________
Your title/position:____________________________________
Were you able to successfully print the document? (Check one.)
_____________ _______________
YES NO
If not, why not?________________________________________
Tell us whether the changes in the document are important for you to receive
at the same time as the software changes. (Check one.)
______________ Very Important
______________ Important
______________ Not Important
______________ I Don't Know
Choose the method of receiving software documentation that will best meet
your needs. (Check one.)
______________ Electronic distribution
______________ Hardcopy manuals
The space below is reserved for your comments and suggestions.
Thank you for your interest.