# HG changeset patch
# User roug
# Date 1018387118 0
# Node ID f2d338984847c8e9a4afc735ce2e74b60425fae9
# Parent 4b708df591ee886ad5e6b83139db578dd1078548
Finished all the I/O system calls.
diff -r 4b708df591ee -r f2d338984847 docs/os9sysprog/os9sysprog.docbook
--- a/docs/os9sysprog/os9sysprog.docbook Mon Apr 08 03:41:41 2002 +0000
+++ b/docs/os9sysprog/os9sysprog.docbook Tue Apr 09 21:18:38 2002 +0000
@@ -60,7 +60,7 @@
architecture, instruction set, and assembly language.
-HISTORY AND DESIGN PHILOSOPHY
+History And Design Philosophy
OS-9 Level One is one of the products of the BASIC09 Advanced 6809
Programming Language development effort undertaken by Microware and
@@ -1038,7 +1038,7 @@
I
4,... . a...a.e.,a4. I
$02 1
-+-- Module Size (bytes) --+
++-- Module Size (bytes) =-+
I
$03 I I 1 1,
,.,.., ...m.aa..a.a.....in.a.,.......,...a4.. 1
@@ -2134,7 +2134,7 @@
NAME: INIT
-INPUT: (U) - ADDRESS OF DEVICE STATIC STORAGE (Y) - ADDRESS OF THE
+INPUT: (U) = ADDRESS OF DEVICE STATIC STORAGE (Y) = ADDRESS OF THE
DEVICE DESCRIPTOR MODULE
@@ -2172,45 +2172,36 @@
NAME: READ
-INPUT: (U) s. ADDRESS OF THE DEVICE STATIC STORAGE
-(Y. -
-ADDRESS OF THE PATH DESCRIPTOR
-(B) - NSB OF DISK LOGICAL SECTOR
-NUMBER
-(X) - LSB's OF DISK LOGICAL SECTOR NUMBER
-
-
-OUTPUT: SECTOR IS RETURNED IN THE SECTOR BUFFER
-
-
+
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
+ NAME:
+ READ
INPUT:
-
+ (U) = ADDRESS OF THE DEVICE STATIC STORAGE
+(Y) = ADDRESS OF THE PATH DESCRIPTOR
+(B) = NSB OF DISK LOGICAL SECTOR NUMBER
+(X) = LSB's OF DISK LOGICAL SECTOR NUMBER
OUTPUT:
-
+ SECTOR IS RETURNED IN THE SECTOR BUFFER
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+ FUNCTION:
+ READ A 256 BYTE SECTOR
-
-FUNCTION: READ A 256 BYTE SECTOR
Read a sector from the disk and place it in the sector buffer
@@ -2258,18 +2249,16 @@
NAME: WRITE
INPUT: (U) = ADDRESS OF TEE DEVICE STATIC STORAGE AREA
-(Y)
-ADDRESS OF THE PATH DESCRIPTOR
- (B) - MSB OF THE DISK LOGICAL
-SECTOR NUMBER
-(X) - LSB's OF THE DISK LOGICAL SECTOR NUMBER
+(Y) = ADDRESS OF THE PATH DESCRIPTOR
+ (B) = MSB OF THE DISK LOGICAL SECTOR NUMBER
+(X) = LSB's OF THE DISK LOGICAL SECTOR NUMBER
OUTPUT: THE SECTOR BUFFER IS WRITTEN OUT TO DISK
-FUNCTION. WRITE A SECTOR
+FUNCTION: WRITE A SECTOR
Wtite the sector buffer (256 bytes) to the disk. Below are the
@@ -2309,10 +2298,9 @@
NAME: GETSTA PUTSTA
-INPUT: (U) - ADDRESS OF TEE DEVICE STATIC STORAGE AREA
-(Y) -
-ADDRESS OF THE PATH DESCRIPTOR
-(A) - STATUS CODE
+INPUT: (U) = ADDRESS OF TEE DEVICE STATIC STORAGE AREA
+(Y) = ADDRESS OF THE PATH DESCRIPTOR
+(A) = STATUS CODE
OUTPUT: (DEPENDS UPON TEE FUNCTION CODE)
@@ -2480,9 +2468,8 @@
INPUT: None.
-OUTPUT: (U) - SIZE OF THE BOOT FILE (in bytes)
-(X) - ADDRESS OF
-WHERE THE BOOT FILE WAS LOADED IN MEMORY
+OUTPUT: (U) = SIZE OF THE BOOT FILE (in bytes)
+(X) = ADDRESS OF WHERE THE BOOT FILE WAS LOADED IN MEMORY
ERROR OUTPUT:
@@ -2542,7 +2529,7 @@
manager module that supports devices that operate on a character-
by-character basis, such as terminals, printers, modems, etc. SCFMAN
can handle any number or type of such devices. It is a reentrant
-subroutine package called by XOMAN for I/O service requests to
+subroutine package called by IOMAN for I/O service requests to
sequentia~ character ~oriented devices. It includes the extensive
input and output e~diting functions typical of line- oriented
operat~.on such as: backspace, line delete, repeat line, auto line
@@ -2583,7 +2570,7 @@
~A. .Z~
-If PD.rXO <> 0, input bytes are echoed, except that
+If PD.EXO <> 0, input bytes are echoed, except that
undefined control characters in the range $0~~$lF print as ~
@@ -2662,80 +2649,56 @@
The table below describes the path descriptors used by SCFMAN and
SCFMAN-type device drivers.
-Name Offset Size Description
-
-Universal Section (Same for all file managers)
-PD.PD $00 1 Path
-number
-PD.MOD $01 I Mode (read/write/update)
-PD.CNT $02 I
-Number of open images
-PD.DEV $03 2 Address of device table
-entry
-PD.CPR $03 I Current process ID
-PD.RGS $06 2 Address of
-callers MPU register stack
-PD.BUF $08 I Butter address
-
-SCFMAN Path Descriptor Definitions
-PD.DVI $OA 2 Device table
-addr of 2nd (echo) device
-PD.RAW $OC I Edit flag: 0-raw mode,
-1-edit mode
-PD.MAX $OD 2 Headline maximum character count
-PD.MIN
-$OF 1. Devices are wininew it cleared
-PD.STS $10 2 Status routine
-module address
+
+Name Offset Size Description
+
+Universal Section (Same for all file managers)
+PD.PD $00 1 Path number
+PD.MOD $01 1 Mode (read/write/update)
+PD.CNT $02 1 Number of open images
+PD.DEV $03 2 Address of device table entry
+PD.CPR $03 1 Current process ID
+PD.RGS $06 2 Address of callers MPU register stack
+PD.BUF $08 1 Butter address
+
+SCFMAN Path Descriptor Definitions
+PD.DVI $0A 2 Device table addr of 2nd (echo) device
+PD.RAW $0C I Edit flag: 0-raw mode, 1-edit mode
+PD.MAX $0D 2 Headline maximum character count
+PD.MIN $0F 1. Devices are wininew it cleared
+PD.STS $10 2 Status routine module address
PD.STh $12 2 Reserved for status routine
-
-
-SCFMAN Option Section Definition
-$20 1 Device class 0-SC F
-2PIPE 35
-PD.UPC $21 1 Oase (0-BOTH, 1-UPPER ONLY)
-PD.BSO $22 1
-Backsp (0-835, 1-835 SP 8SE)
-PD.DLO $23 1 Delete (0 - 855 over
-line, 1-CR LF)
+
+
+SCFMAN Option Section Definition
+$20 1 Device class 0-SCF 2 PIPE 35
+PD.UPC $21 1 Case (0-BOTH, 1-UPPER ONLY)
+PD.BSO $22 1 Backsp (0-835, 1-835 SP 8SE)
+PD.DLO $23 1 Delete (0 - 855 over line, 1-CR LF)
PD.EXO $24 I Echo (0-no echo)
-PD.AtF $25 1 Auto
-LF (0-no auto LF)
+PD.AtF $25 1 Auto LF (0-no auto LF)
PD.NtTL $26 1 End of line null count
-PD.PAU
-$27 1 Pause (0= no end of page pause)
-PD.PAG $28 1 Lines per
-page
+PD.PAU $27 1 Pause (0= no end of page pause)
+PD.PAG $28 1 Lines per page
PD.HSP $29 1 Backspace character
-PD.DEL $2A I Delete line
-character
+PD.DEL $2A I Delete line character
PD.EOR $25 1 End of record character (read only)
-PD.EoF
-$2C I End of file character (read only)
-PD.RPR $2D I Reprint line
-character
+PD.EoF $2C I End of file character (read only)
+PD.RPR $2D I Reprint line character
PD.DUP $25 1 Duplicate last line character
-PD.PSC $2F
-I Pause character
-PD.INT $30 I Meyboard interrupt character (CTL
-C)
+PD.PSC $2F I Pause character
+PD.INT $30 I Meyboard interrupt character (CTL C)
PD.QUT $31 1 Eeyboard abort character (CTL 0)
-PD.BSE $32 1
-Backspace echo character (BSE)
-PD.OVF $33 1 Line overflow
-character (bell)
-PD.PAR $34 1 Device initialization value
-(parity)
-PD.BAQ 335 1 Software settable baud rate
-PD.D2P $36 2
-Offset to 2nd device name string
-PD.STN $38 2 Offset of status
-routine name
+PD.BSE $32 1 Backspace echo character (BSE)
+PD.OVF $33 1 Line overflow character (bell)
+PD.PAR $34 1 Device initialization value (parity)
+PD.BAQ $35 1 Software settable baud rate
+PD.D2P $36 2 Offset to 2nd device name string
+PD.STN $38 2 Offset of status routine name
PD.ERR $3A 1 Most recent I/O error status
-
-
-
-
+
+
+
The first section is universal for all file managers, the second
and third section are specific~for SCFMAN and SCFMAN-type device
@@ -2752,58 +2715,42 @@
-SCF DEVICE DESCRIPTOR MODULES
+SCF Device Descriptor Modules
Device descriptor modules for SCF-type devices contain the device
address and an initialization table which defines inital values for
the I/O editing features, as listed below.
-
+
MODULE
-OFFSET ORG $12
-TABLE 500 , BEGINING OF OPTION
-TABLE
-$12 IT.DVC HItS I DEVICE CLASS (0-SCF l-RBF 2-PIPE
-3-8512)
+OFFSET
+ORG $12 TABLE 500 , BEGINING OF OPTION TABLE
+$12 IT.DVC HItS I DEVICE CLASS (0-SCF l-RBF 2-PIPE 3-8512)
$13 IT.UPC RMB I CASE (0-BOTH, J.UPPER ONLY)
-$14 IT.BSO
-HItS 1 SACS SPACE (0-855, l BSE,SP.BSE)
-$15 IT.DLO HItS 1 DELETE
-(0-885 OVER LINE, 1-CR)
+$14 IT.BSO HItS 1 SACS SPACE (0-855, l BSE,SP.BSE)
+$15 IT.DLO HItS 1 DELETE (0-885 OVER LINE, 1-CR)
$16 IT.EXO RItE 1 50130 (OWNO ECHO)
-$17
-IT.A.LF RItE I. AUTO LINE FEED (0- NO AUTO LF)
-$18 IT.NUL HItS 1
-END OF LINE NULL COUNT
-$19 IT.PAU 5103 1 PAUSE (0 NO END OF PAGE
-PAUSE)
+$17 IT.A.LF RItE I. AUTO LINE FEED (0- NO AUTO LF)
+$18 IT.NUL HItS 1 END OF LINE NULL COUNT
+$19 IT.PAU 5103 1 PAUSE (0 NO END OF PAGE PAUSE)
$1A IT. PAG RItE 1 LINES PER PAGE
-$13 IT. ES? HItS 1
-BACXSPACE CHARACTER
+$13 IT. ES? HItS 1 BACXSPACE CHARACTER
$10 IT.DED HItS 1 DEDETE LINE CHARACTER
-$11)
-IT.EOR RItE 1 END OF RECORD CHARACTER
-$15 IT.EOF RItE 1 END OF
-FILE CHARACTER
+$11 IT.EOR RItE 1 END OF RECORD CHARACTER
+$15 IT.EOF RItE 1 END OF FILE CHARACTER
$1F IT.R~PR RItE 1 REPRINT LINE CHARACTER
-$20
-IT.DUP RItE 1 SUP LAST LINE CHARACTER
-$21 IT.PSC RItE 1 PAUSE
-CHARACTER
+$20 IT.DUP RItE 1 SUP LAST LINE CHARACTER
+$21 IT.PSC RItE 1 PAUSE CHARACTER
$22 IT.INT RItE 1 INTERRUPT CHARACTER
-$23 IT.00T RItE
-1 QUIT CHARACTER
+$23 IT.00T RItE 1 QUIT CHARACTER
$24 IT.BSE RItE 1 BACKSPACE ECHO CHARACTER
-$25
-IT.OVF RItE I LINE OVERFL~ CHARACTER (BELL)
-$26 IT.PAR. RItE 1
-INITIALIZATION VALUE (PARITY)
+$25 IT.OVF RItE I LINE OVERFL~ CHARACTER (BELL)
+$26 IT.PAR. RItE 1 INITIALIZATION VALUE (PARITY)
$27 IT.UAI2 RItE I BAUD RATE
-$28
-IT.D2F RItE 2 ATYACEED DEVICE NAME STING O12FSET
-$2A IT.STN RItE 2
-OFPSET TO STATUS ROUTINE
-320 IT.ERR RItE 1 INITIAL ERROR STATUS
+$28 IT.D2F RItE 2 ATYACEED DEVICE NAME STING O12FSET
+$2A IT.STN RItE 2 OFPSET TO STATUS ROUTINE
+320 IT.ERR RItE 1 INITIAL ERROR STATUS
+
NOTES:
@@ -2817,7 +2764,7 @@
-SCF DEVICE DRIVER STORAGE DEFINITIONS
+SCF Device Driver Storage Definitions
An SCFMAN-type device driver module contains a package of
subroutines that perform raw I/o transfers to or from a specific
@@ -2830,34 +2777,28 @@
of this storage area will be used by IOMAN and SCFMAN, the device
driver is free to use the remainder in any way (typically as
variables and butters). This static storage is defined as:
+
+
OFFSET
ORG 0
$0 V.PAGE RItE 1 PORT EXTENDED ADDRESS
-$1 V.PCRT RItE 2
-DEVICE BASE ADDRESS
+$1 V.PCRT RItE 2 DEVICE BASE ADDRESS
$3 V.LPRC RItE 1 LAST ACTIVE PROCESS ID
-$4
-V.BUSY RItE I ACTIVE PROCESS ID (0 NOT BUSY)
-$5 V. WAKE HItS I
-PROCESS II) TO REAWAZEN
+$4 V.BUSY RItE I ACTIVE PROCESS ID (0 NOT BUSY)
+$5 V. WAKE HItS I PROCESS II) TO REAWAZEN
+
V. USER EQU . END OF OS9 DEFINITIONS
-$6
-V.TYPE RItE I DEVICE TYPE OR PARITY
-$7 V.LINt RItE 1 LINES LEFT
-TILL END OF PAGE
+$6 V.TYPE RItE I DEVICE TYPE OR PARITY
+$7 V.LINt RItE 1 LINES LEFT TILL END OF PAGE
$8 V.PAUS RItE 1 PAUSE REQUEST (0 - NO PAUSE)
-$9
-V.DEV2 RItE 2 ATTACHEs DEVICE STATIC STORAGE
-$5 V. INTH RItE 1
-INTERRUPT CHARACTER
+$9 V.DEV2 RItE 2 ATTACHEs DEVICE STATIC STORAGE
+$5 V. INTH RItE 1 INTERRUPT CHARACTER
$0 V.00IT RItE 1 QUIT CHARACTER
-$1) V.PCHR
-RItE I PAUSE CHARACTER
+$1) V.PCHR RItE I PAUSE CHARACTER
$E V. ERR RItE 1 ERROR ACCUMULATOR
-$F
-V.SCF EQU END OF SCFMAN DEFINITIONS
-FREE EQU . FREE FOR DEVICE
-DRIVER TO USE
+$F V.SCF EQU END OF SCFMAN DEFINITIONS
+FREE EQU . FREE FOR DEVICE DRIVER TO USE
+
V.PAGE, V.PORT These three bytes are defined by IOMAN to be the 24
bit device address.
@@ -2915,7 +2856,7 @@
-SCFMAN DEVICE DRIVER SUBROUTINES
+SCFMAN Device Driver Subroutines
As with all device drivers. SCFMAN device drivers use a standard
executable memory module format with a module type of
@@ -2973,7 +2914,7 @@
NAME: INIT
-INPUT: (U) - ADDRESS OP DEVICE STATIC STORAGE (Y) - ADDRESS OF
+INPUT: (U) = ADDRESS OP DEVICE STATIC STORAGE (Y) = ADDRESS OF
DEVICE DESCRIPTOR MODULE
@@ -3006,9 +2947,9 @@
NAME: READ
-INPUT: (U) - ADDRESS OF DEVICE STATIC STORAGE
-
-(Y) - ADDRESs OP PATH DESCRIPTOR OUTPUT: (A) - CHARACTER READ
+INPUT: (U) = ADDRESS OF DEVICE STATIC STORAGE
+
+(Y) = ADDRESs OP PATH DESCRIPTOR OUTPUT: (A) = CHARACTER READ
ERROR OUTPUT:
@@ -3040,9 +2981,8 @@
NAME: WRITE
INPUT: (U) = ADDRESS OF DEVICE STATIC STORAGE
-(Y) = ADDRESS OF
-THE PATH DESCRIPTOR
-(A) - CHAR TO WRITE
+(Y) = ADDRESS OF THE PATH DESCRIPTOR
+(A) = CHAR TO WRITE
OUTPUT: NONE
@@ -3079,7 +3019,7 @@
NAME: GETSTA/SETSTA
INPUT: (U) = ADDRESS OP DEVICE STATIC STORAGE
-(Y) - ADDRESS OF
+(Y) = ADDRESS OF
PATH DESCRIPTOR
(A) = STATUS CODE
@@ -3187,7 +3127,7 @@
NAME. TERM
-INPUT: (U) - PTR TO DEVICE STATIC STORAGE
+INPUT: (U) = PTR TO DEVICE STATIC STORAGE
OUTPUT: NONE
@@ -3285,9 +3225,9 @@
and memory modules for the OS-9 execution environment.
-HOW TO WRITE POSITION-INDEPENDENT CODE
-
-The 6809 irsstruct~on set was cpttmized to allow efficient use of
+How to Write Position-Independent Code
+
+The 6809 instruction set was optimized to allow efficient use of
Position Independent Code (PIC)~ The basic technique is to always use
PC-relative addressing; for example BRA, LBRA, BSR and L8SR~ Get
addresses of constants and tables using LEA instructions instead of
@@ -3320,9 +3260,7 @@
-
-ADDRESSING VARIABLES AND DATA STRUCTURES
-
+Addressing Variables and Data Structures
Programs executed as processes (by FORK and CHAIN system calls or
by the Shell) are assigned a RAM memory area for variables, stacks,
@@ -3358,7 +3296,7 @@
-STACK REQUIREMENTS
+Stack Requirements
Because OS-9 uses interrupts extensively, and also because many
reentrant 6809 programs use the MPU stack for local variable storage,
@@ -3367,7 +3305,7 @@
-INTERRUPT MASKS
+Interrupt Masks
User programs should keep the condition codes register F (FIRQ
mask) and I (IRQ mask) bits off. They can be set during critical
@@ -3450,10 +3388,11 @@
- A SAMPLE PROGRAM
+A SAMPLE PROGRAM
The OS-9 "list" utility command program is shown on this
and the next page as an example of assembly language programming.
+
Microware OS-9 Assembler 2.1 01/04/82 23:39:37 Page 001
LIST - File List Utility
@@ -3585,30 +3524,35 @@
OS-9 modules to include in ROM. The following checklist is designed
to help you do so:
- Include OS9P1, OS9P2, SYSGO, and INIT. These modules are
- required in any OS-9 system.
- If the target system is perform any I/O or interrupt
- functions include IOMAN.
- If the target system is to perform I/O to character-oriented
- I/O devices using ACIAs, PIAs, eta,,, include SCFM~AN, required
- device drivers (such as ACIA and PIA, and/or your own), and device
- descriptors as needed (such as TERM, TI, 1?, and/or your own),, If
- device addresses and/or initialization functions need to be changed,
- the device descriptor modules must be modified before being ROMed.
- Ii the target system is to perform disk I/O, include RBFMAN,
- and appropriate disk driver and device descriptor modules. As in (c)
- above, change device addresses and initialization if needed, ii
- RBFMAN ~JJJ, n~,t. be included, the INIT and SYSGO modules ~ be
- altered to remove references to disk tiles.
- Ii the target system requires multiprogramming, time-cf-day,~
- or other time-related functions, include a CLOCK module for the
- target system's real-time clock. Also consider how the clock is to
- be started,. You may want to ROM the "Setime" command, or
- have SYSGQ start the clock.
- It tne target system will receive commands manually, or if
- any application program uses Shell functions, include the SHELL and
- SYSGO modules, otherwise include a modified SYSGO module which calls
- your application program instead of Shell.
+ Include OS9P1, OS9P2, SYSGO, and INIT. These modules are
+ required in any OS-9 system.
+
+ If the target system is perform any I/O or interrupt
+ functions include IOMAN.
+
+ If the target system is to perform I/O to character-oriented
+ I/O devices using ACIAs, PIAs, eta,,, include SCFM~AN, required
+ device drivers (such as ACIA and PIA, and/or your own), and device
+ descriptors as needed (such as TERM, TI, 1?, and/or your own),, If
+ device addresses and/or initialization functions need to be changed,
+ the device descriptor modules must be modified before being ROMed.
+
+ Ii the target system is to perform disk I/O, include RBFMAN,
+ and appropriate disk driver and device descriptor modules. As in (c)
+ above, change device addresses and initialization if needed, ii
+ RBFMAN ~JJJ, n~,t. be included, the INIT and SYSGO modules ~ be
+ altered to remove references to disk tiles.
+
+ Ii the target system requires multiprogramming, time-cf-day,~
+ or other time-related functions, include a CLOCK module for the
+ target system's real-time clock. Also consider how the clock is to
+ be started,. You may want to ROM the "Setime" command, or
+ have SYSGQ start the clock.
+
+ It tne target system will receive commands manually, or if
+ any application program uses Shell functions, include the SHELL and
+ SYSGO modules, otherwise include a modified SYSGO module which calls
+ your application program instead of Shell.
@@ -3644,8 +3588,9 @@
directory name string (normally /D0). This device is assumed when
device names are omitted from pathlists. If the system will not use
disks (e.g., RBFMAN will not be used) this offset mustbe
-zero.
-$12,$13 Offset to the initial standard path string
+zero.
+
+$12,$13 Offset to the initial standard path string
(typically /TERM). This path is opened as the standard paths for the
initial startup module. This offset must contain zero if there
is none.
@@ -3730,20 +3675,21 @@
9ere an e pie system call for the ~ULOSE~ service request:
-LDA PATHNUM
+
+LDA PATHNUM
SWI2
FCB $8B
BCS ERROR
-
+
Using the assembler~s ~OS9~ directive simplifies the call:
-
+
LDA PATHNUM
OS9 I$CLOS
BCS ERROR
-
+
The I/O service requests are simpler to use than in many other
operating systems because the calling program does not have to
@@ -3772,43 +3718,31 @@
ABIT Set bits in an allocation bit map F$ABIT
-ASSEMBLER CALL: OS9 F$ABIT
-
-
-MACHINE CODE: 103F 13
-
-INPUT: (X) - Base address of glocation bit map.
-(D) m Bit
-number of first bit to set.
-(Y) m Bit count (number of bits to
-set)
-
-
-OUTPUT: None.
-
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$ABIT
MACHINE CODE:
- 103F
+ 103F 13
INPUT:
-
+ (X) = Base address of glocation bit map.
+(D) = Bit number of first bit to set.
+(Y) = Bit count (number of bits to set)
OUTPUT:
-
+ None.
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -3824,35 +3758,24 @@
CHAIN Load and execute a new primary module, F$CHAN
-ASSEMBLER CALL: OS9 F$CHAN
-
-
-MACHINE CODE: 103F 05
-
-INPUT: (X) - Address of module name or file name
-
-(Y) = Parameter area sime (25~ byte pages)
-
-(U) = Beginning address of parameter area
-
-(A) - Lanquage / type code
-
-(B) = Optional data area size (256 byte pages)
-
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$CHAN
MACHINE CODE:
- 103F
+ 103F 05
INPUT:
-
+ (X) = Address of module name or file name
+(Y) = Parameter area sime (256 byte pages)
+(U) = Beginning address of parameter area
+(A) = Lanquage / type code
+(B) = Optional data area size (256 byte pages)
OUTPUT:
@@ -3860,8 +3783,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -3894,7 +3817,9 @@
the new primary module's header
The diagram below shows bow CHAIN sets up the data memory area and
-registers for the new module,
+registers for the new module.
+
+
+-----------------+ <-- Y
(highest address)
I Parameter I
@@ -3945,8 +3870,8 @@
MACHINE CODE: 103F 11
-INPUT: (X) - Address of first name,
-(B) =Length of first name,
+INPUT: (X) = Address of first name,
+(B) = Length of first name,
(Y) = Address of secorrd name.
OUTPUT: (CC) = C bit clear if the strings match.
@@ -3972,7 +3897,7 @@
INPUT: (X) m Starting byte address,
-(Y) - Byte count,
+(Y) = Byte count,
(U) =
Address of 3 byte CRC accumulator.
@@ -3995,28 +3920,20 @@
DBIT Deallocate in a bit map F$DBIT
-ASSEMBLER CALL: OS9 F$DBIT
-
-
MACHINE CODE: 103F 14
INPUT: (X) = B e address of an allocation bit map.
-(D} - Bit
-number of firs bit to clear.
-(Y) - Bit count (number ~f bits to
-clear).
-
-
-OUTPUT: None.
-
-
-
+(D) = Bit number of firs bit to clear.
+(Y) = Bit count (number ~f bits to clear).
+
+
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$DBIT
MACHINE CODE:
@@ -4028,12 +3945,12 @@
OUTPUT:
-
+ None.
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4083,19 +4000,19 @@
INPUT: (X) ? Addre s o module name or file name.
-(Y) -
+(Y) =
Parameter area size.
-(U) - Beginning address of the parameter
+(U) = Beginning address of the parameter
area.
(A) = Language / Type code,
(B) = Optional data area size
(pages).
OUTPUT: (X) = Updated path the name string.
-(A) - New process
+(A) = New process
ID number.
-
+
@@ -4116,8 +4033,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4203,11 +4120,11 @@
INPUT: (X) = Address of the intercept routine.
-(U) - Address of
+(U) = Address of
the intercept routine local storage.
OUTPUT: None.
-
+
@@ -4228,8 +4145,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4281,12 +4198,12 @@
INPUT: None
-OUTPUT:(A) - Process ID.
+OUTPUT:(A) = Process ID.
(Y) " User ID.
-
+
@@ -4307,8 +4224,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4329,20 +4246,20 @@
MACHINE CODE: 103F 00
-INPUT: (X) - Address of the module name string.
-(A) - Module
+INPUT: (X) = Address of the module name string.
+(A) = Module
type / language byte.
OUTPUT:(X) = Advanced past the module name,
(Y) = Module entry
point absolute address.
-(U) - Module header absolute address.
+(U) = Module header absolute address.
(A)
- Module type / language.
-(B) - Module attributes / revision
+(B) = Module attributes / revision
level.
-
+
@@ -4363,8 +4280,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4399,20 +4316,17 @@
MACHINE CODE: 103F Dl
INPUT: (X) = Address of pathlist (file name)
-(A) = Language /
-type (0 = any language / type)
-
-
-OUTPUT:(X) - Advanced past pathlist
-(Y) - Primary module entry
-point address
-(U) - Address of module header
-(A; - Language /
-type
-(B) - Attributes / revision level
-
-
-
+(A) = Language / type (0 = any language / type)
+
+
+OUTPUT:(X) = Advanced past pathlist
+(Y) = Primary module entry point address
+(U) = Address of module header
+(A; - Language / type
+(B) = Attributes / revision level
+
+
+
@@ -4433,8 +4347,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4464,13 +4378,13 @@
MACHINE CODE: 103F 07
-INPUT: (0) - Desired new memory area size in bytes
+INPUT: (0) = Desired new memory area size in bytes
OUTPUT: (P) = Address of new memory area upper bound
-(D) - Actual new memory .area size in bytes
-
-
+(D) = Actual new memory .area size in bytes
+
+
@@ -4491,8 +4405,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4533,7 +4447,7 @@
OUTPUT: None.
-
+
@@ -4554,8 +4468,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4583,13 +4497,13 @@
INPUT: (X) = Address of the pathlist
-OUTPUT: (X) - Updated past the optional /
-
-
-(Y) - Address of the 14st character of the name + 1~
-
-
-(B) - Length of the name
+OUTPUT: (X) = Updated past the optional /
+
+
+(Y) = Address of the 14st character of the name + 1~
+
+
+(B) = Length of the name
ERROR OUTPUT:
@@ -4597,7 +4511,7 @@
(B) = Appropriate error code.
-(X) - Updated past space characters.
+(X) = Updated past space characters.
Parses the input text string for a legal OS-9 name. The name is
terminated by any character that is not a legal component character,
@@ -4631,15 +4545,15 @@
MACHINE CODE: 103F 12
-INPUT: (X) - Beginning address of a bit map.
-(0) - Beginning
+INPUT: (X) = Beginning address of a bit map.
+(0) = Beginning
bit number.
(Y) = Bit count (free bit block size).
(U) = End of
bit map address.
-OUTPUT: (D) - Beginning bit number.
-(Y) - Bit count.
+OUTPUT: (D) = Beginning bit number.
+(Y) = Bit count.
This system mode service request searches the specified allocation
bit map starting at the "beginning bit number" for a free
@@ -4663,7 +4577,7 @@
OUTPUT: None
-
+
@@ -4684,8 +4598,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4740,7 +4654,7 @@
OUTPUT: (X) = Decremented by the number of ticks that the process
was asleep
-
+
@@ -4761,8 +4675,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4803,7 +4717,7 @@
OUTPUT: None.
-
+
@@ -4824,8 +4738,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -4844,7 +4758,7 @@
MACHINE CODE: 103F 32
-INPUT: (Y) - Address of service request initialization table.
+INPUT: (Y) = Address of service request initialization table.
OUTPUT: None.
@@ -4910,7 +4824,7 @@
- a
a am - - - - m~* +
Y I $6 R$Y
-------- -"4.
+------- -
U
$8 R$tY
4-..
@@ -4953,7 +4867,7 @@
OUTPUT: None
-
+
@@ -4974,8 +4888,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5010,7 +4924,7 @@
OUTPUT: Time/date is set.
-
+
@@ -5031,8 +4945,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5065,7 +4979,7 @@
OUTPUT: Time packet (see below).
-
+
@@ -5086,8 +5000,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5121,7 +5035,7 @@
OUTPUT: None
-
+
@@ -5142,8 +5056,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5177,7 +5091,7 @@
(B) = Child process' exit status code
-
+
@@ -5198,8 +5112,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5244,7 +5158,7 @@
(Y) = Address of block
-
+
@@ -5265,8 +5179,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5324,11 +5238,11 @@
MACHINE CODE: 103F 2C
-INPUT: (N) - Address of process descriptor
+INPUT: (N) = Address of process descriptor
OUTPUT: None
-
+
@@ -5349,8 +5263,8 @@
ERROR OUTPUT:
- (CC) - C bit set.
-(B) Appropriate error code.
+ (CC) = C bit set.
+(B) = Appropriate error code.
@@ -5376,12 +5290,12 @@
MACHINE CODE: 103F 2F
-INPUT: (K) = Add ess o base page, (A) - Block number.
+INPUT: (K) = Add ess o base page, (A) = Block number.
OUTPUT: (Y) = Address of block
-
+
@@ -5428,11 +5342,11 @@
MACHINE CODE: 103F 33
-INPUT: (K) - Address of an I/O module, (see description)
+INPUT: (K) = Address of an I/O module, (see description)
OUTPUT: None
-
+
@@ -5485,7 +5399,7 @@
OUTPUT: None.
-
+
@@ -5530,7 +5444,7 @@
MACHINE CODE: 103F 2A
-INPUT: (X) - Zero to remove device from table, or the address of a
+INPUT: (X) = Zero to remove device from table, or the address of a
packet as defined below to add a device to
@@ -5546,15 +5460,15 @@
(X+21 - priority
-(U) - Address of service routine's static Storage area
-
-(Y) - Device IRQ service routine address
+(U) = Address of service routine's static Storage area
+
+(Y) = Device IRQ service routine address
(D) = Address of the device status register
OUTPUT: None
-
+
@@ -5640,11 +5554,11 @@
INPUT: (K) = Address of the base page.
-(A) - Block number.
+(A) = Block number.
OUTPUT: None
-
+
@@ -5685,11 +5599,11 @@
MACHINE CODE: 103F 28
-INPUT: (D) - Byte count.
+INPUT: (D) = Byte count.
OUTPUT: (U) = Beginning address ,of memory area
-
+
@@ -5732,7 +5646,7 @@
MACHINE CODE: 103F 29
-
+
@@ -5767,7 +5681,7 @@
ASSEMBLER CALL: OS9
-
+
@@ -5804,16 +5718,7 @@
ATTACH Attach a new device to the system. I$ATCH
-MACHINE CODE: 103F 80
-
-
-INPUT: (X) - Address of device name string
-
-(A) - Access mode
-
-OUTPUT: (U) = Address of device table entry
-
-
+
@@ -5822,15 +5727,16 @@
MACHINE CODE:
- 103F
+ 103F 80
INPUT:
-
+ (X) = Address of device name string
+(A) = Access mode.
OUTPUT:
-
+ (U) = Address of device table entry
ERROR OUTPUT:
@@ -5852,43 +5758,34 @@
their address' in a new device table entry. Any permanent storage
needed by the device driver is allocated, and the driver's
initialization routine is called (which usually initializes the
-hardware)
+hardware).
If the device has already been attached, it will not be
-reinitialized
+reinitialized.
An ATTACH system call is not required to perform routine I/O. It
does NOT reserve' the device in question - it just prepares it for
subsequent use by any process. Most devices are automatically
installed, so it is used mostly when devices are dynamically
-installed or to verify the existence of a device
+installed or to verify the existence of a device.
The access mode parameter specifies which subsequent read and/or
-write operations will be permitted as follows:
-
-
-0 = Use device capabilities
-
-1 = Read only
-
-2 a = Write only
-
-3 a = Both read and write
+write operations will be permitted as follows:
+
+
+0 = Use device capabilities.
+
+1 = Read only.
+
+2 = Write only.
+
+3 = Both read and write.
CHDIR Change working directory. I$CDIR
-MACHINE CODE: 103F 86
-
-
-INPUT: (X) - Address of the pathlist
-
-(A) - Access mode
-
-OUTPUT: None
-
-
+
@@ -5897,15 +5794,16 @@
MACHINE CODE:
- 103F
+ 103F 86
INPUT:
-
+ (X) = Address of the pathlist.
+(A) = Access mode.
OUTPUT:
-
+ None.
ERROR OUTPUT:
@@ -5921,9 +5819,9 @@
current execution or the current data directory may be changed (but
only one may be changed per call). The file specified must be a
directory file, and the caller must have read permission for it
-(public read if not owned by the calling process)
-
-ACCESS MODES
+(public read if not owned by the calling process).
+
+ACCESS MODES
1 = Read
@@ -5936,20 +5834,13 @@
If the access mode is read, write, or update the current data
directory is changed. If the access mode is execute, the current
-execution directory is changed
+execution directory is changed.
CLOSE Close a path to a file/device. I$CLOS
-MACHINE CODE: 103F 8F
-
-
-INPUT: (A) = Path number
-
-OUTPUT: None
-
-
+
@@ -5958,15 +5849,15 @@
MACHINE CODE:
- 103F
+ 103F 8F
INPUT:
-
+ (A) = Path number.
OUTPUT:
-
+ None.
ERROR OUTPUT:
@@ -5981,33 +5872,20 @@
longer be performed to the file/device, unless another OPEN or CREATE
call is used. Devices that are non-sharable become available to other
requesting processes. All OS-9 internally managed buffers and
-descriptors are deallocated
+descriptors are deallocated.
Note: Because the OS9 F$EXIT service request automatically closes
all open paths (except the standard I/O paths), it may not he
-necessary to close them individually with the OS9 I$CLOS service r eq
-U e St
+necessary to close them individually with the OS9 I$CLOS service request.
Standard I/O paths are not typically closed except when it is
-desired to change the files/devices they correspond to
+desired to change the files/devices they correspond to.
CREATE Create a path to a new file. I$CREA
-MACHINE CODE: 103F 83
-
-
-INPUT: (N) = Address of the pathlist
-
-(A) - Access mode
-
-(B) = File attributes
-
-OUTPUT: (X) = Updated past the pathlist (trailing blanks skipped)
-(A) = Path number
-
-
+
@@ -6016,15 +5894,18 @@
MACHINE CODE:
- 103F
+ 103F 83
INPUT:
-
+ (X) = Address of the pathlist.
+(A) = Access mode.
+(B) = File attributes.
OUTPUT:
-
+ (X) = Updated past the pathlist (trailing blanks skipped)
+(A) = Path number.
ERROR OUTPUT:
@@ -6035,61 +5916,56 @@
-Used to create a new file on a mnu~1tifiIe mass storage device,
+Used to create a new file on a multifiIe mass storage device.
The pathlist is parsed, and the new file name is entered in the
specified (or default working) directory. The file is given the
attributes passed in the B register, which has individual bits
-defined as follows
-
-bit 0 = read permit
-
-
-bit 3. = write permit bit 2 = execute permit bit 3 = public read
-permit bit 4 = public write permit bit $ - public execute permit bit
-6 = sbarable file
-
+defined as follows:
+
+bit 0 = read permit
+bit 1 = write permit
+bit 2 = execute permit
+bit 3 = public read permit
+bit 4 = public write permit
+bit 5 - public execute permit
+bit 6 = sharable file
+
The access mode parameter passed in register A must be either
"WRITE" or "UPDATE". This only affects the file
until it is closed; it can be reopened later in any access mode
allowed by the file attributes (see OPEN). Files open for "WRITE"
-may allow faster dat~i transfer than "UPDATE", which
-sometimes needs to pre- read setors. These access codes are defined
-as given below:
-
-
-2 = Write only
-
-3 = Update (read and write)
+may allow faster data transfer than "UPDATE", which
+sometimes needs to preread setors. These access codes are defined
+as given below:
+
+
+2 = Write only
+3 = Update (read and write)
+
NOTE: If the execute bit (bit 2) is set, the file will be created
in the working execution directory instead of the working data
-directory
+directory.
The path number returned by OS-9 is used to identify the file in
-subsequent I/O service requests until the file is closed
+subsequent I/O service requests until the file is closed.
No data storage is initially allocated for the file at the time it
is created; this is done automatically by WRITE or explicitly by the
-PUTSTAT call
+PUTSTAT call.
An error will occur if the file name already exists in the
directory. CREATE calls that specify non-multiple file devices (such
as printers, terminals, etc.) work correctly: the CREATE behaves the
same as OPEN. Create cannot be used to make directory files (see
-MAKDIR)
+MAKDIR).
DELETE Delete a file. I$DLET
-MACHINE CODE: 103F 87
-
-INPUT: (K) = Address of pathlist.
-
-OUTPUT: (X) = Updated past pathlist (trailing spaces skipped).
-
-
+
@@ -6098,15 +5974,15 @@
MACHINE CODE:
- 103F
+ 103F 87
INPUT:
-
+ (X) = Address of pathlist.
OUTPUT:
-
+ (X) = Updated past pathlist (trailing spaces skipped).
ERROR OUTPUT:
@@ -6117,8 +5993,8 @@
-This service request deletes the file specified by the pathlist,
-The file must have write permission attributes (public write if ~ot
+This service request deletes the file specified by the pathlist.
+The file must have write permission attributes (public write if not
the owner), and reside on a multifile mass storage device. Attempts
to delete devices will result in an error.
@@ -6126,13 +6002,7 @@
DETACH Remove a device from the system. I$DTCH
-MACHINE CODE: 103F 81
-
-INPUT: (U) = Address of the device table entry.
-
-OUTPUT: None.
-
-
+
@@ -6141,15 +6011,15 @@
MACHINE CODE:
- 103F
+ 103F 81
INPUT:
-
+ (U) = Address of the device table entry.
OUTPUT:
-
+ None.
ERROR OUTPUT:
@@ -6168,22 +6038,14 @@
The I$DTCH service request must be used to un-attach devices that
were attached with the I$ATCH service request. Both of these are used
-mainly by IOHAN and are of limited (or no use) to the typical user,
-SCFMAN also uses ATTACH/DETACH to setup its second (echo) devile
-
+mainly by IOMAN and are of limited (or no use) to the typical user,
+SCFMAN also uses ATTACH/DETACH to setup its second (echo) device.
DUP Duplicate a path. I$DUP
-MACHINE CODE: 103F 82
-
-INPUT: (A) = Path number of path to duplicate.
-
-OUTPUT: (B) = New path number.
-
-
-
+
@@ -6192,15 +6054,15 @@
MACHINE CODE:
- 103F
+ 103F 82
INPUT:
-
+ (A) = Path number of path to duplicate.
OUTPUT:
-
+ (B) = New path number.
ERROR OUTPUT:
@@ -6224,7 +6086,7 @@
GETSTAT Get file device status. I$GSTT
-
+
@@ -6238,7 +6100,7 @@
INPUT:
(A) = Path number.
-(B) Status code
+(B) Status code.
(Other registers depend upon status code)
@@ -6254,12 +6116,235 @@
+This system is a "wild card" call used to handle individual
+device parameters that:
+
+are not uniform on all devices
+are highly hardware dependent
+need to be user-changable
+
+
+The exact operation of this call depends on the device driver an
+file manager associated with the path. A typical use is to
+determine a terminal's parameters for backspace character, delete
+character, echo on/off, null padding, paging, etc. It is commonly
+used in conjunction with the SETSTAT service request which is
+used to set the device operating parameters. Below are presently
+defined function codes for GETSTAT:
+
+
+
+
+
+MNEMONIC
+CODE
+FUNCTION
+
+
+
+
+SS.OPT
+0
+Read the 32 byte option section of the path descriptor.
+
+
+SS.RDY
+1
+Test for data ready on SCFMAN-type device.
+
+
+SS.SIZ
+2
+Return current file size (on RBFMAN-type devices).
+
+
+SS.POS
+5
+Get current file position.
+
+
+SS.EOF
+6
+Test for end of file.
+
+
+
+
+
+CODES 7-127 Reserved for future use
+
+CODES 128-255 These getstat codes and their parameter passing
+conventions are user definable (see the sections of this manual on
+writing device drivers). The function code and register stack are
+passed to the device driver.
+
+Parameter Passing Conventions
+
+The parameter passing conventions for each of these function codes
+are given below:
+
+
+
+
+
+ SS.OPT (code 0):
+ Read option section of the path descriptor.
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 0
+(X) = Address of place to put a 32 byte status packet.
+
+
+ OUTPUT:
+ Status packet.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+This getstat function reads the option section of the path
+descriptor and copies it into the 32 byte area pointed to by the X
+register. It is typically used to determine the current settings for
+echo, auto line feed, etc. For a complete description of the
+status packet, please see the section of this manual on path
+descriptors.
+
+
+
+
+
+ SS.RDY (code 1):
+ Test for data available on SCFMAN supported devices.
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 1
+
+
+ OUTPUT:
+
+
+
+ Ready
+ Not Ready
+ Error
+
+
+ (CC)
+ C bit clear
+ C bit set
+ C bit set
+ (B)
+ zero
+ $F6 (E$NRDY)
+ ERROR Code
+
+
+
+
+
+
+
+
+
+
+ SS.SIZ (code 2):
+ Get current file size (RBFMAN supported devices only)
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 2
+
+
+ OUTPUT:
+ (X) = M.S. 16 bits of current file size.
+(U) = L.S. 16 bits of current file size.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+
+
+
+ SS.POS (code 5):
+ Get current file position (RBFMAN supported devices only)
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 5
+
+
+ OUTPUT:
+ (X) = M.S. 16 bits of current file position.
+(U) = L.S. 16 bits of current file position.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+
+
+
+
+ SS.EOF (code 6):
+ Test for end of file.
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 6
+
+
+ OUTPUT:
+
+
+
+ Not EOF
+ EOF
+ Error
+
+
+ (CC)
+ C bit clear
+ C bit set
+ C bit set
+ (B)
+ zero
+ $D3 (E$EOF)
+ ERROR Code
+
+
+
+
+
+
MAKDIR Make a new directory
-
+
@@ -6272,11 +6357,12 @@
INPUT:
-
+ (X) = Address of pathlist.
+(B) = Directory attributes.
OUTPUT:
-
+ (X) = Updated path pathlist (trailing spaces skipped).
ERROR OUTPUT:
@@ -6286,12 +6372,34 @@
-
+MAKDIR is the only way a new directory file can be created. It
+will create and initialize a new directory as specified by the
+pathlist. The new directory file contains no entries, except for
+an entry for itself (".") and its parent directory ("..")
+
+The caller is made the owner of the directory. MAKDIR dies not
+return a path number because directory files are not "opened" by
+this request (use OPEN to do so). The new directory will
+automatically have its "directory" bit set in the access
+permission attributes. The remaining attributes are specified by
+the byte passed in the B register, which has individual bits
+defined as follows:
+
+
+bit 0 = read permit
+bit 1 = write permit
+bit 2 = execute permit
+bit 3 = public read permit
+bit 4 = public write permit
+bit 5 - public execute permit
+bit 6 = sharable file
+bit 7 = (don't care)
+
OPEN Open a path to a file or device
-
+
@@ -6304,11 +6412,13 @@
INPUT:
-
+ (X) = Address of pathlist.
+(A) = Access mode (D S PE PW PR E W R)
OUTPUT:
-
+ (X) = Updated past pathlist (trailing spaces skipped).
+(A) = Path number.
ERROR OUTPUT:
@@ -6318,12 +6428,49 @@
+
+Opens a path to an existing file or device as specified by the
+pathlist. A path number is returned which is used in subsequent
+service requests to identify the file.
+
+The access mode parameter specifies which subsequent read and/or
+write operation are permitted as follows:
+
+
+1 = read mode
+2 = write mode
+3 = update mode (both read and write)
+
+
+Update mode can be slightly slower because pre-reading of sectors
+may be required for random access of bytes within sectors. The
+access mode must conform to the access permission attributes
+associated with the file or device (see CREATE). Only the owner
+may access a file unless the appropiate "public permit" bits are
+set.
+
+Files can be opened by several processes (users) simultaneously.
+Devices have an attribute that specifies whether or not they are
+sharable on an individual basis.
+
+NOTES:
+
+If the execution bit is set in the access mode, OS-9 will begin
+searching for the file in the working execution directory (unless
+the pathlist begins with a slash).
+
+The sharable bit (bit 6) in the access mode can not lock other
+users out of file in OS-9 Level I. It is present only for
+upward compatibility with OS-9 Level II.
+
+Directory files may be read or written if the D bit (bit 7) is set
+in the access mode.
-READ Read data from a file or device
-
-
+READ Read data from a file or device I$READ
+
+
@@ -6336,11 +6483,13 @@
INPUT:
-
+ (X) = Address to store data.
+(Y) = Number of bytes to read.
+(A) = Path number.
OUTPUT:
-
+ (Y) = Number of bytes actually read.
ERROR OUTPUT:
@@ -6350,12 +6499,37 @@
+
+Reads a specified number of bytes from the path number given. The
+path must previously have been opened in READ or UPDATE mode. The
+data is returned exactly as read from the file/device without
+additional processing or editing such as backspace, line delete,
+end-of-file, etc.
+
+After all data in a file has been read, the next I$READ service
+request will return an end of file error.
+
+NOTES:
+
+The keyboard abort, keyboard interrupt, and end-of-file characters
+may be filtered out of the input data on SCFMAN-type devices
+unless the coresponding entries in the path descriptor have been
+set to zero. It may be desirable to modify the device descriptor
+so that these values in the path descriptor are initialized to
+zero when the path is opened.
+
+The number of bytes requested will be read unless:
+
+A. An end-of-file occurs
+B. An end-of-record occurs (SCFMAN only)
+C. An error condition occurs.
+
-READLN Read a text line with editing
-
-
+READLN Read a text line with editing. I$RDLN
+
+
@@ -6364,15 +6538,17 @@
MACHINE CODE:
- 103F
+ 103F 8B
INPUT:
-
+ (X) = Address to store data.
+(Y) = Number of bytes to read.
+(A) = Path number.
OUTPUT:
-
+ (Y) = Actual number of bytes read.
ERROR OUTPUT:
@@ -6382,12 +6558,29 @@
+
+This system call is the same as "READ" except it reads data from
+the input file or device until a carriage return character is
+encountered or until the maximum byte count specified is reached,
+and that line editing will occur on SCFMAN-type devices. Line
+editing refers to backspace, line delete, echo automatic line
+feed, etc.
+
+SCFMAN requires that the last byte entered be an end-of-record
+character (normally carriage return). If more data is entered
+than the maximum specified, it will not be accepted and a PD.OVF
+character (normally bell) will be echoed.
+
+After all data in the file has been read, the next I$RDLN service
+request will return an end of file error.
+
+NOTE: For more information on line editing, see 7.1.
-SEEK Reposition the logical file pointer
-
-
+SEEK Reposition the logical file pointer I$SEEK
+
+
@@ -6400,11 +6593,59 @@
INPUT:
-
+ (A) = Path number.
+(X) = M.S. 16 bits of desired file position.
+(U) = L.S. 16 bits of desired file position.
OUTPUT:
-
+ None.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+This system call repositions the path's "file pointer"; which is
+the 32-bit addres of the next byte in the file to be read
+from or written to.
+
+A seek may be performed to any value even if the file is not large
+enough. Subsequent WRITEs will automatically expand the file to
+the required size (if possible), but READs will return an end-of-file
+condition. Note that a SEEK to address zero is the same as a
+"rewind" operation.
+
+Seeks to non-random access devices are usually ignored and return
+without error.
+
+
+
+SETSTAT Set file/device status I$SSTT
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 I$SSTT
+
+
+ MACHINE CODE:
+ 103F 8E
+
+
+ INPUT:
+ (A) = Path number.
+(B) Function code.
+(Other registers depend upon function code)
+
+
+ OUTPUT:
+ (depends upon function code)
ERROR OUTPUT:
@@ -6414,54 +6655,230 @@
-
-
-
-SETSTAT Set file/device status
-
+This system is a "wild card" call used to handle individual
+device parameters that:
+
+are not uniform on all devices
+are highly hardware dependent
+need to be user-changable
+
+
+The exact operation of this call depends on the device driver and
+file manager associated with the path. A typical use is to
+set a terminal's parameters for backspace character, delete
+character, echo on/off, null padding, paging, etc. It is commonly
+used in conjunction with the GETSTAT service request which is
+used to read the device operating parameters. Below are presently
+defined function codes:
+
+
+
+
+
+MNEMONIC
+CODE
+FUNCTION
+
+
+
+
+SS.OPT
+$0
+Write the 32 byte option section of the path descriptor
+
+
+SS.SIZ
+$2
+Set the file size (RBF)
+
+
+SS.RST
+$3
+Restore head to track zero (RBF)
+
+
+SS.WRT
+$4
+Write (format) track (RBF)
+
+
+SS.FEE
+$9
+Issue Form Feed (SCF)
+
+
+SS.FRZ
+$A
+Freeze DD. Information (RBF)
+
+
+SS.SPT
+$B
+Set Sectors per track (RBF)
+
+
+SS.SQD
+$C
+Sequence down disk drive (RBF)
+
+
+SS.DCM
+$D
+Direct command to hard disk controller (RBF)
+
+
+
+
+
+Codes 128 through 255 their parameter passing
+conventions are user definable (see the sections of this manual on
+writing device drivers). The function code and register stack are
+passed to the device driver.
+
+
- ASSEMBLER CALL:
- OS9 I$SSTT
-
-
- MACHINE CODE:
- 103F
+ SS.OPT (code 0):
+ Write option section of the path descriptor.
INPUT:
-
+ (A) = Path number
+(B) = Function code 0
+(X) = Address of a 32 byte status packet.
OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
+ None.
+This setstat function writes the option section of the path
+descriptor from the 32 byte status packet pointed to by the X
+register. It is typically used to set the device operating
+parameters, such as echo, auto line feed, etc.
+
+
+
+
+
+ SS.SIZ (code 2):
+ Set the file size (RBF)
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 2
+(X) = M.S. 16 bits of desired file size.
+(U) = L.S. 16 bits of desired file size.
+
+
+ OUTPUT:
+ None.
+
+
+
+
+
+This setstat function is used to change the file's size.
+
+
+
+
+ SS.RST (code 3):
+ Set the file size (RBF)
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 3
+
+
+ OUTPUT:
+ None.
+
+
+
+
+
+Home disk head to track zero. Used for formatting and
+for error recovery.
+
+
+
+
+
+ SS.WTK (code 4):
+ Write track
+
+
+ INPUT:
+ (A) = Path number
+(B) = Function code 4
+(X) = Address of track buffer.
+(U) = Track number (L.S. 8 bits)
+(Y) = Side/density
+ Bit B0 = SIDE (0 = side zero, 1 = side one)
+ Bit B1 = DENSITY (0 = single, 1 = double)
+
+
+ OUTPUT:
+ None.
+
+
+
+
+
+This code causes a format track (most floppy disks)
+operation to occur. For hard disks or floppy disks with a "format
+entire disk" command, this command should format the entire media
+only when the track number equals zero.
+
+
+
+
+
+ SS.FRZ (code $A):
+ Freeze DD. Information
+
+
+ INPUT:
+ none
+
+
+ OUTPUT:
+ none
+
+
+
+
+
+Inhibits the reading of identification sector (LSN 0) to
+DD.xxx variables (that define disk formats) so non-standard disks
+may be read.
+
+
+
+
+ SS.SPT (code $B):
+ Set Sectors Per Track
+
+
+ INPUT:
+ X = new sectors per track
+
+
+
+
WRITE Write Data to File or Device I$WRITE
-/3- Path number
-
-
-INPUT: ~" dl .1 Number of bytes to write (aO) Address of
-buffer
-
-
-OUTPUT: I did Number of bytes actually written
-
-
-
+
@@ -6473,12 +6890,13 @@
103F 8A
- INPUT:
-
+ (A) = Path number.
+(X ) = Address of buffer.
+(Y) = Maximum number of bytes to write
OUTPUT:
-
+ (Y) = Actual number of bytes written.
ERROR OUTPUT:
@@ -6491,37 +6909,19 @@
DESCRIPTION:
-I$Write outputs bytes to a file or device associated with the path
+I$WRITE outputs bytes to a file or device associated with the path
number specified. The path must have been opened or created in the
write or update access modes.
Data is written to the tile or device without processing or
-editing. If data is written past the present end~of~file, the file is
+editing. If data is written past the present end-of-file, the file is
automatically expanded.
-
-NOTE: The IOMan module implements I$Write.
-
-
-NOTE: On RBF devices, any record that was locked is released.
-
-
-
-WritLn Write Line of Text with Editing
-
-INPUT: (A) Path number
-
-
-(Y) = Maximum number of bytes to write
-
-(X ) = Address of buffer
-
-
-OUTPUT: (Y) Actual number of bytes written
-
-
+WritLn Write Line of Text with Editing I$WRLN
+
+
@@ -6534,11 +6934,13 @@
INPUT:
-
+ (A) = Path number.
+(X ) = Address of buffer.
+(Y) = Maximum number of bytes to write
OUTPUT:
-
+ (Y) = Actual number of bytes written
ERROR OUTPUT:
@@ -6549,23 +6951,17 @@
-I$WritLn is similar to I$Write except it writes data until a
-carriage return character or (di) bytes are encountered. Line editing
-is also activated for character~oriented devices such as terminals,
+I$WRLN is similar to I$Write except it writes data until a
+carriage return character or (Y) bytes are encountered. Line editing
+is also activated for character-oriented devices such as terminals,
printers, etc. The line editing refers to auto line feed, null
-padding at en&of line, etc.
-
-The number of bytes actually written (returned in dl .1) does not
+padding at end of line, etc.
+
+The number of bytes actually written (returned in Y) does not
reflect any additional bytes that may have been added by file
managers or device drivers for device control. For example, if SCF
appends a line feed and nulls after carriage return characters, these
-extrt bytes are not counted,
-
-
-
-NOTE: On RBF devices, any record that was locked is released.
-
-NOTE: The IOMan module implements I$WritLn
+extrt bytes are not counted.
@@ -6983,8 +7379,213 @@
Error Codes
-
-These did not OCR well
+
+OS-9 Error Codes
+
+
+
+ $
+ 200
+ PATH TABLE FULL -
+
+ $
+ 201
+ ILLEGAL PATH NUMBER -
+
+ $
+ 202
+ INTERRUPT POLLING TABLE FULL -
+
+ $
+ 203
+ ILLEGAL MODE -
+
+ $
+ 204
+ DEVICE TABLE FULL -
+
+ $
+ 205
+ ILLEGAL MODULE HEADER -
+
+ $
+ 206
+ MODULE DIRECTORY FULL -
+
+ $
+ 207
+ MEMORY FULL -
+
+ $
+ 208
+ ILLEGAL SERVICE REQUEST -
+
+ $
+ 209
+ MODULE BUSY -
+
+ $
+ 210
+ BOUNDARY ERROR -
+
+ $
+ 211
+ END OF FILE -
+
+ $
+ 212
+ RETURNING NON-ALLOCATED MEMORY -
+
+ $
+ 213
+ NON-EXISTING SEGMENT -
+
+ $
+ 214
+ NO PERMISSION -
+
+ $
+ 215
+ BAD PATH NAME -
+
+ $
+ 216
+ PATH NAME NOT FOUND -
+
+ $
+ 217
+ SEGMENT LIST FULL -
+
+ $
+ 218
+ FILE ALREADY EXISTS -
+
+ $
+ 219
+ ILLEGAL BLOCK ADDRESS -
+
+ $
+ 221
+ MODULE NOT FOUND -
+
+ $
+ 223
+ SUICIDE ATTEMPT -
+
+ $
+ 224
+ ILLEGAL PROCESS NUMBER -
+
+ $
+ 226
+ NO CHILDREN -
+
+ $
+ 227
+ ILLEGAL SWI CODE -
+
+ $
+ 228
+ PROCESS ABORTED -
+
+ $
+ 229
+ PROCESS TABLE FULL -
+
+ $
+ 230
+ ILLEGAL PARAMETER AREA -
+
+ $
+ 231
+ KNOWN MODULE -
+
+ $
+ 232
+ INCORRECT MODULE CRC -
+
+ $
+ 233
+ SIGNAL ERROR -
+
+ $
+ 234
+ NON-EXISTENT MODULE -
+
+ $
+ 235
+ BAD NAME -
+
+ $
+ 237
+ RAM FULL -
+
+ $
+ 238
+ UNKNOWN PROCESS ID -
+
+ $
+ 239
+ NO TASK NUMBER AVAILABLE -
+
+ $
+ 240
+ UNIT ERROR -
+
+ $
+ 241
+ SECTOR ERROR -
+
+ $
+ 242
+ WRITE PROTECT -
+
+ $
+ 243
+ CRC ERROR -
+
+ $
+ 244
+ READ ERROR -
+
+ $
+ 245
+ WRITE ERROR -
+
+ $
+ 246
+ NOT READY -
+
+ $
+ 247
+ SEEK ERROR -
+
+ $
+ 248
+ MEDIA FULL -
+
+ $
+ 249
+ WRONG TYPE -
+
+ $
+ 250
+ DEVICE BUSY -
+
+ $
+ 251
+ DISK ID CHANGE -
+
+ $
+ 252
+ RECORD IS LOCKED-OUT -
+
+ $
+ 253
+ NON-SHARABLE FILE BUSY -
+
+
+
@@ -6995,11 +7596,8 @@
Level Two System Service Requests
-$3A*F$AllImg Allocate Image RAM blocks F$AllImg
-
-ASSEMBLER CALL: OS9 F$AllImg
-
-MACHINE CODE: 103F 3A
+$3A* F$AllImg Allocate Image RAM blocks F$AllImg
+
INPUT: (V B~~g block nu~er
@@ -7010,16 +7608,16 @@
Process Z~esc:iptor pointer
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$AllImg
MACHINE CODE:
- 103F
+ 103F 3A
INPUT:
@@ -7054,7 +7652,7 @@
INPUT:
-
+
@@ -7098,7 +7696,7 @@
U) a Desr~re~ block crocnt a t~eVto~ng PAM block numier
-
+
@@ -7137,23 +7735,20 @@
AlhC ~sk Allocate process Task number
-ASSEMBLER CALL: OS9 F$AllTsk
-
-MACHINE CODE: 103F 3F
X a Process Descrrptor pointer
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$AllTsk
MACHINE CODE:
- 103F
+ 103F 3F
INPUT:
@@ -7180,13 +7775,13 @@
-Bootstrap syste~r F$Bcc t
+Bootstrap syste~r F$Boot
ASSEMBLER CALL: OS9 F$Boot
MACHINE CODE: 103F
-
+
@@ -7223,20 +7818,19 @@
-Bootstrap M~ory request OS9 F$13tMen
+Bootstrap M~ory request OS9 F$BtMem
ASSEMBLER CALL: OS9
-MACHINE CODE: 103F 36
-
-U a Byte count reouested~
-
-
-U - Byte count cran~ed~
+
+U = Byte count reouested~
+
+
+U = Byte count cran~ed~
- p~ ~ter to memory sIlo ~ated~
-
+
@@ -7245,7 +7839,7 @@
MACHINE CODE:
- 103F
+ 103F 36
INPUT:
@@ -7274,7 +7868,7 @@
Clear specific Block
-ASSEMBLER CALL: OS9 F$CIrBlk
+ASSEMBLER CALL: OS9 F$ClrBlk
MACHINE CODE: 103F
@@ -7285,7 +7879,7 @@
aAl~ess of first block
-
+
@@ -7321,9 +7915,6 @@
Copy external Memory F$CpyMem
-ASSEMBLER CALL: OS9 F$CpyMem
-
-MACHINE CODE: 103F
~F V (D)-Start~ng Memory Block number
@@ -7331,12 +7922,12 @@
~X aCftset ~n block to begin copy QU -Byte count
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$CpyMem
MACHINE CODE:
@@ -7368,7 +7959,6 @@
ASSEMBLER CALL: OS9 Y~ATLcg
-MACHINE CODE: 103F 44
P - ~AT xmaqe offset
- Block offset
@@ -7376,52 +7966,7 @@
I - ~oqic&~. address~
-
-
-
-
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
-
-
- INPUT:
-
-
-
- OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
-
-
-
-
-
-a DAT inaqe block n~ber and block offset V.
-a oo Al addreza~
-
-NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
-
-
-
-Make Temporary DAT riuace
-
-ASSEMBLER CALL: OS9 F$~DATTmp
-
-
-MACHINE CODE: 103F 45
-
-
-U V. a Block number
-7 - ~AT ~na~e porrter
-
+
@@ -7430,77 +7975,7 @@
MACHINE CODE:
- 103F
-
-
- INPUT:
-
-
-
- OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
-
-
-
-
-
-~pora~; DAD r~age to access ins given memory bloc
-
-NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
-
-
-
-
-$3B* F$DelImg Deallocate tmaqe RAM blocks F$DelImg
-
-
-
-
-
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
-
-
- INPUT:
-
-
-
- OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
-
-
-
-
-
-
-
-
-$4C* Deallocate Process descriptor F$DelPrc
-
-
-
-
-
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
+ 103F 44
INPUT:
@@ -7519,25 +7994,141 @@
+Converts a DAT imaqe block number and block offset to its
+equivalent logical address.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
-Deallocate RAM blocks
-
-
+$45* F$DATTmp Make Temporary DAT image F$DATTmp
+
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 F$DATTmp
+
+
+ MACHINE CODE:
+ 103F 45
+
+
+ INPUT:
+ (D) = Block number
+
+
+ OUTPUT:
+ (Y) = DAT image pointer
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+Builds a temporary DAT image to access the given memory block.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
+
+
+
+$3B* F$DelImg Deallocate Imaqe RAM blocks F$DelImg
+
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$DelImg
+
+
+ MACHINE CODE:
+ 103F 3B
+
+
+ INPUT:
+ (A) = Beginning block number
+(B) = Block count
+(X) = Process Descriptor pointer
+
+
+ OUTPUT:
+ None.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+Deallocated memory from the process' address space.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
+
+
+$4C* Deallocate Process descriptor F$DelPrc
+
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 F$DelPrc
MACHINE CODE:
- 103F
+ 103F 4C
INPUT:
-
+ (A) = Process ID.
+
+
+ OUTPUT:
+ None.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+Returns process descriptor memory to system free memory pool.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
+
+
+Deallocate RAM blocks
+
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 F$DelRam
+
+
+ MACHINE CODE:
+ 103F 51
+
+
+ INPUT:
+ (B) = Number of blocks
+(X) = Beginning block number.
OUTPUT:
@@ -7552,21 +8143,58 @@
Marks blocks in system memory block map as unallocated.
+
NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
$40* F$DelTsk Deallocate process Task number F$DelTsk
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$DelTsk
MACHINE CODE:
- 103F
+ 103F 40
+
+
+ INPUT:
+ (X) = Process Descriptor pointer
+
+
+ OUTPUT:
+ None.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+Releases the Task number in use by the process.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
+
+
+
+$4D* F$ELink Link using module directory Entry F$ELink
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 F$ELink
+
+
+ MACHINE CODE:
+ 103F 4D
INPUT:
@@ -7585,20 +8213,67 @@
+Performs a "Link" given a pointer to a module directory entry. Note
+that this call differs from F$Link in that a pointer to the module
+directory entry is supplied rather than a pointer to a module name.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
-$4D* F$ELink Link using module directory Entry F$ELink
-
+$4E* F$FModul Find Module directory entry F$FModul
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$FModul
MACHINE CODE:
- 103F
+ 103F 4E
+
+
+ INPUT:
+ (A) = Module type.
+(X) = Module Name string pointer.
+(Y) = Name string DAT image pointer.
+
+
+ OUTPUT:
+ (A) = Module Type.
+(B) = Module Revision.
+(X) = Updated past name string.
+(U) = Module directory entry pointer.
+
+
+ ERROR OUTPUT:
+ (CC) = C bit set.
+(B) = Appropriate error code.
+
+
+
+
+
+This call returns a pointer to the module directory entry given the
+module name.
+
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
+
+
+
+$3E* F$FreeHB get Free High block F$FreeHB
+
+
+
+
+ ASSEMBLER CALL:
+ OS9 F$FreeHB
+
+
+ MACHINE CODE:
+ 103F 3E
INPUT:
@@ -7617,79 +8292,13 @@
-a a Ltrt3V given a pointer to a. module directory entry~ Note oail
-differs from F$Link in that a pointer to the inodc~e
-rec~ . ~y
-ent~y is supplied rather than a pointer to a module name
-
-
-
-$4E* F$FModul Find Module directory entry F$FModul
-
-
-
-
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
-
-
- INPUT:
-
-
-
- OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
-
-
-
-
-
-
-
-
-$3E* F$FreeHB get Free High block F$FreeHB
-
-
-
-
- ASSEMBLER CALL:
- OS9 F$
-
-
- MACHINE CODE:
- 103F
-
-
- INPUT:
-
-
-
- OUTPUT:
-
-
-
- ERROR OUTPUT:
- (CC) = C bit set.
-(B) = Appropriate error code.
-
-
-
-
+NOTE: THIS IS A PRIVILEGED SYSTEM MODE SERVICE REQUEST
$3D* F$FreeLB get Free Low block F$FreeLB
-
+
@@ -7724,12 +8333,12 @@
$19 F$GBlkMp Get system Block Map copy F$GBlkMp
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$GBlkMp
MACHINE CODE:
@@ -7757,16 +8366,16 @@
$1A F$GModDr Get Module Directory copy F$GModDr
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$GModDr
MACHINE CODE:
- 103F
+ 103F1A
INPUT:
@@ -7793,24 +8402,23 @@
$18 F$GPrDsc Get Process Descriptor copy F$GPrDsc
-ASSEMBLER CALL: OS9 F$GPrDsc
-
-MACHINE CODE: 103F 18
+
+
(A) a Requested process
ID.
- 512 byte buffer pointer>
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$GPrDsc
MACHINE CODE:
- 103F
+ 103F 18
INPUT:
@@ -7837,20 +8445,16 @@
$37* F$GProcP Get Process Pointer F$GProcP
-ASSEMBLER CALL: OS9 F$GIProcP
-
-MACHINE CODE: 103F 37
-
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$GProcP
MACHINE CODE:
- 103F
+ 103F 37
INPUT:
@@ -7879,16 +8483,16 @@
$49* F$LDABX Load A from 0,1 in task B F$LDABX
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$LDABX
MACHINE CODE:
- 103F
+ 103F 49
INPUT:
@@ -7922,16 +8526,16 @@
$46* F$LDAXY Load A [X, [Y] ] F$LDAXY
-
+
ASSEMBLER CALL:
- OS9 F$
+ OS9 F$LDAXY
MACHINE CODE:
- 103F
+ 103F 46
INPUT:
@@ -7964,7 +8568,7 @@
MACHINE CODE: 103F 47
-
+