Process.st
author claus
Wed, 15 Feb 1995 11:25:20 +0100
changeset 252 cf6eef7703ad
parent 217 a0400fdbc933
child 302 1f76060d58a4
permissions -rw-r--r--
(none)
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 
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    16
				exitAction exitSemaphore suspendSemaphore 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    17
				singleStepping emergencySignalHandler'
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
    18
	 classVariableNames:'TerminateSignal'
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
252
    27
$Header: /cvs/stx/stx/libbasic/Process.st,v 1.20 1995-02-15 10:24:43 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
"
252
    48
$Header: /cvs/stx/stx/libbasic/Process.st,v 1.20 1995-02-15 10:24:43 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
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
    93
	process(s) 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
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   103
    implement this feature, the machines stack had to be preserved and recreated.
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   104
    Although this is possible theoretically, this has not been implemented, since 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   105
    the machines stack layout is highly machine/compiler dependent,
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   106
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   107
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   108
    Process synchronization:
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   109
	any other process can wait for a process to suspend or terminate. This
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   110
	is implemented by using suspendSemaphore and exitSemaphore, which are 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   111
	signalled when these events occur (see waitUntilSuspended/waitUntilTerminated).
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   112
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   113
    Instance variables:
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   114
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   115
	id                     <SmallInteger>   a unique process-id
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   116
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   117
	prio                   <SmallInteger>   the processes priority
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   118
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   119
	state                  <Symbol>         the processes state
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   120
						(for process-monitor)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   121
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   122
	startBlock             <Block>          the startup-block (the one that forked)
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   123
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   124
	name                   <String-or-nil>  the processes name (if any)
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   125
						(for process-monitor)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   126
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   127
	suspendSemaphore       <Semaphore>      triggered when suspend (if nonNil)
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   128
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   129
	exitSemaphore          <Semaphore>      triggered when terminated (if nonNil)
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   130
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   131
	restartable            <Boolean>        is restartable (not yet implemented)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   132
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   133
	interruptActions       <Collection>     interrupt actions as defined by interruptWith:,
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   134
						performed at interrupt time
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   135
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   136
	exitAction             <Block>          additional cleanup action to perform 
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   137
						on termination (if nonNil)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   138
                                                
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   139
	emergencySignalHandler <Block>          can be used for per-process
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   140
						emergency signal handling
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   141
    Class variables:
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   142
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   143
	TerminateSignal         <Signal>        signal used to terminate processes
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   144
						(should not be cought - or at least
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   145
						 rejected in handlers)
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   146
"
213
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   147
!
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   148
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   149
examples 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   150
"
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   151
    start a background process, computing 1000 factorial 100 times;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   152
    the processes priority is set to not disturb any interactive process.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   153
    Since its prio is higher than the 3D animation demos prio, you will notice,
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   154
    that those are suspended while the computation runs. But Interactive views
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   155
    (like browsers) will continue to react normal.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   156
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   157
    [
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   158
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   159
       100 timesRepeat:[1000 factorial].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   160
       'done with factorial' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   161
    ] forkAt:(Processor userBackgroundPriority).
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
    start a background process, computing 1000 factorial 100 times;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   165
    the processes priority is set to not disturb any process.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   166
    The prio is set to 1 (which is the lowest possible) notice that now,
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   167
    the 3D animation demos also continue to run. 
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
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   171
       100 timesRepeat:[1000 factorial].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   172
       'done with factorial' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   173
    ] forkAt:1.
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
    start a background process, reading a pipe without blocking other
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   177
    processes;
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   178
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   179
    [
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   180
       |p|
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   181
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   182
       'starting' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   183
       p := PipeStream readingFrom:'ls -lR .'.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   184
       [p atEnd] whileFalse:[
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   185
	   p readWait.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   186
	   p nextLine printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   187
       ].
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   188
       p close.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   189
       'done with pipe' printNL.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   190
    ] forkAt:1.
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   191
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   192
    see more examples in doc/coding 
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   193
    (or search in the browser for senders of fork*)
3b56a17534fd *** empty log message ***
claus
parents: 202
diff changeset
   194
"
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
   195
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   197
!Process class methodsFor:'initialization'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   198
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   199
initialize
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   200
    TerminateSignal isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   201
	TerminateSignal := Signal new mayProceed:true.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   202
	TerminateSignal nameClass:self message:#terminateSignal.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   203
	TerminateSignal notifierString:'unhandled process termination'.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   204
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   205
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   206
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   207
!Process class methodsFor:'signal access'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   208
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   209
terminateSignal
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   210
    "return the signal used for process termination"
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   211
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   212
    ^ TerminateSignal
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   213
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   214
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   215
!Process class methodsFor:'instance creation'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   216
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   217
for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   218
    "create a new (unscheduled) process which will execute aBlock at
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   219
     a given priority, once scheduled. The process will start execution once
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   220
     it gets a #resume-message."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   221
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   222
    ^ self new for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   223
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   224
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   225
!Process methodsFor:'private'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   226
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   227
for:aBlock priority:aPrio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   228
    "setup the new process - the receiver is not scheduled for
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   229
     execution, to get it running, send it #resume"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   230
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   231
    |nm|
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   232
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   233
    prio := aPrio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   234
    startBlock := aBlock.
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
    "
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   245
    (nm := Processor activeProcess name) notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   246
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   247
	 avoid name inflation
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   248
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   249
	(nm endsWith:'(sub)') ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   250
	    nm := nm , ' (sub)'
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   251
	].
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   252
	name := nm
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   253
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   254
! !
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   255
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
!Process methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
state
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   259
    "return a symbol describing the processes state"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   260
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
    ^ state
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
state:aSymbol
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   265
    "set the state - only to be used from scheduler"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   266
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
    state := aSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
182
f531860566fc more queries
claus
parents: 159
diff changeset
   270
isDead
f531860566fc more queries
claus
parents: 159
diff changeset
   271
    "return true, if the receiver has already terminated"
f531860566fc more queries
claus
parents: 159
diff changeset
   272
f531860566fc more queries
claus
parents: 159
diff changeset
   273
    ^ state == #dead
f531860566fc more queries
claus
parents: 159
diff changeset
   274
!
f531860566fc more queries
claus
parents: 159
diff changeset
   275
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   276
startBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   277
    "return the processes startup-block"
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   278
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   279
    ^ startBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   282
emergencySignalHandler:aOneArgBlock
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   283
    "set the emergencySignalHandler block.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   284
     See Signal>>documentation for more info."
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   285
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   286
    emergencySignalHandler := aOneArgBlock
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   287
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   288
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   289
emergencySignalHandler
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   290
    "return the emergencySignalHandler block.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   291
     See Signal>>documentation for more info."
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   292
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   293
    ^ emergencySignalHandler
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   294
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   295
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
priority
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
    "return the receivers priority"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
    ^ prio
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
priority:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
    "set my priority"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   305
    Processor changePriority:aNumber for:self.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   306
!
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   307
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   308
changePriority:aNumber
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   309
    "same as priority:, but returns the old priority.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   310
     (cannot do this in priority: for ST-80 compatibility)"
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   311
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   312
    |oldPrio|
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   313
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   314
    oldPrio := prio.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   315
    Processor changePriority:aNumber for:self.
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   316
    ^ oldPrio
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   319
isSingleStepping
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   320
    ^ singleStepping
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   321
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   322
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   323
singleStep:aBoolean
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   324
    singleStepping := aBoolean
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   325
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   326
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
id
10
claus
parents: 5
diff changeset
   328
    "return the processes id"
claus
parents: 5
diff changeset
   329
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
    ^ id
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   333
name
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   334
    "return the processes name"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   335
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   336
    ^ name
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   337
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   338
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   339
name:aString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   340
    "set the processes name"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   341
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   342
    name := aString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   343
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   344
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   345
nameOrId
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   346
    "return a string to identify the process - either name or id"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   347
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   348
    name notNil ifTrue:[^ name].
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   349
    ^ id printString
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   350
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   351
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   352
exitAction
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   353
    "return the processes exit action"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   354
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   355
    ^ exitAction
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   356
!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   357
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   358
exitAction:aBlock
182
f531860566fc more queries
claus
parents: 159
diff changeset
   359
    "set the processes exit action to aBlock.
f531860566fc more queries
claus
parents: 159
diff changeset
   360
     This will be evaluated right before the process dies."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   361
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   362
    exitAction := aBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
a27a279701f8 Initial revision
claus
parents:
diff changeset
   365
suspendedContext
182
f531860566fc more queries
claus
parents: 159
diff changeset
   366
    "return the processes suspended context 
f531860566fc more queries
claus
parents: 159
diff changeset
   367
     - this is the context from which a process switch into the scheduler
f531860566fc more queries
claus
parents: 159
diff changeset
   368
     or another process occured.
f531860566fc more queries
claus
parents: 159
diff changeset
   369
     Typically, only the debugger is interrested in this one."
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   370
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   371
%{  /* NOCONTEXT */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
    extern OBJ __threadContext();
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   373
    OBJ i;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
252
   375
    if (__isSmallInteger(i = _INST(id))) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   376
	RETURN (__threadContext(_intVal(i)));
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   377
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   378
%}.
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   379
    ^ nil
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   380
!
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   381
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   382
maximumStackSize
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   383
    "returns the processes stack limit - i.e. the process will be 
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   384
     interrupted with a recursionSignal-raise, if it ever
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   385
     needs more stack (in bytes) than this number"
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   386
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   387
%{  /* NOCONTEXT */
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   388
    extern int __threadMaxStackSize();
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   389
    OBJ i;
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   390
252
   391
    if (__isSmallInteger(i = _INST(id))) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   392
	RETURN( _MKSMALLINT(__threadMaxStackSize(_intVal(i))) );
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   393
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   394
%}.
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   395
    ^ nil
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   396
!
182
f531860566fc more queries
claus
parents: 159
diff changeset
   397
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   398
setMaximumStackSize:limit
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   399
    "sets the processes stack limit - i.e. the process will be
69
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   400
     interrupted with a recursionSignal-raise, if it ever
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   401
     needs more stack (in bytes) than this number.
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   402
     Returns the old value."
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 __threadSetMaxStackSize();
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   406
    OBJ i;
4564b6328136 *** empty log message ***
claus
parents: 59
diff changeset
   407
252
   408
    if (__isSmallInteger(i = _INST(id)) 
   409
     && __isSmallInteger(limit) ) {
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   410
	RETURN ( _MKSMALLINT(__threadSetMaxStackSize(_intVal(i), _intVal(limit))) );
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   411
    }
182
f531860566fc more queries
claus
parents: 159
diff changeset
   412
%}.
f531860566fc more queries
claus
parents: 159
diff changeset
   413
    ^ nil
f531860566fc more queries
claus
parents: 159
diff changeset
   414
! !
f531860566fc more queries
claus
parents: 159
diff changeset
   415
f531860566fc more queries
claus
parents: 159
diff changeset
   416
!Process methodsFor:'monitoring'!
f531860566fc more queries
claus
parents: 159
diff changeset
   417
f531860566fc more queries
claus
parents: 159
diff changeset
   418
usedStackSize
f531860566fc more queries
claus
parents: 159
diff changeset
   419
    "Return the processes current stack size.
f531860566fc more queries
claus
parents: 159
diff changeset
   420
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   421
f531860566fc more queries
claus
parents: 159
diff changeset
   422
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   423
    extern int __threadUsedStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   424
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   425
252
   426
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   427
	RETURN( _MKSMALLINT(__threadUsedStackSize(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   428
    }
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
totalStackSize
f531860566fc more queries
claus
parents: 159
diff changeset
   434
    "return the processes maximum used stack size.
f531860566fc more queries
claus
parents: 159
diff changeset
   435
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   436
f531860566fc more queries
claus
parents: 159
diff changeset
   437
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   438
    extern int __threadTotalStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   439
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   440
252
   441
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   442
	RETURN( _MKSMALLINT(__threadTotalStackSize(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   443
    }
f531860566fc more queries
claus
parents: 159
diff changeset
   444
%}.
f531860566fc more queries
claus
parents: 159
diff changeset
   445
    ^ nil
f531860566fc more queries
claus
parents: 159
diff changeset
   446
!
f531860566fc more queries
claus
parents: 159
diff changeset
   447
f531860566fc more queries
claus
parents: 159
diff changeset
   448
numberOfStackSegments
f531860566fc more queries
claus
parents: 159
diff changeset
   449
    "return the processes number of stack segments currently used.
f531860566fc more queries
claus
parents: 159
diff changeset
   450
     This method is for monitoring purposes only - it may vanish."
f531860566fc more queries
claus
parents: 159
diff changeset
   451
f531860566fc more queries
claus
parents: 159
diff changeset
   452
%{  /* NOCONTEXT */
f531860566fc more queries
claus
parents: 159
diff changeset
   453
    extern int __threadTotalStackSize();
f531860566fc more queries
claus
parents: 159
diff changeset
   454
    OBJ i;
f531860566fc more queries
claus
parents: 159
diff changeset
   455
252
   456
    if (__isSmallInteger(i = _INST(id))) {
182
f531860566fc more queries
claus
parents: 159
diff changeset
   457
	RETURN( _MKSMALLINT(__threadStackSegments(_intVal(i))) );
f531860566fc more queries
claus
parents: 159
diff changeset
   458
    }
f531860566fc more queries
claus
parents: 159
diff changeset
   459
%}.
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   460
    ^ nil
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   461
! !
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   462
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   463
!Process methodsFor:'private scheduler access'!
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   464
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   465
setPriority:aNumber
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   466
    "set priority without telling processor - not for public use"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   467
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   468
    prio := aNumber
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   469
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   470
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   471
setStartBlock:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   472
    "set the receivers startup block"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   473
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   474
    startBlock := aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   475
!
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   476
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   477
setStateTo:newState if:oldState
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   478
    state == oldState ifTrue:[state := newState]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   479
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   480
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   481
setStateTo:newState if:oldState1 or:oldState2
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   482
    (state == oldState1 or:[state == oldState2]) ifTrue:[state := newState]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   483
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   484
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   485
setId:idNumber state:stateSymbol
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   486
    "set id and state - not for public use"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   487
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   488
    id := idNumber.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   489
    state := stateSymbol.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   490
! !
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   491
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   492
!Process methodsFor:'startup '!
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   493
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   494
start
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   495
    "start the process - this is sent by the VM to the process to get
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   496
     the process up and running.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   497
     Sending start to the process allows more flexible handling
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   498
     of processes, since anything that responds to #start can be handled 
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   499
     by the VM then ..."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   500
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   501
    |block|
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   502
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   503
    (block := startBlock) notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   504
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   505
	 just for your convenience ...
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   506
	"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   507
	name isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   508
	    name := '(' , startBlock displayString , ')'
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   509
	].
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   510
	startBlock := nil.
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   511
	(SignalSet with:TerminateSignal with:AbortSignal)
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   512
	handle:[:ex |
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   513
	    ex return
182
f531860566fc more queries
claus
parents: 159
diff changeset
   514
	] do:block.
202
40ca7cc6fb9c *** empty log message ***
claus
parents: 182
diff changeset
   515
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   516
	(block := exitAction) notNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   517
	    exitAction := nil.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   518
	    block value.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   519
	].
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   520
	suspendSemaphore notNil ifTrue:[suspendSemaphore signal].
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   521
	exitSemaphore notNil ifTrue:[exitSemaphore signal].
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   522
	Processor terminateActiveNoSignal
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   523
    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   524
	"is this artificial restriction useful ?"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   525
	self error:'a process cannot be started twice'
116
58fb8728e1a5 added emergencySignalHandler
claus
parents: 93
diff changeset
   526
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
!Process methodsFor:'suspend / resume'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
suspend
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   532
    "suspend the receiver process - will continue to run when a resume is sent"
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   533
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   534
    suspendSemaphore notNil ifTrue:[suspendSemaphore signal].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
    Processor suspend:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
resume
13
62303f84ff5f *** empty log message ***
claus
parents: 10
diff changeset
   539
    "resume the receiver process"
10
claus
parents: 5
diff changeset
   540
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
    Processor resume:self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   544
resumeForSingleSend
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   545
    "resume the receiver process, but only let it execute a single send."
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   546
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   547
    Processor resumeForSingleSend:self
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   548
!
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   549
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
terminate
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   551
    "terminate the receiver process. All unwind actions and the exit-action (if any)
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   552
     will be performed before the process is really terminated."
10
claus
parents: 5
diff changeset
   553
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   554
    Processor activeProcess == self ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   555
	Signal noHandlerSignal handle:[:ex |
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   556
	    ex return.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   557
	] do:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   558
	    TerminateSignal raise.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   559
	].
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   560
	suspendSemaphore notNil ifTrue:[suspendSemaphore signal].
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   561
	exitSemaphore notNil ifTrue:[exitSemaphore signal].
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   562
	Processor terminateNoSignal:self
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   563
    ] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   564
	self interruptWith:[self terminate]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   565
    ]
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   566
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   567
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   568
terminateNoSignal
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   569
    "terminate the receiver process without performing any unwind- or exit-actions"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   570
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   571
    suspendSemaphore notNil ifTrue:[suspendSemaphore signal].
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   572
    exitSemaphore notNil ifTrue:[exitSemaphore signal].
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   573
    Processor terminateNoSignal:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   576
!Process methodsFor:'interrupts'!
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   577
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   578
interruptWith:aBlock
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   579
    "interrupt the receiver and make it evaluate aBlock.
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   580
     If the receiver is currently suspended, the block will be remembered
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   581
     to be evaluated once the receiver wakes up."
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   582
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   583
    self uninterruptablyDo:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   584
	interruptActions isNil ifTrue:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   585
	    interruptActions := OrderedCollection with:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   586
	] ifFalse:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   587
	    interruptActions addLast:aBlock.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   588
	].
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   589
    ].
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   590
    Processor scheduleForInterrupt:self.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   591
!
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   592
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   593
interrupt
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   594
    "evaluate my interrupt-actions
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   595
     the process will go back to where it got interrupted
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   596
     after doing this.
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   597
    "
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   598
    |action|
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   599
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   600
    [interruptActions notNil and:[interruptActions notEmpty]] whileTrue:[
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   601
	action := interruptActions removeFirst.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   602
	action value
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   603
    ].
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   604
    interruptActions := nil
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   605
! !
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   606
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   607
!Process methodsFor:'special'!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   608
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   609
withPriority:aPrio do:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   610
    "execute aBlock at another priority. This can be used to perform
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   611
     time-consuming operations at a more user-friendly priority,
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   612
     or some critical action at a higher priority. Do not use too high
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   613
     of a priority to avoid locking up the system (event processing takes place
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   614
     at 24)"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   615
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   616
    |oldprio|
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   617
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   618
    oldprio := prio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   619
    self priority:aPrio.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   620
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   621
    ^ aBlock valueNowOrOnUnwindDo:[
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   622
	self priority:oldprio
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   623
    ]
182
f531860566fc more queries
claus
parents: 159
diff changeset
   624
f531860566fc more queries
claus
parents: 159
diff changeset
   625
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   626
     Processor activeProcess withPriority:7 do:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   627
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   628
    "be careful - even ^C wont work until done:
f531860566fc more queries
claus
parents: 159
diff changeset
   629
     Processor activeProcess withPriority:25 do:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   630
    "
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   631
!
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   632
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   633
withLowerPriorityDo:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   634
    "execute aBlock at a lower priority. This can be used to perform
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   635
     time-consuming operations at a more user-friendly priority."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   636
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   637
    ^ self withPriority:(prio - 1) do:aBlock
182
f531860566fc more queries
claus
parents: 159
diff changeset
   638
f531860566fc more queries
claus
parents: 159
diff changeset
   639
    "
f531860566fc more queries
claus
parents: 159
diff changeset
   640
     Processor activeProcess withLowerPriorityDo:[3000 factorial]
f531860566fc more queries
claus
parents: 159
diff changeset
   641
    "
159
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
uninterruptablyDo:aBlock
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   645
    "execute aBlock with interrupts blocked. This does not prevent
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   646
     preemption by higher priority processes."
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   647
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   648
    |wasBlocked|
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   649
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   650
    "we must keep track of blocking-state if this is called nested"
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   651
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   652
    wasBlocked := OperatingSystem blockInterrupts.
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   653
    ^ aBlock valueNowOrOnUnwindDo:[
182
f531860566fc more queries
claus
parents: 159
diff changeset
   654
	wasBlocked ifFalse:[OperatingSystem unblockInterrupts].
f531860566fc more queries
claus
parents: 159
diff changeset
   655
	0 "stc hint"
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   656
    ]
217
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   657
!
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   658
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   659
waitUntilTerminated
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   660
    "set the softSuspend flag of the receiver and wait until it
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   661
     suspends. The receviers process must execute checkForSoftSuspend
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   662
     periodically for this rendevous to work."
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   663
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   664
    exitSemaphore := Semaphore new.
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   665
    exitSemaphore wait
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   666
!
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   667
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   668
waitUntilSuspended
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   669
    "set the softSuspend flag of the receiver and wait until it
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   670
     suspends. The receviers process must execute checkForSoftSuspend
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   671
     periodically for this rendevous to work."
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   672
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   673
    suspendSemaphore := Semaphore new.
a0400fdbc933 *** empty log message ***
claus
parents: 213
diff changeset
   674
    suspendSemaphore wait
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   675
! !
24
20cfbafcd0a3 *** empty log message ***
claus
parents: 13
diff changeset
   676
    
93
e31220cb391f *** empty log message ***
claus
parents: 88
diff changeset
   677
!Process methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   678
59
4a86aad06603 *** empty log message ***
claus
parents: 25
diff changeset
   679
printOn:aStream
85
claus
parents: 69
diff changeset
   680
    aStream nextPutAll:state article;
159
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   681
	    space;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   682
	    nextPutAll:state;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   683
	    nextPutAll:' Process (';
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   684
	    nextPutAll:self nameOrId;
514c749165c3 *** empty log message ***
claus
parents: 116
diff changeset
   685
	    nextPutAll:')'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   686
! !