Process.st
author Claus Gittinger <cg@exept.de>
Wed, 01 Nov 1995 15:44:26 +0100
changeset 468 72dfba4603b4
parent 399 c15cfaf3ed4d
child 530 07d0bce293c9
permissions -rw-r--r--
Initial revision
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Link subclass:#Process
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    14
	 instanceVariableNames:'id prio state startBlock name 
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    15
				restartable interruptActions 
375
claus
parents: 359
diff changeset
    16
				exitActions suspendSemaphore 
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    17
				singleStepping emergencySignalHandler'
302
1f76060d58a4 *** empty log message ***
claus
parents: 252
diff changeset
    18
	 classVariableNames:'TerminateSignal CoughtSignals'
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    19
	 poolDictionaries:''
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    20
	 category:'Kernel-Processes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
Process comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    24
COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    25
	     All Rights Reserved
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    26
399
claus
parents: 384
diff changeset
    27
$Header: /cvs/stx/stx/libbasic/Process.st,v 1.33 1995-08-16 18:27:03 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    28
'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    30
!Process class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    31
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    32
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    34
 COPYRIGHT (c) 1992 by Claus Gittinger
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    35
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    36
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    37
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    41
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    44
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    45
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    46
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    47
"
399
claus
parents: 384
diff changeset
    48
$Header: /cvs/stx/stx/libbasic/Process.st,v 1.33 1995-08-16 18:27:03 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    49
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    50
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    51
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    52
documentation
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    53
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    54
    Instances of Process represent lightweight smalltalk processes 
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    55
    (i.e. threads). These all run in a shared smalltalk/X address space,
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    56
    and can thus access and communicate via any objects.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    57
    Do not confuse these with (heavy-weight) unix processes, which are
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    58
    created differently, and do NOT run in the same address space.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    59
    Also notice, that heavy-weight process creation takes much longer.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    60
    (see OperatingSystemclass>>fork).
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    61
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    62
    Processes are typically created by sending #fork or #forkAt: to a block;
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    63
    the block creates a new process, defines itself as its startBlock,
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    64
    and (optionally) tells the Processor about the new process.
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    65
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    66
    Scheduling is done by Processor, which is the sole instance of 
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    67
    ProcessorScheduler.
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    68
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    69
    Processes can be terminated either soft or via a hardTerminate.
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    70
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    71
    A soft terminate (see Process>>terminate) will raise a TerminationSignal
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    72
    in the process, which can be handled by the process. 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    73
    If no other handler was specified, the processes own handler 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    74
    (see Process>>start) will catch the signal and terminate the process. 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    75
    During this signal processing, normal unwind processing takes place,
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    76
    this means that with a soft terminate, all valueOnUnwind:/valueNowOrOnUnwind: 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    77
    cleanup blocks are evaluated.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    78
    (so a process which has set up those blocks correctly does not have to
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    79
     care especially about cleanup in case of termination).
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    80
    Other than that, the TerminateSignal can be cought for special cleanup or
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    81
    even to make the process continue execution.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    82
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    83
    A hard terminate (Process>>terminateNoSignal) will NOT do all of the above,
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    84
    but quickly (and without any cleanup) terminate the process.
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    85
    The debugger offers a quickTerminate option on its popupMenu for
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    86
    situations, when soft termination fails. (for example, if some error was
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    87
    coded into a handler or unwind block).
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    88
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    89
    Notice: 
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    90
	in Smalltalk/X, processes are gone, when an image is restarted;
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    91
	this means, that you have to take care of process re-creation yourself.
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    92
	Usually, this is done by depending on ObjectMemory, recreating the
375
claus
parents: 359
diff changeset
    93
	process(es) when the #returnFromSnapshot-change notifiction arrives.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    94
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    95
	All views (actually windowGroups) recreate their window process
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
    96
	on image-restart. You have to do so manually for your own processes.
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    97
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
    98
    A later version will allow specification of automatic restart, but
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    99
    thats not yet implemented. However, even when implemented, restartable processes
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   100
    will be recreated to restart from the beginning. It will not be possible to
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   101
    automatically continue a processes execution where it left off.
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   102
    This is a consequence of the portable implementation of ST/X, since in order to
375
claus
parents: 359
diff changeset
   103
    implement process continuation, the machines stack had to be preserved and 
claus
parents: 359
diff changeset
   104
    recreated.  Although this is possible to do (and actually not too complicated), 
claus
parents: 359
diff changeset
   105
    this has not been implemented, since the machines stack layout is highly machine/compiler 
claus
parents: 359
diff changeset
   106
    dependent, thus leading to much bigger porting effort of ST/X (which conflicts
claus
parents: 359
diff changeset
   107
    with ST/X's design goal of being highly portable).
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   108
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   109
    Process synchronization:
375
claus
parents: 359
diff changeset
   110
	Synchronization with cooperating processes is supported as usual,
claus
parents: 359
diff changeset
   111
	via Semaphores (see Semaphore, Delay, SharedQueue etc.)
claus
parents: 359
diff changeset
   112
claus
parents: 359
diff changeset
   113
	With uncooperative processes, only synchronization on suspend
claus
parents: 359
diff changeset
   114
	and termination is possible:
claus
parents: 359
diff changeset
   115
	  any other process can wait for a process to suspend or terminate. 
claus
parents: 359
diff changeset
   116
	  This waiting is implemented by using suspendSemaphore and exitBlocks
claus
parents: 359
diff changeset
   117
	  (where an exitSemaphore is signalled).
claus
parents: 359
diff changeset
   118
	  See waitUntilSuspended / waitUntilTerminated.
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   119
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   120
    Instance variables:
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   121
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   122
	id                     <SmallInteger>   a unique process-id
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   123
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   124
	prio                   <SmallInteger>   the processes priority
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   125
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   126
	state                  <Symbol>         the processes state
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   127
						(for process-monitor)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   128
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   129
	startBlock             <Block>          the startup-block (the one that forked)
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   130
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   131
	name                   <String-or-nil>  the processes name (if any)
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   132
						(for process-monitor)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   133
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   134
	suspendSemaphore       <Semaphore>      triggered when suspend (if nonNil)
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   135
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   136
	restartable            <Boolean>        is restartable (not yet implemented)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   137
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   138
	interruptActions       <Collection>     interrupt actions as defined by interruptWith:,
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   139
						performed at interrupt time
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   140
375
claus
parents: 359
diff changeset
   141
	exitActions            <Collection of Block>          
claus
parents: 359
diff changeset
   142
						additional cleanup actions to perform 
claus
parents: 359
diff changeset
   143
						on termination (if nonEmpty)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   144
                                                
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   145
	emergencySignalHandler <Block>          can be used for per-process
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   146
						emergency signal handling
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   147
    Class variables:
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   148
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   149
	TerminateSignal         <Signal>        signal used to terminate processes
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   150
						(should not be cought - or at least
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   151
						 rejected in handlers)
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   152
"
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   153
!
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   154
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   155
examples 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   156
"
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   157
    start a background process, computing 1000 factorial 100 times;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   158
    the processes priority is set to not disturb any interactive process.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   159
    Since its prio is higher than the 3D animation demos prio, you will notice,
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   160
    that those are suspended while the computation runs. But Interactive views
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   161
    (like browsers) will continue to react normal.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   162
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   163
    [
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   164
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   165
       100 timesRepeat:[1000 factorial].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   166
       'done with factorial' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   167
    ] forkAt:(Processor userBackgroundPriority).
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   168
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   169
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   170
    start a background process, computing 1000 factorial 100 times;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   171
    the processes priority is set to not disturb any process.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   172
    The prio is set to 1 (which is the lowest possible) notice that now,
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   173
    the 3D animation demos also continue to run. 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   174
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   175
    [
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   176
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   177
       100 timesRepeat:[1000 factorial].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   178
       'done with factorial' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   179
    ] forkAt:1.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   180
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   181
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   182
    start a background process, reading a pipe without blocking other
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   183
    processes;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   184
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   185
    [
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   186
       |p|
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   187
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   188
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   189
       p := PipeStream readingFrom:'ls -lR .'.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   190
       [p atEnd] whileFalse:[
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   191
	   p readWait.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   192
	   p nextLine printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   193
       ].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   194
       p close.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   195
       'done with pipe' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   196
    ] forkAt:1.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   197
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   198
    see more examples in doc/coding 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   199
    (or search in the browser for senders of fork*)
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   200
"
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   201
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   203
!Process class methodsFor:'initialization'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   204
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   205
initialize
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   206
    TerminateSignal isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   207
	TerminateSignal := Signal new mayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   208
	TerminateSignal nameClass:self message:#terminateSignal.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   209
	TerminateSignal notifierString:'unhandled process termination'.
302
1f76060d58a4 *** empty log message ***
claus
parents: 252
diff changeset
   210
1f76060d58a4 *** empty log message ***
claus
parents: 252
diff changeset
   211
	CoughtSignals := SignalSet with:AbortSignal with:TerminateSignal.
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   212
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   213
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   214
345
claus
parents: 339
diff changeset
   215
!Process class methodsFor:'Signal constants'!
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   216
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   217
terminateSignal
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   218
    "return the signal used for process termination"
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   219
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   220
    ^ TerminateSignal
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   221
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   222
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   223
!Process class methodsFor:'instance creation'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   224
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   225
for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   226
    "create a new (unscheduled) process which will execute aBlock at
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   227
     a given priority, once scheduled. The process will start execution once
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   228
     it gets a #resume-message."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   229
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   230
    ^ self new for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   231
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   232
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   233
!Process methodsFor:'private'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   234
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   235
for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   236
    "setup the new process - the receiver is not scheduled for
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   237
     execution, to get it running, send it #resume"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   238
339
claus
parents: 337
diff changeset
   239
    |nm active|
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   240
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   241
    prio := aPrio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   242
    startBlock := aBlock.
339
claus
parents: 337
diff changeset
   243
    restartable := false.
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   244
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   245
    (Processor newProcessFor:self) ifFalse:[ 
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   246
	"for some reason, the Processor was unable to create
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   247
	 a VM process for me ...."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   248
	^ nil
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   249
    ].
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   250
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   251
    "
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   252
     give me a user-friendly name
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   253
    "
339
claus
parents: 337
diff changeset
   254
    active := Processor activeProcess.
claus
parents: 337
diff changeset
   255
    (nm :=  active name) notNil ifTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   256
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   257
	 avoid name inflation
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   258
	"
314
7581a5c57224 *** empty log message ***
claus
parents: 302
diff changeset
   259
	(nm endsWith:' sub') ifFalse:[
339
claus
parents: 337
diff changeset
   260
	    nm := nm , ' [' ,  active id printString , '] sub'
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   261
	].
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   262
	name := nm
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   263
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   264
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   265
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
!Process methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
state
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   269
    "return a symbol describing the processes state"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   270
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
    ^ state
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
state:aSymbol
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   275
    "set the state - only to be used from scheduler"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   276
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
    state := aSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
182
f531860566fc more queries
claus
parents: 159
diff changeset
   280
isDead
f531860566fc more queries
claus
parents: 159
diff changeset
   281
    "return true, if the receiver has already terminated"
f531860566fc more queries
claus
parents: 159
diff changeset
   282
f531860566fc more queries
claus
parents: 159
diff changeset
   283
    ^ state == #dead
f531860566fc more queries
claus
parents: 159
diff changeset
   284
!
f531860566fc more queries
claus
parents: 159
diff changeset
   285
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   286
startBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   287
    "return the processes startup-block"
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   288
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   289
    ^ startBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   292
emergencySignalHandler:aOneArgBlock
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   293
    "set the emergencySignalHandler block.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   294
     See Signal>>documentation for more info."
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   295
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   296
    emergencySignalHandler := aOneArgBlock
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   297
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   298
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   299
emergencySignalHandler
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   300
    "return the emergencySignalHandler block.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   301
     See Signal>>documentation for more info."
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   302
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   303
    ^ emergencySignalHandler
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   304
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   305
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
priority
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
    "return the receivers priority"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
    ^ prio
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
priority:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
    "set my priority"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   315
    Processor changePriority:aNumber for:self.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   316
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   317
329
claus
parents: 326
diff changeset
   318
isRestartable
claus
parents: 326
diff changeset
   319
    "return true, iff the receiver is restartable"
claus
parents: 326
diff changeset
   320
claus
parents: 326
diff changeset
   321
    ^ restartable
claus
parents: 326
diff changeset
   322
!
claus
parents: 326
diff changeset
   323
claus
parents: 326
diff changeset
   324
restartable:aBoolean
claus
parents: 326
diff changeset
   325
    "set/clear, the restartable flag.
claus
parents: 326
diff changeset
   326
     Restartable processes will automatically be restarted by the
claus
parents: 326
diff changeset
   327
     ProcessorScheduler upon image restart. Others have to be restarted
claus
parents: 326
diff changeset
   328
     manually."
claus
parents: 326
diff changeset
   329
337
claus
parents: 329
diff changeset
   330
    startBlock isNil ifTrue:[
claus
parents: 329
diff changeset
   331
	self error:'cannot be made restartable when already started'.
claus
parents: 329
diff changeset
   332
	^ self
claus
parents: 329
diff changeset
   333
    ].
329
claus
parents: 326
diff changeset
   334
    restartable := aBoolean
claus
parents: 326
diff changeset
   335
!
claus
parents: 326
diff changeset
   336
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   337
changePriority:aNumber
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   338
    "same as priority:, but returns the old priority.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   339
     (cannot do this in priority: for ST-80 compatibility)"
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   340
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   341
    |oldPrio|
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   342
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   343
    oldPrio := prio.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   344
    Processor changePriority:aNumber for:self.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   345
    ^ oldPrio
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   348
isSingleStepping
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   349
    ^ singleStepping
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   350
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   351
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   352
singleStep:aBoolean
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   353
    singleStepping := aBoolean
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   354
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   355
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
id
10
claus
parents: 5
diff changeset
   357
    "return the processes id"
claus
parents: 5
diff changeset
   358
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
    ^ id
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   362
name
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   363
    "return the processes name"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   364
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   365
    ^ name
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   366
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   367
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   368
name:aString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   369
    "set the processes name"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   370
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   371
    name := aString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   372
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   373
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   374
nameOrId
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   375
    "return a string to identify the process - either name or id"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   376
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   377
    name notNil ifTrue:[^ name].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   378
    ^ id printString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   379
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   380
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   381
exitAction:aBlock
375
claus
parents: 359
diff changeset
   382
    "add aBlock to the processes exit actions.
182
f531860566fc more queries
claus
parents: 159
diff changeset
   383
     This will be evaluated right before the process dies."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   384
375
claus
parents: 359
diff changeset
   385
    exitActions isNil ifTrue:[
claus
parents: 359
diff changeset
   386
	exitActions := OrderedCollection new
claus
parents: 359
diff changeset
   387
    ].
claus
parents: 359
diff changeset
   388
    exitActions add:aBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   389
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
suspendedContext
182
f531860566fc more queries
claus
parents: 159
diff changeset
   392
    "return the processes suspended context 
f531860566fc more queries
claus
parents: 159
diff changeset
   393
     - this is the context from which a process switch into the scheduler
f531860566fc more queries
claus
parents: 159
diff changeset
   394
     or another process occured.
f531860566fc more queries
claus
parents: 159
diff changeset
   395
     Typically, only the debugger is interrested in this one."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   396
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   397
%{  /* NOCONTEXT */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   398
    extern OBJ __threadContext();
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   399
    OBJ i;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
252
   401
    if (__isSmallInteger(i = _INST(id))) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   402
	RETURN (__threadContext(_intVal(i)));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   403
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   404
%}.
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   405
    ^ nil
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   406
!
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   407
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   408
maximumStackSize
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   409
    "returns the processes stack limit - i.e. the process will be 
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   410
     interrupted with a recursionSignal-raise, if it ever
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   411
     needs more stack (in bytes) than this number"
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   412
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   413
%{  /* NOCONTEXT */
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   414
    extern int __threadMaxStackSize();
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   415
    OBJ i;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   416
252
   417
    if (__isSmallInteger(i = _INST(id))) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   418
	RETURN( _MKSMALLINT(__threadMaxStackSize(_intVal(i))) );
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   419
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   420
%}.
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   421
    ^ nil
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   422
!
182
f531860566fc more queries
claus
parents: 159
diff changeset
   423
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   424
setMaximumStackSize:limit
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   425
    "sets the processes stack limit - i.e. the process will be
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   426
     interrupted with a recursionSignal-raise, if it ever
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   427
     needs more stack (in bytes) than this number.
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   428
     Returns the old value."
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   429
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   430
%{  /* NOCONTEXT */
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   431
    extern int __threadSetMaxStackSize();
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   432
    OBJ i;
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   433
252
   434
    if (__isSmallInteger(i = _INST(id)) 
   435
     && __isSmallInteger(limit) ) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   436
	RETURN ( _MKSMALLINT(__threadSetMaxStackSize(_intVal(i), _intVal(limit))) );
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   437
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   438
%}.
f531860566fc more queries
claus
parents: 159
diff changeset
   439
    ^ nil
f531860566fc more queries
claus
parents: 159
diff changeset
   440
! !
f531860566fc more queries
claus
parents: 159
diff changeset
   441
f531860566fc more queries
claus
parents: 159
diff changeset
   442
!Process methodsFor:'monitoring'!
f531860566fc more queries
claus
parents: 159
diff changeset
   443
375
claus
parents: 359
diff changeset
   444
vmTrace:aBoolean
claus
parents: 359
diff changeset
   445
    "turn on/off VM message tracing for the receiver.
399
claus
parents: 384
diff changeset
   446
     This is meant for ST/X debugging, and may vanish.
375
claus
parents: 359
diff changeset
   447
     Expect lots of output, once this is turned on."
claus
parents: 359
diff changeset
   448
claus
parents: 359
diff changeset
   449
%{  /* NOCONTEXT */
claus
parents: 359
diff changeset
   450
    OBJ i;
claus
parents: 359
diff changeset
   451
claus
parents: 359
diff changeset
   452
    if (__isSmallInteger(i = _INST(id))) {
claus
parents: 359
diff changeset
   453
	__threadTracing(_intVal(i), aBoolean);
claus
parents: 359
diff changeset
   454
    }
claus
parents: 359
diff changeset
   455
%}.
claus
parents: 359
diff changeset
   456
!
claus
parents: 359
diff changeset
   457
182
f531860566fc more queries
claus
parents: 159
diff changeset
   458
usedStackSize
f531860566fc more queries
claus
parents: 159
diff changeset
   459
    "Return the processes current stack size.
f531860566fc more queries
claus
parents: 159
diff changeset
   460
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   461
f531860566fc more queries
claus
parents: 159
diff changeset
   462
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   463
    extern int __threadUsedStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   464
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   465
252
   466
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   467
	RETURN( _MKSMALLINT(__threadUsedStackSize(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   468
    }
f531860566fc more queries
claus
parents: 159
diff changeset
   469
%}.
f531860566fc more queries
claus
parents: 159
diff changeset
   470
    ^ nil
f531860566fc more queries
claus
parents: 159
diff changeset
   471
!
f531860566fc more queries
claus
parents: 159
diff changeset
   472
f531860566fc more queries
claus
parents: 159
diff changeset
   473
totalStackSize
f531860566fc more queries
claus
parents: 159
diff changeset
   474
    "return the processes maximum used stack size.
f531860566fc more queries
claus
parents: 159
diff changeset
   475
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   476
f531860566fc more queries
claus
parents: 159
diff changeset
   477
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   478
    extern int __threadTotalStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   479
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   480
252
   481
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   482
	RETURN( _MKSMALLINT(__threadTotalStackSize(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   483
    }
f531860566fc more queries
claus
parents: 159
diff changeset
   484
%}.
f531860566fc more queries
claus
parents: 159
diff changeset
   485
    ^ nil
f531860566fc more queries
claus
parents: 159
diff changeset
   486
!
f531860566fc more queries
claus
parents: 159
diff changeset
   487
f531860566fc more queries
claus
parents: 159
diff changeset
   488
numberOfStackSegments
f531860566fc more queries
claus
parents: 159
diff changeset
   489
    "return the processes number of stack segments currently used.
f531860566fc more queries
claus
parents: 159
diff changeset
   490
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   491
f531860566fc more queries
claus
parents: 159
diff changeset
   492
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   493
    extern int __threadTotalStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   494
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   495
252
   496
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   497
	RETURN( _MKSMALLINT(__threadStackSegments(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   498
    }
f531860566fc more queries
claus
parents: 159
diff changeset
   499
%}.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   500
    ^ nil
359
claus
parents: 348
diff changeset
   501
!
claus
parents: 348
diff changeset
   502
claus
parents: 348
diff changeset
   503
numberOfStackBoundaryHits
claus
parents: 348
diff changeset
   504
    "internal monitoring only - will vanish"
claus
parents: 348
diff changeset
   505
claus
parents: 348
diff changeset
   506
%{  /* NOCONTEXT */
claus
parents: 348
diff changeset
   507
    extern int __threadNumberOfStackBoundaryHits();
claus
parents: 348
diff changeset
   508
    int n;
claus
parents: 348
diff changeset
   509
    OBJ i;
claus
parents: 348
diff changeset
   510
claus
parents: 348
diff changeset
   511
    if (__isSmallInteger(i = _INST(id))) {
375
claus
parents: 359
diff changeset
   512
	n = __threadNumberOfStackBoundaryHits(_intVal(i));
359
claus
parents: 348
diff changeset
   513
	n &= 0x3FFFFFFF;
375
claus
parents: 359
diff changeset
   514
	RETURN( _MKSMALLINT(n) );
359
claus
parents: 348
diff changeset
   515
    }
claus
parents: 348
diff changeset
   516
%}.
claus
parents: 348
diff changeset
   517
    ^ nil
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   518
! !
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   519
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   520
!Process methodsFor:'private scheduler access'!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   521
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   522
setPriority:aNumber
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   523
    "set priority without telling processor - not for public use"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   524
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   525
    prio := aNumber
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   526
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   527
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   528
setStartBlock:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   529
    "set the receivers startup block"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   530
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   531
    startBlock := aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   532
!
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   533
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   534
setStateTo:newState if:oldState
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   535
    state == oldState ifTrue:[state := newState]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   536
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   537
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   538
setStateTo:newState if:oldState1 or:oldState2
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   539
    (state == oldState1 or:[state == oldState2]) ifTrue:[state := newState]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   540
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   541
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   542
setId:idNumber state:stateSymbol
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   543
    "set id and state - not for public use"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   544
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   545
    id := idNumber.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   546
    state := stateSymbol.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   547
! !
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   548
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   549
!Process methodsFor:'startup '!
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   550
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   551
start
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   552
    "start the process - this is sent by the VM to the process to get
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   553
     the process up and running.
329
claus
parents: 326
diff changeset
   554
     Sending #start to the process (instead of directly executing the startBlock)
claus
parents: 326
diff changeset
   555
     allows more flexible handling of processes, since anything that responds 
claus
parents: 326
diff changeset
   556
     to #start can be handled transparently by the VM then ..."
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   557
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   558
    |block|
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   559
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   560
    (block := startBlock) notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   561
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   562
	 just for your convenience ...
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   563
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   564
	name isNil ifTrue:[
359
claus
parents: 348
diff changeset
   565
	    name := '(' , block displayString , ')'
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   566
	].
329
claus
parents: 326
diff changeset
   567
	restartable ~~ true ifTrue:[startBlock := nil].
302
1f76060d58a4 *** empty log message ***
claus
parents: 252
diff changeset
   568
	CoughtSignals handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   569
	    ex return
182
f531860566fc more queries
claus
parents: 159
diff changeset
   570
	] do:block.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   571
375
claus
parents: 359
diff changeset
   572
	self terminateNoSignal.
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   573
    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   574
	"is this artificial restriction useful ?"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   575
	self error:'a process cannot be started twice'
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   576
    ]
337
claus
parents: 329
diff changeset
   577
!
claus
parents: 329
diff changeset
   578
claus
parents: 329
diff changeset
   579
restart
claus
parents: 329
diff changeset
   580
    "restart the process from the beginning.
claus
parents: 329
diff changeset
   581
     This is sent by the ProcessorScheduler to all restartable processes."
claus
parents: 329
diff changeset
   582
339
claus
parents: 337
diff changeset
   583
"/  ('restart process ' , id printString) errorPrintNL.
claus
parents: 337
diff changeset
   584
claus
parents: 337
diff changeset
   585
    (Processor newProcessFor:self withId:id) ifFalse:[ 
337
claus
parents: 329
diff changeset
   586
	"for some reason, the Processor was unable to create
claus
parents: 329
diff changeset
   587
	 a VM process for me ...."
claus
parents: 329
diff changeset
   588
claus
parents: 329
diff changeset
   589
	('process ' , id printString , ' failed to restart.') errorPrintNL.
claus
parents: 329
diff changeset
   590
	^ nil
claus
parents: 329
diff changeset
   591
    ].
claus
parents: 329
diff changeset
   592
    self resume
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
!Process methodsFor:'suspend / resume'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
326
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   597
stop
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   598
    "suspend the receiver process - will continue to run when a resume is sent.
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   599
     A stopped process will not be resumed for interrupt processing."
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   600
329
claus
parents: 326
diff changeset
   601
    suspendSemaphore notNil ifTrue:[suspendSemaphore signalForAll].
326
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   602
    state := #stopped.
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   603
    Processor suspend:self
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   604
!
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   605
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
suspend
326
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   607
    "suspend the receiver process - will continue to run when a resume is sent.
d2902942491d *** empty log message ***
claus
parents: 314
diff changeset
   608
     An interrupt will resume the receiver."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   609
329
claus
parents: 326
diff changeset
   610
    suspendSemaphore notNil ifTrue:[suspendSemaphore signalForAll].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
    Processor suspend:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
a27a279701f8 Initial revision
claus
parents:
diff changeset
   614
resume
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   615
    "resume the receiver process"
10
claus
parents: 5
diff changeset
   616
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
    Processor resume:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   620
resumeForSingleSend
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   621
    "resume the receiver process, but only let it execute a single send."
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   622
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   623
    Processor resumeForSingleSend:self
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   624
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   625
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
terminate
375
claus
parents: 359
diff changeset
   627
    "terminate the receiver process. Termination is done by raising
claus
parents: 359
diff changeset
   628
     the terminateSignal in the receiver process, which can be cought.
claus
parents: 359
diff changeset
   629
     All unwind actions and the exit-actions (if any)
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   630
     will be performed before the process is really terminated."
10
claus
parents: 5
diff changeset
   631
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   632
    Processor activeProcess == self ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   633
	Signal noHandlerSignal handle:[:ex |
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   634
	    ex return.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   635
	] do:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   636
	    TerminateSignal raise.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   637
	].
375
claus
parents: 359
diff changeset
   638
	self terminateNoSignal.
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   639
    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   640
	self interruptWith:[self terminate]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   641
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   642
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   643
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   644
terminateNoSignal
375
claus
parents: 359
diff changeset
   645
    "terminate the receiver process without sending a terminateSignal
claus
parents: 359
diff changeset
   646
     or performing any unwind-handling.
claus
parents: 359
diff changeset
   647
     However, exit-actions are performed."
claus
parents: 359
diff changeset
   648
claus
parents: 359
diff changeset
   649
    |block|
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   650
375
claus
parents: 359
diff changeset
   651
    exitActions notNil ifTrue:[
claus
parents: 359
diff changeset
   652
	[exitActions notEmpty] whileTrue:[
claus
parents: 359
diff changeset
   653
	    block := exitActions removeFirst.
claus
parents: 359
diff changeset
   654
	    block value.
claus
parents: 359
diff changeset
   655
	]
claus
parents: 359
diff changeset
   656
    ].
329
claus
parents: 326
diff changeset
   657
    suspendSemaphore notNil ifTrue:[suspendSemaphore signalForAll].
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   658
    Processor terminateNoSignal:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   661
!Process methodsFor:'interrupts'!
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   662
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   663
interruptWith:aBlock
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   664
    "interrupt the receiver and make it evaluate aBlock.
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   665
     If the receiver is currently suspended, the block will be remembered
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   666
     to be evaluated once the receiver wakes up."
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   667
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   668
    self uninterruptablyDo:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   669
	interruptActions isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   670
	    interruptActions := OrderedCollection with:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   671
	] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   672
	    interruptActions addLast:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   673
	].
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   674
    ].
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   675
    Processor scheduleForInterrupt:self.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   676
!
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   677
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   678
interrupt
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   679
    "evaluate my interrupt-actions
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   680
     the process will go back to where it got interrupted
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   681
     after doing this.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   682
    "
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   683
    |action|
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   684
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   685
    [interruptActions notNil and:[interruptActions notEmpty]] whileTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   686
	action := interruptActions removeFirst.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   687
	action value
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   688
    ].
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   689
    interruptActions := nil
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   690
! !
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   691
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   692
!Process methodsFor:'special'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   693
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   694
withPriority:aPrio do:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   695
    "execute aBlock at another priority. This can be used to perform
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   696
     time-consuming operations at a more user-friendly priority,
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   697
     or some critical action at a higher priority. Do not use too high
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   698
     of a priority to avoid locking up the system (event processing takes place
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   699
     at 24)"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   700
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   701
    |oldprio|
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   702
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   703
    oldprio := prio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   704
    self priority:aPrio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   705
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   706
    ^ aBlock valueNowOrOnUnwindDo:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   707
	self priority:oldprio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   708
    ]
182
f531860566fc more queries
claus
parents: 159
diff changeset
   709
f531860566fc more queries
claus
parents: 159
diff changeset
   710
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   711
     Processor activeProcess withPriority:7 do:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   712
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   713
    "be careful - even ^C wont work until done:
f531860566fc more queries
claus
parents: 159
diff changeset
   714
     Processor activeProcess withPriority:25 do:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   715
    "
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   716
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   717
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   718
withLowerPriorityDo:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   719
    "execute aBlock at a lower priority. This can be used to perform
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   720
     time-consuming operations at a more user-friendly priority."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   721
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   722
    ^ self withPriority:(prio - 1) do:aBlock
182
f531860566fc more queries
claus
parents: 159
diff changeset
   723
f531860566fc more queries
claus
parents: 159
diff changeset
   724
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   725
     Processor activeProcess withLowerPriorityDo:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   726
    "
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   727
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   728
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   729
uninterruptablyDo:aBlock
348
claus
parents: 345
diff changeset
   730
    "execute aBlock with interrupts blocked. 
claus
parents: 345
diff changeset
   731
     This does not prevent preemption by a higher priority processes
claus
parents: 345
diff changeset
   732
     if any becomes runnable due to the evaluation of aBlock
claus
parents: 345
diff changeset
   733
     (i.e. if a semaphore is signalled there)."
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   734
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   735
    |wasBlocked|
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   736
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   737
    "we must keep track of blocking-state if this is called nested"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   738
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   739
    wasBlocked := OperatingSystem blockInterrupts.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   740
    ^ aBlock valueNowOrOnUnwindDo:[
182
f531860566fc more queries
claus
parents: 159
diff changeset
   741
	wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
f531860566fc more queries
claus
parents: 159
diff changeset
   742
	0 "stc hint"
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   743
    ]
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   744
!
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   745
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   746
waitUntilTerminated
348
claus
parents: 345
diff changeset
   747
    "wait until the receiver is terminated.
claus
parents: 345
diff changeset
   748
     This method allows another process to wait till the receiver finishes."
329
claus
parents: 326
diff changeset
   749
375
claus
parents: 359
diff changeset
   750
    |wasBlocked sema|
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   751
329
claus
parents: 326
diff changeset
   752
    wasBlocked := OperatingSystem blockInterrupts.
375
claus
parents: 359
diff changeset
   753
    sema := Semaphore new.
claus
parents: 359
diff changeset
   754
    self exitAction:[sema signal].
claus
parents: 359
diff changeset
   755
    sema wait.
329
claus
parents: 326
diff changeset
   756
    wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   757
!
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   758
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   759
waitUntilSuspended
348
claus
parents: 345
diff changeset
   760
    "wait until the receiver is suspended."
329
claus
parents: 326
diff changeset
   761
claus
parents: 326
diff changeset
   762
    |wasBlocked|
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   763
329
claus
parents: 326
diff changeset
   764
    wasBlocked := OperatingSystem blockInterrupts.
claus
parents: 326
diff changeset
   765
    suspendSemaphore isNil ifTrue:[suspendSemaphore := Semaphore new].
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   766
    suspendSemaphore wait
329
claus
parents: 326
diff changeset
   767
    wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   768
! !
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   769
    
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   770
!Process methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   771
59
4a86aad06603 *** empty log message ***
claus
parents: 25
diff changeset
   772
printOn:aStream
329
claus
parents: 326
diff changeset
   773
    "a little more info in my printed representation"
claus
parents: 326
diff changeset
   774
85
claus
parents: 69
diff changeset
   775
    aStream nextPutAll:state article;
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   776
	    space;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   777
	    nextPutAll:state;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   778
	    nextPutAll:' Process (';
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   779
	    nextPutAll:self nameOrId;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   780
	    nextPutAll:')'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   781
! !