Trailing-Edge
-
PDP-10 Archives
-
CFS_TSU04_19910205_1of1
-
update/ftnosr/fordbm.mac
There are 11 other files named fordbm.mac in the archive. Click here to see a list.
SEARCH MTHPRM
TV FORDBM CALL DBMS,10(4113)
;COPYRIGHT (c) DIGITAL EQUIPMENT CORPORATION 1981, 1987
;ALL RIGHTS RESERVED.
;
;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED
;ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE AND WITH THE
;INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS SOFTWARE OR ANY OTHER
;COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY
;OTHER PERSON. NO TITLE TO AND OWNERSHIP OF THE SOFTWARE IS HEREBY
;TRANSFERRED.
;THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE
;AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT
;CORPORATION.
;DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF ITS
;SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL.
COMMENT \
***** Begin Revision History *****
3125 JLC 3-Jun-82
Save the ACs for DBMS calls.
3160 BL 9-Aug-82
Separated module FORDST from FORDBM to make building OTS
more straightforward
3202 JLC 26-Oct-82
Mark pages used by DBMS so that FOROTS won't use them.
3207 BL 8-Nov-82
Bring DBASE & %DBMAD outside of IF20, so FORDBM will compile on TOPS10.
3222 JLC 19-Nov-82
Restore all ACs after FUNCT. call.
3226 JLC 29-Nov-82
Fix page marking code.
3231 JLC 14-Dec-82
Use new entry macro FENTRY. Allows use of new interface for DBMS.
3245 JLC 4-Dec-82
Removed this module from the hiseg and from FORLIB. It only
appears now in DBMSF.REL, built by the DBMS build procedure.
Removed all FOROTS-specific symbols.
3252 JLC 12-Jan-83
Design review patches.
3253 JLC 13-Jan-83
Code review changes: change name of %DBSNONSHARE to %DBSNS.
***** Begin V10 *****
4111 JLC 16-Mar-84
Changed "FDBMS%" to "FDBMS.".
4112 JLC 19-Mar-84
Removed "FDBMS.", as it is no longer necessary.
4113 JLC 23-Mar-84
Fix DBMS-10 interface.
***** End V10 Development *****
***** End Revision History *****
\
;THIS MODULE RESOLVES THE SYMBOL DBMS. AS THE ROUTINE TO
;GET SYS:DBMSF.EXE AND JUMP TO IT. THIS IS THE DEFAULT ACTION
;IF THE LINK COMMAND DOES NOT DEFINE %DBSNS.
ENTRY %DBSNS
EXTERN %DBMAD,ABORT.,FUNCT.
INTERN DBMS.
SEGMENT CODE
%DBSNS==0
DBMS.: SKIPE %DBMAD ;DBMS LOADED?
PJRST @DBASE ;YES, JUMP TO IT
MOVEM 0,SAVE0 ;SAVE 0
MOVE 0,[1,,SAVE1] ;SETUP TO SAVE 1-17
BLT 0,SAVE0+17 ;SAVE THEM
PUSHJ P,GDBMS ;GET DBMS
MOVE T1,%DBMAD ;GET BASE OF SEG AGAIN
HLRZ T2,.JBHRN(T1) ;GET SEGMENT LENGTH
ADDI T2,777 ;ROUND UP TO PAGES
LSH T2,-9
MOVEM T2,FARG2 ;SAVE FOR FUNCT. CALL
LSH T1,-9 ;GET PAGE #
MOVEM T1,FARG1 ;SAVE FOR FUNCT.
MOVEI T1,FN%MPG
MOVEM T1,FCODE ;MARK PAGES USED
XMOVEI L,FBLOCK ;SETUP ARG BLOCK
PUSHJ P,FUNCT.
SKIPE FSTAT ;OK?
$LCALL NRD,ABORT. ;NO ROOM FOR DBMS
MOVSI 16,SAVE0 ;RESTORE ACS
BLT 16,16
JRST @DBASE
;FUNCT. CALL BLOCK
-5,,0
FBLOCK: IFIW TP%INT,FCODE
IFIW TP%LIT,[ASCIZ /FRS/]
IFIW TP%INT,FSTAT
IFIW TP%INT,FARG1
IFIW TP%INT,FARG2
IFIW TP%INT,FARG3
$LERR (?,DNF,-1,0,GTJFN failure on file SYS:DBMSF.EXE)
$LERR (?,CGD,-1,0,Cannot GET SYS:DBMSF.EXE)
$LERR (?,NRD,-1,0,No room for DBMSF.EXE)
SEGMENT DATA
SAVE0: BLOCK 20 ;SAVED ACS
SAVE1==SAVE0+1
FCODE: BLOCK 1 ;FUNCT FUNCTION CODE
FSTAT: BLOCK 1 ;STATUS CODE
FARG1: BLOCK 1 ;ARG 1
FARG2: BLOCK 1 ;ARG 2
FARG3: BLOCK 1 ;ARG 3
SAVEC: BLOCK 1 ;SAVED ENTRY VECTOR
DBASE: BLOCK 1
SEGMENT CODE
IF20,<
GDBMS: MOVEI T1,.FHSLF ;SAVE ENTRY VECTOR ADDRESS
GEVEC%
MOVEM T2,SAVEC ;SAVE IT FOR LATER
MOVX T1,GJ%SHT+GJ%OLD ;GET DBMS
HRROI T2,[ASCIZ /SYS:DBMSF.EXE/]
GTJFN%
$LJCAL DNF,ABORT. ;DBMSF.EXE NOT FOUND
HRLI T1,.FHSLF
TRO T1,GT%NOV
GET%
$LJCAL CGD,ABORT. ;CAN'T GET IT
MOVEI T1,.FHSLF ;GET ENTRY VECTOR ADDRESS
GEVEC%
HLRZ T1,T2 ;GET LH
CAIE T1,254000 ;CHECK FOR JRST-TYPE ENTRY VECTOR
MOVE T2,(T2) ;NORMAL TYPE, GET START ADDRESS
HRRZM T2,DBASE ;SAVE IT
MOVEI T2,(T2) ;GET LOCAL ADDR
SUBI T2,.JBHDA ;POINT TO THE START OF THE SEG(?)
MOVEM T2,%DBMAD ;SAVE IT FOR FORMEM
MOVEI T1,.FHSLF ;PUT REAL ENTRY VECTOR BACK
MOVE T2,SAVEC ;GET THE OLD ONE
SEVEC%
POPJ P, ;DONE
> ;END IF20
IF10,<
DBSADR==700000 ;DBMSF.EXE LINKED AT 700000
DBSL==700
DBSH==775
INTERN DBSTP$
DBSTP$: POPJ P,
GDBMS: MOVEM P,SAVEC ;SAVE P, MERGE BLOWS IT AWAY
MOVEI T1,DBMS ;MERGE DBMS INTO CORE IMAGE
MERGE. T1,
$LCALL CGD,ABORT. ;CAN'T FOR SOME REASON
HRRZ T1,DBSADR+.JBHSA ;GET START ADDRESS
MOVEM T1,DBASE ;SAVE IT
MOVEI T1,DBSADR ;AND SAVE DBMS ADDRESS
MOVEM T1,%DBMAD
MOVE P,SAVEC ;GET P BACK AGAIN
POPJ P,
DBMS: SIXBIT /SYS/
SIXBIT /DBMSF/
SIXBIT /EXE/
0
0
DBSL,,DBSH
> ;END IF10
PRGEND
SEARCH MTHPRM
TV FDBML
;THIS MODULE RESOLVES DBMS. AS THE REAL DBMS, WHICH FOR DBMS V6
;IS DBMS$., AND WHICH FOR DBMS V5 IS DBMS%.
IF20,<
ENTRY DBMS.
EXTERN DBMS$.,FUNCT.
INTERN DBFNAD,HOST$F
DBMS.=DBMS$.
HOST$F=FUNCT.
DBFNAD==0
> ;END IF20
IF10,<
ENTRY DBMS.
EXTERN DBMS%
INTERN DBSTP$
SEGMENT CODE
DBMS.=DBMS%
DBSTP$: POPJ P, ;TELLS FORINI TO GETSEG FOROTS WITHOUT DBMS
> ;END IF10
PRGEND
SEARCH MTHPRM
TV KDBMS KILL VESTIGES OF DBMS
ENTRY KDBMS.
INTERN %DBMAD
SEGMENT CODE
KDBMS.: SETZM %DBMAD ;CLEAR DBMS ADDRESS
POPJ P,
SEGMENT DATA
%DBMAD: BLOCK 2 ;DBMS ADDRESS
END