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