Trailing-Edge
-
PDP-10 Archives
-
FORTRAN-10_V7wLink_Feb83
-
first.bli
There are 12 other files named first.bli in the archive. Click here to see a list.
!THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
! OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.
!COPYRIGHT (C) DIGITAL EQUIPMENT CORPORATION 1972, 1983
!AUTHOR: */TFV/CKS/CDM/RVM/AHM
GLOBAL BIND FIRSTV = 7^24 + 0^18 + #1573; ! Version Date: 1-Jul-82
%(
***** Begin Revision History *****
116 ----- ----- DEFINE "BOUNDS" FLAG IN FLGREG; REMOVE DEFINITION
OF "ISPROT" FLAG FROM SYMBOL TABLE
117 ----- ----- DEFINE "IDLIBFNFLG" IN SYMBOL TABLE ENTRIES
FOR FUNCTION NAMES
121 ----- ----- CHANGE POOLSIZE TO 600
122 ----- ----- ADD THE INEXTSGN BIT TO SYMBOL TABLE
123 ----- ----- CHANGE EQUIVALENCE LIST ENTRY SIZE TO 4, SO
THAT EQLLIST CAN BE A FULL WORD AND NOT LOSE
THE NUMBER OF SUBSCRIPTS IN THE LEFT HALF
124 ----- ----- ADD THE PARAMT BIT TO THE SYMBOL TABLE AND
REMOVE THE INUSE BIT.
REMOVE SFDUMMY AND INGLOBAL BITS.
DEFINE THE IDPARAVAL FIELD TO CONTAIN THE
CONSTANT TABLE POINTER FOR PARAMETER
VARIABLES.
ADD THE EQVISN FIELD TO THE EQUIVALENCE TABLE
ENTRY TO HOLD THE LINE NUMBER SO THAT RELEVENT
ERROR MESSAGES CAN BE PRINTED OUT
ADD THE IDENTLNK FIELD TO THE SYMBOL
TABLE ENTRY - LINKS ENTRY POINTS
125 ----- ----- PUT TOLENTRY BIT IN TO DEFINE .O VARIABLES
THAT MOVE OUT OF THE LOOP
126 ----- ----- EXPAND THE SIZE OF THE EQUIVALENCE TABLE NODE
SO THAT ISN CAN BE INCLUDED AND DISPLACEMENT
CAN STILL BE A FULL WORD SINCE IT GOES NEGATIVE
***** Begin Version 5A *****
127 544 10290 FIND STATEMENT NEEDS MORE ROOM FOR ERR AND END
130 571 22378 ADD IDUSECNT DEFINITION, (DCE)
***** Begin Version 5B *****
131 636 23066 CHANGE SNDEFINED FROM A FIELD TO A FLAG BIT, (JNG)
132 674 11803 MOVE DOSTAK TO MAKE IT BIGGER, ALSO GET
RID OF EXPTBL WHICH WENT AWAY LONG AGO., (DCE)
133 716 26409 ADD LABEL FLAG "SNRFS" - RETURN FROM SUBROUTINE, (DCE)
***** Begin Version 6 *****
134 760 TFV 1-Oct-79 ------
Add IOSTAT to I/O statement blocks and adjust statement sizes
135 761 TFV 1-Mar-80 -----
Define GFLOAT as the /GFLOATING bit in FLAGS2
136 767 DCE 20-May-80 -----
Move GFL flag into F2; redefine GFLOAT appropriately
137 1033 DCE 4-Dec-80 -----
Increase size of DO node to accomodate DOZTRLABEL
***** Begin Version 6A *****
154 1150 DCE 16-Feb-82 20-17292
Add SNASSIGNED field to label table to indicate that the label
has occurred in an ASSIGN statement.
***** Begin Version 7 *****
140 1212 TFV 29-Apr-81 ------
Add compile time data structures for CHARACTER data.
141 1213 TFV 20-May-81
Add lenstar for character*(*) data. Add CW6, CW7, and CW8
definitions. Note IDATTRIBUT(PARAMT) and IDCHLEN are also
declared in LEXICA.BLI. LEXICA will not compile if FIRST.BLI is
required. Beware of skews.
142 1221 CKS 4-Jun-81
Add LITC1, byte pointer to first char of LIT1. Used to ILDB
through chars of literal table entry.
143 1222 CKS 8-Jun-81
Move CONST1 and CONST2 down one word so that LIT1=CONST1. Much
depends on LIT1=CONST1.
144 ---- SRM 16-June-81
Added comments giving octal for statement ID's
145 1227 CKS 22-Jun-81
Add CONST2L to refer to LH of an integer constant
146 1245 TFV 3-Aug-81 ------
Move IDUSED, IDCHOS, IDDEF, IDUSECNT from word 2 to word 8 of
symbol table entries. Word 2 (IDTARGET) becomes a full word for
extended addressing. Also define new flag bits for IDPSECT and
IDPSCHARS for extended addressing support.
147 1262 CKS 21-Sep-81
New stuff for character COMMON and EQUIVALENCE. Add EQLLOWER,
EQLSSTRING, EQVALIGN. Increase EQLSIZ and COMSIZ to 5. Enlarge
COMSIZE, EQVLIMIT, EQVADDR, EQLDISPL, IDADDR to be full words.
148 1402 CKS 22-Oct-81
Add SNDECL, statement number is on a declaration statement and may
not be used for anything.
149 1406 TFV 27-Oct-81 ------
Add IDGENLENFLG to IDFLG word of symbol table entries. It is
used for .Dnnnn compile-time-constant character descriptors. If
it is one then both the byte pointer and the length are output
to the .REL file. Add IDBPOFFSET to symbol table entries. It
is used to generate the IDCHBP field for a .Dnnnn table entry.
The .Dnnnn IDADDR field points to a subnode containing either a
.Qnnnn variable or a scalar or array entry. The IDCHBP field of
the subnode is ADJBP'd by IDBPOFFSET to generate the IDCHBP
field for the .Dnnnn variable. The IDBPOFFSET field shares space
with the IDENTLNK and IDCOLINK field since .Dnnnn variables are
neither entry points nor in common.
150 1466 CDM 1-Feb-82
Addition of IDSFNODE, ENTLINK for argument checking processing.
151 1467 CDM 1-Feb-82
Addition of IDSAVVARRIABLE, IDSAVCOMMON for SAVE statement
processing.
152 1476 RVM 8-Feb-82
Change the name of INEXTSGN to USERFUNCTION.
153 1501 RVM 16-Feb-82
Add some comments on the new meanings of INEXTERN and USERFUNCTION.
1505 AHM 13-Mar-82
Add caveats about uses of PSDATA and IDPSECT in LEXICA and make
IDUSECNT a half word so that there is room for psect indices, etc.
1512 AHM 24-Mar-82
Define PSABS symbol for calls to the ZSYMBOL routine for
random symbols that don't get relocated.
1526 AHM 6-Apr-82
Add warning about reordering the PS???? symbols and changing
the position of IDPSCHARS. Also, add SNPSECT to label table
entries for ASSIGNed FORMAT labels.
1530 TFV 4-May-82
Add fields IOMARK (CW8R) and IOLMARK (CW9L) to I/O statement
nodes. They are pointers to the argument list for CHMRK. and
CHUNW. calls. IOLMARK is non-zero if the IOLST. call has
CONCTV nodes as arguments. IOMARK is non-zero if the FMT
specifier is a CONCTV node or if the iolist has dynamic
concatenations and END, ERR, or IOSTAT is specified. Add an
extra word to iolist nodes (DCSIZ, SLCSIZ, IOLCSIZ, ELCSIZ, and
IOLTAB) for the fields IOLMARK and IOLSTATEMENT.
1551 AHM 3-Jun-82
Define a new psect index called PSOOPS with the value 0 so
that the code generator can detect STEs that have not had
their psect index set explicitly.
1567 CDM 24-Jun-82
Add IDFNFOLD and IDILFOPRCLS for symbol table and inline
function processing.
1573 CKS 1-Jul-82
Add SNWHILE bit
***** End Revision History *****
)%
!FIRST MUST BE COMPILED IN THE ORDER ...,FIRST,TABLES,...
!TO SAVE SPACE AND INCREASE COMPILATION SPEED, ALL MACRO DEFINITIONS
!OF THE FORM "NAME = NUMBER$" HAVE BEEN CHANGED TO BIND'S.
REQUIRE IOFLG.BLI;
REGISTER C = 3, R2 = 2, R1 = 1;
BIND CHR = C;
!
%(***DEFINE THE FLAGS USED BY PHASE 2 SKEL AND PHASE 3***)%
MACRO BTTMSTFNFLG=FLGREG<BTTMSTFL>$, !SET FOR BOTTOMOST ROUTINES
![767] Define GFLOAT as the /GFLOATING bit in F2
%[767]% GFLOAT=F2<GFL>$, ! gfloating flag
LIBARITHFLG=FLGREG<LIBARITH>$, !SET IN "COMPLEXITY" IF ROUTINE INCLUDES ANY ARITHOPS
! THAT REQUIRE USE OF LIBRARY FNS(EG COMPLEX MUL AND DIV)
PEEPFLG=FLGREG<PEEPFL>$; !SET FOR PEEPHOLE OPTIMIZER
! SHOULD BE USED
BIND DEGUG = 0; !FOR DEBUG OPTIONS
!
MACRO XTRAC = IF DEGUG THEN IF .DTRACE NEQ 0 THEN XCALL()$;
BIND OPTIMIZER = 0;
MACHOP JRST = #254,LSHC = #246,ADD=#270;
MACHOP TTCALL = #051, CALLI = #047;
MACHOP ASHC = #244, ADDB = #273, TLZE = #623, AOS = #350,MOVEI = #201;
!
MACRO SIGCHAR = (DO CHAR() WHILE .C LEQ " "; .C)$;
MACRO OUTCHR(X) = TTCALL(1,X)$,
INCHWL(X) = TTCALL(4,X)$,
OUTSTR(X) = TTCALL(3,X)$;
!THE MACROS BELOW IMPLEMENT THE FOLLOWING ALGORITHM WITH 2 INSTRUCTIONS
!
! ((VREG_(.C - START OF RANGE) MOD 1^18) MOD 1^36) LEQ (END OF RANGE - START OF RANGE)
!
MACRO
ALPHA(X) = MOVEI(VREG,-"A",X) LEQ ("Z"-"A")$,
DIGIT(X) = MOVEI(VREG,-"0",X) LEQ 9$,
LCALPHA(X) = MOVEI(VREG,-("A"+" "),X) LEQ ("Z"-"A")$;
!
! THE MODULE GLOBL CONTAINS ALL THE ARRAY DECLARATIONS AND TABLE (PLIT)
! DEFINITIONS THAT WILL BE USED BY SUBSEQUENT ROUTINES THAT ARE
! IN SEPARATE FILES. THE PURPOSE OF THAT FILE IS TO PROVIDE ONE
! PLACE WHERE ALL DECLARATIONS THAT ARE GLOBAL TO THE SCOPE OF
! THE ENTIRE COMPILER CAN BE FOUND EASILY.
!
!
! THE FOLLOWING MACROS AND DECLARATIONS PERTAIN TO THE TABLE MANAGEMENT
! ROUTINE TBLSEARCH() AND ALSO THE CORE MANAGEMENT ROUTINE CORMAN().
!
! THE FOLLOWING MACROS ARE USED TO DEFINE THE PARAMETERS FOR THE
! STRUCTURE DECLARATIONS USED TO DEFINE THE ACCESSING ALGOITHMS
! FOR THE DYNAMIC TABLES USED BY THE FORTRAN COMPILER.
! THESE MACROS DEFINE FIELDS AND SUB-FIELDS IN TABLE ENTRIES.
! FIELDS MAY BE A FULL WORD OR HALF WORD OR LESS.
!
MACRO FULL = 0,36$;
MACRO RIGHT = 0,18$;
MACRO LEFT = 18,18$;
MACRO
CLINK = 0,0,RIGHT$, ! Current link field
NLINK = 1,0,RIGHT$, ! New (next) link field
CW0L = 0,0,LEFT$, ! Left half link word
CW0R = 0,0,RIGHT$, ! Right half link word
CW1 = 0,1,FULL$, ! Current first word
CW1L = 0,1,LEFT$, ! Left half word 1
CW1R = 0,1,RIGHT$, ! Right half word 1
CW2 = 0,2,FULL$, ! Second word
CW2L = 0,2,LEFT$,
CW2R = 0,2,RIGHT$,
CW3 = 0,3,FULL$, ! Third word
CW3L = 0,3,LEFT$,
CW3R = 0,3,RIGHT$,
CW4 = 0,4,FULL$, ! Fourth word
CW4L = 0,4,LEFT$,
CW4R = 0,4,RIGHT$,
CW5 = 0,5,FULL$, ! Fifth word
CW5L = 0,5,LEFT$,
CW5R = 0,5,RIGHT$,
%1213% CW6 = 0,6,FULL$, ! Sixth word
CW6L = 0,6,LEFT$,
CW6R = 0,6,RIGHT$,
%1213% CW7 = 0,7,FULL$, ! Seventh word
CW7L = 0,7,LEFT$,
CW7R = 0,7,RIGHT$,
%1213% CW8 = 0,8,FULL$, ! Eighth word
%760% CW8L = 0,8,LEFT$,
%760% CW8R = 0,8,RIGHT$,
%1530% CW9 = 0,9,FULL$, ! Ninth word
%1530% CW9L = 0,9,LEFT$,
%1530% CW9R = 0,9,RIGHT$;
! THE FOLLOWING MACROS DEFINE THE IDATTRIBUTES OF AN IDENTIFIER
! IDATTRIBUT(X). WHERE X IS ONE OF THE FOLLOWING:
!
! IF ANY ARE MOVED OR CHANGED PLEASE CHECK ROUTINES NAMDEF AND REFERENCE
MACRO ALLOFTHEM= 18,18$,
DEFIND = #576400$,! * !101 111 110 100 000 000
!SEE CORRESPONDING DEFINITIONS BELOW
NOTFUNC = #437400$,! @ !100 011 111 100 000 000
NOTVAR = #500000$,! + !101 000 000 000 000 000
NAMNAM = 35,1$, ! * @ + !NAMELIST NAME
COMBL = 34,1$, ! * @ + !COMMON BLOCK NAME
SFN = 33,1$, ! * + !STATEMENT FUNCTION NAME
![1213] IDATTRIBUT(PARAMT) is also declared in LEXICA.BLI. Beware of skews.
PARAMT = 32,1$, ! * !THIS VARIABLE IS A PARAMETER
STORD = 31,1$, ! * @ !VARIABLE IS STORED INTO
INASSI = 30,1$, ! * @ !IN ASSIGN STATMENT
INNAM = 29,1$, ! * @ !IN NAMELIST
FENTRYNAME= 28,1$, ! * @ !NAME IS AN ENTRY INTO A FUNCTION OR SUBROUTINE
INEQV = 27,1$, ! @ !IN EQUIVALENCE
INCOM = 26,1$, ! @ !IN COMMON BLOCK
TOLENTRY = 25, 1$, !.O VAR IS ASSIGNED
!OUTSIDE THE LOOP OF ITS
!FIRST USE
INDATA = 24,1$, ! !IN DATA STATEMENT
INEXTERN = 23,1$, ! [1501] In an EXTERNAL or INTRINSIC
! statement. This bit allows the name
! a routine to be passed as an argument
! It is lit for both INTRINSIC and user
! functions. It is also set in the STE
! for the dotted name of an intrinsic
! function if it is set in the STE of
! undotted name.
DUMMY = 22,1$, ! !DUMMY PARAMETER
!(THE BIT 21 FROM RIGHT IS USED FOR "RGCANDFLG")
NOALLOC = 20,1$, !DO NOT ALLOCATE THIS VARIABLE
INTYPE = 19,1$, !Identifier declared in type declaration
%1476% USERFUNCTION = 18,1$, ! Either this name has always been a
! user function or it is an intrinsic
! function made into a user function.
ISDEFIND(B)=(.B[IDATTRIBUT(ALLOFTHEM)] AND DEFIND) NEQ 0$,
ISNOTFUNC(B)=(.B[IDATTRIBUT(ALLOFTHEM)] AND NOTFUNC) NEQ 0$,
ISNOTVAR(B)=IF (.B[IDATTRIBUT(ALLOFTHEM)] AND NOTVAR) NEQ 0 THEN
BEGIN
EXTERNAL E4,E6;
IF .B[IDATTRIBUT(SFN)] THEN
FATLEX(B[IDSYMBOL],SFPLIT<0,0>,E4<0,0>)
ELSE FATLEX( B[IDSYMBOL], E6<0,0>)
END$;
!
!
!THE STRUCTURE ACCESS FOR A SYMBOL TABLE ENTRY
!
![1212] Add symbol table fields used for CHARACTER data.
![1212] IDATTRIBUT is full so character*(*) is represented by a length of -1
MACRO IDLINK = CLINK$,
IDOPTIM = CW0L$, !FOR OPTIMIZATION
IDDIM = CW0L$, !PTR TO DIMENSIONS
IDOPER = CW1R$, !OPERATOR FIELD
IDATTRIBUT(X) = 0,1,X$,
RGCANDFLG=0,1,21,1$, !FLAG INDICATING THAT THIS VAR COULD BE LEFT IN A REG
! THIS IS USED ON 1ST PASS OF BB REG ALLOC
VARINREGFLG=RGCANDFLG$, !FLAG INDICATING THAT THIS VAR WAS LEFT IN A REG
! THIS IS USED ON 2ND PASS OF BB REG ALLOC
![1212] Add address for CHARACTER data descriptors, use IDADDR/IDTARGET
IDTARGET = CW2$, !TARGET FOR ADDRESSING IN CODE GEN
%1261% IDADDR = CW2$, !FOR ADDRESSING
%1212% IDCHDESC = IDADDR$, ! Address of the CHARACTER data descriptor
IDSYMBOL = CW3$, !SYMBOL IN SIXBIT
IDCOMMON = CW4L$, !PTR TO COMMON BLOCK NAME IF IN COMMON
!ALSO PTR TO NAMELIST ARG BLK IF NAMELIST
IDDATVAL=CW4R$, !FOR DATASTMNT PROCESSING: THIS WD IS USED TO HOLD THE
! THE CURRENT *VALUE* OF THIS VARIABLE IF IT IS
! A LOOP INDEX FOR A DATA STATEMNT
IDFNATTRIB= CW4$, !ATTRIBUTE-FIELD FOR A FUNCTION NAME (THIS
! WORD IS USED FOR IDDATA,IDCOMMON FOR VARS)
! THIS FIELD CONTINUES THE ATTRIBUTES OF A
! LIBRARY FUNCTION
!THE FOLLOWING ARE SUBFIELDS OF IDFNATTRIB FIELD:
IDPARAVAL= CW4$, !CONTAINS THE CONSTANT LEXEME WHICH IS THE
!VALUE OF THE GIVEN PARAMETER VARIABLE
IDINLINFLG=0,4,35,1$, !FLAG FOR "THIS FN CAN BE EXPANDED IN LINE"
IDLIBFNFLG=0,4,34,1$, !FLAG FOR "THIS IS A LIBRARY FN"
%1567% IDFNFOLD=0,4,33,1$, !This function may be folded later into a
!constant.
IDINLINOPR=CW4R$, !OPERATOR TO BE USED FOR THE IN-LINE FN
! NODE THAT CAN BE SUBSTITUTED FOR THIS FN (IF
! THERE IS ONE)
%1567% IDILFOPRCLS=0,4,8,5$, !The OPRCLS field to assign for inline fn
IDSFNLAB=CW5L$, !LOCAL LABEL ASSIGNED TO A STATEMENT FUNCTION
%1466% IDSFNODE = CW5R$, !Pointer to statement function statement node
IDENTLNK = CW5L$, !LINK TO NEXT ENTRY POINT IF THIS IS AN
!ENTRY POINT - 0 TERMINATES THE LIST
IDCOLINK = CW5R$, !LINK TO NEXT SYMBOL IN COMMON BLOCK THAT
!THIS SYMBOL IS IN
%1406% IDBPOFFSET = CW5$, ! Constant used to do a compile-time ADJBP on
! IDCHBP for a subnode of a .Dnnnn variable to
! form the IDCHBP for the .Dnnnn variable.
![1212] IDCHLEN is also declared in LEXICA.BLI. Beware of skews.
%1212% IDCHLEN = CW6$, ! Character count for CHARACTER data set to -1 if length is *
%1212% IDCHBP = CW7$, ! Byte pointer to CHARACTER data, not used for dummy args
%1245% IDFLG = CW8$, ! word for extra flag bits - i.e. PSECTs
![1526] If the definition of IDPSECT or IDPSCHARS is changed, alter
![1526] the fields used in LEXICA in the ACMENDID macro.
%1245% IDPSECT = 0,8,34,2$, ! PSECT for IDADDR field
%1245% IDPSCHARS = 0,8,32,2$, ! PSECT for actual data for character variables
! (right half of byte pointer)
%1406% IDGENLENFLG = 0,8,31,1$, ! Flag for .Dnnnn variables - if set
%1406% ! then both the byte pointer and length
%1406% ! word of the character descriptor are
%1406% ! output
%1467% IDSAVVARIABLE = 0,8,30,1$, ! Variable is in SAVE statement
%1467% IDSAVCOMMON = 0,8,29,1$, ! Common is in SAVE statement
%1245% ! IDCHOS, IDUSED, IDDEF, IDUSECNT moved from word 2 since IDTARGET needs a full word
%1245% IDCHOS = 0,8,20,5$, !LOOP # USED IN DEF PT CALCULATION
%1245% IDUSED = 0,8,19,1$, !FLAG USED IN DEF PT CALCULATION
%1245% IDDEF = 0,8,18,1$,
%1505% IDUSECNT = CW8R$; !Use count for shared .I dimension offsets
![1213] Define mnemonic for CHARACTER*(*) i.e. length star is IDCHLEN = -1.
%1213% BIND LENSTAR = -1;
![1526] Note that the PSxxxx symbols are used as indices into the
![1526] EXTERNPSECTS UPLIT in RELBUF and the PSECTS vector in GLOBAL.
![1526] Those tables must be reordered if the symbols change.
![1505] If the value of PSDATA is changed, alter the value used in the
![1505] ACMENDID macro in LEXICA.
BIND
%1551% PSOOPS = 0, ! For psects that are not set by accident
%1245% PSDATA = 1, ! Lowseg data psect
%1245% PSCODE = 2, ! Hiseg code psect
%1245% PSLARGE = 3, ! Large data psect (extended addressing)
%1512% PSABS = 4; ! For things that don't get relocated
!
!THE STRUCTURE ACCESS FOR CONSTANT TABLE
!
MACRO CONLINK = CLINK$,
CONOPER = CW1R$, !OPERATOR FIELD
CNTOBEALCFLG= 0,1,35,1$, !FLAG FOR "THIS CONSTANT NEEDS TO BE IN CORE"
CONADDR = CW2R$, !HISEG ADDR OF THIS CONSTANT
CONST1 = CW4$, !HIGH ORDER VALUE(CONTAINS REAL PART OR HI ORDER OF DP OR SINGLE REAL )
!MUST BE THE SAME AS LIT1
CONST2 = CW5$, !LOW ORDER VALUE (CONTAINS INTEGER VALUE)
!MUST BE THE SAME AS LIT2
CONST2L = CW5L$; !LEFT HALF OF CONSTANT AOBJN POINTER
!
!THE STRUCTURE FOR THE LITERAL TABLE
!
![1212] Add character count field for CHARACTER constants. Change offsets
![1212] for accessing 1st, 2nd, 3rd words of literal or CHARACTER constant
MACRO LITSIZ = CW0L$, !NUMBER OF WORDS OCCUPIED BY CHARACTER
!STRING, INCLUDING NULL WORD AT END
LITLINK = CLINK$, !LINK TO NEXT LITERAL
LITOPER = CW1R$, !OPER FIELD OF LITERAL
LITFLGS = CW1L$, !LITERAL FLAG FIELD
LITEXWDFLG=0,1,34,1$, !FLAG INDICATING THAT THIS LITERAL HAS AN EXTRA
! WD ON THE END CONTAINING ONLY A NULL (THIS
! IS NECESSARY IF THE NUMBER OF CHARS FITTED INTO AN
! EXACT NUMBER OF WDS)
LITADDR = CW2$, !ADDR OF LIT STRING
%1212% LITLEN = CW3$, ! Character count for CHARACTER constant
%1212% LIT1=CW4$, !1ST WD OF THE LITERAL STRING (ASCII - LEFT JUSTIF)
!MUST BE THE SAME AS CONST1
%1221% LITC1=0,4,36,7$, !ILDB BYTE ADDRESS OF THE FIRST CHARACTER OF THE LITERAL
%1527% LITC2=0,4,29,7$, !LDB BYTE ADDRESS OF FIRST CHAR OF LITERAL
%1212% LIT2=CW5$, !2ND WD OF THE LITERAL STRING (WILL BE FILLED WITH NULLS IF
! STRING IS ONLY 1 WD
! MUST BE THE SAME AS CONST2
! SUCCESSIVE WDS OF THE LITERAL WILL BE STORED IN WDS FOLLOWING
![1212] First word of literal or CHARACTER constant is now word 4 of entry
%1212% LITWD(IX)=0,3+IX,FULL$, !TO ACCESS THE NTH WORD OF A LITERAL
! (NOTE THAT THE 1ST WD IS WORD 1)
FIRSTLIT = LITTBL[0]$;
%(***DEFINE A SPECIAL STRUCTURE TO ACCESS THE NTH WORD OF A LITERAL***)%
![1212] First word of literal or CHARACTER constant is now word 4 of entry
![1212] LITERALENTRY has become HOLLENTRY
%1212% STRUCTURE HOLLENTRY[CT]=
%1212% (@.HOLLENTRY + 4 + .CT-1)<0,36>;
!
!THE STRUCTURE ACCESS FOR THE COMMON BLOCK NAME TABLE
!
MACRO COMLINK = CLINK$, !LINK TO NEXT BLOCK
COMNAME = CW1$, !BLOCK NAME IS SIXBIT
COMFIRST = CW2L$, !FIRST ENTRY IN BLOCK PTR
COMLAST = CW2R$, !LAST ENTRY IN BLOCK PTR
COMADDR = CW3L$, !THE RELATIVE LOCATION OF THIS BLOCK IN COMMON
NEXCOMBLK =CW3R$, !PTR TO NEXT COMMON BLOCK IN SEQUENCE AS DEFINED
!FOR ALLOCATION PURPOSES
%1261% COMSIZE = CW4$; !SIZE OF THIS COMMON BLOCK IN CHARACTERS
!THE STRUCTURE ACCESS FOR THE EQIVALENCE GROUP TABLE ENTRY
!
MACRO EQVINCOM = 0,0,35,1$, !IS GROUP IN COMMON BIT
EQVAVAIL = 0,0,33,2$, !AVAILABLE FOR SEARCHING BIT 0=AVAIL
!1=OK FOR SEARCH, 2=NOT AVAIL
%1261% EQVALIGN = 0,0,18,3$, !CHAR POSITION TO ALIGN GROUP ON
EQVLINK = CLINK$, !LINK TO NEXT GROUP
EQVHEAD = CW1L$, !PTR TO ACTUAL HEAD OF GROUP
EQVISN = CW1R$, !EQUIVALENCE STATEMENT NUMBER
EQVFIRST = CW2L$, !PTR TO FIRST ITEM IN GROUP
EQVLAST = CW2R$, !PTR TO LAST LIST ENTRY IN GROUP
EQVADDR = CW3$, !DISPLACEMEN OF CLASS 'HEAD' FROM 0
EQVLIMIT = CW4$; !LIMIT VALUE OF EQUIV CLASS
!
!THE STRUCTURE ACCES FOR THE EQUIVALENCE LIST ENTRY
!
MACRO EQLINDIC = 0,0,35,1$, !INDICATES SYMBOL NOT DIMENSIONED YET
%1262% EQLSSTRING = 0,0,34,1$, !THIS SYMBOL IS A SUBSTRING
EQLLINK = CLINK$, !LINK TO NEXT SYMBOL
EQLID = CW1R$, !PTR TO SYMBOLTABLE
EQLDISPL = CW2$, !DISPLACEMENT OF THIS SYMBOL FROM GROUP HEAD
EQLLIST = CW3$, !PTR TO LIST OF SUBSCRIPTS (CONSTANTS)
%1262% EQLLOWER = CW4$; !LOWER SUBSTRING BOUND, 0 IF NONE
!
!THE STRUCTURE ACCESS FOR ENCODED SOURCE (EXECUTABLE PROGRAM) TREE
!
MACRO SRCID = 0,1,1,7$, !ID CODE OF STATEMENT
SRCLINK = CLINK$, !LINK PTR TO NEXT STATEMENT HEADER
SRCCMPLX=0,0,30,6$, !NUMBER OF REGS THAT CAN BE USED TO EVAL THIS STMNT
SRCSONNXTUSE=0,0,18,12$, !ISN OF STMNT OR EXPRESSION LATER IN THIS BASIC BLOCK
! WHERE THE VAR UNDER THIS STMNT WILL NEXT BE USED
SRCISN = CW2L$, !INTERNAL SEQUENCE NUMBER OF STAEMENT
SRCFLAGS = CW1L$, !FLAGS FOR LABEL TABLE
INNERDOFLG = 0,1,32,1$, !FLAGS INNERMOST DO STATEMENTS
SRCSAVREGFLG=0,1,34,1$, !FLAG USED BY BASIC BLOCK REG ALLOC,
! INDICATES THAT THE REG CONTAINING THE VAR UNDER THIS
! ASMNT OR DO STMNT SHOULD BE SAVED
SRCOPER = CW1R$, !OPER FIELD- OPERCLS = STATEMENT
!OPERSPC = SRCID
SRCLBL = CW3L$, !LABEL TABLE POINTER (0 IF NO LABEL)
SRCOPT = CW2R$, !PTR TO OPTIMIZATION WORDS USED BY PHAZ 2
SRCCOMNSUB = CW2R$, !COMMON SUBEXPRESSION HERE
P2SDONE = 0,0,35,1$, !USED BY OPT - INDICATES THAT P2SKEL OPTS
! HAVE BEEN PERFORMED ON THIS STMNT (SAME BIT
! AS 1ST BIT OF SRCCMPLX)
%(***DEFINE A MACRO TO USE IN SPECIFYING OPERATOR FIELDS OF STATEMENT NODES-
FOR A STMNT NODE THE OPRCLS FIELD IS IN BITS 23-27, THE SRCID IS
IN BITS 28-34
******)%
STOPERC(OPCLS,OPSRCID)=
(OPCLS^8 OR OPSRCID^1)$,
!
!THE FOLLOWING STRUCTURES ARE AN INTEGRAL PART OF THE STAEMENT HEADER
!FOR EACH KIND OF EXECUTABLE STATEMENT, ONLY THE ABOVE FIELDS
!CONTAIN INFORMATION COMMON FOR EACH STAEMENT NODE
!
!
!GO TO STATEMENT FIELDS
!
GOTOLBL = CW3R$, !PTR TO LABEL TABLE
AGOTOLBL = CW3R$, !ASSIGNED GO TO LABEL PTR
CGOTOLBL = CW3R$, !COMPUTED GO TO PTR TO PSEUDO EXPRESSION NODE
GOTOLIST = CW4R$, !PTR TO LIST OF LABELS (OR 0) IF NO LIST
GOTONUM = CW4L$, !NUMBER OF LABELL INLIST
!
!IF STATEMENT FIELDS
!
LIFEXPR = CW3R$, !PTR TO EXPR NODE FOR LOGICAL IF
LIFSTATE = CW4R$, !PTR TO STATEMENT NODE IF TRUE CONDITON
AIFEXPR = LIFEXPR$, !SAME AS FOR LOGICAL IF
AIFLESS = CW4R$, !LABEL PTR IF LESS
AIFEQL = CW4L$, !LABEL TO GO TO IF EQUAL
AIFGTR = CW5R$, !LABEL TO GO TO IF GTR
AIFREG = 0,5,23,4$, !REG TO HOLD THE VAL TO BE TESTED
!BITS WITHIN THE FLAGS FIELD USED BY ARITHMETIC IF ONLY
! (THESE BITS ARE ALL USED ELSEWHERE AS FLAGS DESCRIBING ARG2 OF AN EXPRESSION)
AIFLBEQV=0,EXOPWD,21,2$, !VAL OF THIS FIELD INDICATES WHCH (IF ANY)
! OF THE 3 LABELS ARE EQUAL TO EACHOTHER
!(THESE BITS ARE USED IN EXPRS AS A2NEGFLG AND A2NOTFLG)
AIFLBNXT=0,EXOPWD,19,2$, !VAL OF THIS FIELD INDICATES WHICH (IF ANY)
! OF THE LABELS INDICATES THE FOLLOWING STATEMENT
AIFFLGS=0,EXOPWD,19,4$, !THE CONCATENATION OF THE AIFLBEQV AND AIFLBNXT FIELDS
!(THESE BITS ARE A2SAMEFLG AND A2IMMEDFLG IN EXPRS)
!
!ASSIGN STATEMENT FIELDS
!
ASILBL = CW3R$, !PTR TO LABEL IN ASSIGN
ASISYM = CW4L$, !PTR TO SYMBOL TABLE
ASILINK = CW4R$, !LINKS ASSIGN STATEMENTS
!
!DO STATEMENT FIELDS
!
DOPRED = CW6L$, !PTR TO DO STATEMENT PREDECESSOR
DOLBL = CW3R$, !PTR TO DO LABEL TERMINUS ENTRY
DOSYM = CW4R$, !POINTER TO DO INDEX VARIABLE
DOM1 = CW4L$, !POINTER TO INITIAL VALUE
DOM2 = CW5L$, !POINTER TO UPPER LIMIT
DOM3 = CW5R$, !POINTER TO STEP SIZE
DOSSIZE = DOM3$, !ANOTHER NAME FOR STEP SIZE
DOLPCTL = CW7R$, !POINTER TO CONTROL EXPRESSION
DOCTLVAR = CW7L$, !POINTER TO CONTROL VARIABLE
DOCREG=0,6,0,4$, !DO LOOP CONTROL REG
DOIREG=0,6,4,4$, !DO LOOP INDUCTION VARIABLE REGISTER; 0 IS NONE
DOFLGS=CW1L$, !FLAGS ON THIS STMNT (SEE "TABLES" FOR SPECIFIC FLAGS)
DOFLGAUX=0,6,8,10$, !MORE FLAGS ON THIS STMN
%1033% DOZTRLABEL=CW8R$, !PTR TO END-OF-LOOP LABEL
!
!THE STRUCTURE OF DO LOOP TREE NODES
!
PARLVL = CW0L$, !PTR TO PARALLEL LEVEL DO LOOP
NEXTDO = CW0R$, !PTR TO NEXT DEEPER NESTED DO
PREVDO = CW1L$, !PTR TO ENCLOSING DO LOOP
LEVL = CW1R$, !NEST LEVEL OF LOOP
DOSRC = CW2R$, !PTR TO SOURCE TREE OF THE DO
DONODESIZ = 3$,
!
!I/O STATEMENT FIELDS
!
IOARGLBL = CW4L$, ! Pointer to label for statement argument list
IOLINK = CW4R$, ! Link I/O statements for generation of
! argument list to IN., etc. calls
IOUNIT = CW5L$, ! Pointer to UNIT
IOVAR = CW5L$, ! Variable for ENCODE and DECODE
IOREPT = CW5R$, ! For repeat factor on BACKSPACE, etc.
IORECORD = CW5R$, ! Pointer to record for random access
IOCNT = CW5R$, ! Character count for ENCODE and DECODE
IOLIST = CW6L$, ! Pointer to iolist
IOFORM = CW6R$, ! Pointer to format (0 if unformatted)
IONAME = CW6R$, ! Pointer to name list for namelist
IOERR = CW7L$, ! Pointer to ERR label
IOEND = CW7R$, ! Pointer to END label
%760% IOIOSTAT = CW8L$, ! Pointer to IOSTAT variable
%1530% IOMARK = CW8R$, ! Pointer to argument list for CHMRK./CHUNW.
%1530% ! calls. Used for dynamic concatenations
%1530% IOLMARK = CW9L$, ! Pointer to argument list for CHMRK./CHUNW.
%1530% ! calls. Used for dynamic concatenations
%1530% ! in iolists.
!
!FORMAT STATEMENT FIELDS
!
FORSIZ = CW4L$, !SIZE OF STRING IN WORDS
FORLINK = CLINK$,
FOROPER = CW1R$,
FORADDR = CW4R$, !ADDR OF STRING (IN LOW SEG)
FMTLINK = CW5L$, !LINK TO NEXT FORMAT STATEMENT
FORSTRING = CW5R$, !PTR TO CHARACTER STRING
!
!DATA STATEMENT NODE
!
DATALNK = CLINK$, !LINKS NODES TOGETHER
DATISN = SRCISN$, !CW2L
DATCOUNT = CW1$, !NUMBER OF WORDS SPECIFIED FOR INITIALIZATION
DATITEMS = CW0L$, !PTR LINKED LIST OF DATAITEM NODES
DATCONS = CW2R$, !PTR TO LINKED LIST OF CONSTANT NODE PTRS
%(***DEFINE THE FIELDS IN THE LINKED LIST OF CONSTANTS UNDER A DATA STMNT***)%
DCONST=CW1R$, !PTR TO CONSTANT TABLE ENTRY
DATARPT=CW1L$, !CT OF NUMBER OF TIMES THIS CONSTANT IS TO BE STORED
!
!
!NAMELIST NODE
!
NAMLINK =CLINK$, !LINK TO NEXT NODE
NAMLID =CW2L$, !PTR TO NAMELIST NAME
NAMADDR =CW2R$, !ALLOCATED ADDRESS OF NAMELIST ARGLIST
NAMCNT =CW1L$, !NUMBER OF ITEMS IN NAMLIST
NAMLIST =CW1R$, !PTR TO LIST OF NAMELIST NAMES
!
!OPEN STATEMENT
!
OPSIZ= IOCNT$, !NUMBER OF OPEN PARAMETERS
OPLST= IOLIST$, !LOCATION OF PARAMETER LIST
!
!ASSIGNMENT STATEMENT
!
LHEXP = CW4R$, !PTR TO LEFT SIDE EXPRESSION
RHEXP = CW3R$, !PTR TO RIGHT SIDE EXPR
ASMNTREG = 0,4,23,4$,
!
!STATEMENT FUNCTION FIELDS
!
SFNNAME = CW3R$,
SFNLIST = CW4R$,
SFNEXPR = CW4L$,
SFNCLBREG=CW5R$, !TO SAVE CLOBBREGS FIELD
!
!CALL STATEMENT FIELDS
!
CALSYM = CW3R$, !PTR TO SUBROUTINE NAME SYMBOL
CALLIST = CW4R$, !PTR TO LIST OF ARGS OR 0
CALNUM = CW4L$, !NUMBER OF ARGS IN CALL
!
!RETURN STATEMENT
!
RETEXPR = CW3R$, !PARAMETER NUMBER TO RETURN THRU
!
!STOP STATEMENT
!
STOPIDENT = CW3R$, !STOP LOCATION IDENTIFIER
STOPLBL=CW4L$, !LABEL ASSOCIATED WITH THE ARGLIST TO
! FOROTS USED FOR THIS STMNT
!
!PAUSE STATEMENT
!
PAUSIDENT = CW3R$, !PAUSE LOCATION IDENTIFIER
PAUSLBL=CW4L$, !LABEL ASSOCIATED WITH THE ARGLIST FOR FOROTS USED
! FOR THIS STMNT
!
!REGMASK NODE (FOR GLOBAL ALLOCATION)
!
NEWREGSET=CW3R$,
!
!ENTRY STATEMENT FIELDS (ALSO GOOD FOR SUBROUTINE AND FUNCTION DEFINITIONS)
!
ENTSYM = CW3R$, ! Ptr to entry name
ENTLIST = CW4R$, ! Ptr to list of args or 0
ENTNUM = CW4L$, ! 0 for principle entry, else non-zero
ENTID = CW5R$, ! Actual name for a function .
%1466% ENTLINK = CW5L$; ! Link to the next entry statement or 0.
!
!THE STRUCTURE ACCESS FOR STATEMENT NUMBER TABLE ENTRY
!
MACRO
SNLINK = CLINK$, !LINK TO NEXT TABLE ENTRY
SNNXTLAB = CW0L$, !PTR TO INTERNAL LABEL WITH SAME ADDR FIELD
SNOPER = CW1R$, !OPER FIELD FOR STATEMENT NUMBER
SNMADELABL =0,1,35,1$, !FLAG FOR MADE LABEL
SNIO = 0,1,18,1$, ! LABEL HAS BEEN REFERENCED IN AN IO STATEMENT
! OR IS A FORMAT STATEMENT LABEL
SNEXECU = 0,1,19,1$, ! LABEL HAS BEEN REFERENCED IN AN EXECUTABLE
! STATEMENT OR IS AN EXECUTABLE STATEMENT LABEL
%[636]% SNDEFINED = 0,1,20,1$, !SET IF SNADDR FIELD HAS BEEN SET UP
%[716]% SNRFS = 0,1,21,1$, !SET IF LABEL IS POTENTIAL RETURN FROM
%[716]% !A SUBROUTINE LABEL AND HENCE A PROBLEM
%1402% SNDECL = 0,1,22,1$, !SET IF LABEL IS ON A DECLARATION STATEMENT
%1150% SNASSIGNED = 0,1,23,1$, !SET IF LABEL HAS BEEN USED IN ASSIGN STATEMENT
%1526% SNPSECT = 0,1,24,2$, ! Psect index for label's address
%1573% SNWHILE = 0,1,26,1$, !SET IF LABEL IS TERMINAL STMT OF A DO WHILE
SNFLAGS = CW1L$, !
SNEXTND = CW2L$, !FOR EXTENDED DO CONSTRUCTION
SNREF = CW2$, !WHOLE WORD USED FOR ADDING 0NE IN TESTENTRY
SNREFNO = CW2R$, !NUMBER OF TIMES LABEL REFERENCED
SNADDR = CW2R$, !THE ABSOLUTE ADDRESS OF THIS LABEL
SNHDR = CW3L$, !PTR TO SOURCE STATEMENT TREE OF DEFINING STATEMENT
SNUMBER = CW3R$, !ACTUAL STATEMENT LABEL
SNDOLVL = CW4R$, !COUNT OF NESTED DO'S REFERENCING THIS LABEL
SNDOLNK = CW4L$, !PTR TO LIST OF 1 WORD POINTERS TO DO LOOPS
SNCADDRWD = CW5$, !WD OF ENTRY USED BY PEEPHOLER
SN1STLAB = CW5R$, !PTR TO 1ST LABEL THAT HAS SAME ADDR
SNSTATUS = CW5L$; !STATUS OF THIS LABEL:
! 0 - UNRESOLVED
! 1 - IN PEEPHOLE BUFFER
! 2 - OUT OF PEEPHOLE BUFFER
!REFERENCING THIS LABEL
!
!
!
MACRO DOUBLE = .SYMTYPE GTR REAL$; %FOR TESTING DOUBLE OR COMPLEX MODE%
!***************************************************************
! The following bind defines the table numbers and entry sizes
! for the various tables built by the compiler. The left half of
! the global NAME is the entry size and the right half is the
! table number that is used to identify a specific table in the
! calls to the table search routine (TBLSEARCH).
!***************************************************************
BIND
%1530% FLSIZ = 16, ! Number of entries in FREELIST used by
! CORMAN and SAVSPACE. NUMCHARS in
! ACMENTLITLEX in LEXICA must be greater
! than CHARSPERWORD * FLSIZ for literals
! to work.
%1245% IDSIZ = 9, ! Symbol table entry
POOLSIZ = 600, ! Size of buffer for input cards (20 X 72
! characters) same declaration as in GLOBAL.BLI
STKSIZ = 250, ! Size of syntax stack STK
EXSIZ = 4, ! Expression table entry
SUBNODESIZ = 5, ! Substring (expression) node
SNSIZ = 6, ! Statement number table entry
CONSIZ = 6, ! Constant table entry
%1212% LTLSIZ = 4, ! Literal table entry - must agree with
%1212% ! definition in LEXICA
%1261% COMSIZ = 5, ! Common block name table entry
EQVSIZ = 5, ! Equivalence group entry
%1262% EQLSIZ = 5, ! Equivalence list entry
DATSIZ = 3, ! Data table entry
NAMSIZ = 3, ! Namelist node entry
SRCSIZ = 4, ! Encoded source tree entry - header
ASGNSIZ = 1, ! ASSIGNMENT part
ASSISIZ = 1, ! ASSIGN part
CALLSIZ = 1, ! CALL part
CONTSIZ = 0, ! CONTINUE part
%1033% DOSIZ = 5, ! DO part
ENTSIZ = 2, ! ENTRY part
GOTOSIZ = 1, ! GOTO part
AGOSIZ = 1, ! Assigned GOTO part
CGOSIZ = 1, ! Computed GOTO part
IFSIZ = 3, ! IF part
IFASIZ = 2, ! Arithmetic IF part
IFLSIZ = 2, ! Logical IF part
RETUSIZ = 1, ! RETURN part
STOPSIZ = 2, ! STOP part
%1530% IOSIZ = 6, ! I/O statement part
%1530% READSIZ = IOSIZ, ! READ part
%1530% WRITSIZ = IOSIZ, ! WRITE part
%1530% DECOSIZ = IOSIZ, ! DECODE part
%1530% ENCOSIZ = IOSIZ, ! ENCODE part
%760% FINDSIZ = 5, ! FIND part
%1530% CLOSSIZ = IOSIZ, ! CLOSE part
%1530% INPUSIZ = IOSIZ, ! INPUT - obsolete
%1530% OUTPSIZ = IOSIZ, ! OUTPUT - obsolete
%760% BACKSIZ = 5, ! BACKFILE, BACKSPACE, REWIND, SKIPFILE,
%760% ! SKIPRECORD, UNLOAD part
%760% ENDFSIZ = 5, ! ENDFILE part
PAUSSIZ = 2, ! PAUSE part
%1530% OPENSIZ = IOSIZ, ! OPEN part
FORMSIZ = 2, ! FORMAT statement part
SFSIZ = 2, ! Statement function part
%1245% DIMSIZ = 4, ! DIMENSION table entry (plus two words for
%1245% ! each dimension)
%1530% DCSIZ = 4, ! DATACALL iolist table entry
%1530% SLCSIZ = 4, ! SLISTCALL iolist table entry
%1530% IOLCSIZ = 6, ! IOLISTCALL iolist table entry
%1530% ELCSIZ = 6; ! E1LISTCALL and E2LISTCALL iolist table entry
! Define the tables for TBLSEARCH
BIND IDTAB = IDSIZ^18 + 0, ! Symbol table
CONTAB = CONSIZ^18 + 1, ! Constant table
CXPTAB = EXSIZ^18 + 2, ! Common subexpression table
LABTAB = SNSIZ^18 + 3, ! Label table
COMTAB = COMSIZ^18 + 4, ! COMMON block table
SORTAB = SRCSIZ^18 + 5, ! Encoded source
DIMTAB = DIMSIZ^18 + 6, ! Dimension table
EXPTAB = EXSIZ^18 + 7, ! Expression table
%1530% IOLTAB = DCSIZ^18 + 8, ! Iolist table (default is
%1530% ! a DATACALL node)
! The number of words per literal table entry varies depending
! on the size of the string
LITTAB = 9, ! Literal table
LFUTAB = 10, ! Library function id table
! static and allocated in the
! compiler's HISEG
EQVTAB = EQVSIZ^18 + 11, ! Equivalence group table
EQLTAB = EQLSIZ^18 + 12, ! Equivalence list table
DATATAB = DATSIZ^18 + 13, ! Data group table
NAMTAB = NAMSIZ^18+ 14; ! Namelist group table
!***************************************************************
! Define the id for different FORTRAN statements (All statements
! have OPRCLS=STATEMENT=01110)
!***************************************************************
! Start of first group (regular)
BIND ASGNID = 000, !ASSIGNMENT (SRCOPER=7000)
ASSIID = 001, !(SRCOPER=7002)
CALLID = 002, !(SRCOPER=7004)
CONTID = 003, !(SRCOPER=7006)
DOID = 004, !(SRCOPER=7010)
ENTRID = 005, !(SRCOPER=7012)
COMNSUB = 006, !(SRCOPER=7014)
! Start of regular branching
GOTOID = 007, !(SRCOPER=7016)
AGOID = 008, !(SRCOPER=7020)
CGOID = 009, !(SRCOPER=7022)
IFAID = 010, !(SRCOPER=7024)
IFLID = 011, !(SRCOPER=7026)
RETUID = 012, !(7030)
STOPID = 013, !(7032)
! Start of I/O branching
READID = 014, !(7034)
WRITID = 015, !(7036)
DECOID = 016, !(7040)
ENCOID = 017, !(7042)
REREDID = 018, !(7044)
FINDID = 019, !(7046)
CLOSID = 020, !(7050)
INPUID = 021, !(7052)
OUTPID = 022, !(7054)
BACKID = 023, !(7056)
BKFILID = 024, !(7060)
REWDID = 025, !(7062)
SKFILID = 026, !(7064)
SKRECID = 027, !(7066)
UNLODID = 028, !(7070)
RELSID = 029, !(7072)
ENDFID = 030, !(7074)
! Start of miscellaneous
ENDID = 031, !(7076)
PAUSID = 032, !(7100)
OPENID = 033, !(7102)
SFNID = 034, !(7104)
FORMID = 035, !(7106)
BLTID = 036, !
REGMASK = 037; !
!***************************************************************
! Define data for building source tree entries for statements.
! Left half is number of words for each type of statement.
! Right half is id of statement.
!***************************************************************
BIND
ASGNDATA = (ASGNSIZ + SRCSIZ)^18 + ASGNID,
SFNDATA = (SFSIZ + SRCSIZ)^18 + SFNID,
ASSIDATA = (ASSISIZ + SRCSIZ)^18 + ASSIID,
BACKDATA = (BACKSIZ + SRCSIZ)^18 + BACKID,
BKFILDATA = (BACKSIZ + SRCSIZ)^18 + BKFILID,
SKIPDATA = (BACKSIZ + SRCSIZ)^18 + SKRECID,
SKIPFDATA = (BACKSIZ + SRCSIZ)^18 + SKFILID,
REWIDATA = (BACKSIZ + SRCSIZ)^18 + REWDID,
UNLODATA = (BACKSIZ + SRCSIZ)^18 + UNLODID,
REREDATA = (IOSIZ + SRCSIZ)^18 + REREDID,
CALLDATA = (CALLSIZ + SRCSIZ)^18 + CALLID,
CONTDATA = (CONTSIZ + SRCSIZ)^18 + CONTID,
DECODATA = (DECOSIZ + SRCSIZ)^18 + DECOID,
OPENDATA = (OPENSIZ + SRCSIZ)^18 + OPENID,
CLOSDATA = (CLOSSIZ + SRCSIZ)^18 + CLOSID,
DODATA = (DOSIZ + SRCSIZ)^18 + DOID,
ENCODATA = (ENCOSIZ + SRCSIZ)^18 + ENCOID,
ENDFDATA = (ENDFSIZ + SRCSIZ)^18 + ENDFID,
ENTRDATA = (ENTSIZ + SRCSIZ)^18 + ENTRID,
FINDDATA = (FINDSIZ + SRCSIZ)^18 + FINDID,
READDATA = (READSIZ + SRCSIZ)^18 + READID,
WRITDATA = (WRITSIZ + SRCSIZ)^18 + WRITID,
GOTODATA = (GOTOSIZ + SRCSIZ)^18 + GOTOID,
AGODATA = (AGOSIZ + SRCSIZ)^18 + AGOID,
CGODATA = (CGOSIZ + SRCSIZ)^18 + CGOID,
IFADATA = (IFASIZ + SRCSIZ)^18 + IFAID,
IFLDATA = (IFLSIZ + SRCSIZ)^18 + IFLID,
INPUDATA = (INPUSIZ + SRCSIZ)^18 + INPUID,
OUTPDATA = (OUTPSIZ + SRCSIZ)^18 + OUTPID,
ENDDATA = SRCSIZ^18 + ENDID,
RETUDATA = (RETUSIZ + SRCSIZ)^18 + RETUID,
STOPDATA = (STOPSIZ + SRCSIZ)^18 + STOPID,
FORMDATA = (FORMSIZ + SRCSIZ)^18 + FORMID,
PAUSDATA = (PAUSSIZ + SRCSIZ)^18 + PAUSID;
!
! BIND ENTRSIZ = PLIT(IDTAB,CONTAB,EXPTAB,LABTAB,COMTAB,
! SORTAB,DIMTAB,IOLTAB,LITTAB);
!
! THE FOLLOWING MACROS MAY BE NEEDED FOR INDEFINITE SIZE ENTRIES
! AND FOR INDEFINITE LEVEL OF INDIRECT REFERENCE
!
MACRO CWD(L,N) = L,N,FULL$;
!
! L - MEANS LEVEL OF INDIRECTION
! N - MEANS THE N-TH WORD IN THE ENTRY
!
!
!! THE FOLLOWING STRUCTURE DECLARATION DEFINES THE HASH TABLES
! FOR THE SYMBOL TABLE THE CONSTANT TABLE,EXPRESSION TABLE AND
!
!
STRUCTURE HTABLE[I] = (.HTABLE +.I)<RIGHT>;
! DEFINE THE TABLE SIZES
BIND SSIZ = 79, %SYMBOL HASH TABLE%
CSIZ = 37, %CONSTANTS HASH TBLE%
%[674]% ESIZ = 1, %EXPRESSION HASH%
LASIZ = 37, %STATMENT NUMBER HASH SIZE%
NSIZ = 17, %NAMELIST HASH SIZE%
SOSIZ = 1, %NO HASH TABLE FOR ENCODED SOURCE%
DISIZ = 1, %NO HASH TABLE FOR DIMENSIONS%
DASIZ = 1, %NO HASH TABLE FOR DATA STATEMENT%
LISIZ = 1; %LITERAL TABLE IS NOT HASHED%
![674] SET UP DOSTAK DIFFERENTLY SO THAT IT OVERLAPS INTO EHASH
![674] DURING FORTG (CODE GENERATION) - THE TOTAL SIZE OF DOSTAK
![674] WILL BE TDOSTSIZ WHICH MAY BE INCREASED BY MAKING
![674] DOSTSIZ BIGGER (HEAVEN FORBID!)
%[674]% BIND EHSIZ=29, !HASH TABLE SIZE
%[674]% DOSTSIZ=50, !DO STACK SIZE (ADDED TO EHSIZ IN FORTG)
%[674]% TDOSTSIZ=EHSIZ+DOSTSIZ; !TOTAL DO STACK SIZE
!WHICH IS THE MAXIMUM LEVEL TO WHICH DO LOOPS MAY BE NESTED
!
EXTERNAL SYMTBL[SSIZ],CONTBL[CSIZ],EXPTBL[1],LABTBL[LASIZ],
LITTBL[LISIZ],NAMTBL[NSIZ],SRCTBL[SOSIZ],
DIMTBL[DISIZ],DATTBL[DASIZ];
!
! BIND LISTX = PLIT(SYMTBL,CONTBL,EXPTBL,LABTBL,SRCTBL,
! DIMTBL,DATTBL,NAMTBL,LITTBL);
MAP HTABLE SYMTBL: CONTBL: LABTBL: NAMTBL;
!
!
! THE NEXT STRUCTURE DEFINES THE ACCESSING ALGORITHM FOR THE
! LINKED LIST STRUCTURES THAT ARE THE ACTUAL TABLES CONTAINING
! SYMBOL ENTRIES,CONSTANT ENTRIES,EXPRESSION ENTRIES ETC.
!
STRUCTURE BASE[I,J,K,L] =
CASE .I OF SET
%0% (@.BASE +.J)<.K,.L>; %LEVEL 1 ENTRY POINTED TO BY BASE%
%1% (@@.BASE +.J)<.K,.L> %LEVEL 2 ENTRY%
TES;
!
!! THE PARAMETERS ARE DEFINED AS FOLLOWS
! I - THE LEVEL OF INDIRCTION
! 0 - MEANS CONTENTS OF BASE
! 1 - MEANS CONTENTS OF ENTRY POINTED TO BY BASE
! 2 - CONTENTS OF ENTRY POINTED TO BY RIGHT HALF OF
! ADDRESS POINTED TO BY BASE
!
! J - THE J-TH WORD IN THE TABLE ENTRY POINTED TO
! CURRENT RANGE IS 0 TO 4
! J=0 MEANS POINT TO CHAIN FIELD (RIGHT HALF OF FIRST WORD)
!
! MAP THE POINTERS TO THE BASE
!
EXTERNAL BASE BASEPTR;
!
!******
!
!
!******
!
!
!THE FOLLOWING GLOBALS ARE USED FOR SEMANTICS CHECKING
!THEY CONTAIN POINTERS TO TABLE ENTRIES FOR THE LAST COMMON BLOCK
!NAME, THE LAST LITERAL, THE LAST SYMBOL ENTERED ETC.
!
EXTERNAL DTRACE,JOBFF,JOBREL,XAREA,XCALL,XSTAK,XALTX,TYPTAB;
!
EXTERNAL
COMBLKPTR, !POINTERS FOR LAST AND FIRST COMMMON BLOCKS
LITPOINTER, !LAST AND FIRST LITERALS
SYMPTR, !LAST AND FIRST SYMBOLS
SORCPTR, !LAST AND FIRST SOURCE ENTRIES
LASTEXP, !LAST EXPRESSION ENTRY
LASTDIM, !LAST DIMENSION ENTRY
CONSPTR, !LAST AND FIRST CONSTANTS
LABLPTR, !FIRSTAND LAST STATEMENT LABELS
SPACEFREE; !AMOUNT OF FREE LOWSEG SPACE
EXTERNAL
SRCHONLY, !FLAG FOR TBLSEARCH FOR SEARCH ONLY MODE
ISN, !INTERNAL SOURCE SEQUENCE NUMBER
IDOFSTATEMENT, !IDENTIFICATION OF EXECUTABLE STEMENT IN TREE
LABLOFSTATEMENT;!POINTER TO LABEL TABLE NODE FOR STMT NUMBER
!IF CURRENT STATEMENT HAS ONE - OR 0
EXTERNAL
DLOOPTREE, !PTR TO DO LOOP NEST TREE
LASLVL0, !PTR TO LAST LEVEL 0 NEST SEEN
DELETPTR; !PTR TO DELETED TABLE ENTRY FOR DELETE ROUTINE
EXTERNAL
SYMTYPE, !TYPE OF CRRENT SYMBOL
POINTER , !USEFUL POINTER
LIBFUNTAB, !DEFINES THE FUNCTION NAMES IN LIBRARY
LIBATTRIBUTES, !DEFINES THE LIBRARY ATTRIBURES
ONEAFTERLIB, !END OF THE LIB TABLE ADDRESS
NAME, !NAME OF THE TABLE FOR TBLSEARCH
!AND SIZ OF ENTRY IN LEFT HALF
EQVPTR, !PTR TO FIRST AND LAST EQIV GROUPS
FORMPTR, !PTR TO FIRST AND LAST FORMAT TABLE ENTRIES
DATASPTR, !PTR TO LINKED LIST OF DATA STATEMENT NODES
IOLSPTR, !PTR TO LINKED IO STATEMENTS
ENTRY; !THE GLOBAL PARAMETER VECTOR FOR TBLSEARCH
!*****
MACRO FIRSTSRC = SORCPTR<LEFT>$,
LASTSRC = SORCPTR<RIGHT>$,
IOFIRST = IOLSPTR<LEFT>$, !POINTS TO FIRST IO STATEMENT
IOLAST = IOLSPTR<RIGHT>$, !POINTS TO LAST IO STATEMENT SEEN SO FAR
DATFIRST = DATASPTR<LEFT>$,
DATLAST = DATASPTR<RIGHT>,
FIREQVGROUP = EQVPTR<LEFT>$,
LASEQVGROUP = EQVPTR<RIGHT>$,
LASCOMBLK = COMBLKPTR<RIGHT>$,
FIRCOMBLK = COMBLKPTR<LEFT>$,
DELETFIELD = CW0L$, !IF LEFT HALF OF FIRST WORD OF ENTRY IS -1 THEN ENTRY IS DELETED
FOUND = -1$,
NOTFOUND = 0$,
FLAG = FLGREG<FOUNDFLG>$, !FLAG FOR TBLSEARCH FOUND(-1) OR NOTFOUND(0)
BASEPOINT = BASEPTR$;
!
BIND BPR = BASEPTR, !FOR THE ENCLOSING ROUTINES
XCONSTANT = 12,
XSYMBOL = 8,
XLABLL = 4,
EXPRES = 0;
!