1 | #
|
---|
2 |
|
---|
3 |
|
---|
4 | ; $Header: /cvsup/minix/src/lib/ack/libp/encaps.e,v 1.1 2005/10/10 15:27:46 beng Exp $
|
---|
5 | ; (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
---|
6 | ;
|
---|
7 | ; This product is part of the Amsterdam Compiler Kit.
|
---|
8 | ;
|
---|
9 | ; Permission to use, sell, duplicate or disclose this software must be
|
---|
10 | ; obtained in writing. Requests for such permissions may be sent to
|
---|
11 | ;
|
---|
12 | ; Dr. Andrew S. Tanenbaum
|
---|
13 | ; Wiskundig Seminarium
|
---|
14 | ; Vrije Universiteit
|
---|
15 | ; Postbox 7161
|
---|
16 | ; 1007 MC Amsterdam
|
---|
17 | ; The Netherlands
|
---|
18 | ;
|
---|
19 |
|
---|
20 | mes 2,_EM_WSIZE,_EM_PSIZE
|
---|
21 |
|
---|
22 | ; procedure encaps(procedure p; procedure(q(n:integer));
|
---|
23 | ; {call q if a trap occurs during the execution of p}
|
---|
24 | ; {if q returns, continue execution of p}
|
---|
25 |
|
---|
26 |
|
---|
27 | inp $handler
|
---|
28 |
|
---|
29 | #define PIISZ 2*_EM_PSIZE
|
---|
30 |
|
---|
31 | #define PARG 0
|
---|
32 | #define QARG PIISZ
|
---|
33 | #define E_ELB 0-_EM_PSIZE
|
---|
34 | #define E_EHA -2*_EM_PSIZE
|
---|
35 |
|
---|
36 | ; encaps is called with two parameters:
|
---|
37 | ; - procedure instance identifier of q (QARG)
|
---|
38 | ; - procedure instance identifier of p (PARG)
|
---|
39 | ; and two local variables:
|
---|
40 | ; - the lb of the previous encaps (E_ELB)
|
---|
41 | ; - the procedure identifier of the previous handler (E_EHA)
|
---|
42 | ;
|
---|
43 | ; One static variable:
|
---|
44 | ; - the lb of the currently active encaps (enc_lb)
|
---|
45 |
|
---|
46 | enc_lb
|
---|
47 | bss _EM_PSIZE,0,0
|
---|
48 |
|
---|
49 | exp $encaps
|
---|
50 | pro $encaps,PIISZ
|
---|
51 | ; save lb of previous encaps
|
---|
52 | lae enc_lb
|
---|
53 | loi _EM_PSIZE
|
---|
54 | lal E_ELB
|
---|
55 | sti _EM_PSIZE
|
---|
56 | ; set new lb
|
---|
57 | lxl 0
|
---|
58 | lae enc_lb
|
---|
59 | sti _EM_PSIZE
|
---|
60 | ; save old handler id while setting up the new handler
|
---|
61 | lpi $handler
|
---|
62 | sig
|
---|
63 | lal E_EHA
|
---|
64 | sti _EM_PSIZE
|
---|
65 | ; handler is ready, p can be called
|
---|
66 | ; p doesn't expect parameters except possibly the static link
|
---|
67 | ; always passing the link won't hurt
|
---|
68 | lal PARG
|
---|
69 | loi PIISZ
|
---|
70 | cai
|
---|
71 | asp _EM_PSIZE
|
---|
72 | ; reinstate old handler
|
---|
73 | lal E_ELB
|
---|
74 | loi _EM_PSIZE
|
---|
75 | lae enc_lb
|
---|
76 | sti _EM_PSIZE
|
---|
77 | lal E_EHA
|
---|
78 | loi _EM_PSIZE
|
---|
79 | sig
|
---|
80 | asp _EM_PSIZE
|
---|
81 | ret 0
|
---|
82 | end ?
|
---|
83 |
|
---|
84 | #define TRAP 0
|
---|
85 | #define H_ELB 0-_EM_PSIZE
|
---|
86 |
|
---|
87 | ; handler is called with one parameter:
|
---|
88 | ; - trap number (TRAP)
|
---|
89 | ; one local variable
|
---|
90 | ; - the current LB of the enclosing encaps (H_ELB)
|
---|
91 |
|
---|
92 |
|
---|
93 | pro $handler,_EM_PSIZE
|
---|
94 | ; save LB of nearest encaps
|
---|
95 | lae enc_lb
|
---|
96 | loi _EM_PSIZE
|
---|
97 | lal H_ELB
|
---|
98 | sti _EM_PSIZE
|
---|
99 | ; fetch setting for previous encaps via LB of nearest
|
---|
100 | lal H_ELB
|
---|
101 | loi _EM_PSIZE
|
---|
102 | adp E_ELB
|
---|
103 | loi _EM_PSIZE ; LB of previous encaps
|
---|
104 | lae enc_lb
|
---|
105 | sti _EM_PSIZE
|
---|
106 | lal H_ELB
|
---|
107 | loi _EM_PSIZE
|
---|
108 | adp E_EHA
|
---|
109 | loi _EM_PSIZE ; previous handler
|
---|
110 | sig
|
---|
111 | asp _EM_PSIZE
|
---|
112 | ; previous handler is re-instated, time to call Q
|
---|
113 | lol TRAP ; the one and only real parameter
|
---|
114 | lal H_ELB
|
---|
115 | loi _EM_PSIZE
|
---|
116 | lpb ; argument base of enclosing encaps
|
---|
117 | adp QARG
|
---|
118 | loi PIISZ
|
---|
119 | exg _EM_PSIZE
|
---|
120 | dup _EM_PSIZE ; The static link is now on top
|
---|
121 | zer _EM_PSIZE
|
---|
122 | cmp
|
---|
123 | zeq *1
|
---|
124 | ; non-zero LB
|
---|
125 | exg _EM_PSIZE
|
---|
126 | cai
|
---|
127 | asp _EM_WSIZE+_EM_PSIZE
|
---|
128 | bra *2
|
---|
129 | 1
|
---|
130 | ; zero LB
|
---|
131 | asp _EM_PSIZE
|
---|
132 | cai
|
---|
133 | asp _EM_WSIZE
|
---|
134 | 2
|
---|
135 | ; now reinstate handler for continued execution of p
|
---|
136 | lal H_ELB
|
---|
137 | loi _EM_PSIZE
|
---|
138 | lae enc_lb
|
---|
139 | sti _EM_PSIZE
|
---|
140 | lpi $handler
|
---|
141 | sig
|
---|
142 | asp _EM_PSIZE
|
---|
143 | rtt
|
---|
144 | end ?
|
---|