3 .sh 2 "X.25 Public Data Network Support"
5 This ARGO release includes support for an X.25 Public Data Network (PDN)
6 in the form of a device driver for the Eicon Technology
9 This adapter, its software, and its documentation are
10 available from Eicon Technology Corporation, 3452 Ashby Street, Montreal,
11 Quebec, Canada H4R 2C1.
13 The adapter and its software, together with
14 the ARGO \fIecn(4)\fR driver, implement
15 the X.25 packet layer protocol as required to support the OSI connection
16 oriented network service.
17 The remainder of this section of this manual
18 destribes the ARGO device driver (hereinafter called "the driver")
19 for the Eicon Technology Network Adapter (hereinafter called "the adapter"),
20 the interface between the driver
21 and the CONS software described above, and the interface
22 between the driver and the software on the adapter.
23 .sh 3 "Software Modules"
25 The modules relevant to the design of the driver are listed below.
27 The Connection Oriented Network Service (CONS) provides the upper ISO layers
28 with an interface to the PDN.
30 the PDN is 1980 X.25, although support for 1984 X.25 is included.
31 CONS can receive requests
32 from the CLNP entity and
33 from the OSI transport entity.
34 In addition, the CONS module
35 supports \fIioctl()\fR commands used by
36 \fIifconfig(8)\fR to configure
37 the X.25 network address and to
38 declare the adapter to be up or down.
41 The driver accepts commands from CONS, formats these commands
42 for the adapter, and interprets error indications delivered by the adapter.
43 This driver supports all the UNIX configuration device structures.
46 \fIEcnconf\fR is a program that allows the privileged user to
48 the options offered by the software on the adapter.
49 \fIEcnconf\fR can be run at any time.
52 \fIEcnload\fR is a program that downloads Eicon Technology software
53 to the adapter and passes the configuration changes made
54 with the \fIecnconf\fR program to the driver.
55 \fIEcnload must be run only when the X.25 link is considered down\fR.
58 \fIEcnstat\fR is a program that
59 prints the connection state information and counters kept by
60 the adapter and by the driver.
61 The statistics include the number of sends and receives,
62 active connections, and errors.
63 For more information, see \fI ecnstat(8)\fR.
65 The adapter's interface to the driver is the Network Control
66 Block and Request Vector that exist within the adapter's shared memory (often
67 called the "Common Data Area").
68 This is described in detail below.
69 .sh 3 "Interactions Among the Modules"
72 passed between CONS and the driver can be any one of the \fIECN\fR
73 commands outlined in the
74 sections "ECN Requests" and "ECN Replies", below.
75 CONS uses the \fCecnrestart()\fR procedure for restart requests,
76 \fCecnshutdown()\fR procedure for shutdown requests, and
77 \fCecnoutput()\fR procedure for all
78 normal data transfer requests.
79 CONS uses the \fCecnioctl()\fR procedure call for
80 servicing adapter status requests from the X.25 statistics program \fIecnstat\fR.
82 Commands passed between the driver and the adapter can
83 be any one of the network control block (\fINCB\fR)
84 commands described in the section "NCB Commands", below.
85 All commands to and from the adapter are
86 communicated in the Network Control Block and Request Vector within
87 the adapter's Common Data Area.
89 \fIEcnload\fR starts the
90 Eicon Technology Network Adapter software on the adapter
91 and downloads the validated configuration
95 The \fIECN\fR request types that CONS can pass to the driver are listed below.
96 .ip "\fIECN_STOP - (by calling ecnshutdown())\fR"
97 This request instructs the driver to restart the network but not to listen for
99 CONS issues this request in response to an \fIioctl()\fR command
100 issued by the utility program \fIifconfig\fR, when
101 \fIifconfig\fR is used to bring down the adapter.
102 .ip "\fIECN_RESTART - (by calling ecnrestart())\fR"
103 This request instructs the driver to restart the network \fIand\fR to listen
104 and accept any incoming calls.
105 CONS issues this request in response to an \fIioctl()\fR command
106 issued by the utility program \fIifconfig\fR, when
107 \fIifconfig\fR is used to bring the adapter up.
108 .ip "\fIECN_CALL - 0x90\fR"
109 This request instructs the driver to place
111 to the specified DTE.
112 .ip "\fIECN_CLEAR - 0x92\fR"
113 This request instructs the driver to clear a given virtual circuit.
114 All outbound data are acknowledged by the remote DTE
115 before the circuit is cleared.
116 .ip "\fIECN_SEND - 0x94\fR"
117 This request instructs the driver to transmit a data buffer across a given
119 .ip "\fIECN_RESET - 0x04\fR"
120 This request instructs the driver to reset the given virtual circuit and
121 clear out all outstanding requests
122 associated with that virtual circuit.
123 .ip "\fIECN_STATUS - 0xb4 (exclusively through ecnioctl())\fR"
124 This requests instructs the driver to
125 solicit the adapter's current connection state information and
129 The \fIECN\fR responses
131 to CONS are listed below.
132 .ip "\fIECN_CONNECT - 0x01\fR"
133 This reply notifies CONS that the driver has established a virtual circuit
134 connection initiated by the remote DTE.
135 .ip "\fIECN_ACCEPT - 0x03\fR"
136 This reply notifies CONS that an ECN_CALL request has succeeded. The
137 reply contains a pointer to a protocol control block.
138 .ip "\fIECN_REFUSE - 0x02\fR"
139 This reply notifies CONS that a previous \fIECN_CALL\fR request has failed.
140 The reply contains a pointer to a protocol control block.
141 .ip "\fIECN_CLEAR - 0x92\fR"
142 This reply notifies CONS that a given virtual circuit has been cleared
143 either by the DCE or by the remote DTE.
144 .ip "\fIECN_RECEIVE - 0x95\fR"
145 This reply notifies CONS that the driver has received a data packet from
147 .ip "\fIECN_RESET - 0x04\fR"
148 This reply notifies CONS that the virtual circuit has been reset either
149 by the DCE or by the remote DTE.
150 .ip "\fIECN_ACK - 0x05\fR"
151 This reply tells CONS that the associated ECN_SEND request has been been
152 completed by the adapter.
155 The driver hides from the CONS module
156 many of the idiosyncrasies of the adapter's
158 by mapping many of the above \fIECN\fR requests into corresponding
159 \fINCB\fR commands. Below is a list of requests that the driver can place to
160 the adapter. For each request that the driver places to the adapter, the adapter
161 returns with a command completion.
162 .ip "\fINCB_CALL - 0x90\fR"
163 This command creates a virtual circuit.
164 .ip "\fINCB_LISTEN - 0x91\fR"
165 This command tells the adapter that our host is
166 willing to accept incoming calls.
167 .ip "\fINCB_CLEAR (and NCB_ABORT) - 0x92\fR"
168 This command clears a virtual circuit. An option exists to clear the circuit
169 immediately, without waiting first for outstanding acknowledgments.
170 .ip "\fINCB_SEND (and NCB_RESET) - 0x94\fR"
171 This command sends data to the remote DTE. An option is
172 available for resetting the
173 virtual circuit. This command can return a status indicating that the
174 circuit has been cleared by the DCE or the remote DTE.
175 .ip "\fINCB_RECEIVE - 0x95\fR"
176 This command tells the adapter that our host is
177 willing to receive data on a given virtual circuit. This command can return
178 received data, a reset circuit, M-, D-, and Q-bits, interrupt packets,
179 or a cleared circuit.
180 .ip "\fINCB_STATUS - 0xb4\fR"
181 This command queries the adapter about
182 the status of a virtual circuit.
183 The driver uses this command to support the ECN_STATUS request.
184 .ip "\fINCB_RESTART - 0xb2\fR"
185 This command restarts the network. This command requires that a corresponding
186 configuration file be passed down to the adapter.
188 .sh 3 "ECN Request and Reply Structure"
191 the data structure used in CONS-driver
193 This data structure is a parameter to the
194 \fIecnoutput()\fR procedure.
197 /* Eicon Driver Request Structure -- used between CONS and the driver */
199 struct eicon_request {
200 struct ecn_ncb eicon_req_ncb; /* the network control block */
201 caddr_t eicon_req_pcb; /* CONS pcb used on CALL requests */
202 int eicon_req_state; /* used internally by the driver */
203 int eicon_retry_cnt; /* used internally by the driver */
204 int eicon_more; /* used internally by the driver */
205 u_char eicon_reason; /* source of CLEAR requests */
209 The \fCeicon_req_ncb\fR field in the eicon request structure is of
210 type \fCecn_ncb\fR, defined in the following section. This structure stores
212 that the driver uses in communicating with the adapter.
213 The command block contains a \fIlogical session number\fR (LSN),
214 which identifies a virtual circuit.
215 Requests such as ECN_CALL are made without an LSN to identify
217 When an LSN is not available, the request is identified by
219 \fCeicon_req_pcb\fR, which is a pointer to a CONS protocol control block.
220 The \fCeicon_req_state\fR field is used by the driver to keep track
221 of the status of the given request.
222 The following list defines the various values for this field:
224 The driver recognizes a new request, has placed the request into the driver's
225 own request queue, but has yet to interrupt the
226 adapter. (The driver maintains a pointer \fCecn_pending_req\fR that indicates
227 whether an interrupt to the adapter is outstanding. If one is outstanding, the
228 driver places any new requests in this \fIREQ_NEW\fR state. If an interrupt
230 outstanding, the driver places the request immediately in the
231 \fIREQ_INTERRUPT\fR state defined below.)
232 .ip "\fIREQ_INTERRUPT\fR"
233 The driver has dequeued the CONS request, assigned \fCecn_pending_req\fR to
234 point to the request, and
235 interrupted the adapter for a chance to post this request.
236 .ip "\fIREQ_POSTED\fR"
237 The driver has sent the request to the adapter.
238 .ip "\fIREQ_COMPLETE\fR"
239 The driver has just completed the request, and if necessary, is now posting
242 The \fCeicon_retry_cnt\fR field in the eicon request structure keeps track
243 of how many times the driver has tried posting this command to the adapter.
244 After the second retry, the driver gives up and performs the appropriate
246 The \fCeicon_more\fR field defines a \fIRECEIVE\fR request that
247 has been re-posted to the adapter to take care of m-bit transfers.
248 The \fCeicon_reason\fR field quantifies the reason for a connection being
249 cleared. These reasons are defined in the include file \fCiso_errno.h\fR.
251 Any data associated with the request are linked to the request through the
252 request mbuf's \fCm_next\fR field.
253 This is done so that when
254 the driver calls the \fIMFREE_M\fR deallocation routine, both the request
255 and the data are freed together.
257 The following chart defines those fields within the eicon request structure
258 that are relevant in any CONS request
259 to the driver via the \fIecnoutput()\fR call.
268 \fBField Definitions for CONS \(-> Driver Requests\fR
270 \fI:Request Types (CONS \(-> Driver)\fR
271 \fIField:ECN_CALL:ECN_CLEAR:ECN_SEND:ECN_RESET\fR
273 \fIncb\(->command\fR:0x90:0x92:0x94:0x04
275 \fIncb\(->loc_ses_num\fR:T{
280 \fIncb\(->info\fR:0x0:0x0:0x0:0x2
282 \fIeicon_req_pcb\fR:T{
284 address of CONS' protocol control block
287 \fIeicon_req_data\fR:T{
289 address of mbuf containing contents of Call Request packet (including DTE address, facilities, and call user data)
292 NULL or address of mbuf containing contents of Clear Request packet
295 address of mbuf containing contents of user data
298 NULL or the address of mbuf containing a one byte Reset Diagnostic code
302 .sh 3 "Structure of the Network Control Block (NCB)"
304 The \fCecn_ncb\fR structure is used by the driver to
305 make requests of the adapter.
308 /* Network Control Block -- used between the driver and the Eicon adapter */
311 u_char command; /* command field */
312 u_char retcode; /* return code field */
313 u_char lsn; /* local session number */
314 u_char info; /* additional information */
315 caddr_t buffer; /* pointer to data buffer's mbuf */
316 u_short length; /* buffer length */
317 u_char callname[16]; /* module name on NA "X25" */
318 u_char appl_name[16]; /* application name */
319 u_char rxto; /* receive timeout in secs */
320 u_char txto; /* send(tx) timeout in secs */
321 caddr_t post; /* NULL */
322 u_char lana_num; /* specifies Eicon Tech NA */
323 u_char cmd_cplt; /* command status */
324 u_char reserve[14]; /* reserved area */
329 The chart below defines those fields that are relevant in any
330 reply passed by the driver back up to CONS.
339 \fBField Definitions for Driver \(-> CONS Replies\fR
341 \fI:Reply Types (Driver \(-> CONS)\fR
342 \fIField:ECN_CONNECT:ECN_ACCEPT:ECN_REFUSE:ECN_CLEAR:ECN_RECEIVE:ECN_RESET\fR
344 \fIncb\(->command\fR:0x01:0x03:0x02:0x92:0x95:0x04
346 \fIncb\(->loc_ses_num\fR:VC #:VC #:ignore:VC #:VC #:VC #
348 \fIncb\(->info\fR:ignore:ignore:ignore:ignore:T{
350 Interrupt received (bit 0), D-bit set (bit 6), and/or Q-bit set (bit 7). Zero
351 info field implies a normal receive.
354 \fIeicon_req_pcb\fR:NULL:T{
356 address of CONS's protocol control block
359 address of CONS's protocol control block
360 T}:ignore:ignore:ignore
362 \fIeicon_req_data\fR:T{
364 NULL or address of mbuf containing contents of Call Indication packet
367 NULL or address of mbuf containing contents of Call Connected data
370 NULL or address of mbuf containing contents of Call Cleared data
373 NULL or address of mbuf containing contents of Call Cleared data
376 address of mbuf containing contents of user data
379 NULL or address of mbuf containing one byte Reset Diagnostic code
382 \fIeicon_reason\fR:ignore:ignore:T{
395 .sh 3 "Internal Driver Data Sructures"
397 The main driver data structure
398 is the \fIecn_softc\fR structure.
399 This structure keeps track of the interface request queue
400 (\fCecn_if\fR and \fCecn_pending_req\fR),
401 magic addresses on the adapter (\fCecn_iom_base, ecn_mem_base,\fR and
402 \fCecn_data_base\fR),
403 error statistics (\fCecn_errors\fR), the state
404 of each virtual circuit (\fCecn_vc_state\fR), the state of the \fILISTEN\fR
405 request (\fCecn_listen_pending\fR), and the current caller (\fCecn_cause\fR).
409 int ecn_errors[NCB_MAX][ST_MAX];
410 int ecn_cause[CAUSE_MAX]; /* ecn_work() causes */
411 struct mbuf *ecn_pending_req; /* waiting for command req */
412 char ecn_listen_pending; /* boolean = listen req pending? */
413 char ecn_vc_state[LSN_MAX]; /* the current state of each vc */
415 *ecn_iom_base; /* base address of io map */
416 struct ecn_request_vector
417 *ecn_mem_base; /* base address of memory map */
418 caddr_t ecn_data_base; /* base address for data area */
419 struct ifnet ecn_if; /* queue of new requests */
422 .so figs/ecn_queue.nr
423 .sh 2 "Queueing in the Driver"
426 illustrates the queueing mechanism used by the driver.
428 CONS queues its data transfer requests at the end of the queue managed by
429 \fCecn_if\fR field in the \fCecn_softc\fR structure.
430 At this point, each request has the state value of
432 Once the driver notifies the adapter that it has a command to post,
433 the driver dequeues the first request from the \fCecn_if\fR queue
435 \fCecn_pending_req\fR to point to the request.
436 At this point, the request is in the \fIREQ_INTERRUPT\fR state.
438 Once the driver posts the request to the adapter, it
439 dequeues the next request in the \fCecn_if\fR queue, reassigns the
440 \fCecn_pending_req\fR pointer, and then indicates to the adapter
441 that it is ready to post another request.
442 The driver no longer has to keep track of the previous request,
443 because for every reply, the adapter includes the associated
445 While the request is outstanding, the request is in the \fIREQ_POSTED\fR state.
448 After the adapter completes the command, the driver may want to reply to CONS.
449 It does this by placing its reply in CONS's \fCconsintrq\fR queue, defined as
450 an external \fCifqueue\fR in the driver code.
451 .sh 2 "Virtual Circuit States"
453 The \fCecn_vc_state\fR array in the \fCecn_softc\fR structure above keeps track
454 of the state of each virtual circuit (VC).
455 This is necessary to avoid handing
456 the adapter any commands that may not apply during a given state.
458 is especially useful in dealing with unexpected aborts or clears where there
459 is the potential for all outstanding commands to complete with errors.
461 states, the driver can prevent redundant commands (like clears and aborts)
462 from being passed either to the adapter or to CONS.
464 The driver only keeps track of four different states, as illustrated in
468 .ip "\fIVC_NO_CONNECTION\fR"
469 When a virtual circuit is in this state, the virtual circuit does not exits.
470 Only \fICALL\fR and \fILISTEN\fR commands are valid.
471 .ip "\fIVC_DATA_XFER\fR"
472 All commands, except \fICALL\fR and \fILISTEN\fR commands are valid once the
474 .ip "\fIVC_RESET_IN_PROGRESS\fR"
475 In this state, either the driver has issued an \fINCB_RESET\fR or it has
476 received a reset error code on the completion of a command.
477 Only reissued \fIRESET\fR commands and \fIRECEIVE\fRs are
479 \fIRECEIVE\fR is valid in this state because the adapter uses the
480 completion of this command to hand back the cause of the reset (the RESET
482 .ip "\fIVC_CLEAR_IN_PROGRESS\fR"
483 The driver has either issued an \fINCB_CLEAR\fR command or has just
484 received a clear error code on the completion of a command.
485 Within this state, only reissued
486 \fICLEAR\fR and \fIABORT\fR commands are valid.
487 .sh 2 "Error Statistics"
489 With the \fCecn_errors\fR field in the \fCecn_softc\fR structure,
490 the driver maintains a two dimensional array of counters
491 if the frequencies of errors.
492 In order to inspect this array easily with
493 the kernel debugger, the first index to every command ( <command, 0> ) is
494 reserved for a four character ASCII command identifier.
496 .sh 3 "The Driver State Machine"
497 .sh 2 "Handling of Normal Command Completions"
499 The chart below lists
500 all the available adapter request types, at what level each of
501 these requests can be used, options, and the driver's action after a normal
502 completion of the command.
511 \fBNormal Completion Handling\fR
513 \fINCB:Options:Action Based on Normal Competion of\fR
514 \fICommand:To Adapter:From Adapter:Driver\(->Adapter Command\fR
516 \fINCB_RESTART\fR:none:none:T{
518 dequeue the request, and issue an NCB_LISTEN request to the adapter.
521 \fINCB_CALL\fR:none:connected:T{
523 dequeue the request, pass an ECN_ACCEPT reply to CONS, and issue a RECEIVE to
529 use zero-length Call User Data and a zero-length Calling DTE address
532 dequeue the request, pass an ECN_CONNECT to CONS, and issue a RECEIVE to the
533 adapter. Re-issue another NCB_LISTEN
534 for another possible virtual circuit connection.
539 normal clearing with all outstanding ACKs returned
558 dequeue the request and reply to CONS with an ECN_ACK.
563 reset the virtual circuit
568 \fINCB_RECEIVE\fR:none:T{
570 normal, uncomplicated receive
573 dequeue the request and bcopy the data into the request's associated mbuf. Ship to CONS. Re-issue another NCB_RECEIVE.
581 same as above (adapter does the resegmentation automatically).
612 dequeue the request, send an ECN_RESET back up to CONS, and issue another
618 .uh "CONS \(-> Driver"
620 All entries in this column indicate that the CONS module can send this request
621 down to the driver. Command names in parenthesis define the mapping between
622 the \fIECN\fR and \fINCB\fR commands.
623 .uh "Driver \(-> Adapter"
625 All checks in this column indicate that the driver can send this request
626 to the adapter. The last column in the above table defines what the driver must
627 do upon normal completion of the command from the adapter.
628 Note that not all driver-to-adapter
629 commands have a CONS-to-driver equivalent.
631 command request is generated within the driver, rather than originating from
633 .uh "Driver \(-> CONS"
635 All entries in this column indicate that the driver can send this reply
636 back to CONS. Command names in parenthesis define the mapping between
637 the \fIECN\fR and \fINCB\fR commands.
639 .sh 3 "Handling of Errors upon Command Completion"
641 Below is listed all the driver request and pseudo request types, along with the
642 actions the driver must perform given a command completion error delivered by
643 the Eicon Network Adapter.
653 \fBError Completion Handling\fR
655 :\fIAction Based on Error Completion of Driver \(-> Adapter Command\fR
656 \fIError Returned\fR:_:_:_:_:_:_:_
657 \fI:NCB_CALL:NCB_LISTEN:NCB_CLEAR:NCB_ABORT:NCB_RESET:NCB_SEND:NCB_RECEIVE\fR
659 \fIST_BAD_LEN\fR:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>
661 \fIST_INVALID\fR:<soft-error>:<soft-error>:<dequeue>:<dequeue>:<dequeue>:<dequeue>:<dequeue>
663 \fIST_COMMAND_TO\fR:<retry>:<retry>:<retry>:<retry>:<abort>:<abort>:<retry>
665 \fIST_ISSUE_ANOTHER_RCV\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:T{
667 requeue request and increment "more" count
670 \fIST_BAD_LSN\fR:<soft-error>:<soft-error>:<dequeue>:<dequeue>:<dequeue>:<dequeue>:<dequeue>
672 \fIST_NO_RESOURCES\fR:<retry>:<retry>:<retry>:<retry>:<abort>:<abort>:<retry>
674 \fIST_CALL_CLEARED\fR:<refuse>:<retry>:<retry>:<retry>:<clear>:<clear>:<clear>
676 \fIST_COMMAND_CANCELLED\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>:
678 \fIST_NO_CIRCUITS\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>
680 \fIST_CALL_UNSUCCESSFUL\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>
682 \fIST_INCORRECT_CALLNAME\fR:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>:<soft-error>
684 \fIST_X25_RESET\fR:<refuse>:<retry>:<retry>:<retry>:<dequeue>:<dequeue>:<retry>
686 \fIST_TOO_MANY_COMMANDS\fR:<retry>:<retry>:<retry>:<retry>:<abort>:<abort>:<retry>
688 \fIST_L1_NO_DATA_SET_READY\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>
690 \fIST_L1_NO_CLEAR_TO_SEND\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>
692 \fIST_L1_NO_CLOCK\fR:<refuse>:<retry>:<retry>:<retry>:<abort>:<abort>:<abort>
697 Each of the actions from the above chart are defined as follows.
698 .ip "\fI<abort>\fR -"
699 The driver should clear the connection by issuing an \fINCB_ABORT\fR
700 to the adapter and sending an \fIECN_CLEAR\fR to CONS.
701 .ip "\fI<refuse>\fR -"
702 The driver should send an \fIECN_REFUSE\fR back to CONS.
703 .ip "\fI<dequeue>\fR -"
704 The driver should simply dequeue the request. Usually these errors occur when a
705 reset or clear occurs on the adapter while the driver is in the midst of
706 issuing the command which subsequently completes with an error status.
707 .ip "\fI<clear>\fR -"
708 The driver should send an \fIECN_CLEAR\fR back up to CONS.
709 .ip "\fI<retry>\fR -"
710 The driver should requeue the request if and only if the
711 \fCecn_retry_cnt\fR field in the request structure does not exceed the
713 .ip "\fI<soft-error>\fR -"
714 This action only takes place when a software error has occurred. The driver
716 print the error to the console in big bold letters and then panic.
718 .sh 3 "The IFP Flags"
720 The IFP flags in the standard \fCifnet\fR structure
721 should be used in the following way.
722 .ip "\fIIFF_UP on -\fR"
723 This flag is set by the driver only after the procedure \fIecnrestart()\fR
724 successfully completes.
725 .ip "\fIIFF_UP off -\fR"
726 This flag is set immediately upon entry into the procedure \fIecnshutdown()\fR.
727 .ip "\fIIFF_RUNNING on -\fR"
728 This flag is set on whenever the \fIecnwork()\fR procedure is active, eg. the
729 driver is actually doing something.
730 .ip "\fIIFF_RUNNING off -\fR"
731 This flag is turned off upon exit from the \fIecnwork()\fR procedure.