Google
 

Trailing-Edge - PDP-10 Archives - ap-c800d-sb - gendcl.mac
There are 22 other files named gendcl.mac in the archive. Click here to see a list.
	UNIVERSAL GENDCL
	SUBTTL	LINKAGE MACROS



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
;
;COPYRIGHT (C) 1974, 1979 BY DIGITAL EQUIPMENT CORPORATION

	DEFINE SEGSYM<
	;;;	EXISTS SO THAT PASS 2 RE-INITS WILL OCCUR
	  OFFS.==0
	  LMREG.==0
	  LGREG.==16
	;;;	ALLOW GROUP OF MODULES TO HAVE SOME COMMON REGS (MU=MOD UNIV)
	  IFDEF MUREG.,<MREG.=MUREG.>
	  IFNDEF MUREG.,<MREG.==TREG.>
	  HMREG.==MREG.
	  HIGH==1
	>
	DEFINE SEGMEN<
	  TWOSEG
	  RELOC	0
	  GDATA.==0				;;FOR GDATA'S IFDEF TEST
	  SEGSYM
	>

	DEFINE SAVE (A)<
	IRP A,<	PUSH	P,A>>

	DEFINE RESTOR (A)<
	IRP A,<	POP	P,A>>

	DEFINE BLTSAV(LO.,HI.)<
	  HRRZ	R0,P
	  ADD	R0,[LO.,,1]		;;THE 1 GETS YOU TO 1ST UNUSED WORD ON STACK
	  BLT	R0,HI.(P)
	  T1.==HI.-LO.+1
	  ADD	P,[T1.,,T1.]		;;THE PUSH SIMULATION
	>
	DEFINE BLTPOP(LO.,HI.)<
	  T1.==HI.-LO.+1
	  SUB	P,[T1.,,T1.]
	  HRLZ	AP,P
	  ADD	AP,[1,,LO.]
	  BLT	AP,HI.
	>

	DEFINE SAVTMPS<SAVE<R2,R3,R4,R5>>
	DEFINE POPTMPS<RESTOR<R5,R4,R3,R2>>

	DEFINE	SAVALL <
	  IFN HMREG.-MREG.,<		;;ONLY DO SELF, IF CAN'T DO IN COM
	    T1.==TREG.
	    REPEAT <MREG.-TREG.>,<
	      T1.==T1.+1
	      SAVE	T1.
	    >
	    IFDEF UNWIND,<MOVEM P,UNWIND>
	    IFDEF MY.INI,<JSP R1,MY.INI>
	  >
	  IFE HMREG.-MREG.,<JSP	R1,SAV$A>
;;	HRRZ	R0,P
;;	ADD	R0,[2,,1]
;;	BLT	R0,16(P)
;;	ADD	P,D13D13##
	>

	DEFINE POPALL <
	T1.==MREG.
	REPEAT <MREG.-TREG.>,<
	  RESTOR	T1.
	  T1.=T1.-1
	>
;;	SUB	P,D13D13
;;	HRLZ	AP,P
;;	ADD	AP,[1,,2]
;;	BLT	AP,16
	>

	DEFINE LEAVE<POP$A+HMREG.-MREG.>
	DEFINE RETURN<
	  IFN MREG.-TREG.,<JRST	LEAVE>
	  IFE MREG.-TREG.,<POPJ	P,>
	>

	DEFINE $FUNCT(NAME,ARGLST)<
	IFG HIGH,<
	  RELOC	400000
	  HIGH==-1
	  IFG MREG.-TREG.,<
SAV$A:
	  T1.==TREG.
	  REPEAT <MREG.-TREG.>,<
	    T1.==T1.+1
	    SAVE	T1.
	  >
	  IFDEF UNWIND,<
	    MOVEM P,UNWIND
	    IFDEF UNWEXIT,<
	      IFDEF MY.EXIT,<COPI UNWEXIT,MY.EXIT>
	      IFNDEF MY.EXIT,<COPI UNWEXIT,POP$A-1>
	    >
	  >
	  IFDEF MY.INI,<JRST MY.INI>	;;MUST RETURN WITH JRST 0(R1)
	  IFNDEF MY.INI,<JRST	0(R1)>
	  >
	  IFDEF UNWEXIT,<IFNDEF MY.EXIT,<MOVE P,UNWIND>>
POP$A:
	  POPALL
	  POPJ	P,
	>

NAME:
	ENTRY NAME
	IFN LMREG.,<MREG.==LMREG.
			LMREG.==0>
	AOFF.=0
	IFNB <ARGLST>,<
	  IRP ARGLST,<
	  ARGLST=AOFF.
	  AOFF.=AOFF.+1
	  >
	>
	IFN MREG.-TREG.,<SAVALL>		;;KEYED BY MREG.
	IFE MREG.-TREG.,<
	  IFDEF UNWIND,<MOVEM P,UNWIND>
	  IFDEF MY.INI,<JSP R1,MY.INI>
	>
	>

	DEFINE $UTIL(NAME,ARGLST)<
NAME:
	IFE LMREG.,<LMREG.==MREG.>
	MREG.=TREG.			;;UTIL'S DON'T AFFECT MOD REGS
	AOFF.=0
	IFNB <ARGLST>,<
	  IRP ARGLST,<
	  ARGLST=AOFF.
	  AOFF.=AOFF.+1
	  >
	>
	>

	DEFINE $GLOYO(NAME,ARGLST)<
	IFG HIGH,<
	  RELOC	400000
	  HIGH==-1
	  MREG.==TREG.				;;IF A GLOYO FIRST GLOBAL ENTRY, THERE CAN BE NO FUNCTS
	  HMREG.==MREG.				;;...AND THEREFORE NO MODULE REGS
POP$A:
	  POPJ	P,
	>
NAME:
	ENTRY NAME
	IFE LMREG.,<LMREG.==MREG.>
	MREG.=TREG.			;;YOYO'S DON'T AFFECT MOD REGS
	>

	DEFINE $YOYO(NAME,ARGLST)<
NAME:
	IFE LMREG.,<LMREG.==MREG.>
	MREG.=TREG.			;;YOYO'S DON'T AFFECT MOD REGS
	>


	DEFINE GLOYO(PROG,ARGLST)<
	IF2, <IFNDEF PROG,<EXTERNAL PROG>>
	PUSHJ	P,PROG		;;ARGLST JUST FOR DOC
	>

	DEFINE YOYO(PROG,ARGLST)<
	PUSHJ	P,PROG		;;ARGLST JUST FOR DOC
	>

	;;;	SAME EXCEPT MUST PRESERVE SUBSYS (IE. SAVE R2-R5)
	SYN	$FUNCT,$LINK
	SYN	FUNCT,LINK


	DEFINE FUNCT(PROG,ARGLST)<
	SALL
	ARGS.=0
	IF2, <IFNDEF PROG,<EXTERNAL PROG>>
	  IFB <ARGLST>,<	PUSHJ P,PROG>
	  IFNB <ARGLST>,<
	  IRP ARGLST,<ARGS.=ARGS.+1>
	  MOVEI	AP,[-ARGS.,,0
	  IRP ARGLST,<ARGLST>
	  ]+1
	  PUSHJ	P,PROG
	  >
	>


	DEFINE UTIL(PROG,ARGLST)<
	SALL
	ARGS.=0
	  IFB <ARGLST>,<	PUSHJ P,PROG>
	  IFNB <ARGLST>,<
	  IRP ARGLST,<ARGS.=ARGS.+1>
	  MOVEI	AP,[-ARGS.,,0
	  IRP ARGLST,<ARGLST>
	  ]+1
	  PUSHJ	P,PROG
	  >
	>

	SYN $UTIL,$ULINK
	SYN UTIL,ULINK
	SUBTTL	DECLARATIVE MACROS FOR USER VARIABLES

	DEFINE GDATA(NAME,LEN)<
	  IFNDEF GDATA.,<EXTERN NAME>
	  IFDEF GDATA.,<
	    IFB<LEN>,<NAME:: BLOCK 1>
	    IFNB<LEN>,<NAME:: BLOCK LEN>
	  >
	>

	DEFINE DATA(NAME,LEN)<
	IFB<LEN>,<	NAME: BLOCK 1>
	IFNB<LEN>,<	NAME: BLOCK LEN>
	>

	DEFINE GREG(NAME,VALUE)<		;;GLOBAL REG
	  IFB <VALUE>,<GREG.==GREG.-1>
	  IFNB <VALUE>,<GREG.==VALUE>
	  IFL GREG.-LGREG.,<LGREG.=GREG.>
	  NAME=GREG.
	  IFDEF .'NAME,<
	    IFN .'NAME+GREG.,<
	      PRINTX "NAME" ALTER-EGO ALREADY IN USE
	    >
	  >
	  IFNDEF .'NAME,<  .'NAME==-GREG.>
	>

	DEFINE MREG(NAME,VALUE)<		;;MODULE REG
	  IFN LMREG.,<MREG.==LMREG.
			LMREG.==0>
	  IFB <VALUE>,<MREG.==MREG.+1>
	  IFNB <VALUE>,<MREG.==VALUE>
	  IFB <NAME>,<MREG.=TREG.>
	  IFG MREG.-HMREG.,<HMREG.=MREG.>
	 IFNB <NAME>,<
	  NAME=MREG.
	  IFDEF .'NAME,<
	    IFN .'NAME+MREG.,<
	      PRINTX "NAME" ALTER-EGO ALREADY IN USE
	    >
	  >
	  IFNDEF .'NAME,<  .'NAME==-MREG.>
	 >
	>

	DEFINE REG(NAME,VALUE)<
	  NAME=VALUE
	  IFDEF .'NAME,<
	    IFN .'NAME+VALUE,<
	      PRINTX "NAME" ALTER-EGO ALREADY IN USE
	    >
	  >
	  IFNDEF .'NAME,<  .'NAME==-VALUE>
	>


	DEFINE ASP(NAM.,SIZ.,INIT.)<
	GETLEN	<INIT.>
NAM.:	POINT 7,.+2
	XWD	SIZ.,LEN.
	ASCII\INIT.\
	T1.==<LEN.+4>/5
	T1.==T1.*5
	T1.==SIZ.-T1.
	BLOCK	<<T1.+4>/5>
	>

	DEFINE BP(STRUC.,FIELD.,BASE.)<
	  POINT STRUC.'$'FIELD.,STRUC.'.'FIELD.'BASE.,STRUC.'%'FIELD.
	>
	DEFINE DUMMY(STRUC.,FIELDS,PFX.)<
	ONEBYT(STRUC.,FIELDS,PFX.)
	>
	DEFINE ONEBYT(STRUC.,FIELD.,SIZE.,PFX.)<
	  IFNB <PFX.>,<PFX.'.'FIELD.=OFFS.-STRUC.'.'PFX.>
	  STRUC.'.'FIELD.==OFFS.
	  STRUC.'$'FIELD.==SIZE.
	  POS.==POS.+SIZE.
	  STRUC.'%'FIELD.==POS.
	>
	DEFINE BYTES(STRUC.,FIELDS)<
	  POS.==-1
	  IRP FIELDS,<DUMMY(STRUC.,FIELDS)>
	  OFFS.==OFFS.+1
	>
	DEFINE BYTPFX(STRUC.,PFX.,FIELDS)<
	  POS.==-1
	  IRP FIELDS,<DUMMY(STRUC.,FIELDS,PFX.)>
	  OFFS.==OFFS.+1
	>
	DEFINE WORD(STRUC.,FIELDS)<
	  BYTES(STRUC.,<FIELDS>)
	  OFFS.==0
	>

	DEFINE FIELD(FIELD.,SIZE.)<
	  T1.=1
	  IFNB <SIZE.>,<
	    T1.==SIZE.
	    IFN 100000*T1.-100000*SIZE.,<T1.==T1.+1>
	  >
	  FIELD.=OFFS.
	  OFFS.==OFFS.+T1.
	>
	DEFINE PREFIX(STRUC.,PFX.,FIELD.,SIZE.)<
	  PFX.'.'FIELD.==OFFS.-STRUC.'.'PFX.
	  FIELD	(STRUC.'.'FIELD.,SIZE.)
	>

	DEFINE ARRAY(FIELD.,SIZE.)<
	  T1.==1
	  IFNB <SIZE.>,<
	    T1.==SIZE.
	    IFN 100000*T1.-100000*SIZE.,<T1.==T1.+1>
	  >
	  FIELD.==OFFS. - 1
	  OFFS.==OFFS.+T1.
	>

	DEFINE BLKSIZ(SIZID.)<
	  SIZID.==OFFS.
	  OFFS.==0
	>

	;;;	BORROWED FROM MACTEN...
	;MACRO TO COMPUTE THE WIDTH OF A MASK
	;	"WID" RETURNS THE LENGTH OF THE LEFTMOST STRING OF
	;	CONSECUTIVE ONES IN THE WORD.
	DEFINE	WID(MASK),<<^L<-<<MASK>_<^L<MASK>>>-1>>>

	;MACRO TO COMPUTE THE POSITION OF A MASK
	DEFINE	POS(MASK),<<^L<MASK>+^L<-<<MASK>_<^L<MASK>>>-1>-1>>

	;MACRO TO BUILD A POINTER TO A MASKED QUANTITY
	;	POINTR	LOCATION,MASK
	DEFINE	POINTR(LOC,MASK),<<POINT	WID(MASK),LOC,POS(MASK)>>

	;MACRO TO BUILD A MASK "WID" BITS WIDE, WITH ITS RIGHTMOST BIT
	;	IN THE BIT POSITION "POS".   (I.E. A MASK FOR THE BYTE
	;	POINTED TO BY THE BYTE POINTER "POINT  WID,LOC,POS")
	DEFINE	MASK.(WID,POS),<<<<1_<WID>>-1>B<POS>>>

	;MACRO TO DEFINE A SYMBOL IF NOT ALREADY DEFINED
	;	ND  SYMBOL,VALUE
	DEFINE	ND(SYMBOL,VALUE),<
	  IFNDEF	SYMBOL,<SYMBOL==VALUE>
	>

	SUBTTL DECLARATIVE MACROS FOR CONSTANT DATA

	DEFINE PATTRN(NAM.,STR.)<
	  STR.ST=.
	  BYTE (12)STR.
	  LEN.==0
	  IRP STR.,<LEN.==LEN.+1>
NAM.:	  POINT	^D12,STR.ST
	  XWD	0,LEN.
	>

	DEFINE MESSAG(NAM,ELEM)<
	EXP	[
	  IRP ELEM,<
	  ACT..=0
	    IRPC ELEM,<IFIDN <-><ELEM>,<ACT..=1>
				  STOPI>
	    IFN ACT..,<
	    ELEM
	    >
	    IFE ACT..,<
		GETLEN <ELEM>
		ADDR.==[EXP LEN.
			ASCIZ\ELEM\]
		EXP <ADDR.+1>
	    >
	  >
			0	]
	NAM:: MSG..
	MSG..=MSG..+2
	>

	DEFINE GETLEN(STRING)<
	  LEN.=0
	  IRPC STRING,<LEN.=LEN.+1>
	>

	DEFINE SETADDR(STRING)<
	 GETLEN	STRING
	  ADDR.=1B12 + [	LEN.
			 ASCII/STRING/]+1
	>

	DEFINE VARY(NAM)<1B12+NAM>
	DEFINE INT(WORD)<2B12+WORD>
	DEFINE ASZ(NAM.)<17B12+NAM.>

	DEFINE ZERO<[0]>
	DEFINE ONE<[1]>
	DEFINE TWO<[2]>
	DEFINE THREE<[3]>
	DEFINE FOUR<[4]>
	DEFINE FIVE<[5]>
	DEFINE SIX<[6]>

	DEFINE MLIT(STRIN)<
	17B12+[ASCIZ\STRIN\]
	>

	DEFINE STRIVRY(NAM,STRING)<
	GETLEN (<STRING>)
	EXP LEN.
NAM:	ASCII/STRING/
	>

	DEFINE STRIPT(STRING)<
	GETLEN (<STRING>)
	POINT	7,[ASCII\STRING\]
	EXP	LEN.
	>
	SUBTTL	PROCEDURAL MACROS

	DEFINE WHATYP(SYM)<
	SYM..==0
	  IRPC SYM,<
	  IFIDN <SYM><@>,<SYM..=1
			  STOPI>
	  IFIDN <SYM><(>,<SYM..=2
			  STOPI>
	  IFIDN <SYM><[>,<SYM..=3
			  STOPI>
	  IFIDN <SYM><+>,<SYM..=4
			  STOPI>
	  IFIDN <SYM><->,<SYM..=4
			  STOPI>
	  >
	  IFE SYM..,<
	    IFDEF .'SYM,<SYM..=-1>
	  >
	>

	DEFINE	CASE(REG,VECTOR)<
	  JRST	@[EXP .+1,VECTOR](REG)
	>

	DEFINE DBP(BP,BCNT)<		;;ASCII ONLY
	REPEAT 5-BCNT,<IBP	BP>
	SOS	BP
	>

	DEFINE TURNON(REG.,VAL.)<TXO	REG.,VAL.>
	DEFINE TURNOFF(REG.,VAL.)<TXZ REG.,VAL.>
	DEFINE TX(DESIG.,REG.,BIT.)<
	IFE BIT.&777777,<TL'DESIG.	REG.,(BIT.)>
	IFN BIT.&777777,<TR'DESIG.	REG.,BIT.>
	>
	DEFINE TXNE(A,B)<TX(NE,A,B)>
	DEFINE TXNN(A,B)<TX(NN,A,B)>
	DEFINE TXOA(A,B)<TX(OA,A,B)>
	DEFINE TXOE(A,B)<TX(OE,A,B)>
	DEFINE TXON(A,B)<TX(ON,A,B)>
	DEFINE TXO(A,B)<TX(O,A,B)>
	DEFINE TXZA(A,B)<TX(ZA,A,B)>
	DEFINE TXZE(A,B)<TX(ZE,A,B)>
	DEFINE TXZN(A,B)<TX(ZN,A,B)>
	DEFINE TXZ (A,B)<TX(Z,A,B)>
	DEFINE TXC (A,B)<TX(C,A,B)>

	DEFINE COPY(DEST,SORCE)<
	WHATYP	<DEST>
	IFE SYM..+1,<
	MOVE	DEST,SORCE>
	IFN SYM..+1,<
	  WHATYP <SORCE>
	  IFN SYM..+1,<
	  MOVE	0,SORCE
	  MOVEM	0,DEST>
	  IFE SYM..+1,<
	  MOVEM	SORCE,DEST>
	>
>

	DEFINE COPI(DEST,SORCE)<
	WHATYP	<DEST>
	IFE SYM..+1,<
	MOVEI	DEST,SORCE>
	IFN SYM..+1,<
	MOVEI	0,SORCE
	MOVEM	0,DEST>
>

	DEFINE DMOVEM(REGIS,MEM)<
	MOVEM	REGIS,MEM
	MOVEM	REGIS+1,1+MEM
	>

	DEFINE DCOPY(DEST,SORCE)<
	WHATYP	<DEST>
	IFE SYM..+1,<
	MOVE	DEST,SORCE
	MOVE	DEST+1,1+SORCE
	>
	IFN SYM..+1,<
	  WHATYP	<SORCE>
	  IFN SYM..+1,<
	  MOVE	0,SORCE
	  MOVEM	0,DEST
	  MOVE	0,1+SORCE
	  MOVEM	0,1+DEST
	  >
	  IFE SYM..+1,<
	  MOVEM	SORCE,DEST
	  MOVEM	SORCE+1,1+DEST
	  >
	>
	>

	DEFINE LD(REG.,STRUC.,FIELD.,BASE.)<
	  IFNDEF STRUC.'$'FIELD.,<T1.==^D36>
	  IFDEF STRUC.'$'FIELD.,<T1.==STRUC.'$'FIELD.>
	  IFE T1.-^D36,<MOVE REG.,STRUC.'.'FIELD.'BASE.>
	  IFN T1.-^D36,<
	    IFN T1.-^D18,<LDB REG.,[BP (STRUC.,FIELD.,BASE.)]>
	    IFE T1.-^D18,<
	      T1.==STRUC.'%'FIELD.
	      IFE T1.-^D17,<HLRZ REG.,STRUC.'.'FIELD.'BASE.>
	      IFE T1.-^D35,<HRRZ REG.,STRUC.'.'FIELD.'BASE.>
	    >
	  >
	>
	DEFINE LDEX(REG.,STRUC.,FIELD.,BASE.)<		;;SIGNED-NESS IS A PROP OF A FIELD SO...
	  IFNDEF STRUC.'$'FIELD.,<T1.==^D36>
	  IFDEF STRUC.'$'FIELD.,<T1.==STRUC.'$'FIELD.>
	  IFE T1.-^D36,<MOVE REG.,STRUC.'.'FIELD.'BASE.>
	  IFN T1.-^D36,<
	    IFN T1.-^D18,<LDB REG.,[BP (STRUC.,FIELD.,BASE.)]>
	    IFE T1.-^D18,<
	      T1.==STRUC.'%'FIELD.
	      IFE T1.-^D17,<HLRE REG.,STRUC.'.'FIELD.'BASE.>
	      IFE T1.-^D35,<HRRE REG.,STRUC.'.'FIELD.'BASE.>
	    >
	  >
	>

	DEFINE ST(REG.,STRUC.,FIELD.,BASE.)<
	  IFNDEF STRUC.'$'FIELD.,<T1.==^D36>
	  IFDEF STRUC.'$'FIELD.,<T1.==STRUC.'$'FIELD.>
	  IFE T1.-^D36,<MOVEM REG.,STRUC.'.'FIELD.'BASE.>
	  IFN T1.-^D36,<
	    IFN T1.-^D18,<DPB REG.,[BP (STRUC.,FIELD.,BASE.)]>
	    IFE T1.-^D18,<
	      T1.==STRUC.'%'FIELD.
	      IFE T1.-^D17,<HRLM REG.,STRUC.'.'FIELD.'BASE.>
	      IFE T1.-^D35,<HRRM REG.,STRUC.'.'FIELD.'BASE.>
	    >
	  >
	>

	DEFINE STFIX(REG.,STRUC.,FIELD.,BASE.)<		;;PROVIDE SPECIAL CASE SUPPORT FOR THIS COMMON CASE
	  T1.==STRUC.'%'FIELD.
	  IFE T1.-^D17,<MOVSM REG.,STRUC.'.'FIELD.'BASE.>
	  IFE T1.-^D35,<IFN REG.-BASE.,<MOVEM REG.,STRUC.'.'FIELD.'BASE.>>
	>
	SUBTTL	EXCEPTION HANDLING MACROS

	DEFINE SETABORT(ADDR.)<
	  MOVEM	P,FRAMCON
	  COPI	PARSCON,ADDR.
	>

	DEFINE ERRS(ARGS.,REENT.)<
	JRST	[FUNCT	TYPOUT,<ARGS.>
		 JRST	REENT.]
	>

	SYN ERRS,WARNS
	SYN ERRS,SYSERS
	SYN ERRS,USRERS
	SYN ERRS,SYNERS
	SYN ERRS,FILERS

	DEFINE ERR(ARGS.,REENT.)<
	FUNCT	TYPOUT,<ARGS.>
	IFNB <REENT.>,<JRST	REENT.>
	>

	SYN ERR,WARNJ			;;FOR THE .+1 CASE
	SYN ERR,SYSERR
	SYN ERR,USRERR
	SYN ERR,SYNERR
	SYN ERR,FILERR

	DEFINE WARN(ARGS.)<
	FUNCT	TYPOUT,<ARGS.>
	>

	;;;	GENMSG INTERFACE MACROS
	DEFINE	CASLAB(NUM.)<CAS'NUM.::>
	DEFINE	SETCAS(NAM.)<
	  CA.'NAM.==CA.USR
	  CASLAB(\CA.USR)
	  CA.USR==CA.USR+1
	>

	DEFINE OTHCAS<
	  REPEAT <CA.UMAX-CA.USR+1>,<
	    CASLAB(\CA.USR)
	    CA.USR==CA.USR+1
	  >
	>
	SUBTTL	NEEDED SYMBOLS, REGISTERS, ETC.

	REG(R0,0)
	REG(R1,1)
	REG(R2,2)
	REG(R3,3)
	REG(R4,4)
	REG(R5,5)
	REG(AP,16)
	REG(TAP,AP)			;GIVE DIF NAME FOR USE AS TEMP
	REG(P,17)

	;;;	GENMSG DEFINED MESSAGE CASES
	CA.VAR==1
	CA.ASZ==2
	CA.PAD==3
	CA.PT==4
	CA.SIX==5
	CA.CRLF==6
	CA.NUM==7
	CA.NOCR==10
	CA.FF==11
	CA.DBK==12
	CA.COL==13			;LIMITED CONTROL OF WHAT COLUMN TO START NEXT FIELD
	;;;	UNDEFINED AND LIMIT CASES
	CA.UNU==14
	CA.SMAX==14
	CA.UMAX==24

	;;;	GENIO MODES
	GENIN==1
	GENOUT==2
	GENAPP==3
	GENIO==4
	; ***	SWITCH COMPON
	GENASZ==0
	GENBIN==1B32				;IE. 10
	; ***	CONSTANT CHANNEL DEFS
	DEFINE CHAN(CHAN.,VAL.)<
	  CHAN.'CHAN==VAL.
	  $$$'CHAN.==1B<^D35-VAL.>
	  INI.CH==INI.CH ! $$$'CHAN.
	>

	;;;	SCAN BLK OFFSETS
	OFFS.==0			;0 EXPLIC SINCE HERE
	FIELD	(F.DEV)			;DEVICE NAME
	FIELD	(F.NAME)		;FILE NAME
	FIELD	(F.NAMM)		;MASK
	FIELD	(F.EXT)			;EXT/MASK
	FIELD	(F.MOD)			;VARIOUS JUNK
	FIELD	(F.MODM)
	FIELD	(F.DIR)			;DIRECTORY WORD
	FIELD	(F.DIRM)
	FIELD	(F.SFD,^D12)
	BLKSIZ	(F.SLEN)
	F.LEN==F.SLEN

	;;;	ENQ/DEQ RESOURCE BLK
	; ***	THE HEADER PORTION
	BYTES	(RS,<<NUM,^D18>,<SIZ,^D18>>)	;NUM OF LOCKS/SIZ OF BLK
	BYTES	(RS,<<RUPT,^D18>,<RQID,^D18>>)	;INTERRUPT CHAN/REQ ID
	BLKSIZ	(HDR.RS)
	; ***	PER-LOCK BLK
	BYTES	(RS,<<SHAR,1>,<IGLN,1>,<UNU,7>,<LEV,^D9>,<CHAN,^D18>>)
						;SHARED?,IGNOR LEV?,LEV#,JFN/CHAN OF RES
	FIELD	(RS.LOCK)			;5B2+NUM OR BYTE PTR
	BYTES	(RS,<<POOL,^D18>,<GROUP,^D18>>)	;POOL SIZE/SHAR GROUP
	BLKSIZ	(SIZ.RS)

	;;;	IPCF ARG BLKS
	; ***	PACKET DESCRIPTOR
	BYTES	(PD,<<FLAG,^D24>,<ERR,5>,<SSC,3>,<NANS,3>>)
					;1 BIT FLAGS, REF DIRECTLY
					;IPCF RETURNED ERROR CODE
					;SYS SENDER CODE, FOR COMMUN WIHT INFO
					;WAS AN UNANSWERED MSG RETURNED
	FIELD	(PD.SEND)
	FIELD	(PD.CEIV)
	BYTES	(PD,<<MLEN,^D18>,<MADD,^D18>>)
	FIELD	(PD.DIR)
	FIELD	(PD.CAPAB)
	BLKSIZ	(SIZ.PD)
	; ***	[SYS]INFO DATA PACKET
	BYTES	(INP,<<CODE,^D18>,<FUNC,^D18>>)
	FIELD	(INP.CPID)			;COPY PID
	FIELD	(INP.ARG)			;BEGIN OF VAR LEN ARG
	BLKSIZ	(SIZ.INP)

	;;;	MGRMEM ARG BLK
	FIELD	(MM.CUR)			;-LEFT,,START -- SORT OF PSEUDO AOBJ PTR FOR STORBLK
	FIELD	(MM.SIZ)			;AMOUNT USER WANTS
	FIELD	(MM.ALC)			;AMOUNT TO GRAB IF RUN OUT
	BLKSIZ	(SIZ.MM)

	;;;	VARIOUS STANDARD WAYS OF BREAKING UP A WORD INTO SUB-FIELDS
	WORD	(UUO,<<OPC,^D9>,<CHAN,4>,<EA,^D23>>)
	WORD	(BP,<<POS,6>,<SIZ,6>,<UNU,1>,<EA,^D23>>)
	WORD	(INS,<<OPC,^D9>,<AC,4>,<IND,1>,<IDX,4>,<MEM,^D18>>)
	WORD	(ARG,<<UNU,^D9>,<TYP,4>,<EA,^D23>>)

	;;;	MISCELLANEOUS SYMBOLS
	TREG.==5		;MORE OR LESS IN ACCORD WITH DPSS
	CPW==5				;ASCII--CHARS PER WORD
	DEFINE CFOPF<^D36B5+OF%NWT+OF%PLN> ;THIS WAY SINCE OTHERWISE O/S DEP (COMMON FLAGS FOR OPENF)

	END