home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: 10 Tools
/
10-Tools.zip
/
xco212p.zip
/
ISODEF
/
coroutin.def
< prev
next >
Wrap
Text File
|
1994-12-28
|
4KB
|
89 lines
<*+ M2EXTENSIONS *>
DEFINITION MODULE COROUTINES;
(* Facilities for coroutines and the handling of interrupts *)
IMPORT SYSTEM;
TYPE
COROUTINE; (* Values of this type are created dynamically by NEWCOROUTINE
and identify the coroutine in subsequent operations *)
INTERRUPTSOURCE = (* implementation-defined *)
(i0,i1,i2,i3,i4,i5,i6,i7,i8,i9,
i10,i11,i12,i13,i14,i15,i16,i17,i18,i19,
i20,i21,i22,i23,i24,i25,i26,i27,i28,i29,
i30,i31,i32,i33,i34,i35,i36,i37,i38,i39,
i40,i41,i42,i43,i44,i45,i46,i47,i48,i49,
i50,i51,i52,i53,i54,i55,i56,i57,i58,i59,
i60,i61,i62,i63,i64,i65,i66,i67,i68,i69,
i70,i71,i72,i73,i74,i75,i76,i77,i78,i79,
i80,i81,i82,i83,i84,i85,i86,i87,i88,i89,
i90,i91,i92,i93,i94,i95,i96,i97,i98,i99,
i100,i101,i102,i103,i104,i105,i106,i107,i108,i109,
i110,i111,i112,i113,i114,i115,i116,i117,i118,i119,
i120,i121,i122,i123,i124,i125,i126,i127,i128,i129,
i130,i131,i132,i133,i134,i135,i136,i137,i138,i139,
i140,i141,i142,i143,i144,i145,i146,i147,i148,i149,
i150,i151,i152,i153,i154,i155,i156,i157,i158,i159,
i160,i161,i162,i163,i164,i165,i166,i167,i168,i169,
i170,i171,i172,i173,i174,i175,i176,i177,i178,i179,
i180,i181,i182,i183,i184,i185,i186,i187,i188,i189,
i190,i191,i192,i193,i194,i195,i196,i197,i198,i199,
i200,i201,i202,i203,i204,i205,i206,i207,i208,i209,
i210,i211,i212,i213,i214,i215,i216,i217,i218,i219,
i220,i221,i222,i223,i224,i225,i226,i227,i228,i229,
i230,i231,i232,i233,i234,i235,i236,i237,i238,i239,
i240,i241,i242,i243,i244,i245,i246,i247,i248,i249,
i250,i251,i252,i253,i254,i255);
PROCEDURE NEWCOROUTINE (procBody: PROC; workspace: SYSTEM.ADDRESS; size: CARDINAL;
VAR cr: COROUTINE;
initProtection:=INTERRUPTIBLE: PROTECTION);
(* Creates a new coroutine whose body is given by procBody, and returns the identity
of the coroutine in cr. workspace is a pointer to the work space allocated to
the coroutine; size specifies the size of this workspace in terms of SYSTEM.LOC.
initProtection is an optional parameter that specifies the initial protection
level of the coroutine.
*)
PROCEDURE TRANSFER (VAR from: COROUTINE; to: COROUTINE);
(* Returns the identity of the calling coroutine in from, and transfers control to
the coroutine specified by to.
*)
PROCEDURE IOTRANSFER (VAR from: COROUTINE; to: COROUTINE);
(* Returns the identity of the calling coroutine in from and transfers control to
the coroutine specified by to. On occurrence of an interrupt, associated with the
caller, control is transferred back to the caller, and the identity of the
interrupted coroutine is returned in from. The calling coroutine must be
associated with a source of interrupts.
*)
PROCEDURE ATTACH (source: INTERRUPTSOURCE);
(* Associates the specified source of interrupts with the calling coroutine. *)
PROCEDURE DETACH (source: INTERRUPTSOURCE);
(* Dissociates the specified source of interrupts from the calling coroutine. *)
PROCEDURE IsATTACHED (source: INTERRUPTSOURCE): BOOLEAN;
(* Returns TRUE if and only if the specified source of interrupts is currently
associated with a coroutine; otherwise returns FALSE.
*)
PROCEDURE HANDLER (source: INTERRUPTSOURCE): COROUTINE;
(* Returns the coroutine, if any, that is associated with the source of interrupts.
The result is undefined if IsATTACHED(source) = FALSE.
*)
PROCEDURE CURRENT (): COROUTINE;
(* Returns the identity of the calling coroutine. *)
PROCEDURE LISTEN (p: PROTECTION);
(* Momentarily changes the protection of the calling coroutine to p. *)
PROCEDURE PROT (): PROTECTION;
(* Returns the protection of the calling coroutine. *)
END COROUTINES.