forked from zuberfowler/HASM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLOAD.ASM
131 lines (131 loc) · 7.47 KB
/
LOAD.ASM
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
LOADA CSECT
* LOAD VERSION 2.0 BY CLYDE THOMAS ZUBER *
***********************************************************************
* *
* ATTR: RENT,REUS,REFR,AMODE(31),RMODE(ANY) *
* *
* PROGRAM DESCRIPTION: *
* *
* THIS SUBROUTINE IS TO ENABLE HIGH LEVEL LANGUAGES TO USE AN *
* ASSEMBLER LOAD INSTRUCTION. *
* *
* THIS ROUTINE HAS TWO ENTRY POINTS. LOADA IS FOR REGULAR OS/370 *
* LINKAGE AND LOAD IS SPECIFICALLY FOR PL/I PROGRAMS USING PL/I *
* OPTIMIZER R3.1, R4.0 AND R5.0 CONVENTIONS. *
* *
* ENTRY LOADA: *
* THREE ARGUMENTS ARE PASSED AS PARAMETERS WHICH ARE FULL WORD *
* VALUES. REGULAR OS LINKAGE IS PERFORMED. *
* *
* ENTRY LOAD: *
* IN PL/I IF THE CALL FORMAT IS USED IT HAS THREE ARGUMENTS WHICH *
* CAN BE EITHER FIXED BINARY(31) OR PTR (POINTER) OR ANY MIXTURE *
* THEREOF. IF USED WITH CALL DECLARE IT AS FOLLOWS: *
* DECLARE LOAD ENTRY OPITONS(ASM, INTER); *
* CALL LOAD(OFFSET, ADDRESS, NEW_ADDR); *
* *
* NORMALLY, HOWEVER, IT IS MORE USEFUL TO USE AS A MOCK PL/I FUNCTION.*
* THE DECLARE MUST SPECIFY SPECIFICALLY WHICH DATA TYPE IT WILL *
* EXPECT TO BE RETURNED EVEN THOUGH INTERNALLY THEY ARE THE SAME: *
* DECLARE LOAD ENTRY RETURNS(PTR); /* REALLY ASM */ *
* OR *
* DECLARE LOAD ENTRY RETURNS(FIXED BINARY(31)); /* REALLY ASM */*
* *
* VALUE = LOAD(OFFSET, ADDRESS); *
* WITH THIS FORM IT APPROXIMATES THE ASSEMBLER EVEN IN ORDER. *
* L 2,35(3) *
* *
* THE RETURNS(FIXED BINARY(31)) OR RETURNS(PTR) WORKS BECAUSE PL/I *
* CREATES A THIRD ARGUMENT TO OBTAIN ITS RETURN VALUE. *
* *
* NOTE: PL/I ERROR MSG OFFSETS ARE RELATIVE TO REAL ENTRY POINT *
* R11 - PROCEDURE BASE *
* R12 - RESERVED *
* R13 - ADDRESS OF DYNAMIC STORAGE AREA *
* *
* *
***********************************************************************
EJECT
LOADA AMODE 31
LOADA RMODE ANY
***********************************************************************
*** REGULAR OS ENTRY POINT ********************************************
***********************************************************************
USING *,15 IDENTIFY BASE REGISTER
B START SKIP IDENTIFICATION SECTION
DC AL1(4) PROGRAM IDENTIFIER
DC C'LOAD V2.0 BY CLYDE THOMAS ZUBER'
START STM 14,12,12(13) STORE REGISTERS
LR 2,1 ADDRESS OF PARM ADDR LIST
GETMAIN R,LV=STOREND-STORAGE
L 15,16(13) RESTORE R15 (BASE REG)
ST 13,4(1) CHAIN SAVE AREAS
ST 1,8(13) ..
MVI 0(1),X'00' CLEAR FLAG (WILL DO FREEMAIN)
LR 13,1 POINT TO DSA
USING STORAGE,13 ..
B LOADPROC SKIP OTHER ENTRY CODE
EJECT
***********************************************************************
*** PL/I REAL ENTRY - PROLOGUE CODE ***********************************
***********************************************************************
ENTRY LOAD
DC C' LOAD' PROGRAM IDENTIFIER
DC AL1(4) ..
LOAD DS 0H
USING *,15 IDENTIFY BASE REGISTER
STM 14,12,12(13) SAVE REGISTERS
LR 2,1 SAVE PARAMETER LIST ADDRESS
LA 0,STOREND-STORAGE PUT THE LENGTH OF THE NEW DSA IN R0
L 1,76(13) PTR NEXT AVAIL BYTE AFTER LAST DSA
ALR 0,1 ADD THEM TOGETHER
CL 0,12(12) COMPARE WITH LAST AVAILABLE BYTE
BNH SPCAVAIL IT WILL FIT
L 15,116(12) OBTAIN MORE STORAGE (PL/I ROUTINE)
BALR 14,15 ..
SPCAVAIL L 14,72(13) GET ADDR OF LSW FROM OLD DSA
LR 15,0 COPY R0 (NAB AFTER NEW DSA)
STM 14,0,72(1) SAVE LSW AND NAB IN NEW DSA
L 15,16(13) RESTORE R15 (BASE REG)
ST 13,4(1) ADDR OF LAST DSA IN NEW DSA
ST 1,8(13) CHAIN SAVE AREA (NOT DONE BY PL/I)
MVI 0(1),X'80' SET FLAGS IN DSA TO PRESERVE PL/I
MVI 1(1),X'00' ERROR HANDLING IN THIS ROUTINE
MVI 86(1),X'91' ..
MVI 87(1),X'C0' ..
LR 13,1 POINT TO NEW DSA
USING STORAGE,13 ..
EJECT
***********************************************************************
*** PROCEDURE BASE ****************************************************
***********************************************************************
LOADPROC EQU *
BALR 11,0 RESET BASE ADDRESS
USING *,11 IDENTIFY BASE REGISTER
LM 2,4,0(2) GET ADDR OF PARAMETERS
L 5,0(2) GET OFFSET VALUE
L 6,0(3) GET BASE VALUE
AR 5,6 ADD BASE AND OFFSET
L 7,0(5) THE CONTENTS OF THAT ADDRESS
ST 7,0(4) RETURN THE CONTENTS
***********************************************************************
*** EPILOGUE CODE *****************************************************
***********************************************************************
FINISH DS 0H
LR 1,13 COPY R13
L 13,4(13) RESTORE R13
*********ST****15,16(13)***********SAVE*RETURN*CODE********************
TM 0(1),X'80' IS DSA FROM PL/I?
BO RETURN YES, NO FREEMAIN REQUIRED
LA 0,STOREND-STORAGE GET LENGTH
FREEMAIN R,LV=(0),A=(1) FREE DSA
RETURN LM 14,12,12(13) RESTORE CALLER'S REGISTERS
BR 14 RETURN
***********************************************************************
*** DYNAMIC STORAGE AREA **********************************************
***********************************************************************
STORAGE DSECT
SAVEAREA DS 22F
STOREND DS 0D
END