summaryrefslogtreecommitdiff
path: root/v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM
diff options
context:
space:
mode:
Diffstat (limited to 'v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM')
-rw-r--r--v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM223
1 files changed, 223 insertions, 0 deletions
diff --git a/v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM b/v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM
new file mode 100644
index 0000000..d94ede4
--- /dev/null
+++ b/v4.0/src/CMD/GRAFTABL/GRTABHAN.ASM
@@ -0,0 +1,223 @@
1 PAGE 90,132 ;A2
2 TITLE GRTABHAN - INTERRUPT HANDLER FOR INT 2FH, GRAFTABL LOADED
3;****************** START OF SPECIFICATIONS *****************************
4; MODULE NAME: GRTABHAN.SAL
5
6; DESCRIPTIVE NAME: For GRAFTABL, this is the Multiplexor Interrupt Handler
7
8;FUNCTION: This module contains the Interrupt Handler that will be hooked
9; into the INT 2FH vector. When invoked with AL=0, it responds
10; that GRAFTABL is loaded by changing AL to contain hex FF. If
11; option AL=1 specified, it puts into the vector at DS:[BX] the
12; pointer to the previously loaded table.
13
14; NOTES:
15; This module should be processed with the SALUT preprocessor:
16
17; SALUT GRTABHAN
18
19; To assemble these modules, the alphabetical or sequential
20; ordering of segments may be used.
21
22; For LINK instructions, refer to the PROLOG of the main module,
23; GRTAB.SAL. This module, containing a resident interrupt handler,
24; should be first in the list of .OBJ to be linked.
25
26; At the time this handler code is made resident, the loader, GRTAB,
27; made certain instruction modifications. PATCH_OFF and PATCH_SEG
28; are the immediate word fields of two move word immediate to
29; storage type of instructions. The loaded Revised these to
30; contain the offset and the segid respectively of where the
31; resident font table would be that is to stay resident.
32
33; Also at load time, GRTAB made another instruction modification by
34; changing the JUMP DUMMY instruction's DWORD immediate field to
35; contain the vector pointing to the previous owner of the
36; Multiplexor Interrupt Vector.
37
38; ENTRY POINT: There are two entry points: one, from DOS at 100H, is
39; END_PSP. The jump instruction there has nothing to do with
40; the interrupt handler, but merely jumps to the GRTAB module to
41; what is effectively the real DOS entry point, ENTRY_POINT.
42
43; The other is where the interrupt vector will be set to point,
44; the entry point to the interrupt handler code: HANDLER.
45
46; For the rest of this module description, the HANDLER entry
47; point conditions are being described.
48
49; INPUT: AH = Multiplexor Number. I do nothing if this is not my own.
50; The value of the Multiplexor Number is defined in the EQU:
51; MY_MULTIPLEXOR_NUMBER as being the value, B0H.
52; AL = Function Request. There are two functions recognized:
53; 0 = "GET INSTALLED STATE"
54; 1 = "WHERE ARE YOU?"
55; and DS:BX points to vector to receive pointer
56; to the previously installed GRAFTABL table.
57; If Function request is not '1', it is assumed to be '0'.
58
59; EXIT-NORMAL: If the proper multiplexor number is presented, respond with
60; AH = 0FFH, otherwise, pass control to previous owner
61; of this interrupt.
62
63; EXIT-ERROR: None
64
65; INTERNAL REFERENCES:
66; ROUTINES: none
67
68; DATA AREAS:
69; PUBLIC symbols:
70; PREV_OWN Far jump direct to previous owner of interrupt 2FH.
71; PATCH_OFF Offset portion of vector pointing to loaded char cable.
72; PATCH_SEG Segment portion of vector pointing to loaded char table.
73; HANDLER Entry point pointed to by the vector at interrupt 2FH.
74; HANDLER_SIZE Location of the end of the resident code portion of the
75; interrupt 2FH handler, including the 60H bytes left of
76; the PSP, so this offset is relative to the start of the PSP
77; after the code has been relocated downward into the PSP.
78; MPEXNUM The byte containing the value defined
79; as being the id checked for when INT 2FH is called used
80; to identify this GRAFTABL member of the multiplexor chain.
81;
82
83; EXTERNAL REFERENCES:
84; ROUTINES: none
85
86; DATA AREAS: none
87
88;****************** END OF SPECIFICATIONS *****************************
89 IF1
90 %OUT COMPONENT=GRAFTABL, MODULE=GRTABHAN.SAL...
91 ENDIF
92; $SALUT (4,21,25,41)
93 HEADER <MACRO DEFINITIONS, STRUC DEFINITIONS, EQUATES>
94 INCLUDE PATHMAC.INC ;AN006;
95HEADER MACRO TEXT
96.XLIST
97 SUBTTL TEXT
98.LIST
99 PAGE
100 ENDM
101; = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
102VECTOR STRUC
103VECOFF DW ? ;OFFSET PORTION OF VECTOR POINTER
104VECSEG DW ? ;SEGMENT PORTION OF VECTOR POINTER
105VECTOR ENDS
106; = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
107; DEFINITION OF FUNCTIONS TO BE REQUESTED OF INT 2FH
108GET_INST_STATE EQU 0 ;FUNCTION = "GET INSTALLED STATE"
109WHERE_R_U EQU 1 ;FUNCTION = "WHERE ARE YOU?"
110 ; REQUESTS VECTOR OF LOADED TABLE BE
111 ; PUT IN VECTOR POINTED TO BY DS:[BX]
112RES_FUNC EQU 0F8H ;RESERVED FUNCTIONS IN RANGE OF F8 TO FF, IGNORE
113
114; OTHER EQUATES
115PATCHED EQU 0 ;DUMMY VALUE, TO BE REPLACED AT EXECUTION TIME
116INSTALLED EQU 0FFH ;RESPONSE, INDICATES THIS HANDLER IS INSTALLED
117MY_MULTIPLEX_NUMBER EQU 0B0H ;THE UNIQUE IDENTIFICATION NUMBER ASSIGNED
118 ; TO "GRAFTABL" FOR INT 2FH
119; = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
120DUMMY_SEG SEGMENT AT 0
121DUMMY LABEL FAR ;NOTHING HERE REALLY, ONLY
122 ; USED TO MAKE MASM GENERATE A FAR CALL DIRECT
123 ; THE ABSOLUTE VECTOR IN THAT INS WILL BE PATCHED
124
125DUMMY_SEG ENDS
126; = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
127 HEADER <DOS ENTRY POINT>
128CSEG SEGMENT PARA PUBLIC
129;THIS SEGMENT IS ALIGNED ON PARA SINCE IT IS THE START OF THE LOAD MODULE,
130; WHICH IS ON A PARA BOUNDARY ANYWAY. THIS MODULE IS PADDED AT THE END
131; TO A MULTIPLE OF 16 BYTES, SO THE NEXT SEGMENT WILL ALSO START
132; ON A PARA BOUNDARY, WHICH WILL BE THE US CHARACTER SET TABLE.
133
134 ASSUME CS:CSEG
135
136 EXTRN ENTRY_POINT:NEAR
137
138 ORG 60H
139 PUBLIC MOV_DEST
140MOV_DEST LABEL BYTE ;WHERE THIS INTERRUPT HANDLER
141 ; WILL BE MOVED TO, FOLLOWED BY THE 1K TABLE.
142 ORG 100H
143 PUBLIC END_PSP ;BEGINNING HERE, THIS WILL BE MOVED TO "MOV_DEST"
144END_PSP EQU $ ;ENTRY POINT FROM DOS
145 JMP ENTRY_POINT ;INIT THE INT HANDLER, SET UP CHAR TABLES
146 ; THIS JUMP TARGET IS DEFINED
147 ; IN THE GRTAB.SAL MODULE
148; AREAS TO BE PATCHED WITHIN THIS MODULE
149
150 PUBLIC PREV_OWN ;PATCH IS IN JMP INSTR TO PREVIOUS OWNER
151;THE ABOVE PATCH IS FIXED BY THE GRTAB.SAL MODULE, JUST BEFORE ALTERING THE 2FH VECTOR
152
153 PUBLIC PATCH_OFF ;OFFSET PORTION OF VECTOR POINTING TO LOADED CHAR TABLE
154 PUBLIC PATCH_SEG ;SEGMENT PORTION OF VECTOR POINTING TO LOADED CHAR TABLE
155;THE ABOVE TWO PATCHES ARE FIXED BY THE GRTAB.SAL MODULE, AT THE VERY BEGINNING.
156
157;THIS NEXT ONE BYTE FIELD SHOULD BE KEPT AS THE BYTE JUST PREVIOUS TO THE
158;INTERRUPT HANDLER ENTRY POINT AT "HANDLER".
159 PUBLIC MPEXNUM
160MPEXNUM DB MY_MULTIPLEX_NUMBER ;PATCHING THIS ONE BYTE WILL CHANGE FOR ALL THE VALUE
161 HEADER <MULTIPLEXOR INTERRUPT HANDLER>
162;CONDITIONS OF REGS AT ENTRY TO HANDLER:
163;INPUT: AH = MULTIPLEXOR NUMBER. I DO NOTHING IF THIS IS NOT MY OWN.
164; AL = FUNCTION REQUEST. THERE ARE TWO FUNCTIONS RECOGNIZED:
165; 0 = "GET INSTALLED STATE"
166; 1 = "WHERE ARE YOU?"
167; AND DS:BX POINTS TO VECTOR TO RECEIVE POINTER
168; TO THE PREVIOUSLY INSTALLED GRAFTABL TABLE.
169; IF FUNCTION REQUEST IS NOT '1', IT IS ASSUMED TO BE '0'.
170
171 PUBLIC HANDLER
172HANDLER PROC FAR ;INTERRUPT HANDLER ENTRY POINT
173; $SALUT (4,3,9,41)
174 PATHLABL GRTABHAN ;AN006;
175 CMP AH,MPEXNUM ;IS THIS MULTIPLEXOR REQUEST IS FOR ME?
176; $IF E ;IF MY MULTIPLEX NUMBER IS CALLED
177 JNE $$IF1
178 CMP AL,RES_FUNC ;IF IN RANGE F8-FF, DO NOTHING, JUST RETURN
179; $IF B
180 JNB $$IF2
181 CMP AL,WHERE_R_U ;IF REQUEST FOR "WHERE ARE YOU?"
182; $IF E
183 JNE $$IF3
184 ;FOR THIS REQUEST, DS:BX POINTS TO A VECTOR
185 ; WHICH IS TO RECEIVE THE POINTER TO
186 ; WHERE THE ORIGINAL TABLE WAS LOADED
187
188 ;PASS OFFSET OF WHERE TABLE IS
189 MOV [BX].VECOFF,PATCHED ; TO FIRST WORD OF RESPONSE AREA
190PATCH_OFF EQU WORD PTR $-2 ;THE ACTUAL VALUE OF THE IMMEDIATE IS PATCHED IN
191
192 ;PASS SEGID OF WHERE TABLE IS
193 MOV [BX].VECSEG,PATCHED ; TO SECOND WORD OF RESPONSE AREA
194PATCH_SEG EQU WORD PTR $-2 ;THE ACTUAL VALUE OF THE IMMEDIATE IS PATCHED IN
195; $ENDIF
196$$IF3:
197 MOV AL,INSTALLED ;SAY "INSTALLED"
198; $ENDIF
199$$IF2:
200 IRET ;RETURN TO INTERRUPT INVOKER
201; $ENDIF
202$$IF1:
203;SINCE THE MULTIPLEX NUMBER IS FOR SOMEBODY ELSE, PASS THE CALL ON TO PREVIOUS OWNER
204JMPREV: ;REFERENCED WHEN PATCHING OUT "DUMMY"
205 JMP DUMMY ;CHAIN ON TO THE PREVIOUS OWNER
206 ; OF THE VECTOR AT 1FH*4.
207 ; USAGE OF "DUMMY" HERE IS JUST A PLACE-HLDER
208 ; WHICH WILL BE REPLACED DURING EXECUTION OF LOADER
209 PATHLABL GRTABHAN ;AN006;
210;=================================================================
211 HEADER <POINTERS TO PREVIOUS OWNER, INSTRUCTION MODIFICATION>
212; $SALUT (4,14,20,41)
213PREV_OWN EQU DWORD PTR JMPREV+1 ;REFERENCED DURING REPLACEMENT OF "HANDLER"
214 ; IN THE ABOVE JMP INSTRUCTION
215HANDLER ENDP
216 IF ($-CSEG) MOD 16 ;IF NOT ALREADY ON 16 BYTE BOUNDARY
217 ORG ($-CSEG)+16-(($-CSEG) MOD 16) ;ADD PADDING TO GET TO 16 BYTE BOUNDARY
218 ENDIF
219HANDLER_SIZE EQU ($-CSEG)-(END_PSP-CSEG) ;MARK THE END OF RESIDENT EXECUTABLE ;AN000;
220 PUBLIC HANDLER_SIZE ; PORTION, NOT INCLUDING THE PSP ;AN000;
221CSEG ENDS
222 END END_PSP
223 \ No newline at end of file